@semiont/frontend 0.4.7 → 0.4.11

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (267) hide show
  1. package/dist/assets/AuthContext-CYne_gJM.js +2 -0
  2. package/dist/assets/AuthContext-CYne_gJM.js.map +1 -0
  3. package/dist/assets/{CookiePreferences-L69Zja-8.js → CookiePreferences-DxD0u90z.js} +2 -2
  4. package/dist/assets/{CookiePreferences-L69Zja-8.js.map → CookiePreferences-DxD0u90z.js.map} +1 -1
  5. package/dist/assets/KnowledgeBaseContext-CgnF8K-_.js +2 -0
  6. package/dist/assets/KnowledgeBaseContext-CgnF8K-_.js.map +1 -0
  7. package/dist/assets/PdfAnnotationCanvas.client-CW6SKH2U-CVmEpRfP.js +2 -0
  8. package/dist/assets/PdfAnnotationCanvas.client-CW6SKH2U-CVmEpRfP.js.map +1 -0
  9. package/dist/assets/PlusIcon-qGFPUzg0.js +2 -0
  10. package/dist/assets/PlusIcon-qGFPUzg0.js.map +1 -0
  11. package/dist/assets/StreamStatusContext-BuPATpTz.js +2 -0
  12. package/dist/assets/StreamStatusContext-BuPATpTz.js.map +1 -0
  13. package/dist/assets/ToolbarPanels-tcvPzqNN.js +2 -0
  14. package/dist/assets/ToolbarPanels-tcvPzqNN.js.map +1 -0
  15. package/dist/assets/ar-R4CRNXEF-Ca4TvZQX.js +2 -0
  16. package/dist/assets/ar-R4CRNXEF-Ca4TvZQX.js.map +1 -0
  17. package/dist/assets/bn-CZKGRHTA-BYgoliLL.js +2 -0
  18. package/dist/assets/bn-CZKGRHTA-BYgoliLL.js.map +1 -0
  19. package/dist/assets/client-87q-RlKa.js +2 -0
  20. package/dist/assets/{client-Cxt1NUWp.js.map → client-87q-RlKa.js.map} +1 -1
  21. package/dist/assets/client-BZBaSaZ0.js +2 -0
  22. package/dist/assets/{client-D1NYe5bc.js.map → client-BZBaSaZ0.js.map} +1 -1
  23. package/dist/assets/client-CKEJUXXb.js +2 -0
  24. package/dist/assets/{client-CmvSjN3K.js.map → client-CKEJUXXb.js.map} +1 -1
  25. package/dist/assets/client-DWcJNpII.js +2 -0
  26. package/dist/assets/{client-D5mudL5R.js.map → client-DWcJNpII.js.map} +1 -1
  27. package/dist/assets/cs-4WIB2IHH-C7kYZeeH.js +2 -0
  28. package/dist/assets/cs-4WIB2IHH-C7kYZeeH.js.map +1 -0
  29. package/dist/assets/da-JWYEUYPX-ZaU3NHTl.js +2 -0
  30. package/dist/assets/da-JWYEUYPX-ZaU3NHTl.js.map +1 -0
  31. package/dist/assets/de-GWUQZGER-DsO9vSRx.js +2 -0
  32. package/dist/assets/de-GWUQZGER-DsO9vSRx.js.map +1 -0
  33. package/dist/assets/el-DM2GT7P5-Baqj4u37.js +2 -0
  34. package/dist/assets/el-DM2GT7P5-Baqj4u37.js.map +1 -0
  35. package/dist/assets/en-IUV4ZXKH-BjYNERUx.js +135 -0
  36. package/dist/assets/en-IUV4ZXKH-BjYNERUx.js.map +1 -0
  37. package/dist/assets/es-6LVQIM3D-iPWrspyh.js +2 -0
  38. package/dist/assets/es-6LVQIM3D-iPWrspyh.js.map +1 -0
  39. package/dist/assets/fa-IRUJY3QI-D7jhkhZq.js +2 -0
  40. package/dist/assets/fa-IRUJY3QI-D7jhkhZq.js.map +1 -0
  41. package/dist/assets/fi-53FBOEVT-DyL1QG5i.js +2 -0
  42. package/dist/assets/fi-53FBOEVT-DyL1QG5i.js.map +1 -0
  43. package/dist/assets/fr-Q5KY7QL6-CGM9feO_.js +2 -0
  44. package/dist/assets/fr-Q5KY7QL6-CGM9feO_.js.map +1 -0
  45. package/dist/assets/he-HJNKULBY-CiS3ww0i.js +2 -0
  46. package/dist/assets/he-HJNKULBY-CiS3ww0i.js.map +1 -0
  47. package/dist/assets/hi-UYZ4X6CR-Cb3OYOtm.js +2 -0
  48. package/dist/assets/hi-UYZ4X6CR-Cb3OYOtm.js.map +1 -0
  49. package/dist/assets/id-UAQMH6U2-CgqnTJaj.js +2 -0
  50. package/dist/assets/id-UAQMH6U2-CgqnTJaj.js.map +1 -0
  51. package/dist/assets/{index-IyxbPWuo.js → index-D4SjcYxX.js} +3 -3
  52. package/dist/assets/index-D4SjcYxX.js.map +1 -0
  53. package/dist/assets/index-x79a-Q1-.css +1 -0
  54. package/dist/assets/it-C7QEBNFA-BP64tE9N.js +2 -0
  55. package/dist/assets/it-C7QEBNFA-BP64tE9N.js.map +1 -0
  56. package/dist/assets/ja-THS6AOSJ-BlrsrgpZ.js +2 -0
  57. package/dist/assets/ja-THS6AOSJ-BlrsrgpZ.js.map +1 -0
  58. package/dist/assets/ko-XKK3TWQG-BnscEkav.js +2 -0
  59. package/dist/assets/ko-XKK3TWQG-BnscEkav.js.map +1 -0
  60. package/dist/assets/layout-B-TMNLm1.js +6 -0
  61. package/dist/assets/layout-B-TMNLm1.js.map +1 -0
  62. package/dist/assets/layout-C4uWiY4F.js +2 -0
  63. package/dist/assets/layout-C4uWiY4F.js.map +1 -0
  64. package/dist/assets/layout-D9y4fNSa.js +2 -0
  65. package/dist/assets/layout-D9y4fNSa.js.map +1 -0
  66. package/dist/assets/layout-DYXeBZ7E.js +2 -0
  67. package/dist/assets/{layout-5_En-vLB.js.map → layout-DYXeBZ7E.js.map} +1 -1
  68. package/dist/assets/ms-GSK7LIF7-BWJ-3eXy.js +2 -0
  69. package/dist/assets/ms-GSK7LIF7-BWJ-3eXy.js.map +1 -0
  70. package/dist/assets/nl-KUBWITGY-DeqIcEFQ.js +2 -0
  71. package/dist/assets/nl-KUBWITGY-DeqIcEFQ.js.map +1 -0
  72. package/dist/assets/no-ECWZUHT6-DMgg097w.js +2 -0
  73. package/dist/assets/no-ECWZUHT6-DMgg097w.js.map +1 -0
  74. package/dist/assets/{not-found-BjlzlRT_.js → not-found-D39eX95i.js} +2 -2
  75. package/dist/assets/{not-found-BjlzlRT_.js.map → not-found-D39eX95i.js.map} +1 -1
  76. package/dist/assets/page-B68iiwby.js +2 -0
  77. package/dist/assets/page-B68iiwby.js.map +1 -0
  78. package/dist/assets/{page-B8hAUDzt.js → page-B8rInMTj.js} +2 -2
  79. package/dist/assets/{page-B8hAUDzt.js.map → page-B8rInMTj.js.map} +1 -1
  80. package/dist/assets/page-BBEm8LmA.js +2 -0
  81. package/dist/assets/{page-4vdCvEL0.js.map → page-BBEm8LmA.js.map} +1 -1
  82. package/dist/assets/{page-D77AjrZW.js → page-BjjPEFxE.js} +2 -2
  83. package/dist/assets/{page-D77AjrZW.js.map → page-BjjPEFxE.js.map} +1 -1
  84. package/dist/assets/page-Bs0m7wcI.js +2 -0
  85. package/dist/assets/page-Bs0m7wcI.js.map +1 -0
  86. package/dist/assets/page-C2ievByA.js +2 -0
  87. package/dist/assets/{page-n2Dj9C-v.js.map → page-C2ievByA.js.map} +1 -1
  88. package/dist/assets/{page-D7qEC0QY.js → page-CEDbSdpB.js} +2 -2
  89. package/dist/assets/{page-D7qEC0QY.js.map → page-CEDbSdpB.js.map} +1 -1
  90. package/dist/assets/{page-DwQP9ZTM.js → page-CnBwmYIE.js} +2 -2
  91. package/dist/assets/{page-DwQP9ZTM.js.map → page-CnBwmYIE.js.map} +1 -1
  92. package/dist/assets/page-D9kiPafj.js +2 -0
  93. package/dist/assets/{page-VpcpXQSK.js.map → page-D9kiPafj.js.map} +1 -1
  94. package/dist/assets/page-DU4gR5Xo.js +2 -0
  95. package/dist/assets/page-DU4gR5Xo.js.map +1 -0
  96. package/dist/assets/page-DVuwkaR0.js +2 -0
  97. package/dist/assets/{page-6Y-lDxnu.js.map → page-DVuwkaR0.js.map} +1 -1
  98. package/dist/assets/page-DX3FJ71G.js +2 -0
  99. package/dist/assets/page-DX3FJ71G.js.map +1 -0
  100. package/dist/assets/{page-kZNdnhdh.js → page-DfClTFD9.js} +2 -2
  101. package/dist/assets/{page-kZNdnhdh.js.map → page-DfClTFD9.js.map} +1 -1
  102. package/dist/assets/{page-CPxgvPSe.js → page-KDTjODvy.js} +2 -2
  103. package/dist/assets/{page-CPxgvPSe.js.map → page-KDTjODvy.js.map} +1 -1
  104. package/dist/assets/{page-bnSUmwNQ.js → page-eebHZHg3.js} +2 -2
  105. package/dist/assets/page-eebHZHg3.js.map +1 -0
  106. package/dist/assets/page-fN3EjI48.js +2 -0
  107. package/dist/assets/{page-Bb2aSxYZ.js.map → page-fN3EjI48.js.map} +1 -1
  108. package/dist/assets/page-kM0Ep9uD.js +2 -0
  109. package/dist/assets/{page-CkeyIRf4.js.map → page-kM0Ep9uD.js.map} +1 -1
  110. package/dist/assets/page-m23deNER.js +2 -0
  111. package/dist/assets/{page-CG2brhZf.js.map → page-m23deNER.js.map} +1 -1
  112. package/dist/assets/pl-PLVWSZWS-B9TKLToJ.js +2 -0
  113. package/dist/assets/pl-PLVWSZWS-B9TKLToJ.js.map +1 -0
  114. package/dist/assets/{privacy-D5H-YTl9.js → privacy-QEJYcmMw.js} +2 -2
  115. package/dist/assets/{privacy-D5H-YTl9.js.map → privacy-QEJYcmMw.js.map} +1 -1
  116. package/dist/assets/pt-AL74ZTKB-dm40issX.js +2 -0
  117. package/dist/assets/pt-AL74ZTKB-dm40issX.js.map +1 -0
  118. package/dist/assets/ro-WTPHLHGS-42q4gQmg.js +2 -0
  119. package/dist/assets/ro-WTPHLHGS-42q4gQmg.js.map +1 -0
  120. package/dist/assets/routing-BgsGBuSe.js +2 -0
  121. package/dist/assets/routing-BgsGBuSe.js.map +1 -0
  122. package/dist/assets/{routing-tt0MahYa.js → routing-nZgBtxly.js} +2 -2
  123. package/dist/assets/routing-nZgBtxly.js.map +1 -0
  124. package/dist/assets/sv-QCLI7SG4-KVnre_zY.js +2 -0
  125. package/dist/assets/sv-QCLI7SG4-KVnre_zY.js.map +1 -0
  126. package/dist/assets/th-WCKVZU6U-CfRhC_Eg.js +2 -0
  127. package/dist/assets/th-WCKVZU6U-CfRhC_Eg.js.map +1 -0
  128. package/dist/assets/tr-2CAFS2XS-425EzbTD.js +2 -0
  129. package/dist/assets/tr-2CAFS2XS-425EzbTD.js.map +1 -0
  130. package/dist/assets/uk-TDE4JLCY-BUQpzvxx.js +2 -0
  131. package/dist/assets/uk-TDE4JLCY-BUQpzvxx.js.map +1 -0
  132. package/dist/assets/useAuth-CqtZE9nt.js +2 -0
  133. package/dist/assets/useAuth-CqtZE9nt.js.map +1 -0
  134. package/dist/assets/vi-KKXZ4PCX-BqlhZbBi.js +2 -0
  135. package/dist/assets/vi-KKXZ4PCX-BqlhZbBi.js.map +1 -0
  136. package/dist/assets/zh-VH4XN5PV-TNQ5FOx-.js +2 -0
  137. package/dist/assets/zh-VH4XN5PV-TNQ5FOx-.js.map +1 -0
  138. package/dist/index.html +2 -2
  139. package/dist/messages/ar.json +7 -1
  140. package/dist/messages/bn.json +7 -1
  141. package/dist/messages/cs.json +7 -1
  142. package/dist/messages/da.json +7 -1
  143. package/dist/messages/de.json +7 -1
  144. package/dist/messages/el.json +7 -1
  145. package/dist/messages/en.json +7 -1
  146. package/dist/messages/es.json +7 -1
  147. package/dist/messages/fa.json +7 -1
  148. package/dist/messages/fi.json +7 -1
  149. package/dist/messages/fr.json +7 -1
  150. package/dist/messages/he.json +7 -1
  151. package/dist/messages/hi.json +7 -1
  152. package/dist/messages/id.json +7 -1
  153. package/dist/messages/it.json +7 -1
  154. package/dist/messages/ja.json +7 -1
  155. package/dist/messages/ko.json +7 -1
  156. package/dist/messages/ms.json +7 -1
  157. package/dist/messages/nl.json +7 -1
  158. package/dist/messages/no.json +7 -1
  159. package/dist/messages/pl.json +7 -1
  160. package/dist/messages/pt.json +7 -1
  161. package/dist/messages/ro.json +7 -1
  162. package/dist/messages/sv.json +7 -1
  163. package/dist/messages/th.json +7 -1
  164. package/dist/messages/tr.json +7 -1
  165. package/dist/messages/uk.json +7 -1
  166. package/dist/messages/vi.json +7 -1
  167. package/dist/messages/zh.json +7 -1
  168. package/package.json +1 -1
  169. package/server.js +2 -17
  170. package/dist/assets/AuthContext-xM132UqD.js +0 -2
  171. package/dist/assets/AuthContext-xM132UqD.js.map +0 -1
  172. package/dist/assets/PdfAnnotationCanvas.client-LF6DDTCV-DjnFutDo.js +0 -2
  173. package/dist/assets/PdfAnnotationCanvas.client-LF6DDTCV-DjnFutDo.js.map +0 -1
  174. package/dist/assets/ToolbarPanels-Dq0eXjjR.js +0 -2
  175. package/dist/assets/ToolbarPanels-Dq0eXjjR.js.map +0 -1
  176. package/dist/assets/ar-3URRW77J-BgHZZOLD.js +0 -2
  177. package/dist/assets/ar-3URRW77J-BgHZZOLD.js.map +0 -1
  178. package/dist/assets/bn-DCQD3XZ5-a8MFRoWf.js +0 -2
  179. package/dist/assets/bn-DCQD3XZ5-a8MFRoWf.js.map +0 -1
  180. package/dist/assets/client-CmvSjN3K.js +0 -2
  181. package/dist/assets/client-Cxt1NUWp.js +0 -2
  182. package/dist/assets/client-D1NYe5bc.js +0 -2
  183. package/dist/assets/client-D5mudL5R.js +0 -2
  184. package/dist/assets/cs-23KOZUFE-BKDMuHSJ.js +0 -2
  185. package/dist/assets/cs-23KOZUFE-BKDMuHSJ.js.map +0 -1
  186. package/dist/assets/da-OIQ66A42-PSD9x0p6.js +0 -2
  187. package/dist/assets/da-OIQ66A42-PSD9x0p6.js.map +0 -1
  188. package/dist/assets/de-FCCLKE2X-D-mIACTN.js +0 -2
  189. package/dist/assets/de-FCCLKE2X-D-mIACTN.js.map +0 -1
  190. package/dist/assets/el-3ADITCGI-R9uL01ba.js +0 -2
  191. package/dist/assets/el-3ADITCGI-R9uL01ba.js.map +0 -1
  192. package/dist/assets/en-LNW2A3RA-CQBvSBCl.js +0 -136
  193. package/dist/assets/en-LNW2A3RA-CQBvSBCl.js.map +0 -1
  194. package/dist/assets/es-POQEEYIW-GYtOr1-U.js +0 -2
  195. package/dist/assets/es-POQEEYIW-GYtOr1-U.js.map +0 -1
  196. package/dist/assets/fa-RQPXVELG-CYYoB8V3.js +0 -2
  197. package/dist/assets/fa-RQPXVELG-CYYoB8V3.js.map +0 -1
  198. package/dist/assets/fi-UXOVOUGT-CCtELQFh.js +0 -2
  199. package/dist/assets/fi-UXOVOUGT-CCtELQFh.js.map +0 -1
  200. package/dist/assets/fr-6W2T3R7G-BHzGzKtv.js +0 -2
  201. package/dist/assets/fr-6W2T3R7G-BHzGzKtv.js.map +0 -1
  202. package/dist/assets/he-65UHPZIU-Be0-u6De.js +0 -2
  203. package/dist/assets/he-65UHPZIU-Be0-u6De.js.map +0 -1
  204. package/dist/assets/hi-SGJIVPTN-DzNg8bSF.js +0 -2
  205. package/dist/assets/hi-SGJIVPTN-DzNg8bSF.js.map +0 -1
  206. package/dist/assets/id-EYJJQCS2-CNqoDHx8.js +0 -2
  207. package/dist/assets/id-EYJJQCS2-CNqoDHx8.js.map +0 -1
  208. package/dist/assets/index-CZe1KZuP.css +0 -1
  209. package/dist/assets/index-IyxbPWuo.js.map +0 -1
  210. package/dist/assets/it-IZGQEDO7-Fnj60r5j.js +0 -2
  211. package/dist/assets/it-IZGQEDO7-Fnj60r5j.js.map +0 -1
  212. package/dist/assets/ja-SR272JSY-CJI0KETh.js +0 -2
  213. package/dist/assets/ja-SR272JSY-CJI0KETh.js.map +0 -1
  214. package/dist/assets/ko-YWTXVVXE-C01Ur29L.js +0 -2
  215. package/dist/assets/ko-YWTXVVXE-C01Ur29L.js.map +0 -1
  216. package/dist/assets/layout-5_En-vLB.js +0 -2
  217. package/dist/assets/layout-DF8lLIQx.js +0 -2
  218. package/dist/assets/layout-DF8lLIQx.js.map +0 -1
  219. package/dist/assets/layout-DYaEHeqB.js +0 -2
  220. package/dist/assets/layout-DYaEHeqB.js.map +0 -1
  221. package/dist/assets/layout-QdxLp1Jq.js +0 -6
  222. package/dist/assets/layout-QdxLp1Jq.js.map +0 -1
  223. package/dist/assets/ms-3K2XSJGM-Cy5ruqOy.js +0 -2
  224. package/dist/assets/ms-3K2XSJGM-Cy5ruqOy.js.map +0 -1
  225. package/dist/assets/nl-YIGP4SLE-Bd4rMBpn.js +0 -2
  226. package/dist/assets/nl-YIGP4SLE-Bd4rMBpn.js.map +0 -1
  227. package/dist/assets/no-IFYIL3ND-BuY6j8M1.js +0 -2
  228. package/dist/assets/no-IFYIL3ND-BuY6j8M1.js.map +0 -1
  229. package/dist/assets/page-4vdCvEL0.js +0 -2
  230. package/dist/assets/page-6Y-lDxnu.js +0 -2
  231. package/dist/assets/page-BUPqapmo.js +0 -2
  232. package/dist/assets/page-BUPqapmo.js.map +0 -1
  233. package/dist/assets/page-Bb2aSxYZ.js +0 -2
  234. package/dist/assets/page-CG2brhZf.js +0 -2
  235. package/dist/assets/page-CTn7lGDa.js +0 -2
  236. package/dist/assets/page-CTn7lGDa.js.map +0 -1
  237. package/dist/assets/page-CkeyIRf4.js +0 -2
  238. package/dist/assets/page-DA0znMx6.js +0 -2
  239. package/dist/assets/page-DA0znMx6.js.map +0 -1
  240. package/dist/assets/page-MyIklHT7.js +0 -2
  241. package/dist/assets/page-MyIklHT7.js.map +0 -1
  242. package/dist/assets/page-VpcpXQSK.js +0 -2
  243. package/dist/assets/page-bnSUmwNQ.js.map +0 -1
  244. package/dist/assets/page-n2Dj9C-v.js +0 -2
  245. package/dist/assets/pl-6MWSASJR-JUc86Y3e.js +0 -2
  246. package/dist/assets/pl-6MWSASJR-JUc86Y3e.js.map +0 -1
  247. package/dist/assets/pt-NZNN6WUN-BoRJoxUF.js +0 -2
  248. package/dist/assets/pt-NZNN6WUN-BoRJoxUF.js.map +0 -1
  249. package/dist/assets/ro-NF3SMUJS-BolW-qxZ.js +0 -2
  250. package/dist/assets/ro-NF3SMUJS-BolW-qxZ.js.map +0 -1
  251. package/dist/assets/routing-CBiIPmyX.js +0 -2
  252. package/dist/assets/routing-CBiIPmyX.js.map +0 -1
  253. package/dist/assets/routing-tt0MahYa.js.map +0 -1
  254. package/dist/assets/sv-ZHM7GSTD-BJQebEes.js +0 -2
  255. package/dist/assets/sv-ZHM7GSTD-BJQebEes.js.map +0 -1
  256. package/dist/assets/th-LX4NO5BJ-PLcdn3k3.js +0 -2
  257. package/dist/assets/th-LX4NO5BJ-PLcdn3k3.js.map +0 -1
  258. package/dist/assets/tr-DZ4GDSRR-B9p6aQNC.js +0 -2
  259. package/dist/assets/tr-DZ4GDSRR-B9p6aQNC.js.map +0 -1
  260. package/dist/assets/uk-KC5KVVBY-CyfCqBoA.js +0 -2
  261. package/dist/assets/uk-KC5KVVBY-CyfCqBoA.js.map +0 -1
  262. package/dist/assets/useAuth-Bw_w8L0H.js +0 -2
  263. package/dist/assets/useAuth-Bw_w8L0H.js.map +0 -1
  264. package/dist/assets/vi-KNCR3OXZ-CWlV3YWY.js +0 -2
  265. package/dist/assets/vi-KNCR3OXZ-CWlV3YWY.js.map +0 -1
  266. package/dist/assets/zh-M2HV2A27-Pnzhdw9W.js +0 -2
  267. package/dist/assets/zh-M2HV2A27-Pnzhdw9W.js.map +0 -1
@@ -1 +0,0 @@
1
- {"version":3,"file":"layout-DYaEHeqB.js","sources":["../../../../node_modules/@heroicons/react/24/outline/esm/PlusIcon.js","../../src/components/knowledge/KnowledgeNavigation.tsx","../../src/components/knowledge/KnowledgeSidebarWrapper.tsx","../../../../node_modules/@dnd-kit/core/dist/core.esm.js","../../../../node_modules/@dnd-kit/sortable/dist/sortable.esm.js","../../src/hooks/useOpenResourcesManager.ts","../../src/hooks/useCacheManager.ts","../../src/app/[locale]/know/layout.tsx"],"sourcesContent":["import * as React from \"react\";\nfunction PlusIcon({\n title,\n titleId,\n ...props\n}, svgRef) {\n return /*#__PURE__*/React.createElement(\"svg\", Object.assign({\n xmlns: \"http://www.w3.org/2000/svg\",\n fill: \"none\",\n viewBox: \"0 0 24 24\",\n strokeWidth: 1.5,\n stroke: \"currentColor\",\n \"aria-hidden\": \"true\",\n \"data-slot\": \"icon\",\n ref: svgRef,\n \"aria-labelledby\": titleId\n }, props), title ? /*#__PURE__*/React.createElement(\"title\", {\n id: titleId\n }, title) : null, /*#__PURE__*/React.createElement(\"path\", {\n strokeLinecap: \"round\",\n strokeLinejoin: \"round\",\n d: \"M12 4.5v15m7.5-7.5h-15\"\n }));\n}\nconst ForwardRef = /*#__PURE__*/ React.forwardRef(PlusIcon);\nexport default ForwardRef;","import React, { useCallback } from 'react';\nimport { useTranslation } from 'react-i18next';\nimport { Link } from '@/i18n/routing';\nimport { usePathname, useRouter } from '@/i18n/routing';\nimport { PlusIcon, ChevronLeftIcon, Bars3Icon, XMarkIcon } from '@heroicons/react/24/outline';\nimport {\n useOpenResources,\n useEventSubscriptions,\n CollapsibleResourceNavigation,\n type NavigationItem,\n type OpenResource\n} from '@semiont/react-ui';\n\n// Custom telescope icon component\nconst TelescopeIcon = ({ className }: { className?: string }) => (\n <span className={className} style={{ fontSize: '1.25rem', lineHeight: '1' }}>🔭</span>\n);\n\ninterface KnowledgeNavigationProps {\n isCollapsed: boolean;\n toggleCollapsed: () => void;\n navigationMenu?: (onClose: () => void) => React.ReactNode;\n}\n\n// Adapter: CollapsibleResourceNavigation passes href, but our Link uses `to`\nfunction HrefLink({ href, to: _to, ...props }: React.ComponentProps<typeof Link> & { href?: string }) {\n return <Link to={(href ?? '') as string} {...props} />;\n}\n\nexport function KnowledgeNavigation({ isCollapsed, toggleCollapsed, navigationMenu }: KnowledgeNavigationProps) {\n const { t: _t } = useTranslation();\n const t = (k: string, p?: Record<string, unknown>) => _t(`Sidebar.${k}`, p as any) as string;\n const pathname = usePathname();\n const router = useRouter();\n const { openResources, removeResource, reorderResources } = useOpenResources();\n\n const fixedNavigation: NavigationItem[] = [\n {\n name: t('discover'),\n href: '/know/discover',\n icon: TelescopeIcon,\n description: t('searchAndBrowse')\n },\n {\n name: t('compose'),\n href: '/know/compose',\n icon: PlusIcon,\n description: t('composeNewResource')\n }\n ];\n\n // Handle sidebar toggle events\n const handleSidebarToggle = useCallback(() => {\n toggleCollapsed();\n }, [toggleCollapsed]);\n\n // Handle resource close events\n const handleResourceClose = useCallback(({ resourceId }: { resourceId: string }) => {\n removeResource(resourceId);\n\n // If we're closing the currently viewed document, navigate to Discover\n if (pathname === `/know/resource/${resourceId}`) {\n router.push('/know/discover');\n }\n }, [removeResource, pathname, router]);\n\n // Handle resource reorder events\n const handleResourceReorder = useCallback(({ oldIndex, newIndex }: { oldIndex: number; newIndex: number }) => {\n reorderResources(oldIndex, newIndex);\n }, [reorderResources]);\n\n // Subscribe to navigation events\n useEventSubscriptions({\n 'browse:sidebar-toggle': handleSidebarToggle,\n 'browse:resource-close': handleResourceClose,\n 'browse:resource-reorder': handleResourceReorder,\n });\n\n // Handle navigation\n const handleNavigate = (path: string) => {\n router.push(path);\n };\n\n // Build resource href\n const getResourceHref = (resourceId: string) => {\n return `/know/resource/${resourceId}`;\n };\n\n return (\n <CollapsibleResourceNavigation\n fixedItems={fixedNavigation}\n resources={openResources as OpenResource[]}\n isCollapsed={isCollapsed}\n currentPath={pathname}\n LinkComponent={HrefLink as any}\n onNavigate={handleNavigate}\n getResourceHref={getResourceHref}\n className=\"knowledge-navigation\"\n translations={{\n title: t('title')\n }}\n icons={{\n chevronLeft: ChevronLeftIcon,\n bars: Bars3Icon,\n close: XMarkIcon\n }}\n navigationMenu={navigationMenu}\n />\n );\n}","import React from 'react';\nimport { useTranslation } from 'react-i18next';\nimport { LeftSidebar } from '@semiont/react-ui';\nimport { KnowledgeNavigation } from './KnowledgeNavigation';\nimport { Link, routes } from '@/lib/routing';\nimport { useAuth } from '@/hooks/useAuth';\n\nexport function KnowledgeSidebarWrapper() {\n const { t: _t } = useTranslation();\n const t = (k: string, p?: Record<string, unknown>) => _t(`Navigation.${k}`, p as any) as string;\n const { t: _tHome } = useTranslation();\n const tHome = (k: string, p?: Record<string, unknown>) => _tHome(`Home.${k}`, p as any) as string;\n const { isAuthenticated, isAdmin, isModerator } = useAuth();\n\n return (\n <LeftSidebar\n Link={Link}\n routes={routes}\n t={t}\n tHome={tHome}\n brandingLink=\"/\"\n collapsible={true}\n storageKey=\"knowledgeNavCollapsed\"\n isAuthenticated={isAuthenticated}\n isAdmin={isAdmin}\n isModerator={isModerator}\n >\n {(isCollapsed, toggleCollapsed, navigationMenu) => (\n <KnowledgeNavigation\n isCollapsed={isCollapsed}\n toggleCollapsed={toggleCollapsed}\n navigationMenu={navigationMenu}\n />\n )}\n </LeftSidebar>\n );\n}\n","import React, { createContext, useContext, useEffect, useState, useCallback, useMemo, useRef, memo, useReducer, cloneElement, forwardRef } from 'react';\nimport { createPortal, unstable_batchedUpdates } from 'react-dom';\nimport { useUniqueId, getEventCoordinates, getWindow, isDocument, isHTMLElement, isSVGElement, canUseDOM, isWindow, isNode, getOwnerDocument, add, isKeyboardEvent, subtract, useLazyMemo, useInterval, usePrevious, useLatestValue, useEvent, useIsomorphicLayoutEffect, useNodeRef, findFirstFocusableNode, CSS } from '@dnd-kit/utilities';\nimport { useAnnouncement, HiddenText, LiveRegion } from '@dnd-kit/accessibility';\n\nconst DndMonitorContext = /*#__PURE__*/createContext(null);\n\nfunction useDndMonitor(listener) {\n const registerListener = useContext(DndMonitorContext);\n useEffect(() => {\n if (!registerListener) {\n throw new Error('useDndMonitor must be used within a children of <DndContext>');\n }\n\n const unsubscribe = registerListener(listener);\n return unsubscribe;\n }, [listener, registerListener]);\n}\n\nfunction useDndMonitorProvider() {\n const [listeners] = useState(() => new Set());\n const registerListener = useCallback(listener => {\n listeners.add(listener);\n return () => listeners.delete(listener);\n }, [listeners]);\n const dispatch = useCallback(_ref => {\n let {\n type,\n event\n } = _ref;\n listeners.forEach(listener => {\n var _listener$type;\n\n return (_listener$type = listener[type]) == null ? void 0 : _listener$type.call(listener, event);\n });\n }, [listeners]);\n return [dispatch, registerListener];\n}\n\nconst defaultScreenReaderInstructions = {\n draggable: \"\\n To pick up a draggable item, press the space bar.\\n While dragging, use the arrow keys to move the item.\\n Press space again to drop the item in its new position, or press escape to cancel.\\n \"\n};\nconst defaultAnnouncements = {\n onDragStart(_ref) {\n let {\n active\n } = _ref;\n return \"Picked up draggable item \" + active.id + \".\";\n },\n\n onDragOver(_ref2) {\n let {\n active,\n over\n } = _ref2;\n\n if (over) {\n return \"Draggable item \" + active.id + \" was moved over droppable area \" + over.id + \".\";\n }\n\n return \"Draggable item \" + active.id + \" is no longer over a droppable area.\";\n },\n\n onDragEnd(_ref3) {\n let {\n active,\n over\n } = _ref3;\n\n if (over) {\n return \"Draggable item \" + active.id + \" was dropped over droppable area \" + over.id;\n }\n\n return \"Draggable item \" + active.id + \" was dropped.\";\n },\n\n onDragCancel(_ref4) {\n let {\n active\n } = _ref4;\n return \"Dragging was cancelled. Draggable item \" + active.id + \" was dropped.\";\n }\n\n};\n\nfunction Accessibility(_ref) {\n let {\n announcements = defaultAnnouncements,\n container,\n hiddenTextDescribedById,\n screenReaderInstructions = defaultScreenReaderInstructions\n } = _ref;\n const {\n announce,\n announcement\n } = useAnnouncement();\n const liveRegionId = useUniqueId(\"DndLiveRegion\");\n const [mounted, setMounted] = useState(false);\n useEffect(() => {\n setMounted(true);\n }, []);\n useDndMonitor(useMemo(() => ({\n onDragStart(_ref2) {\n let {\n active\n } = _ref2;\n announce(announcements.onDragStart({\n active\n }));\n },\n\n onDragMove(_ref3) {\n let {\n active,\n over\n } = _ref3;\n\n if (announcements.onDragMove) {\n announce(announcements.onDragMove({\n active,\n over\n }));\n }\n },\n\n onDragOver(_ref4) {\n let {\n active,\n over\n } = _ref4;\n announce(announcements.onDragOver({\n active,\n over\n }));\n },\n\n onDragEnd(_ref5) {\n let {\n active,\n over\n } = _ref5;\n announce(announcements.onDragEnd({\n active,\n over\n }));\n },\n\n onDragCancel(_ref6) {\n let {\n active,\n over\n } = _ref6;\n announce(announcements.onDragCancel({\n active,\n over\n }));\n }\n\n }), [announce, announcements]));\n\n if (!mounted) {\n return null;\n }\n\n const markup = React.createElement(React.Fragment, null, React.createElement(HiddenText, {\n id: hiddenTextDescribedById,\n value: screenReaderInstructions.draggable\n }), React.createElement(LiveRegion, {\n id: liveRegionId,\n announcement: announcement\n }));\n return container ? createPortal(markup, container) : markup;\n}\n\nvar Action;\n\n(function (Action) {\n Action[\"DragStart\"] = \"dragStart\";\n Action[\"DragMove\"] = \"dragMove\";\n Action[\"DragEnd\"] = \"dragEnd\";\n Action[\"DragCancel\"] = \"dragCancel\";\n Action[\"DragOver\"] = \"dragOver\";\n Action[\"RegisterDroppable\"] = \"registerDroppable\";\n Action[\"SetDroppableDisabled\"] = \"setDroppableDisabled\";\n Action[\"UnregisterDroppable\"] = \"unregisterDroppable\";\n})(Action || (Action = {}));\n\nfunction noop() {}\n\nfunction useSensor(sensor, options) {\n return useMemo(() => ({\n sensor,\n options: options != null ? options : {}\n }), // eslint-disable-next-line react-hooks/exhaustive-deps\n [sensor, options]);\n}\n\nfunction useSensors() {\n for (var _len = arguments.length, sensors = new Array(_len), _key = 0; _key < _len; _key++) {\n sensors[_key] = arguments[_key];\n }\n\n return useMemo(() => [...sensors].filter(sensor => sensor != null), // eslint-disable-next-line react-hooks/exhaustive-deps\n [...sensors]);\n}\n\nconst defaultCoordinates = /*#__PURE__*/Object.freeze({\n x: 0,\n y: 0\n});\n\n/**\r\n * Returns the distance between two points\r\n */\nfunction distanceBetween(p1, p2) {\n return Math.sqrt(Math.pow(p1.x - p2.x, 2) + Math.pow(p1.y - p2.y, 2));\n}\n\nfunction getRelativeTransformOrigin(event, rect) {\n const eventCoordinates = getEventCoordinates(event);\n\n if (!eventCoordinates) {\n return '0 0';\n }\n\n const transformOrigin = {\n x: (eventCoordinates.x - rect.left) / rect.width * 100,\n y: (eventCoordinates.y - rect.top) / rect.height * 100\n };\n return transformOrigin.x + \"% \" + transformOrigin.y + \"%\";\n}\n\n/**\r\n * Sort collisions from smallest to greatest value\r\n */\nfunction sortCollisionsAsc(_ref, _ref2) {\n let {\n data: {\n value: a\n }\n } = _ref;\n let {\n data: {\n value: b\n }\n } = _ref2;\n return a - b;\n}\n/**\r\n * Sort collisions from greatest to smallest value\r\n */\n\nfunction sortCollisionsDesc(_ref3, _ref4) {\n let {\n data: {\n value: a\n }\n } = _ref3;\n let {\n data: {\n value: b\n }\n } = _ref4;\n return b - a;\n}\n/**\r\n * Returns the coordinates of the corners of a given rectangle:\r\n * [TopLeft {x, y}, TopRight {x, y}, BottomLeft {x, y}, BottomRight {x, y}]\r\n */\n\nfunction cornersOfRectangle(_ref5) {\n let {\n left,\n top,\n height,\n width\n } = _ref5;\n return [{\n x: left,\n y: top\n }, {\n x: left + width,\n y: top\n }, {\n x: left,\n y: top + height\n }, {\n x: left + width,\n y: top + height\n }];\n}\nfunction getFirstCollision(collisions, property) {\n if (!collisions || collisions.length === 0) {\n return null;\n }\n\n const [firstCollision] = collisions;\n return property ? firstCollision[property] : firstCollision;\n}\n\n/**\r\n * Returns the coordinates of the center of a given ClientRect\r\n */\n\nfunction centerOfRectangle(rect, left, top) {\n if (left === void 0) {\n left = rect.left;\n }\n\n if (top === void 0) {\n top = rect.top;\n }\n\n return {\n x: left + rect.width * 0.5,\n y: top + rect.height * 0.5\n };\n}\n/**\r\n * Returns the closest rectangles from an array of rectangles to the center of a given\r\n * rectangle.\r\n */\n\n\nconst closestCenter = _ref => {\n let {\n collisionRect,\n droppableRects,\n droppableContainers\n } = _ref;\n const centerRect = centerOfRectangle(collisionRect, collisionRect.left, collisionRect.top);\n const collisions = [];\n\n for (const droppableContainer of droppableContainers) {\n const {\n id\n } = droppableContainer;\n const rect = droppableRects.get(id);\n\n if (rect) {\n const distBetween = distanceBetween(centerOfRectangle(rect), centerRect);\n collisions.push({\n id,\n data: {\n droppableContainer,\n value: distBetween\n }\n });\n }\n }\n\n return collisions.sort(sortCollisionsAsc);\n};\n\n/**\r\n * Returns the closest rectangles from an array of rectangles to the corners of\r\n * another rectangle.\r\n */\n\nconst closestCorners = _ref => {\n let {\n collisionRect,\n droppableRects,\n droppableContainers\n } = _ref;\n const corners = cornersOfRectangle(collisionRect);\n const collisions = [];\n\n for (const droppableContainer of droppableContainers) {\n const {\n id\n } = droppableContainer;\n const rect = droppableRects.get(id);\n\n if (rect) {\n const rectCorners = cornersOfRectangle(rect);\n const distances = corners.reduce((accumulator, corner, index) => {\n return accumulator + distanceBetween(rectCorners[index], corner);\n }, 0);\n const effectiveDistance = Number((distances / 4).toFixed(4));\n collisions.push({\n id,\n data: {\n droppableContainer,\n value: effectiveDistance\n }\n });\n }\n }\n\n return collisions.sort(sortCollisionsAsc);\n};\n\n/**\r\n * Returns the intersecting rectangle area between two rectangles\r\n */\n\nfunction getIntersectionRatio(entry, target) {\n const top = Math.max(target.top, entry.top);\n const left = Math.max(target.left, entry.left);\n const right = Math.min(target.left + target.width, entry.left + entry.width);\n const bottom = Math.min(target.top + target.height, entry.top + entry.height);\n const width = right - left;\n const height = bottom - top;\n\n if (left < right && top < bottom) {\n const targetArea = target.width * target.height;\n const entryArea = entry.width * entry.height;\n const intersectionArea = width * height;\n const intersectionRatio = intersectionArea / (targetArea + entryArea - intersectionArea);\n return Number(intersectionRatio.toFixed(4));\n } // Rectangles do not overlap, or overlap has an area of zero (edge/corner overlap)\n\n\n return 0;\n}\n/**\r\n * Returns the rectangles that has the greatest intersection area with a given\r\n * rectangle in an array of rectangles.\r\n */\n\nconst rectIntersection = _ref => {\n let {\n collisionRect,\n droppableRects,\n droppableContainers\n } = _ref;\n const collisions = [];\n\n for (const droppableContainer of droppableContainers) {\n const {\n id\n } = droppableContainer;\n const rect = droppableRects.get(id);\n\n if (rect) {\n const intersectionRatio = getIntersectionRatio(rect, collisionRect);\n\n if (intersectionRatio > 0) {\n collisions.push({\n id,\n data: {\n droppableContainer,\n value: intersectionRatio\n }\n });\n }\n }\n }\n\n return collisions.sort(sortCollisionsDesc);\n};\n\n/**\r\n * Check if a given point is contained within a bounding rectangle\r\n */\n\nfunction isPointWithinRect(point, rect) {\n const {\n top,\n left,\n bottom,\n right\n } = rect;\n return top <= point.y && point.y <= bottom && left <= point.x && point.x <= right;\n}\n/**\r\n * Returns the rectangles that the pointer is hovering over\r\n */\n\n\nconst pointerWithin = _ref => {\n let {\n droppableContainers,\n droppableRects,\n pointerCoordinates\n } = _ref;\n\n if (!pointerCoordinates) {\n return [];\n }\n\n const collisions = [];\n\n for (const droppableContainer of droppableContainers) {\n const {\n id\n } = droppableContainer;\n const rect = droppableRects.get(id);\n\n if (rect && isPointWithinRect(pointerCoordinates, rect)) {\n /* There may be more than a single rectangle intersecting\r\n * with the pointer coordinates. In order to sort the\r\n * colliding rectangles, we measure the distance between\r\n * the pointer and the corners of the intersecting rectangle\r\n */\n const corners = cornersOfRectangle(rect);\n const distances = corners.reduce((accumulator, corner) => {\n return accumulator + distanceBetween(pointerCoordinates, corner);\n }, 0);\n const effectiveDistance = Number((distances / 4).toFixed(4));\n collisions.push({\n id,\n data: {\n droppableContainer,\n value: effectiveDistance\n }\n });\n }\n }\n\n return collisions.sort(sortCollisionsAsc);\n};\n\nfunction adjustScale(transform, rect1, rect2) {\n return { ...transform,\n scaleX: rect1 && rect2 ? rect1.width / rect2.width : 1,\n scaleY: rect1 && rect2 ? rect1.height / rect2.height : 1\n };\n}\n\nfunction getRectDelta(rect1, rect2) {\n return rect1 && rect2 ? {\n x: rect1.left - rect2.left,\n y: rect1.top - rect2.top\n } : defaultCoordinates;\n}\n\nfunction createRectAdjustmentFn(modifier) {\n return function adjustClientRect(rect) {\n for (var _len = arguments.length, adjustments = new Array(_len > 1 ? _len - 1 : 0), _key = 1; _key < _len; _key++) {\n adjustments[_key - 1] = arguments[_key];\n }\n\n return adjustments.reduce((acc, adjustment) => ({ ...acc,\n top: acc.top + modifier * adjustment.y,\n bottom: acc.bottom + modifier * adjustment.y,\n left: acc.left + modifier * adjustment.x,\n right: acc.right + modifier * adjustment.x\n }), { ...rect\n });\n };\n}\nconst getAdjustedRect = /*#__PURE__*/createRectAdjustmentFn(1);\n\nfunction parseTransform(transform) {\n if (transform.startsWith('matrix3d(')) {\n const transformArray = transform.slice(9, -1).split(/, /);\n return {\n x: +transformArray[12],\n y: +transformArray[13],\n scaleX: +transformArray[0],\n scaleY: +transformArray[5]\n };\n } else if (transform.startsWith('matrix(')) {\n const transformArray = transform.slice(7, -1).split(/, /);\n return {\n x: +transformArray[4],\n y: +transformArray[5],\n scaleX: +transformArray[0],\n scaleY: +transformArray[3]\n };\n }\n\n return null;\n}\n\nfunction inverseTransform(rect, transform, transformOrigin) {\n const parsedTransform = parseTransform(transform);\n\n if (!parsedTransform) {\n return rect;\n }\n\n const {\n scaleX,\n scaleY,\n x: translateX,\n y: translateY\n } = parsedTransform;\n const x = rect.left - translateX - (1 - scaleX) * parseFloat(transformOrigin);\n const y = rect.top - translateY - (1 - scaleY) * parseFloat(transformOrigin.slice(transformOrigin.indexOf(' ') + 1));\n const w = scaleX ? rect.width / scaleX : rect.width;\n const h = scaleY ? rect.height / scaleY : rect.height;\n return {\n width: w,\n height: h,\n top: y,\n right: x + w,\n bottom: y + h,\n left: x\n };\n}\n\nconst defaultOptions = {\n ignoreTransform: false\n};\n/**\r\n * Returns the bounding client rect of an element relative to the viewport.\r\n */\n\nfunction getClientRect(element, options) {\n if (options === void 0) {\n options = defaultOptions;\n }\n\n let rect = element.getBoundingClientRect();\n\n if (options.ignoreTransform) {\n const {\n transform,\n transformOrigin\n } = getWindow(element).getComputedStyle(element);\n\n if (transform) {\n rect = inverseTransform(rect, transform, transformOrigin);\n }\n }\n\n const {\n top,\n left,\n width,\n height,\n bottom,\n right\n } = rect;\n return {\n top,\n left,\n width,\n height,\n bottom,\n right\n };\n}\n/**\r\n * Returns the bounding client rect of an element relative to the viewport.\r\n *\r\n * @remarks\r\n * The ClientRect returned by this method does not take into account transforms\r\n * applied to the element it measures.\r\n *\r\n */\n\nfunction getTransformAgnosticClientRect(element) {\n return getClientRect(element, {\n ignoreTransform: true\n });\n}\n\nfunction getWindowClientRect(element) {\n const width = element.innerWidth;\n const height = element.innerHeight;\n return {\n top: 0,\n left: 0,\n right: width,\n bottom: height,\n width,\n height\n };\n}\n\nfunction isFixed(node, computedStyle) {\n if (computedStyle === void 0) {\n computedStyle = getWindow(node).getComputedStyle(node);\n }\n\n return computedStyle.position === 'fixed';\n}\n\nfunction isScrollable(element, computedStyle) {\n if (computedStyle === void 0) {\n computedStyle = getWindow(element).getComputedStyle(element);\n }\n\n const overflowRegex = /(auto|scroll|overlay)/;\n const properties = ['overflow', 'overflowX', 'overflowY'];\n return properties.some(property => {\n const value = computedStyle[property];\n return typeof value === 'string' ? overflowRegex.test(value) : false;\n });\n}\n\nfunction getScrollableAncestors(element, limit) {\n const scrollParents = [];\n\n function findScrollableAncestors(node) {\n if (limit != null && scrollParents.length >= limit) {\n return scrollParents;\n }\n\n if (!node) {\n return scrollParents;\n }\n\n if (isDocument(node) && node.scrollingElement != null && !scrollParents.includes(node.scrollingElement)) {\n scrollParents.push(node.scrollingElement);\n return scrollParents;\n }\n\n if (!isHTMLElement(node) || isSVGElement(node)) {\n return scrollParents;\n }\n\n if (scrollParents.includes(node)) {\n return scrollParents;\n }\n\n const computedStyle = getWindow(element).getComputedStyle(node);\n\n if (node !== element) {\n if (isScrollable(node, computedStyle)) {\n scrollParents.push(node);\n }\n }\n\n if (isFixed(node, computedStyle)) {\n return scrollParents;\n }\n\n return findScrollableAncestors(node.parentNode);\n }\n\n if (!element) {\n return scrollParents;\n }\n\n return findScrollableAncestors(element);\n}\nfunction getFirstScrollableAncestor(node) {\n const [firstScrollableAncestor] = getScrollableAncestors(node, 1);\n return firstScrollableAncestor != null ? firstScrollableAncestor : null;\n}\n\nfunction getScrollableElement(element) {\n if (!canUseDOM || !element) {\n return null;\n }\n\n if (isWindow(element)) {\n return element;\n }\n\n if (!isNode(element)) {\n return null;\n }\n\n if (isDocument(element) || element === getOwnerDocument(element).scrollingElement) {\n return window;\n }\n\n if (isHTMLElement(element)) {\n return element;\n }\n\n return null;\n}\n\nfunction getScrollXCoordinate(element) {\n if (isWindow(element)) {\n return element.scrollX;\n }\n\n return element.scrollLeft;\n}\nfunction getScrollYCoordinate(element) {\n if (isWindow(element)) {\n return element.scrollY;\n }\n\n return element.scrollTop;\n}\nfunction getScrollCoordinates(element) {\n return {\n x: getScrollXCoordinate(element),\n y: getScrollYCoordinate(element)\n };\n}\n\nvar Direction;\n\n(function (Direction) {\n Direction[Direction[\"Forward\"] = 1] = \"Forward\";\n Direction[Direction[\"Backward\"] = -1] = \"Backward\";\n})(Direction || (Direction = {}));\n\nfunction isDocumentScrollingElement(element) {\n if (!canUseDOM || !element) {\n return false;\n }\n\n return element === document.scrollingElement;\n}\n\nfunction getScrollPosition(scrollingContainer) {\n const minScroll = {\n x: 0,\n y: 0\n };\n const dimensions = isDocumentScrollingElement(scrollingContainer) ? {\n height: window.innerHeight,\n width: window.innerWidth\n } : {\n height: scrollingContainer.clientHeight,\n width: scrollingContainer.clientWidth\n };\n const maxScroll = {\n x: scrollingContainer.scrollWidth - dimensions.width,\n y: scrollingContainer.scrollHeight - dimensions.height\n };\n const isTop = scrollingContainer.scrollTop <= minScroll.y;\n const isLeft = scrollingContainer.scrollLeft <= minScroll.x;\n const isBottom = scrollingContainer.scrollTop >= maxScroll.y;\n const isRight = scrollingContainer.scrollLeft >= maxScroll.x;\n return {\n isTop,\n isLeft,\n isBottom,\n isRight,\n maxScroll,\n minScroll\n };\n}\n\nconst defaultThreshold = {\n x: 0.2,\n y: 0.2\n};\nfunction getScrollDirectionAndSpeed(scrollContainer, scrollContainerRect, _ref, acceleration, thresholdPercentage) {\n let {\n top,\n left,\n right,\n bottom\n } = _ref;\n\n if (acceleration === void 0) {\n acceleration = 10;\n }\n\n if (thresholdPercentage === void 0) {\n thresholdPercentage = defaultThreshold;\n }\n\n const {\n isTop,\n isBottom,\n isLeft,\n isRight\n } = getScrollPosition(scrollContainer);\n const direction = {\n x: 0,\n y: 0\n };\n const speed = {\n x: 0,\n y: 0\n };\n const threshold = {\n height: scrollContainerRect.height * thresholdPercentage.y,\n width: scrollContainerRect.width * thresholdPercentage.x\n };\n\n if (!isTop && top <= scrollContainerRect.top + threshold.height) {\n // Scroll Up\n direction.y = Direction.Backward;\n speed.y = acceleration * Math.abs((scrollContainerRect.top + threshold.height - top) / threshold.height);\n } else if (!isBottom && bottom >= scrollContainerRect.bottom - threshold.height) {\n // Scroll Down\n direction.y = Direction.Forward;\n speed.y = acceleration * Math.abs((scrollContainerRect.bottom - threshold.height - bottom) / threshold.height);\n }\n\n if (!isRight && right >= scrollContainerRect.right - threshold.width) {\n // Scroll Right\n direction.x = Direction.Forward;\n speed.x = acceleration * Math.abs((scrollContainerRect.right - threshold.width - right) / threshold.width);\n } else if (!isLeft && left <= scrollContainerRect.left + threshold.width) {\n // Scroll Left\n direction.x = Direction.Backward;\n speed.x = acceleration * Math.abs((scrollContainerRect.left + threshold.width - left) / threshold.width);\n }\n\n return {\n direction,\n speed\n };\n}\n\nfunction getScrollElementRect(element) {\n if (element === document.scrollingElement) {\n const {\n innerWidth,\n innerHeight\n } = window;\n return {\n top: 0,\n left: 0,\n right: innerWidth,\n bottom: innerHeight,\n width: innerWidth,\n height: innerHeight\n };\n }\n\n const {\n top,\n left,\n right,\n bottom\n } = element.getBoundingClientRect();\n return {\n top,\n left,\n right,\n bottom,\n width: element.clientWidth,\n height: element.clientHeight\n };\n}\n\nfunction getScrollOffsets(scrollableAncestors) {\n return scrollableAncestors.reduce((acc, node) => {\n return add(acc, getScrollCoordinates(node));\n }, defaultCoordinates);\n}\nfunction getScrollXOffset(scrollableAncestors) {\n return scrollableAncestors.reduce((acc, node) => {\n return acc + getScrollXCoordinate(node);\n }, 0);\n}\nfunction getScrollYOffset(scrollableAncestors) {\n return scrollableAncestors.reduce((acc, node) => {\n return acc + getScrollYCoordinate(node);\n }, 0);\n}\n\nfunction scrollIntoViewIfNeeded(element, measure) {\n if (measure === void 0) {\n measure = getClientRect;\n }\n\n if (!element) {\n return;\n }\n\n const {\n top,\n left,\n bottom,\n right\n } = measure(element);\n const firstScrollableAncestor = getFirstScrollableAncestor(element);\n\n if (!firstScrollableAncestor) {\n return;\n }\n\n if (bottom <= 0 || right <= 0 || top >= window.innerHeight || left >= window.innerWidth) {\n element.scrollIntoView({\n block: 'center',\n inline: 'center'\n });\n }\n}\n\nconst properties = [['x', ['left', 'right'], getScrollXOffset], ['y', ['top', 'bottom'], getScrollYOffset]];\nclass Rect {\n constructor(rect, element) {\n this.rect = void 0;\n this.width = void 0;\n this.height = void 0;\n this.top = void 0;\n this.bottom = void 0;\n this.right = void 0;\n this.left = void 0;\n const scrollableAncestors = getScrollableAncestors(element);\n const scrollOffsets = getScrollOffsets(scrollableAncestors);\n this.rect = { ...rect\n };\n this.width = rect.width;\n this.height = rect.height;\n\n for (const [axis, keys, getScrollOffset] of properties) {\n for (const key of keys) {\n Object.defineProperty(this, key, {\n get: () => {\n const currentOffsets = getScrollOffset(scrollableAncestors);\n const scrollOffsetsDeltla = scrollOffsets[axis] - currentOffsets;\n return this.rect[key] + scrollOffsetsDeltla;\n },\n enumerable: true\n });\n }\n }\n\n Object.defineProperty(this, 'rect', {\n enumerable: false\n });\n }\n\n}\n\nclass Listeners {\n constructor(target) {\n this.target = void 0;\n this.listeners = [];\n\n this.removeAll = () => {\n this.listeners.forEach(listener => {\n var _this$target;\n\n return (_this$target = this.target) == null ? void 0 : _this$target.removeEventListener(...listener);\n });\n };\n\n this.target = target;\n }\n\n add(eventName, handler, options) {\n var _this$target2;\n\n (_this$target2 = this.target) == null ? void 0 : _this$target2.addEventListener(eventName, handler, options);\n this.listeners.push([eventName, handler, options]);\n }\n\n}\n\nfunction getEventListenerTarget(target) {\n // If the `event.target` element is removed from the document events will still be targeted\n // at it, and hence won't always bubble up to the window or document anymore.\n // If there is any risk of an element being removed while it is being dragged,\n // the best practice is to attach the event listeners directly to the target.\n // https://developer.mozilla.org/en-US/docs/Web/API/EventTarget\n const {\n EventTarget\n } = getWindow(target);\n return target instanceof EventTarget ? target : getOwnerDocument(target);\n}\n\nfunction hasExceededDistance(delta, measurement) {\n const dx = Math.abs(delta.x);\n const dy = Math.abs(delta.y);\n\n if (typeof measurement === 'number') {\n return Math.sqrt(dx ** 2 + dy ** 2) > measurement;\n }\n\n if ('x' in measurement && 'y' in measurement) {\n return dx > measurement.x && dy > measurement.y;\n }\n\n if ('x' in measurement) {\n return dx > measurement.x;\n }\n\n if ('y' in measurement) {\n return dy > measurement.y;\n }\n\n return false;\n}\n\nvar EventName;\n\n(function (EventName) {\n EventName[\"Click\"] = \"click\";\n EventName[\"DragStart\"] = \"dragstart\";\n EventName[\"Keydown\"] = \"keydown\";\n EventName[\"ContextMenu\"] = \"contextmenu\";\n EventName[\"Resize\"] = \"resize\";\n EventName[\"SelectionChange\"] = \"selectionchange\";\n EventName[\"VisibilityChange\"] = \"visibilitychange\";\n})(EventName || (EventName = {}));\n\nfunction preventDefault(event) {\n event.preventDefault();\n}\nfunction stopPropagation(event) {\n event.stopPropagation();\n}\n\nvar KeyboardCode;\n\n(function (KeyboardCode) {\n KeyboardCode[\"Space\"] = \"Space\";\n KeyboardCode[\"Down\"] = \"ArrowDown\";\n KeyboardCode[\"Right\"] = \"ArrowRight\";\n KeyboardCode[\"Left\"] = \"ArrowLeft\";\n KeyboardCode[\"Up\"] = \"ArrowUp\";\n KeyboardCode[\"Esc\"] = \"Escape\";\n KeyboardCode[\"Enter\"] = \"Enter\";\n KeyboardCode[\"Tab\"] = \"Tab\";\n})(KeyboardCode || (KeyboardCode = {}));\n\nconst defaultKeyboardCodes = {\n start: [KeyboardCode.Space, KeyboardCode.Enter],\n cancel: [KeyboardCode.Esc],\n end: [KeyboardCode.Space, KeyboardCode.Enter, KeyboardCode.Tab]\n};\nconst defaultKeyboardCoordinateGetter = (event, _ref) => {\n let {\n currentCoordinates\n } = _ref;\n\n switch (event.code) {\n case KeyboardCode.Right:\n return { ...currentCoordinates,\n x: currentCoordinates.x + 25\n };\n\n case KeyboardCode.Left:\n return { ...currentCoordinates,\n x: currentCoordinates.x - 25\n };\n\n case KeyboardCode.Down:\n return { ...currentCoordinates,\n y: currentCoordinates.y + 25\n };\n\n case KeyboardCode.Up:\n return { ...currentCoordinates,\n y: currentCoordinates.y - 25\n };\n }\n\n return undefined;\n};\n\nclass KeyboardSensor {\n constructor(props) {\n this.props = void 0;\n this.autoScrollEnabled = false;\n this.referenceCoordinates = void 0;\n this.listeners = void 0;\n this.windowListeners = void 0;\n this.props = props;\n const {\n event: {\n target\n }\n } = props;\n this.props = props;\n this.listeners = new Listeners(getOwnerDocument(target));\n this.windowListeners = new Listeners(getWindow(target));\n this.handleKeyDown = this.handleKeyDown.bind(this);\n this.handleCancel = this.handleCancel.bind(this);\n this.attach();\n }\n\n attach() {\n this.handleStart();\n this.windowListeners.add(EventName.Resize, this.handleCancel);\n this.windowListeners.add(EventName.VisibilityChange, this.handleCancel);\n setTimeout(() => this.listeners.add(EventName.Keydown, this.handleKeyDown));\n }\n\n handleStart() {\n const {\n activeNode,\n onStart\n } = this.props;\n const node = activeNode.node.current;\n\n if (node) {\n scrollIntoViewIfNeeded(node);\n }\n\n onStart(defaultCoordinates);\n }\n\n handleKeyDown(event) {\n if (isKeyboardEvent(event)) {\n const {\n active,\n context,\n options\n } = this.props;\n const {\n keyboardCodes = defaultKeyboardCodes,\n coordinateGetter = defaultKeyboardCoordinateGetter,\n scrollBehavior = 'smooth'\n } = options;\n const {\n code\n } = event;\n\n if (keyboardCodes.end.includes(code)) {\n this.handleEnd(event);\n return;\n }\n\n if (keyboardCodes.cancel.includes(code)) {\n this.handleCancel(event);\n return;\n }\n\n const {\n collisionRect\n } = context.current;\n const currentCoordinates = collisionRect ? {\n x: collisionRect.left,\n y: collisionRect.top\n } : defaultCoordinates;\n\n if (!this.referenceCoordinates) {\n this.referenceCoordinates = currentCoordinates;\n }\n\n const newCoordinates = coordinateGetter(event, {\n active,\n context: context.current,\n currentCoordinates\n });\n\n if (newCoordinates) {\n const coordinatesDelta = subtract(newCoordinates, currentCoordinates);\n const scrollDelta = {\n x: 0,\n y: 0\n };\n const {\n scrollableAncestors\n } = context.current;\n\n for (const scrollContainer of scrollableAncestors) {\n const direction = event.code;\n const {\n isTop,\n isRight,\n isLeft,\n isBottom,\n maxScroll,\n minScroll\n } = getScrollPosition(scrollContainer);\n const scrollElementRect = getScrollElementRect(scrollContainer);\n const clampedCoordinates = {\n x: Math.min(direction === KeyboardCode.Right ? scrollElementRect.right - scrollElementRect.width / 2 : scrollElementRect.right, Math.max(direction === KeyboardCode.Right ? scrollElementRect.left : scrollElementRect.left + scrollElementRect.width / 2, newCoordinates.x)),\n y: Math.min(direction === KeyboardCode.Down ? scrollElementRect.bottom - scrollElementRect.height / 2 : scrollElementRect.bottom, Math.max(direction === KeyboardCode.Down ? scrollElementRect.top : scrollElementRect.top + scrollElementRect.height / 2, newCoordinates.y))\n };\n const canScrollX = direction === KeyboardCode.Right && !isRight || direction === KeyboardCode.Left && !isLeft;\n const canScrollY = direction === KeyboardCode.Down && !isBottom || direction === KeyboardCode.Up && !isTop;\n\n if (canScrollX && clampedCoordinates.x !== newCoordinates.x) {\n const newScrollCoordinates = scrollContainer.scrollLeft + coordinatesDelta.x;\n const canScrollToNewCoordinates = direction === KeyboardCode.Right && newScrollCoordinates <= maxScroll.x || direction === KeyboardCode.Left && newScrollCoordinates >= minScroll.x;\n\n if (canScrollToNewCoordinates && !coordinatesDelta.y) {\n // We don't need to update coordinates, the scroll adjustment alone will trigger\n // logic to auto-detect the new container we are over\n scrollContainer.scrollTo({\n left: newScrollCoordinates,\n behavior: scrollBehavior\n });\n return;\n }\n\n if (canScrollToNewCoordinates) {\n scrollDelta.x = scrollContainer.scrollLeft - newScrollCoordinates;\n } else {\n scrollDelta.x = direction === KeyboardCode.Right ? scrollContainer.scrollLeft - maxScroll.x : scrollContainer.scrollLeft - minScroll.x;\n }\n\n if (scrollDelta.x) {\n scrollContainer.scrollBy({\n left: -scrollDelta.x,\n behavior: scrollBehavior\n });\n }\n\n break;\n } else if (canScrollY && clampedCoordinates.y !== newCoordinates.y) {\n const newScrollCoordinates = scrollContainer.scrollTop + coordinatesDelta.y;\n const canScrollToNewCoordinates = direction === KeyboardCode.Down && newScrollCoordinates <= maxScroll.y || direction === KeyboardCode.Up && newScrollCoordinates >= minScroll.y;\n\n if (canScrollToNewCoordinates && !coordinatesDelta.x) {\n // We don't need to update coordinates, the scroll adjustment alone will trigger\n // logic to auto-detect the new container we are over\n scrollContainer.scrollTo({\n top: newScrollCoordinates,\n behavior: scrollBehavior\n });\n return;\n }\n\n if (canScrollToNewCoordinates) {\n scrollDelta.y = scrollContainer.scrollTop - newScrollCoordinates;\n } else {\n scrollDelta.y = direction === KeyboardCode.Down ? scrollContainer.scrollTop - maxScroll.y : scrollContainer.scrollTop - minScroll.y;\n }\n\n if (scrollDelta.y) {\n scrollContainer.scrollBy({\n top: -scrollDelta.y,\n behavior: scrollBehavior\n });\n }\n\n break;\n }\n }\n\n this.handleMove(event, add(subtract(newCoordinates, this.referenceCoordinates), scrollDelta));\n }\n }\n }\n\n handleMove(event, coordinates) {\n const {\n onMove\n } = this.props;\n event.preventDefault();\n onMove(coordinates);\n }\n\n handleEnd(event) {\n const {\n onEnd\n } = this.props;\n event.preventDefault();\n this.detach();\n onEnd();\n }\n\n handleCancel(event) {\n const {\n onCancel\n } = this.props;\n event.preventDefault();\n this.detach();\n onCancel();\n }\n\n detach() {\n this.listeners.removeAll();\n this.windowListeners.removeAll();\n }\n\n}\nKeyboardSensor.activators = [{\n eventName: 'onKeyDown',\n handler: (event, _ref, _ref2) => {\n let {\n keyboardCodes = defaultKeyboardCodes,\n onActivation\n } = _ref;\n let {\n active\n } = _ref2;\n const {\n code\n } = event.nativeEvent;\n\n if (keyboardCodes.start.includes(code)) {\n const activator = active.activatorNode.current;\n\n if (activator && event.target !== activator) {\n return false;\n }\n\n event.preventDefault();\n onActivation == null ? void 0 : onActivation({\n event: event.nativeEvent\n });\n return true;\n }\n\n return false;\n }\n}];\n\nfunction isDistanceConstraint(constraint) {\n return Boolean(constraint && 'distance' in constraint);\n}\n\nfunction isDelayConstraint(constraint) {\n return Boolean(constraint && 'delay' in constraint);\n}\n\nclass AbstractPointerSensor {\n constructor(props, events, listenerTarget) {\n var _getEventCoordinates;\n\n if (listenerTarget === void 0) {\n listenerTarget = getEventListenerTarget(props.event.target);\n }\n\n this.props = void 0;\n this.events = void 0;\n this.autoScrollEnabled = true;\n this.document = void 0;\n this.activated = false;\n this.initialCoordinates = void 0;\n this.timeoutId = null;\n this.listeners = void 0;\n this.documentListeners = void 0;\n this.windowListeners = void 0;\n this.props = props;\n this.events = events;\n const {\n event\n } = props;\n const {\n target\n } = event;\n this.props = props;\n this.events = events;\n this.document = getOwnerDocument(target);\n this.documentListeners = new Listeners(this.document);\n this.listeners = new Listeners(listenerTarget);\n this.windowListeners = new Listeners(getWindow(target));\n this.initialCoordinates = (_getEventCoordinates = getEventCoordinates(event)) != null ? _getEventCoordinates : defaultCoordinates;\n this.handleStart = this.handleStart.bind(this);\n this.handleMove = this.handleMove.bind(this);\n this.handleEnd = this.handleEnd.bind(this);\n this.handleCancel = this.handleCancel.bind(this);\n this.handleKeydown = this.handleKeydown.bind(this);\n this.removeTextSelection = this.removeTextSelection.bind(this);\n this.attach();\n }\n\n attach() {\n const {\n events,\n props: {\n options: {\n activationConstraint,\n bypassActivationConstraint\n }\n }\n } = this;\n this.listeners.add(events.move.name, this.handleMove, {\n passive: false\n });\n this.listeners.add(events.end.name, this.handleEnd);\n\n if (events.cancel) {\n this.listeners.add(events.cancel.name, this.handleCancel);\n }\n\n this.windowListeners.add(EventName.Resize, this.handleCancel);\n this.windowListeners.add(EventName.DragStart, preventDefault);\n this.windowListeners.add(EventName.VisibilityChange, this.handleCancel);\n this.windowListeners.add(EventName.ContextMenu, preventDefault);\n this.documentListeners.add(EventName.Keydown, this.handleKeydown);\n\n if (activationConstraint) {\n if (bypassActivationConstraint != null && bypassActivationConstraint({\n event: this.props.event,\n activeNode: this.props.activeNode,\n options: this.props.options\n })) {\n return this.handleStart();\n }\n\n if (isDelayConstraint(activationConstraint)) {\n this.timeoutId = setTimeout(this.handleStart, activationConstraint.delay);\n this.handlePending(activationConstraint);\n return;\n }\n\n if (isDistanceConstraint(activationConstraint)) {\n this.handlePending(activationConstraint);\n return;\n }\n }\n\n this.handleStart();\n }\n\n detach() {\n this.listeners.removeAll();\n this.windowListeners.removeAll(); // Wait until the next event loop before removing document listeners\n // This is necessary because we listen for `click` and `selection` events on the document\n\n setTimeout(this.documentListeners.removeAll, 50);\n\n if (this.timeoutId !== null) {\n clearTimeout(this.timeoutId);\n this.timeoutId = null;\n }\n }\n\n handlePending(constraint, offset) {\n const {\n active,\n onPending\n } = this.props;\n onPending(active, constraint, this.initialCoordinates, offset);\n }\n\n handleStart() {\n const {\n initialCoordinates\n } = this;\n const {\n onStart\n } = this.props;\n\n if (initialCoordinates) {\n this.activated = true; // Stop propagation of click events once activation constraints are met\n\n this.documentListeners.add(EventName.Click, stopPropagation, {\n capture: true\n }); // Remove any text selection from the document\n\n this.removeTextSelection(); // Prevent further text selection while dragging\n\n this.documentListeners.add(EventName.SelectionChange, this.removeTextSelection);\n onStart(initialCoordinates);\n }\n }\n\n handleMove(event) {\n var _getEventCoordinates2;\n\n const {\n activated,\n initialCoordinates,\n props\n } = this;\n const {\n onMove,\n options: {\n activationConstraint\n }\n } = props;\n\n if (!initialCoordinates) {\n return;\n }\n\n const coordinates = (_getEventCoordinates2 = getEventCoordinates(event)) != null ? _getEventCoordinates2 : defaultCoordinates;\n const delta = subtract(initialCoordinates, coordinates); // Constraint validation\n\n if (!activated && activationConstraint) {\n if (isDistanceConstraint(activationConstraint)) {\n if (activationConstraint.tolerance != null && hasExceededDistance(delta, activationConstraint.tolerance)) {\n return this.handleCancel();\n }\n\n if (hasExceededDistance(delta, activationConstraint.distance)) {\n return this.handleStart();\n }\n }\n\n if (isDelayConstraint(activationConstraint)) {\n if (hasExceededDistance(delta, activationConstraint.tolerance)) {\n return this.handleCancel();\n }\n }\n\n this.handlePending(activationConstraint, delta);\n return;\n }\n\n if (event.cancelable) {\n event.preventDefault();\n }\n\n onMove(coordinates);\n }\n\n handleEnd() {\n const {\n onAbort,\n onEnd\n } = this.props;\n this.detach();\n\n if (!this.activated) {\n onAbort(this.props.active);\n }\n\n onEnd();\n }\n\n handleCancel() {\n const {\n onAbort,\n onCancel\n } = this.props;\n this.detach();\n\n if (!this.activated) {\n onAbort(this.props.active);\n }\n\n onCancel();\n }\n\n handleKeydown(event) {\n if (event.code === KeyboardCode.Esc) {\n this.handleCancel();\n }\n }\n\n removeTextSelection() {\n var _this$document$getSel;\n\n (_this$document$getSel = this.document.getSelection()) == null ? void 0 : _this$document$getSel.removeAllRanges();\n }\n\n}\n\nconst events = {\n cancel: {\n name: 'pointercancel'\n },\n move: {\n name: 'pointermove'\n },\n end: {\n name: 'pointerup'\n }\n};\nclass PointerSensor extends AbstractPointerSensor {\n constructor(props) {\n const {\n event\n } = props; // Pointer events stop firing if the target is unmounted while dragging\n // Therefore we attach listeners to the owner document instead\n\n const listenerTarget = getOwnerDocument(event.target);\n super(props, events, listenerTarget);\n }\n\n}\nPointerSensor.activators = [{\n eventName: 'onPointerDown',\n handler: (_ref, _ref2) => {\n let {\n nativeEvent: event\n } = _ref;\n let {\n onActivation\n } = _ref2;\n\n if (!event.isPrimary || event.button !== 0) {\n return false;\n }\n\n onActivation == null ? void 0 : onActivation({\n event\n });\n return true;\n }\n}];\n\nconst events$1 = {\n move: {\n name: 'mousemove'\n },\n end: {\n name: 'mouseup'\n }\n};\nvar MouseButton;\n\n(function (MouseButton) {\n MouseButton[MouseButton[\"RightClick\"] = 2] = \"RightClick\";\n})(MouseButton || (MouseButton = {}));\n\nclass MouseSensor extends AbstractPointerSensor {\n constructor(props) {\n super(props, events$1, getOwnerDocument(props.event.target));\n }\n\n}\nMouseSensor.activators = [{\n eventName: 'onMouseDown',\n handler: (_ref, _ref2) => {\n let {\n nativeEvent: event\n } = _ref;\n let {\n onActivation\n } = _ref2;\n\n if (event.button === MouseButton.RightClick) {\n return false;\n }\n\n onActivation == null ? void 0 : onActivation({\n event\n });\n return true;\n }\n}];\n\nconst events$2 = {\n cancel: {\n name: 'touchcancel'\n },\n move: {\n name: 'touchmove'\n },\n end: {\n name: 'touchend'\n }\n};\nclass TouchSensor extends AbstractPointerSensor {\n constructor(props) {\n super(props, events$2);\n }\n\n static setup() {\n // Adding a non-capture and non-passive `touchmove` listener in order\n // to force `event.preventDefault()` calls to work in dynamically added\n // touchmove event handlers. This is required for iOS Safari.\n window.addEventListener(events$2.move.name, noop, {\n capture: false,\n passive: false\n });\n return function teardown() {\n window.removeEventListener(events$2.move.name, noop);\n }; // We create a new handler because the teardown function of another sensor\n // could remove our event listener if we use a referentially equal listener.\n\n function noop() {}\n }\n\n}\nTouchSensor.activators = [{\n eventName: 'onTouchStart',\n handler: (_ref, _ref2) => {\n let {\n nativeEvent: event\n } = _ref;\n let {\n onActivation\n } = _ref2;\n const {\n touches\n } = event;\n\n if (touches.length > 1) {\n return false;\n }\n\n onActivation == null ? void 0 : onActivation({\n event\n });\n return true;\n }\n}];\n\nvar AutoScrollActivator;\n\n(function (AutoScrollActivator) {\n AutoScrollActivator[AutoScrollActivator[\"Pointer\"] = 0] = \"Pointer\";\n AutoScrollActivator[AutoScrollActivator[\"DraggableRect\"] = 1] = \"DraggableRect\";\n})(AutoScrollActivator || (AutoScrollActivator = {}));\n\nvar TraversalOrder;\n\n(function (TraversalOrder) {\n TraversalOrder[TraversalOrder[\"TreeOrder\"] = 0] = \"TreeOrder\";\n TraversalOrder[TraversalOrder[\"ReversedTreeOrder\"] = 1] = \"ReversedTreeOrder\";\n})(TraversalOrder || (TraversalOrder = {}));\n\nfunction useAutoScroller(_ref) {\n let {\n acceleration,\n activator = AutoScrollActivator.Pointer,\n canScroll,\n draggingRect,\n enabled,\n interval = 5,\n order = TraversalOrder.TreeOrder,\n pointerCoordinates,\n scrollableAncestors,\n scrollableAncestorRects,\n delta,\n threshold\n } = _ref;\n const scrollIntent = useScrollIntent({\n delta,\n disabled: !enabled\n });\n const [setAutoScrollInterval, clearAutoScrollInterval] = useInterval();\n const scrollSpeed = useRef({\n x: 0,\n y: 0\n });\n const scrollDirection = useRef({\n x: 0,\n y: 0\n });\n const rect = useMemo(() => {\n switch (activator) {\n case AutoScrollActivator.Pointer:\n return pointerCoordinates ? {\n top: pointerCoordinates.y,\n bottom: pointerCoordinates.y,\n left: pointerCoordinates.x,\n right: pointerCoordinates.x\n } : null;\n\n case AutoScrollActivator.DraggableRect:\n return draggingRect;\n }\n }, [activator, draggingRect, pointerCoordinates]);\n const scrollContainerRef = useRef(null);\n const autoScroll = useCallback(() => {\n const scrollContainer = scrollContainerRef.current;\n\n if (!scrollContainer) {\n return;\n }\n\n const scrollLeft = scrollSpeed.current.x * scrollDirection.current.x;\n const scrollTop = scrollSpeed.current.y * scrollDirection.current.y;\n scrollContainer.scrollBy(scrollLeft, scrollTop);\n }, []);\n const sortedScrollableAncestors = useMemo(() => order === TraversalOrder.TreeOrder ? [...scrollableAncestors].reverse() : scrollableAncestors, [order, scrollableAncestors]);\n useEffect(() => {\n if (!enabled || !scrollableAncestors.length || !rect) {\n clearAutoScrollInterval();\n return;\n }\n\n for (const scrollContainer of sortedScrollableAncestors) {\n if ((canScroll == null ? void 0 : canScroll(scrollContainer)) === false) {\n continue;\n }\n\n const index = scrollableAncestors.indexOf(scrollContainer);\n const scrollContainerRect = scrollableAncestorRects[index];\n\n if (!scrollContainerRect) {\n continue;\n }\n\n const {\n direction,\n speed\n } = getScrollDirectionAndSpeed(scrollContainer, scrollContainerRect, rect, acceleration, threshold);\n\n for (const axis of ['x', 'y']) {\n if (!scrollIntent[axis][direction[axis]]) {\n speed[axis] = 0;\n direction[axis] = 0;\n }\n }\n\n if (speed.x > 0 || speed.y > 0) {\n clearAutoScrollInterval();\n scrollContainerRef.current = scrollContainer;\n setAutoScrollInterval(autoScroll, interval);\n scrollSpeed.current = speed;\n scrollDirection.current = direction;\n return;\n }\n }\n\n scrollSpeed.current = {\n x: 0,\n y: 0\n };\n scrollDirection.current = {\n x: 0,\n y: 0\n };\n clearAutoScrollInterval();\n }, // eslint-disable-next-line react-hooks/exhaustive-deps\n [acceleration, autoScroll, canScroll, clearAutoScrollInterval, enabled, interval, // eslint-disable-next-line react-hooks/exhaustive-deps\n JSON.stringify(rect), // eslint-disable-next-line react-hooks/exhaustive-deps\n JSON.stringify(scrollIntent), setAutoScrollInterval, scrollableAncestors, sortedScrollableAncestors, scrollableAncestorRects, // eslint-disable-next-line react-hooks/exhaustive-deps\n JSON.stringify(threshold)]);\n}\nconst defaultScrollIntent = {\n x: {\n [Direction.Backward]: false,\n [Direction.Forward]: false\n },\n y: {\n [Direction.Backward]: false,\n [Direction.Forward]: false\n }\n};\n\nfunction useScrollIntent(_ref2) {\n let {\n delta,\n disabled\n } = _ref2;\n const previousDelta = usePrevious(delta);\n return useLazyMemo(previousIntent => {\n if (disabled || !previousDelta || !previousIntent) {\n // Reset scroll intent tracking when auto-scrolling is disabled\n return defaultScrollIntent;\n }\n\n const direction = {\n x: Math.sign(delta.x - previousDelta.x),\n y: Math.sign(delta.y - previousDelta.y)\n }; // Keep track of the user intent to scroll in each direction for both axis\n\n return {\n x: {\n [Direction.Backward]: previousIntent.x[Direction.Backward] || direction.x === -1,\n [Direction.Forward]: previousIntent.x[Direction.Forward] || direction.x === 1\n },\n y: {\n [Direction.Backward]: previousIntent.y[Direction.Backward] || direction.y === -1,\n [Direction.Forward]: previousIntent.y[Direction.Forward] || direction.y === 1\n }\n };\n }, [disabled, delta, previousDelta]);\n}\n\nfunction useCachedNode(draggableNodes, id) {\n const draggableNode = id != null ? draggableNodes.get(id) : undefined;\n const node = draggableNode ? draggableNode.node.current : null;\n return useLazyMemo(cachedNode => {\n var _ref;\n\n if (id == null) {\n return null;\n } // In some cases, the draggable node can unmount while dragging\n // This is the case for virtualized lists. In those situations,\n // we fall back to the last known value for that node.\n\n\n return (_ref = node != null ? node : cachedNode) != null ? _ref : null;\n }, [node, id]);\n}\n\nfunction useCombineActivators(sensors, getSyntheticHandler) {\n return useMemo(() => sensors.reduce((accumulator, sensor) => {\n const {\n sensor: Sensor\n } = sensor;\n const sensorActivators = Sensor.activators.map(activator => ({\n eventName: activator.eventName,\n handler: getSyntheticHandler(activator.handler, sensor)\n }));\n return [...accumulator, ...sensorActivators];\n }, []), [sensors, getSyntheticHandler]);\n}\n\nvar MeasuringStrategy;\n\n(function (MeasuringStrategy) {\n MeasuringStrategy[MeasuringStrategy[\"Always\"] = 0] = \"Always\";\n MeasuringStrategy[MeasuringStrategy[\"BeforeDragging\"] = 1] = \"BeforeDragging\";\n MeasuringStrategy[MeasuringStrategy[\"WhileDragging\"] = 2] = \"WhileDragging\";\n})(MeasuringStrategy || (MeasuringStrategy = {}));\n\nvar MeasuringFrequency;\n\n(function (MeasuringFrequency) {\n MeasuringFrequency[\"Optimized\"] = \"optimized\";\n})(MeasuringFrequency || (MeasuringFrequency = {}));\n\nconst defaultValue = /*#__PURE__*/new Map();\nfunction useDroppableMeasuring(containers, _ref) {\n let {\n dragging,\n dependencies,\n config\n } = _ref;\n const [queue, setQueue] = useState(null);\n const {\n frequency,\n measure,\n strategy\n } = config;\n const containersRef = useRef(containers);\n const disabled = isDisabled();\n const disabledRef = useLatestValue(disabled);\n const measureDroppableContainers = useCallback(function (ids) {\n if (ids === void 0) {\n ids = [];\n }\n\n if (disabledRef.current) {\n return;\n }\n\n setQueue(value => {\n if (value === null) {\n return ids;\n }\n\n return value.concat(ids.filter(id => !value.includes(id)));\n });\n }, [disabledRef]);\n const timeoutId = useRef(null);\n const droppableRects = useLazyMemo(previousValue => {\n if (disabled && !dragging) {\n return defaultValue;\n }\n\n if (!previousValue || previousValue === defaultValue || containersRef.current !== containers || queue != null) {\n const map = new Map();\n\n for (let container of containers) {\n if (!container) {\n continue;\n }\n\n if (queue && queue.length > 0 && !queue.includes(container.id) && container.rect.current) {\n // This container does not need to be re-measured\n map.set(container.id, container.rect.current);\n continue;\n }\n\n const node = container.node.current;\n const rect = node ? new Rect(measure(node), node) : null;\n container.rect.current = rect;\n\n if (rect) {\n map.set(container.id, rect);\n }\n }\n\n return map;\n }\n\n return previousValue;\n }, [containers, queue, dragging, disabled, measure]);\n useEffect(() => {\n containersRef.current = containers;\n }, [containers]);\n useEffect(() => {\n if (disabled) {\n return;\n }\n\n measureDroppableContainers();\n }, // eslint-disable-next-line react-hooks/exhaustive-deps\n [dragging, disabled]);\n useEffect(() => {\n if (queue && queue.length > 0) {\n setQueue(null);\n }\n }, //eslint-disable-next-line react-hooks/exhaustive-deps\n [JSON.stringify(queue)]);\n useEffect(() => {\n if (disabled || typeof frequency !== 'number' || timeoutId.current !== null) {\n return;\n }\n\n timeoutId.current = setTimeout(() => {\n measureDroppableContainers();\n timeoutId.current = null;\n }, frequency);\n }, // eslint-disable-next-line react-hooks/exhaustive-deps\n [frequency, disabled, measureDroppableContainers, ...dependencies]);\n return {\n droppableRects,\n measureDroppableContainers,\n measuringScheduled: queue != null\n };\n\n function isDisabled() {\n switch (strategy) {\n case MeasuringStrategy.Always:\n return false;\n\n case MeasuringStrategy.BeforeDragging:\n return dragging;\n\n default:\n return !dragging;\n }\n }\n}\n\nfunction useInitialValue(value, computeFn) {\n return useLazyMemo(previousValue => {\n if (!value) {\n return null;\n }\n\n if (previousValue) {\n return previousValue;\n }\n\n return typeof computeFn === 'function' ? computeFn(value) : value;\n }, [computeFn, value]);\n}\n\nfunction useInitialRect(node, measure) {\n return useInitialValue(node, measure);\n}\n\n/**\r\n * Returns a new MutationObserver instance.\r\n * If `MutationObserver` is undefined in the execution environment, returns `undefined`.\r\n */\n\nfunction useMutationObserver(_ref) {\n let {\n callback,\n disabled\n } = _ref;\n const handleMutations = useEvent(callback);\n const mutationObserver = useMemo(() => {\n if (disabled || typeof window === 'undefined' || typeof window.MutationObserver === 'undefined') {\n return undefined;\n }\n\n const {\n MutationObserver\n } = window;\n return new MutationObserver(handleMutations);\n }, [handleMutations, disabled]);\n useEffect(() => {\n return () => mutationObserver == null ? void 0 : mutationObserver.disconnect();\n }, [mutationObserver]);\n return mutationObserver;\n}\n\n/**\r\n * Returns a new ResizeObserver instance bound to the `onResize` callback.\r\n * If `ResizeObserver` is undefined in the execution environment, returns `undefined`.\r\n */\n\nfunction useResizeObserver(_ref) {\n let {\n callback,\n disabled\n } = _ref;\n const handleResize = useEvent(callback);\n const resizeObserver = useMemo(() => {\n if (disabled || typeof window === 'undefined' || typeof window.ResizeObserver === 'undefined') {\n return undefined;\n }\n\n const {\n ResizeObserver\n } = window;\n return new ResizeObserver(handleResize);\n }, // eslint-disable-next-line react-hooks/exhaustive-deps\n [disabled]);\n useEffect(() => {\n return () => resizeObserver == null ? void 0 : resizeObserver.disconnect();\n }, [resizeObserver]);\n return resizeObserver;\n}\n\nfunction defaultMeasure(element) {\n return new Rect(getClientRect(element), element);\n}\n\nfunction useRect(element, measure, fallbackRect) {\n if (measure === void 0) {\n measure = defaultMeasure;\n }\n\n const [rect, setRect] = useState(null);\n\n function measureRect() {\n setRect(currentRect => {\n if (!element) {\n return null;\n }\n\n if (element.isConnected === false) {\n var _ref;\n\n // Fall back to last rect we measured if the element is\n // no longer connected to the DOM.\n return (_ref = currentRect != null ? currentRect : fallbackRect) != null ? _ref : null;\n }\n\n const newRect = measure(element);\n\n if (JSON.stringify(currentRect) === JSON.stringify(newRect)) {\n return currentRect;\n }\n\n return newRect;\n });\n }\n\n const mutationObserver = useMutationObserver({\n callback(records) {\n if (!element) {\n return;\n }\n\n for (const record of records) {\n const {\n type,\n target\n } = record;\n\n if (type === 'childList' && target instanceof HTMLElement && target.contains(element)) {\n measureRect();\n break;\n }\n }\n }\n\n });\n const resizeObserver = useResizeObserver({\n callback: measureRect\n });\n useIsomorphicLayoutEffect(() => {\n measureRect();\n\n if (element) {\n resizeObserver == null ? void 0 : resizeObserver.observe(element);\n mutationObserver == null ? void 0 : mutationObserver.observe(document.body, {\n childList: true,\n subtree: true\n });\n } else {\n resizeObserver == null ? void 0 : resizeObserver.disconnect();\n mutationObserver == null ? void 0 : mutationObserver.disconnect();\n }\n }, [element]);\n return rect;\n}\n\nfunction useRectDelta(rect) {\n const initialRect = useInitialValue(rect);\n return getRectDelta(rect, initialRect);\n}\n\nconst defaultValue$1 = [];\nfunction useScrollableAncestors(node) {\n const previousNode = useRef(node);\n const ancestors = useLazyMemo(previousValue => {\n if (!node) {\n return defaultValue$1;\n }\n\n if (previousValue && previousValue !== defaultValue$1 && node && previousNode.current && node.parentNode === previousNode.current.parentNode) {\n return previousValue;\n }\n\n return getScrollableAncestors(node);\n }, [node]);\n useEffect(() => {\n previousNode.current = node;\n }, [node]);\n return ancestors;\n}\n\nfunction useScrollOffsets(elements) {\n const [scrollCoordinates, setScrollCoordinates] = useState(null);\n const prevElements = useRef(elements); // To-do: Throttle the handleScroll callback\n\n const handleScroll = useCallback(event => {\n const scrollingElement = getScrollableElement(event.target);\n\n if (!scrollingElement) {\n return;\n }\n\n setScrollCoordinates(scrollCoordinates => {\n if (!scrollCoordinates) {\n return null;\n }\n\n scrollCoordinates.set(scrollingElement, getScrollCoordinates(scrollingElement));\n return new Map(scrollCoordinates);\n });\n }, []);\n useEffect(() => {\n const previousElements = prevElements.current;\n\n if (elements !== previousElements) {\n cleanup(previousElements);\n const entries = elements.map(element => {\n const scrollableElement = getScrollableElement(element);\n\n if (scrollableElement) {\n scrollableElement.addEventListener('scroll', handleScroll, {\n passive: true\n });\n return [scrollableElement, getScrollCoordinates(scrollableElement)];\n }\n\n return null;\n }).filter(entry => entry != null);\n setScrollCoordinates(entries.length ? new Map(entries) : null);\n prevElements.current = elements;\n }\n\n return () => {\n cleanup(elements);\n cleanup(previousElements);\n };\n\n function cleanup(elements) {\n elements.forEach(element => {\n const scrollableElement = getScrollableElement(element);\n scrollableElement == null ? void 0 : scrollableElement.removeEventListener('scroll', handleScroll);\n });\n }\n }, [handleScroll, elements]);\n return useMemo(() => {\n if (elements.length) {\n return scrollCoordinates ? Array.from(scrollCoordinates.values()).reduce((acc, coordinates) => add(acc, coordinates), defaultCoordinates) : getScrollOffsets(elements);\n }\n\n return defaultCoordinates;\n }, [elements, scrollCoordinates]);\n}\n\nfunction useScrollOffsetsDelta(scrollOffsets, dependencies) {\n if (dependencies === void 0) {\n dependencies = [];\n }\n\n const initialScrollOffsets = useRef(null);\n useEffect(() => {\n initialScrollOffsets.current = null;\n }, // eslint-disable-next-line react-hooks/exhaustive-deps\n dependencies);\n useEffect(() => {\n const hasScrollOffsets = scrollOffsets !== defaultCoordinates;\n\n if (hasScrollOffsets && !initialScrollOffsets.current) {\n initialScrollOffsets.current = scrollOffsets;\n }\n\n if (!hasScrollOffsets && initialScrollOffsets.current) {\n initialScrollOffsets.current = null;\n }\n }, [scrollOffsets]);\n return initialScrollOffsets.current ? subtract(scrollOffsets, initialScrollOffsets.current) : defaultCoordinates;\n}\n\nfunction useSensorSetup(sensors) {\n useEffect(() => {\n if (!canUseDOM) {\n return;\n }\n\n const teardownFns = sensors.map(_ref => {\n let {\n sensor\n } = _ref;\n return sensor.setup == null ? void 0 : sensor.setup();\n });\n return () => {\n for (const teardown of teardownFns) {\n teardown == null ? void 0 : teardown();\n }\n };\n }, // TO-DO: Sensors length could theoretically change which would not be a valid dependency\n // eslint-disable-next-line react-hooks/exhaustive-deps\n sensors.map(_ref2 => {\n let {\n sensor\n } = _ref2;\n return sensor;\n }));\n}\n\nfunction useSyntheticListeners(listeners, id) {\n return useMemo(() => {\n return listeners.reduce((acc, _ref) => {\n let {\n eventName,\n handler\n } = _ref;\n\n acc[eventName] = event => {\n handler(event, id);\n };\n\n return acc;\n }, {});\n }, [listeners, id]);\n}\n\nfunction useWindowRect(element) {\n return useMemo(() => element ? getWindowClientRect(element) : null, [element]);\n}\n\nconst defaultValue$2 = [];\nfunction useRects(elements, measure) {\n if (measure === void 0) {\n measure = getClientRect;\n }\n\n const [firstElement] = elements;\n const windowRect = useWindowRect(firstElement ? getWindow(firstElement) : null);\n const [rects, setRects] = useState(defaultValue$2);\n\n function measureRects() {\n setRects(() => {\n if (!elements.length) {\n return defaultValue$2;\n }\n\n return elements.map(element => isDocumentScrollingElement(element) ? windowRect : new Rect(measure(element), element));\n });\n }\n\n const resizeObserver = useResizeObserver({\n callback: measureRects\n });\n useIsomorphicLayoutEffect(() => {\n resizeObserver == null ? void 0 : resizeObserver.disconnect();\n measureRects();\n elements.forEach(element => resizeObserver == null ? void 0 : resizeObserver.observe(element));\n }, [elements]);\n return rects;\n}\n\nfunction getMeasurableNode(node) {\n if (!node) {\n return null;\n }\n\n if (node.children.length > 1) {\n return node;\n }\n\n const firstChild = node.children[0];\n return isHTMLElement(firstChild) ? firstChild : node;\n}\n\nfunction useDragOverlayMeasuring(_ref) {\n let {\n measure\n } = _ref;\n const [rect, setRect] = useState(null);\n const handleResize = useCallback(entries => {\n for (const {\n target\n } of entries) {\n if (isHTMLElement(target)) {\n setRect(rect => {\n const newRect = measure(target);\n return rect ? { ...rect,\n width: newRect.width,\n height: newRect.height\n } : newRect;\n });\n break;\n }\n }\n }, [measure]);\n const resizeObserver = useResizeObserver({\n callback: handleResize\n });\n const handleNodeChange = useCallback(element => {\n const node = getMeasurableNode(element);\n resizeObserver == null ? void 0 : resizeObserver.disconnect();\n\n if (node) {\n resizeObserver == null ? void 0 : resizeObserver.observe(node);\n }\n\n setRect(node ? measure(node) : null);\n }, [measure, resizeObserver]);\n const [nodeRef, setRef] = useNodeRef(handleNodeChange);\n return useMemo(() => ({\n nodeRef,\n rect,\n setRef\n }), [rect, nodeRef, setRef]);\n}\n\nconst defaultSensors = [{\n sensor: PointerSensor,\n options: {}\n}, {\n sensor: KeyboardSensor,\n options: {}\n}];\nconst defaultData = {\n current: {}\n};\nconst defaultMeasuringConfiguration = {\n draggable: {\n measure: getTransformAgnosticClientRect\n },\n droppable: {\n measure: getTransformAgnosticClientRect,\n strategy: MeasuringStrategy.WhileDragging,\n frequency: MeasuringFrequency.Optimized\n },\n dragOverlay: {\n measure: getClientRect\n }\n};\n\nclass DroppableContainersMap extends Map {\n get(id) {\n var _super$get;\n\n return id != null ? (_super$get = super.get(id)) != null ? _super$get : undefined : undefined;\n }\n\n toArray() {\n return Array.from(this.values());\n }\n\n getEnabled() {\n return this.toArray().filter(_ref => {\n let {\n disabled\n } = _ref;\n return !disabled;\n });\n }\n\n getNodeFor(id) {\n var _this$get$node$curren, _this$get;\n\n return (_this$get$node$curren = (_this$get = this.get(id)) == null ? void 0 : _this$get.node.current) != null ? _this$get$node$curren : undefined;\n }\n\n}\n\nconst defaultPublicContext = {\n activatorEvent: null,\n active: null,\n activeNode: null,\n activeNodeRect: null,\n collisions: null,\n containerNodeRect: null,\n draggableNodes: /*#__PURE__*/new Map(),\n droppableRects: /*#__PURE__*/new Map(),\n droppableContainers: /*#__PURE__*/new DroppableContainersMap(),\n over: null,\n dragOverlay: {\n nodeRef: {\n current: null\n },\n rect: null,\n setRef: noop\n },\n scrollableAncestors: [],\n scrollableAncestorRects: [],\n measuringConfiguration: defaultMeasuringConfiguration,\n measureDroppableContainers: noop,\n windowRect: null,\n measuringScheduled: false\n};\nconst defaultInternalContext = {\n activatorEvent: null,\n activators: [],\n active: null,\n activeNodeRect: null,\n ariaDescribedById: {\n draggable: ''\n },\n dispatch: noop,\n draggableNodes: /*#__PURE__*/new Map(),\n over: null,\n measureDroppableContainers: noop\n};\nconst InternalContext = /*#__PURE__*/createContext(defaultInternalContext);\nconst PublicContext = /*#__PURE__*/createContext(defaultPublicContext);\n\nfunction getInitialState() {\n return {\n draggable: {\n active: null,\n initialCoordinates: {\n x: 0,\n y: 0\n },\n nodes: new Map(),\n translate: {\n x: 0,\n y: 0\n }\n },\n droppable: {\n containers: new DroppableContainersMap()\n }\n };\n}\nfunction reducer(state, action) {\n switch (action.type) {\n case Action.DragStart:\n return { ...state,\n draggable: { ...state.draggable,\n initialCoordinates: action.initialCoordinates,\n active: action.active\n }\n };\n\n case Action.DragMove:\n if (state.draggable.active == null) {\n return state;\n }\n\n return { ...state,\n draggable: { ...state.draggable,\n translate: {\n x: action.coordinates.x - state.draggable.initialCoordinates.x,\n y: action.coordinates.y - state.draggable.initialCoordinates.y\n }\n }\n };\n\n case Action.DragEnd:\n case Action.DragCancel:\n return { ...state,\n draggable: { ...state.draggable,\n active: null,\n initialCoordinates: {\n x: 0,\n y: 0\n },\n translate: {\n x: 0,\n y: 0\n }\n }\n };\n\n case Action.RegisterDroppable:\n {\n const {\n element\n } = action;\n const {\n id\n } = element;\n const containers = new DroppableContainersMap(state.droppable.containers);\n containers.set(id, element);\n return { ...state,\n droppable: { ...state.droppable,\n containers\n }\n };\n }\n\n case Action.SetDroppableDisabled:\n {\n const {\n id,\n key,\n disabled\n } = action;\n const element = state.droppable.containers.get(id);\n\n if (!element || key !== element.key) {\n return state;\n }\n\n const containers = new DroppableContainersMap(state.droppable.containers);\n containers.set(id, { ...element,\n disabled\n });\n return { ...state,\n droppable: { ...state.droppable,\n containers\n }\n };\n }\n\n case Action.UnregisterDroppable:\n {\n const {\n id,\n key\n } = action;\n const element = state.droppable.containers.get(id);\n\n if (!element || key !== element.key) {\n return state;\n }\n\n const containers = new DroppableContainersMap(state.droppable.containers);\n containers.delete(id);\n return { ...state,\n droppable: { ...state.droppable,\n containers\n }\n };\n }\n\n default:\n {\n return state;\n }\n }\n}\n\nfunction RestoreFocus(_ref) {\n let {\n disabled\n } = _ref;\n const {\n active,\n activatorEvent,\n draggableNodes\n } = useContext(InternalContext);\n const previousActivatorEvent = usePrevious(activatorEvent);\n const previousActiveId = usePrevious(active == null ? void 0 : active.id); // Restore keyboard focus on the activator node\n\n useEffect(() => {\n if (disabled) {\n return;\n }\n\n if (!activatorEvent && previousActivatorEvent && previousActiveId != null) {\n if (!isKeyboardEvent(previousActivatorEvent)) {\n return;\n }\n\n if (document.activeElement === previousActivatorEvent.target) {\n // No need to restore focus\n return;\n }\n\n const draggableNode = draggableNodes.get(previousActiveId);\n\n if (!draggableNode) {\n return;\n }\n\n const {\n activatorNode,\n node\n } = draggableNode;\n\n if (!activatorNode.current && !node.current) {\n return;\n }\n\n requestAnimationFrame(() => {\n for (const element of [activatorNode.current, node.current]) {\n if (!element) {\n continue;\n }\n\n const focusableNode = findFirstFocusableNode(element);\n\n if (focusableNode) {\n focusableNode.focus();\n break;\n }\n }\n });\n }\n }, [activatorEvent, disabled, draggableNodes, previousActiveId, previousActivatorEvent]);\n return null;\n}\n\nfunction applyModifiers(modifiers, _ref) {\n let {\n transform,\n ...args\n } = _ref;\n return modifiers != null && modifiers.length ? modifiers.reduce((accumulator, modifier) => {\n return modifier({\n transform: accumulator,\n ...args\n });\n }, transform) : transform;\n}\n\nfunction useMeasuringConfiguration(config) {\n return useMemo(() => ({\n draggable: { ...defaultMeasuringConfiguration.draggable,\n ...(config == null ? void 0 : config.draggable)\n },\n droppable: { ...defaultMeasuringConfiguration.droppable,\n ...(config == null ? void 0 : config.droppable)\n },\n dragOverlay: { ...defaultMeasuringConfiguration.dragOverlay,\n ...(config == null ? void 0 : config.dragOverlay)\n }\n }), // eslint-disable-next-line react-hooks/exhaustive-deps\n [config == null ? void 0 : config.draggable, config == null ? void 0 : config.droppable, config == null ? void 0 : config.dragOverlay]);\n}\n\nfunction useLayoutShiftScrollCompensation(_ref) {\n let {\n activeNode,\n measure,\n initialRect,\n config = true\n } = _ref;\n const initialized = useRef(false);\n const {\n x,\n y\n } = typeof config === 'boolean' ? {\n x: config,\n y: config\n } : config;\n useIsomorphicLayoutEffect(() => {\n const disabled = !x && !y;\n\n if (disabled || !activeNode) {\n initialized.current = false;\n return;\n }\n\n if (initialized.current || !initialRect) {\n // Return early if layout shift scroll compensation was already attempted\n // or if there is no initialRect to compare to.\n return;\n } // Get the most up to date node ref for the active draggable\n\n\n const node = activeNode == null ? void 0 : activeNode.node.current;\n\n if (!node || node.isConnected === false) {\n // Return early if there is no attached node ref or if the node is\n // disconnected from the document.\n return;\n }\n\n const rect = measure(node);\n const rectDelta = getRectDelta(rect, initialRect);\n\n if (!x) {\n rectDelta.x = 0;\n }\n\n if (!y) {\n rectDelta.y = 0;\n } // Only perform layout shift scroll compensation once\n\n\n initialized.current = true;\n\n if (Math.abs(rectDelta.x) > 0 || Math.abs(rectDelta.y) > 0) {\n const firstScrollableAncestor = getFirstScrollableAncestor(node);\n\n if (firstScrollableAncestor) {\n firstScrollableAncestor.scrollBy({\n top: rectDelta.y,\n left: rectDelta.x\n });\n }\n }\n }, [activeNode, x, y, initialRect, measure]);\n}\n\nconst ActiveDraggableContext = /*#__PURE__*/createContext({ ...defaultCoordinates,\n scaleX: 1,\n scaleY: 1\n});\nvar Status;\n\n(function (Status) {\n Status[Status[\"Uninitialized\"] = 0] = \"Uninitialized\";\n Status[Status[\"Initializing\"] = 1] = \"Initializing\";\n Status[Status[\"Initialized\"] = 2] = \"Initialized\";\n})(Status || (Status = {}));\n\nconst DndContext = /*#__PURE__*/memo(function DndContext(_ref) {\n var _sensorContext$curren, _dragOverlay$nodeRef$, _dragOverlay$rect, _over$rect;\n\n let {\n id,\n accessibility,\n autoScroll = true,\n children,\n sensors = defaultSensors,\n collisionDetection = rectIntersection,\n measuring,\n modifiers,\n ...props\n } = _ref;\n const store = useReducer(reducer, undefined, getInitialState);\n const [state, dispatch] = store;\n const [dispatchMonitorEvent, registerMonitorListener] = useDndMonitorProvider();\n const [status, setStatus] = useState(Status.Uninitialized);\n const isInitialized = status === Status.Initialized;\n const {\n draggable: {\n active: activeId,\n nodes: draggableNodes,\n translate\n },\n droppable: {\n containers: droppableContainers\n }\n } = state;\n const node = activeId != null ? draggableNodes.get(activeId) : null;\n const activeRects = useRef({\n initial: null,\n translated: null\n });\n const active = useMemo(() => {\n var _node$data;\n\n return activeId != null ? {\n id: activeId,\n // It's possible for the active node to unmount while dragging\n data: (_node$data = node == null ? void 0 : node.data) != null ? _node$data : defaultData,\n rect: activeRects\n } : null;\n }, [activeId, node]);\n const activeRef = useRef(null);\n const [activeSensor, setActiveSensor] = useState(null);\n const [activatorEvent, setActivatorEvent] = useState(null);\n const latestProps = useLatestValue(props, Object.values(props));\n const draggableDescribedById = useUniqueId(\"DndDescribedBy\", id);\n const enabledDroppableContainers = useMemo(() => droppableContainers.getEnabled(), [droppableContainers]);\n const measuringConfiguration = useMeasuringConfiguration(measuring);\n const {\n droppableRects,\n measureDroppableContainers,\n measuringScheduled\n } = useDroppableMeasuring(enabledDroppableContainers, {\n dragging: isInitialized,\n dependencies: [translate.x, translate.y],\n config: measuringConfiguration.droppable\n });\n const activeNode = useCachedNode(draggableNodes, activeId);\n const activationCoordinates = useMemo(() => activatorEvent ? getEventCoordinates(activatorEvent) : null, [activatorEvent]);\n const autoScrollOptions = getAutoScrollerOptions();\n const initialActiveNodeRect = useInitialRect(activeNode, measuringConfiguration.draggable.measure);\n useLayoutShiftScrollCompensation({\n activeNode: activeId != null ? draggableNodes.get(activeId) : null,\n config: autoScrollOptions.layoutShiftCompensation,\n initialRect: initialActiveNodeRect,\n measure: measuringConfiguration.draggable.measure\n });\n const activeNodeRect = useRect(activeNode, measuringConfiguration.draggable.measure, initialActiveNodeRect);\n const containerNodeRect = useRect(activeNode ? activeNode.parentElement : null);\n const sensorContext = useRef({\n activatorEvent: null,\n active: null,\n activeNode,\n collisionRect: null,\n collisions: null,\n droppableRects,\n draggableNodes,\n draggingNode: null,\n draggingNodeRect: null,\n droppableContainers,\n over: null,\n scrollableAncestors: [],\n scrollAdjustedTranslate: null\n });\n const overNode = droppableContainers.getNodeFor((_sensorContext$curren = sensorContext.current.over) == null ? void 0 : _sensorContext$curren.id);\n const dragOverlay = useDragOverlayMeasuring({\n measure: measuringConfiguration.dragOverlay.measure\n }); // Use the rect of the drag overlay if it is mounted\n\n const draggingNode = (_dragOverlay$nodeRef$ = dragOverlay.nodeRef.current) != null ? _dragOverlay$nodeRef$ : activeNode;\n const draggingNodeRect = isInitialized ? (_dragOverlay$rect = dragOverlay.rect) != null ? _dragOverlay$rect : activeNodeRect : null;\n const usesDragOverlay = Boolean(dragOverlay.nodeRef.current && dragOverlay.rect); // The delta between the previous and new position of the draggable node\n // is only relevant when there is no drag overlay\n\n const nodeRectDelta = useRectDelta(usesDragOverlay ? null : activeNodeRect); // Get the window rect of the dragging node\n\n const windowRect = useWindowRect(draggingNode ? getWindow(draggingNode) : null); // Get scrollable ancestors of the dragging node\n\n const scrollableAncestors = useScrollableAncestors(isInitialized ? overNode != null ? overNode : activeNode : null);\n const scrollableAncestorRects = useRects(scrollableAncestors); // Apply modifiers\n\n const modifiedTranslate = applyModifiers(modifiers, {\n transform: {\n x: translate.x - nodeRectDelta.x,\n y: translate.y - nodeRectDelta.y,\n scaleX: 1,\n scaleY: 1\n },\n activatorEvent,\n active,\n activeNodeRect,\n containerNodeRect,\n draggingNodeRect,\n over: sensorContext.current.over,\n overlayNodeRect: dragOverlay.rect,\n scrollableAncestors,\n scrollableAncestorRects,\n windowRect\n });\n const pointerCoordinates = activationCoordinates ? add(activationCoordinates, translate) : null;\n const scrollOffsets = useScrollOffsets(scrollableAncestors); // Represents the scroll delta since dragging was initiated\n\n const scrollAdjustment = useScrollOffsetsDelta(scrollOffsets); // Represents the scroll delta since the last time the active node rect was measured\n\n const activeNodeScrollDelta = useScrollOffsetsDelta(scrollOffsets, [activeNodeRect]);\n const scrollAdjustedTranslate = add(modifiedTranslate, scrollAdjustment);\n const collisionRect = draggingNodeRect ? getAdjustedRect(draggingNodeRect, modifiedTranslate) : null;\n const collisions = active && collisionRect ? collisionDetection({\n active,\n collisionRect,\n droppableRects,\n droppableContainers: enabledDroppableContainers,\n pointerCoordinates\n }) : null;\n const overId = getFirstCollision(collisions, 'id');\n const [over, setOver] = useState(null); // When there is no drag overlay used, we need to account for the\n // window scroll delta\n\n const appliedTranslate = usesDragOverlay ? modifiedTranslate : add(modifiedTranslate, activeNodeScrollDelta);\n const transform = adjustScale(appliedTranslate, (_over$rect = over == null ? void 0 : over.rect) != null ? _over$rect : null, activeNodeRect);\n const activeSensorRef = useRef(null);\n const instantiateSensor = useCallback((event, _ref2) => {\n let {\n sensor: Sensor,\n options\n } = _ref2;\n\n if (activeRef.current == null) {\n return;\n }\n\n const activeNode = draggableNodes.get(activeRef.current);\n\n if (!activeNode) {\n return;\n }\n\n const activatorEvent = event.nativeEvent;\n const sensorInstance = new Sensor({\n active: activeRef.current,\n activeNode,\n event: activatorEvent,\n options,\n // Sensors need to be instantiated with refs for arguments that change over time\n // otherwise they are frozen in time with the stale arguments\n context: sensorContext,\n\n onAbort(id) {\n const draggableNode = draggableNodes.get(id);\n\n if (!draggableNode) {\n return;\n }\n\n const {\n onDragAbort\n } = latestProps.current;\n const event = {\n id\n };\n onDragAbort == null ? void 0 : onDragAbort(event);\n dispatchMonitorEvent({\n type: 'onDragAbort',\n event\n });\n },\n\n onPending(id, constraint, initialCoordinates, offset) {\n const draggableNode = draggableNodes.get(id);\n\n if (!draggableNode) {\n return;\n }\n\n const {\n onDragPending\n } = latestProps.current;\n const event = {\n id,\n constraint,\n initialCoordinates,\n offset\n };\n onDragPending == null ? void 0 : onDragPending(event);\n dispatchMonitorEvent({\n type: 'onDragPending',\n event\n });\n },\n\n onStart(initialCoordinates) {\n const id = activeRef.current;\n\n if (id == null) {\n return;\n }\n\n const draggableNode = draggableNodes.get(id);\n\n if (!draggableNode) {\n return;\n }\n\n const {\n onDragStart\n } = latestProps.current;\n const event = {\n activatorEvent,\n active: {\n id,\n data: draggableNode.data,\n rect: activeRects\n }\n };\n unstable_batchedUpdates(() => {\n onDragStart == null ? void 0 : onDragStart(event);\n setStatus(Status.Initializing);\n dispatch({\n type: Action.DragStart,\n initialCoordinates,\n active: id\n });\n dispatchMonitorEvent({\n type: 'onDragStart',\n event\n });\n setActiveSensor(activeSensorRef.current);\n setActivatorEvent(activatorEvent);\n });\n },\n\n onMove(coordinates) {\n dispatch({\n type: Action.DragMove,\n coordinates\n });\n },\n\n onEnd: createHandler(Action.DragEnd),\n onCancel: createHandler(Action.DragCancel)\n });\n activeSensorRef.current = sensorInstance;\n\n function createHandler(type) {\n return async function handler() {\n const {\n active,\n collisions,\n over,\n scrollAdjustedTranslate\n } = sensorContext.current;\n let event = null;\n\n if (active && scrollAdjustedTranslate) {\n const {\n cancelDrop\n } = latestProps.current;\n event = {\n activatorEvent,\n active: active,\n collisions,\n delta: scrollAdjustedTranslate,\n over\n };\n\n if (type === Action.DragEnd && typeof cancelDrop === 'function') {\n const shouldCancel = await Promise.resolve(cancelDrop(event));\n\n if (shouldCancel) {\n type = Action.DragCancel;\n }\n }\n }\n\n activeRef.current = null;\n unstable_batchedUpdates(() => {\n dispatch({\n type\n });\n setStatus(Status.Uninitialized);\n setOver(null);\n setActiveSensor(null);\n setActivatorEvent(null);\n activeSensorRef.current = null;\n const eventName = type === Action.DragEnd ? 'onDragEnd' : 'onDragCancel';\n\n if (event) {\n const handler = latestProps.current[eventName];\n handler == null ? void 0 : handler(event);\n dispatchMonitorEvent({\n type: eventName,\n event\n });\n }\n });\n };\n }\n }, // eslint-disable-next-line react-hooks/exhaustive-deps\n [draggableNodes]);\n const bindActivatorToSensorInstantiator = useCallback((handler, sensor) => {\n return (event, active) => {\n const nativeEvent = event.nativeEvent;\n const activeDraggableNode = draggableNodes.get(active);\n\n if ( // Another sensor is already instantiating\n activeRef.current !== null || // No active draggable\n !activeDraggableNode || // Event has already been captured\n nativeEvent.dndKit || nativeEvent.defaultPrevented) {\n return;\n }\n\n const activationContext = {\n active: activeDraggableNode\n };\n const shouldActivate = handler(event, sensor.options, activationContext);\n\n if (shouldActivate === true) {\n nativeEvent.dndKit = {\n capturedBy: sensor.sensor\n };\n activeRef.current = active;\n instantiateSensor(event, sensor);\n }\n };\n }, [draggableNodes, instantiateSensor]);\n const activators = useCombineActivators(sensors, bindActivatorToSensorInstantiator);\n useSensorSetup(sensors);\n useIsomorphicLayoutEffect(() => {\n if (activeNodeRect && status === Status.Initializing) {\n setStatus(Status.Initialized);\n }\n }, [activeNodeRect, status]);\n useEffect(() => {\n const {\n onDragMove\n } = latestProps.current;\n const {\n active,\n activatorEvent,\n collisions,\n over\n } = sensorContext.current;\n\n if (!active || !activatorEvent) {\n return;\n }\n\n const event = {\n active,\n activatorEvent,\n collisions,\n delta: {\n x: scrollAdjustedTranslate.x,\n y: scrollAdjustedTranslate.y\n },\n over\n };\n unstable_batchedUpdates(() => {\n onDragMove == null ? void 0 : onDragMove(event);\n dispatchMonitorEvent({\n type: 'onDragMove',\n event\n });\n });\n }, // eslint-disable-next-line react-hooks/exhaustive-deps\n [scrollAdjustedTranslate.x, scrollAdjustedTranslate.y]);\n useEffect(() => {\n const {\n active,\n activatorEvent,\n collisions,\n droppableContainers,\n scrollAdjustedTranslate\n } = sensorContext.current;\n\n if (!active || activeRef.current == null || !activatorEvent || !scrollAdjustedTranslate) {\n return;\n }\n\n const {\n onDragOver\n } = latestProps.current;\n const overContainer = droppableContainers.get(overId);\n const over = overContainer && overContainer.rect.current ? {\n id: overContainer.id,\n rect: overContainer.rect.current,\n data: overContainer.data,\n disabled: overContainer.disabled\n } : null;\n const event = {\n active,\n activatorEvent,\n collisions,\n delta: {\n x: scrollAdjustedTranslate.x,\n y: scrollAdjustedTranslate.y\n },\n over\n };\n unstable_batchedUpdates(() => {\n setOver(over);\n onDragOver == null ? void 0 : onDragOver(event);\n dispatchMonitorEvent({\n type: 'onDragOver',\n event\n });\n });\n }, // eslint-disable-next-line react-hooks/exhaustive-deps\n [overId]);\n useIsomorphicLayoutEffect(() => {\n sensorContext.current = {\n activatorEvent,\n active,\n activeNode,\n collisionRect,\n collisions,\n droppableRects,\n draggableNodes,\n draggingNode,\n draggingNodeRect,\n droppableContainers,\n over,\n scrollableAncestors,\n scrollAdjustedTranslate\n };\n activeRects.current = {\n initial: draggingNodeRect,\n translated: collisionRect\n };\n }, [active, activeNode, collisions, collisionRect, draggableNodes, draggingNode, draggingNodeRect, droppableRects, droppableContainers, over, scrollableAncestors, scrollAdjustedTranslate]);\n useAutoScroller({ ...autoScrollOptions,\n delta: translate,\n draggingRect: collisionRect,\n pointerCoordinates,\n scrollableAncestors,\n scrollableAncestorRects\n });\n const publicContext = useMemo(() => {\n const context = {\n active,\n activeNode,\n activeNodeRect,\n activatorEvent,\n collisions,\n containerNodeRect,\n dragOverlay,\n draggableNodes,\n droppableContainers,\n droppableRects,\n over,\n measureDroppableContainers,\n scrollableAncestors,\n scrollableAncestorRects,\n measuringConfiguration,\n measuringScheduled,\n windowRect\n };\n return context;\n }, [active, activeNode, activeNodeRect, activatorEvent, collisions, containerNodeRect, dragOverlay, draggableNodes, droppableContainers, droppableRects, over, measureDroppableContainers, scrollableAncestors, scrollableAncestorRects, measuringConfiguration, measuringScheduled, windowRect]);\n const internalContext = useMemo(() => {\n const context = {\n activatorEvent,\n activators,\n active,\n activeNodeRect,\n ariaDescribedById: {\n draggable: draggableDescribedById\n },\n dispatch,\n draggableNodes,\n over,\n measureDroppableContainers\n };\n return context;\n }, [activatorEvent, activators, active, activeNodeRect, dispatch, draggableDescribedById, draggableNodes, over, measureDroppableContainers]);\n return React.createElement(DndMonitorContext.Provider, {\n value: registerMonitorListener\n }, React.createElement(InternalContext.Provider, {\n value: internalContext\n }, React.createElement(PublicContext.Provider, {\n value: publicContext\n }, React.createElement(ActiveDraggableContext.Provider, {\n value: transform\n }, children)), React.createElement(RestoreFocus, {\n disabled: (accessibility == null ? void 0 : accessibility.restoreFocus) === false\n })), React.createElement(Accessibility, { ...accessibility,\n hiddenTextDescribedById: draggableDescribedById\n }));\n\n function getAutoScrollerOptions() {\n const activeSensorDisablesAutoscroll = (activeSensor == null ? void 0 : activeSensor.autoScrollEnabled) === false;\n const autoScrollGloballyDisabled = typeof autoScroll === 'object' ? autoScroll.enabled === false : autoScroll === false;\n const enabled = isInitialized && !activeSensorDisablesAutoscroll && !autoScrollGloballyDisabled;\n\n if (typeof autoScroll === 'object') {\n return { ...autoScroll,\n enabled\n };\n }\n\n return {\n enabled\n };\n }\n});\n\nconst NullContext = /*#__PURE__*/createContext(null);\nconst defaultRole = 'button';\nconst ID_PREFIX = 'Draggable';\nfunction useDraggable(_ref) {\n let {\n id,\n data,\n disabled = false,\n attributes\n } = _ref;\n const key = useUniqueId(ID_PREFIX);\n const {\n activators,\n activatorEvent,\n active,\n activeNodeRect,\n ariaDescribedById,\n draggableNodes,\n over\n } = useContext(InternalContext);\n const {\n role = defaultRole,\n roleDescription = 'draggable',\n tabIndex = 0\n } = attributes != null ? attributes : {};\n const isDragging = (active == null ? void 0 : active.id) === id;\n const transform = useContext(isDragging ? ActiveDraggableContext : NullContext);\n const [node, setNodeRef] = useNodeRef();\n const [activatorNode, setActivatorNodeRef] = useNodeRef();\n const listeners = useSyntheticListeners(activators, id);\n const dataRef = useLatestValue(data);\n useIsomorphicLayoutEffect(() => {\n draggableNodes.set(id, {\n id,\n key,\n node,\n activatorNode,\n data: dataRef\n });\n return () => {\n const node = draggableNodes.get(id);\n\n if (node && node.key === key) {\n draggableNodes.delete(id);\n }\n };\n }, // eslint-disable-next-line react-hooks/exhaustive-deps\n [draggableNodes, id]);\n const memoizedAttributes = useMemo(() => ({\n role,\n tabIndex,\n 'aria-disabled': disabled,\n 'aria-pressed': isDragging && role === defaultRole ? true : undefined,\n 'aria-roledescription': roleDescription,\n 'aria-describedby': ariaDescribedById.draggable\n }), [disabled, role, tabIndex, isDragging, roleDescription, ariaDescribedById.draggable]);\n return {\n active,\n activatorEvent,\n activeNodeRect,\n attributes: memoizedAttributes,\n isDragging,\n listeners: disabled ? undefined : listeners,\n node,\n over,\n setNodeRef,\n setActivatorNodeRef,\n transform\n };\n}\n\nfunction useDndContext() {\n return useContext(PublicContext);\n}\n\nconst ID_PREFIX$1 = 'Droppable';\nconst defaultResizeObserverConfig = {\n timeout: 25\n};\nfunction useDroppable(_ref) {\n let {\n data,\n disabled = false,\n id,\n resizeObserverConfig\n } = _ref;\n const key = useUniqueId(ID_PREFIX$1);\n const {\n active,\n dispatch,\n over,\n measureDroppableContainers\n } = useContext(InternalContext);\n const previous = useRef({\n disabled\n });\n const resizeObserverConnected = useRef(false);\n const rect = useRef(null);\n const callbackId = useRef(null);\n const {\n disabled: resizeObserverDisabled,\n updateMeasurementsFor,\n timeout: resizeObserverTimeout\n } = { ...defaultResizeObserverConfig,\n ...resizeObserverConfig\n };\n const ids = useLatestValue(updateMeasurementsFor != null ? updateMeasurementsFor : id);\n const handleResize = useCallback(() => {\n if (!resizeObserverConnected.current) {\n // ResizeObserver invokes the `handleResize` callback as soon as `observe` is called,\n // assuming the element is rendered and displayed.\n resizeObserverConnected.current = true;\n return;\n }\n\n if (callbackId.current != null) {\n clearTimeout(callbackId.current);\n }\n\n callbackId.current = setTimeout(() => {\n measureDroppableContainers(Array.isArray(ids.current) ? ids.current : [ids.current]);\n callbackId.current = null;\n }, resizeObserverTimeout);\n }, //eslint-disable-next-line react-hooks/exhaustive-deps\n [resizeObserverTimeout]);\n const resizeObserver = useResizeObserver({\n callback: handleResize,\n disabled: resizeObserverDisabled || !active\n });\n const handleNodeChange = useCallback((newElement, previousElement) => {\n if (!resizeObserver) {\n return;\n }\n\n if (previousElement) {\n resizeObserver.unobserve(previousElement);\n resizeObserverConnected.current = false;\n }\n\n if (newElement) {\n resizeObserver.observe(newElement);\n }\n }, [resizeObserver]);\n const [nodeRef, setNodeRef] = useNodeRef(handleNodeChange);\n const dataRef = useLatestValue(data);\n useEffect(() => {\n if (!resizeObserver || !nodeRef.current) {\n return;\n }\n\n resizeObserver.disconnect();\n resizeObserverConnected.current = false;\n resizeObserver.observe(nodeRef.current);\n }, [nodeRef, resizeObserver]);\n useEffect(() => {\n dispatch({\n type: Action.RegisterDroppable,\n element: {\n id,\n key,\n disabled,\n node: nodeRef,\n rect,\n data: dataRef\n }\n });\n return () => dispatch({\n type: Action.UnregisterDroppable,\n key,\n id\n });\n }, // eslint-disable-next-line react-hooks/exhaustive-deps\n [id]);\n useEffect(() => {\n if (disabled !== previous.current.disabled) {\n dispatch({\n type: Action.SetDroppableDisabled,\n id,\n key,\n disabled\n });\n previous.current.disabled = disabled;\n }\n }, [id, key, disabled, dispatch]);\n return {\n active,\n rect,\n isOver: (over == null ? void 0 : over.id) === id,\n node: nodeRef,\n over,\n setNodeRef\n };\n}\n\nfunction AnimationManager(_ref) {\n let {\n animation,\n children\n } = _ref;\n const [clonedChildren, setClonedChildren] = useState(null);\n const [element, setElement] = useState(null);\n const previousChildren = usePrevious(children);\n\n if (!children && !clonedChildren && previousChildren) {\n setClonedChildren(previousChildren);\n }\n\n useIsomorphicLayoutEffect(() => {\n if (!element) {\n return;\n }\n\n const key = clonedChildren == null ? void 0 : clonedChildren.key;\n const id = clonedChildren == null ? void 0 : clonedChildren.props.id;\n\n if (key == null || id == null) {\n setClonedChildren(null);\n return;\n }\n\n Promise.resolve(animation(id, element)).then(() => {\n setClonedChildren(null);\n });\n }, [animation, clonedChildren, element]);\n return React.createElement(React.Fragment, null, children, clonedChildren ? cloneElement(clonedChildren, {\n ref: setElement\n }) : null);\n}\n\nconst defaultTransform = {\n x: 0,\n y: 0,\n scaleX: 1,\n scaleY: 1\n};\nfunction NullifiedContextProvider(_ref) {\n let {\n children\n } = _ref;\n return React.createElement(InternalContext.Provider, {\n value: defaultInternalContext\n }, React.createElement(ActiveDraggableContext.Provider, {\n value: defaultTransform\n }, children));\n}\n\nconst baseStyles = {\n position: 'fixed',\n touchAction: 'none'\n};\n\nconst defaultTransition = activatorEvent => {\n const isKeyboardActivator = isKeyboardEvent(activatorEvent);\n return isKeyboardActivator ? 'transform 250ms ease' : undefined;\n};\n\nconst PositionedOverlay = /*#__PURE__*/forwardRef((_ref, ref) => {\n let {\n as,\n activatorEvent,\n adjustScale,\n children,\n className,\n rect,\n style,\n transform,\n transition = defaultTransition\n } = _ref;\n\n if (!rect) {\n return null;\n }\n\n const scaleAdjustedTransform = adjustScale ? transform : { ...transform,\n scaleX: 1,\n scaleY: 1\n };\n const styles = { ...baseStyles,\n width: rect.width,\n height: rect.height,\n top: rect.top,\n left: rect.left,\n transform: CSS.Transform.toString(scaleAdjustedTransform),\n transformOrigin: adjustScale && activatorEvent ? getRelativeTransformOrigin(activatorEvent, rect) : undefined,\n transition: typeof transition === 'function' ? transition(activatorEvent) : transition,\n ...style\n };\n return React.createElement(as, {\n className,\n style: styles,\n ref\n }, children);\n});\n\nconst defaultDropAnimationSideEffects = options => _ref => {\n let {\n active,\n dragOverlay\n } = _ref;\n const originalStyles = {};\n const {\n styles,\n className\n } = options;\n\n if (styles != null && styles.active) {\n for (const [key, value] of Object.entries(styles.active)) {\n if (value === undefined) {\n continue;\n }\n\n originalStyles[key] = active.node.style.getPropertyValue(key);\n active.node.style.setProperty(key, value);\n }\n }\n\n if (styles != null && styles.dragOverlay) {\n for (const [key, value] of Object.entries(styles.dragOverlay)) {\n if (value === undefined) {\n continue;\n }\n\n dragOverlay.node.style.setProperty(key, value);\n }\n }\n\n if (className != null && className.active) {\n active.node.classList.add(className.active);\n }\n\n if (className != null && className.dragOverlay) {\n dragOverlay.node.classList.add(className.dragOverlay);\n }\n\n return function cleanup() {\n for (const [key, value] of Object.entries(originalStyles)) {\n active.node.style.setProperty(key, value);\n }\n\n if (className != null && className.active) {\n active.node.classList.remove(className.active);\n }\n };\n};\n\nconst defaultKeyframeResolver = _ref2 => {\n let {\n transform: {\n initial,\n final\n }\n } = _ref2;\n return [{\n transform: CSS.Transform.toString(initial)\n }, {\n transform: CSS.Transform.toString(final)\n }];\n};\n\nconst defaultDropAnimationConfiguration = {\n duration: 250,\n easing: 'ease',\n keyframes: defaultKeyframeResolver,\n sideEffects: /*#__PURE__*/defaultDropAnimationSideEffects({\n styles: {\n active: {\n opacity: '0'\n }\n }\n })\n};\nfunction useDropAnimation(_ref3) {\n let {\n config,\n draggableNodes,\n droppableContainers,\n measuringConfiguration\n } = _ref3;\n return useEvent((id, node) => {\n if (config === null) {\n return;\n }\n\n const activeDraggable = draggableNodes.get(id);\n\n if (!activeDraggable) {\n return;\n }\n\n const activeNode = activeDraggable.node.current;\n\n if (!activeNode) {\n return;\n }\n\n const measurableNode = getMeasurableNode(node);\n\n if (!measurableNode) {\n return;\n }\n\n const {\n transform\n } = getWindow(node).getComputedStyle(node);\n const parsedTransform = parseTransform(transform);\n\n if (!parsedTransform) {\n return;\n }\n\n const animation = typeof config === 'function' ? config : createDefaultDropAnimation(config);\n scrollIntoViewIfNeeded(activeNode, measuringConfiguration.draggable.measure);\n return animation({\n active: {\n id,\n data: activeDraggable.data,\n node: activeNode,\n rect: measuringConfiguration.draggable.measure(activeNode)\n },\n draggableNodes,\n dragOverlay: {\n node,\n rect: measuringConfiguration.dragOverlay.measure(measurableNode)\n },\n droppableContainers,\n measuringConfiguration,\n transform: parsedTransform\n });\n });\n}\n\nfunction createDefaultDropAnimation(options) {\n const {\n duration,\n easing,\n sideEffects,\n keyframes\n } = { ...defaultDropAnimationConfiguration,\n ...options\n };\n return _ref4 => {\n let {\n active,\n dragOverlay,\n transform,\n ...rest\n } = _ref4;\n\n if (!duration) {\n // Do not animate if animation duration is zero.\n return;\n }\n\n const delta = {\n x: dragOverlay.rect.left - active.rect.left,\n y: dragOverlay.rect.top - active.rect.top\n };\n const scale = {\n scaleX: transform.scaleX !== 1 ? active.rect.width * transform.scaleX / dragOverlay.rect.width : 1,\n scaleY: transform.scaleY !== 1 ? active.rect.height * transform.scaleY / dragOverlay.rect.height : 1\n };\n const finalTransform = {\n x: transform.x - delta.x,\n y: transform.y - delta.y,\n ...scale\n };\n const animationKeyframes = keyframes({ ...rest,\n active,\n dragOverlay,\n transform: {\n initial: transform,\n final: finalTransform\n }\n });\n const [firstKeyframe] = animationKeyframes;\n const lastKeyframe = animationKeyframes[animationKeyframes.length - 1];\n\n if (JSON.stringify(firstKeyframe) === JSON.stringify(lastKeyframe)) {\n // The start and end keyframes are the same, infer that there is no animation needed.\n return;\n }\n\n const cleanup = sideEffects == null ? void 0 : sideEffects({\n active,\n dragOverlay,\n ...rest\n });\n const animation = dragOverlay.node.animate(animationKeyframes, {\n duration,\n easing,\n fill: 'forwards'\n });\n return new Promise(resolve => {\n animation.onfinish = () => {\n cleanup == null ? void 0 : cleanup();\n resolve();\n };\n });\n };\n}\n\nlet key = 0;\nfunction useKey(id) {\n return useMemo(() => {\n if (id == null) {\n return;\n }\n\n key++;\n return key;\n }, [id]);\n}\n\nconst DragOverlay = /*#__PURE__*/React.memo(_ref => {\n let {\n adjustScale = false,\n children,\n dropAnimation: dropAnimationConfig,\n style,\n transition,\n modifiers,\n wrapperElement = 'div',\n className,\n zIndex = 999\n } = _ref;\n const {\n activatorEvent,\n active,\n activeNodeRect,\n containerNodeRect,\n draggableNodes,\n droppableContainers,\n dragOverlay,\n over,\n measuringConfiguration,\n scrollableAncestors,\n scrollableAncestorRects,\n windowRect\n } = useDndContext();\n const transform = useContext(ActiveDraggableContext);\n const key = useKey(active == null ? void 0 : active.id);\n const modifiedTransform = applyModifiers(modifiers, {\n activatorEvent,\n active,\n activeNodeRect,\n containerNodeRect,\n draggingNodeRect: dragOverlay.rect,\n over,\n overlayNodeRect: dragOverlay.rect,\n scrollableAncestors,\n scrollableAncestorRects,\n transform,\n windowRect\n });\n const initialRect = useInitialValue(activeNodeRect);\n const dropAnimation = useDropAnimation({\n config: dropAnimationConfig,\n draggableNodes,\n droppableContainers,\n measuringConfiguration\n }); // We need to wait for the active node to be measured before connecting the drag overlay ref\n // otherwise collisions can be computed against a mispositioned drag overlay\n\n const ref = initialRect ? dragOverlay.setRef : undefined;\n return React.createElement(NullifiedContextProvider, null, React.createElement(AnimationManager, {\n animation: dropAnimation\n }, active && key ? React.createElement(PositionedOverlay, {\n key: key,\n id: active.id,\n ref: ref,\n as: wrapperElement,\n activatorEvent: activatorEvent,\n adjustScale: adjustScale,\n className: className,\n transition: transition,\n rect: initialRect,\n style: {\n zIndex,\n ...style\n },\n transform: modifiedTransform\n }, children) : null));\n});\n\nexport { AutoScrollActivator, DndContext, DragOverlay, KeyboardCode, KeyboardSensor, MeasuringFrequency, MeasuringStrategy, MouseSensor, PointerSensor, TouchSensor, TraversalOrder, applyModifiers, closestCenter, closestCorners, defaultAnnouncements, defaultCoordinates, defaultDropAnimationConfiguration as defaultDropAnimation, defaultDropAnimationSideEffects, defaultKeyboardCoordinateGetter, defaultScreenReaderInstructions, getClientRect, getFirstCollision, getScrollableAncestors, pointerWithin, rectIntersection, useDndContext, useDndMonitor, useDraggable, useDroppable, useSensor, useSensors };\n//# sourceMappingURL=core.esm.js.map\n","import React, { useMemo, useRef, useEffect, useState, useContext } from 'react';\nimport { useDndContext, getClientRect, useDroppable, useDraggable, closestCorners, getFirstCollision, getScrollableAncestors, KeyboardCode } from '@dnd-kit/core';\nimport { useUniqueId, useIsomorphicLayoutEffect, CSS, useCombinedRefs, isKeyboardEvent, subtract } from '@dnd-kit/utilities';\n\n/**\r\n * Move an array item to a different position. Returns a new array with the item moved to the new position.\r\n */\nfunction arrayMove(array, from, to) {\n const newArray = array.slice();\n newArray.splice(to < 0 ? newArray.length + to : to, 0, newArray.splice(from, 1)[0]);\n return newArray;\n}\n\n/**\r\n * Swap an array item to a different position. Returns a new array with the item swapped to the new position.\r\n */\nfunction arraySwap(array, from, to) {\n const newArray = array.slice();\n newArray[from] = array[to];\n newArray[to] = array[from];\n return newArray;\n}\n\nfunction getSortedRects(items, rects) {\n return items.reduce((accumulator, id, index) => {\n const rect = rects.get(id);\n\n if (rect) {\n accumulator[index] = rect;\n }\n\n return accumulator;\n }, Array(items.length));\n}\n\nfunction isValidIndex(index) {\n return index !== null && index >= 0;\n}\n\nfunction itemsEqual(a, b) {\n if (a === b) {\n return true;\n }\n\n if (a.length !== b.length) {\n return false;\n }\n\n for (let i = 0; i < a.length; i++) {\n if (a[i] !== b[i]) {\n return false;\n }\n }\n\n return true;\n}\n\nfunction normalizeDisabled(disabled) {\n if (typeof disabled === 'boolean') {\n return {\n draggable: disabled,\n droppable: disabled\n };\n }\n\n return disabled;\n}\n\n// To-do: We should be calculating scale transformation\nconst defaultScale = {\n scaleX: 1,\n scaleY: 1\n};\nconst horizontalListSortingStrategy = _ref => {\n var _rects$activeIndex;\n\n let {\n rects,\n activeNodeRect: fallbackActiveRect,\n activeIndex,\n overIndex,\n index\n } = _ref;\n const activeNodeRect = (_rects$activeIndex = rects[activeIndex]) != null ? _rects$activeIndex : fallbackActiveRect;\n\n if (!activeNodeRect) {\n return null;\n }\n\n const itemGap = getItemGap(rects, index, activeIndex);\n\n if (index === activeIndex) {\n const newIndexRect = rects[overIndex];\n\n if (!newIndexRect) {\n return null;\n }\n\n return {\n x: activeIndex < overIndex ? newIndexRect.left + newIndexRect.width - (activeNodeRect.left + activeNodeRect.width) : newIndexRect.left - activeNodeRect.left,\n y: 0,\n ...defaultScale\n };\n }\n\n if (index > activeIndex && index <= overIndex) {\n return {\n x: -activeNodeRect.width - itemGap,\n y: 0,\n ...defaultScale\n };\n }\n\n if (index < activeIndex && index >= overIndex) {\n return {\n x: activeNodeRect.width + itemGap,\n y: 0,\n ...defaultScale\n };\n }\n\n return {\n x: 0,\n y: 0,\n ...defaultScale\n };\n};\n\nfunction getItemGap(rects, index, activeIndex) {\n const currentRect = rects[index];\n const previousRect = rects[index - 1];\n const nextRect = rects[index + 1];\n\n if (!currentRect || !previousRect && !nextRect) {\n return 0;\n }\n\n if (activeIndex < index) {\n return previousRect ? currentRect.left - (previousRect.left + previousRect.width) : nextRect.left - (currentRect.left + currentRect.width);\n }\n\n return nextRect ? nextRect.left - (currentRect.left + currentRect.width) : currentRect.left - (previousRect.left + previousRect.width);\n}\n\nconst rectSortingStrategy = _ref => {\n let {\n rects,\n activeIndex,\n overIndex,\n index\n } = _ref;\n const newRects = arrayMove(rects, overIndex, activeIndex);\n const oldRect = rects[index];\n const newRect = newRects[index];\n\n if (!newRect || !oldRect) {\n return null;\n }\n\n return {\n x: newRect.left - oldRect.left,\n y: newRect.top - oldRect.top,\n scaleX: newRect.width / oldRect.width,\n scaleY: newRect.height / oldRect.height\n };\n};\n\nconst rectSwappingStrategy = _ref => {\n let {\n activeIndex,\n index,\n rects,\n overIndex\n } = _ref;\n let oldRect;\n let newRect;\n\n if (index === activeIndex) {\n oldRect = rects[index];\n newRect = rects[overIndex];\n }\n\n if (index === overIndex) {\n oldRect = rects[index];\n newRect = rects[activeIndex];\n }\n\n if (!newRect || !oldRect) {\n return null;\n }\n\n return {\n x: newRect.left - oldRect.left,\n y: newRect.top - oldRect.top,\n scaleX: newRect.width / oldRect.width,\n scaleY: newRect.height / oldRect.height\n };\n};\n\n// To-do: We should be calculating scale transformation\nconst defaultScale$1 = {\n scaleX: 1,\n scaleY: 1\n};\nconst verticalListSortingStrategy = _ref => {\n var _rects$activeIndex;\n\n let {\n activeIndex,\n activeNodeRect: fallbackActiveRect,\n index,\n rects,\n overIndex\n } = _ref;\n const activeNodeRect = (_rects$activeIndex = rects[activeIndex]) != null ? _rects$activeIndex : fallbackActiveRect;\n\n if (!activeNodeRect) {\n return null;\n }\n\n if (index === activeIndex) {\n const overIndexRect = rects[overIndex];\n\n if (!overIndexRect) {\n return null;\n }\n\n return {\n x: 0,\n y: activeIndex < overIndex ? overIndexRect.top + overIndexRect.height - (activeNodeRect.top + activeNodeRect.height) : overIndexRect.top - activeNodeRect.top,\n ...defaultScale$1\n };\n }\n\n const itemGap = getItemGap$1(rects, index, activeIndex);\n\n if (index > activeIndex && index <= overIndex) {\n return {\n x: 0,\n y: -activeNodeRect.height - itemGap,\n ...defaultScale$1\n };\n }\n\n if (index < activeIndex && index >= overIndex) {\n return {\n x: 0,\n y: activeNodeRect.height + itemGap,\n ...defaultScale$1\n };\n }\n\n return {\n x: 0,\n y: 0,\n ...defaultScale$1\n };\n};\n\nfunction getItemGap$1(clientRects, index, activeIndex) {\n const currentRect = clientRects[index];\n const previousRect = clientRects[index - 1];\n const nextRect = clientRects[index + 1];\n\n if (!currentRect) {\n return 0;\n }\n\n if (activeIndex < index) {\n return previousRect ? currentRect.top - (previousRect.top + previousRect.height) : nextRect ? nextRect.top - (currentRect.top + currentRect.height) : 0;\n }\n\n return nextRect ? nextRect.top - (currentRect.top + currentRect.height) : previousRect ? currentRect.top - (previousRect.top + previousRect.height) : 0;\n}\n\nconst ID_PREFIX = 'Sortable';\nconst Context = /*#__PURE__*/React.createContext({\n activeIndex: -1,\n containerId: ID_PREFIX,\n disableTransforms: false,\n items: [],\n overIndex: -1,\n useDragOverlay: false,\n sortedRects: [],\n strategy: rectSortingStrategy,\n disabled: {\n draggable: false,\n droppable: false\n }\n});\nfunction SortableContext(_ref) {\n let {\n children,\n id,\n items: userDefinedItems,\n strategy = rectSortingStrategy,\n disabled: disabledProp = false\n } = _ref;\n const {\n active,\n dragOverlay,\n droppableRects,\n over,\n measureDroppableContainers\n } = useDndContext();\n const containerId = useUniqueId(ID_PREFIX, id);\n const useDragOverlay = Boolean(dragOverlay.rect !== null);\n const items = useMemo(() => userDefinedItems.map(item => typeof item === 'object' && 'id' in item ? item.id : item), [userDefinedItems]);\n const isDragging = active != null;\n const activeIndex = active ? items.indexOf(active.id) : -1;\n const overIndex = over ? items.indexOf(over.id) : -1;\n const previousItemsRef = useRef(items);\n const itemsHaveChanged = !itemsEqual(items, previousItemsRef.current);\n const disableTransforms = overIndex !== -1 && activeIndex === -1 || itemsHaveChanged;\n const disabled = normalizeDisabled(disabledProp);\n useIsomorphicLayoutEffect(() => {\n if (itemsHaveChanged && isDragging) {\n measureDroppableContainers(items);\n }\n }, [itemsHaveChanged, items, isDragging, measureDroppableContainers]);\n useEffect(() => {\n previousItemsRef.current = items;\n }, [items]);\n const contextValue = useMemo(() => ({\n activeIndex,\n containerId,\n disabled,\n disableTransforms,\n items,\n overIndex,\n useDragOverlay,\n sortedRects: getSortedRects(items, droppableRects),\n strategy\n }), // eslint-disable-next-line react-hooks/exhaustive-deps\n [activeIndex, containerId, disabled.draggable, disabled.droppable, disableTransforms, items, overIndex, droppableRects, useDragOverlay, strategy]);\n return React.createElement(Context.Provider, {\n value: contextValue\n }, children);\n}\n\nconst defaultNewIndexGetter = _ref => {\n let {\n id,\n items,\n activeIndex,\n overIndex\n } = _ref;\n return arrayMove(items, activeIndex, overIndex).indexOf(id);\n};\nconst defaultAnimateLayoutChanges = _ref2 => {\n let {\n containerId,\n isSorting,\n wasDragging,\n index,\n items,\n newIndex,\n previousItems,\n previousContainerId,\n transition\n } = _ref2;\n\n if (!transition || !wasDragging) {\n return false;\n }\n\n if (previousItems !== items && index === newIndex) {\n return false;\n }\n\n if (isSorting) {\n return true;\n }\n\n return newIndex !== index && containerId === previousContainerId;\n};\nconst defaultTransition = {\n duration: 200,\n easing: 'ease'\n};\nconst transitionProperty = 'transform';\nconst disabledTransition = /*#__PURE__*/CSS.Transition.toString({\n property: transitionProperty,\n duration: 0,\n easing: 'linear'\n});\nconst defaultAttributes = {\n roleDescription: 'sortable'\n};\n\n/*\r\n * When the index of an item changes while sorting,\r\n * we need to temporarily disable the transforms\r\n */\n\nfunction useDerivedTransform(_ref) {\n let {\n disabled,\n index,\n node,\n rect\n } = _ref;\n const [derivedTransform, setDerivedtransform] = useState(null);\n const previousIndex = useRef(index);\n useIsomorphicLayoutEffect(() => {\n if (!disabled && index !== previousIndex.current && node.current) {\n const initial = rect.current;\n\n if (initial) {\n const current = getClientRect(node.current, {\n ignoreTransform: true\n });\n const delta = {\n x: initial.left - current.left,\n y: initial.top - current.top,\n scaleX: initial.width / current.width,\n scaleY: initial.height / current.height\n };\n\n if (delta.x || delta.y) {\n setDerivedtransform(delta);\n }\n }\n }\n\n if (index !== previousIndex.current) {\n previousIndex.current = index;\n }\n }, [disabled, index, node, rect]);\n useEffect(() => {\n if (derivedTransform) {\n setDerivedtransform(null);\n }\n }, [derivedTransform]);\n return derivedTransform;\n}\n\nfunction useSortable(_ref) {\n let {\n animateLayoutChanges = defaultAnimateLayoutChanges,\n attributes: userDefinedAttributes,\n disabled: localDisabled,\n data: customData,\n getNewIndex = defaultNewIndexGetter,\n id,\n strategy: localStrategy,\n resizeObserverConfig,\n transition = defaultTransition\n } = _ref;\n const {\n items,\n containerId,\n activeIndex,\n disabled: globalDisabled,\n disableTransforms,\n sortedRects,\n overIndex,\n useDragOverlay,\n strategy: globalStrategy\n } = useContext(Context);\n const disabled = normalizeLocalDisabled(localDisabled, globalDisabled);\n const index = items.indexOf(id);\n const data = useMemo(() => ({\n sortable: {\n containerId,\n index,\n items\n },\n ...customData\n }), [containerId, customData, index, items]);\n const itemsAfterCurrentSortable = useMemo(() => items.slice(items.indexOf(id)), [items, id]);\n const {\n rect,\n node,\n isOver,\n setNodeRef: setDroppableNodeRef\n } = useDroppable({\n id,\n data,\n disabled: disabled.droppable,\n resizeObserverConfig: {\n updateMeasurementsFor: itemsAfterCurrentSortable,\n ...resizeObserverConfig\n }\n });\n const {\n active,\n activatorEvent,\n activeNodeRect,\n attributes,\n setNodeRef: setDraggableNodeRef,\n listeners,\n isDragging,\n over,\n setActivatorNodeRef,\n transform\n } = useDraggable({\n id,\n data,\n attributes: { ...defaultAttributes,\n ...userDefinedAttributes\n },\n disabled: disabled.draggable\n });\n const setNodeRef = useCombinedRefs(setDroppableNodeRef, setDraggableNodeRef);\n const isSorting = Boolean(active);\n const displaceItem = isSorting && !disableTransforms && isValidIndex(activeIndex) && isValidIndex(overIndex);\n const shouldDisplaceDragSource = !useDragOverlay && isDragging;\n const dragSourceDisplacement = shouldDisplaceDragSource && displaceItem ? transform : null;\n const strategy = localStrategy != null ? localStrategy : globalStrategy;\n const finalTransform = displaceItem ? dragSourceDisplacement != null ? dragSourceDisplacement : strategy({\n rects: sortedRects,\n activeNodeRect,\n activeIndex,\n overIndex,\n index\n }) : null;\n const newIndex = isValidIndex(activeIndex) && isValidIndex(overIndex) ? getNewIndex({\n id,\n items,\n activeIndex,\n overIndex\n }) : index;\n const activeId = active == null ? void 0 : active.id;\n const previous = useRef({\n activeId,\n items,\n newIndex,\n containerId\n });\n const itemsHaveChanged = items !== previous.current.items;\n const shouldAnimateLayoutChanges = animateLayoutChanges({\n active,\n containerId,\n isDragging,\n isSorting,\n id,\n index,\n items,\n newIndex: previous.current.newIndex,\n previousItems: previous.current.items,\n previousContainerId: previous.current.containerId,\n transition,\n wasDragging: previous.current.activeId != null\n });\n const derivedTransform = useDerivedTransform({\n disabled: !shouldAnimateLayoutChanges,\n index,\n node,\n rect\n });\n useEffect(() => {\n if (isSorting && previous.current.newIndex !== newIndex) {\n previous.current.newIndex = newIndex;\n }\n\n if (containerId !== previous.current.containerId) {\n previous.current.containerId = containerId;\n }\n\n if (items !== previous.current.items) {\n previous.current.items = items;\n }\n }, [isSorting, newIndex, containerId, items]);\n useEffect(() => {\n if (activeId === previous.current.activeId) {\n return;\n }\n\n if (activeId != null && previous.current.activeId == null) {\n previous.current.activeId = activeId;\n return;\n }\n\n const timeoutId = setTimeout(() => {\n previous.current.activeId = activeId;\n }, 50);\n return () => clearTimeout(timeoutId);\n }, [activeId]);\n return {\n active,\n activeIndex,\n attributes,\n data,\n rect,\n index,\n newIndex,\n items,\n isOver,\n isSorting,\n isDragging,\n listeners,\n node,\n overIndex,\n over,\n setNodeRef,\n setActivatorNodeRef,\n setDroppableNodeRef,\n setDraggableNodeRef,\n transform: derivedTransform != null ? derivedTransform : finalTransform,\n transition: getTransition()\n };\n\n function getTransition() {\n if ( // Temporarily disable transitions for a single frame to set up derived transforms\n derivedTransform || // Or to prevent items jumping to back to their \"new\" position when items change\n itemsHaveChanged && previous.current.newIndex === index) {\n return disabledTransition;\n }\n\n if (shouldDisplaceDragSource && !isKeyboardEvent(activatorEvent) || !transition) {\n return undefined;\n }\n\n if (isSorting || shouldAnimateLayoutChanges) {\n return CSS.Transition.toString({ ...transition,\n property: transitionProperty\n });\n }\n\n return undefined;\n }\n}\n\nfunction normalizeLocalDisabled(localDisabled, globalDisabled) {\n var _localDisabled$dragga, _localDisabled$droppa;\n\n if (typeof localDisabled === 'boolean') {\n return {\n draggable: localDisabled,\n // Backwards compatibility\n droppable: false\n };\n }\n\n return {\n draggable: (_localDisabled$dragga = localDisabled == null ? void 0 : localDisabled.draggable) != null ? _localDisabled$dragga : globalDisabled.draggable,\n droppable: (_localDisabled$droppa = localDisabled == null ? void 0 : localDisabled.droppable) != null ? _localDisabled$droppa : globalDisabled.droppable\n };\n}\n\nfunction hasSortableData(entry) {\n if (!entry) {\n return false;\n }\n\n const data = entry.data.current;\n\n if (data && 'sortable' in data && typeof data.sortable === 'object' && 'containerId' in data.sortable && 'items' in data.sortable && 'index' in data.sortable) {\n return true;\n }\n\n return false;\n}\n\nconst directions = [KeyboardCode.Down, KeyboardCode.Right, KeyboardCode.Up, KeyboardCode.Left];\nconst sortableKeyboardCoordinates = (event, _ref) => {\n let {\n context: {\n active,\n collisionRect,\n droppableRects,\n droppableContainers,\n over,\n scrollableAncestors\n }\n } = _ref;\n\n if (directions.includes(event.code)) {\n event.preventDefault();\n\n if (!active || !collisionRect) {\n return;\n }\n\n const filteredContainers = [];\n droppableContainers.getEnabled().forEach(entry => {\n if (!entry || entry != null && entry.disabled) {\n return;\n }\n\n const rect = droppableRects.get(entry.id);\n\n if (!rect) {\n return;\n }\n\n switch (event.code) {\n case KeyboardCode.Down:\n if (collisionRect.top < rect.top) {\n filteredContainers.push(entry);\n }\n\n break;\n\n case KeyboardCode.Up:\n if (collisionRect.top > rect.top) {\n filteredContainers.push(entry);\n }\n\n break;\n\n case KeyboardCode.Left:\n if (collisionRect.left > rect.left) {\n filteredContainers.push(entry);\n }\n\n break;\n\n case KeyboardCode.Right:\n if (collisionRect.left < rect.left) {\n filteredContainers.push(entry);\n }\n\n break;\n }\n });\n const collisions = closestCorners({\n active,\n collisionRect: collisionRect,\n droppableRects,\n droppableContainers: filteredContainers,\n pointerCoordinates: null\n });\n let closestId = getFirstCollision(collisions, 'id');\n\n if (closestId === (over == null ? void 0 : over.id) && collisions.length > 1) {\n closestId = collisions[1].id;\n }\n\n if (closestId != null) {\n const activeDroppable = droppableContainers.get(active.id);\n const newDroppable = droppableContainers.get(closestId);\n const newRect = newDroppable ? droppableRects.get(newDroppable.id) : null;\n const newNode = newDroppable == null ? void 0 : newDroppable.node.current;\n\n if (newNode && newRect && activeDroppable && newDroppable) {\n const newScrollAncestors = getScrollableAncestors(newNode);\n const hasDifferentScrollAncestors = newScrollAncestors.some((element, index) => scrollableAncestors[index] !== element);\n const hasSameContainer = isSameContainer(activeDroppable, newDroppable);\n const isAfterActive = isAfter(activeDroppable, newDroppable);\n const offset = hasDifferentScrollAncestors || !hasSameContainer ? {\n x: 0,\n y: 0\n } : {\n x: isAfterActive ? collisionRect.width - newRect.width : 0,\n y: isAfterActive ? collisionRect.height - newRect.height : 0\n };\n const rectCoordinates = {\n x: newRect.left,\n y: newRect.top\n };\n const newCoordinates = offset.x && offset.y ? rectCoordinates : subtract(rectCoordinates, offset);\n return newCoordinates;\n }\n }\n }\n\n return undefined;\n};\n\nfunction isSameContainer(a, b) {\n if (!hasSortableData(a) || !hasSortableData(b)) {\n return false;\n }\n\n return a.data.current.sortable.containerId === b.data.current.sortable.containerId;\n}\n\nfunction isAfter(a, b) {\n if (!hasSortableData(a) || !hasSortableData(b)) {\n return false;\n }\n\n if (!isSameContainer(a, b)) {\n return false;\n }\n\n return a.data.current.sortable.index < b.data.current.sortable.index;\n}\n\nexport { SortableContext, arrayMove, arraySwap, defaultAnimateLayoutChanges, defaultNewIndexGetter, hasSortableData, horizontalListSortingStrategy, rectSortingStrategy, rectSwappingStrategy, sortableKeyboardCoordinates, useSortable, verticalListSortingStrategy };\n//# sourceMappingURL=sortable.esm.js.map\n","import { useState, useEffect, useCallback, useMemo } from 'react';\nimport { arrayMove } from '@dnd-kit/sortable';\nimport type { OpenResource, OpenResourcesManager } from '@semiont/react-ui';\n\n/**\n * Hook that provides OpenResourcesManager implementation using localStorage\n * This is the app-level implementation that gets passed to components as props\n */\nexport function useOpenResourcesManager(): OpenResourcesManager {\n const [openResources, setOpenResources] = useState<OpenResource[]>([]);\n const [isInitialized, setIsInitialized] = useState(false);\n\n // Load from localStorage on mount\n useEffect(() => {\n const stored = localStorage.getItem('openDocuments');\n if (stored) {\n try {\n const resources = JSON.parse(stored) as OpenResource[];\n // Sort by order if present, otherwise by openedAt (for backward compatibility)\n setOpenResources(resources.sort((a, b) => {\n if (a.order !== undefined && b.order !== undefined) {\n return a.order - b.order;\n }\n return a.openedAt - b.openedAt;\n }));\n } catch (e) {\n console.error('Failed to parse open resources:', e);\n }\n }\n setIsInitialized(true);\n }, []);\n\n // Save to localStorage whenever resources change (but not on initial mount)\n useEffect(() => {\n if (isInitialized) {\n localStorage.setItem('openDocuments', JSON.stringify(openResources));\n }\n }, [openResources, isInitialized]);\n\n // Listen for storage events from other tabs\n useEffect(() => {\n const handleStorageChange = (e: StorageEvent) => {\n if (e.key === 'openDocuments' && e.newValue) {\n try {\n const resources = JSON.parse(e.newValue) as OpenResource[];\n // Sort by order if present, otherwise by openedAt\n setOpenResources(resources.sort((a, b) => {\n if (a.order !== undefined && b.order !== undefined) {\n return a.order - b.order;\n }\n return a.openedAt - b.openedAt;\n }));\n } catch (err) {\n console.error('Failed to parse open resources from storage event:', err);\n }\n }\n };\n\n window.addEventListener('storage', handleStorageChange);\n return () => window.removeEventListener('storage', handleStorageChange);\n }, []);\n\n const addResource = useCallback((id: string, name: string, mediaType?: string, storageUri?: string) => {\n setOpenResources(prev => {\n const existing = prev.find(resource => resource.id === id);\n if (existing) {\n // Update name, mediaType, and storageUri if resource already exists\n return prev.map(resource =>\n resource.id === id ? { ...resource, name, ...(mediaType && { mediaType }), ...(storageUri && { storageUri }) } : resource\n );\n }\n // Add new resource with order = max order + 1\n const maxOrder = prev.length > 0\n ? Math.max(...prev.map(r => r.order ?? r.openedAt))\n : 0;\n return [...prev, { id, name, openedAt: Date.now(), order: maxOrder + 1, ...(mediaType && { mediaType }), ...(storageUri && { storageUri }) }];\n });\n }, []);\n\n const removeResource = useCallback((id: string) => {\n setOpenResources(prev => prev.filter(resource => resource.id !== id));\n }, []);\n\n const updateResourceName = useCallback((id: string, name: string) => {\n setOpenResources(prev =>\n prev.map(resource => resource.id === id ? { ...resource, name } : resource)\n );\n }, []);\n\n const reorderResources = useCallback((oldIndex: number, newIndex: number) => {\n setOpenResources(prev => {\n const reordered = arrayMove(prev, oldIndex, newIndex);\n // Update order field to preserve the new position\n return reordered.map((resource, index) => ({\n ...resource,\n order: index\n }));\n });\n }, []);\n\n return useMemo(\n () => ({\n openResources,\n addResource,\n removeResource,\n updateResourceName,\n reorderResources\n }),\n [openResources, addResource, removeResource, updateResourceName, reorderResources]\n );\n}\n","import { useMemo } from 'react';\nimport { useQueryClient } from '@tanstack/react-query';\nimport type { CacheManager } from '@semiont/react-ui';\nimport type { ResourceId } from '@semiont/core';\n\n/**\n * Frontend implementation of CacheManager using React Query\n *\n * Usage:\n * ```typescript\n * const cacheManager = useCacheManager();\n * <CacheProvider cacheManager={cacheManager}>\n * <YourComponents />\n * </CacheProvider>\n * ```\n */\nexport function useCacheManager(): CacheManager {\n const queryClient = useQueryClient();\n\n return useMemo(() => ({\n invalidateAnnotations: (rUri: ResourceId) => {\n queryClient.invalidateQueries({ queryKey: ['resources', rUri, 'annotations'] });\n },\n invalidateEvents: (rUri: ResourceId) => {\n queryClient.invalidateQueries({ queryKey: ['resources', rUri, 'events'] });\n }\n }), [queryClient]);\n}\n","import { useContext } from 'react';\nimport { Outlet } from 'react-router-dom';\nimport { useTranslation } from 'react-i18next';\nimport { KnowledgeSidebarWrapper } from '@/components/knowledge/KnowledgeSidebarWrapper';\nimport { Footer, ResourceAnnotationsProvider, OpenResourcesProvider, CacheProvider, ApiClientProvider, AuthTokenProvider, useGlobalEvents, useAttentionStream } from '@semiont/react-ui';\nimport { CookiePreferences } from '@/components/CookiePreferences';\nimport { KeyboardShortcutsContext } from '@/contexts/KeyboardShortcutsContext';\nimport { Link, routes } from '@/lib/routing';\nimport { useOpenResourcesManager } from '@/hooks/useOpenResourcesManager';\nimport { useCacheManager } from '@/hooks/useCacheManager';\nimport { useAuth } from '@/hooks/useAuth';\nimport { useRouter } from '@/i18n/routing';\nimport { SEMIONT_BACKEND_URL } from '@/lib/env';\n\nfunction GlobalEventsConnector() {\n useGlobalEvents();\n return null;\n}\n\nfunction AttentionStreamConnector() {\n useAttentionStream();\n return null;\n}\n\nexport default function KnowledgeLayout() {\n const { t } = useTranslation();\n const keyboardContext = useContext(KeyboardShortcutsContext);\n const openResourcesManager = useOpenResourcesManager();\n const cacheManager = useCacheManager();\n const { token: authToken, isLoading } = useAuth();\n const router = useRouter();\n\n if (isLoading) {\n return (\n <div className=\"h-screen flex items-center justify-center\">\n <div className=\"text-center\">\n <div className=\"animate-spin rounded-full h-12 w-12 border-b-2 border-blue-600 mx-auto mb-4\"></div>\n <p className=\"text-gray-600 dark:text-gray-400\">Loading...</p>\n </div>\n </div>\n );\n }\n\n if (!authToken) {\n router.push(`/auth/signin?callbackUrl=${encodeURIComponent(typeof window !== 'undefined' ? window.location.pathname : '/know')}`);\n return null;\n }\n\n return (\n <AuthTokenProvider token={authToken}>\n <ApiClientProvider baseUrl={SEMIONT_BACKEND_URL}>\n <CacheProvider cacheManager={cacheManager}>\n <OpenResourcesProvider openResourcesManager={openResourcesManager}>\n <ResourceAnnotationsProvider>\n <GlobalEventsConnector />\n <AttentionStreamConnector />\n <div className=\"h-screen semiont-knowledge-layout semiont-layout-with-footer flex flex-col overflow-hidden\">\n <div className=\"flex flex-1 overflow-hidden\">\n <KnowledgeSidebarWrapper />\n <main className=\"flex-1 w-full px-2 pb-6 flex flex-col overflow-hidden\">\n <div className=\"w-full mx-auto flex-1 flex flex-col h-full overflow-hidden\">\n <Outlet />\n </div>\n </main>\n </div>\n <Footer\n Link={Link}\n routes={routes}\n t={(key: string) => t(`Footer.${key}`)}\n CookiePreferences={CookiePreferences}\n {...(keyboardContext?.openKeyboardHelp && { onOpenKeyboardHelp: keyboardContext.openKeyboardHelp })}\n />\n </div>\n </ResourceAnnotationsProvider>\n </OpenResourcesProvider>\n </CacheProvider>\n </ApiClientProvider>\n </AuthTokenProvider>\n );\n}\n"],"names":["PlusIcon","title","titleId","props","svgRef","React.createElement","ForwardRef","React.forwardRef","TelescopeIcon","className","jsx","HrefLink","href","_to","Link","KnowledgeNavigation","isCollapsed","toggleCollapsed","navigationMenu","_t","useTranslation","t","k","p","pathname","usePathname","router","useRouter","openResources","removeResource","reorderResources","useOpenResources","fixedNavigation","handleSidebarToggle","useCallback","handleResourceClose","resourceId","handleResourceReorder","oldIndex","newIndex","useEventSubscriptions","handleNavigate","path","getResourceHref","CollapsibleResourceNavigation","ChevronLeftIcon","Bars3Icon","XMarkIcon","KnowledgeSidebarWrapper","_tHome","tHome","isAuthenticated","isAdmin","isModerator","useAuth","LeftSidebar","routes","Action","defaultCoordinates","Direction","EventName","KeyboardCode","MouseButton","AutoScrollActivator","TraversalOrder","MeasuringStrategy","MeasuringFrequency","Status","arrayMove","array","from","to","newArray","useOpenResourcesManager","setOpenResources","useState","isInitialized","setIsInitialized","useEffect","stored","resources","a","b","e","handleStorageChange","err","addResource","id","name","mediaType","storageUri","prev","resource","maxOrder","r","updateResourceName","index","useMemo","useCacheManager","queryClient","useQueryClient","rUri","GlobalEventsConnector","useGlobalEvents","AttentionStreamConnector","useAttentionStream","KnowledgeLayout","keyboardContext","useContext","KeyboardShortcutsContext","openResourcesManager","cacheManager","authToken","isLoading","jsxs","AuthTokenProvider","ApiClientProvider","SEMIONT_BACKEND_URL","CacheProvider","OpenResourcesProvider","ResourceAnnotationsProvider","Outlet","Footer","key","CookiePreferences"],"mappings":"yoBACA,SAASA,GAAS,CAChB,MAAAC,EACA,QAAAC,EACA,GAAGC,CACL,EAAGC,EAAQ,CACT,OAAoBC,gBAAoB,MAAO,OAAO,OAAO,CAC3D,MAAO,6BACP,KAAM,OACN,QAAS,YACT,YAAa,IACb,OAAQ,eACR,cAAe,OACf,YAAa,OACb,IAAKD,EACL,kBAAmBF,CACvB,EAAKC,CAAK,EAAGF,EAAqBI,EAAAA,cAAoB,QAAS,CAC3D,GAAIH,CACR,EAAKD,CAAK,EAAI,KAAmBI,EAAAA,cAAoB,OAAQ,CACzD,cAAe,QACf,eAAgB,QAChB,EAAG,wBACP,CAAG,CAAC,CACJ,CACA,MAAMC,GAA2BC,EAAAA,WAAiBP,EAAQ,ECVpDQ,GAAgB,CAAC,CAAE,UAAAC,CAAA,IACvBC,EAAAA,IAAC,OAAA,CAAK,UAAAD,EAAsB,MAAO,CAAE,SAAU,UAAW,WAAY,GAAA,EAAO,SAAA,KAAE,EAUjF,SAASE,GAAS,CAAE,KAAAC,EAAM,GAAIC,EAAK,GAAGV,GAAgE,CACpG,aAAQW,EAAA,CAAK,GAAKF,GAAQ,GAAgB,GAAGT,EAAO,CACtD,CAEO,SAASY,GAAoB,CAAE,YAAAC,EAAa,gBAAAC,EAAiB,eAAAC,GAA4C,CAC9G,KAAM,CAAE,EAAGC,CAAA,EAAOC,EAAA,EACZC,EAAI,CAACC,EAAWC,IAAgCJ,EAAG,WAAWG,CAAC,GAAIC,CAAQ,EAC3EC,EAAWC,EAAA,EACXC,EAASC,EAAA,EACT,CAAE,cAAAC,EAAe,eAAAC,EAAgB,iBAAAC,CAAA,EAAqBC,EAAA,EAEtDC,EAAoC,CACxC,CACE,KAAMX,EAAE,UAAU,EAClB,KAAM,iBACN,KAAMb,GACN,YAAaa,EAAE,iBAAiB,CAAA,EAElC,CACE,KAAMA,EAAE,SAAS,EACjB,KAAM,gBACN,KAAMrB,GACN,YAAaqB,EAAE,oBAAoB,CAAA,CACrC,EAIIY,EAAsBC,EAAAA,YAAY,IAAM,CAC5CjB,EAAA,CACF,EAAG,CAACA,CAAe,CAAC,EAGdkB,EAAsBD,EAAAA,YAAY,CAAC,CAAE,WAAAE,KAAyC,CAClFP,EAAeO,CAAU,EAGrBZ,IAAa,kBAAkBY,CAAU,IAC3CV,EAAO,KAAK,gBAAgB,CAEhC,EAAG,CAACG,EAAgBL,EAAUE,CAAM,CAAC,EAG/BW,EAAwBH,EAAAA,YAAY,CAAC,CAAE,SAAAI,EAAU,SAAAC,KAAuD,CAC5GT,EAAiBQ,EAAUC,CAAQ,CACrC,EAAG,CAACT,CAAgB,CAAC,EAGrBU,EAAsB,CACpB,wBAAyBP,EACzB,wBAAyBE,EACzB,0BAA2BE,CAAA,CAC5B,EAGD,MAAMI,EAAkBC,GAAiB,CACvChB,EAAO,KAAKgB,CAAI,CAClB,EAGMC,EAAmBP,GAChB,kBAAkBA,CAAU,GAGrC,OACE1B,EAAAA,IAACkC,EAAA,CACC,WAAYZ,EACZ,UAAWJ,EACX,YAAAZ,EACA,YAAaQ,EACb,cAAeb,GACf,WAAY8B,EACZ,gBAAAE,EACA,UAAU,uBACV,aAAc,CACZ,MAAOtB,EAAE,OAAO,CAAA,EAElB,MAAO,CACL,YAAawB,GACb,KAAMC,EACN,MAAOC,CAAA,EAET,eAAA7B,CAAA,CAAA,CAGN,CCtGO,SAAS8B,IAA0B,CACxC,KAAM,CAAE,EAAG7B,CAAA,EAAOC,EAAA,EACZC,EAAI,CAACC,EAAWC,IAAgCJ,EAAG,cAAcG,CAAC,GAAIC,CAAQ,EAC9E,CAAE,EAAG0B,CAAA,EAAW7B,EAAA,EAChB8B,EAAQ,CAAC5B,EAAWC,IAAgC0B,EAAO,QAAQ3B,CAAC,GAAIC,CAAQ,EAChF,CAAE,gBAAA4B,EAAiB,QAAAC,EAAS,YAAAC,CAAA,EAAgBC,EAAA,EAElD,OACE5C,EAAAA,IAAC6C,EAAA,CAAA,KACCzC,EACA,OAAA0C,EACA,EAAAnC,EACA,MAAA6B,EACA,aAAa,IACb,YAAa,GACb,WAAW,wBACX,gBAAAC,EACA,QAAAC,EACA,YAAAC,EAEC,SAAA,CAACrC,EAAaC,EAAiBC,IAC9BR,EAAAA,IAACK,GAAA,CACC,YAAAC,EACA,gBAAAC,EACA,eAAAC,CAAA,CAAA,CACF,CAAA,CAIR,CC0IA,IAAIuC,GAEH,SAAUA,EAAQ,CACjBA,EAAO,UAAe,YACtBA,EAAO,SAAc,WACrBA,EAAO,QAAa,UACpBA,EAAO,WAAgB,aACvBA,EAAO,SAAc,WACrBA,EAAO,kBAAuB,oBAC9BA,EAAO,qBAA0B,uBACjCA,EAAO,oBAAyB,qBAClC,GAAGA,IAAWA,EAAS,CAAA,EAAG,EAqB1B,MAAMC,GAAkC,OAAO,OAAO,CACpD,EAAG,EACH,EAAG,CACL,CAAC,EA4jBD,IAAIC,GAEH,SAAUA,EAAW,CACpBA,EAAUA,EAAU,QAAa,CAAC,EAAI,UACtCA,EAAUA,EAAU,SAAc,EAAE,EAAI,UAC1C,GAAGA,IAAcA,EAAY,CAAA,EAAG,EAuRhC,IAAIC,GAEH,SAAUA,EAAW,CACpBA,EAAU,MAAW,QACrBA,EAAU,UAAe,YACzBA,EAAU,QAAa,UACvBA,EAAU,YAAiB,cAC3BA,EAAU,OAAY,SACtBA,EAAU,gBAAqB,kBAC/BA,EAAU,iBAAsB,kBAClC,GAAGA,IAAcA,EAAY,CAAA,EAAG,EAShC,IAAIC,GAEH,SAAUA,EAAc,CACvBA,EAAa,MAAW,QACxBA,EAAa,KAAU,YACvBA,EAAa,MAAW,aACxBA,EAAa,KAAU,YACvBA,EAAa,GAAQ,UACrBA,EAAa,IAAS,SACtBA,EAAa,MAAW,QACxBA,EAAa,IAAS,KACxB,GAAGA,IAAiBA,EAAe,CAAA,EAAG,EAG5BA,EAAa,MAAOA,EAAa,MAChCA,EAAa,IAChBA,EAAa,MAAOA,EAAa,MAAOA,EAAa,IAgjB7D,IAAIC,GAEH,SAAUA,EAAa,CACtBA,EAAYA,EAAY,WAAgB,CAAC,EAAI,YAC/C,GAAGA,IAAgBA,EAAc,CAAA,EAAG,EAsFpC,IAAIC,GAEH,SAAUA,EAAqB,CAC9BA,EAAoBA,EAAoB,QAAa,CAAC,EAAI,UAC1DA,EAAoBA,EAAoB,cAAmB,CAAC,EAAI,eAClE,GAAGA,IAAwBA,EAAsB,CAAA,EAAG,EAEpD,IAAIC,GAEH,SAAUA,EAAgB,CACzBA,EAAeA,EAAe,UAAe,CAAC,EAAI,YAClDA,EAAeA,EAAe,kBAAuB,CAAC,EAAI,mBAC5D,GAAGA,IAAmBA,EAAiB,CAAA,EAAG,EAkHrCL,EAAU,SAAV,GACAA,EAAU,QAAV,GAGAA,EAAU,SAAV,GACAA,EAAU,QAAV,GAgEL,IAAIM,GAEH,SAAUA,EAAmB,CAC5BA,EAAkBA,EAAkB,OAAY,CAAC,EAAI,SACrDA,EAAkBA,EAAkB,eAAoB,CAAC,EAAI,iBAC7DA,EAAkBA,EAAkB,cAAmB,CAAC,EAAI,eAC9D,GAAGA,IAAsBA,EAAoB,CAAA,EAAG,EAEhD,IAAIC,GAEH,SAAUA,EAAoB,CAC7BA,EAAmB,UAAe,WACpC,GAAGA,IAAuBA,EAAqB,CAAA,EAAG,EA8gBpCD,EAAkB,cACjBC,EAAmB,WAsWwB,CAAE,GAAGR,EAG/D,GACA,IAAIS,GAEH,SAAUA,EAAQ,CACjBA,EAAOA,EAAO,cAAmB,CAAC,EAAI,gBACtCA,EAAOA,EAAO,aAAkB,CAAC,EAAI,eACrCA,EAAOA,EAAO,YAAiB,CAAC,EAAI,aACtC,GAAGA,IAAWA,EAAS,CAAA,EAAG,EC7xF1B,SAASC,GAAUC,EAAOC,EAAMC,EAAI,CAClC,MAAMC,EAAWH,EAAM,MAAK,EAC5B,OAAAG,EAAS,OAAOD,EAAK,EAAIC,EAAS,OAASD,EAAKA,EAAI,EAAGC,EAAS,OAAOF,EAAM,CAAC,EAAE,CAAC,CAAC,EAC3EE,CACT,CAooBoBX,EAAa,KAAMA,EAAa,MAAOA,EAAa,GAAIA,EAAa,KCvoBlF,SAASY,IAAgD,CAC9D,KAAM,CAAC7C,EAAe8C,CAAgB,EAAIC,EAAAA,SAAyB,CAAA,CAAE,EAC/D,CAACC,EAAeC,CAAgB,EAAIF,EAAAA,SAAS,EAAK,EAGxDG,EAAAA,UAAU,IAAM,CACd,MAAMC,EAAS,aAAa,QAAQ,eAAe,EACnD,GAAIA,EACF,GAAI,CACF,MAAMC,EAAY,KAAK,MAAMD,CAAM,EAEnCL,EAAiBM,EAAU,KAAK,CAACC,EAAGC,IAC9BD,EAAE,QAAU,QAAaC,EAAE,QAAU,OAChCD,EAAE,MAAQC,EAAE,MAEdD,EAAE,SAAWC,EAAE,QACvB,CAAC,CACJ,OAASC,EAAG,CACV,QAAQ,MAAM,kCAAmCA,CAAC,CACpD,CAEFN,EAAiB,EAAI,CACvB,EAAG,CAAA,CAAE,EAGLC,EAAAA,UAAU,IAAM,CACVF,GACF,aAAa,QAAQ,gBAAiB,KAAK,UAAUhD,CAAa,CAAC,CAEvE,EAAG,CAACA,EAAegD,CAAa,CAAC,EAGjCE,EAAAA,UAAU,IAAM,CACd,MAAMM,EAAuBD,GAAoB,CAC/C,GAAIA,EAAE,MAAQ,iBAAmBA,EAAE,SACjC,GAAI,CACF,MAAMH,EAAY,KAAK,MAAMG,EAAE,QAAQ,EAEvCT,EAAiBM,EAAU,KAAK,CAACC,EAAGC,IAC9BD,EAAE,QAAU,QAAaC,EAAE,QAAU,OAChCD,EAAE,MAAQC,EAAE,MAEdD,EAAE,SAAWC,EAAE,QACvB,CAAC,CACJ,OAASG,EAAK,CACZ,QAAQ,MAAM,qDAAsDA,CAAG,CACzE,CAEJ,EAEA,cAAO,iBAAiB,UAAWD,CAAmB,EAC/C,IAAM,OAAO,oBAAoB,UAAWA,CAAmB,CACxE,EAAG,CAAA,CAAE,EAEL,MAAME,EAAcpD,EAAAA,YAAY,CAACqD,EAAYC,EAAcC,EAAoBC,IAAwB,CACrGhB,EAAiBiB,GAAQ,CAEvB,GADiBA,EAAK,KAAKC,GAAYA,EAAS,KAAOL,CAAE,EAGvD,OAAOI,EAAK,OACVC,EAAS,KAAOL,EAAK,CAAE,GAAGK,EAAU,KAAAJ,EAAM,GAAIC,GAAa,CAAE,UAAAA,GAAc,GAAIC,GAAc,CAAE,WAAAA,CAAA,GAAkBE,CAAA,EAIrH,MAAMC,EAAWF,EAAK,OAAS,EAC3B,KAAK,IAAI,GAAGA,EAAK,OAASG,EAAE,OAASA,EAAE,QAAQ,CAAC,EAChD,EACJ,MAAO,CAAC,GAAGH,EAAM,CAAE,GAAAJ,EAAI,KAAAC,EAAM,SAAU,KAAK,MAAO,MAAOK,EAAW,EAAG,GAAIJ,GAAa,CAAE,UAAAA,CAAA,EAAc,GAAIC,GAAc,CAAE,WAAAA,CAAA,EAAe,CAC9I,CAAC,CACH,EAAG,CAAA,CAAE,EAEC7D,EAAiBK,cAAaqD,GAAe,CACjDb,KAAyBiB,EAAK,UAAmBC,EAAS,KAAOL,CAAE,CAAC,CACtE,EAAG,CAAA,CAAE,EAECQ,EAAqB7D,EAAAA,YAAY,CAACqD,EAAYC,IAAiB,CACnEd,EAAiBiB,GACfA,EAAK,IAAIC,GAAYA,EAAS,KAAOL,EAAK,CAAE,GAAGK,EAAU,KAAAJ,CAAA,EAASI,CAAQ,CAAA,CAE9E,EAAG,CAAA,CAAE,EAEC9D,EAAmBI,EAAAA,YAAY,CAACI,EAAkBC,IAAqB,CAC3EmC,EAAiBiB,GACGvB,GAAUuB,EAAMrD,EAAUC,CAAQ,EAEnC,IAAI,CAACqD,EAAUI,KAAW,CACzC,GAAGJ,EACH,MAAOI,CAAA,EACP,CACH,CACH,EAAG,CAAA,CAAE,EAEL,OAAOC,EAAAA,QACL,KAAO,CACL,cAAArE,EACA,YAAA0D,EACA,eAAAzD,EACA,mBAAAkE,EACA,iBAAAjE,CAAA,GAEF,CAACF,EAAe0D,EAAazD,EAAgBkE,EAAoBjE,CAAgB,CAAA,CAErF,CC9FO,SAASoE,IAAgC,CAC9C,MAAMC,EAAcC,EAAA,EAEpB,OAAOH,EAAAA,QAAQ,KAAO,CACpB,sBAAwBI,GAAqB,CAC3CF,EAAY,kBAAkB,CAAE,SAAU,CAAC,YAAaE,EAAM,aAAa,EAAG,CAChF,EACA,iBAAmBA,GAAqB,CACtCF,EAAY,kBAAkB,CAAE,SAAU,CAAC,YAAaE,EAAM,QAAQ,EAAG,CAC3E,CAAA,GACE,CAACF,CAAW,CAAC,CACnB,CCbA,SAASG,IAAwB,CAC/B,OAAAC,EAAA,EACO,IACT,CAEA,SAASC,IAA2B,CAClC,OAAAC,EAAA,EACO,IACT,CAEA,SAAwBC,IAAkB,CACxC,KAAM,CAAE,EAAArF,CAAA,EAAMD,EAAA,EACRuF,EAAkBC,EAAAA,WAAWC,EAAwB,EACrDC,EAAuBrC,GAAA,EACvBsC,EAAeb,GAAA,EACf,CAAE,MAAOc,EAAW,UAAAC,CAAA,EAAc3D,EAAA,EAClC5B,EAASC,EAAA,EAEf,OAAIsF,QAEC,MAAA,CAAI,UAAU,4CACb,SAAAC,EAAAA,KAAC,MAAA,CAAI,UAAU,cACb,SAAA,CAAAxG,EAAAA,IAAC,MAAA,CAAI,UAAU,6EAAA,CAA8E,EAC7FA,EAAAA,IAAC,IAAA,CAAE,UAAU,mCAAmC,SAAA,YAAA,CAAU,CAAA,CAAA,CAC5D,CAAA,CACF,EAICsG,EAMHtG,MAACyG,EAAA,CAAkB,MAAOH,EACxB,eAACI,EAAA,CAAkB,QAASC,GAC1B,SAAA3G,MAAC4G,GAAc,aAAAP,EACb,SAAArG,EAAAA,IAAC6G,EAAA,CAAsB,qBAAAT,EACrB,gBAACU,EAAA,CACC,SAAA,CAAA9G,EAAAA,IAAC4F,GAAA,EAAsB,QACtBE,GAAA,EAAyB,EAC1BU,EAAAA,KAAC,MAAA,CAAI,UAAU,6FACb,SAAA,CAAAA,EAAAA,KAAC,MAAA,CAAI,UAAU,8BACb,SAAA,CAAAxG,EAAAA,IAACsC,GAAA,EAAwB,EACzBtC,EAAAA,IAAC,OAAA,CAAK,UAAU,wDACd,SAAAA,EAAAA,IAAC,MAAA,CAAI,UAAU,6DACb,SAAAA,EAAAA,IAAC+G,EAAA,CAAA,CAAO,CAAA,CACV,CAAA,CACF,CAAA,EACF,EACA/G,EAAAA,IAACgH,EAAA,CAAA,KACC5G,EACA,OAAA0C,EACA,EAAImE,GAAgBtG,EAAE,UAAUsG,CAAG,EAAE,EACrC,kBAAAC,EACC,IAAIjB,GAAA,YAAAA,EAAiB,mBAAoB,CAAE,mBAAoBA,EAAgB,gBAAA,CAAiB,CAAA,CACnG,CAAA,CACF,CAAA,CAAA,CACF,CAAA,CACF,EACF,CAAA,CACF,CAAA,CACF,GAjCAjF,EAAO,KAAK,4BAA4B,mBAAmB,OAAO,OAAW,IAAc,OAAO,SAAS,SAAW,OAAO,CAAC,EAAE,EACzH,KAkCX","x_google_ignoreList":[0,3,4]}
@@ -1,6 +0,0 @@
1
- import{j as c,Q as on,M as ln,a as sn,b as an}from"./query-ATBhtd3K.js";import{r as a,R as y,j as un,t as st,O as cn}from"./vendor-EnoIVk-c.js";import{l as dn,ag as Be,ah as at,ai as ut,aj as fn,ak as mn,al as pn,am as hn,an as vn,ao as gn,ap as yn,aq as bn,ar as jt,as as St,at as xn,au as wn}from"./en-LNW2A3RA-CQBvSBCl.js";import{a as En,C as jn,b as Sn,i as $n,c as Cn,s as We}from"./privacy-D5H-YTl9.js";import{a as $t}from"./routing-tt0MahYa.js";import{A as kn,u as Tn}from"./AuthContext-xM132UqD.js";import{u as Pn}from"./useAuth-Bw_w8L0H.js";import{u as Ct}from"./i18n-BYxb14hm.js";import"./index-IyxbPWuo.js";function Nn(){const e=$t(),t=a.useCallback(({url:r,cancelFallback:o})=>{o(),e.push(r)},[e]),n=a.useCallback(({path:r})=>{e.push(r)},[e]);return dn({"browse:external-navigate":t,"browse:router-push":n}),null}class Fn extends y.Component{constructor(t){super(t),this.handleReset=()=>{this.setState({hasError:!1,error:null})},this.handleSignIn=()=>{window.location.href=`/auth/signin?callbackUrl=${encodeURIComponent(window.location.pathname)}`},this.state={hasError:!1,error:null}}static getDerivedStateFromError(t){return{hasError:!0,error:t}}componentDidCatch(t,n){}render(){var t,n,r,o,i,u;if(this.state.hasError){const l=((n=(t=this.state.error)==null?void 0:t.message)==null?void 0:n.toLowerCase().includes("auth"))||((o=(r=this.state.error)==null?void 0:r.message)==null?void 0:o.toLowerCase().includes("session"))||((u=(i=this.state.error)==null?void 0:i.message)==null?void 0:u.toLowerCase().includes("token"));return c.jsx("div",{className:"min-h-[400px] flex items-center justify-center p-4",children:c.jsxs("div",{className:"max-w-md w-full bg-white dark:bg-gray-800 rounded-lg shadow-lg p-6",children:[c.jsxs("div",{className:"flex items-center gap-3 mb-4",children:[c.jsx("div",{className:"flex-shrink-0 w-10 h-10 bg-red-100 dark:bg-red-900/30 rounded-full flex items-center justify-center",children:c.jsx("svg",{className:"w-6 h-6 text-red-600 dark:text-red-400",fill:"none",stroke:"currentColor",viewBox:"0 0 24 24",children:c.jsx("path",{strokeLinecap:"round",strokeLinejoin:"round",strokeWidth:2,d:"M12 9v2m0 4h.01m-6.938 4h13.856c1.54 0 2.502-1.667 1.732-3L13.732 4c-.77-1.333-2.694-1.333-3.464 0L3.34 16c-.77 1.333.192 3 1.732 3z"})})}),c.jsx("h2",{className:"text-xl font-semibold text-gray-900 dark:text-white",children:l?"Authentication Error":"Something went wrong"})]}),c.jsx("p",{className:"text-gray-600 dark:text-gray-300 mb-6",children:l?"There was a problem with your authentication. Please try signing in again.":"An unexpected error occurred. Please try refreshing the page."}),!1,c.jsx("div",{className:"flex gap-3",children:l?c.jsxs(c.Fragment,{children:[c.jsx("button",{onClick:this.handleReset,className:"flex-1 px-4 py-2 text-gray-600 hover:text-gray-800 dark:text-gray-400 dark:hover:text-gray-200 transition-colors",children:"Try Again"}),c.jsx("button",{onClick:this.handleSignIn,className:"flex-1 px-4 py-2 bg-blue-600 text-white rounded-lg hover:bg-blue-700 transition-colors",children:"Sign In"})]}):c.jsx("button",{onClick:()=>window.location.reload(),className:"w-full px-4 py-2 bg-blue-600 text-white rounded-lg hover:bg-blue-700 transition-colors",children:"Refresh Page"})})]})})}return this.props.children}}function An(){const{token:e}=Pn(),[t,n]=a.useState(null);return a.useEffect(()=>{if(e)try{const r=e.split(".");if(r.length===3&&r[1]){const o=JSON.parse(atob(r[1]));o.exp&&n(new Date(o.exp*1e3))}}catch{n(null)}else n(null)},[e]),a.useMemo(()=>{const r=Date.now(),o=t?t.getTime()-r:null;return{isAuthenticated:!!e,expiresAt:t,timeUntilExpiry:o,isExpiringSoon:o!==null&&o<300*1e3&&o>0}},[e,t])}function Rn(){const{i18n:e}=Ct();return a.useMemo(()=>({t:(t,n,r)=>{var u;const o=e.getResourceBundle(e.language,"translation");let i=(u=o==null?void 0:o[t])==null?void 0:u[n];if(!i)return`${t}.${n}`;if(r&&typeof i=="string"){let l=i;return Object.entries(r).forEach(([s,d])=>{l=l.replace(new RegExp(`\\{${s}\\}`,"g"),String(d))}),l}return i}}),[e,e.language])}function On(){return new on({queryCache:new sn({onError:e=>{e instanceof Be&&(e.status===401?at("Your session has expired. Please sign in again."):e.status===403&&ut("You do not have permission to access this resource."))}}),mutationCache:new ln({onError:e=>{e instanceof Be&&(e.status===401?at("Your session has expired. Please sign in again."):e.status===403&&ut("You do not have permission to perform this action."))}}),defaultOptions:{queries:{retry:(e,t)=>t instanceof Be&&(t.status===401||t.status===403||t.status>=400&&t.status<500)?!1:e<3,retryDelay:e=>Math.min(1e3*2**e,3e4),staleTime:300*1e3,refetchOnWindowFocus:!1}}})}function Ln({children:e,queryClient:t}){const n=An(),r=Rn();return c.jsx(Fn,{children:c.jsx(fn,{sessionManager:n,children:c.jsx(mn,{translationManager:r,children:c.jsx(an,{client:t,children:c.jsx(pn,{children:c.jsx(hn,{children:c.jsx(En,{children:c.jsx(vn,{children:c.jsxs(gn,{children:[c.jsx(Nn,{}),e]})})})})})})})})})}function Dn({children:e}){const[t]=a.useState(()=>On());return c.jsx(kn,{children:c.jsx(Ln,{queryClient:t,children:e})})}function Mn({title:e,titleId:t,...n},r){return a.createElement("svg",Object.assign({xmlns:"http://www.w3.org/2000/svg",fill:"none",viewBox:"0 0 24 24",strokeWidth:1.5,stroke:"currentColor","aria-hidden":"true","data-slot":"icon",ref:r,"aria-labelledby":t},n),e?a.createElement("title",{id:t},e):null,a.createElement("path",{strokeLinecap:"round",strokeLinejoin:"round",d:"m19.5 8.25-7.5 7.5-7.5-7.5"}))}const In=a.forwardRef(Mn);function _n({title:e,titleId:t,...n},r){return a.createElement("svg",Object.assign({xmlns:"http://www.w3.org/2000/svg",fill:"none",viewBox:"0 0 24 24",strokeWidth:1.5,stroke:"currentColor","aria-hidden":"true","data-slot":"icon",ref:r,"aria-labelledby":t},n),e?a.createElement("title",{id:t},e):null,a.createElement("path",{strokeLinecap:"round",strokeLinejoin:"round",d:"m4.5 15.75 7.5-7.5 7.5 7.5"}))}const Bn=a.forwardRef(_n);function Wn({className:e=""}){const{t}=Ct(),n=(h,w)=>t(`CookieBanner.${h}`,w),[r,o]=a.useState(!1),[i,u]=a.useState(!1),[l,s]=a.useState(!1),[d,f]=a.useState("GENERAL"),[p,m]=a.useState({necessary:!0,analytics:!1,marketing:!1,preferences:!1});a.useEffect(()=>{(async()=>{if(Sn()){o(!0);try{const[w,N]=await Promise.all([$n(),Cn()]);f(w?"GDPR":N?"CCPA":"GENERAL")}catch(w){console.error("Failed to detect region:",w),f("GENERAL")}}})()},[]);const v=async()=>{s(!0);try{const h={necessary:!0,analytics:!0,marketing:!0,preferences:!0};await Promise.resolve(We(h)),o(!1)}catch(h){console.error("Failed to save cookie consent:",h)}finally{s(!1)}},g=async()=>{s(!0);try{const h={necessary:!0,analytics:!1,marketing:!1,preferences:!1};await Promise.resolve(We(h)),o(!1)}catch(h){console.error("Failed to save cookie consent:",h)}finally{s(!1)}},x=async()=>{s(!0);try{await Promise.resolve(We(p)),o(!1)}catch(h){console.error("Failed to save cookie consent:",h)}finally{s(!1)}},b=h=>{h!=="necessary"&&m(w=>({...w,[h]:!w[h]}))},$=()=>{switch(d){case"GDPR":return{title:n("gdprTitle"),description:n("gdprDescription"),learnMore:n("gdprLearnMore")};case"CCPA":return{title:n("ccpaTitle"),description:n("ccpaDescription"),learnMore:n("ccpaLearnMore")};default:return{title:n("generalTitle"),description:n("generalDescription"),learnMore:n("generalLearnMore")}}};if(!r)return null;const S=$();return c.jsx("div",{className:e,style:{position:"fixed",bottom:0,left:0,right:0,zIndex:50,backgroundColor:"var(--semiont-bg-primary)",borderTop:"1px solid var(--semiont-border-primary)",boxShadow:"var(--semiont-shadow-lg)"},children:c.jsx("div",{style:{maxWidth:"80rem",margin:"0 auto",padding:"1rem 1.5rem"},children:c.jsxs("div",{style:{display:"flex",flexDirection:"column",gap:"1rem"},children:[c.jsxs("div",{style:{display:"flex",alignItems:"center",justifyContent:"space-between",gap:"1.5rem",flexWrap:"wrap"},children:[c.jsxs("div",{style:{flex:1,minWidth:"300px"},children:[c.jsx("h3",{style:{fontSize:"1.125rem",fontWeight:600,color:"var(--semiont-text-primary)",marginBottom:"0.5rem"},children:S.title}),c.jsx("p",{style:{fontSize:"var(--semiont-text-sm, 0.875rem)",color:"var(--semiont-text-secondary)",marginBottom:"0.25rem"},children:S.description}),c.jsx("p",{style:{fontSize:"var(--semiont-text-xs, 0.75rem)",color:"var(--semiont-text-tertiary)"},children:S.learnMore})]}),c.jsxs("div",{style:{display:"flex",gap:"0.75rem",alignItems:"center",flexWrap:"wrap"},children:[c.jsxs("button",{type:"button",onClick:()=>u(!i),className:"semiont-button--secondary",style:{display:"flex",alignItems:"center",gap:"0.25rem"},children:[n("customize"),i?c.jsx(Bn,{style:{width:"1rem",height:"1rem"}}):c.jsx(In,{style:{width:"1rem",height:"1rem"}})]}),d!=="GDPR"&&c.jsx("button",{type:"button",onClick:g,disabled:l,className:"semiont-button--secondary",children:n(l?"saving":"rejectAll")}),c.jsx("button",{type:"button",onClick:v,disabled:l,className:"semiont-button--primary",children:n(l?"saving":"acceptAll")})]})]}),i&&c.jsx("div",{style:{borderTop:"1px solid var(--semiont-border-primary)",paddingTop:"1rem"},children:c.jsxs("div",{style:{display:"flex",flexDirection:"column",gap:"1rem"},children:[c.jsx("h4",{style:{fontSize:"1rem",fontWeight:500,color:"var(--semiont-text-primary)"},children:n("cookiePreferences")}),c.jsx("div",{style:{display:"flex",flexDirection:"column",gap:"0.75rem"},children:jn.map(h=>c.jsxs("div",{style:{display:"flex",alignItems:"flex-start",gap:"0.75rem"},children:[c.jsx("div",{style:{display:"flex",alignItems:"center",height:"1.25rem"},children:c.jsx("input",{id:`cookie-${h.id}`,type:"checkbox",checked:p[h.id]||!1,onChange:()=>b(h.id),disabled:h.required||l,style:{accentColor:"var(--semiont-color-primary-600, #2563eb)"}})}),c.jsxs("div",{style:{flex:1,minWidth:0},children:[c.jsxs("label",{htmlFor:`cookie-${h.id}`,style:{fontSize:"var(--semiont-text-sm, 0.875rem)",fontWeight:500,color:"var(--semiont-text-primary)",cursor:"pointer"},children:[h.name,h.required&&c.jsx("span",{style:{fontSize:"var(--semiont-text-xs, 0.75rem)",color:"var(--semiont-text-tertiary)",marginLeft:"0.25rem"},children:n("required")})]}),c.jsx("p",{style:{fontSize:"var(--semiont-text-xs, 0.75rem)",color:"var(--semiont-text-secondary)",marginTop:"0.25rem"},children:h.description}),c.jsxs("details",{style:{marginTop:"0.25rem"},children:[c.jsx("summary",{style:{fontSize:"var(--semiont-text-xs, 0.75rem)",color:"var(--semiont-color-primary-600, #2563eb)",cursor:"pointer"},children:n("viewCookies")}),c.jsx("div",{style:{marginTop:"0.25rem",fontSize:"var(--semiont-text-xs, 0.75rem)",color:"var(--semiont-text-tertiary)"},children:h.cookies.join(", ")})]})]})]},h.id))}),c.jsxs("div",{style:{display:"flex",justifyContent:"flex-end",gap:"0.75rem",paddingTop:"1rem"},children:[c.jsx("button",{type:"button",onClick:()=>u(!1),className:"semiont-button--secondary",children:n("cancel")}),c.jsx("button",{type:"button",onClick:x,disabled:l,className:"semiont-button--primary",children:n(l?"saving":"savePreferences")})]})]})})]})})})}var Hn=Object.defineProperty,Un=(e,t,n)=>t in e?Hn(e,t,{enumerable:!0,configurable:!0,writable:!0,value:n}):e[t]=n,He=(e,t,n)=>(Un(e,typeof t!="symbol"?t+"":t,n),n);let Gn=class{constructor(){He(this,"current",this.detect()),He(this,"handoffState","pending"),He(this,"currentId",0)}set(t){this.current!==t&&(this.handoffState="pending",this.currentId=0,this.current=t)}reset(){this.set(this.detect())}nextId(){return++this.currentId}get isServer(){return this.current==="server"}get isClient(){return this.current==="client"}detect(){return typeof window>"u"||typeof document>"u"?"server":"client"}handoff(){this.handoffState==="pending"&&(this.handoffState="complete")}get isHandoffComplete(){return this.handoffState==="complete"}},D=new Gn;function pe(e){var t;return D.isServer?null:e==null?document:(t=e==null?void 0:e.ownerDocument)!=null?t:document}function Ye(e){var t,n;return D.isServer?null:e==null?document:(n=(t=e==null?void 0:e.getRootNode)==null?void 0:t.call(e))!=null?n:document}function kt(e){var t,n;return(n=(t=Ye(e))==null?void 0:t.activeElement)!=null?n:null}function zn(e){return kt(e)===e}function Te(e){typeof queueMicrotask=="function"?queueMicrotask(e):Promise.resolve().then(e).catch(t=>setTimeout(()=>{throw t}))}function H(){let e=[],t={addEventListener(n,r,o,i){return n.addEventListener(r,o,i),t.add(()=>n.removeEventListener(r,o,i))},requestAnimationFrame(...n){let r=requestAnimationFrame(...n);return t.add(()=>cancelAnimationFrame(r))},nextFrame(...n){return t.requestAnimationFrame(()=>t.requestAnimationFrame(...n))},setTimeout(...n){let r=setTimeout(...n);return t.add(()=>clearTimeout(r))},microTask(...n){let r={current:!0};return Te(()=>{r.current&&n[0]()}),t.add(()=>{r.current=!1})},style(n,r,o){let i=n.style.getPropertyValue(r);return Object.assign(n.style,{[r]:o}),this.add(()=>{Object.assign(n.style,{[r]:i})})},group(n){let r=H();return n(r),this.add(()=>r.dispose())},add(n){return e.includes(n)||e.push(n),()=>{let r=e.indexOf(n);if(r>=0)for(let o of e.splice(r,1))o()}},dispose(){for(let n of e.splice(0))n()}};return t}function Pe(){let[e]=a.useState(H);return a.useEffect(()=>()=>e.dispose(),[e]),e}let k=(e,t)=>{D.isServer?a.useEffect(e,t):a.useLayoutEffect(e,t)};function te(e){let t=a.useRef(e);return k(()=>{t.current=e},[e]),t}let j=function(e){let t=te(e);return y.useCallback((...n)=>t.current(...n),[t])};function he(e){return a.useMemo(()=>e,Object.values(e))}let Yn=a.createContext(void 0);function qn(){return a.useContext(Yn)}function qe(...e){return Array.from(new Set(e.flatMap(t=>typeof t=="string"?t.split(" "):[]))).filter(Boolean).join(" ")}function W(e,t,...n){if(e in t){let o=t[e];return typeof o=="function"?o(...n):o}let r=new Error(`Tried to handle "${e}" but there is no handler defined. Only defined handlers are: ${Object.keys(t).map(o=>`"${o}"`).join(", ")}.`);throw Error.captureStackTrace&&Error.captureStackTrace(r,W),r}var $e=(e=>(e[e.None=0]="None",e[e.RenderStrategy=1]="RenderStrategy",e[e.Static=2]="Static",e))($e||{}),z=(e=>(e[e.Unmount=0]="Unmount",e[e.Hidden=1]="Hidden",e))(z||{});function A(){let e=Kn();return a.useCallback(t=>Vn({mergeRefs:e,...t}),[e])}function Vn({ourProps:e,theirProps:t,slot:n,defaultTag:r,features:o,visible:i=!0,name:u,mergeRefs:l}){l=l??Xn;let s=Tt(t,e);if(i)return je(s,n,r,u,l);let d=o??0;if(d&2){let{static:f=!1,...p}=s;if(f)return je(p,n,r,u,l)}if(d&1){let{unmount:f=!0,...p}=s;return W(f?0:1,{0(){return null},1(){return je({...p,hidden:!0,style:{display:"none"}},n,r,u,l)}})}return je(s,n,r,u,l)}function je(e,t={},n,r,o){let{as:i=n,children:u,refName:l="ref",...s}=Ue(e,["unmount","static"]),d=e.ref!==void 0?{[l]:e.ref}:{},f=typeof u=="function"?u(t):u;"className"in s&&s.className&&typeof s.className=="function"&&(s.className=s.className(t)),s["aria-labelledby"]&&s["aria-labelledby"]===s.id&&(s["aria-labelledby"]=void 0);let p={};if(t){let m=!1,v=[];for(let[g,x]of Object.entries(t))typeof x=="boolean"&&(m=!0),x===!0&&v.push(g.replace(/([A-Z])/g,b=>`-${b.toLowerCase()}`));if(m){p["data-headlessui-state"]=v.join(" ");for(let g of v)p[`data-${g}`]=""}}if(de(i)&&(Object.keys(X(s)).length>0||Object.keys(X(p)).length>0))if(!a.isValidElement(f)||Array.isArray(f)&&f.length>1||Zn(f)){if(Object.keys(X(s)).length>0)throw new Error(['Passing props on "Fragment"!',"",`The current component <${r} /> is rendering a "Fragment".`,"However we need to passthrough the following props:",Object.keys(X(s)).concat(Object.keys(X(p))).map(m=>` - ${m}`).join(`
2
- `),"","You can apply a few solutions:",['Add an `as="..."` prop, to ensure that we render an actual element instead of a "Fragment".',"Render a single element as the child so that we can forward the props onto that element."].map(m=>` - ${m}`).join(`
3
- `)].join(`
4
- `))}else{let m=f.props,v=m==null?void 0:m.className,g=typeof v=="function"?(...$)=>qe(v(...$),s.className):qe(v,s.className),x=g?{className:g}:{},b=Tt(f.props,X(Ue(s,["ref"])));for(let $ in p)$ in b&&delete p[$];return a.cloneElement(f,Object.assign({},b,p,d,{ref:o(Qn(f),d.ref)},x))}return a.createElement(i,Object.assign({},Ue(s,["ref"]),!de(i)&&d,!de(i)&&p),f)}function Kn(){let e=a.useRef([]),t=a.useCallback(n=>{for(let r of e.current)r!=null&&(typeof r=="function"?r(n):r.current=n)},[]);return(...n)=>{if(!n.every(r=>r==null))return e.current=n,t}}function Xn(...e){return e.every(t=>t==null)?void 0:t=>{for(let n of e)n!=null&&(typeof n=="function"?n(t):n.current=t)}}function Tt(...e){if(e.length===0)return{};if(e.length===1)return e[0];let t={},n={};for(let r of e)for(let o in r)o.startsWith("on")&&typeof r[o]=="function"?(n[o]!=null||(n[o]=[]),n[o].push(r[o])):t[o]=r[o];if(t.disabled||t["aria-disabled"])for(let r in n)/^(on(?:Click|Pointer|Mouse|Key)(?:Down|Up|Press)?)$/.test(r)&&(n[r]=[o=>{var i;return(i=o==null?void 0:o.preventDefault)==null?void 0:i.call(o)}]);for(let r in n)Object.assign(t,{[r](o,...i){let u=n[r];for(let l of u){if((o instanceof Event||(o==null?void 0:o.nativeEvent)instanceof Event)&&o.defaultPrevented)return;l(o,...i)}}});return t}function T(e){var t;return Object.assign(a.forwardRef(e),{displayName:(t=e.displayName)!=null?t:e.name})}function X(e){let t=Object.assign({},e);for(let n in t)t[n]===void 0&&delete t[n];return t}function Ue(e,t=[]){let n=Object.assign({},e);for(let r of t)r in n&&delete n[r];return n}function Qn(e){return y.version.split(".")[0]>="19"?e.props.ref:e.ref}function de(e){return e===a.Fragment||e===Symbol.for("react.fragment")}function Zn(e){return de(e.type)}let Jn="span";var Ce=(e=>(e[e.None=1]="None",e[e.Focusable=2]="Focusable",e[e.Hidden=4]="Hidden",e))(Ce||{});function er(e,t){var n;let{features:r=1,...o}=e,i={ref:t,"aria-hidden":(r&2)===2?!0:(n=o["aria-hidden"])!=null?n:void 0,hidden:(r&4)===4?!0:void 0,style:{position:"fixed",top:1,left:1,width:1,height:0,padding:0,margin:-1,overflow:"hidden",clip:"rect(0, 0, 0, 0)",whiteSpace:"nowrap",borderWidth:"0",...(r&4)===4&&(r&2)!==2&&{display:"none"}}};return A()({ourProps:i,theirProps:o,slot:{},defaultTag:Jn,name:"Hidden"})}let Ve=T(er);function tr(e){return typeof e!="object"||e===null?!1:"nodeType"in e}function q(e){return tr(e)&&"tagName"in e}function J(e){return q(e)&&"accessKey"in e}function Y(e){return q(e)&&"tabIndex"in e}function nr(e){return q(e)&&"style"in e}function rr(e){return J(e)&&e.nodeName==="IFRAME"}function or(e){return J(e)&&e.nodeName==="INPUT"}let Pt=Symbol();function ir(e,t=!0){return Object.assign(e,{[Pt]:t})}function M(...e){let t=a.useRef(e);a.useEffect(()=>{t.current=e},[e]);let n=j(r=>{for(let o of t.current)o!=null&&(typeof o=="function"?o(r):o.current=r)});return e.every(r=>r==null||(r==null?void 0:r[Pt]))?void 0:n}let Je=a.createContext(null);Je.displayName="DescriptionContext";function Nt(){let e=a.useContext(Je);if(e===null){let t=new Error("You used a <Description /> component, but it is not inside a relevant parent.");throw Error.captureStackTrace&&Error.captureStackTrace(t,Nt),t}return e}function lr(){let[e,t]=a.useState([]);return[e.length>0?e.join(" "):void 0,a.useMemo(()=>function(n){let r=j(i=>(t(u=>[...u,i]),()=>t(u=>{let l=u.slice(),s=l.indexOf(i);return s!==-1&&l.splice(s,1),l}))),o=a.useMemo(()=>({register:r,slot:n.slot,name:n.name,props:n.props,value:n.value}),[r,n.slot,n.name,n.props,n.value]);return y.createElement(Je.Provider,{value:o},n.children)},[t])]}let sr="p";function ar(e,t){let n=a.useId(),r=qn(),{id:o=`headlessui-description-${n}`,...i}=e,u=Nt(),l=M(t);k(()=>u.register(o),[o,u.register]);let s=he({...u.slot,disabled:r||!1}),d={ref:l,...u.props,id:o};return A()({ourProps:d,theirProps:i,slot:s,defaultTag:sr,name:u.name||"Description"})}let ur=T(ar),cr=Object.assign(ur,{});var Ft=(e=>(e.Space=" ",e.Enter="Enter",e.Escape="Escape",e.Backspace="Backspace",e.Delete="Delete",e.ArrowLeft="ArrowLeft",e.ArrowUp="ArrowUp",e.ArrowRight="ArrowRight",e.ArrowDown="ArrowDown",e.Home="Home",e.End="End",e.PageUp="PageUp",e.PageDown="PageDown",e.Tab="Tab",e))(Ft||{});let dr=a.createContext(()=>{});function fr({value:e,children:t}){return y.createElement(dr.Provider,{value:e},t)}let At=class extends Map{constructor(t){super(),this.factory=t}get(t){let n=super.get(t);return n===void 0&&(n=this.factory(t),this.set(t,n)),n}};var mr=Object.defineProperty,pr=(e,t,n)=>t in e?mr(e,t,{enumerable:!0,configurable:!0,writable:!0,value:n}):e[t]=n,hr=(e,t,n)=>(pr(e,t+"",n),n),Rt=(e,t,n)=>{if(!t.has(e))throw TypeError("Cannot "+n)},F=(e,t,n)=>(Rt(e,t,"read from private field"),n?n.call(e):t.get(e)),Ge=(e,t,n)=>{if(t.has(e))throw TypeError("Cannot add the same private member more than once");t instanceof WeakSet?t.add(e):t.set(e,n)},ct=(e,t,n,r)=>(Rt(e,t,"write to private field"),t.set(e,n),n),L,ae,ue;let vr=class{constructor(t){Ge(this,L,{}),Ge(this,ae,new At(()=>new Set)),Ge(this,ue,new Set),hr(this,"disposables",H()),ct(this,L,t),D.isServer&&this.disposables.microTask(()=>{this.dispose()})}dispose(){this.disposables.dispose()}get state(){return F(this,L)}subscribe(t,n){if(D.isServer)return()=>{};let r={selector:t,callback:n,current:t(F(this,L))};return F(this,ue).add(r),this.disposables.add(()=>{F(this,ue).delete(r)})}on(t,n){return D.isServer?()=>{}:(F(this,ae).get(t).add(n),this.disposables.add(()=>{F(this,ae).get(t).delete(n)}))}send(t){let n=this.reduce(F(this,L),t);if(n!==F(this,L)){ct(this,L,n);for(let r of F(this,ue)){let o=r.selector(F(this,L));Ot(r.current,o)||(r.current=o,r.callback(o))}for(let r of F(this,ae).get(t.type))r(F(this,L),t)}}};L=new WeakMap,ae=new WeakMap,ue=new WeakMap;function Ot(e,t){return Object.is(e,t)?!0:typeof e!="object"||e===null||typeof t!="object"||t===null?!1:Array.isArray(e)&&Array.isArray(t)?e.length!==t.length?!1:ze(e[Symbol.iterator](),t[Symbol.iterator]()):e instanceof Map&&t instanceof Map||e instanceof Set&&t instanceof Set?e.size!==t.size?!1:ze(e.entries(),t.entries()):dt(e)&&dt(t)?ze(Object.entries(e)[Symbol.iterator](),Object.entries(t)[Symbol.iterator]()):!1}function ze(e,t){do{let n=e.next(),r=t.next();if(n.done&&r.done)return!0;if(n.done||r.done||!Object.is(n.value,r.value))return!1}while(!0)}function dt(e){if(Object.prototype.toString.call(e)!=="[object Object]")return!1;let t=Object.getPrototypeOf(e);return t===null||Object.getPrototypeOf(t)===null}var gr=Object.defineProperty,yr=(e,t,n)=>t in e?gr(e,t,{enumerable:!0,configurable:!0,writable:!0,value:n}):e[t]=n,ft=(e,t,n)=>(yr(e,typeof t!="symbol"?t+"":t,n),n),br=(e=>(e[e.Push=0]="Push",e[e.Pop=1]="Pop",e))(br||{});let xr={0(e,t){let n=t.id,r=e.stack,o=e.stack.indexOf(n);if(o!==-1){let i=e.stack.slice();return i.splice(o,1),i.push(n),r=i,{...e,stack:r}}return{...e,stack:[...e.stack,n]}},1(e,t){let n=t.id,r=e.stack.indexOf(n);if(r===-1)return e;let o=e.stack.slice();return o.splice(r,1),{...e,stack:o}}},wr=class Lt extends vr{constructor(){super(...arguments),ft(this,"actions",{push:t=>this.send({type:0,id:t}),pop:t=>this.send({type:1,id:t})}),ft(this,"selectors",{isTop:(t,n)=>t.stack[t.stack.length-1]===n,inStack:(t,n)=>t.stack.includes(n)})}static new(){return new Lt({stack:[]})}reduce(t,n){return W(n.type,xr,t,n)}};const Dt=new At(()=>wr.new());function Mt(e,t,n=Ot){return yn.useSyncExternalStoreWithSelector(j(r=>e.subscribe(Er,r)),j(()=>e.state),j(()=>e.state),j(t),n)}function Er(e){return e}function ve(e,t){let n=a.useId(),r=Dt.get(t),[o,i]=Mt(r,a.useCallback(u=>[r.selectors.isTop(u,n),r.selectors.inStack(u,n)],[r,n]));return k(()=>{if(e)return r.actions.push(n),()=>r.actions.pop(n)},[r,e,n]),e?i?o:!0:!1}let Ke=new Map,fe=new Map;function mt(e){var t;let n=(t=fe.get(e))!=null?t:0;return fe.set(e,n+1),n!==0?()=>pt(e):(Ke.set(e,{"aria-hidden":e.getAttribute("aria-hidden"),inert:e.inert}),e.setAttribute("aria-hidden","true"),e.inert=!0,()=>pt(e))}function pt(e){var t;let n=(t=fe.get(e))!=null?t:1;if(n===1?fe.delete(e):fe.set(e,n-1),n!==1)return;let r=Ke.get(e);r&&(r["aria-hidden"]===null?e.removeAttribute("aria-hidden"):e.setAttribute("aria-hidden",r["aria-hidden"]),e.inert=r.inert,Ke.delete(e))}function jr(e,{allowed:t,disallowed:n}={}){let r=ve(e,"inert-others");k(()=>{var o,i;if(!r)return;let u=H();for(let s of(o=n==null?void 0:n())!=null?o:[])s&&u.add(mt(s));let l=(i=t==null?void 0:t())!=null?i:[];for(let s of l){if(!s)continue;let d=pe(s);if(!d)continue;let f=s.parentElement;for(;f&&f!==d.body;){for(let p of f.children)l.some(m=>p.contains(m))||u.add(mt(p));f=f.parentElement}}return u.dispose},[r,t,n])}function Sr(e,t,n){let r=te(o=>{let i=o.getBoundingClientRect();i.x===0&&i.y===0&&i.width===0&&i.height===0&&n()});a.useEffect(()=>{if(!e)return;let o=t===null?null:J(t)?t:t.current;if(!o)return;let i=H();if(typeof ResizeObserver<"u"){let u=new ResizeObserver(()=>r.current(o));u.observe(o),i.add(()=>u.disconnect())}if(typeof IntersectionObserver<"u"){let u=new IntersectionObserver(()=>r.current(o));u.observe(o),i.add(()=>u.disconnect())}return()=>i.dispose()},[t,r,e])}let ke=["[contentEditable=true]","[tabindex]","a[href]","area[href]","button:not([disabled])","iframe","input:not([disabled])","select:not([disabled])","details>summary","textarea:not([disabled])"].map(e=>`${e}:not([tabindex='-1'])`).join(","),$r=["[data-autofocus]"].map(e=>`${e}:not([tabindex='-1'])`).join(",");var _=(e=>(e[e.First=1]="First",e[e.Previous=2]="Previous",e[e.Next=4]="Next",e[e.Last=8]="Last",e[e.WrapAround=16]="WrapAround",e[e.NoScroll=32]="NoScroll",e[e.AutoFocus=64]="AutoFocus",e))(_||{}),Xe=(e=>(e[e.Error=0]="Error",e[e.Overflow=1]="Overflow",e[e.Success=2]="Success",e[e.Underflow=3]="Underflow",e))(Xe||{}),Cr=(e=>(e[e.Previous=-1]="Previous",e[e.Next=1]="Next",e))(Cr||{});function kr(e=document.body){return e==null?[]:Array.from(e.querySelectorAll(ke)).sort((t,n)=>Math.sign((t.tabIndex||Number.MAX_SAFE_INTEGER)-(n.tabIndex||Number.MAX_SAFE_INTEGER)))}function Tr(e=document.body){return e==null?[]:Array.from(e.querySelectorAll($r)).sort((t,n)=>Math.sign((t.tabIndex||Number.MAX_SAFE_INTEGER)-(n.tabIndex||Number.MAX_SAFE_INTEGER)))}var It=(e=>(e[e.Strict=0]="Strict",e[e.Loose=1]="Loose",e))(It||{});function Pr(e,t=0){var n;return e===((n=pe(e))==null?void 0:n.body)?!1:W(t,{0(){return e.matches(ke)},1(){let r=e;for(;r!==null;){if(r.matches(ke))return!0;r=r.parentElement}return!1}})}var Nr=(e=>(e[e.Keyboard=0]="Keyboard",e[e.Mouse=1]="Mouse",e))(Nr||{});typeof window<"u"&&typeof document<"u"&&(document.addEventListener("keydown",e=>{e.metaKey||e.altKey||e.ctrlKey||(document.documentElement.dataset.headlessuiFocusVisible="")},!0),document.addEventListener("click",e=>{e.detail===1?delete document.documentElement.dataset.headlessuiFocusVisible:e.detail===0&&(document.documentElement.dataset.headlessuiFocusVisible="")},!0));function B(e){e==null||e.focus({preventScroll:!0})}let Fr=["textarea","input"].join(",");function Ar(e){var t,n;return(n=(t=e==null?void 0:e.matches)==null?void 0:t.call(e,Fr))!=null?n:!1}function Rr(e,t=n=>n){return e.slice().sort((n,r)=>{let o=t(n),i=t(r);if(o===null||i===null)return 0;let u=o.compareDocumentPosition(i);return u&Node.DOCUMENT_POSITION_FOLLOWING?-1:u&Node.DOCUMENT_POSITION_PRECEDING?1:0})}function me(e,t,{sorted:n=!0,relativeTo:r=null,skipElements:o=[]}={}){let i=Array.isArray(e)?e.length>0?Ye(e[0]):document:Ye(e),u=Array.isArray(e)?n?Rr(e):e:t&64?Tr(e):kr(e);o.length>0&&u.length>1&&(u=u.filter(v=>!o.some(g=>g!=null&&"current"in g?(g==null?void 0:g.current)===v:g===v))),r=r??(i==null?void 0:i.activeElement);let l=(()=>{if(t&5)return 1;if(t&10)return-1;throw new Error("Missing Focus.First, Focus.Previous, Focus.Next or Focus.Last")})(),s=(()=>{if(t&1)return 0;if(t&2)return Math.max(0,u.indexOf(r))-1;if(t&4)return Math.max(0,u.indexOf(r))+1;if(t&8)return u.length-1;throw new Error("Missing Focus.First, Focus.Previous, Focus.Next or Focus.Last")})(),d=t&32?{preventScroll:!0}:{},f=0,p=u.length,m;do{if(f>=p||f+p<=0)return 0;let v=s+f;if(t&16)v=(v+p)%p;else{if(v<0)return 3;if(v>=p)return 1}m=u[v],m==null||m.focus(d),f+=l}while(m!==kt(m));return t&6&&Ar(m)&&m.select(),2}function _t(){return/iPhone/gi.test(window.navigator.platform)||/Mac/gi.test(window.navigator.platform)&&window.navigator.maxTouchPoints>0}function Or(){return/Android/gi.test(window.navigator.userAgent)}function ht(){return _t()||Or()}function Se(e,t,n,r){let o=te(n);a.useEffect(()=>{if(!e)return;function i(u){o.current(u)}return document.addEventListener(t,i,r),()=>document.removeEventListener(t,i,r)},[e,t,r])}function Bt(e,t,n,r){let o=te(n);a.useEffect(()=>{if(!e)return;function i(u){o.current(u)}return window.addEventListener(t,i,r),()=>window.removeEventListener(t,i,r)},[e,t,r])}const vt=30;function Lr(e,t,n){let r=te(n),o=a.useCallback(function(l,s){if(l.defaultPrevented)return;let d=s(l);if(d===null||!d.getRootNode().contains(d)||!d.isConnected)return;let f=(function p(m){return typeof m=="function"?p(m()):Array.isArray(m)||m instanceof Set?m:[m]})(t);for(let p of f)if(p!==null&&(p.contains(d)||l.composed&&l.composedPath().includes(p)))return;return!Pr(d,It.Loose)&&d.tabIndex!==-1&&l.preventDefault(),r.current(l,d)},[r,t]),i=a.useRef(null);Se(e,"pointerdown",l=>{var s,d;ht()||(i.current=((d=(s=l.composedPath)==null?void 0:s.call(l))==null?void 0:d[0])||l.target)},!0),Se(e,"pointerup",l=>{if(ht()||!i.current)return;let s=i.current;return i.current=null,o(l,()=>s)},!0);let u=a.useRef({x:0,y:0});Se(e,"touchstart",l=>{u.current.x=l.touches[0].clientX,u.current.y=l.touches[0].clientY},!0),Se(e,"touchend",l=>{let s={x:l.changedTouches[0].clientX,y:l.changedTouches[0].clientY};if(!(Math.abs(s.x-u.current.x)>=vt||Math.abs(s.y-u.current.y)>=vt))return o(l,()=>Y(l.target)?l.target:null)},!0),Bt(e,"blur",l=>o(l,()=>rr(window.document.activeElement)?window.document.activeElement:null),!0)}function et(...e){return a.useMemo(()=>pe(...e),[...e])}function Wt(e,t,n,r){let o=te(n);a.useEffect(()=>{e=e??window;function i(u){o.current(u)}return e.addEventListener(t,i,r),()=>e.removeEventListener(t,i,r)},[e,t,r])}function Dr(e){return a.useSyncExternalStore(e.subscribe,e.getSnapshot,e.getSnapshot)}function Mr(e,t){let n=e(),r=new Set;return{getSnapshot(){return n},subscribe(o){return r.add(o),()=>r.delete(o)},dispatch(o,...i){let u=t[o].call(n,...i);u&&(n=u,r.forEach(l=>l()))}}}function Ir(){let e;return{before({doc:t}){var n;let r=t.documentElement,o=(n=t.defaultView)!=null?n:window;e=Math.max(0,o.innerWidth-r.clientWidth)},after({doc:t,d:n}){let r=t.documentElement,o=Math.max(0,r.clientWidth-r.offsetWidth),i=Math.max(0,e-o);n.style(r,"paddingRight",`${i}px`)}}}function _r(){return _t()?{before({doc:e,d:t,meta:n}){function r(o){for(let i of n().containers)for(let u of i())if(u.contains(o))return!0;return!1}t.microTask(()=>{var o;if(window.getComputedStyle(e.documentElement).scrollBehavior!=="auto"){let l=H();l.style(e.documentElement,"scrollBehavior","auto"),t.add(()=>t.microTask(()=>l.dispose()))}let i=(o=window.scrollY)!=null?o:window.pageYOffset,u=null;t.addEventListener(e,"click",l=>{if(Y(l.target))try{let s=l.target.closest("a");if(!s)return;let{hash:d}=new URL(s.href),f=e.querySelector(d);Y(f)&&!r(f)&&(u=f)}catch{}},!0),t.group(l=>{t.addEventListener(e,"touchstart",s=>{if(l.dispose(),Y(s.target)&&nr(s.target))if(r(s.target)){let d=s.target;for(;d.parentElement&&r(d.parentElement);)d=d.parentElement;l.style(d,"overscrollBehavior","contain")}else l.style(s.target,"touchAction","none")})}),t.addEventListener(e,"touchmove",l=>{if(Y(l.target)){if(or(l.target))return;if(r(l.target)){let s=l.target;for(;s.parentElement&&s.dataset.headlessuiPortal!==""&&!(s.scrollHeight>s.clientHeight||s.scrollWidth>s.clientWidth);)s=s.parentElement;s.dataset.headlessuiPortal===""&&l.preventDefault()}else l.preventDefault()}},{passive:!1}),t.add(()=>{var l;let s=(l=window.scrollY)!=null?l:window.pageYOffset;i!==s&&window.scrollTo(0,i),u&&u.isConnected&&(u.scrollIntoView({block:"nearest"}),u=null)})})}}:{}}function Br(){return{before({doc:e,d:t}){t.style(e.documentElement,"overflow","hidden")}}}function gt(e){let t={};for(let n of e)Object.assign(t,n(t));return t}let Z=Mr(()=>new Map,{PUSH(e,t){var n;let r=(n=this.get(e))!=null?n:{doc:e,count:0,d:H(),meta:new Set,computedMeta:{}};return r.count++,r.meta.add(t),r.computedMeta=gt(r.meta),this.set(e,r),this},POP(e,t){let n=this.get(e);return n&&(n.count--,n.meta.delete(t),n.computedMeta=gt(n.meta)),this},SCROLL_PREVENT(e){let t={doc:e.doc,d:e.d,meta(){return e.computedMeta}},n=[_r(),Ir(),Br()];n.forEach(({before:r})=>r==null?void 0:r(t)),n.forEach(({after:r})=>r==null?void 0:r(t))},SCROLL_ALLOW({d:e}){e.dispose()},TEARDOWN({doc:e}){this.delete(e)}});Z.subscribe(()=>{let e=Z.getSnapshot(),t=new Map;for(let[n]of e)t.set(n,n.documentElement.style.overflow);for(let n of e.values()){let r=t.get(n.doc)==="hidden",o=n.count!==0;(o&&!r||!o&&r)&&Z.dispatch(n.count>0?"SCROLL_PREVENT":"SCROLL_ALLOW",n),n.count===0&&Z.dispatch("TEARDOWN",n)}});function Wr(e,t,n=()=>({containers:[]})){let r=Dr(Z),o=t?r.get(t):void 0,i=o?o.count>0:!1;return k(()=>{if(!(!t||!e))return Z.dispatch("PUSH",t,n),()=>Z.dispatch("POP",t,n)},[e,t]),i}function Hr(e,t,n=()=>[document.body]){let r=ve(e,"scroll-lock");Wr(r,t,o=>{var i;return{containers:[...(i=o.containers)!=null?i:[],n]}})}function Ur(e=0){let[t,n]=a.useState(e),r=a.useCallback(s=>n(s),[]),o=a.useCallback(s=>n(d=>d|s),[]),i=a.useCallback(s=>(t&s)===s,[t]),u=a.useCallback(s=>n(d=>d&~s),[]),l=a.useCallback(s=>n(d=>d^s),[]);return{flags:t,setFlag:r,addFlag:o,hasFlag:i,removeFlag:u,toggleFlag:l}}var Gr={},yt,bt;typeof process<"u"&&typeof globalThis<"u"&&typeof Element<"u"&&((yt=process==null?void 0:Gr)==null?void 0:yt.NODE_ENV)==="test"&&typeof((bt=Element==null?void 0:Element.prototype)==null?void 0:bt.getAnimations)>"u"&&(Element.prototype.getAnimations=function(){return console.warn(["Headless UI has polyfilled `Element.prototype.getAnimations` for your tests.","Please install a proper polyfill e.g. `jsdom-testing-mocks`, to silence these warnings.","","Example usage:","```js","import { mockAnimationsApi } from 'jsdom-testing-mocks'","mockAnimationsApi()","```"].join(`
5
- `)),[]});var zr=(e=>(e[e.None=0]="None",e[e.Closed=1]="Closed",e[e.Enter=2]="Enter",e[e.Leave=4]="Leave",e))(zr||{});function Yr(e){let t={};for(let n in e)e[n]===!0&&(t[`data-${n}`]="");return t}function qr(e,t,n,r){let[o,i]=a.useState(n),{hasFlag:u,addFlag:l,removeFlag:s}=Ur(e&&o?3:0),d=a.useRef(!1),f=a.useRef(!1),p=Pe();return k(()=>{var m;if(e){if(n&&i(!0),!t){n&&l(3);return}return(m=r==null?void 0:r.start)==null||m.call(r,n),Vr(t,{inFlight:d,prepare(){f.current?f.current=!1:f.current=d.current,d.current=!0,!f.current&&(n?(l(3),s(4)):(l(4),s(2)))},run(){f.current?n?(s(3),l(4)):(s(4),l(3)):n?s(1):l(1)},done(){var v;f.current&&Qr(t)||(d.current=!1,s(7),n||i(!1),(v=r==null?void 0:r.end)==null||v.call(r,n))}})}},[e,n,t,p]),e?[o,{closed:u(1),enter:u(2),leave:u(4),transition:u(2)||u(4)}]:[n,{closed:void 0,enter:void 0,leave:void 0,transition:void 0}]}function Vr(e,{prepare:t,run:n,done:r,inFlight:o}){let i=H();return Xr(e,{prepare:t,inFlight:o}),i.nextFrame(()=>{n(),i.requestAnimationFrame(()=>{i.add(Kr(e,r))})}),i.dispose}function Kr(e,t){var n,r;let o=H();if(!e)return o.dispose;let i=!1;o.add(()=>{i=!0});let u=(r=(n=e.getAnimations)==null?void 0:n.call(e).filter(l=>l instanceof CSSTransition))!=null?r:[];return u.length===0?(t(),o.dispose):(Promise.allSettled(u.map(l=>l.finished)).then(()=>{i||t()}),o.dispose)}function Xr(e,{inFlight:t,prepare:n}){if(t!=null&&t.current){n();return}let r=e.style.transition;e.style.transition="none",n(),e.offsetHeight,e.style.transition=r}function Qr(e){var t,n;return((n=(t=e.getAnimations)==null?void 0:t.call(e))!=null?n:[]).some(r=>r instanceof CSSTransition&&r.playState!=="finished")}function tt(e,t){let n=a.useRef([]),r=j(e);a.useEffect(()=>{let o=[...n.current];for(let[i,u]of t.entries())if(n.current[i]!==u){let l=r(t,o);return n.current=t,l}},[r,...t])}let Ne=a.createContext(null);Ne.displayName="OpenClosedContext";var O=(e=>(e[e.Open=1]="Open",e[e.Closed=2]="Closed",e[e.Closing=4]="Closing",e[e.Opening=8]="Opening",e))(O||{});function Fe(){return a.useContext(Ne)}function Zr({value:e,children:t}){return y.createElement(Ne.Provider,{value:e},t)}function Jr({children:e}){return y.createElement(Ne.Provider,{value:null},e)}function eo(e){function t(){document.readyState!=="loading"&&(e(),document.removeEventListener("DOMContentLoaded",t))}typeof window<"u"&&typeof document<"u"&&(document.addEventListener("DOMContentLoaded",t),t())}let G=[];eo(()=>{function e(t){if(!Y(t.target)||t.target===document.body||G[0]===t.target)return;let n=t.target;n=n.closest(ke),G.unshift(n??t.target),G=G.filter(r=>r!=null&&r.isConnected),G.splice(10)}window.addEventListener("click",e,{capture:!0}),window.addEventListener("mousedown",e,{capture:!0}),window.addEventListener("focus",e,{capture:!0}),document.body.addEventListener("click",e,{capture:!0}),document.body.addEventListener("mousedown",e,{capture:!0}),document.body.addEventListener("focus",e,{capture:!0})});function Ht(e){let t=j(e),n=a.useRef(!1);a.useEffect(()=>(n.current=!1,()=>{n.current=!0,Te(()=>{n.current&&t()})}),[t])}let Ut=a.createContext(!1);function to(){return a.useContext(Ut)}function xt(e){return y.createElement(Ut.Provider,{value:e.force},e.children)}function no(e){let t=to(),n=a.useContext(zt),[r,o]=a.useState(()=>{var i;if(!t&&n!==null)return(i=n.current)!=null?i:null;if(D.isServer)return null;let u=e==null?void 0:e.getElementById("headlessui-portal-root");if(u)return u;if(e===null)return null;let l=e.createElement("div");return l.setAttribute("id","headlessui-portal-root"),e.body.appendChild(l)});return a.useEffect(()=>{r!==null&&(e!=null&&e.body.contains(r)||e==null||e.body.appendChild(r))},[r,e]),a.useEffect(()=>{t||n!==null&&o(n.current)},[n,o,t]),r}let Gt=a.Fragment,ro=T(function(e,t){let{ownerDocument:n=null,...r}=e,o=a.useRef(null),i=M(ir(m=>{o.current=m}),t),u=et(o.current),l=n??u,s=no(l),d=a.useContext(Qe),f=Pe(),p=A();return Ht(()=>{var m;s&&s.childNodes.length<=0&&((m=s.parentElement)==null||m.removeChild(s))}),s?un.createPortal(y.createElement("div",{"data-headlessui-portal":"",ref:m=>{f.dispose(),d&&m&&f.add(d.register(m))}},p({ourProps:{ref:i},theirProps:r,slot:{},defaultTag:Gt,name:"Portal"})),s):null});function oo(e,t){let n=M(t),{enabled:r=!0,ownerDocument:o,...i}=e,u=A();return r?y.createElement(ro,{...i,ownerDocument:o,ref:n}):u({ourProps:{ref:n},theirProps:i,slot:{},defaultTag:Gt,name:"Portal"})}let io=a.Fragment,zt=a.createContext(null);function lo(e,t){let{target:n,...r}=e,o={ref:M(t)},i=A();return y.createElement(zt.Provider,{value:n},i({ourProps:o,theirProps:r,defaultTag:io,name:"Popover.Group"}))}let Qe=a.createContext(null);function so(){let e=a.useContext(Qe),t=a.useRef([]),n=j(i=>(t.current.push(i),e&&e.register(i),()=>r(i))),r=j(i=>{let u=t.current.indexOf(i);u!==-1&&t.current.splice(u,1),e&&e.unregister(i)}),o=a.useMemo(()=>({register:n,unregister:r,portals:t}),[n,r,t]);return[t,a.useMemo(()=>function({children:i}){return y.createElement(Qe.Provider,{value:o},i)},[o])]}let ao=T(oo),Yt=T(lo),uo=Object.assign(ao,{Group:Yt});function co(e,t=typeof document<"u"?document.defaultView:null,n){let r=ve(e,"escape");Wt(t,"keydown",o=>{r&&(o.defaultPrevented||o.key===Ft.Escape&&n(o))})}function fo(){var e;let[t]=a.useState(()=>typeof window<"u"&&typeof window.matchMedia=="function"?window.matchMedia("(pointer: coarse)"):null),[n,r]=a.useState((e=t==null?void 0:t.matches)!=null?e:!1);return k(()=>{if(!t)return;function o(i){r(i.matches)}return t.addEventListener("change",o),()=>t.removeEventListener("change",o)},[t]),n}function mo({defaultContainers:e=[],portals:t,mainTreeNode:n}={}){let r=j(()=>{var o,i;let u=pe(n),l=[];for(let s of e)s!==null&&(q(s)?l.push(s):"current"in s&&q(s.current)&&l.push(s.current));if(t!=null&&t.current)for(let s of t.current)l.push(s);for(let s of(o=u==null?void 0:u.querySelectorAll("html > *, body > *"))!=null?o:[])s!==document.body&&s!==document.head&&q(s)&&s.id!=="headlessui-portal-root"&&(n&&(s.contains(n)||s.contains((i=n==null?void 0:n.getRootNode())==null?void 0:i.host))||l.some(d=>s.contains(d))||l.push(s));return l});return{resolveContainers:r,contains:j(o=>r().some(i=>i.contains(o)))}}let qt=a.createContext(null);function wt({children:e,node:t}){let[n,r]=a.useState(null),o=Vt(t??n);return y.createElement(qt.Provider,{value:o},e,o===null&&y.createElement(Ve,{features:Ce.Hidden,ref:i=>{var u,l;if(i){for(let s of(l=(u=pe(i))==null?void 0:u.querySelectorAll("html > *, body > *"))!=null?l:[])if(s!==document.body&&s!==document.head&&q(s)&&s!=null&&s.contains(i)){r(s);break}}}}))}function Vt(e=null){var t;return(t=a.useContext(qt))!=null?t:e}function po(){let e=typeof document>"u";return"useSyncExternalStore"in st?(t=>t.useSyncExternalStore)(st)(()=>()=>{},()=>!1,()=>!e):!1}function Ae(){let e=po(),[t,n]=a.useState(D.isHandoffComplete);return t&&D.isHandoffComplete===!1&&n(!1),a.useEffect(()=>{t!==!0&&n(!0)},[t]),a.useEffect(()=>D.handoff(),[]),e?!1:t}function nt(){let e=a.useRef(!1);return k(()=>(e.current=!0,()=>{e.current=!1}),[]),e}var ce=(e=>(e[e.Forwards=0]="Forwards",e[e.Backwards=1]="Backwards",e))(ce||{});function ho(){let e=a.useRef(0);return Bt(!0,"keydown",t=>{t.key==="Tab"&&(e.current=t.shiftKey?1:0)},!0),e}function Kt(e){if(!e)return new Set;if(typeof e=="function")return new Set(e());let t=new Set;for(let n of e.current)q(n.current)&&t.add(n.current);return t}let vo="div";var Q=(e=>(e[e.None=0]="None",e[e.InitialFocus=1]="InitialFocus",e[e.TabLock=2]="TabLock",e[e.FocusLock=4]="FocusLock",e[e.RestoreFocus=8]="RestoreFocus",e[e.AutoFocus=16]="AutoFocus",e))(Q||{});function go(e,t){let n=a.useRef(null),r=M(n,t),{initialFocus:o,initialFocusFallback:i,containers:u,features:l=15,...s}=e;Ae()||(l=0);let d=et(n.current);wo(l,{ownerDocument:d});let f=Eo(l,{ownerDocument:d,container:n,initialFocus:o,initialFocusFallback:i});jo(l,{ownerDocument:d,container:n,containers:u,previousActiveElement:f});let p=ho(),m=j(S=>{if(!J(n.current))return;let h=n.current;(w=>w())(()=>{W(p.current,{[ce.Forwards]:()=>{me(h,_.First,{skipElements:[S.relatedTarget,i]})},[ce.Backwards]:()=>{me(h,_.Last,{skipElements:[S.relatedTarget,i]})}})})}),v=ve(!!(l&2),"focus-trap#tab-lock"),g=Pe(),x=a.useRef(!1),b={ref:r,onKeyDown(S){S.key=="Tab"&&(x.current=!0,g.requestAnimationFrame(()=>{x.current=!1}))},onBlur(S){if(!(l&4))return;let h=Kt(u);J(n.current)&&h.add(n.current);let w=S.relatedTarget;Y(w)&&w.dataset.headlessuiFocusGuard!=="true"&&(Xt(h,w)||(x.current?me(n.current,W(p.current,{[ce.Forwards]:()=>_.Next,[ce.Backwards]:()=>_.Previous})|_.WrapAround,{relativeTo:S.target}):Y(S.target)&&B(S.target)))}},$=A();return y.createElement(y.Fragment,null,v&&y.createElement(Ve,{as:"button",type:"button","data-headlessui-focus-guard":!0,onFocus:m,features:Ce.Focusable}),$({ourProps:b,theirProps:s,defaultTag:vo,name:"FocusTrap"}),v&&y.createElement(Ve,{as:"button",type:"button","data-headlessui-focus-guard":!0,onFocus:m,features:Ce.Focusable}))}let yo=T(go),bo=Object.assign(yo,{features:Q});function xo(e=!0){let t=a.useRef(G.slice());return tt(([n],[r])=>{r===!0&&n===!1&&Te(()=>{t.current.splice(0)}),r===!1&&n===!0&&(t.current=G.slice())},[e,G,t]),j(()=>{var n;return(n=t.current.find(r=>r!=null&&r.isConnected))!=null?n:null})}function wo(e,{ownerDocument:t}){let n=!!(e&8),r=xo(n);tt(()=>{n||zn(t==null?void 0:t.body)&&B(r())},[n]),Ht(()=>{n&&B(r())})}function Eo(e,{ownerDocument:t,container:n,initialFocus:r,initialFocusFallback:o}){let i=a.useRef(null),u=ve(!!(e&1),"focus-trap#initial-focus"),l=nt();return tt(()=>{if(e===0)return;if(!u){o!=null&&o.current&&B(o.current);return}let s=n.current;s&&Te(()=>{if(!l.current)return;let d=t==null?void 0:t.activeElement;if(r!=null&&r.current){if((r==null?void 0:r.current)===d){i.current=d;return}}else if(s.contains(d)){i.current=d;return}if(r!=null&&r.current)B(r.current);else{if(e&16){if(me(s,_.First|_.AutoFocus)!==Xe.Error)return}else if(me(s,_.First)!==Xe.Error)return;if(o!=null&&o.current&&(B(o.current),(t==null?void 0:t.activeElement)===o.current))return;console.warn("There are no focusable elements inside the <FocusTrap />")}i.current=t==null?void 0:t.activeElement})},[o,u,e]),i}function jo(e,{ownerDocument:t,container:n,containers:r,previousActiveElement:o}){let i=nt(),u=!!(e&4);Wt(t==null?void 0:t.defaultView,"focus",l=>{if(!u||!i.current)return;let s=Kt(r);J(n.current)&&s.add(n.current);let d=o.current;if(!d)return;let f=l.target;J(f)?Xt(s,f)?(o.current=f,B(f)):(l.preventDefault(),l.stopPropagation(),B(d)):B(o.current)},!0)}function Xt(e,t){for(let n of e)if(n.contains(t))return!0;return!1}function Qt(e){var t;return!!(e.enter||e.enterFrom||e.enterTo||e.leave||e.leaveFrom||e.leaveTo)||!de((t=e.as)!=null?t:Jt)||y.Children.count(e.children)===1}let Re=a.createContext(null);Re.displayName="TransitionContext";var So=(e=>(e.Visible="visible",e.Hidden="hidden",e))(So||{});function $o(){let e=a.useContext(Re);if(e===null)throw new Error("A <Transition.Child /> is used but it is missing a parent <Transition /> or <Transition.Root />.");return e}function Co(){let e=a.useContext(Oe);if(e===null)throw new Error("A <Transition.Child /> is used but it is missing a parent <Transition /> or <Transition.Root />.");return e}let Oe=a.createContext(null);Oe.displayName="NestingContext";function Le(e){return"children"in e?Le(e.children):e.current.filter(({el:t})=>t.current!==null).filter(({state:t})=>t==="visible").length>0}function Zt(e,t){let n=te(e),r=a.useRef([]),o=nt(),i=Pe(),u=j((v,g=z.Hidden)=>{let x=r.current.findIndex(({el:b})=>b===v);x!==-1&&(W(g,{[z.Unmount](){r.current.splice(x,1)},[z.Hidden](){r.current[x].state="hidden"}}),i.microTask(()=>{var b;!Le(r)&&o.current&&((b=n.current)==null||b.call(n))}))}),l=j(v=>{let g=r.current.find(({el:x})=>x===v);return g?g.state!=="visible"&&(g.state="visible"):r.current.push({el:v,state:"visible"}),()=>u(v,z.Unmount)}),s=a.useRef([]),d=a.useRef(Promise.resolve()),f=a.useRef({enter:[],leave:[]}),p=j((v,g,x)=>{s.current.splice(0),t&&(t.chains.current[g]=t.chains.current[g].filter(([b])=>b!==v)),t==null||t.chains.current[g].push([v,new Promise(b=>{s.current.push(b)})]),t==null||t.chains.current[g].push([v,new Promise(b=>{Promise.all(f.current[g].map(([$,S])=>S)).then(()=>b())})]),g==="enter"?d.current=d.current.then(()=>t==null?void 0:t.wait.current).then(()=>x(g)):x(g)}),m=j((v,g,x)=>{Promise.all(f.current[g].splice(0).map(([b,$])=>$)).then(()=>{var b;(b=s.current.shift())==null||b()}).then(()=>x(g))});return a.useMemo(()=>({children:r,register:l,unregister:u,onStart:p,onStop:m,wait:d,chains:f}),[l,u,r,p,m,f,d])}let Jt=a.Fragment,en=$e.RenderStrategy;function ko(e,t){var n,r;let{transition:o=!0,beforeEnter:i,afterEnter:u,beforeLeave:l,afterLeave:s,enter:d,enterFrom:f,enterTo:p,entered:m,leave:v,leaveFrom:g,leaveTo:x,...b}=e,[$,S]=a.useState(null),h=a.useRef(null),w=Qt(e),N=M(...w?[h,t,S]:t===null?[]:[t]),I=(n=b.unmount)==null||n?z.Unmount:z.Hidden,{show:P,appear:ge,initial:ye}=$o(),[C,V]=a.useState(P?"visible":"hidden"),oe=Co(),{register:R,unregister:K}=oe;k(()=>R(h),[R,h]),k(()=>{if(I===z.Hidden&&h.current){if(P&&C!=="visible"){V("visible");return}return W(C,{hidden:()=>K(h),visible:()=>R(h)})}},[C,h,R,K,P,I]);let ie=Ae();k(()=>{if(w&&ie&&C==="visible"&&h.current===null)throw new Error("Did you forget to passthrough the `ref` to the actual DOM node?")},[h,C,ie,w]);let Me=ye&&!ge,be=ge&&P&&ye,ne=a.useRef(!1),re=Zt(()=>{ne.current||(V("hidden"),K(h))},oe),xe=j(_e=>{ne.current=!0;let Ee=_e?"enter":"leave";re.onStart(h,Ee,se=>{se==="enter"?i==null||i():se==="leave"&&(l==null||l())})}),U=j(_e=>{let Ee=_e?"enter":"leave";ne.current=!1,re.onStop(h,Ee,se=>{se==="enter"?u==null||u():se==="leave"&&(s==null||s())}),Ee==="leave"&&!Le(re)&&(V("hidden"),K(h))});a.useEffect(()=>{w&&o||(xe(P),U(P))},[P,w,o]);let Ie=!(!o||!w||!ie||Me),[,E]=qr(Ie,$,P,{start:xe,end:U}),we=X({ref:N,className:((r=qe(b.className,be&&d,be&&f,E.enter&&d,E.enter&&E.closed&&f,E.enter&&!E.closed&&p,E.leave&&v,E.leave&&!E.closed&&g,E.leave&&E.closed&&x,!E.transition&&P&&m))==null?void 0:r.trim())||void 0,...Yr(E)}),le=0;C==="visible"&&(le|=O.Open),C==="hidden"&&(le|=O.Closed),P&&C==="hidden"&&(le|=O.Opening),!P&&C==="visible"&&(le|=O.Closing);let rn=A();return y.createElement(Oe.Provider,{value:re},y.createElement(Zr,{value:le},rn({ourProps:we,theirProps:b,defaultTag:Jt,features:en,visible:C==="visible",name:"Transition.Child"})))}function To(e,t){let{show:n,appear:r=!1,unmount:o=!0,...i}=e,u=a.useRef(null),l=Qt(e),s=M(...l?[u,t]:t===null?[]:[t]);Ae();let d=Fe();if(n===void 0&&d!==null&&(n=(d&O.Open)===O.Open),n===void 0)throw new Error("A <Transition /> is used but it is missing a `show={true | false}` prop.");let[f,p]=a.useState(n?"visible":"hidden"),m=Zt(()=>{n||p("hidden")}),[v,g]=a.useState(!0),x=a.useRef([n]);k(()=>{v!==!1&&x.current[x.current.length-1]!==n&&(x.current.push(n),g(!1))},[x,n]);let b=a.useMemo(()=>({show:n,appear:r,initial:v}),[n,r,v]);k(()=>{n?p("visible"):!Le(m)&&u.current!==null&&p("hidden")},[n,m]);let $={unmount:o},S=j(()=>{var N;v&&g(!1),(N=e.beforeEnter)==null||N.call(e)}),h=j(()=>{var N;v&&g(!1),(N=e.beforeLeave)==null||N.call(e)}),w=A();return y.createElement(Oe.Provider,{value:m},y.createElement(Re.Provider,{value:b},w({ourProps:{...$,as:a.Fragment,children:y.createElement(tn,{ref:s,...$,...i,beforeEnter:S,beforeLeave:h})},theirProps:{},defaultTag:a.Fragment,features:en,visible:f==="visible",name:"Transition"})))}function Po(e,t){let n=a.useContext(Re)!==null,r=Fe()!==null;return y.createElement(y.Fragment,null,!n&&r?y.createElement(Ze,{ref:t,...e}):y.createElement(tn,{ref:t,...e}))}let Ze=T(To),tn=T(ko),ee=T(Po),rt=Object.assign(Ze,{Child:ee,Root:Ze});var No=(e=>(e[e.Open=0]="Open",e[e.Closed=1]="Closed",e))(No||{}),Fo=(e=>(e[e.SetTitleId=0]="SetTitleId",e))(Fo||{});let Ao={0(e,t){return e.titleId===t.id?e:{...e,titleId:t.id}}},ot=a.createContext(null);ot.displayName="DialogContext";function De(e){let t=a.useContext(ot);if(t===null){let n=new Error(`<${e} /> is missing a parent <Dialog /> component.`);throw Error.captureStackTrace&&Error.captureStackTrace(n,De),n}return t}function Ro(e,t){return W(t.type,Ao,e,t)}let Et=T(function(e,t){let n=a.useId(),{id:r=`headlessui-dialog-${n}`,open:o,onClose:i,initialFocus:u,role:l="dialog",autoFocus:s=!0,__demoMode:d=!1,unmount:f=!1,...p}=e,m=a.useRef(!1);l=(function(){return l==="dialog"||l==="alertdialog"?l:(m.current||(m.current=!0,console.warn(`Invalid role [${l}] passed to <Dialog />. Only \`dialog\` and and \`alertdialog\` are supported. Using \`dialog\` instead.`)),"dialog")})();let v=Fe();o===void 0&&v!==null&&(o=(v&O.Open)===O.Open);let g=a.useRef(null),x=M(g,t),b=et(g.current),$=o?0:1,[S,h]=a.useReducer(Ro,{titleId:null,descriptionId:null,panelRef:a.createRef()}),w=j(()=>i(!1)),N=j(E=>h({type:0,id:E})),I=Ae()?$===0:!1,[P,ge]=so(),ye={get current(){var E;return(E=S.panelRef.current)!=null?E:g.current}},C=Vt(),{resolveContainers:V}=mo({mainTreeNode:C,portals:P,defaultContainers:[ye]}),oe=v!==null?(v&O.Closing)===O.Closing:!1;jr(d||oe?!1:I,{allowed:j(()=>{var E,we;return[(we=(E=g.current)==null?void 0:E.closest("[data-headlessui-portal]"))!=null?we:null]}),disallowed:j(()=>{var E;return[(E=C==null?void 0:C.closest("body > *:not(#headlessui-portal-root)"))!=null?E:null]})});let R=Dt.get(null);k(()=>{if(I)return R.actions.push(r),()=>R.actions.pop(r)},[R,r,I]);let K=Mt(R,a.useCallback(E=>R.selectors.isTop(E,r),[R,r]));Lr(K,V,E=>{E.preventDefault(),w()}),co(K,b==null?void 0:b.defaultView,E=>{E.preventDefault(),E.stopPropagation(),document.activeElement&&"blur"in document.activeElement&&typeof document.activeElement.blur=="function"&&document.activeElement.blur(),w()}),Hr(d||oe?!1:I,b,V),Sr(I,g,w);let[ie,Me]=lr(),be=a.useMemo(()=>[{dialogState:$,close:w,setTitleId:N,unmount:f},S],[$,w,N,f,S]),ne=he({open:$===0}),re={ref:x,id:r,role:l,tabIndex:-1,"aria-modal":d?void 0:$===0?!0:void 0,"aria-labelledby":S.titleId,"aria-describedby":ie,unmount:f},xe=!fo(),U=Q.None;I&&!d&&(U|=Q.RestoreFocus,U|=Q.TabLock,s&&(U|=Q.AutoFocus),xe&&(U|=Q.InitialFocus));let Ie=A();return y.createElement(Jr,null,y.createElement(xt,{force:!0},y.createElement(uo,null,y.createElement(ot.Provider,{value:be},y.createElement(Yt,{target:g},y.createElement(xt,{force:!1},y.createElement(Me,{slot:ne},y.createElement(ge,null,y.createElement(bo,{initialFocus:u,initialFocusFallback:g,containers:V,features:U},y.createElement(fr,{value:w},Ie({ourProps:re,theirProps:p,slot:ne,defaultTag:Oo,features:Lo,visible:$===0,name:"Dialog"})))))))))))}),Oo="div",Lo=$e.RenderStrategy|$e.Static;function Do(e,t){let{transition:n=!1,open:r,...o}=e,i=Fe(),u=e.hasOwnProperty("open")||i!==null,l=e.hasOwnProperty("onClose");if(!u&&!l)throw new Error("You have to provide an `open` and an `onClose` prop to the `Dialog` component.");if(!u)throw new Error("You provided an `onClose` prop to the `Dialog`, but forgot an `open` prop.");if(!l)throw new Error("You provided an `open` prop to the `Dialog`, but forgot an `onClose` prop.");if(!i&&typeof e.open!="boolean")throw new Error(`You provided an \`open\` prop to the \`Dialog\`, but the value is not a boolean. Received: ${e.open}`);if(typeof e.onClose!="function")throw new Error(`You provided an \`onClose\` prop to the \`Dialog\`, but the value is not a function. Received: ${e.onClose}`);return(r!==void 0||n)&&!o.static?y.createElement(wt,null,y.createElement(rt,{show:r,transition:n,unmount:o.unmount},y.createElement(Et,{ref:t,...o}))):y.createElement(wt,null,y.createElement(Et,{ref:t,open:r,...o}))}let Mo="div";function Io(e,t){let n=a.useId(),{id:r=`headlessui-dialog-panel-${n}`,transition:o=!1,...i}=e,[{dialogState:u,unmount:l},s]=De("Dialog.Panel"),d=M(t,s.panelRef),f=he({open:u===0}),p=j(b=>{b.stopPropagation()}),m={ref:d,id:r,onClick:p},v=o?ee:a.Fragment,g=o?{unmount:l}:{},x=A();return y.createElement(v,{...g},x({ourProps:m,theirProps:i,slot:f,defaultTag:Mo,name:"Dialog.Panel"}))}let _o="div";function Bo(e,t){let{transition:n=!1,...r}=e,[{dialogState:o,unmount:i}]=De("Dialog.Backdrop"),u=he({open:o===0}),l={ref:t,"aria-hidden":!0},s=n?ee:a.Fragment,d=n?{unmount:i}:{},f=A();return y.createElement(s,{...d},f({ourProps:l,theirProps:r,slot:u,defaultTag:_o,name:"Dialog.Backdrop"}))}let Wo="h2";function Ho(e,t){let n=a.useId(),{id:r=`headlessui-dialog-title-${n}`,...o}=e,[{dialogState:i,setTitleId:u}]=De("Dialog.Title"),l=M(t);a.useEffect(()=>(u(r),()=>u(null)),[r,u]);let s=he({open:i===0}),d={ref:l,id:r};return A()({ourProps:d,theirProps:o,slot:s,defaultTag:Wo,name:"Dialog.Title"})}let Uo=T(Do),it=T(Io);T(Bo);let lt=T(Ho),nn=Object.assign(Uo,{Panel:it,Title:lt,Description:cr});function Go(){const{isAuthenticated:e}=bn(),[t,n]=a.useState(e),[r,o]=a.useState(!1);a.useEffect(()=>{t&&!e&&o(!0),n(e)},[e,t]),a.useEffect(()=>jt(St.UNAUTHORIZED,()=>{o(!0)}),[]);const i=()=>{window.location.href=`/auth/signin?callbackUrl=${encodeURIComponent(window.location.pathname)}`},u=()=>{o(!1),window.location.href="/"};return c.jsx(rt,{appear:!0,show:r,children:c.jsxs(nn,{as:"div",className:"semiont-modal",onClose:u,children:[c.jsx(ee,{enter:"ease-out duration-200",enterFrom:"opacity-0",enterTo:"opacity-100",leave:"ease-in duration-150",leaveFrom:"opacity-100",leaveTo:"opacity-0",children:c.jsx("div",{className:"semiont-modal__backdrop"})}),c.jsx("div",{className:"semiont-modal__container",children:c.jsx("div",{className:"semiont-modal__wrapper",children:c.jsx(ee,{enter:"ease-out duration-200",enterFrom:"opacity-0 scale-95",enterTo:"opacity-100 scale-100",leave:"ease-in duration-150",leaveFrom:"opacity-100 scale-100",leaveTo:"opacity-0 scale-95",children:c.jsxs(it,{className:"semiont-modal__panel semiont-modal__panel--medium",children:[c.jsx("div",{className:"semiont-modal__icon-wrapper",children:c.jsx("div",{className:"semiont-modal__icon",style:{background:"linear-gradient(to bottom right, var(--semiont-color-red-100, #fee2e2), var(--semiont-color-red-300, #fca5a5))"},children:c.jsx("svg",{style:{width:"1.5rem",height:"1.5rem",color:"var(--semiont-color-red-600, #dc2626)"},fill:"none",stroke:"currentColor",viewBox:"0 0 24 24",xmlns:"http://www.w3.org/2000/svg",children:c.jsx("path",{strokeLinecap:"round",strokeLinejoin:"round",strokeWidth:2,d:"M12 8v4l3 3m6-3a9 9 0 11-18 0 9 9 0 0118 0z"})})})}),c.jsxs("div",{className:"semiont-modal__content",children:[c.jsx(lt,{className:"semiont-modal__title semiont-modal__title--centered",children:"Session Expired"}),c.jsx("p",{className:"semiont-modal__description",children:"Your session has expired for security reasons. Please sign in again to continue working."})]}),c.jsxs("div",{className:"semiont-modal__actions",children:[c.jsx("button",{type:"button",onClick:u,className:"semiont-button--secondary semiont-button--flex",children:"Go to Home"}),c.jsx("button",{type:"button",onClick:i,className:"semiont-button--primary semiont-button--flex",children:"Sign In Again"})]})]})})})})]})})}function zo(){var d;const[e,t]=a.useState(!1),[n,r]=a.useState(""),o=$t(),{session:i}=Tn();a.useEffect(()=>jt(St.FORBIDDEN,p=>{r(p.detail.message||"You do not have permission to perform this action."),t(!0)}),[]);const u=()=>{t(!1),o.back()},l=()=>{t(!1),o.push("/")},s=()=>{t(!1),window.location.href=`/auth/signin?callbackUrl=${encodeURIComponent(window.location.pathname)}`};return c.jsx(rt,{appear:!0,show:e,children:c.jsxs(nn,{as:"div",className:"semiont-modal",onClose:u,children:[c.jsx(ee,{enter:"ease-out duration-200",enterFrom:"opacity-0",enterTo:"opacity-100",leave:"ease-in duration-150",leaveFrom:"opacity-100",leaveTo:"opacity-0",children:c.jsx("div",{className:"semiont-modal__backdrop"})}),c.jsx("div",{className:"semiont-modal__container",children:c.jsx("div",{className:"semiont-modal__wrapper",children:c.jsx(ee,{enter:"ease-out duration-200",enterFrom:"opacity-0 scale-95",enterTo:"opacity-100 scale-100",leave:"ease-in duration-150",leaveFrom:"opacity-100 scale-100",leaveTo:"opacity-0 scale-95",children:c.jsxs(it,{className:"semiont-modal__panel semiont-modal__panel--medium",children:[c.jsx("div",{className:"semiont-modal__icon-wrapper",children:c.jsx("div",{className:"semiont-modal__icon",children:c.jsx("svg",{style:{width:"1.5rem",height:"1.5rem",color:"var(--semiont-color-amber-600, #d97706)"},fill:"none",stroke:"currentColor",viewBox:"0 0 24 24",xmlns:"http://www.w3.org/2000/svg",children:c.jsx("path",{strokeLinecap:"round",strokeLinejoin:"round",strokeWidth:2,d:"M12 15v2m-6 4h12a2 2 0 002-2v-6a2 2 0 00-2-2H6a2 2 0 00-2 2v6a2 2 0 002 2zm10-10V7a4 4 0 00-8 0v4h8z"})})})}),c.jsxs("div",{className:"semiont-modal__content",children:[c.jsx(lt,{className:"semiont-modal__title semiont-modal__title--centered",children:"Access Denied"}),c.jsx("p",{className:"semiont-modal__description",children:n})]}),c.jsxs("div",{style:{padding:"0.75rem",backgroundColor:"var(--semiont-bg-secondary)",borderRadius:"var(--semiont-radius-md, 0.375rem)",border:"1px solid var(--semiont-border-primary)",fontSize:"var(--semiont-text-sm, 0.875rem)",marginBottom:"1rem"},children:[c.jsx("p",{style:{color:"var(--semiont-text-secondary)",marginBottom:"0.5rem"},children:"This could be because:"}),c.jsxs("ul",{style:{listStyle:"disc",listStylePosition:"inside",color:"var(--semiont-text-tertiary)",display:"flex",flexDirection:"column",gap:"0.25rem"},children:[c.jsx("li",{children:"You don't have the required permissions"}),c.jsx("li",{children:"The resource is restricted to specific users or teams"}),c.jsx("li",{children:"Your account type doesn't include this feature"})]})]}),((d=i==null?void 0:i.user)==null?void 0:d.email)&&c.jsxs("p",{style:{fontSize:"var(--semiont-text-xs, 0.75rem)",color:"var(--semiont-text-tertiary)",marginBottom:"1rem"},children:["Currently signed in as: ",c.jsx("span",{style:{fontWeight:500},children:i.user.email})]}),c.jsxs("div",{className:"semiont-modal__actions",children:[c.jsx("button",{type:"button",onClick:u,className:"semiont-button--primary semiont-button--flex",children:"Go Back"}),c.jsx("button",{type:"button",onClick:l,className:"semiont-button--secondary semiont-button--flex",children:"Go to Home"})]}),c.jsx("div",{className:"semiont-modal__actions",style:{marginTop:"0.5rem",paddingTop:"0.5rem",borderTop:"1px solid var(--semiont-border-primary)"},children:c.jsx("button",{type:"button",onClick:s,className:"semiont-button--secondary semiont-button--flex",style:{fontSize:"var(--semiont-text-sm, 0.875rem)"},children:"Switch Account"})})]})})})})]})})}function Yo(){return c.jsxs(c.Fragment,{children:[c.jsx(xn,{}),c.jsx(Go,{}),c.jsx(zo,{})]})}function ii(){return c.jsxs(Dn,{children:[c.jsx(wn,{}),c.jsx(Yo,{}),c.jsx(cn,{}),c.jsx(Wn,{})]})}export{ii as default};
6
- //# sourceMappingURL=layout-QdxLp1Jq.js.map