@powerhousedao/connect 1.0.4 → 1.0.5-dev.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (274) hide show
  1. package/LICENSE +661 -0
  2. package/README.md +1 -0
  3. package/dist/.env +11 -6
  4. package/dist/assets/app-CcH3qGge.css +5805 -0
  5. package/dist/assets/app-D5aQi0aY.js +80396 -0
  6. package/dist/assets/app-loader-D5SWSIlq.js +31582 -0
  7. package/dist/assets/app-loader-DGByWxSG.css +5640 -0
  8. package/dist/assets/ccip-BmvACOxw.js +170 -0
  9. package/dist/assets/connect-loader-CvOC68Ih.mp4 +0 -0
  10. package/dist/assets/content-CjM3gin6.js +3967 -0
  11. package/dist/assets/home-bg-BEhF9NuW.png +0 -0
  12. package/dist/assets/index-D60iiT4f.js +2560 -0
  13. package/dist/assets/index-DIYv2p_P.js +12 -0
  14. package/dist/assets/index-d_545vU_.js +46565 -0
  15. package/dist/assets/main.DnroXr_4.js +105 -0
  16. package/dist/assets/powerhouse-rounded-CeKGGUG4.png +0 -0
  17. package/dist/assets/renown-short-hover-BiSLBV7L.png +0 -0
  18. package/dist/assets/rwa-report-Bb0W5-ac.png +0 -0
  19. package/dist/assets/style-Ce3V83BE.css +1658 -0
  20. package/dist/external-packages.js +5 -0
  21. package/dist/hmr.js +4 -0
  22. package/dist/icon.ico +0 -0
  23. package/dist/index.html +48 -10
  24. package/dist/modules/@powerhousedao/reactor-browser/chunk-2ESYSVXG.js +48 -0
  25. package/dist/modules/@powerhousedao/reactor-browser/chunk-2ONJ2PX4.js +50 -0
  26. package/dist/modules/@powerhousedao/reactor-browser/chunk-2X2M6BYG.js +2542 -0
  27. package/dist/modules/@powerhousedao/reactor-browser/chunk-64UP3MVE.js +14171 -0
  28. package/dist/modules/@powerhousedao/reactor-browser/chunk-7OQWVUC5.js +43 -0
  29. package/dist/modules/@powerhousedao/reactor-browser/chunk-C7QRY43M.js +786 -0
  30. package/dist/modules/@powerhousedao/reactor-browser/chunk-CO2RVWYY.js +67 -0
  31. package/dist/modules/@powerhousedao/reactor-browser/chunk-DKDARAJS.js +0 -0
  32. package/dist/modules/@powerhousedao/reactor-browser/chunk-F6NNSREE.js +2513 -0
  33. package/dist/modules/@powerhousedao/reactor-browser/chunk-FQF4YAVC.js +11917 -0
  34. package/dist/modules/@powerhousedao/reactor-browser/chunk-GDP7BUIH.js +45 -0
  35. package/dist/modules/@powerhousedao/reactor-browser/chunk-IQTSFTNF.js +48 -0
  36. package/dist/modules/@powerhousedao/reactor-browser/chunk-J5TYPY7U.js +36 -0
  37. package/dist/modules/@powerhousedao/reactor-browser/chunk-LH2T6NLN.js +0 -0
  38. package/dist/modules/@powerhousedao/reactor-browser/chunk-LRNZZ3SR.js +14 -0
  39. package/dist/modules/@powerhousedao/reactor-browser/chunk-NHD6VUCD.js +53 -0
  40. package/dist/modules/@powerhousedao/reactor-browser/chunk-OVGOA2P5.js +11 -0
  41. package/dist/modules/@powerhousedao/reactor-browser/chunk-P6NJ6IAQ.js +12 -0
  42. package/dist/modules/@powerhousedao/reactor-browser/chunk-QXHTR6KF.js +0 -0
  43. package/dist/modules/@powerhousedao/reactor-browser/chunk-RGIB4DD4.js +162 -0
  44. package/dist/modules/@powerhousedao/reactor-browser/chunk-U34SEKEB.js +250 -0
  45. package/dist/modules/@powerhousedao/reactor-browser/chunk-U36SV333.js +0 -0
  46. package/dist/modules/@powerhousedao/reactor-browser/chunk-UWJGRLW3.js +82 -0
  47. package/dist/modules/@powerhousedao/reactor-browser/chunk-XBTEGV5M.js +17 -0
  48. package/dist/modules/@powerhousedao/reactor-browser/chunk-Y7NTRTMT.js +25 -0
  49. package/dist/modules/@powerhousedao/reactor-browser/chunk-YG67WAIS.js +0 -0
  50. package/dist/modules/@powerhousedao/reactor-browser/chunk-YSOX63EM.js +178 -0
  51. package/dist/modules/@powerhousedao/reactor-browser/chunk-YWKVPJNL.js +52 -0
  52. package/dist/modules/@powerhousedao/reactor-browser/chunk-ZL5IPB6D.js +0 -0
  53. package/dist/modules/@powerhousedao/reactor-browser/chunk-ZWFCVUBU.js +113 -0
  54. package/dist/modules/@powerhousedao/reactor-browser/context/index.js +16 -0
  55. package/dist/modules/@powerhousedao/reactor-browser/context/read-mode.js +15 -0
  56. package/dist/modules/@powerhousedao/reactor-browser/crypto/browser.js +7 -0
  57. package/dist/modules/@powerhousedao/reactor-browser/crypto/index.js +7 -0
  58. package/dist/modules/@powerhousedao/reactor-browser/document-model.js +10 -0
  59. package/dist/modules/@powerhousedao/reactor-browser/hooks/document-state.js +96 -0
  60. package/dist/modules/@powerhousedao/reactor-browser/hooks/index.js +98 -0
  61. package/dist/modules/@powerhousedao/reactor-browser/hooks/useAddDebouncedOperations.js +11 -0
  62. package/dist/modules/@powerhousedao/reactor-browser/hooks/useConnectCrypto.js +12 -0
  63. package/dist/modules/@powerhousedao/reactor-browser/hooks/useDocument.js +7 -0
  64. package/dist/modules/@powerhousedao/reactor-browser/hooks/useDocumentDispatch.js +7 -0
  65. package/dist/modules/@powerhousedao/reactor-browser/hooks/useDocumentDrives.js +13 -0
  66. package/dist/modules/@powerhousedao/reactor-browser/hooks/useDocumentEditor.js +20 -0
  67. package/dist/modules/@powerhousedao/reactor-browser/hooks/useDriveActions.js +9 -0
  68. package/dist/modules/@powerhousedao/reactor-browser/hooks/useDriveActionsWithUiNodes.js +14 -0
  69. package/dist/modules/@powerhousedao/reactor-browser/hooks/useDriveContext.js +9 -0
  70. package/dist/modules/@powerhousedao/reactor-browser/hooks/useUiNodesContext.js +46 -0
  71. package/dist/modules/@powerhousedao/reactor-browser/hooks/useUserPermissions.js +7 -0
  72. package/dist/modules/@powerhousedao/reactor-browser/index.js +125 -0
  73. package/dist/modules/@powerhousedao/reactor-browser/reactor.js +11 -0
  74. package/dist/modules/@powerhousedao/reactor-browser/renown/constants.js +53 -0
  75. package/dist/modules/@powerhousedao/reactor-browser/renown/types.js +1 -0
  76. package/dist/modules/@powerhousedao/reactor-browser/storage/index.js +1 -0
  77. package/dist/modules/@powerhousedao/reactor-browser/storage/types.js +1 -0
  78. package/dist/modules/@powerhousedao/reactor-browser/uiNodes/constants.js +37 -0
  79. package/dist/modules/@powerhousedao/reactor-browser/uiNodes/types.js +1 -0
  80. package/dist/modules/@powerhousedao/reactor-browser/utils/export-document.js +8 -0
  81. package/dist/modules/@powerhousedao/reactor-browser/utils/index.js +9 -0
  82. package/dist/modules/@powerhousedao/reactor-browser/utils/signature.js +10 -0
  83. package/dist/service-worker.js +46 -2
  84. package/dist/swEnv.js +9 -8
  85. package/dist/vite-envs.sh +56 -35
  86. package/nginx.conf +93 -0
  87. package/nginx.sh +10 -0
  88. package/package.json +36 -50
  89. package/dist/assets/ArrowFilledRight-blx8xu7X-D3d8PUWh.js +0 -2
  90. package/dist/assets/ArrowFilledRight-blx8xu7X-D3d8PUWh.js.map +0 -1
  91. package/dist/assets/ArrowLeft-7pYNK4eX-8ZR_YHAJ.js +0 -2
  92. package/dist/assets/ArrowLeft-7pYNK4eX-8ZR_YHAJ.js.map +0 -1
  93. package/dist/assets/ArrowUp-Bbr_dwo_-C5ppCQo4.js +0 -2
  94. package/dist/assets/ArrowUp-Bbr_dwo_-C5ppCQo4.js.map +0 -1
  95. package/dist/assets/BarChart-B0G05Nfd-CHDJ7OaJ.js +0 -2
  96. package/dist/assets/BarChart-B0G05Nfd-CHDJ7OaJ.js.map +0 -1
  97. package/dist/assets/BaseArrowLeft-DBzhFHMt-Dkbf2sWs.js +0 -2
  98. package/dist/assets/BaseArrowLeft-DBzhFHMt-Dkbf2sWs.js.map +0 -1
  99. package/dist/assets/BaseArrowRight-DYQTBWAs-CkkPllYm.js +0 -2
  100. package/dist/assets/BaseArrowRight-DYQTBWAs-CkkPllYm.js.map +0 -1
  101. package/dist/assets/Braces-N-sH2Zyc-3LcexUsR.js +0 -2
  102. package/dist/assets/Braces-N-sH2Zyc-3LcexUsR.js.map +0 -1
  103. package/dist/assets/Branch-CWdBw1_P-CmGdOXsI.js +0 -2
  104. package/dist/assets/Branch-CWdBw1_P-CmGdOXsI.js.map +0 -1
  105. package/dist/assets/BrickGlobe-67zaG6_H-DP0By6z_.js +0 -2
  106. package/dist/assets/BrickGlobe-67zaG6_H-DP0By6z_.js.map +0 -1
  107. package/dist/assets/Briefcase-CedW3KRR-DO5_k15F.js +0 -2
  108. package/dist/assets/Briefcase-CedW3KRR-DO5_k15F.js.map +0 -1
  109. package/dist/assets/Calendar-C-6HV96D-YetudWvP.js +0 -2
  110. package/dist/assets/Calendar-C-6HV96D-YetudWvP.js.map +0 -1
  111. package/dist/assets/Caret-Ep0j0fz2-By3ojfim.js +0 -2
  112. package/dist/assets/Caret-Ep0j0fz2-By3ojfim.js.map +0 -1
  113. package/dist/assets/CaretDown-3X7LFYBf-C43xdKg8.js +0 -2
  114. package/dist/assets/CaretDown-3X7LFYBf-C43xdKg8.js.map +0 -1
  115. package/dist/assets/CaretSort-BkGdLETT-DVOzEEqR.js +0 -2
  116. package/dist/assets/CaretSort-BkGdLETT-DVOzEEqR.js.map +0 -1
  117. package/dist/assets/Check-DV-U4AEq-B582NMZp.js +0 -2
  118. package/dist/assets/Check-DV-U4AEq-B582NMZp.js.map +0 -1
  119. package/dist/assets/CheckCircle-DI5fEgGd-CVF4LDhR.js +0 -2
  120. package/dist/assets/CheckCircle-DI5fEgGd-CVF4LDhR.js.map +0 -1
  121. package/dist/assets/CheckCircleFill-C-F0v5mB-BSW1YMqM.js +0 -2
  122. package/dist/assets/CheckCircleFill-C-F0v5mB-BSW1YMqM.js.map +0 -1
  123. package/dist/assets/Checkmark-BXnfChpo-CyQitGI2.js +0 -2
  124. package/dist/assets/Checkmark-BXnfChpo-CyQitGI2.js.map +0 -1
  125. package/dist/assets/ChevronDown-ouBxrU-k-eUsCPXcB.js +0 -2
  126. package/dist/assets/ChevronDown-ouBxrU-k-eUsCPXcB.js.map +0 -1
  127. package/dist/assets/Circle-n3-Wh4HS-8dOehHQf.js +0 -2
  128. package/dist/assets/Circle-n3-Wh4HS-8dOehHQf.js.map +0 -1
  129. package/dist/assets/CircleInfo-BhZY3C2Q-CZgYK1h2.js +0 -2
  130. package/dist/assets/CircleInfo-BhZY3C2Q-CZgYK1h2.js.map +0 -1
  131. package/dist/assets/ClockFill-Bd0t48q7-CcfHiJtH.js +0 -2
  132. package/dist/assets/ClockFill-Bd0t48q7-CcfHiJtH.js.map +0 -1
  133. package/dist/assets/CloudSlash-B-zJBjaD-CxVyp-Ac.js +0 -2
  134. package/dist/assets/CloudSlash-B-zJBjaD-CxVyp-Ac.js.map +0 -1
  135. package/dist/assets/Collapse-DRDB8Czs-CGcuZQgy.js +0 -2
  136. package/dist/assets/Collapse-DRDB8Czs-CGcuZQgy.js.map +0 -1
  137. package/dist/assets/Connect-Dme-qfKq-CgniLji8.js +0 -2
  138. package/dist/assets/Connect-Dme-qfKq-CgniLji8.js.map +0 -1
  139. package/dist/assets/Discord-CAS0Cj7s-CcsBWpnf.js +0 -2
  140. package/dist/assets/Discord-CAS0Cj7s-CcsBWpnf.js.map +0 -1
  141. package/dist/assets/Drive-GMcgBcIY-CzahDx9j.js +0 -2
  142. package/dist/assets/Drive-GMcgBcIY-CzahDx9j.js.map +0 -1
  143. package/dist/assets/Ellipsis-XK8AwMEC-BuVBeYhB.js +0 -2
  144. package/dist/assets/Ellipsis-XK8AwMEC-BuVBeYhB.js.map +0 -1
  145. package/dist/assets/Error-BmIZ2ZUy-CphzuMLn.js +0 -2
  146. package/dist/assets/Error-BmIZ2ZUy-CphzuMLn.js.map +0 -1
  147. package/dist/assets/Exclamation-CVsNS_QS-DLccamql.js +0 -2
  148. package/dist/assets/Exclamation-CVsNS_QS-DLccamql.js.map +0 -1
  149. package/dist/assets/FilesEarmark-CyrCQy8E-Bhut4E02.js +0 -2
  150. package/dist/assets/FilesEarmark-CyrCQy8E-Bhut4E02.js.map +0 -1
  151. package/dist/assets/FolderClose-DG_qHisc-CH6NoBuu.js +0 -2
  152. package/dist/assets/FolderClose-DG_qHisc-CH6NoBuu.js.map +0 -1
  153. package/dist/assets/FolderOpen-kDoWFkJO-Cciutkdg.js +0 -2
  154. package/dist/assets/FolderOpen-kDoWFkJO-Cciutkdg.js.map +0 -1
  155. package/dist/assets/FolderPlus-CSBSl9lZ-CifD0ek9.js +0 -2
  156. package/dist/assets/FolderPlus-CSBSl9lZ-CifD0ek9.js.map +0 -1
  157. package/dist/assets/Forum-DZ-CkLFh-BwabccAX.js +0 -2
  158. package/dist/assets/Forum-DZ-CkLFh-BwabccAX.js.map +0 -1
  159. package/dist/assets/Gear-cUlHJ4q6-B9R2l_9_.js +0 -2
  160. package/dist/assets/Gear-cUlHJ4q6-B9R2l_9_.js.map +0 -1
  161. package/dist/assets/Github-0PLiINY0-CjkZIHCO.js +0 -2
  162. package/dist/assets/Github-0PLiINY0-CjkZIHCO.js.map +0 -1
  163. package/dist/assets/Globe-CIYqVkpa-CL530H46.js +0 -2
  164. package/dist/assets/Globe-CIYqVkpa-CL530H46.js.map +0 -1
  165. package/dist/assets/GlobeWww-DN4yKujh-Ci7aa5CE.js +0 -2
  166. package/dist/assets/GlobeWww-DN4yKujh-Ci7aa5CE.js.map +0 -1
  167. package/dist/assets/Hdd-Dn_LdJIh-CJ6x9Bve.js +0 -2
  168. package/dist/assets/Hdd-Dn_LdJIh-CJ6x9Bve.js.map +0 -1
  169. package/dist/assets/History-BP4SmaS_-P4WBKyqX.js +0 -2
  170. package/dist/assets/History-BP4SmaS_-P4WBKyqX.js.map +0 -1
  171. package/dist/assets/InfoSquare-C98JaLiz-yPcGR71f.js +0 -2
  172. package/dist/assets/InfoSquare-C98JaLiz-yPcGR71f.js.map +0 -1
  173. package/dist/assets/Link-BF7aZjVu-CXIVQOz6.js +0 -2
  174. package/dist/assets/Link-BF7aZjVu-CXIVQOz6.js.map +0 -1
  175. package/dist/assets/Linkedin-DJwIkS6q-Dkb5Tp_Z.js +0 -2
  176. package/dist/assets/Linkedin-DJwIkS6q-Dkb5Tp_Z.js.map +0 -1
  177. package/dist/assets/Lock-PyaFHdNS-D_qxRTye.js +0 -2
  178. package/dist/assets/Lock-PyaFHdNS-D_qxRTye.js.map +0 -1
  179. package/dist/assets/M-DozhhPMY-DBQw97P_.js +0 -2
  180. package/dist/assets/M-DozhhPMY-DBQw97P_.js.map +0 -1
  181. package/dist/assets/Pencil-D7lvxXIP-D830iveq.js +0 -2
  182. package/dist/assets/Pencil-D7lvxXIP-D830iveq.js.map +0 -1
  183. package/dist/assets/People-CUB8LYKf-CyJmMqcw.js +0 -2
  184. package/dist/assets/People-CUB8LYKf-CyJmMqcw.js.map +0 -1
  185. package/dist/assets/Person-DuL4PQzm-ttQR0nPy.js +0 -2
  186. package/dist/assets/Person-DuL4PQzm-ttQR0nPy.js.map +0 -1
  187. package/dist/assets/Plus-DPFWGJM4-BztpK8li.js +0 -2
  188. package/dist/assets/Plus-DPFWGJM4-BztpK8li.js.map +0 -1
  189. package/dist/assets/PlusCircle-BEnWRjHa-w5zztKGx.js +0 -2
  190. package/dist/assets/PlusCircle-BEnWRjHa-w5zztKGx.js.map +0 -1
  191. package/dist/assets/PowerhouseLogoSmall-CmO95IAS-CDGLkst3.js +0 -2
  192. package/dist/assets/PowerhouseLogoSmall-CmO95IAS-CDGLkst3.js.map +0 -1
  193. package/dist/assets/Project-BlXuclr0-EsBam9d0.js +0 -2
  194. package/dist/assets/Project-BlXuclr0-EsBam9d0.js.map +0 -1
  195. package/dist/assets/RedoArrow-BJeEsiph-BbidqIFP.js +0 -2
  196. package/dist/assets/RedoArrow-BJeEsiph-BbidqIFP.js.map +0 -1
  197. package/dist/assets/Renown-6m7hx37h-CItksi2j.js +0 -2
  198. package/dist/assets/Renown-6m7hx37h-CItksi2j.js.map +0 -1
  199. package/dist/assets/RenownHover-CQ0TZHZv-cYQgnwQW.js +0 -2
  200. package/dist/assets/RenownHover-CQ0TZHZv-cYQgnwQW.js.map +0 -1
  201. package/dist/assets/Ring-DKv0gnwT-CDHLz87h.js +0 -2
  202. package/dist/assets/Ring-DKv0gnwT-CDHLz87h.js.map +0 -1
  203. package/dist/assets/Save-BBxj68pn-BkUvn89C.js +0 -2
  204. package/dist/assets/Save-BBxj68pn-BkUvn89C.js.map +0 -1
  205. package/dist/assets/Search-YUJuRBLe-CecGUkZA.js +0 -2
  206. package/dist/assets/Search-YUJuRBLe-CecGUkZA.js.map +0 -1
  207. package/dist/assets/Server-Bfkkjui1-lBan_3Dm.js +0 -2
  208. package/dist/assets/Server-Bfkkjui1-lBan_3Dm.js.map +0 -1
  209. package/dist/assets/Settings-mbbylBS5-Cca-sV-_.js +0 -2
  210. package/dist/assets/Settings-mbbylBS5-Cca-sV-_.js.map +0 -1
  211. package/dist/assets/Synced-DKJXzPiw-Cui8pDsS.js +0 -2
  212. package/dist/assets/Synced-DKJXzPiw-Cui8pDsS.js.map +0 -1
  213. package/dist/assets/Syncing-aT9WSMFf-2VhhyCcX.js +0 -2
  214. package/dist/assets/Syncing-aT9WSMFf-2VhhyCcX.js.map +0 -1
  215. package/dist/assets/Trash-CgSbHk-P-DIYkVMER.js +0 -2
  216. package/dist/assets/Trash-CgSbHk-P-DIYkVMER.js.map +0 -1
  217. package/dist/assets/TrashFill-DN50ercb-Oqx67xXN.js +0 -2
  218. package/dist/assets/TrashFill-DN50ercb-Oqx67xXN.js.map +0 -1
  219. package/dist/assets/VariantArrowLeft-CnuX59_e-6Zt_Q3tm.js +0 -2
  220. package/dist/assets/VariantArrowLeft-CnuX59_e-6Zt_Q3tm.js.map +0 -1
  221. package/dist/assets/VerticalDots-C8QYf7et-CCxZfvjq.js +0 -2
  222. package/dist/assets/VerticalDots-C8QYf7et-CCxZfvjq.js.map +0 -1
  223. package/dist/assets/WarningFill-WowAvi5P-D5XCckM6.js +0 -2
  224. package/dist/assets/WarningFill-WowAvi5P-D5XCckM6.js.map +0 -1
  225. package/dist/assets/XTwitter-k3Pt8itk-mvLk8TKx.js +0 -2
  226. package/dist/assets/XTwitter-k3Pt8itk-mvLk8TKx.js.map +0 -1
  227. package/dist/assets/Xmark-8qnJCs2Y-CZ3t0Fap.js +0 -2
  228. package/dist/assets/Xmark-8qnJCs2Y-CZ3t0Fap.js.map +0 -1
  229. package/dist/assets/XmarkLight-GHzDR5_F-CloMvuzt.js +0 -2
  230. package/dist/assets/XmarkLight-GHzDR5_F-CloMvuzt.js.map +0 -1
  231. package/dist/assets/Youtube-i8V0IXUU-Bkiwoayp.js +0 -2
  232. package/dist/assets/Youtube-i8V0IXUU-Bkiwoayp.js.map +0 -1
  233. package/dist/assets/app-BdM_bCqD.js +0 -842
  234. package/dist/assets/app-BdM_bCqD.js.map +0 -1
  235. package/dist/assets/app-loader-B7xllAoS.js +0 -3
  236. package/dist/assets/app-loader-B7xllAoS.js.map +0 -1
  237. package/dist/assets/app-loader-D5wPX62N.css +0 -1
  238. package/dist/assets/browser-CwKAjz_f.js +0 -43
  239. package/dist/assets/browser-CwKAjz_f.js.map +0 -1
  240. package/dist/assets/browser-Dmr6AWWk.js +0 -2
  241. package/dist/assets/browser-Dmr6AWWk.js.map +0 -1
  242. package/dist/assets/ccip-BoVyVgwR.js +0 -2
  243. package/dist/assets/ccip-BoVyVgwR.js.map +0 -1
  244. package/dist/assets/content-BmCNR4Pw.js +0 -6
  245. package/dist/assets/content-BmCNR4Pw.js.map +0 -1
  246. package/dist/assets/editor-Cma-7Z7k.js +0 -2
  247. package/dist/assets/editor-Cma-7Z7k.js.map +0 -1
  248. package/dist/assets/editor-IMwm8pim.js +0 -2
  249. package/dist/assets/editor-IMwm8pim.js.map +0 -1
  250. package/dist/assets/editor-vgD9wEAH.js +0 -2
  251. package/dist/assets/editor-vgD9wEAH.js.map +0 -1
  252. package/dist/assets/editors-DQC0rqOg.js +0 -347
  253. package/dist/assets/editors-DQC0rqOg.js.map +0 -1
  254. package/dist/assets/index-BP2fj1j6.js +0 -16
  255. package/dist/assets/index-BP2fj1j6.js.map +0 -1
  256. package/dist/assets/index-SwNHx8hV.js +0 -3
  257. package/dist/assets/index-SwNHx8hV.js.map +0 -1
  258. package/dist/assets/index-T6Et30Eh-CdVwpIBO.js +0 -12
  259. package/dist/assets/index-T6Et30Eh-CdVwpIBO.js.map +0 -1
  260. package/dist/assets/main.DQ-aV7Qq.js +0 -2
  261. package/dist/assets/main.DQ-aV7Qq.js.map +0 -1
  262. package/dist/assets/root-BKJF0Yl6.js +0 -12
  263. package/dist/assets/root-BKJF0Yl6.js.map +0 -1
  264. package/dist/assets/router-Hd499Vrp.js +0 -12
  265. package/dist/assets/router-Hd499Vrp.js.map +0 -1
  266. package/dist/assets/useUiNodes-Ch-W4vsB.js +0 -107
  267. package/dist/assets/useUiNodes-Ch-W4vsB.js.map +0 -1
  268. package/dist/service-worker.js.map +0 -1
  269. package/dist/studio/cli.js +0 -6
  270. package/dist/studio/helpers.d.ts +0 -2
  271. package/dist/studio/index.d.ts +0 -20
  272. package/dist/studio/index.js +0 -580
  273. package/dist/studio/server.d.ts +0 -7
  274. package/dist/studio/vite-plugin.d.ts +0 -12
@@ -0,0 +1,3967 @@
1
+ import { jsx, jsxs, Fragment as Fragment$1 } from "react/jsx-runtime";
2
+ import { t as twMerge, B as Button, m as mergeClassNameProps, E as ERROR, M as MISSING, C as CONFLICT, S as SUCCESS, h as SYNCING, I as INITIAL_SYNC, i as ConnectDropdownMenu, u as useOnClickOutside, j as useEventListener, k as useCopyToClipboard, l as Select, n as ENSAvatar, P as Provider, o as Root3, T as Trigger, p as Portal, q as Content2, v as validateInitialState, w as validateStateSchemaName, x as validateModules, y as useUnwrappedReactor, z as useConnectDid, A as useConnectCrypto, D as useTranslation, F as useModal, G as useAtomValue, H as themeAtom, J as useUser, K as useUserPermissions, L as useUiNodes, N as exportFile, O as useGetDocumentModelModule, Q as addActionContext, U as signOperation, V as useDocumentDriveServer, W as useHotkeys, X as useGetEditor, Y as isSameDocument, Z as useNavigate, _ as ErrorBoundary, $ as DriveLayout, a0 as SearchBar, a1 as useAsyncReactor, a2 as useFilteredDocumentModels, a3 as useDriveEditor, a4 as useDocumentDriveById } from "./app-D5aQi0aY.js";
3
+ import * as React from "react";
4
+ import React__default, { useState, useCallback, useMemo, useEffect, Fragment, useRef, useLayoutEffect, memo as memo$1, createElement, useSyncExternalStore, Suspense } from "react";
5
+ import { _ as Icon, aX as getDimensions, aY as READ, aZ as nodeOptionsMap, a_ as defaultFileOptions, a$ as DELETE, b0 as RENAME, b1 as WRITE, b2 as DUPLICATE, b3 as defaultFolderOptions, b4 as garbageCollect, b5 as sortOperations, b6 as UI_NODE, aO as DRIVE, ay as FILE, b7 as undo, b8 as redo, ac as logger, b9 as useDocumentDispatch, aP as FOLDER, ak as driveDocumentModelModule } from "./app-loader-D5SWSIlq.js";
6
+ import { useDocument, useDocumentEditorProps } from "@powerhousedao/reactor-browser";
7
+ import { useUiNodesContext, FILE as FILE$1 } from "@powerhousedao/reactor-browser/hooks/useUiNodesContext";
8
+ import { useDriveActionsWithUiNodes } from "@powerhousedao/reactor-browser/hooks/useDriveActionsWithUiNodes";
9
+ import { useDriveContext, DriveContextProvider } from "@powerhousedao/reactor-browser/hooks/useDriveContext";
10
+ import "@powerhousedao/reactor-browser/uiNodes/constants";
11
+ import { makeDriveDocumentStateHook } from "@powerhousedao/reactor-browser/hooks/document-state";
12
+ import { flushSync } from "react-dom";
13
+ import "./main.DnroXr_4.js";
14
+ const PaginationButton = ({ active = false, ...props }) => {
15
+ const className = twMerge("h-8 min-w-8 border border-solid border-gray-300 bg-white px-3 py-1 text-xs text-gray-900 hover:bg-gray-100", !active && "border-0");
16
+ return jsx(Button, { color: "light", size: "small", ...mergeClassNameProps(props, className), children: props.children });
17
+ };
18
+ const Pagination = (props) => {
19
+ const { pages = [], goToFirstPage, goToLastPage, goToNextPage, goToPreviousPage, goToPage, isNextPageAvailable, isPreviousPageAvailable, hiddenNextPages, firstPageLabel = "First", lastPageLabel = "Last", nextPageLabel = "Next", previousPageLabel = "Previous" } = props;
20
+ return jsxs("div", { className: "flex gap-x-1", children: [firstPageLabel ? jsx(PaginationButton, { disabled: !isPreviousPageAvailable, onClick: () => goToFirstPage(), children: firstPageLabel }) : null, previousPageLabel ? jsxs(PaginationButton, { disabled: !isPreviousPageAvailable, onClick: () => goToPreviousPage(), children: [jsx(Icon, { className: "rotate-90", name: "ChevronDown", size: 16 }), previousPageLabel] }) : null, pages.map((page) => jsx(PaginationButton, { active: page.active, onClick: () => goToPage(page.index), children: page.number }, page.index)), hiddenNextPages ? jsx("span", { className: "flex items-center justify-center px-2", children: "..." }) : null, nextPageLabel ? jsxs(PaginationButton, { disabled: !isNextPageAvailable, onClick: () => goToNextPage(), children: [nextPageLabel, jsx(Icon, { className: "-rotate-90", name: "ChevronDown", size: 16 })] }) : null, lastPageLabel ? jsx(PaginationButton, { disabled: !isNextPageAvailable, onClick: () => goToLastPage(), children: lastPageLabel }) : null] });
21
+ };
22
+ function usePagination(items, options) {
23
+ const { itemsPerPage = 20, initialPage = 0, pageRange = 3 } = options || {};
24
+ const [currentPage, setCurrentPage] = useState(initialPage);
25
+ const pageCount = Math.ceil(items.length / itemsPerPage);
26
+ const isNextPageAvailable = currentPage < pageCount - 1;
27
+ const isPreviousPageAvailable = currentPage > 0;
28
+ const goToNextPage = useCallback(() => {
29
+ if (isNextPageAvailable) {
30
+ setCurrentPage((prev) => prev + 1);
31
+ }
32
+ }, [isNextPageAvailable, setCurrentPage]);
33
+ const goToPreviousPage = useCallback(() => {
34
+ if (isPreviousPageAvailable) {
35
+ setCurrentPage((prev) => prev - 1);
36
+ }
37
+ }, [isPreviousPageAvailable, setCurrentPage]);
38
+ const goToLastPage = useCallback(() => {
39
+ setCurrentPage(pageCount - 1);
40
+ }, [pageCount]);
41
+ const goToFirstPage = useCallback(() => {
42
+ setCurrentPage(0);
43
+ }, []);
44
+ const goToPage = useCallback((page) => {
45
+ if (page >= 0 && page < pageCount) {
46
+ setCurrentPage(page);
47
+ }
48
+ }, [pageCount]);
49
+ const pageOffset = Math.floor((pageRange - 1) / 2);
50
+ const availableRange = Math.min(pageRange, pageCount);
51
+ const maxStartIndex = Math.max(pageCount - availableRange);
52
+ const startIndex = Math.min(maxStartIndex, Math.max(currentPage - pageOffset, 0));
53
+ const pages = useMemo(() => {
54
+ const range = [];
55
+ for (let i = startIndex; i < availableRange + startIndex; i++) {
56
+ range.push({
57
+ index: i,
58
+ active: i === currentPage,
59
+ number: i + 1
60
+ });
61
+ }
62
+ return range;
63
+ }, [availableRange, startIndex, currentPage]);
64
+ const pageItems = items.slice(currentPage * itemsPerPage, (currentPage + 1) * itemsPerPage);
65
+ const hiddenNextPages = pages.length > 0 && pages.slice(-1)[0].index < pageCount - 1;
66
+ return {
67
+ pages,
68
+ goToPage,
69
+ pageItems,
70
+ pageCount,
71
+ currentPage,
72
+ goToLastPage,
73
+ goToFirstPage,
74
+ goToNextPage,
75
+ hiddenNextPages,
76
+ goToPreviousPage,
77
+ isNextPageAvailable,
78
+ isPreviousPageAvailable
79
+ };
80
+ }
81
+ const useWindowSize = () => {
82
+ const [windowSize, setWindowSize] = useState({
83
+ innerWidth: window.innerWidth,
84
+ innerHeight: window.innerHeight
85
+ });
86
+ useEffect(() => {
87
+ const windowSizeHandler = () => {
88
+ setWindowSize({
89
+ innerWidth: window.innerWidth,
90
+ innerHeight: window.innerHeight
91
+ });
92
+ };
93
+ window.addEventListener("resize", windowSizeHandler);
94
+ return () => {
95
+ window.removeEventListener("resize", windowSizeHandler);
96
+ };
97
+ }, []);
98
+ return windowSize;
99
+ };
100
+ const ConnectLoaderVideo = "/assets/connect-loader-CvOC68Ih.mp4";
101
+ function AnimatedLoader(props) {
102
+ var _a, _b;
103
+ const { style, size = 100, ...delegatedProps } = props;
104
+ const dimensions = getDimensions(size);
105
+ const _style = {
106
+ objectFit: "contain",
107
+ pointerEvents: "none",
108
+ ...dimensions,
109
+ ...style
110
+ };
111
+ const width = (_a = dimensions.width) == null ? void 0 : _a.replace("px", "");
112
+ const height = (_b = dimensions.height) == null ? void 0 : _b.replace("px", "");
113
+ return jsx("video", { autoPlay: true, height, loop: true, muted: true, playsInline: true, width, ...delegatedProps, style: _style, children: jsx("source", { src: ConnectLoaderVideo, type: "video/mp4" }) });
114
+ }
115
+ function Breadcrumbs(props) {
116
+ const { breadcrumbs, createEnabled, onBreadcrumbSelected } = props;
117
+ const [isCreating, setIsCreating] = useState(false);
118
+ const onCreate = props.createEnabled ? props.onCreate : void 0;
119
+ function onAddNew() {
120
+ setIsCreating(true);
121
+ }
122
+ const onSubmit = useCallback((name) => {
123
+ var _a;
124
+ if (!createEnabled || !onCreate)
125
+ return;
126
+ onCreate(name, (_a = breadcrumbs.at(-1)) == null ? void 0 : _a.id);
127
+ setIsCreating(false);
128
+ }, [breadcrumbs, createEnabled, onCreate]);
129
+ const onCancel = useCallback(() => {
130
+ setIsCreating(false);
131
+ }, []);
132
+ return jsxs("div", { className: "flex h-9 flex-row items-center gap-2 p-6 text-gray-500", children: [breadcrumbs.map((node) => jsxs(Fragment, { children: [jsx(Breadcrumb, { node, onClick: onBreadcrumbSelected }), jsx("span", { children: "/" })] }, node.id)), createEnabled && (isCreating ? jsx(NodeInput, { className: "text-gray-800", defaultValue: "New Folder", onCancel, onSubmit, placeholder: "New Folder" }) : jsxs("button", { type: "button", className: "ml-1 flex items-center justify-center gap-2 rounded-md bg-gray-50 px-2 py-1.5 transition-colors hover:bg-gray-200 hover:text-gray-800", onClick: onAddNew, children: [jsx(Icon, { name: "Plus", size: 14 }), "Add new"] }))] });
133
+ }
134
+ function Breadcrumb(props) {
135
+ const { node, onClick } = props;
136
+ return jsx("div", { className: "transition-colors last-of-type:text-gray-800 hover:text-gray-800", onClick: () => onClick(node), role: "button", children: node.name });
137
+ }
138
+ function useBreadcrumbs({ selectedNodePath, getNodeById, setSelectedNode }) {
139
+ const breadcrumbs = useMemo(() => selectedNodePath.map((node) => ({
140
+ id: node.id,
141
+ name: node.name
142
+ })), [selectedNodePath]);
143
+ const onBreadcrumbSelected = useCallback((breadcrumb) => {
144
+ const node = getNodeById(breadcrumb.id);
145
+ if (node) {
146
+ setSelectedNode(node);
147
+ } else {
148
+ console.error(`Node with id ${breadcrumb.id} not found`, breadcrumb);
149
+ }
150
+ }, [getNodeById, setSelectedNode]);
151
+ return {
152
+ breadcrumbs,
153
+ onBreadcrumbSelected
154
+ };
155
+ }
156
+ function DefaultEditorLoader(props) {
157
+ const { message: message2 = "Loading editor", ...divProps } = props;
158
+ return jsx("div", { className: "grid h-full place-items-center", ...divProps, children: jsxs("div", { className: "-mt-20 grid place-items-center", children: [jsx("h3", { className: "mb-4 text-xl", children: message2 }), jsx(AnimatedLoader, {})] }) });
159
+ }
160
+ const DocumentToolbar = (props) => {
161
+ const { undo: undo2, canUndo, redo: redo2, canRedo, title, onClose, onExport, className, onShowRevisionHistory, onSwitchboardLinkClick } = props;
162
+ return jsxs("div", { className: twMerge("flex items-center justify-between", className), children: [jsx("div", { children: undo2 && redo2 && canUndo && canRedo && jsx(EditorUndoRedoButtons, { undo: undo2, canUndo, redo: redo2, canRedo }) }), jsx("div", { children: jsx("h2", { className: "text-sm font-semibold", children: title }) }), jsx("div", { children: jsx(EditorActionButtons, { onClose, onExport, onShowRevisionHistory, onSwitchboardLinkClick }) })] });
163
+ };
164
+ function EditorActionButtons(props) {
165
+ const { onSwitchboardLinkClick, onExport, onClose, onShowRevisionHistory } = props;
166
+ return jsxs("div", { className: "flex gap-x-2", children: [onSwitchboardLinkClick ? jsx("button", { className: "flex h-8 items-center gap-x-2 rounded border border-gray-200 px-3 text-sm font-semibold text-gray-900 active:opacity-50", onClick: onSwitchboardLinkClick, children: jsx(Icon, { name: "Drive", size: 16 }) }) : null, jsxs("button", { className: "flex h-8 items-center gap-x-2 rounded border border-gray-200 px-3 text-sm font-semibold text-gray-900 active:opacity-50", onClick: onExport, children: ["Export ", jsx(Icon, { name: "Save", size: 16 })] }), jsxs("button", { className: "flex h-8 items-center gap-x-2 whitespace-nowrap rounded border border-gray-200 px-3 text-sm font-semibold text-gray-900 active:opacity-50", onClick: onShowRevisionHistory, children: ["Revision history ", jsx(Icon, { name: "History", size: 16 })] }), jsx("button", { className: "grid size-8 place-items-center rounded border border-gray-200 active:opacity-50", onClick: onClose, children: jsx(Icon, { name: "Xmark" }) })] });
167
+ }
168
+ function EditorUndoRedoButtons(props) {
169
+ const { canUndo, canRedo, undo: undo2, redo: redo2 } = props;
170
+ const buttonStyles = "w-8 h-8 rounded-lg flex justify-center items-center rounded border border-gray-200";
171
+ return jsxs("div", { className: "flex gap-x-2 text-gray-500", children: [jsx("button", { className: buttonStyles, disabled: !canUndo, onClick: undo2, children: jsx(Icon, { className: twMerge("-scale-x-100", canUndo ? "text-gray-900 active:opacity-50" : "text-gray-500"), name: "RedoArrow", size: 18 }) }), jsx("button", { className: buttonStyles, disabled: !canRedo, onClick: redo2, children: jsx(Icon, { className: twMerge(canRedo ? "text-gray-900 active:opacity-50" : "text-gray-500"), name: "RedoArrow", size: 18 }) })] });
172
+ }
173
+ const syncIcons = {
174
+ SYNCING: "Syncing",
175
+ SUCCESS: "Synced",
176
+ CONFLICT: "Error",
177
+ MISSING: "Circle",
178
+ ERROR: "Error",
179
+ INITIAL_SYNC: "Syncing"
180
+ };
181
+ function SyncStatusIcon(props) {
182
+ const { syncStatus, className, overrideSyncIcons = {}, ...iconProps } = props;
183
+ const icons = { ...syncIcons, ...overrideSyncIcons };
184
+ const syncStatusIcons = {
185
+ [INITIAL_SYNC]: jsx(Icon, { size: 16, ...iconProps, className: twMerge("text-blue-900", className), name: icons[INITIAL_SYNC] }),
186
+ [SYNCING]: jsx(Icon, { size: 16, ...iconProps, className: twMerge("text-blue-900", className), name: icons[SYNCING] }),
187
+ [SUCCESS]: jsx(Icon, { size: 16, ...iconProps, className: twMerge("text-green-900", className), name: icons[SUCCESS] }),
188
+ [CONFLICT]: jsx(Icon, { size: 16, ...iconProps, className: twMerge("text-orange-900", className), name: icons[CONFLICT] }),
189
+ [MISSING]: jsx(Icon, { size: 16, ...iconProps, className: twMerge("text-red-900", className), name: icons[MISSING] }),
190
+ [ERROR]: jsx(Icon, { size: 16, ...iconProps, className: twMerge("text-red-900", className), name: icons[ERROR] })
191
+ };
192
+ return syncStatusIcons[syncStatus];
193
+ }
194
+ function FileItem(props) {
195
+ const { uiNode, className, customDocumentIconSrc, onSelectNode, onRenameNode, onDuplicateNode, onDeleteNode, isAllowedToCreateDocuments } = props;
196
+ const [mode, setMode] = useState(READ);
197
+ const [isDropdownMenuOpen, setIsDropdownMenuOpen] = useState(false);
198
+ const { dragProps } = useDrag({ uiNode });
199
+ const isReadMode = mode === READ;
200
+ const dropdownMenuHandlers = {
201
+ [DUPLICATE]: () => onDuplicateNode(uiNode),
202
+ [RENAME]: () => setMode(WRITE),
203
+ [DELETE]: () => onDeleteNode(uiNode)
204
+ };
205
+ const dropdownMenuOptions = Object.entries(nodeOptionsMap).map(([id, option]) => ({
206
+ ...option,
207
+ id
208
+ })).filter((option) => defaultFileOptions.includes(option.id));
209
+ function onSubmit(name) {
210
+ onRenameNode(name, uiNode);
211
+ setMode(READ);
212
+ }
213
+ function onCancel() {
214
+ setMode(READ);
215
+ }
216
+ function onClick() {
217
+ onSelectNode(uiNode);
218
+ }
219
+ function onDropdownMenuOptionClick(itemId) {
220
+ const handler = dropdownMenuHandlers[itemId];
221
+ if (!handler) {
222
+ console.error(`No handler found for dropdown menu item: ${itemId}`);
223
+ return;
224
+ }
225
+ handler();
226
+ setIsDropdownMenuOpen(false);
227
+ }
228
+ const iconSrc = getDocumentIconSrc(uiNode.documentType, customDocumentIconSrc);
229
+ const iconNode = jsxs("div", { className: "relative", children: [jsx("img", { alt: "file icon", className: "max-w-none", height: 34, src: iconSrc, width: 32 }), isReadMode && uiNode.syncStatus && jsx("div", { className: "absolute bottom-[-2px] right-0 size-3 rounded-full bg-white", children: jsx("div", { className: "absolute left-[-2px] top-[-2px]", children: jsx(SyncStatusIcon, { overrideSyncIcons: { SUCCESS: "CheckCircleFill" }, syncStatus: uiNode.syncStatus }) }) })] });
230
+ const containerStyles = twMerge("group flex h-12 cursor-pointer select-none items-center rounded-lg bg-gray-200 px-2 text-gray-600 hover:text-gray-800", className);
231
+ const content = isReadMode ? jsxs("div", { className: "flex w-52 items-center justify-between", children: [jsxs("div", { className: "mr-2 truncate group-hover:mr-0", children: [jsx("div", { className: "max-h-6 truncate text-sm font-medium group-hover:text-gray-800", children: uiNode.name }), jsx("div", { className: "max-h-6 truncate text-xs font-medium text-gray-600 group-hover:text-gray-800", children: uiNode.documentType })] }), isAllowedToCreateDocuments ? jsx(ConnectDropdownMenu, { items: dropdownMenuOptions, onItemClick: onDropdownMenuOptionClick, onOpenChange: setIsDropdownMenuOpen, open: isDropdownMenuOpen, children: jsx("button", { className: twMerge("hidden group-hover:block", isDropdownMenuOpen && "block"), onClick: (e) => {
232
+ e.stopPropagation();
233
+ setIsDropdownMenuOpen(true);
234
+ }, children: jsx(Icon, { className: "text-gray-600", name: "VerticalDots" }) }) }) : null] }) : jsx(NodeInput, { className: "ml-3 flex-1 font-medium", defaultValue: uiNode.name, onCancel, onSubmit });
235
+ return jsx("div", { className: "relative w-64", onClick, children: jsx("div", { ...dragProps, className: containerStyles, children: jsxs("div", { className: "flex items-center", children: [jsx("div", { className: "mr-1.5", children: iconNode }), content] }) }) });
236
+ }
237
+ function FolderItem(props) {
238
+ const { uiNode, isAllowedToCreateDocuments, className, onRenameNode, onDuplicateNode, onDeleteNode, onSelectNode, onAddFile, onCopyNode, onMoveNode } = props;
239
+ const [mode, setMode] = useState(READ);
240
+ const [isDropdownMenuOpen, setIsDropdownMenuOpen] = useState(false);
241
+ const { dragProps } = useDrag({ ...props, uiNode });
242
+ const { isDropTarget, dropProps } = useDrop({
243
+ uiNode,
244
+ onAddFile,
245
+ onCopyNode,
246
+ onMoveNode
247
+ });
248
+ const isReadMode = mode === READ;
249
+ function onCancel() {
250
+ setMode(READ);
251
+ }
252
+ function onSubmit(name) {
253
+ onRenameNode(name, uiNode);
254
+ setMode(READ);
255
+ }
256
+ function onClick() {
257
+ onSelectNode(uiNode);
258
+ }
259
+ const dropdownMenuHandlers = {
260
+ [DUPLICATE]: () => onDuplicateNode(uiNode),
261
+ [RENAME]: () => setMode(WRITE),
262
+ [DELETE]: () => onDeleteNode(uiNode)
263
+ };
264
+ const dropdownMenuOptions = Object.entries(nodeOptionsMap).map(([id, option]) => ({
265
+ ...option,
266
+ id
267
+ })).filter((option) => defaultFolderOptions.includes(option.id));
268
+ function onDropdownMenuOptionClick(itemId) {
269
+ const handler = dropdownMenuHandlers[itemId];
270
+ if (!handler) {
271
+ console.error(`No handler found for dropdown menu item: ${itemId}`);
272
+ return;
273
+ }
274
+ handler();
275
+ setIsDropdownMenuOpen(false);
276
+ }
277
+ const content = isReadMode || !isAllowedToCreateDocuments ? jsx("div", { className: "ml-3 max-h-6 truncate font-medium text-gray-600 group-hover:text-gray-800", children: uiNode.name }) : jsx(NodeInput, { className: "ml-3 font-medium", defaultValue: uiNode.name, onCancel, onSubmit });
278
+ const containerStyles = twMerge("group flex h-12 cursor-pointer select-none items-center rounded-lg bg-gray-200 px-2", className, isDropTarget && "bg-blue-100");
279
+ return jsx("div", { className: "relative w-64", onClick, children: jsxs("div", { ...dragProps, ...dropProps, className: containerStyles, children: [jsxs("div", { className: "flex items-center overflow-hidden", children: [jsx("div", { className: "p-1", children: jsxs("div", { className: "relative", children: [jsx(Icon, { name: "FolderClose", size: 24 }), isReadMode && uiNode.syncStatus ? jsx("div", { className: "absolute bottom-[-3px] right-[-2px] size-3 rounded-full bg-white", children: jsx("div", { className: "absolute left-[-2px] top-[-2px]", children: jsx(SyncStatusIcon, { overrideSyncIcons: {
280
+ SUCCESS: "CheckCircleFill"
281
+ }, syncStatus: uiNode.syncStatus }) }) }) : null] }) }), content] }), isReadMode && isAllowedToCreateDocuments ? jsx(ConnectDropdownMenu, { items: dropdownMenuOptions, onItemClick: onDropdownMenuOptionClick, onOpenChange: setIsDropdownMenuOpen, open: isDropdownMenuOpen, children: jsx("button", { className: twMerge("ml-auto hidden group-hover:block", isDropdownMenuOpen && "block"), onClick: (e) => {
282
+ e.stopPropagation();
283
+ setIsDropdownMenuOpen(true);
284
+ }, children: jsx(Icon, { className: "text-gray-600", name: "VerticalDots" }) }) }) : null] }) });
285
+ }
286
+ const millisecondsInWeek = 6048e5;
287
+ const millisecondsInDay = 864e5;
288
+ const constructFromSymbol = Symbol.for("constructDateFrom");
289
+ function constructFrom(date, value) {
290
+ if (typeof date === "function") return date(value);
291
+ if (date && typeof date === "object" && constructFromSymbol in date)
292
+ return date[constructFromSymbol](value);
293
+ if (date instanceof Date) return new date.constructor(value);
294
+ return new Date(value);
295
+ }
296
+ function toDate(argument, context) {
297
+ return constructFrom(context || argument, argument);
298
+ }
299
+ let defaultOptions = {};
300
+ function getDefaultOptions() {
301
+ return defaultOptions;
302
+ }
303
+ function startOfWeek(date, options) {
304
+ var _a, _b, _c, _d;
305
+ const defaultOptions2 = getDefaultOptions();
306
+ const weekStartsOn = (options == null ? void 0 : options.weekStartsOn) ?? ((_b = (_a = options == null ? void 0 : options.locale) == null ? void 0 : _a.options) == null ? void 0 : _b.weekStartsOn) ?? defaultOptions2.weekStartsOn ?? ((_d = (_c = defaultOptions2.locale) == null ? void 0 : _c.options) == null ? void 0 : _d.weekStartsOn) ?? 0;
307
+ const _date = toDate(date, options == null ? void 0 : options.in);
308
+ const day = _date.getDay();
309
+ const diff = (day < weekStartsOn ? 7 : 0) + day - weekStartsOn;
310
+ _date.setDate(_date.getDate() - diff);
311
+ _date.setHours(0, 0, 0, 0);
312
+ return _date;
313
+ }
314
+ function startOfISOWeek(date, options) {
315
+ return startOfWeek(date, { ...options, weekStartsOn: 1 });
316
+ }
317
+ function getISOWeekYear(date, options) {
318
+ const _date = toDate(date, options == null ? void 0 : options.in);
319
+ const year = _date.getFullYear();
320
+ const fourthOfJanuaryOfNextYear = constructFrom(_date, 0);
321
+ fourthOfJanuaryOfNextYear.setFullYear(year + 1, 0, 4);
322
+ fourthOfJanuaryOfNextYear.setHours(0, 0, 0, 0);
323
+ const startOfNextYear = startOfISOWeek(fourthOfJanuaryOfNextYear);
324
+ const fourthOfJanuaryOfThisYear = constructFrom(_date, 0);
325
+ fourthOfJanuaryOfThisYear.setFullYear(year, 0, 4);
326
+ fourthOfJanuaryOfThisYear.setHours(0, 0, 0, 0);
327
+ const startOfThisYear = startOfISOWeek(fourthOfJanuaryOfThisYear);
328
+ if (_date.getTime() >= startOfNextYear.getTime()) {
329
+ return year + 1;
330
+ } else if (_date.getTime() >= startOfThisYear.getTime()) {
331
+ return year;
332
+ } else {
333
+ return year - 1;
334
+ }
335
+ }
336
+ function getTimezoneOffsetInMilliseconds(date) {
337
+ const _date = toDate(date);
338
+ const utcDate = new Date(
339
+ Date.UTC(
340
+ _date.getFullYear(),
341
+ _date.getMonth(),
342
+ _date.getDate(),
343
+ _date.getHours(),
344
+ _date.getMinutes(),
345
+ _date.getSeconds(),
346
+ _date.getMilliseconds()
347
+ )
348
+ );
349
+ utcDate.setUTCFullYear(_date.getFullYear());
350
+ return +date - +utcDate;
351
+ }
352
+ function normalizeDates(context, ...dates) {
353
+ const normalize = constructFrom.bind(
354
+ null,
355
+ dates.find((date) => typeof date === "object")
356
+ );
357
+ return dates.map(normalize);
358
+ }
359
+ function startOfDay(date, options) {
360
+ const _date = toDate(date, options == null ? void 0 : options.in);
361
+ _date.setHours(0, 0, 0, 0);
362
+ return _date;
363
+ }
364
+ function differenceInCalendarDays(laterDate, earlierDate, options) {
365
+ const [laterDate_, earlierDate_] = normalizeDates(
366
+ options == null ? void 0 : options.in,
367
+ laterDate,
368
+ earlierDate
369
+ );
370
+ const laterStartOfDay = startOfDay(laterDate_);
371
+ const earlierStartOfDay = startOfDay(earlierDate_);
372
+ const laterTimestamp = +laterStartOfDay - getTimezoneOffsetInMilliseconds(laterStartOfDay);
373
+ const earlierTimestamp = +earlierStartOfDay - getTimezoneOffsetInMilliseconds(earlierStartOfDay);
374
+ return Math.round((laterTimestamp - earlierTimestamp) / millisecondsInDay);
375
+ }
376
+ function startOfISOWeekYear(date, options) {
377
+ const year = getISOWeekYear(date, options);
378
+ const fourthOfJanuary = constructFrom(date, 0);
379
+ fourthOfJanuary.setFullYear(year, 0, 4);
380
+ fourthOfJanuary.setHours(0, 0, 0, 0);
381
+ return startOfISOWeek(fourthOfJanuary);
382
+ }
383
+ function isDate(value) {
384
+ return value instanceof Date || typeof value === "object" && Object.prototype.toString.call(value) === "[object Date]";
385
+ }
386
+ function isValid(date) {
387
+ return !(!isDate(date) && typeof date !== "number" || isNaN(+toDate(date)));
388
+ }
389
+ function startOfYear(date, options) {
390
+ const date_ = toDate(date, options == null ? void 0 : options.in);
391
+ date_.setFullYear(date_.getFullYear(), 0, 1);
392
+ date_.setHours(0, 0, 0, 0);
393
+ return date_;
394
+ }
395
+ const formatDistanceLocale = {
396
+ lessThanXSeconds: {
397
+ one: "less than a second",
398
+ other: "less than {{count}} seconds"
399
+ },
400
+ xSeconds: {
401
+ one: "1 second",
402
+ other: "{{count}} seconds"
403
+ },
404
+ halfAMinute: "half a minute",
405
+ lessThanXMinutes: {
406
+ one: "less than a minute",
407
+ other: "less than {{count}} minutes"
408
+ },
409
+ xMinutes: {
410
+ one: "1 minute",
411
+ other: "{{count}} minutes"
412
+ },
413
+ aboutXHours: {
414
+ one: "about 1 hour",
415
+ other: "about {{count}} hours"
416
+ },
417
+ xHours: {
418
+ one: "1 hour",
419
+ other: "{{count}} hours"
420
+ },
421
+ xDays: {
422
+ one: "1 day",
423
+ other: "{{count}} days"
424
+ },
425
+ aboutXWeeks: {
426
+ one: "about 1 week",
427
+ other: "about {{count}} weeks"
428
+ },
429
+ xWeeks: {
430
+ one: "1 week",
431
+ other: "{{count}} weeks"
432
+ },
433
+ aboutXMonths: {
434
+ one: "about 1 month",
435
+ other: "about {{count}} months"
436
+ },
437
+ xMonths: {
438
+ one: "1 month",
439
+ other: "{{count}} months"
440
+ },
441
+ aboutXYears: {
442
+ one: "about 1 year",
443
+ other: "about {{count}} years"
444
+ },
445
+ xYears: {
446
+ one: "1 year",
447
+ other: "{{count}} years"
448
+ },
449
+ overXYears: {
450
+ one: "over 1 year",
451
+ other: "over {{count}} years"
452
+ },
453
+ almostXYears: {
454
+ one: "almost 1 year",
455
+ other: "almost {{count}} years"
456
+ }
457
+ };
458
+ const formatDistance = (token, count, options) => {
459
+ let result;
460
+ const tokenValue = formatDistanceLocale[token];
461
+ if (typeof tokenValue === "string") {
462
+ result = tokenValue;
463
+ } else if (count === 1) {
464
+ result = tokenValue.one;
465
+ } else {
466
+ result = tokenValue.other.replace("{{count}}", count.toString());
467
+ }
468
+ if (options == null ? void 0 : options.addSuffix) {
469
+ if (options.comparison && options.comparison > 0) {
470
+ return "in " + result;
471
+ } else {
472
+ return result + " ago";
473
+ }
474
+ }
475
+ return result;
476
+ };
477
+ function buildFormatLongFn(args) {
478
+ return (options = {}) => {
479
+ const width = options.width ? String(options.width) : args.defaultWidth;
480
+ const format2 = args.formats[width] || args.formats[args.defaultWidth];
481
+ return format2;
482
+ };
483
+ }
484
+ const dateFormats = {
485
+ full: "EEEE, MMMM do, y",
486
+ long: "MMMM do, y",
487
+ medium: "MMM d, y",
488
+ short: "MM/dd/yyyy"
489
+ };
490
+ const timeFormats = {
491
+ full: "h:mm:ss a zzzz",
492
+ long: "h:mm:ss a z",
493
+ medium: "h:mm:ss a",
494
+ short: "h:mm a"
495
+ };
496
+ const dateTimeFormats = {
497
+ full: "{{date}} 'at' {{time}}",
498
+ long: "{{date}} 'at' {{time}}",
499
+ medium: "{{date}}, {{time}}",
500
+ short: "{{date}}, {{time}}"
501
+ };
502
+ const formatLong = {
503
+ date: buildFormatLongFn({
504
+ formats: dateFormats,
505
+ defaultWidth: "full"
506
+ }),
507
+ time: buildFormatLongFn({
508
+ formats: timeFormats,
509
+ defaultWidth: "full"
510
+ }),
511
+ dateTime: buildFormatLongFn({
512
+ formats: dateTimeFormats,
513
+ defaultWidth: "full"
514
+ })
515
+ };
516
+ const formatRelativeLocale = {
517
+ lastWeek: "'last' eeee 'at' p",
518
+ yesterday: "'yesterday at' p",
519
+ today: "'today at' p",
520
+ tomorrow: "'tomorrow at' p",
521
+ nextWeek: "eeee 'at' p",
522
+ other: "P"
523
+ };
524
+ const formatRelative = (token, _date, _baseDate, _options) => formatRelativeLocale[token];
525
+ function buildLocalizeFn(args) {
526
+ return (value, options) => {
527
+ const context = (options == null ? void 0 : options.context) ? String(options.context) : "standalone";
528
+ let valuesArray;
529
+ if (context === "formatting" && args.formattingValues) {
530
+ const defaultWidth = args.defaultFormattingWidth || args.defaultWidth;
531
+ const width = (options == null ? void 0 : options.width) ? String(options.width) : defaultWidth;
532
+ valuesArray = args.formattingValues[width] || args.formattingValues[defaultWidth];
533
+ } else {
534
+ const defaultWidth = args.defaultWidth;
535
+ const width = (options == null ? void 0 : options.width) ? String(options.width) : args.defaultWidth;
536
+ valuesArray = args.values[width] || args.values[defaultWidth];
537
+ }
538
+ const index = args.argumentCallback ? args.argumentCallback(value) : value;
539
+ return valuesArray[index];
540
+ };
541
+ }
542
+ const eraValues = {
543
+ narrow: ["B", "A"],
544
+ abbreviated: ["BC", "AD"],
545
+ wide: ["Before Christ", "Anno Domini"]
546
+ };
547
+ const quarterValues = {
548
+ narrow: ["1", "2", "3", "4"],
549
+ abbreviated: ["Q1", "Q2", "Q3", "Q4"],
550
+ wide: ["1st quarter", "2nd quarter", "3rd quarter", "4th quarter"]
551
+ };
552
+ const monthValues = {
553
+ narrow: ["J", "F", "M", "A", "M", "J", "J", "A", "S", "O", "N", "D"],
554
+ abbreviated: [
555
+ "Jan",
556
+ "Feb",
557
+ "Mar",
558
+ "Apr",
559
+ "May",
560
+ "Jun",
561
+ "Jul",
562
+ "Aug",
563
+ "Sep",
564
+ "Oct",
565
+ "Nov",
566
+ "Dec"
567
+ ],
568
+ wide: [
569
+ "January",
570
+ "February",
571
+ "March",
572
+ "April",
573
+ "May",
574
+ "June",
575
+ "July",
576
+ "August",
577
+ "September",
578
+ "October",
579
+ "November",
580
+ "December"
581
+ ]
582
+ };
583
+ const dayValues = {
584
+ narrow: ["S", "M", "T", "W", "T", "F", "S"],
585
+ short: ["Su", "Mo", "Tu", "We", "Th", "Fr", "Sa"],
586
+ abbreviated: ["Sun", "Mon", "Tue", "Wed", "Thu", "Fri", "Sat"],
587
+ wide: [
588
+ "Sunday",
589
+ "Monday",
590
+ "Tuesday",
591
+ "Wednesday",
592
+ "Thursday",
593
+ "Friday",
594
+ "Saturday"
595
+ ]
596
+ };
597
+ const dayPeriodValues = {
598
+ narrow: {
599
+ am: "a",
600
+ pm: "p",
601
+ midnight: "mi",
602
+ noon: "n",
603
+ morning: "morning",
604
+ afternoon: "afternoon",
605
+ evening: "evening",
606
+ night: "night"
607
+ },
608
+ abbreviated: {
609
+ am: "AM",
610
+ pm: "PM",
611
+ midnight: "midnight",
612
+ noon: "noon",
613
+ morning: "morning",
614
+ afternoon: "afternoon",
615
+ evening: "evening",
616
+ night: "night"
617
+ },
618
+ wide: {
619
+ am: "a.m.",
620
+ pm: "p.m.",
621
+ midnight: "midnight",
622
+ noon: "noon",
623
+ morning: "morning",
624
+ afternoon: "afternoon",
625
+ evening: "evening",
626
+ night: "night"
627
+ }
628
+ };
629
+ const formattingDayPeriodValues = {
630
+ narrow: {
631
+ am: "a",
632
+ pm: "p",
633
+ midnight: "mi",
634
+ noon: "n",
635
+ morning: "in the morning",
636
+ afternoon: "in the afternoon",
637
+ evening: "in the evening",
638
+ night: "at night"
639
+ },
640
+ abbreviated: {
641
+ am: "AM",
642
+ pm: "PM",
643
+ midnight: "midnight",
644
+ noon: "noon",
645
+ morning: "in the morning",
646
+ afternoon: "in the afternoon",
647
+ evening: "in the evening",
648
+ night: "at night"
649
+ },
650
+ wide: {
651
+ am: "a.m.",
652
+ pm: "p.m.",
653
+ midnight: "midnight",
654
+ noon: "noon",
655
+ morning: "in the morning",
656
+ afternoon: "in the afternoon",
657
+ evening: "in the evening",
658
+ night: "at night"
659
+ }
660
+ };
661
+ const ordinalNumber = (dirtyNumber, _options) => {
662
+ const number = Number(dirtyNumber);
663
+ const rem100 = number % 100;
664
+ if (rem100 > 20 || rem100 < 10) {
665
+ switch (rem100 % 10) {
666
+ case 1:
667
+ return number + "st";
668
+ case 2:
669
+ return number + "nd";
670
+ case 3:
671
+ return number + "rd";
672
+ }
673
+ }
674
+ return number + "th";
675
+ };
676
+ const localize = {
677
+ ordinalNumber,
678
+ era: buildLocalizeFn({
679
+ values: eraValues,
680
+ defaultWidth: "wide"
681
+ }),
682
+ quarter: buildLocalizeFn({
683
+ values: quarterValues,
684
+ defaultWidth: "wide",
685
+ argumentCallback: (quarter) => quarter - 1
686
+ }),
687
+ month: buildLocalizeFn({
688
+ values: monthValues,
689
+ defaultWidth: "wide"
690
+ }),
691
+ day: buildLocalizeFn({
692
+ values: dayValues,
693
+ defaultWidth: "wide"
694
+ }),
695
+ dayPeriod: buildLocalizeFn({
696
+ values: dayPeriodValues,
697
+ defaultWidth: "wide",
698
+ formattingValues: formattingDayPeriodValues,
699
+ defaultFormattingWidth: "wide"
700
+ })
701
+ };
702
+ function buildMatchFn(args) {
703
+ return (string, options = {}) => {
704
+ const width = options.width;
705
+ const matchPattern = width && args.matchPatterns[width] || args.matchPatterns[args.defaultMatchWidth];
706
+ const matchResult = string.match(matchPattern);
707
+ if (!matchResult) {
708
+ return null;
709
+ }
710
+ const matchedString = matchResult[0];
711
+ const parsePatterns = width && args.parsePatterns[width] || args.parsePatterns[args.defaultParseWidth];
712
+ const key = Array.isArray(parsePatterns) ? findIndex(parsePatterns, (pattern) => pattern.test(matchedString)) : (
713
+ // [TODO] -- I challenge you to fix the type
714
+ findKey(parsePatterns, (pattern) => pattern.test(matchedString))
715
+ );
716
+ let value;
717
+ value = args.valueCallback ? args.valueCallback(key) : key;
718
+ value = options.valueCallback ? (
719
+ // [TODO] -- I challenge you to fix the type
720
+ options.valueCallback(value)
721
+ ) : value;
722
+ const rest = string.slice(matchedString.length);
723
+ return { value, rest };
724
+ };
725
+ }
726
+ function findKey(object, predicate) {
727
+ for (const key in object) {
728
+ if (Object.prototype.hasOwnProperty.call(object, key) && predicate(object[key])) {
729
+ return key;
730
+ }
731
+ }
732
+ return void 0;
733
+ }
734
+ function findIndex(array, predicate) {
735
+ for (let key = 0; key < array.length; key++) {
736
+ if (predicate(array[key])) {
737
+ return key;
738
+ }
739
+ }
740
+ return void 0;
741
+ }
742
+ function buildMatchPatternFn(args) {
743
+ return (string, options = {}) => {
744
+ const matchResult = string.match(args.matchPattern);
745
+ if (!matchResult) return null;
746
+ const matchedString = matchResult[0];
747
+ const parseResult = string.match(args.parsePattern);
748
+ if (!parseResult) return null;
749
+ let value = args.valueCallback ? args.valueCallback(parseResult[0]) : parseResult[0];
750
+ value = options.valueCallback ? options.valueCallback(value) : value;
751
+ const rest = string.slice(matchedString.length);
752
+ return { value, rest };
753
+ };
754
+ }
755
+ const matchOrdinalNumberPattern = /^(\d+)(th|st|nd|rd)?/i;
756
+ const parseOrdinalNumberPattern = /\d+/i;
757
+ const matchEraPatterns = {
758
+ narrow: /^(b|a)/i,
759
+ abbreviated: /^(b\.?\s?c\.?|b\.?\s?c\.?\s?e\.?|a\.?\s?d\.?|c\.?\s?e\.?)/i,
760
+ wide: /^(before christ|before common era|anno domini|common era)/i
761
+ };
762
+ const parseEraPatterns = {
763
+ any: [/^b/i, /^(a|c)/i]
764
+ };
765
+ const matchQuarterPatterns = {
766
+ narrow: /^[1234]/i,
767
+ abbreviated: /^q[1234]/i,
768
+ wide: /^[1234](th|st|nd|rd)? quarter/i
769
+ };
770
+ const parseQuarterPatterns = {
771
+ any: [/1/i, /2/i, /3/i, /4/i]
772
+ };
773
+ const matchMonthPatterns = {
774
+ narrow: /^[jfmasond]/i,
775
+ abbreviated: /^(jan|feb|mar|apr|may|jun|jul|aug|sep|oct|nov|dec)/i,
776
+ wide: /^(january|february|march|april|may|june|july|august|september|october|november|december)/i
777
+ };
778
+ const parseMonthPatterns = {
779
+ narrow: [
780
+ /^j/i,
781
+ /^f/i,
782
+ /^m/i,
783
+ /^a/i,
784
+ /^m/i,
785
+ /^j/i,
786
+ /^j/i,
787
+ /^a/i,
788
+ /^s/i,
789
+ /^o/i,
790
+ /^n/i,
791
+ /^d/i
792
+ ],
793
+ any: [
794
+ /^ja/i,
795
+ /^f/i,
796
+ /^mar/i,
797
+ /^ap/i,
798
+ /^may/i,
799
+ /^jun/i,
800
+ /^jul/i,
801
+ /^au/i,
802
+ /^s/i,
803
+ /^o/i,
804
+ /^n/i,
805
+ /^d/i
806
+ ]
807
+ };
808
+ const matchDayPatterns = {
809
+ narrow: /^[smtwf]/i,
810
+ short: /^(su|mo|tu|we|th|fr|sa)/i,
811
+ abbreviated: /^(sun|mon|tue|wed|thu|fri|sat)/i,
812
+ wide: /^(sunday|monday|tuesday|wednesday|thursday|friday|saturday)/i
813
+ };
814
+ const parseDayPatterns = {
815
+ narrow: [/^s/i, /^m/i, /^t/i, /^w/i, /^t/i, /^f/i, /^s/i],
816
+ any: [/^su/i, /^m/i, /^tu/i, /^w/i, /^th/i, /^f/i, /^sa/i]
817
+ };
818
+ const matchDayPeriodPatterns = {
819
+ narrow: /^(a|p|mi|n|(in the|at) (morning|afternoon|evening|night))/i,
820
+ any: /^([ap]\.?\s?m\.?|midnight|noon|(in the|at) (morning|afternoon|evening|night))/i
821
+ };
822
+ const parseDayPeriodPatterns = {
823
+ any: {
824
+ am: /^a/i,
825
+ pm: /^p/i,
826
+ midnight: /^mi/i,
827
+ noon: /^no/i,
828
+ morning: /morning/i,
829
+ afternoon: /afternoon/i,
830
+ evening: /evening/i,
831
+ night: /night/i
832
+ }
833
+ };
834
+ const match = {
835
+ ordinalNumber: buildMatchPatternFn({
836
+ matchPattern: matchOrdinalNumberPattern,
837
+ parsePattern: parseOrdinalNumberPattern,
838
+ valueCallback: (value) => parseInt(value, 10)
839
+ }),
840
+ era: buildMatchFn({
841
+ matchPatterns: matchEraPatterns,
842
+ defaultMatchWidth: "wide",
843
+ parsePatterns: parseEraPatterns,
844
+ defaultParseWidth: "any"
845
+ }),
846
+ quarter: buildMatchFn({
847
+ matchPatterns: matchQuarterPatterns,
848
+ defaultMatchWidth: "wide",
849
+ parsePatterns: parseQuarterPatterns,
850
+ defaultParseWidth: "any",
851
+ valueCallback: (index) => index + 1
852
+ }),
853
+ month: buildMatchFn({
854
+ matchPatterns: matchMonthPatterns,
855
+ defaultMatchWidth: "wide",
856
+ parsePatterns: parseMonthPatterns,
857
+ defaultParseWidth: "any"
858
+ }),
859
+ day: buildMatchFn({
860
+ matchPatterns: matchDayPatterns,
861
+ defaultMatchWidth: "wide",
862
+ parsePatterns: parseDayPatterns,
863
+ defaultParseWidth: "any"
864
+ }),
865
+ dayPeriod: buildMatchFn({
866
+ matchPatterns: matchDayPeriodPatterns,
867
+ defaultMatchWidth: "any",
868
+ parsePatterns: parseDayPeriodPatterns,
869
+ defaultParseWidth: "any"
870
+ })
871
+ };
872
+ const enUS = {
873
+ code: "en-US",
874
+ formatDistance,
875
+ formatLong,
876
+ formatRelative,
877
+ localize,
878
+ match,
879
+ options: {
880
+ weekStartsOn: 0,
881
+ firstWeekContainsDate: 1
882
+ }
883
+ };
884
+ function getDayOfYear(date, options) {
885
+ const _date = toDate(date, options == null ? void 0 : options.in);
886
+ const diff = differenceInCalendarDays(_date, startOfYear(_date));
887
+ const dayOfYear = diff + 1;
888
+ return dayOfYear;
889
+ }
890
+ function getISOWeek(date, options) {
891
+ const _date = toDate(date, options == null ? void 0 : options.in);
892
+ const diff = +startOfISOWeek(_date) - +startOfISOWeekYear(_date);
893
+ return Math.round(diff / millisecondsInWeek) + 1;
894
+ }
895
+ function getWeekYear(date, options) {
896
+ var _a, _b, _c, _d;
897
+ const _date = toDate(date, options == null ? void 0 : options.in);
898
+ const year = _date.getFullYear();
899
+ const defaultOptions2 = getDefaultOptions();
900
+ const firstWeekContainsDate = (options == null ? void 0 : options.firstWeekContainsDate) ?? ((_b = (_a = options == null ? void 0 : options.locale) == null ? void 0 : _a.options) == null ? void 0 : _b.firstWeekContainsDate) ?? defaultOptions2.firstWeekContainsDate ?? ((_d = (_c = defaultOptions2.locale) == null ? void 0 : _c.options) == null ? void 0 : _d.firstWeekContainsDate) ?? 1;
901
+ const firstWeekOfNextYear = constructFrom((options == null ? void 0 : options.in) || date, 0);
902
+ firstWeekOfNextYear.setFullYear(year + 1, 0, firstWeekContainsDate);
903
+ firstWeekOfNextYear.setHours(0, 0, 0, 0);
904
+ const startOfNextYear = startOfWeek(firstWeekOfNextYear, options);
905
+ const firstWeekOfThisYear = constructFrom((options == null ? void 0 : options.in) || date, 0);
906
+ firstWeekOfThisYear.setFullYear(year, 0, firstWeekContainsDate);
907
+ firstWeekOfThisYear.setHours(0, 0, 0, 0);
908
+ const startOfThisYear = startOfWeek(firstWeekOfThisYear, options);
909
+ if (+_date >= +startOfNextYear) {
910
+ return year + 1;
911
+ } else if (+_date >= +startOfThisYear) {
912
+ return year;
913
+ } else {
914
+ return year - 1;
915
+ }
916
+ }
917
+ function startOfWeekYear(date, options) {
918
+ var _a, _b, _c, _d;
919
+ const defaultOptions2 = getDefaultOptions();
920
+ const firstWeekContainsDate = (options == null ? void 0 : options.firstWeekContainsDate) ?? ((_b = (_a = options == null ? void 0 : options.locale) == null ? void 0 : _a.options) == null ? void 0 : _b.firstWeekContainsDate) ?? defaultOptions2.firstWeekContainsDate ?? ((_d = (_c = defaultOptions2.locale) == null ? void 0 : _c.options) == null ? void 0 : _d.firstWeekContainsDate) ?? 1;
921
+ const year = getWeekYear(date, options);
922
+ const firstWeek = constructFrom((options == null ? void 0 : options.in) || date, 0);
923
+ firstWeek.setFullYear(year, 0, firstWeekContainsDate);
924
+ firstWeek.setHours(0, 0, 0, 0);
925
+ const _date = startOfWeek(firstWeek, options);
926
+ return _date;
927
+ }
928
+ function getWeek(date, options) {
929
+ const _date = toDate(date, options == null ? void 0 : options.in);
930
+ const diff = +startOfWeek(_date, options) - +startOfWeekYear(_date, options);
931
+ return Math.round(diff / millisecondsInWeek) + 1;
932
+ }
933
+ function addLeadingZeros(number, targetLength) {
934
+ const sign = number < 0 ? "-" : "";
935
+ const output = Math.abs(number).toString().padStart(targetLength, "0");
936
+ return sign + output;
937
+ }
938
+ const lightFormatters = {
939
+ // Year
940
+ y(date, token) {
941
+ const signedYear = date.getFullYear();
942
+ const year = signedYear > 0 ? signedYear : 1 - signedYear;
943
+ return addLeadingZeros(token === "yy" ? year % 100 : year, token.length);
944
+ },
945
+ // Month
946
+ M(date, token) {
947
+ const month = date.getMonth();
948
+ return token === "M" ? String(month + 1) : addLeadingZeros(month + 1, 2);
949
+ },
950
+ // Day of the month
951
+ d(date, token) {
952
+ return addLeadingZeros(date.getDate(), token.length);
953
+ },
954
+ // AM or PM
955
+ a(date, token) {
956
+ const dayPeriodEnumValue = date.getHours() / 12 >= 1 ? "pm" : "am";
957
+ switch (token) {
958
+ case "a":
959
+ case "aa":
960
+ return dayPeriodEnumValue.toUpperCase();
961
+ case "aaa":
962
+ return dayPeriodEnumValue;
963
+ case "aaaaa":
964
+ return dayPeriodEnumValue[0];
965
+ case "aaaa":
966
+ default:
967
+ return dayPeriodEnumValue === "am" ? "a.m." : "p.m.";
968
+ }
969
+ },
970
+ // Hour [1-12]
971
+ h(date, token) {
972
+ return addLeadingZeros(date.getHours() % 12 || 12, token.length);
973
+ },
974
+ // Hour [0-23]
975
+ H(date, token) {
976
+ return addLeadingZeros(date.getHours(), token.length);
977
+ },
978
+ // Minute
979
+ m(date, token) {
980
+ return addLeadingZeros(date.getMinutes(), token.length);
981
+ },
982
+ // Second
983
+ s(date, token) {
984
+ return addLeadingZeros(date.getSeconds(), token.length);
985
+ },
986
+ // Fraction of second
987
+ S(date, token) {
988
+ const numberOfDigits = token.length;
989
+ const milliseconds = date.getMilliseconds();
990
+ const fractionalSeconds = Math.trunc(
991
+ milliseconds * Math.pow(10, numberOfDigits - 3)
992
+ );
993
+ return addLeadingZeros(fractionalSeconds, token.length);
994
+ }
995
+ };
996
+ const dayPeriodEnum = {
997
+ midnight: "midnight",
998
+ noon: "noon",
999
+ morning: "morning",
1000
+ afternoon: "afternoon",
1001
+ evening: "evening",
1002
+ night: "night"
1003
+ };
1004
+ const formatters = {
1005
+ // Era
1006
+ G: function(date, token, localize2) {
1007
+ const era = date.getFullYear() > 0 ? 1 : 0;
1008
+ switch (token) {
1009
+ // AD, BC
1010
+ case "G":
1011
+ case "GG":
1012
+ case "GGG":
1013
+ return localize2.era(era, { width: "abbreviated" });
1014
+ // A, B
1015
+ case "GGGGG":
1016
+ return localize2.era(era, { width: "narrow" });
1017
+ // Anno Domini, Before Christ
1018
+ case "GGGG":
1019
+ default:
1020
+ return localize2.era(era, { width: "wide" });
1021
+ }
1022
+ },
1023
+ // Year
1024
+ y: function(date, token, localize2) {
1025
+ if (token === "yo") {
1026
+ const signedYear = date.getFullYear();
1027
+ const year = signedYear > 0 ? signedYear : 1 - signedYear;
1028
+ return localize2.ordinalNumber(year, { unit: "year" });
1029
+ }
1030
+ return lightFormatters.y(date, token);
1031
+ },
1032
+ // Local week-numbering year
1033
+ Y: function(date, token, localize2, options) {
1034
+ const signedWeekYear = getWeekYear(date, options);
1035
+ const weekYear = signedWeekYear > 0 ? signedWeekYear : 1 - signedWeekYear;
1036
+ if (token === "YY") {
1037
+ const twoDigitYear = weekYear % 100;
1038
+ return addLeadingZeros(twoDigitYear, 2);
1039
+ }
1040
+ if (token === "Yo") {
1041
+ return localize2.ordinalNumber(weekYear, { unit: "year" });
1042
+ }
1043
+ return addLeadingZeros(weekYear, token.length);
1044
+ },
1045
+ // ISO week-numbering year
1046
+ R: function(date, token) {
1047
+ const isoWeekYear = getISOWeekYear(date);
1048
+ return addLeadingZeros(isoWeekYear, token.length);
1049
+ },
1050
+ // Extended year. This is a single number designating the year of this calendar system.
1051
+ // The main difference between `y` and `u` localizers are B.C. years:
1052
+ // | Year | `y` | `u` |
1053
+ // |------|-----|-----|
1054
+ // | AC 1 | 1 | 1 |
1055
+ // | BC 1 | 1 | 0 |
1056
+ // | BC 2 | 2 | -1 |
1057
+ // Also `yy` always returns the last two digits of a year,
1058
+ // while `uu` pads single digit years to 2 characters and returns other years unchanged.
1059
+ u: function(date, token) {
1060
+ const year = date.getFullYear();
1061
+ return addLeadingZeros(year, token.length);
1062
+ },
1063
+ // Quarter
1064
+ Q: function(date, token, localize2) {
1065
+ const quarter = Math.ceil((date.getMonth() + 1) / 3);
1066
+ switch (token) {
1067
+ // 1, 2, 3, 4
1068
+ case "Q":
1069
+ return String(quarter);
1070
+ // 01, 02, 03, 04
1071
+ case "QQ":
1072
+ return addLeadingZeros(quarter, 2);
1073
+ // 1st, 2nd, 3rd, 4th
1074
+ case "Qo":
1075
+ return localize2.ordinalNumber(quarter, { unit: "quarter" });
1076
+ // Q1, Q2, Q3, Q4
1077
+ case "QQQ":
1078
+ return localize2.quarter(quarter, {
1079
+ width: "abbreviated",
1080
+ context: "formatting"
1081
+ });
1082
+ // 1, 2, 3, 4 (narrow quarter; could be not numerical)
1083
+ case "QQQQQ":
1084
+ return localize2.quarter(quarter, {
1085
+ width: "narrow",
1086
+ context: "formatting"
1087
+ });
1088
+ // 1st quarter, 2nd quarter, ...
1089
+ case "QQQQ":
1090
+ default:
1091
+ return localize2.quarter(quarter, {
1092
+ width: "wide",
1093
+ context: "formatting"
1094
+ });
1095
+ }
1096
+ },
1097
+ // Stand-alone quarter
1098
+ q: function(date, token, localize2) {
1099
+ const quarter = Math.ceil((date.getMonth() + 1) / 3);
1100
+ switch (token) {
1101
+ // 1, 2, 3, 4
1102
+ case "q":
1103
+ return String(quarter);
1104
+ // 01, 02, 03, 04
1105
+ case "qq":
1106
+ return addLeadingZeros(quarter, 2);
1107
+ // 1st, 2nd, 3rd, 4th
1108
+ case "qo":
1109
+ return localize2.ordinalNumber(quarter, { unit: "quarter" });
1110
+ // Q1, Q2, Q3, Q4
1111
+ case "qqq":
1112
+ return localize2.quarter(quarter, {
1113
+ width: "abbreviated",
1114
+ context: "standalone"
1115
+ });
1116
+ // 1, 2, 3, 4 (narrow quarter; could be not numerical)
1117
+ case "qqqqq":
1118
+ return localize2.quarter(quarter, {
1119
+ width: "narrow",
1120
+ context: "standalone"
1121
+ });
1122
+ // 1st quarter, 2nd quarter, ...
1123
+ case "qqqq":
1124
+ default:
1125
+ return localize2.quarter(quarter, {
1126
+ width: "wide",
1127
+ context: "standalone"
1128
+ });
1129
+ }
1130
+ },
1131
+ // Month
1132
+ M: function(date, token, localize2) {
1133
+ const month = date.getMonth();
1134
+ switch (token) {
1135
+ case "M":
1136
+ case "MM":
1137
+ return lightFormatters.M(date, token);
1138
+ // 1st, 2nd, ..., 12th
1139
+ case "Mo":
1140
+ return localize2.ordinalNumber(month + 1, { unit: "month" });
1141
+ // Jan, Feb, ..., Dec
1142
+ case "MMM":
1143
+ return localize2.month(month, {
1144
+ width: "abbreviated",
1145
+ context: "formatting"
1146
+ });
1147
+ // J, F, ..., D
1148
+ case "MMMMM":
1149
+ return localize2.month(month, {
1150
+ width: "narrow",
1151
+ context: "formatting"
1152
+ });
1153
+ // January, February, ..., December
1154
+ case "MMMM":
1155
+ default:
1156
+ return localize2.month(month, { width: "wide", context: "formatting" });
1157
+ }
1158
+ },
1159
+ // Stand-alone month
1160
+ L: function(date, token, localize2) {
1161
+ const month = date.getMonth();
1162
+ switch (token) {
1163
+ // 1, 2, ..., 12
1164
+ case "L":
1165
+ return String(month + 1);
1166
+ // 01, 02, ..., 12
1167
+ case "LL":
1168
+ return addLeadingZeros(month + 1, 2);
1169
+ // 1st, 2nd, ..., 12th
1170
+ case "Lo":
1171
+ return localize2.ordinalNumber(month + 1, { unit: "month" });
1172
+ // Jan, Feb, ..., Dec
1173
+ case "LLL":
1174
+ return localize2.month(month, {
1175
+ width: "abbreviated",
1176
+ context: "standalone"
1177
+ });
1178
+ // J, F, ..., D
1179
+ case "LLLLL":
1180
+ return localize2.month(month, {
1181
+ width: "narrow",
1182
+ context: "standalone"
1183
+ });
1184
+ // January, February, ..., December
1185
+ case "LLLL":
1186
+ default:
1187
+ return localize2.month(month, { width: "wide", context: "standalone" });
1188
+ }
1189
+ },
1190
+ // Local week of year
1191
+ w: function(date, token, localize2, options) {
1192
+ const week = getWeek(date, options);
1193
+ if (token === "wo") {
1194
+ return localize2.ordinalNumber(week, { unit: "week" });
1195
+ }
1196
+ return addLeadingZeros(week, token.length);
1197
+ },
1198
+ // ISO week of year
1199
+ I: function(date, token, localize2) {
1200
+ const isoWeek = getISOWeek(date);
1201
+ if (token === "Io") {
1202
+ return localize2.ordinalNumber(isoWeek, { unit: "week" });
1203
+ }
1204
+ return addLeadingZeros(isoWeek, token.length);
1205
+ },
1206
+ // Day of the month
1207
+ d: function(date, token, localize2) {
1208
+ if (token === "do") {
1209
+ return localize2.ordinalNumber(date.getDate(), { unit: "date" });
1210
+ }
1211
+ return lightFormatters.d(date, token);
1212
+ },
1213
+ // Day of year
1214
+ D: function(date, token, localize2) {
1215
+ const dayOfYear = getDayOfYear(date);
1216
+ if (token === "Do") {
1217
+ return localize2.ordinalNumber(dayOfYear, { unit: "dayOfYear" });
1218
+ }
1219
+ return addLeadingZeros(dayOfYear, token.length);
1220
+ },
1221
+ // Day of week
1222
+ E: function(date, token, localize2) {
1223
+ const dayOfWeek = date.getDay();
1224
+ switch (token) {
1225
+ // Tue
1226
+ case "E":
1227
+ case "EE":
1228
+ case "EEE":
1229
+ return localize2.day(dayOfWeek, {
1230
+ width: "abbreviated",
1231
+ context: "formatting"
1232
+ });
1233
+ // T
1234
+ case "EEEEE":
1235
+ return localize2.day(dayOfWeek, {
1236
+ width: "narrow",
1237
+ context: "formatting"
1238
+ });
1239
+ // Tu
1240
+ case "EEEEEE":
1241
+ return localize2.day(dayOfWeek, {
1242
+ width: "short",
1243
+ context: "formatting"
1244
+ });
1245
+ // Tuesday
1246
+ case "EEEE":
1247
+ default:
1248
+ return localize2.day(dayOfWeek, {
1249
+ width: "wide",
1250
+ context: "formatting"
1251
+ });
1252
+ }
1253
+ },
1254
+ // Local day of week
1255
+ e: function(date, token, localize2, options) {
1256
+ const dayOfWeek = date.getDay();
1257
+ const localDayOfWeek = (dayOfWeek - options.weekStartsOn + 8) % 7 || 7;
1258
+ switch (token) {
1259
+ // Numerical value (Nth day of week with current locale or weekStartsOn)
1260
+ case "e":
1261
+ return String(localDayOfWeek);
1262
+ // Padded numerical value
1263
+ case "ee":
1264
+ return addLeadingZeros(localDayOfWeek, 2);
1265
+ // 1st, 2nd, ..., 7th
1266
+ case "eo":
1267
+ return localize2.ordinalNumber(localDayOfWeek, { unit: "day" });
1268
+ case "eee":
1269
+ return localize2.day(dayOfWeek, {
1270
+ width: "abbreviated",
1271
+ context: "formatting"
1272
+ });
1273
+ // T
1274
+ case "eeeee":
1275
+ return localize2.day(dayOfWeek, {
1276
+ width: "narrow",
1277
+ context: "formatting"
1278
+ });
1279
+ // Tu
1280
+ case "eeeeee":
1281
+ return localize2.day(dayOfWeek, {
1282
+ width: "short",
1283
+ context: "formatting"
1284
+ });
1285
+ // Tuesday
1286
+ case "eeee":
1287
+ default:
1288
+ return localize2.day(dayOfWeek, {
1289
+ width: "wide",
1290
+ context: "formatting"
1291
+ });
1292
+ }
1293
+ },
1294
+ // Stand-alone local day of week
1295
+ c: function(date, token, localize2, options) {
1296
+ const dayOfWeek = date.getDay();
1297
+ const localDayOfWeek = (dayOfWeek - options.weekStartsOn + 8) % 7 || 7;
1298
+ switch (token) {
1299
+ // Numerical value (same as in `e`)
1300
+ case "c":
1301
+ return String(localDayOfWeek);
1302
+ // Padded numerical value
1303
+ case "cc":
1304
+ return addLeadingZeros(localDayOfWeek, token.length);
1305
+ // 1st, 2nd, ..., 7th
1306
+ case "co":
1307
+ return localize2.ordinalNumber(localDayOfWeek, { unit: "day" });
1308
+ case "ccc":
1309
+ return localize2.day(dayOfWeek, {
1310
+ width: "abbreviated",
1311
+ context: "standalone"
1312
+ });
1313
+ // T
1314
+ case "ccccc":
1315
+ return localize2.day(dayOfWeek, {
1316
+ width: "narrow",
1317
+ context: "standalone"
1318
+ });
1319
+ // Tu
1320
+ case "cccccc":
1321
+ return localize2.day(dayOfWeek, {
1322
+ width: "short",
1323
+ context: "standalone"
1324
+ });
1325
+ // Tuesday
1326
+ case "cccc":
1327
+ default:
1328
+ return localize2.day(dayOfWeek, {
1329
+ width: "wide",
1330
+ context: "standalone"
1331
+ });
1332
+ }
1333
+ },
1334
+ // ISO day of week
1335
+ i: function(date, token, localize2) {
1336
+ const dayOfWeek = date.getDay();
1337
+ const isoDayOfWeek = dayOfWeek === 0 ? 7 : dayOfWeek;
1338
+ switch (token) {
1339
+ // 2
1340
+ case "i":
1341
+ return String(isoDayOfWeek);
1342
+ // 02
1343
+ case "ii":
1344
+ return addLeadingZeros(isoDayOfWeek, token.length);
1345
+ // 2nd
1346
+ case "io":
1347
+ return localize2.ordinalNumber(isoDayOfWeek, { unit: "day" });
1348
+ // Tue
1349
+ case "iii":
1350
+ return localize2.day(dayOfWeek, {
1351
+ width: "abbreviated",
1352
+ context: "formatting"
1353
+ });
1354
+ // T
1355
+ case "iiiii":
1356
+ return localize2.day(dayOfWeek, {
1357
+ width: "narrow",
1358
+ context: "formatting"
1359
+ });
1360
+ // Tu
1361
+ case "iiiiii":
1362
+ return localize2.day(dayOfWeek, {
1363
+ width: "short",
1364
+ context: "formatting"
1365
+ });
1366
+ // Tuesday
1367
+ case "iiii":
1368
+ default:
1369
+ return localize2.day(dayOfWeek, {
1370
+ width: "wide",
1371
+ context: "formatting"
1372
+ });
1373
+ }
1374
+ },
1375
+ // AM or PM
1376
+ a: function(date, token, localize2) {
1377
+ const hours = date.getHours();
1378
+ const dayPeriodEnumValue = hours / 12 >= 1 ? "pm" : "am";
1379
+ switch (token) {
1380
+ case "a":
1381
+ case "aa":
1382
+ return localize2.dayPeriod(dayPeriodEnumValue, {
1383
+ width: "abbreviated",
1384
+ context: "formatting"
1385
+ });
1386
+ case "aaa":
1387
+ return localize2.dayPeriod(dayPeriodEnumValue, {
1388
+ width: "abbreviated",
1389
+ context: "formatting"
1390
+ }).toLowerCase();
1391
+ case "aaaaa":
1392
+ return localize2.dayPeriod(dayPeriodEnumValue, {
1393
+ width: "narrow",
1394
+ context: "formatting"
1395
+ });
1396
+ case "aaaa":
1397
+ default:
1398
+ return localize2.dayPeriod(dayPeriodEnumValue, {
1399
+ width: "wide",
1400
+ context: "formatting"
1401
+ });
1402
+ }
1403
+ },
1404
+ // AM, PM, midnight, noon
1405
+ b: function(date, token, localize2) {
1406
+ const hours = date.getHours();
1407
+ let dayPeriodEnumValue;
1408
+ if (hours === 12) {
1409
+ dayPeriodEnumValue = dayPeriodEnum.noon;
1410
+ } else if (hours === 0) {
1411
+ dayPeriodEnumValue = dayPeriodEnum.midnight;
1412
+ } else {
1413
+ dayPeriodEnumValue = hours / 12 >= 1 ? "pm" : "am";
1414
+ }
1415
+ switch (token) {
1416
+ case "b":
1417
+ case "bb":
1418
+ return localize2.dayPeriod(dayPeriodEnumValue, {
1419
+ width: "abbreviated",
1420
+ context: "formatting"
1421
+ });
1422
+ case "bbb":
1423
+ return localize2.dayPeriod(dayPeriodEnumValue, {
1424
+ width: "abbreviated",
1425
+ context: "formatting"
1426
+ }).toLowerCase();
1427
+ case "bbbbb":
1428
+ return localize2.dayPeriod(dayPeriodEnumValue, {
1429
+ width: "narrow",
1430
+ context: "formatting"
1431
+ });
1432
+ case "bbbb":
1433
+ default:
1434
+ return localize2.dayPeriod(dayPeriodEnumValue, {
1435
+ width: "wide",
1436
+ context: "formatting"
1437
+ });
1438
+ }
1439
+ },
1440
+ // in the morning, in the afternoon, in the evening, at night
1441
+ B: function(date, token, localize2) {
1442
+ const hours = date.getHours();
1443
+ let dayPeriodEnumValue;
1444
+ if (hours >= 17) {
1445
+ dayPeriodEnumValue = dayPeriodEnum.evening;
1446
+ } else if (hours >= 12) {
1447
+ dayPeriodEnumValue = dayPeriodEnum.afternoon;
1448
+ } else if (hours >= 4) {
1449
+ dayPeriodEnumValue = dayPeriodEnum.morning;
1450
+ } else {
1451
+ dayPeriodEnumValue = dayPeriodEnum.night;
1452
+ }
1453
+ switch (token) {
1454
+ case "B":
1455
+ case "BB":
1456
+ case "BBB":
1457
+ return localize2.dayPeriod(dayPeriodEnumValue, {
1458
+ width: "abbreviated",
1459
+ context: "formatting"
1460
+ });
1461
+ case "BBBBB":
1462
+ return localize2.dayPeriod(dayPeriodEnumValue, {
1463
+ width: "narrow",
1464
+ context: "formatting"
1465
+ });
1466
+ case "BBBB":
1467
+ default:
1468
+ return localize2.dayPeriod(dayPeriodEnumValue, {
1469
+ width: "wide",
1470
+ context: "formatting"
1471
+ });
1472
+ }
1473
+ },
1474
+ // Hour [1-12]
1475
+ h: function(date, token, localize2) {
1476
+ if (token === "ho") {
1477
+ let hours = date.getHours() % 12;
1478
+ if (hours === 0) hours = 12;
1479
+ return localize2.ordinalNumber(hours, { unit: "hour" });
1480
+ }
1481
+ return lightFormatters.h(date, token);
1482
+ },
1483
+ // Hour [0-23]
1484
+ H: function(date, token, localize2) {
1485
+ if (token === "Ho") {
1486
+ return localize2.ordinalNumber(date.getHours(), { unit: "hour" });
1487
+ }
1488
+ return lightFormatters.H(date, token);
1489
+ },
1490
+ // Hour [0-11]
1491
+ K: function(date, token, localize2) {
1492
+ const hours = date.getHours() % 12;
1493
+ if (token === "Ko") {
1494
+ return localize2.ordinalNumber(hours, { unit: "hour" });
1495
+ }
1496
+ return addLeadingZeros(hours, token.length);
1497
+ },
1498
+ // Hour [1-24]
1499
+ k: function(date, token, localize2) {
1500
+ let hours = date.getHours();
1501
+ if (hours === 0) hours = 24;
1502
+ if (token === "ko") {
1503
+ return localize2.ordinalNumber(hours, { unit: "hour" });
1504
+ }
1505
+ return addLeadingZeros(hours, token.length);
1506
+ },
1507
+ // Minute
1508
+ m: function(date, token, localize2) {
1509
+ if (token === "mo") {
1510
+ return localize2.ordinalNumber(date.getMinutes(), { unit: "minute" });
1511
+ }
1512
+ return lightFormatters.m(date, token);
1513
+ },
1514
+ // Second
1515
+ s: function(date, token, localize2) {
1516
+ if (token === "so") {
1517
+ return localize2.ordinalNumber(date.getSeconds(), { unit: "second" });
1518
+ }
1519
+ return lightFormatters.s(date, token);
1520
+ },
1521
+ // Fraction of second
1522
+ S: function(date, token) {
1523
+ return lightFormatters.S(date, token);
1524
+ },
1525
+ // Timezone (ISO-8601. If offset is 0, output is always `'Z'`)
1526
+ X: function(date, token, _localize) {
1527
+ const timezoneOffset = date.getTimezoneOffset();
1528
+ if (timezoneOffset === 0) {
1529
+ return "Z";
1530
+ }
1531
+ switch (token) {
1532
+ // Hours and optional minutes
1533
+ case "X":
1534
+ return formatTimezoneWithOptionalMinutes(timezoneOffset);
1535
+ // Hours, minutes and optional seconds without `:` delimiter
1536
+ // Note: neither ISO-8601 nor JavaScript supports seconds in timezone offsets
1537
+ // so this token always has the same output as `XX`
1538
+ case "XXXX":
1539
+ case "XX":
1540
+ return formatTimezone(timezoneOffset);
1541
+ // Hours, minutes and optional seconds with `:` delimiter
1542
+ // Note: neither ISO-8601 nor JavaScript supports seconds in timezone offsets
1543
+ // so this token always has the same output as `XXX`
1544
+ case "XXXXX":
1545
+ case "XXX":
1546
+ // Hours and minutes with `:` delimiter
1547
+ default:
1548
+ return formatTimezone(timezoneOffset, ":");
1549
+ }
1550
+ },
1551
+ // Timezone (ISO-8601. If offset is 0, output is `'+00:00'` or equivalent)
1552
+ x: function(date, token, _localize) {
1553
+ const timezoneOffset = date.getTimezoneOffset();
1554
+ switch (token) {
1555
+ // Hours and optional minutes
1556
+ case "x":
1557
+ return formatTimezoneWithOptionalMinutes(timezoneOffset);
1558
+ // Hours, minutes and optional seconds without `:` delimiter
1559
+ // Note: neither ISO-8601 nor JavaScript supports seconds in timezone offsets
1560
+ // so this token always has the same output as `xx`
1561
+ case "xxxx":
1562
+ case "xx":
1563
+ return formatTimezone(timezoneOffset);
1564
+ // Hours, minutes and optional seconds with `:` delimiter
1565
+ // Note: neither ISO-8601 nor JavaScript supports seconds in timezone offsets
1566
+ // so this token always has the same output as `xxx`
1567
+ case "xxxxx":
1568
+ case "xxx":
1569
+ // Hours and minutes with `:` delimiter
1570
+ default:
1571
+ return formatTimezone(timezoneOffset, ":");
1572
+ }
1573
+ },
1574
+ // Timezone (GMT)
1575
+ O: function(date, token, _localize) {
1576
+ const timezoneOffset = date.getTimezoneOffset();
1577
+ switch (token) {
1578
+ // Short
1579
+ case "O":
1580
+ case "OO":
1581
+ case "OOO":
1582
+ return "GMT" + formatTimezoneShort(timezoneOffset, ":");
1583
+ // Long
1584
+ case "OOOO":
1585
+ default:
1586
+ return "GMT" + formatTimezone(timezoneOffset, ":");
1587
+ }
1588
+ },
1589
+ // Timezone (specific non-location)
1590
+ z: function(date, token, _localize) {
1591
+ const timezoneOffset = date.getTimezoneOffset();
1592
+ switch (token) {
1593
+ // Short
1594
+ case "z":
1595
+ case "zz":
1596
+ case "zzz":
1597
+ return "GMT" + formatTimezoneShort(timezoneOffset, ":");
1598
+ // Long
1599
+ case "zzzz":
1600
+ default:
1601
+ return "GMT" + formatTimezone(timezoneOffset, ":");
1602
+ }
1603
+ },
1604
+ // Seconds timestamp
1605
+ t: function(date, token, _localize) {
1606
+ const timestamp = Math.trunc(+date / 1e3);
1607
+ return addLeadingZeros(timestamp, token.length);
1608
+ },
1609
+ // Milliseconds timestamp
1610
+ T: function(date, token, _localize) {
1611
+ return addLeadingZeros(+date, token.length);
1612
+ }
1613
+ };
1614
+ function formatTimezoneShort(offset, delimiter = "") {
1615
+ const sign = offset > 0 ? "-" : "+";
1616
+ const absOffset = Math.abs(offset);
1617
+ const hours = Math.trunc(absOffset / 60);
1618
+ const minutes = absOffset % 60;
1619
+ if (minutes === 0) {
1620
+ return sign + String(hours);
1621
+ }
1622
+ return sign + String(hours) + delimiter + addLeadingZeros(minutes, 2);
1623
+ }
1624
+ function formatTimezoneWithOptionalMinutes(offset, delimiter) {
1625
+ if (offset % 60 === 0) {
1626
+ const sign = offset > 0 ? "-" : "+";
1627
+ return sign + addLeadingZeros(Math.abs(offset) / 60, 2);
1628
+ }
1629
+ return formatTimezone(offset, delimiter);
1630
+ }
1631
+ function formatTimezone(offset, delimiter = "") {
1632
+ const sign = offset > 0 ? "-" : "+";
1633
+ const absOffset = Math.abs(offset);
1634
+ const hours = addLeadingZeros(Math.trunc(absOffset / 60), 2);
1635
+ const minutes = addLeadingZeros(absOffset % 60, 2);
1636
+ return sign + hours + delimiter + minutes;
1637
+ }
1638
+ const dateLongFormatter = (pattern, formatLong2) => {
1639
+ switch (pattern) {
1640
+ case "P":
1641
+ return formatLong2.date({ width: "short" });
1642
+ case "PP":
1643
+ return formatLong2.date({ width: "medium" });
1644
+ case "PPP":
1645
+ return formatLong2.date({ width: "long" });
1646
+ case "PPPP":
1647
+ default:
1648
+ return formatLong2.date({ width: "full" });
1649
+ }
1650
+ };
1651
+ const timeLongFormatter = (pattern, formatLong2) => {
1652
+ switch (pattern) {
1653
+ case "p":
1654
+ return formatLong2.time({ width: "short" });
1655
+ case "pp":
1656
+ return formatLong2.time({ width: "medium" });
1657
+ case "ppp":
1658
+ return formatLong2.time({ width: "long" });
1659
+ case "pppp":
1660
+ default:
1661
+ return formatLong2.time({ width: "full" });
1662
+ }
1663
+ };
1664
+ const dateTimeLongFormatter = (pattern, formatLong2) => {
1665
+ const matchResult = pattern.match(/(P+)(p+)?/) || [];
1666
+ const datePattern = matchResult[1];
1667
+ const timePattern = matchResult[2];
1668
+ if (!timePattern) {
1669
+ return dateLongFormatter(pattern, formatLong2);
1670
+ }
1671
+ let dateTimeFormat;
1672
+ switch (datePattern) {
1673
+ case "P":
1674
+ dateTimeFormat = formatLong2.dateTime({ width: "short" });
1675
+ break;
1676
+ case "PP":
1677
+ dateTimeFormat = formatLong2.dateTime({ width: "medium" });
1678
+ break;
1679
+ case "PPP":
1680
+ dateTimeFormat = formatLong2.dateTime({ width: "long" });
1681
+ break;
1682
+ case "PPPP":
1683
+ default:
1684
+ dateTimeFormat = formatLong2.dateTime({ width: "full" });
1685
+ break;
1686
+ }
1687
+ return dateTimeFormat.replace("{{date}}", dateLongFormatter(datePattern, formatLong2)).replace("{{time}}", timeLongFormatter(timePattern, formatLong2));
1688
+ };
1689
+ const longFormatters = {
1690
+ p: timeLongFormatter,
1691
+ P: dateTimeLongFormatter
1692
+ };
1693
+ const dayOfYearTokenRE = /^D+$/;
1694
+ const weekYearTokenRE = /^Y+$/;
1695
+ const throwTokens = ["D", "DD", "YY", "YYYY"];
1696
+ function isProtectedDayOfYearToken(token) {
1697
+ return dayOfYearTokenRE.test(token);
1698
+ }
1699
+ function isProtectedWeekYearToken(token) {
1700
+ return weekYearTokenRE.test(token);
1701
+ }
1702
+ function warnOrThrowProtectedError(token, format2, input) {
1703
+ const _message = message(token, format2, input);
1704
+ console.warn(_message);
1705
+ if (throwTokens.includes(token)) throw new RangeError(_message);
1706
+ }
1707
+ function message(token, format2, input) {
1708
+ const subject = token[0] === "Y" ? "years" : "days of the month";
1709
+ return `Use \`${token.toLowerCase()}\` instead of \`${token}\` (in \`${format2}\`) for formatting ${subject} to the input \`${input}\`; see: https://github.com/date-fns/date-fns/blob/master/docs/unicodeTokens.md`;
1710
+ }
1711
+ const formattingTokensRegExp = /[yYQqMLwIdDecihHKkms]o|(\w)\1*|''|'(''|[^'])+('|$)|./g;
1712
+ const longFormattingTokensRegExp = /P+p+|P+|p+|''|'(''|[^'])+('|$)|./g;
1713
+ const escapedStringRegExp = /^'([^]*?)'?$/;
1714
+ const doubleQuoteRegExp = /''/g;
1715
+ const unescapedLatinCharacterRegExp = /[a-zA-Z]/;
1716
+ function format(date, formatStr, options) {
1717
+ var _a, _b, _c, _d;
1718
+ const defaultOptions2 = getDefaultOptions();
1719
+ const locale = defaultOptions2.locale ?? enUS;
1720
+ const firstWeekContainsDate = defaultOptions2.firstWeekContainsDate ?? ((_b = (_a = defaultOptions2.locale) == null ? void 0 : _a.options) == null ? void 0 : _b.firstWeekContainsDate) ?? 1;
1721
+ const weekStartsOn = defaultOptions2.weekStartsOn ?? ((_d = (_c = defaultOptions2.locale) == null ? void 0 : _c.options) == null ? void 0 : _d.weekStartsOn) ?? 0;
1722
+ const originalDate = toDate(date, options == null ? void 0 : options.in);
1723
+ if (!isValid(originalDate)) {
1724
+ throw new RangeError("Invalid time value");
1725
+ }
1726
+ let parts = formatStr.match(longFormattingTokensRegExp).map((substring) => {
1727
+ const firstCharacter = substring[0];
1728
+ if (firstCharacter === "p" || firstCharacter === "P") {
1729
+ const longFormatter = longFormatters[firstCharacter];
1730
+ return longFormatter(substring, locale.formatLong);
1731
+ }
1732
+ return substring;
1733
+ }).join("").match(formattingTokensRegExp).map((substring) => {
1734
+ if (substring === "''") {
1735
+ return { isToken: false, value: "'" };
1736
+ }
1737
+ const firstCharacter = substring[0];
1738
+ if (firstCharacter === "'") {
1739
+ return { isToken: false, value: cleanEscapedString(substring) };
1740
+ }
1741
+ if (formatters[firstCharacter]) {
1742
+ return { isToken: true, value: substring };
1743
+ }
1744
+ if (firstCharacter.match(unescapedLatinCharacterRegExp)) {
1745
+ throw new RangeError(
1746
+ "Format string contains an unescaped latin alphabet character `" + firstCharacter + "`"
1747
+ );
1748
+ }
1749
+ return { isToken: false, value: substring };
1750
+ });
1751
+ if (locale.localize.preprocessor) {
1752
+ parts = locale.localize.preprocessor(originalDate, parts);
1753
+ }
1754
+ const formatterOptions = {
1755
+ firstWeekContainsDate,
1756
+ weekStartsOn,
1757
+ locale
1758
+ };
1759
+ return parts.map((part) => {
1760
+ if (!part.isToken) return part.value;
1761
+ const token = part.value;
1762
+ if (isProtectedWeekYearToken(token) || isProtectedDayOfYearToken(token)) {
1763
+ warnOrThrowProtectedError(token, formatStr, String(date));
1764
+ }
1765
+ const formatter = formatters[token[0]];
1766
+ return formatter(originalDate, token, locale.localize, formatterOptions);
1767
+ }).join("");
1768
+ }
1769
+ function cleanEscapedString(input) {
1770
+ const matched = input.match(escapedStringRegExp);
1771
+ if (!matched) {
1772
+ return input;
1773
+ }
1774
+ return matched[1].replace(doubleQuoteRegExp, "'");
1775
+ }
1776
+ function NodeInput(props) {
1777
+ const { onSubmit, onCancel, defaultValue, className, minLength = 1, ...inputProps } = props;
1778
+ const [value, setValue] = useState(defaultValue ?? "");
1779
+ const ref = useRef(null);
1780
+ useOnClickOutside(ref, handleSubmit);
1781
+ useEventListener("keyup", (e) => {
1782
+ if (e.key === "Enter") {
1783
+ handleSubmit();
1784
+ }
1785
+ if (e.key === "Escape") {
1786
+ onCancel();
1787
+ }
1788
+ });
1789
+ useLayoutEffect(() => {
1790
+ setTimeout(() => {
1791
+ var _a, _b, _c;
1792
+ (_a = ref.current) == null ? void 0 : _a.focus();
1793
+ (_b = ref.current) == null ? void 0 : _b.select();
1794
+ (_c = ref.current) == null ? void 0 : _c.scroll({ left: 9999 });
1795
+ }, 100);
1796
+ }, []);
1797
+ function handleSubmit() {
1798
+ if (value.length >= minLength) {
1799
+ onSubmit(value);
1800
+ }
1801
+ }
1802
+ return jsx("input", { ...inputProps, autoFocus: true, className: twMerge("bg-inherit text-inherit outline-none", className), minLength, onChange: (e) => setValue(e.target.value), ref, required: true, type: "text", value });
1803
+ }
1804
+ function Branch(props) {
1805
+ const { branch = "main" } = props;
1806
+ return jsxs("button", { className: "flex h-8 items-center gap-1 rounded-lg bg-slate-50 pl-1 pr-2 text-xs text-slate-100", children: [jsx(Icon, { name: "Branch" }), jsx("span", { children: "BRANCH" }), jsx("span", { className: "text-gray-900", children: branch })] });
1807
+ }
1808
+ function DocId(props) {
1809
+ const { docId } = props;
1810
+ const [, copy] = useCopyToClipboard();
1811
+ function handleCopy(text) {
1812
+ return () => {
1813
+ copy(text).catch((error) => {
1814
+ console.error("Failed to copy!", error);
1815
+ });
1816
+ };
1817
+ }
1818
+ return jsxs("button", { className: "flex h-8 items-center gap-1 rounded-lg bg-slate-50 pl-1 pr-2 text-xs text-slate-100", onClick: handleCopy(docId), children: [jsx(Icon, { name: "Link" }), "DOC ID", jsx("span", { className: "text-gray-900", children: docId })] });
1819
+ }
1820
+ function Scope(props) {
1821
+ const { value, onChange } = props;
1822
+ const items = [
1823
+ { displayValue: "Global scope", value: "global" },
1824
+ { displayValue: "Local scope", value: "local" }
1825
+ ];
1826
+ return jsx(Select, { absolutePositionMenu: true, containerClassName: "bg-slate-50 text-gray-500 rounded-lg w-fit text-xs z-10", id: "scope select", itemClassName: "py-2 text-gray-500 grid grid-cols-[auto,auto] gap-1", items, menuClassName: "min-w-0 text-gray-500", onChange, value });
1827
+ }
1828
+ function Header(props) {
1829
+ const { title, docId, scope, onChangeScope, onClose, className, ...divProps } = props;
1830
+ return jsxs("header", { className: twMerge("flex items-center justify-between bg-transparent", className), ...divProps, children: [jsxs("div", { className: "flex items-center gap-3", children: [jsx("button", { className: "shadow-button rounded-lg bg-gray-50 p-1 text-slate-100", onClick: onClose, children: jsx(Icon, { name: "VariantArrowLeft" }) }), jsx("h1", { className: "text-xs", children: title })] }), jsxs("div", { className: "flex items-center gap-2", children: [jsx(DocId, { docId }), jsx(Branch, {}), jsx(Scope, { onChange: onChangeScope, value: scope })] })] });
1831
+ }
1832
+ function memo(getDeps, fn, opts) {
1833
+ let deps = opts.initialDeps ?? [];
1834
+ let result;
1835
+ function memoizedFunction() {
1836
+ var _a, _b, _c, _d;
1837
+ let depTime;
1838
+ if (opts.key && ((_a = opts.debug) == null ? void 0 : _a.call(opts))) depTime = Date.now();
1839
+ const newDeps = getDeps();
1840
+ const depsChanged = newDeps.length !== deps.length || newDeps.some((dep, index) => deps[index] !== dep);
1841
+ if (!depsChanged) {
1842
+ return result;
1843
+ }
1844
+ deps = newDeps;
1845
+ let resultTime;
1846
+ if (opts.key && ((_b = opts.debug) == null ? void 0 : _b.call(opts))) resultTime = Date.now();
1847
+ result = fn(...newDeps);
1848
+ if (opts.key && ((_c = opts.debug) == null ? void 0 : _c.call(opts))) {
1849
+ const depEndTime = Math.round((Date.now() - depTime) * 100) / 100;
1850
+ const resultEndTime = Math.round((Date.now() - resultTime) * 100) / 100;
1851
+ const resultFpsPercentage = resultEndTime / 16;
1852
+ const pad = (str, num) => {
1853
+ str = String(str);
1854
+ while (str.length < num) {
1855
+ str = " " + str;
1856
+ }
1857
+ return str;
1858
+ };
1859
+ console.info(
1860
+ `%c⏱ ${pad(resultEndTime, 5)} /${pad(depEndTime, 5)} ms`,
1861
+ `
1862
+ font-size: .6rem;
1863
+ font-weight: bold;
1864
+ color: hsl(${Math.max(
1865
+ 0,
1866
+ Math.min(120 - 120 * resultFpsPercentage, 120)
1867
+ )}deg 100% 31%);`,
1868
+ opts == null ? void 0 : opts.key
1869
+ );
1870
+ }
1871
+ (_d = opts == null ? void 0 : opts.onChange) == null ? void 0 : _d.call(opts, result);
1872
+ return result;
1873
+ }
1874
+ memoizedFunction.updateDeps = (newDeps) => {
1875
+ deps = newDeps;
1876
+ };
1877
+ return memoizedFunction;
1878
+ }
1879
+ function notUndefined(value, msg) {
1880
+ if (value === void 0) {
1881
+ throw new Error(`Unexpected undefined${""}`);
1882
+ } else {
1883
+ return value;
1884
+ }
1885
+ }
1886
+ const approxEqual = (a, b) => Math.abs(a - b) < 1;
1887
+ const debounce = (targetWindow, fn, ms) => {
1888
+ let timeoutId;
1889
+ return function(...args) {
1890
+ targetWindow.clearTimeout(timeoutId);
1891
+ timeoutId = targetWindow.setTimeout(() => fn.apply(this, args), ms);
1892
+ };
1893
+ };
1894
+ const defaultKeyExtractor = (index) => index;
1895
+ const defaultRangeExtractor = (range) => {
1896
+ const start = Math.max(range.startIndex - range.overscan, 0);
1897
+ const end = Math.min(range.endIndex + range.overscan, range.count - 1);
1898
+ const arr = [];
1899
+ for (let i = start; i <= end; i++) {
1900
+ arr.push(i);
1901
+ }
1902
+ return arr;
1903
+ };
1904
+ const observeElementRect = (instance, cb) => {
1905
+ const element = instance.scrollElement;
1906
+ if (!element) {
1907
+ return;
1908
+ }
1909
+ const targetWindow = instance.targetWindow;
1910
+ if (!targetWindow) {
1911
+ return;
1912
+ }
1913
+ const handler = (rect) => {
1914
+ const { width, height } = rect;
1915
+ cb({ width: Math.round(width), height: Math.round(height) });
1916
+ };
1917
+ handler(element.getBoundingClientRect());
1918
+ if (!targetWindow.ResizeObserver) {
1919
+ return () => {
1920
+ };
1921
+ }
1922
+ const observer = new targetWindow.ResizeObserver((entries) => {
1923
+ const run = () => {
1924
+ const entry = entries[0];
1925
+ if (entry == null ? void 0 : entry.borderBoxSize) {
1926
+ const box = entry.borderBoxSize[0];
1927
+ if (box) {
1928
+ handler({ width: box.inlineSize, height: box.blockSize });
1929
+ return;
1930
+ }
1931
+ }
1932
+ handler(element.getBoundingClientRect());
1933
+ };
1934
+ instance.options.useAnimationFrameWithResizeObserver ? requestAnimationFrame(run) : run();
1935
+ });
1936
+ observer.observe(element, { box: "border-box" });
1937
+ return () => {
1938
+ observer.unobserve(element);
1939
+ };
1940
+ };
1941
+ const addEventListenerOptions = {
1942
+ passive: true
1943
+ };
1944
+ const supportsScrollend = typeof window == "undefined" ? true : "onscrollend" in window;
1945
+ const observeElementOffset = (instance, cb) => {
1946
+ const element = instance.scrollElement;
1947
+ if (!element) {
1948
+ return;
1949
+ }
1950
+ const targetWindow = instance.targetWindow;
1951
+ if (!targetWindow) {
1952
+ return;
1953
+ }
1954
+ let offset = 0;
1955
+ const fallback = instance.options.useScrollendEvent && supportsScrollend ? () => void 0 : debounce(
1956
+ targetWindow,
1957
+ () => {
1958
+ cb(offset, false);
1959
+ },
1960
+ instance.options.isScrollingResetDelay
1961
+ );
1962
+ const createHandler = (isScrolling) => () => {
1963
+ const { horizontal, isRtl } = instance.options;
1964
+ offset = horizontal ? element["scrollLeft"] * (isRtl && -1 || 1) : element["scrollTop"];
1965
+ fallback();
1966
+ cb(offset, isScrolling);
1967
+ };
1968
+ const handler = createHandler(true);
1969
+ const endHandler = createHandler(false);
1970
+ endHandler();
1971
+ element.addEventListener("scroll", handler, addEventListenerOptions);
1972
+ const registerScrollendEvent = instance.options.useScrollendEvent && supportsScrollend;
1973
+ if (registerScrollendEvent) {
1974
+ element.addEventListener("scrollend", endHandler, addEventListenerOptions);
1975
+ }
1976
+ return () => {
1977
+ element.removeEventListener("scroll", handler);
1978
+ if (registerScrollendEvent) {
1979
+ element.removeEventListener("scrollend", endHandler);
1980
+ }
1981
+ };
1982
+ };
1983
+ const measureElement = (element, entry, instance) => {
1984
+ if (entry == null ? void 0 : entry.borderBoxSize) {
1985
+ const box = entry.borderBoxSize[0];
1986
+ if (box) {
1987
+ const size = Math.round(
1988
+ box[instance.options.horizontal ? "inlineSize" : "blockSize"]
1989
+ );
1990
+ return size;
1991
+ }
1992
+ }
1993
+ return Math.round(
1994
+ element.getBoundingClientRect()[instance.options.horizontal ? "width" : "height"]
1995
+ );
1996
+ };
1997
+ const elementScroll = (offset, {
1998
+ adjustments = 0,
1999
+ behavior
2000
+ }, instance) => {
2001
+ var _a, _b;
2002
+ const toOffset = offset + adjustments;
2003
+ (_b = (_a = instance.scrollElement) == null ? void 0 : _a.scrollTo) == null ? void 0 : _b.call(_a, {
2004
+ [instance.options.horizontal ? "left" : "top"]: toOffset,
2005
+ behavior
2006
+ });
2007
+ };
2008
+ class Virtualizer {
2009
+ constructor(opts) {
2010
+ this.unsubs = [];
2011
+ this.scrollElement = null;
2012
+ this.targetWindow = null;
2013
+ this.isScrolling = false;
2014
+ this.scrollToIndexTimeoutId = null;
2015
+ this.measurementsCache = [];
2016
+ this.itemSizeCache = /* @__PURE__ */ new Map();
2017
+ this.pendingMeasuredCacheIndexes = [];
2018
+ this.scrollRect = null;
2019
+ this.scrollOffset = null;
2020
+ this.scrollDirection = null;
2021
+ this.scrollAdjustments = 0;
2022
+ this.elementsCache = /* @__PURE__ */ new Map();
2023
+ this.observer = /* @__PURE__ */ (() => {
2024
+ let _ro = null;
2025
+ const get = () => {
2026
+ if (_ro) {
2027
+ return _ro;
2028
+ }
2029
+ if (!this.targetWindow || !this.targetWindow.ResizeObserver) {
2030
+ return null;
2031
+ }
2032
+ return _ro = new this.targetWindow.ResizeObserver((entries) => {
2033
+ entries.forEach((entry) => {
2034
+ const run = () => {
2035
+ this._measureElement(entry.target, entry);
2036
+ };
2037
+ this.options.useAnimationFrameWithResizeObserver ? requestAnimationFrame(run) : run();
2038
+ });
2039
+ });
2040
+ };
2041
+ return {
2042
+ disconnect: () => {
2043
+ var _a;
2044
+ (_a = get()) == null ? void 0 : _a.disconnect();
2045
+ _ro = null;
2046
+ },
2047
+ observe: (target) => {
2048
+ var _a;
2049
+ return (_a = get()) == null ? void 0 : _a.observe(target, { box: "border-box" });
2050
+ },
2051
+ unobserve: (target) => {
2052
+ var _a;
2053
+ return (_a = get()) == null ? void 0 : _a.unobserve(target);
2054
+ }
2055
+ };
2056
+ })();
2057
+ this.range = null;
2058
+ this.setOptions = (opts2) => {
2059
+ Object.entries(opts2).forEach(([key, value]) => {
2060
+ if (typeof value === "undefined") delete opts2[key];
2061
+ });
2062
+ this.options = {
2063
+ debug: false,
2064
+ initialOffset: 0,
2065
+ overscan: 1,
2066
+ paddingStart: 0,
2067
+ paddingEnd: 0,
2068
+ scrollPaddingStart: 0,
2069
+ scrollPaddingEnd: 0,
2070
+ horizontal: false,
2071
+ getItemKey: defaultKeyExtractor,
2072
+ rangeExtractor: defaultRangeExtractor,
2073
+ onChange: () => {
2074
+ },
2075
+ measureElement,
2076
+ initialRect: { width: 0, height: 0 },
2077
+ scrollMargin: 0,
2078
+ gap: 0,
2079
+ indexAttribute: "data-index",
2080
+ initialMeasurementsCache: [],
2081
+ lanes: 1,
2082
+ isScrollingResetDelay: 150,
2083
+ enabled: true,
2084
+ isRtl: false,
2085
+ useScrollendEvent: false,
2086
+ useAnimationFrameWithResizeObserver: false,
2087
+ ...opts2
2088
+ };
2089
+ };
2090
+ this.notify = (sync) => {
2091
+ var _a, _b;
2092
+ (_b = (_a = this.options).onChange) == null ? void 0 : _b.call(_a, this, sync);
2093
+ };
2094
+ this.maybeNotify = memo(
2095
+ () => {
2096
+ this.calculateRange();
2097
+ return [
2098
+ this.isScrolling,
2099
+ this.range ? this.range.startIndex : null,
2100
+ this.range ? this.range.endIndex : null
2101
+ ];
2102
+ },
2103
+ (isScrolling) => {
2104
+ this.notify(isScrolling);
2105
+ },
2106
+ {
2107
+ key: false,
2108
+ debug: () => this.options.debug,
2109
+ initialDeps: [
2110
+ this.isScrolling,
2111
+ this.range ? this.range.startIndex : null,
2112
+ this.range ? this.range.endIndex : null
2113
+ ]
2114
+ }
2115
+ );
2116
+ this.cleanup = () => {
2117
+ this.unsubs.filter(Boolean).forEach((d) => d());
2118
+ this.unsubs = [];
2119
+ this.observer.disconnect();
2120
+ this.scrollElement = null;
2121
+ this.targetWindow = null;
2122
+ };
2123
+ this._didMount = () => {
2124
+ return () => {
2125
+ this.cleanup();
2126
+ };
2127
+ };
2128
+ this._willUpdate = () => {
2129
+ var _a;
2130
+ const scrollElement = this.options.enabled ? this.options.getScrollElement() : null;
2131
+ if (this.scrollElement !== scrollElement) {
2132
+ this.cleanup();
2133
+ if (!scrollElement) {
2134
+ this.maybeNotify();
2135
+ return;
2136
+ }
2137
+ this.scrollElement = scrollElement;
2138
+ if (this.scrollElement && "ownerDocument" in this.scrollElement) {
2139
+ this.targetWindow = this.scrollElement.ownerDocument.defaultView;
2140
+ } else {
2141
+ this.targetWindow = ((_a = this.scrollElement) == null ? void 0 : _a.window) ?? null;
2142
+ }
2143
+ this.elementsCache.forEach((cached) => {
2144
+ this.observer.observe(cached);
2145
+ });
2146
+ this._scrollToOffset(this.getScrollOffset(), {
2147
+ adjustments: void 0,
2148
+ behavior: void 0
2149
+ });
2150
+ this.unsubs.push(
2151
+ this.options.observeElementRect(this, (rect) => {
2152
+ this.scrollRect = rect;
2153
+ this.maybeNotify();
2154
+ })
2155
+ );
2156
+ this.unsubs.push(
2157
+ this.options.observeElementOffset(this, (offset, isScrolling) => {
2158
+ this.scrollAdjustments = 0;
2159
+ this.scrollDirection = isScrolling ? this.getScrollOffset() < offset ? "forward" : "backward" : null;
2160
+ this.scrollOffset = offset;
2161
+ this.isScrolling = isScrolling;
2162
+ this.maybeNotify();
2163
+ })
2164
+ );
2165
+ }
2166
+ };
2167
+ this.getSize = () => {
2168
+ if (!this.options.enabled) {
2169
+ this.scrollRect = null;
2170
+ return 0;
2171
+ }
2172
+ this.scrollRect = this.scrollRect ?? this.options.initialRect;
2173
+ return this.scrollRect[this.options.horizontal ? "width" : "height"];
2174
+ };
2175
+ this.getScrollOffset = () => {
2176
+ if (!this.options.enabled) {
2177
+ this.scrollOffset = null;
2178
+ return 0;
2179
+ }
2180
+ this.scrollOffset = this.scrollOffset ?? (typeof this.options.initialOffset === "function" ? this.options.initialOffset() : this.options.initialOffset);
2181
+ return this.scrollOffset;
2182
+ };
2183
+ this.getFurthestMeasurement = (measurements, index) => {
2184
+ const furthestMeasurementsFound = /* @__PURE__ */ new Map();
2185
+ const furthestMeasurements = /* @__PURE__ */ new Map();
2186
+ for (let m = index - 1; m >= 0; m--) {
2187
+ const measurement = measurements[m];
2188
+ if (furthestMeasurementsFound.has(measurement.lane)) {
2189
+ continue;
2190
+ }
2191
+ const previousFurthestMeasurement = furthestMeasurements.get(
2192
+ measurement.lane
2193
+ );
2194
+ if (previousFurthestMeasurement == null || measurement.end > previousFurthestMeasurement.end) {
2195
+ furthestMeasurements.set(measurement.lane, measurement);
2196
+ } else if (measurement.end < previousFurthestMeasurement.end) {
2197
+ furthestMeasurementsFound.set(measurement.lane, true);
2198
+ }
2199
+ if (furthestMeasurementsFound.size === this.options.lanes) {
2200
+ break;
2201
+ }
2202
+ }
2203
+ return furthestMeasurements.size === this.options.lanes ? Array.from(furthestMeasurements.values()).sort((a, b) => {
2204
+ if (a.end === b.end) {
2205
+ return a.index - b.index;
2206
+ }
2207
+ return a.end - b.end;
2208
+ })[0] : void 0;
2209
+ };
2210
+ this.getMeasurementOptions = memo(
2211
+ () => [
2212
+ this.options.count,
2213
+ this.options.paddingStart,
2214
+ this.options.scrollMargin,
2215
+ this.options.getItemKey,
2216
+ this.options.enabled
2217
+ ],
2218
+ (count, paddingStart, scrollMargin, getItemKey, enabled) => {
2219
+ this.pendingMeasuredCacheIndexes = [];
2220
+ return {
2221
+ count,
2222
+ paddingStart,
2223
+ scrollMargin,
2224
+ getItemKey,
2225
+ enabled
2226
+ };
2227
+ },
2228
+ {
2229
+ key: false
2230
+ }
2231
+ );
2232
+ this.getMeasurements = memo(
2233
+ () => [this.getMeasurementOptions(), this.itemSizeCache],
2234
+ ({ count, paddingStart, scrollMargin, getItemKey, enabled }, itemSizeCache) => {
2235
+ if (!enabled) {
2236
+ this.measurementsCache = [];
2237
+ this.itemSizeCache.clear();
2238
+ return [];
2239
+ }
2240
+ if (this.measurementsCache.length === 0) {
2241
+ this.measurementsCache = this.options.initialMeasurementsCache;
2242
+ this.measurementsCache.forEach((item) => {
2243
+ this.itemSizeCache.set(item.key, item.size);
2244
+ });
2245
+ }
2246
+ const min = this.pendingMeasuredCacheIndexes.length > 0 ? Math.min(...this.pendingMeasuredCacheIndexes) : 0;
2247
+ this.pendingMeasuredCacheIndexes = [];
2248
+ const measurements = this.measurementsCache.slice(0, min);
2249
+ for (let i = min; i < count; i++) {
2250
+ const key = getItemKey(i);
2251
+ const furthestMeasurement = this.options.lanes === 1 ? measurements[i - 1] : this.getFurthestMeasurement(measurements, i);
2252
+ const start = furthestMeasurement ? furthestMeasurement.end + this.options.gap : paddingStart + scrollMargin;
2253
+ const measuredSize = itemSizeCache.get(key);
2254
+ const size = typeof measuredSize === "number" ? measuredSize : this.options.estimateSize(i);
2255
+ const end = start + size;
2256
+ const lane = furthestMeasurement ? furthestMeasurement.lane : i % this.options.lanes;
2257
+ measurements[i] = {
2258
+ index: i,
2259
+ start,
2260
+ size,
2261
+ end,
2262
+ key,
2263
+ lane
2264
+ };
2265
+ }
2266
+ this.measurementsCache = measurements;
2267
+ return measurements;
2268
+ },
2269
+ {
2270
+ key: false,
2271
+ debug: () => this.options.debug
2272
+ }
2273
+ );
2274
+ this.calculateRange = memo(
2275
+ () => [
2276
+ this.getMeasurements(),
2277
+ this.getSize(),
2278
+ this.getScrollOffset(),
2279
+ this.options.lanes
2280
+ ],
2281
+ (measurements, outerSize, scrollOffset, lanes) => {
2282
+ return this.range = measurements.length > 0 && outerSize > 0 ? calculateRange({
2283
+ measurements,
2284
+ outerSize,
2285
+ scrollOffset,
2286
+ lanes
2287
+ }) : null;
2288
+ },
2289
+ {
2290
+ key: false,
2291
+ debug: () => this.options.debug
2292
+ }
2293
+ );
2294
+ this.getVirtualIndexes = memo(
2295
+ () => {
2296
+ let startIndex = null;
2297
+ let endIndex = null;
2298
+ const range = this.calculateRange();
2299
+ if (range) {
2300
+ startIndex = range.startIndex;
2301
+ endIndex = range.endIndex;
2302
+ }
2303
+ this.maybeNotify.updateDeps([this.isScrolling, startIndex, endIndex]);
2304
+ return [
2305
+ this.options.rangeExtractor,
2306
+ this.options.overscan,
2307
+ this.options.count,
2308
+ startIndex,
2309
+ endIndex
2310
+ ];
2311
+ },
2312
+ (rangeExtractor, overscan, count, startIndex, endIndex) => {
2313
+ return startIndex === null || endIndex === null ? [] : rangeExtractor({
2314
+ startIndex,
2315
+ endIndex,
2316
+ overscan,
2317
+ count
2318
+ });
2319
+ },
2320
+ {
2321
+ key: false,
2322
+ debug: () => this.options.debug
2323
+ }
2324
+ );
2325
+ this.indexFromElement = (node) => {
2326
+ const attributeName = this.options.indexAttribute;
2327
+ const indexStr = node.getAttribute(attributeName);
2328
+ if (!indexStr) {
2329
+ console.warn(
2330
+ `Missing attribute name '${attributeName}={index}' on measured element.`
2331
+ );
2332
+ return -1;
2333
+ }
2334
+ return parseInt(indexStr, 10);
2335
+ };
2336
+ this._measureElement = (node, entry) => {
2337
+ const index = this.indexFromElement(node);
2338
+ const item = this.measurementsCache[index];
2339
+ if (!item) {
2340
+ return;
2341
+ }
2342
+ const key = item.key;
2343
+ const prevNode = this.elementsCache.get(key);
2344
+ if (prevNode !== node) {
2345
+ if (prevNode) {
2346
+ this.observer.unobserve(prevNode);
2347
+ }
2348
+ this.observer.observe(node);
2349
+ this.elementsCache.set(key, node);
2350
+ }
2351
+ if (node.isConnected) {
2352
+ this.resizeItem(index, this.options.measureElement(node, entry, this));
2353
+ }
2354
+ };
2355
+ this.resizeItem = (index, size) => {
2356
+ const item = this.measurementsCache[index];
2357
+ if (!item) {
2358
+ return;
2359
+ }
2360
+ const itemSize = this.itemSizeCache.get(item.key) ?? item.size;
2361
+ const delta = size - itemSize;
2362
+ if (delta !== 0) {
2363
+ if (this.shouldAdjustScrollPositionOnItemSizeChange !== void 0 ? this.shouldAdjustScrollPositionOnItemSizeChange(item, delta, this) : item.start < this.getScrollOffset() + this.scrollAdjustments) {
2364
+ this._scrollToOffset(this.getScrollOffset(), {
2365
+ adjustments: this.scrollAdjustments += delta,
2366
+ behavior: void 0
2367
+ });
2368
+ }
2369
+ this.pendingMeasuredCacheIndexes.push(item.index);
2370
+ this.itemSizeCache = new Map(this.itemSizeCache.set(item.key, size));
2371
+ this.notify(false);
2372
+ }
2373
+ };
2374
+ this.measureElement = (node) => {
2375
+ if (!node) {
2376
+ this.elementsCache.forEach((cached, key) => {
2377
+ if (!cached.isConnected) {
2378
+ this.observer.unobserve(cached);
2379
+ this.elementsCache.delete(key);
2380
+ }
2381
+ });
2382
+ return;
2383
+ }
2384
+ this._measureElement(node, void 0);
2385
+ };
2386
+ this.getVirtualItems = memo(
2387
+ () => [this.getVirtualIndexes(), this.getMeasurements()],
2388
+ (indexes, measurements) => {
2389
+ const virtualItems = [];
2390
+ for (let k = 0, len = indexes.length; k < len; k++) {
2391
+ const i = indexes[k];
2392
+ const measurement = measurements[i];
2393
+ virtualItems.push(measurement);
2394
+ }
2395
+ return virtualItems;
2396
+ },
2397
+ {
2398
+ key: false,
2399
+ debug: () => this.options.debug
2400
+ }
2401
+ );
2402
+ this.getVirtualItemForOffset = (offset) => {
2403
+ const measurements = this.getMeasurements();
2404
+ if (measurements.length === 0) {
2405
+ return void 0;
2406
+ }
2407
+ return notUndefined(
2408
+ measurements[findNearestBinarySearch(
2409
+ 0,
2410
+ measurements.length - 1,
2411
+ (index) => notUndefined(measurements[index]).start,
2412
+ offset
2413
+ )]
2414
+ );
2415
+ };
2416
+ this.getOffsetForAlignment = (toOffset, align, itemSize = 0) => {
2417
+ const size = this.getSize();
2418
+ const scrollOffset = this.getScrollOffset();
2419
+ if (align === "auto") {
2420
+ align = toOffset >= scrollOffset + size ? "end" : "start";
2421
+ }
2422
+ if (align === "center") {
2423
+ toOffset += (itemSize - size) / 2;
2424
+ } else if (align === "end") {
2425
+ toOffset -= size;
2426
+ }
2427
+ const scrollSizeProp = this.options.horizontal ? "scrollWidth" : "scrollHeight";
2428
+ const scrollSize = this.scrollElement ? "document" in this.scrollElement ? this.scrollElement.document.documentElement[scrollSizeProp] : this.scrollElement[scrollSizeProp] : 0;
2429
+ const maxOffset = scrollSize - size;
2430
+ return Math.max(Math.min(maxOffset, toOffset), 0);
2431
+ };
2432
+ this.getOffsetForIndex = (index, align = "auto") => {
2433
+ index = Math.max(0, Math.min(index, this.options.count - 1));
2434
+ const item = this.measurementsCache[index];
2435
+ if (!item) {
2436
+ return void 0;
2437
+ }
2438
+ const size = this.getSize();
2439
+ const scrollOffset = this.getScrollOffset();
2440
+ if (align === "auto") {
2441
+ if (item.end >= scrollOffset + size - this.options.scrollPaddingEnd) {
2442
+ align = "end";
2443
+ } else if (item.start <= scrollOffset + this.options.scrollPaddingStart) {
2444
+ align = "start";
2445
+ } else {
2446
+ return [scrollOffset, align];
2447
+ }
2448
+ }
2449
+ const toOffset = align === "end" ? item.end + this.options.scrollPaddingEnd : item.start - this.options.scrollPaddingStart;
2450
+ return [
2451
+ this.getOffsetForAlignment(toOffset, align, item.size),
2452
+ align
2453
+ ];
2454
+ };
2455
+ this.isDynamicMode = () => this.elementsCache.size > 0;
2456
+ this.cancelScrollToIndex = () => {
2457
+ if (this.scrollToIndexTimeoutId !== null && this.targetWindow) {
2458
+ this.targetWindow.clearTimeout(this.scrollToIndexTimeoutId);
2459
+ this.scrollToIndexTimeoutId = null;
2460
+ }
2461
+ };
2462
+ this.scrollToOffset = (toOffset, { align = "start", behavior } = {}) => {
2463
+ this.cancelScrollToIndex();
2464
+ if (behavior === "smooth" && this.isDynamicMode()) {
2465
+ console.warn(
2466
+ "The `smooth` scroll behavior is not fully supported with dynamic size."
2467
+ );
2468
+ }
2469
+ this._scrollToOffset(this.getOffsetForAlignment(toOffset, align), {
2470
+ adjustments: void 0,
2471
+ behavior
2472
+ });
2473
+ };
2474
+ this.scrollToIndex = (index, { align: initialAlign = "auto", behavior } = {}) => {
2475
+ index = Math.max(0, Math.min(index, this.options.count - 1));
2476
+ this.cancelScrollToIndex();
2477
+ if (behavior === "smooth" && this.isDynamicMode()) {
2478
+ console.warn(
2479
+ "The `smooth` scroll behavior is not fully supported with dynamic size."
2480
+ );
2481
+ }
2482
+ const offsetAndAlign = this.getOffsetForIndex(index, initialAlign);
2483
+ if (!offsetAndAlign) return;
2484
+ const [offset, align] = offsetAndAlign;
2485
+ this._scrollToOffset(offset, { adjustments: void 0, behavior });
2486
+ if (behavior !== "smooth" && this.isDynamicMode() && this.targetWindow) {
2487
+ this.scrollToIndexTimeoutId = this.targetWindow.setTimeout(() => {
2488
+ this.scrollToIndexTimeoutId = null;
2489
+ const elementInDOM = this.elementsCache.has(
2490
+ this.options.getItemKey(index)
2491
+ );
2492
+ if (elementInDOM) {
2493
+ const [latestOffset] = notUndefined(
2494
+ this.getOffsetForIndex(index, align)
2495
+ );
2496
+ if (!approxEqual(latestOffset, this.getScrollOffset())) {
2497
+ this.scrollToIndex(index, { align, behavior });
2498
+ }
2499
+ } else {
2500
+ this.scrollToIndex(index, { align, behavior });
2501
+ }
2502
+ });
2503
+ }
2504
+ };
2505
+ this.scrollBy = (delta, { behavior } = {}) => {
2506
+ this.cancelScrollToIndex();
2507
+ if (behavior === "smooth" && this.isDynamicMode()) {
2508
+ console.warn(
2509
+ "The `smooth` scroll behavior is not fully supported with dynamic size."
2510
+ );
2511
+ }
2512
+ this._scrollToOffset(this.getScrollOffset() + delta, {
2513
+ adjustments: void 0,
2514
+ behavior
2515
+ });
2516
+ };
2517
+ this.getTotalSize = () => {
2518
+ var _a;
2519
+ const measurements = this.getMeasurements();
2520
+ let end;
2521
+ if (measurements.length === 0) {
2522
+ end = this.options.paddingStart;
2523
+ } else if (this.options.lanes === 1) {
2524
+ end = ((_a = measurements[measurements.length - 1]) == null ? void 0 : _a.end) ?? 0;
2525
+ } else {
2526
+ const endByLane = Array(this.options.lanes).fill(null);
2527
+ let endIndex = measurements.length - 1;
2528
+ while (endIndex > 0 && endByLane.some((val) => val === null)) {
2529
+ const item = measurements[endIndex];
2530
+ if (endByLane[item.lane] === null) {
2531
+ endByLane[item.lane] = item.end;
2532
+ }
2533
+ endIndex--;
2534
+ }
2535
+ end = Math.max(...endByLane.filter((val) => val !== null));
2536
+ }
2537
+ return Math.max(
2538
+ end - this.options.scrollMargin + this.options.paddingEnd,
2539
+ 0
2540
+ );
2541
+ };
2542
+ this._scrollToOffset = (offset, {
2543
+ adjustments,
2544
+ behavior
2545
+ }) => {
2546
+ this.options.scrollToFn(offset, { behavior, adjustments }, this);
2547
+ };
2548
+ this.measure = () => {
2549
+ this.itemSizeCache = /* @__PURE__ */ new Map();
2550
+ this.notify(false);
2551
+ };
2552
+ this.setOptions(opts);
2553
+ }
2554
+ }
2555
+ const findNearestBinarySearch = (low, high, getCurrentValue, value) => {
2556
+ while (low <= high) {
2557
+ const middle = (low + high) / 2 | 0;
2558
+ const currentValue = getCurrentValue(middle);
2559
+ if (currentValue < value) {
2560
+ low = middle + 1;
2561
+ } else if (currentValue > value) {
2562
+ high = middle - 1;
2563
+ } else {
2564
+ return middle;
2565
+ }
2566
+ }
2567
+ if (low > 0) {
2568
+ return low - 1;
2569
+ } else {
2570
+ return 0;
2571
+ }
2572
+ };
2573
+ function calculateRange({
2574
+ measurements,
2575
+ outerSize,
2576
+ scrollOffset,
2577
+ lanes
2578
+ }) {
2579
+ const lastIndex = measurements.length - 1;
2580
+ const getOffset = (index) => measurements[index].start;
2581
+ if (measurements.length <= lanes) {
2582
+ return {
2583
+ startIndex: 0,
2584
+ endIndex: lastIndex
2585
+ };
2586
+ }
2587
+ let startIndex = findNearestBinarySearch(
2588
+ 0,
2589
+ lastIndex,
2590
+ getOffset,
2591
+ scrollOffset
2592
+ );
2593
+ let endIndex = startIndex;
2594
+ if (lanes === 1) {
2595
+ while (endIndex < lastIndex && measurements[endIndex].end < scrollOffset + outerSize) {
2596
+ endIndex++;
2597
+ }
2598
+ } else if (lanes > 1) {
2599
+ const endPerLane = Array(lanes).fill(0);
2600
+ while (endIndex < lastIndex && endPerLane.some((pos) => pos < scrollOffset + outerSize)) {
2601
+ const item = measurements[endIndex];
2602
+ endPerLane[item.lane] = item.end;
2603
+ endIndex++;
2604
+ }
2605
+ const startPerLane = Array(lanes).fill(scrollOffset + outerSize);
2606
+ while (startIndex > 0 && startPerLane.some((pos) => pos >= scrollOffset)) {
2607
+ const item = measurements[startIndex];
2608
+ startPerLane[item.lane] = item.start;
2609
+ startIndex--;
2610
+ }
2611
+ startIndex = Math.max(0, startIndex - startIndex % lanes);
2612
+ endIndex = Math.min(lastIndex, endIndex + (lanes - 1 - endIndex % lanes));
2613
+ }
2614
+ return { startIndex, endIndex };
2615
+ }
2616
+ const useIsomorphicLayoutEffect = typeof document !== "undefined" ? React.useLayoutEffect : React.useEffect;
2617
+ function useVirtualizerBase(options) {
2618
+ const rerender = React.useReducer(() => ({}), {})[1];
2619
+ const resolvedOptions = {
2620
+ ...options,
2621
+ onChange: (instance2, sync) => {
2622
+ var _a;
2623
+ if (sync) {
2624
+ flushSync(rerender);
2625
+ } else {
2626
+ rerender();
2627
+ }
2628
+ (_a = options.onChange) == null ? void 0 : _a.call(options, instance2, sync);
2629
+ }
2630
+ };
2631
+ const [instance] = React.useState(
2632
+ () => new Virtualizer(resolvedOptions)
2633
+ );
2634
+ instance.setOptions(resolvedOptions);
2635
+ useIsomorphicLayoutEffect(() => {
2636
+ return instance._didMount();
2637
+ }, []);
2638
+ useIsomorphicLayoutEffect(() => {
2639
+ return instance._willUpdate();
2640
+ });
2641
+ return instance;
2642
+ }
2643
+ function useVirtualizer(options) {
2644
+ return useVirtualizerBase({
2645
+ observeElementRect,
2646
+ observeElementOffset,
2647
+ scrollToFn: elementScroll,
2648
+ ...options
2649
+ });
2650
+ }
2651
+ function Address(props) {
2652
+ const { address, chainId } = props;
2653
+ const [, copy] = useCopyToClipboard();
2654
+ if (!address)
2655
+ return null;
2656
+ const shortenedAddress = formatEthAddress(address);
2657
+ function handleCopy(text) {
2658
+ return () => {
2659
+ copy(text).catch((error) => {
2660
+ console.error("Failed to copy!", error);
2661
+ });
2662
+ };
2663
+ }
2664
+ const tooltipContent = jsxs("button", { className: "flex items-center gap-1", onClick: handleCopy(address), children: [address, jsx(Icon, { className: "inline-block text-gray-600", name: "FilesEarmark", size: 16 })] });
2665
+ return jsx(Tooltip, { content: tooltipContent, children: jsxs("span", { className: "flex w-fit cursor-pointer items-center gap-1 rounded-lg bg-gray-100 p-1 text-xs text-slate-100", children: [jsx(ENSAvatar, { address, chainId }), shortenedAddress] }) });
2666
+ }
2667
+ function Errors(props) {
2668
+ const { errors } = props;
2669
+ const hasErrors = !!(errors == null ? void 0 : errors.length);
2670
+ const color = hasErrors ? "text-red-800" : "text-green-700";
2671
+ const icon = hasErrors ? jsx(Icon, { name: "Exclamation", size: 16 }) : jsx(Icon, { name: "Check", size: 16 });
2672
+ const text = hasErrors ? `Error: ${errors[0]}` : "No errors";
2673
+ const content = jsxs("span", { className: twMerge("flex w-fit items-center rounded-lg border border-gray-200 px-2 py-1 text-xs", color, hasErrors && "cursor-pointer"), children: [icon, jsx("span", { className: twMerge("inline-block max-w-36 truncate"), children: text })] });
2674
+ const tooltipContent = errors == null ? void 0 : errors.map((message2, index) => jsxs("p", { className: "text-red-800", children: ["Error: ", message2] }, index));
2675
+ if (hasErrors)
2676
+ return jsx(Tooltip, { content: tooltipContent, children: content });
2677
+ return content;
2678
+ }
2679
+ function Operation(props) {
2680
+ const { operationType, operationInput } = props;
2681
+ const tooltipContent = jsx("code", { children: jsx("pre", { children: JSON.stringify(operationInput, null, 2) }) });
2682
+ return jsx(Tooltip, { content: tooltipContent, children: jsxs("span", { className: "flex cursor-pointer items-center gap-2 text-xs", children: [operationType, jsx(Icon, { className: "text-gray-300", name: "Braces", size: 16 })] }) });
2683
+ }
2684
+ function RevisionNumber(props) {
2685
+ const { operationIndex, eventId, stateHash } = props;
2686
+ const [, copy] = useCopyToClipboard();
2687
+ const revisionNumber = operationIndex + 1;
2688
+ const tooltipContent = jsxs("button", { className: "flex items-center gap-1", onClick: handleCopy(stateHash), children: ["Revision ", revisionNumber, " - Event ID: ", eventId, " - State Hash: ", stateHash, jsx(Icon, { className: "inline-block text-gray-600", name: "FilesEarmark", size: 16 })] });
2689
+ function handleCopy(text) {
2690
+ return () => {
2691
+ copy(text).catch((error) => {
2692
+ console.error("Failed to copy!", error);
2693
+ });
2694
+ };
2695
+ }
2696
+ return jsx(Tooltip, { content: tooltipContent, children: jsxs("span", { className: "flex cursor-pointer items-center gap-2 text-xs text-gray-600", children: ["Revision ", revisionNumber, ".", jsx("a", { children: jsx(Icon, { className: "cursor-pointer text-slate-100", name: "Ellipsis", size: 14 }) })] }) });
2697
+ }
2698
+ function Signature(props) {
2699
+ const { signatures } = props;
2700
+ if (!(signatures == null ? void 0 : signatures.length))
2701
+ return null;
2702
+ const tooltipContent = jsxs("div", { className: "text-xs text-slate-300", children: [jsx("h3", { className: "mb-2", children: "Signature details:" }), signatures.map((signature, index) => jsxs("div", { className: "mb-2 last:mb-0", children: [jsxs("h4", { children: ["Signature #", index + 1, " -", " ", signature.isVerified ? "verified" : "unverified"] }), jsx("code", { children: jsx("pre", { children: JSON.stringify(signature, null, 2) }) })] }, signature.hash))] });
2703
+ return jsx(Tooltip, { content: tooltipContent, children: jsxs("span", { className: "flex w-fit cursor-pointer items-center gap-1 rounded-lg border border-gray-200 px-2 py-1", children: [jsx(VerificationStatus, { signatures }), " ", jsx(Icon, { className: "text-gray-300", name: "InfoSquare", size: 16 })] }) });
2704
+ }
2705
+ function VerificationStatus(props) {
2706
+ const { signatures } = props;
2707
+ if (!(signatures == null ? void 0 : signatures.length))
2708
+ return null;
2709
+ const signatureCount = signatures.length;
2710
+ const verifiedSignaturesCount = signatures.filter((signature) => signature.isVerified).length;
2711
+ const signatureText = signatureCount === 1 ? "signature" : "signatures";
2712
+ const verificationStatusText = `${verifiedSignaturesCount}/${signatureCount} ${signatureText} verified`;
2713
+ const color = verifiedSignaturesCount === 0 ? "text-red-800" : verifiedSignaturesCount === signatureCount ? "text-green-700" : "text-orange-700";
2714
+ return jsx("span", { className: `text-xs ${color}`, children: verificationStatusText });
2715
+ }
2716
+ function Timestamp(props) {
2717
+ const { timestamp } = props;
2718
+ const timestampNumber = typeof timestamp === "string" && !timestamp.includes("-") ? parseInt(timestamp) : timestamp;
2719
+ const date = new Date(timestampNumber);
2720
+ const shortDate = format(date, "HH:mm 'UTC'");
2721
+ const longDate = format(date, "eee, dd MMM yyyy HH:mm:ss 'UTC'");
2722
+ const tooltipContent = jsx("div", { children: longDate });
2723
+ return jsx(Tooltip, { content: tooltipContent, children: jsxs("span", { className: "cursor-pointer text-xs", children: ["committed at ", shortDate] }) });
2724
+ }
2725
+ function _Revision(props) {
2726
+ return jsxs("article", { className: "flex items-center justify-between rounded-xl border border-gray-200 bg-white px-4 py-2", children: [jsxs("div", { className: "flex items-center gap-2", children: [jsx(RevisionNumber, { ...props }), jsx(Operation, { ...props }), jsx(Address, { ...props }), jsx(Timestamp, { ...props })] }), jsxs("div", { className: "flex items-center gap-1", children: [jsx(Signature, { ...props }), jsx(Errors, { ...props })] })] });
2727
+ }
2728
+ const Revision = memo$1(_Revision);
2729
+ function Skip(props) {
2730
+ const { operationIndex, skipCount } = props;
2731
+ const revisionNumber = operationIndex;
2732
+ const skippedRevisions = skipCount === 1 ? `${revisionNumber}` : `${revisionNumber} - ${revisionNumber + 1 - skipCount}`;
2733
+ return jsxs("article", { className: "grid grid-cols-[1fr,auto,1fr] items-center py-2", children: [jsx("div", { className: "h-px rounded-full bg-slate-100" }), jsxs("div", { className: "mx-3 text-xs text-slate-100", children: ["[Skipped Revision ", skippedRevisions, "]"] }), jsx("div", { className: "h-px rounded-full bg-slate-100" })] });
2734
+ }
2735
+ function makeRows(operations) {
2736
+ var _a, _b, _c, _d, _e, _f;
2737
+ const revisionsAndSkips = [];
2738
+ const seenDays = /* @__PURE__ */ new Set();
2739
+ for (const operation of operations) {
2740
+ const day = operation.timestamp.split("T")[0];
2741
+ if (!seenDays.has(day)) {
2742
+ seenDays.add(day);
2743
+ revisionsAndSkips.push({
2744
+ type: "day",
2745
+ height: 32,
2746
+ timestamp: day
2747
+ });
2748
+ }
2749
+ revisionsAndSkips.push({
2750
+ type: "revision",
2751
+ height: 46,
2752
+ operationIndex: operation.index,
2753
+ eventId: operation.id ?? "EVENT_ID_NOT_FOUND",
2754
+ stateHash: operation.hash,
2755
+ operationType: operation.type,
2756
+ operationInput: operation.input ?? {},
2757
+ address: (_b = (_a = operation.context) == null ? void 0 : _a.signer) == null ? void 0 : _b.user.address,
2758
+ chainId: (_d = (_c = operation.context) == null ? void 0 : _c.signer) == null ? void 0 : _d.user.chainId,
2759
+ timestamp: operation.timestamp,
2760
+ signatures: makeSignatures(((_f = (_e = operation.context) == null ? void 0 : _e.signer) == null ? void 0 : _f.signatures) ?? []),
2761
+ errors: operation.error ? [operation.error] : void 0
2762
+ });
2763
+ if (operation.skip > 0) {
2764
+ revisionsAndSkips.push({
2765
+ type: "skip",
2766
+ height: 34,
2767
+ operationIndex: operation.index,
2768
+ skipCount: operation.skip,
2769
+ timestamp: operation.timestamp
2770
+ });
2771
+ }
2772
+ }
2773
+ return revisionsAndSkips;
2774
+ }
2775
+ function makeSignatureFromSignatureArray(signatureArray) {
2776
+ const [signerAddress, hash, prevStateHash, signatureBytes] = signatureArray;
2777
+ return {
2778
+ signerAddress,
2779
+ hash,
2780
+ prevStateHash,
2781
+ signatureBytes,
2782
+ isVerified: true
2783
+ };
2784
+ }
2785
+ function makeSignatures(signaturesArray) {
2786
+ return signaturesArray == null ? void 0 : signaturesArray.map(makeSignatureFromSignatureArray);
2787
+ }
2788
+ function Day(props) {
2789
+ const { timestamp } = props;
2790
+ const formattedDate = format(timestamp, "MMM dd, yyyy");
2791
+ return jsxs("h2", { className: "-ml-6 flex items-center gap-1 bg-slate-50 py-2 text-xs text-slate-100", children: [jsx(Icon, { name: "Ring", size: 16 }), " Changes on ", formattedDate] });
2792
+ }
2793
+ function Timeline(props) {
2794
+ const { localOperations, globalOperations, scope } = props;
2795
+ const operations = scope === "local" ? localOperations : globalOperations;
2796
+ const initialNumRowsToShow = 100;
2797
+ const allRows = useMemo(() => makeRows(operations), [operations]);
2798
+ const [scrollAmount, setScrollAmount] = useState(0);
2799
+ const [numRowsToShow, setNumRowsToShow] = useState(initialNumRowsToShow);
2800
+ const [rows, setRows] = useState(() => allRows.slice(0, numRowsToShow));
2801
+ const parentRef = useRef(null);
2802
+ const hasNextPage = rows.length < allRows.length;
2803
+ const rowVirtualizer = useVirtualizer({
2804
+ count: rows.length,
2805
+ getScrollElement: () => parentRef.current,
2806
+ estimateSize: (i) => allRows[i].height,
2807
+ gap: 8
2808
+ });
2809
+ useEffect(() => {
2810
+ if (!hasNextPage)
2811
+ return;
2812
+ const ratio = Math.floor(scrollAmount / 46);
2813
+ const newNumRevisions = initialNumRowsToShow + ratio;
2814
+ setNumRowsToShow((prev) => newNumRevisions > prev ? newNumRevisions : prev);
2815
+ }, [scrollAmount, hasNextPage]);
2816
+ useEffect(() => {
2817
+ setRows(allRows.slice(0, numRowsToShow));
2818
+ }, [allRows, numRowsToShow]);
2819
+ const handleScroll = (e) => {
2820
+ setScrollAmount((prev) => {
2821
+ const n = prev + e.deltaY;
2822
+ if (n < 0) {
2823
+ return 0;
2824
+ }
2825
+ return n;
2826
+ });
2827
+ };
2828
+ useEffect(() => {
2829
+ window.addEventListener("wheel", handleScroll);
2830
+ return () => {
2831
+ window.removeEventListener("wheel", handleScroll);
2832
+ };
2833
+ }, []);
2834
+ return jsx("div", { className: "border-l border-slate-100", ref: parentRef, style: {
2835
+ height: `${rowVirtualizer.getTotalSize()}px`,
2836
+ width: "100%",
2837
+ position: "relative"
2838
+ }, children: rowVirtualizer.getVirtualItems().map((virtualRow) => {
2839
+ const row = rows[virtualRow.index];
2840
+ return jsxs("div", { style: {
2841
+ position: "absolute",
2842
+ top: 0,
2843
+ left: 16,
2844
+ width: "100%",
2845
+ height: `${virtualRow.size}px`,
2846
+ transform: `translateY(${virtualRow.start}px)`
2847
+ }, children: [row.type === "revision" && createElement(Revision, { ...row, key: virtualRow.key }), row.type === "skip" && jsx(Skip, { ...row }, virtualRow.key), row.type === "day" && jsx(Day, { ...row }, virtualRow.key)] }, virtualRow.index);
2848
+ }) });
2849
+ }
2850
+ function RevisionHistory(props) {
2851
+ const { documentTitle, documentId, globalOperations, localOperations, onClose, itemsPerPage = 100 } = props;
2852
+ const [scope, setScope] = useState("global");
2853
+ const visibleOperations = useMemo(() => {
2854
+ const operations = scope === "global" ? globalOperations : localOperations;
2855
+ return garbageCollect(sortOperations(operations)).sort((a, b) => b.index - a.index);
2856
+ }, [globalOperations, localOperations, scope]);
2857
+ const { pageItems, pages, goToPage, goToNextPage, goToPreviousPage, goToFirstPage, goToLastPage, hiddenNextPages, isNextPageAvailable, isPreviousPageAvailable } = usePagination(visibleOperations, {
2858
+ itemsPerPage
2859
+ });
2860
+ function onChangeScope(scope2) {
2861
+ goToFirstPage();
2862
+ setScope(scope2);
2863
+ }
2864
+ const showPagination = visibleOperations.length > itemsPerPage;
2865
+ const PaginationComponent = showPagination ? jsx("div", { className: "mt-4 flex w-full justify-end", children: jsx(Pagination, { firstPageLabel: "First Page", goToFirstPage, goToLastPage, goToNextPage, goToPage, goToPreviousPage, hiddenNextPages, isNextPageAvailable, isPreviousPageAvailable, lastPageLabel: "Last Page", nextPageLabel: "Next", pages, previousPageLabel: "Previous" }) }) : jsx("hr", { className: "h-12 border-none" });
2866
+ return jsxs(TooltipProvider, { children: [jsx(Header, { docId: documentId, onChangeScope, onClose, scope, title: documentTitle }), PaginationComponent, jsx("div", { className: "mt-4 flex justify-center rounded-md bg-slate-50 p-4", children: visibleOperations.length > 0 ? jsx("div", { className: "grid grid-cols-[minmax(min-content,1018px)]", children: jsx(Timeline, { globalOperations: scope === "global" ? pageItems : [], localOperations: scope === "local" ? pageItems : [], scope }) }) : jsx("h3", { className: "my-40 text-gray-600", children: "This document has no recorded operations yet." }) }), PaginationComponent] });
2867
+ }
2868
+ function Tooltip(props) {
2869
+ const { children, content, open, defaultOpen, onOpenChange, className, ...rest } = props;
2870
+ return jsxs(Root3, { defaultOpen, delayDuration: 0, onOpenChange, open, children: [jsx(Trigger, { asChild: true, children }), jsx(Portal, { children: jsx(Content2, { ...rest, className: twMerge("shadow-tooltip rounded-lg border border-gray-200 bg-white p-2 text-xs", className), children: content }) })] });
2871
+ }
2872
+ const TooltipProvider = Provider;
2873
+ const BUDGET = "powerhouse/budget-statement";
2874
+ const DEFAULT = "powerhouse/default";
2875
+ const MAKERDAO_RWA_PORTFOLIO = "makerdao/rwa-portfolio";
2876
+ const documentTypes = [BUDGET, DEFAULT, MAKERDAO_RWA_PORTFOLIO];
2877
+ const BudgetStatementImg = "";
2878
+ const MakerdaoRWAPortfolioImg = "/assets/rwa-report-Bb0W5-ac.png";
2879
+ const DefaultImg = "";
2880
+ const iconMap = {
2881
+ [BUDGET]: BudgetStatementImg,
2882
+ [DEFAULT]: DefaultImg,
2883
+ [MAKERDAO_RWA_PORTFOLIO]: MakerdaoRWAPortfolioImg
2884
+ };
2885
+ function useDrag(props) {
2886
+ const { uiNode } = props;
2887
+ const [isDragging, setIsDragging] = useState(false);
2888
+ const onDragStart = useCallback((event) => {
2889
+ event.dataTransfer.setData(UI_NODE, JSON.stringify(uiNode));
2890
+ }, [uiNode]);
2891
+ const onDragEnd = useCallback(() => {
2892
+ setIsDragging(false);
2893
+ }, []);
2894
+ const allowedToDragNode = !!uiNode && uiNode.kind !== DRIVE;
2895
+ return useMemo(() => {
2896
+ const dragProps = allowedToDragNode ? {
2897
+ draggable: true,
2898
+ onDragStart,
2899
+ onDragEnd
2900
+ } : {
2901
+ draggable: false,
2902
+ onDragStart: void 0,
2903
+ onDragEnd: void 0
2904
+ };
2905
+ return {
2906
+ isDragging,
2907
+ dragProps
2908
+ };
2909
+ }, [allowedToDragNode, isDragging, onDragEnd, onDragStart]);
2910
+ }
2911
+ function useDrop(props) {
2912
+ const { uiNode, onAddFile, onCopyNode, onMoveNode } = props;
2913
+ const [isDropTarget, setIsDropTarget] = useState(false);
2914
+ const allowedToBeDropTarget = !!uiNode && uiNode.kind !== FILE;
2915
+ const onDragOver = useCallback((event) => {
2916
+ event.preventDefault();
2917
+ setIsDropTarget(true);
2918
+ }, []);
2919
+ const onDragLeave = useCallback(() => {
2920
+ setIsDropTarget(false);
2921
+ }, []);
2922
+ const onDrop = useCallback(async (event) => {
2923
+ event.preventDefault();
2924
+ event.stopPropagation();
2925
+ if (!uiNode)
2926
+ return;
2927
+ const droppedFiles = getDroppedFiles(event.dataTransfer.items).filter(Boolean);
2928
+ if (droppedFiles.length) {
2929
+ for (const file of droppedFiles) {
2930
+ if (file) {
2931
+ await onAddFile(file, uiNode);
2932
+ }
2933
+ }
2934
+ } else {
2935
+ const altOrOptionKeyPressed = event.getModifierState("Alt");
2936
+ const data = event.dataTransfer.getData(UI_NODE);
2937
+ const droppedNode = JSON.parse(data);
2938
+ if (altOrOptionKeyPressed) {
2939
+ await onCopyNode(droppedNode, uiNode);
2940
+ } else {
2941
+ await onMoveNode(droppedNode, uiNode);
2942
+ }
2943
+ }
2944
+ setIsDropTarget(false);
2945
+ }, [onAddFile, onCopyNode, onMoveNode, uiNode]);
2946
+ return useMemo(() => {
2947
+ const dropProps = allowedToBeDropTarget ? { onDragOver, onDragLeave, onDrop } : {
2948
+ onDragOver: void 0,
2949
+ onDragLeave: void 0,
2950
+ onDrop: void 0
2951
+ };
2952
+ return {
2953
+ isDropTarget,
2954
+ dropProps
2955
+ };
2956
+ }, [allowedToBeDropTarget, isDropTarget, onDragLeave, onDragOver, onDrop]);
2957
+ }
2958
+ function getDroppedFiles(items) {
2959
+ const droppedFiles = Array.from(items).map((item) => item.kind === "file" ? item.getAsFile() : null).filter(Boolean);
2960
+ return droppedFiles;
2961
+ }
2962
+ function formatEthAddress(address) {
2963
+ return `${address.slice(0, 7)}...${address.slice(-5)}`;
2964
+ }
2965
+ function getDocumentIconSrc(documentType, customDocumentIconSrc) {
2966
+ if (customDocumentIconSrc) {
2967
+ return customDocumentIconSrc;
2968
+ }
2969
+ if (documentTypes.includes(documentType)) {
2970
+ return iconMap[documentType];
2971
+ }
2972
+ return iconMap[DEFAULT];
2973
+ }
2974
+ const validateDocument = (document2) => {
2975
+ const errors = [];
2976
+ if (document2.documentType !== "powerhouse/document-model") {
2977
+ return errors;
2978
+ }
2979
+ const doc = document2;
2980
+ const specs = doc.state.global.specifications[0];
2981
+ const initialStateErrors = Object.keys(specs.state).reduce((acc, scopeKey) => {
2982
+ const scope = scopeKey;
2983
+ return [
2984
+ ...acc,
2985
+ ...validateInitialState(
2986
+ specs.state[scope].initialValue,
2987
+ scope !== "global"
2988
+ ).map((err) => ({
2989
+ ...err,
2990
+ message: `${err.message}. Scope: ${scope}`,
2991
+ details: { ...err.details, scope }
2992
+ }))
2993
+ ];
2994
+ }, []);
2995
+ const schemaStateErrors = Object.keys(specs.state).reduce((acc, scopeKey) => {
2996
+ var _a;
2997
+ const scope = scopeKey;
2998
+ const isGlobalScope = scope === "global";
2999
+ return [
3000
+ ...acc,
3001
+ ...validateStateSchemaName(
3002
+ specs.state[scope].schema,
3003
+ doc.name || ((_a = doc.state.global) == null ? void 0 : _a.name) || "",
3004
+ !isGlobalScope ? scope : "",
3005
+ !isGlobalScope
3006
+ ).map((err) => ({
3007
+ ...err,
3008
+ message: `${err.message}. Scope: ${scope}`,
3009
+ details: { ...err.details, scope }
3010
+ }))
3011
+ ];
3012
+ }, []);
3013
+ const modulesErrors = validateModules(specs.modules);
3014
+ return [...initialStateErrors, ...schemaStateErrors, ...modulesErrors];
3015
+ };
3016
+ function useDocumentEditor(props) {
3017
+ const { driveId, documentId, documentType, documentModelModule, user } = props;
3018
+ const reactor = useUnwrappedReactor();
3019
+ const connectDid = useConnectDid();
3020
+ const { sign } = useConnectCrypto();
3021
+ const doc = useDocument(reactor, { documentId, driveId, documentType });
3022
+ const documentEditorProps = useDocumentEditorProps(reactor, {
3023
+ nodeId: documentId,
3024
+ driveId,
3025
+ document: doc,
3026
+ documentModelModule,
3027
+ connectDid,
3028
+ sign,
3029
+ user
3030
+ });
3031
+ return documentEditorProps;
3032
+ }
3033
+ function useEditorDispatch(node, documentDispatch, onAddOperation) {
3034
+ const user = useUser() || void 0;
3035
+ const connectDid = useConnectDid();
3036
+ const { sign } = useConnectCrypto();
3037
+ const documentType = (node == null ? void 0 : node.kind) === "DRIVE" ? "powerhouse/document-drive" : node == null ? void 0 : node.documentType;
3038
+ const getDocumentModelModule = useGetDocumentModelModule();
3039
+ const documentModelModule = useMemo(
3040
+ () => documentType ? getDocumentModelModule(documentType) : void 0,
3041
+ [documentType, getDocumentModelModule]
3042
+ );
3043
+ const dispatch = useCallback(
3044
+ (action, onErrorCallback) => {
3045
+ const callback = (operation, state) => {
3046
+ if (!(node == null ? void 0 : node.id)) return;
3047
+ const { prevState } = state;
3048
+ signOperation(
3049
+ operation,
3050
+ sign,
3051
+ node.id,
3052
+ prevState,
3053
+ documentModelModule == null ? void 0 : documentModelModule.reducer,
3054
+ user
3055
+ ).then((op) => {
3056
+ var _a;
3057
+ (_a = window.documentEditorDebugTools) == null ? void 0 : _a.pushOperation(
3058
+ operation
3059
+ );
3060
+ return onAddOperation(op);
3061
+ }).catch(logger.error);
3062
+ };
3063
+ documentDispatch(
3064
+ addActionContext(action, connectDid, user),
3065
+ callback,
3066
+ onErrorCallback
3067
+ );
3068
+ },
3069
+ [
3070
+ documentDispatch,
3071
+ connectDid,
3072
+ documentModelModule == null ? void 0 : documentModelModule.reducer,
3073
+ onAddOperation,
3074
+ node,
3075
+ sign,
3076
+ user
3077
+ ]
3078
+ );
3079
+ return dispatch;
3080
+ }
3081
+ function useEditorProps(document2, node, documentDispatch, onAddOperation) {
3082
+ const { t } = useTranslation();
3083
+ const { showModal } = useModal();
3084
+ const theme = useAtomValue(themeAtom);
3085
+ const user = useUser() || void 0;
3086
+ const userPermissions = useUserPermissions();
3087
+ const context = useMemo(() => ({ theme, user }), [theme, user]);
3088
+ const {
3089
+ selectedParentNode,
3090
+ selectedDocument,
3091
+ setSelectedNode,
3092
+ getDocumentModelModule
3093
+ } = useUiNodes();
3094
+ const canUndo = !!document2 && (document2.revision.global > 0 || document2.revision.local > 0);
3095
+ const canRedo = !!(document2 == null ? void 0 : document2.clipboard.length);
3096
+ const dispatch = useEditorDispatch(node, documentDispatch, onAddOperation);
3097
+ const handleUndo = useCallback(() => {
3098
+ dispatch(undo());
3099
+ }, [dispatch]);
3100
+ const handleRedo = useCallback(() => {
3101
+ dispatch(redo());
3102
+ }, [dispatch]);
3103
+ const onClose = useCallback(() => {
3104
+ setSelectedNode(selectedParentNode);
3105
+ }, [selectedParentNode, setSelectedNode]);
3106
+ const exportDocument = useCallback(
3107
+ (document22) => {
3108
+ const validationErrors = validateDocument(document22);
3109
+ if (validationErrors.length) {
3110
+ showModal("confirmationModal", {
3111
+ title: t("modals.exportDocumentWithErrors.title"),
3112
+ body: /* @__PURE__ */ jsxs("div", { children: [
3113
+ /* @__PURE__ */ jsx("p", { children: t("modals.exportDocumentWithErrors.body") }),
3114
+ /* @__PURE__ */ jsx("ul", { className: "mt-4 flex list-disc flex-col items-start px-4 text-xs", children: validationErrors.map((error, index) => /* @__PURE__ */ jsx("li", { children: error.message }, index)) })
3115
+ ] }),
3116
+ cancelLabel: t("common.cancel"),
3117
+ continueLabel: t("common.export"),
3118
+ onCancel(closeModal) {
3119
+ closeModal();
3120
+ },
3121
+ onContinue(closeModal) {
3122
+ closeModal();
3123
+ return exportFile(document22, getDocumentModelModule);
3124
+ }
3125
+ });
3126
+ } else {
3127
+ return exportFile(document22, getDocumentModelModule);
3128
+ }
3129
+ },
3130
+ [getDocumentModelModule, showModal, t]
3131
+ );
3132
+ const onExport = useCallback(() => {
3133
+ if (selectedDocument) {
3134
+ return exportDocument(selectedDocument);
3135
+ }
3136
+ }, [exportDocument, selectedDocument]);
3137
+ const [revisionHistoryVisible, setRevisionHistoryVisible] = useState(false);
3138
+ const showRevisionHistory = useCallback(
3139
+ () => setRevisionHistoryVisible(true),
3140
+ []
3141
+ );
3142
+ return {
3143
+ dispatch,
3144
+ revisionHistoryVisible,
3145
+ context,
3146
+ canUndo,
3147
+ canRedo,
3148
+ undo: handleUndo,
3149
+ redo: handleRedo,
3150
+ onClose,
3151
+ onExport,
3152
+ onShowRevisionHistory: showRevisionHistory,
3153
+ isAllowedToCreateDocuments: (userPermissions == null ? void 0 : userPermissions.isAllowedToCreateDocuments) ?? false,
3154
+ isAllowedToEditDocuments: (userPermissions == null ? void 0 : userPermissions.isAllowedToEditDocuments) ?? false
3155
+ };
3156
+ }
3157
+ function useSyncStatus(driveId, documentId) {
3158
+ const { getSyncStatusSync, onSyncStatus, documentDrives } = useDocumentDriveServer();
3159
+ const syncStatus = useSyncExternalStore(
3160
+ (onStoreChange) => {
3161
+ const unsub = onSyncStatus(onStoreChange);
3162
+ return unsub;
3163
+ },
3164
+ () => {
3165
+ var _a;
3166
+ const drive = documentDrives.find(
3167
+ (_drive) => _drive.state.global.id === driveId
3168
+ );
3169
+ if (!drive) return;
3170
+ const isReadDrive = "readContext" in drive;
3171
+ const _sharingType = !isReadDrive ? (_a = drive.state.local.sharingType) == null ? void 0 : _a.toUpperCase() : "PUBLIC";
3172
+ const sharingType = _sharingType === "PRIVATE" ? "LOCAL" : _sharingType;
3173
+ if (!documentId) {
3174
+ const status2 = getSyncStatusSync(
3175
+ driveId,
3176
+ sharingType
3177
+ );
3178
+ return status2;
3179
+ }
3180
+ const document2 = drive.state.global.nodes.find(
3181
+ (node) => node.id === documentId
3182
+ );
3183
+ if (!document2) return;
3184
+ if (!("synchronizationUnits" in document2)) return;
3185
+ const status = getSyncStatusSync(
3186
+ document2.synchronizationUnits[0].syncId,
3187
+ sharingType
3188
+ );
3189
+ return status;
3190
+ }
3191
+ );
3192
+ return syncStatus;
3193
+ }
3194
+ const useUndoRedoShortcuts = (props) => {
3195
+ var _a;
3196
+ const { undo: undo2, redo: redo2, canRedo, canUndo } = props;
3197
+ const { isMac } = ((_a = window.electronAPI) == null ? void 0 : _a.platformInfo) || {};
3198
+ let undoShortcut = "ctrl+z";
3199
+ let redoShortcut = "ctrl+y";
3200
+ if (isMac) {
3201
+ undoShortcut = "mod+z";
3202
+ redoShortcut = "mod+shift+z";
3203
+ }
3204
+ useHotkeys(
3205
+ undoShortcut,
3206
+ (event) => {
3207
+ event.preventDefault();
3208
+ if (canUndo) {
3209
+ undo2();
3210
+ }
3211
+ },
3212
+ {},
3213
+ [canUndo, undo2]
3214
+ );
3215
+ useHotkeys(
3216
+ redoShortcut,
3217
+ (event) => {
3218
+ event.preventDefault();
3219
+ if (canRedo) {
3220
+ redo2();
3221
+ }
3222
+ },
3223
+ {},
3224
+ [canRedo, redo2]
3225
+ );
3226
+ };
3227
+ function EditorLoader(props) {
3228
+ const [showLoading, setShowLoading] = useState(false);
3229
+ useEffect(() => {
3230
+ setTimeout(() => {
3231
+ setShowLoading(true);
3232
+ }, props.loadingTimeout ?? 200);
3233
+ }, [props]);
3234
+ if (!showLoading) return null;
3235
+ const { customEditorLoader, ...defaultProps } = props;
3236
+ if (customEditorLoader) return /* @__PURE__ */ jsx(Fragment$1, { children: customEditorLoader });
3237
+ return /* @__PURE__ */ jsx(DefaultEditorLoader, { ...defaultProps });
3238
+ }
3239
+ function EditorError({ message: message2 }) {
3240
+ return /* @__PURE__ */ jsx("div", { className: "flex size-full items-center justify-center", children: /* @__PURE__ */ jsx("h3", { className: "text-lg font-semibold", children: message2 }) });
3241
+ }
3242
+ function FallbackEditorError(props) {
3243
+ const message2 = props.error instanceof Error ? props.error.message : props.error;
3244
+ return /* @__PURE__ */ jsx(EditorError, { message: message2 });
3245
+ }
3246
+ const DocumentEditor = (props) => {
3247
+ const {
3248
+ fileNodeDocument,
3249
+ document: initialDocument,
3250
+ onClose,
3251
+ onChange,
3252
+ onExport,
3253
+ onAddOperation,
3254
+ onOpenSwitchboardLink
3255
+ } = props;
3256
+ const documentId = fileNodeDocument == null ? void 0 : fileNodeDocument.documentId;
3257
+ const [revisionHistoryVisible, setRevisionHistoryVisible] = useState(false);
3258
+ const theme = useAtomValue(themeAtom);
3259
+ const user = useUser() || void 0;
3260
+ const connectDid = useConnectDid();
3261
+ const { sign } = useConnectCrypto();
3262
+ const getDocumentModelModule = useGetDocumentModelModule();
3263
+ const getEditor = useGetEditor();
3264
+ const documentType = fileNodeDocument == null ? void 0 : fileNodeDocument.documentType;
3265
+ const documentModel = useMemo(
3266
+ () => documentType ? getDocumentModelModule(documentType) : void 0,
3267
+ [documentType, getDocumentModelModule]
3268
+ );
3269
+ const editor = useMemo(
3270
+ () => documentType ? getEditor(documentType) : void 0,
3271
+ [documentType, getEditor]
3272
+ );
3273
+ const [document2, _dispatch, error] = useDocumentDispatch(
3274
+ documentModel == null ? void 0 : documentModel.reducer,
3275
+ initialDocument
3276
+ );
3277
+ const context = useMemo(
3278
+ () => ({ theme, user }),
3279
+ [theme, user]
3280
+ );
3281
+ const userPermissions = useUserPermissions();
3282
+ const currentDocument = useRef({ ...fileNodeDocument, document: document2 });
3283
+ useEffect(() => {
3284
+ var _a;
3285
+ if (!(fileNodeDocument == null ? void 0 : fileNodeDocument.documentId) || !document2) return;
3286
+ if (!("documentId" in currentDocument.current) || currentDocument.current.documentId !== documentId) {
3287
+ currentDocument.current = { ...fileNodeDocument, document: document2 };
3288
+ return;
3289
+ }
3290
+ if (!isSameDocument(currentDocument.current.document, document2)) {
3291
+ currentDocument.current.document = document2;
3292
+ (_a = window.documentEditorDebugTools) == null ? void 0 : _a.setDocument(document2);
3293
+ onChange == null ? void 0 : onChange(documentId, document2);
3294
+ }
3295
+ }, [document2, documentId, fileNodeDocument, onChange]);
3296
+ const dispatch = useCallback(
3297
+ (action, onErrorCallback) => {
3298
+ const callback = (operation, state) => {
3299
+ if (!(fileNodeDocument == null ? void 0 : fileNodeDocument.documentId)) return;
3300
+ const { prevState } = state;
3301
+ signOperation(
3302
+ operation,
3303
+ sign,
3304
+ fileNodeDocument.documentId,
3305
+ prevState,
3306
+ documentModel == null ? void 0 : documentModel.reducer,
3307
+ user
3308
+ ).then((op) => {
3309
+ var _a;
3310
+ (_a = window.documentEditorDebugTools) == null ? void 0 : _a.pushOperation(
3311
+ operation
3312
+ );
3313
+ return onAddOperation(op);
3314
+ }).catch(logger.error);
3315
+ };
3316
+ _dispatch(
3317
+ addActionContext(action, connectDid, user),
3318
+ callback,
3319
+ onErrorCallback
3320
+ );
3321
+ },
3322
+ [
3323
+ _dispatch,
3324
+ connectDid,
3325
+ documentModel == null ? void 0 : documentModel.reducer,
3326
+ onAddOperation,
3327
+ fileNodeDocument,
3328
+ sign,
3329
+ user
3330
+ ]
3331
+ );
3332
+ const showRevisionHistory = useCallback(
3333
+ () => setRevisionHistoryVisible(true),
3334
+ []
3335
+ );
3336
+ const hideRevisionHistory = useCallback(
3337
+ () => setRevisionHistoryVisible(false),
3338
+ []
3339
+ );
3340
+ const handleUndo = useCallback(() => {
3341
+ dispatch(undo());
3342
+ }, [dispatch]);
3343
+ const handleRedo = useCallback(() => {
3344
+ dispatch(redo());
3345
+ }, [dispatch]);
3346
+ const isLoadingDocument = (fileNodeDocument == null ? void 0 : fileNodeDocument.status) === "LOADING" || !document2;
3347
+ const isLoadingEditor = editor === void 0 || !!document2 && editor && !editor.documentTypes.includes(document2.documentType) && !editor.documentTypes.includes("*");
3348
+ const canUndo = !!document2 && (document2.revision.global > 0 || document2.revision.local > 0);
3349
+ const canRedo = !!(document2 == null ? void 0 : document2.clipboard.length);
3350
+ useUndoRedoShortcuts({
3351
+ undo: handleUndo,
3352
+ redo: handleRedo,
3353
+ canUndo,
3354
+ canRedo
3355
+ });
3356
+ useEffect(() => {
3357
+ return () => {
3358
+ var _a;
3359
+ (_a = window.documentEditorDebugTools) == null ? void 0 : _a.clear();
3360
+ };
3361
+ }, []);
3362
+ const navigate = useNavigate();
3363
+ const { showModal } = useModal();
3364
+ const [editorError, setEditorError] = useState(void 0);
3365
+ useEffect(() => {
3366
+ if (editorError && editorError.documentId !== (fileNodeDocument == null ? void 0 : fileNodeDocument.documentId)) {
3367
+ setEditorError(void 0);
3368
+ }
3369
+ }, [editorError, fileNodeDocument, document2]);
3370
+ const handleEditorError = useCallback(
3371
+ (error2, info) => {
3372
+ setEditorError({
3373
+ error: error2,
3374
+ documentId,
3375
+ info
3376
+ });
3377
+ },
3378
+ [documentId]
3379
+ );
3380
+ if ((fileNodeDocument == null ? void 0 : fileNodeDocument.status) === "ERROR") {
3381
+ return /* @__PURE__ */ jsx(EditorError, { message: "Error loading document" });
3382
+ }
3383
+ if (isLoadingDocument || isLoadingEditor) {
3384
+ const message2 = isLoadingDocument ? "Loading document" : "Loading editor";
3385
+ return /* @__PURE__ */ jsx(EditorLoader, { message: message2 });
3386
+ }
3387
+ if (!fileNodeDocument) {
3388
+ return null;
3389
+ }
3390
+ if (!documentModel) {
3391
+ return /* @__PURE__ */ jsx(
3392
+ EditorError,
3393
+ {
3394
+ message: /* @__PURE__ */ jsxs("div", { className: "text-center leading-10", children: [
3395
+ /* @__PURE__ */ jsxs("p", { children: [
3396
+ 'Unable to open the document because the document model "',
3397
+ documentType,
3398
+ '" is not supported.'
3399
+ ] }),
3400
+ /* @__PURE__ */ jsxs("p", { children: [
3401
+ "Go to the",
3402
+ " ",
3403
+ /* @__PURE__ */ jsx(
3404
+ "button",
3405
+ {
3406
+ type: "button",
3407
+ className: "cursor-pointer underline",
3408
+ onClick: () => {
3409
+ showModal("settingsModal", {
3410
+ onRefresh: () => navigate(0)
3411
+ });
3412
+ },
3413
+ children: "package manager"
3414
+ }
3415
+ ),
3416
+ " ",
3417
+ "to install this document model"
3418
+ ] })
3419
+ ] })
3420
+ }
3421
+ );
3422
+ }
3423
+ if (editor === null) {
3424
+ return /* @__PURE__ */ jsx(
3425
+ EditorError,
3426
+ {
3427
+ message: /* @__PURE__ */ jsxs("div", { className: "text-center leading-10", children: [
3428
+ /* @__PURE__ */ jsx("p", { children: "Unable to open the document because no editor has been found" }),
3429
+ /* @__PURE__ */ jsxs("p", { children: [
3430
+ "Go to the",
3431
+ " ",
3432
+ /* @__PURE__ */ jsx(
3433
+ "button",
3434
+ {
3435
+ type: "button",
3436
+ className: "cursor-pointer underline",
3437
+ onClick: () => {
3438
+ showModal("settingsModal", {
3439
+ onRefresh: () => navigate(0)
3440
+ });
3441
+ },
3442
+ children: "package manager"
3443
+ }
3444
+ ),
3445
+ " ",
3446
+ 'an editor for the "$',
3447
+ documentType,
3448
+ '" document type'
3449
+ ] })
3450
+ ] })
3451
+ }
3452
+ );
3453
+ }
3454
+ const EditorComponent = editor.Component;
3455
+ const {
3456
+ disableExternalControls,
3457
+ documentToolbarEnabled,
3458
+ showSwitchboardLink
3459
+ } = editor.config || {};
3460
+ const handleSwitchboardLinkClick = showSwitchboardLink !== false ? onOpenSwitchboardLink : void 0;
3461
+ return /* @__PURE__ */ jsxs("div", { className: "relative h-full", id: "document-editor-context", children: [
3462
+ documentToolbarEnabled && disableExternalControls && !revisionHistoryVisible && /* @__PURE__ */ jsx(
3463
+ DocumentToolbar,
3464
+ {
3465
+ onClose,
3466
+ onExport,
3467
+ onShowRevisionHistory: showRevisionHistory,
3468
+ title: fileNodeDocument.name || document2.name,
3469
+ onSwitchboardLinkClick: handleSwitchboardLinkClick
3470
+ }
3471
+ ),
3472
+ !disableExternalControls && /* @__PURE__ */ jsxs("div", { className: "mb-4 flex justify-end gap-10", children: [
3473
+ /* @__PURE__ */ jsx(Button, { onClick: onExport, children: "Export" }),
3474
+ /* @__PURE__ */ jsxs("div", { className: "flex gap-4", children: [
3475
+ /* @__PURE__ */ jsx(Button, { onClick: handleUndo, disabled: !canUndo, children: "Undo" }),
3476
+ /* @__PURE__ */ jsx(Button, { onClick: handleRedo, disabled: !canRedo, children: "Redo" })
3477
+ ] }),
3478
+ /* @__PURE__ */ jsx("div", { className: "flex gap-4", children: /* @__PURE__ */ jsx(Button, { onClick: onClose, children: "Close" }) })
3479
+ ] }),
3480
+ revisionHistoryVisible ? /* @__PURE__ */ jsx(
3481
+ RevisionHistory,
3482
+ {
3483
+ documentTitle: document2.name,
3484
+ documentId: fileNodeDocument.documentId,
3485
+ globalOperations: document2.operations.global,
3486
+ localOperations: document2.operations.local,
3487
+ onClose: hideRevisionHistory
3488
+ },
3489
+ documentId
3490
+ ) : /* @__PURE__ */ jsx(Suspense, { fallback: /* @__PURE__ */ jsx(EditorLoader, {}), children: /* @__PURE__ */ jsx(
3491
+ ErrorBoundary,
3492
+ {
3493
+ fallbackRender: FallbackEditorError,
3494
+ onError: handleEditorError,
3495
+ children: !(editorError == null ? void 0 : editorError.error) && /* @__PURE__ */ jsx(
3496
+ EditorComponent,
3497
+ {
3498
+ error,
3499
+ context,
3500
+ document: document2,
3501
+ documentNodeName: fileNodeDocument.name,
3502
+ dispatch,
3503
+ onClose,
3504
+ onExport,
3505
+ canUndo,
3506
+ canRedo,
3507
+ undo: handleUndo,
3508
+ redo: handleRedo,
3509
+ onSwitchboardLinkClick: handleSwitchboardLinkClick,
3510
+ onShowRevisionHistory: showRevisionHistory,
3511
+ isAllowedToCreateDocuments: (userPermissions == null ? void 0 : userPermissions.isAllowedToCreateDocuments) ?? false,
3512
+ isAllowedToEditDocuments: (userPermissions == null ? void 0 : userPermissions.isAllowedToEditDocuments) ?? false
3513
+ },
3514
+ documentId
3515
+ )
3516
+ },
3517
+ documentId
3518
+ ) })
3519
+ ] });
3520
+ };
3521
+ function DocumentEditorContainer() {
3522
+ const { t } = useTranslation();
3523
+ const { showModal } = useModal();
3524
+ const {
3525
+ selectedNode,
3526
+ selectedParentNode,
3527
+ isRemoteDrive,
3528
+ selectedDocument,
3529
+ fileNodeDocument,
3530
+ setSelectedNode,
3531
+ setSelectedDocument,
3532
+ openSwitchboardLink,
3533
+ addOperationToSelectedDocument,
3534
+ renameNode,
3535
+ getDocumentModelModule
3536
+ } = useUiNodes();
3537
+ const handleAddOperationToSelectedDocument = useCallback(
3538
+ async (operation) => {
3539
+ if (!selectedDocument) {
3540
+ throw new Error("No document selected");
3541
+ }
3542
+ if (!addOperationToSelectedDocument) {
3543
+ throw new Error("No add operation function defined");
3544
+ }
3545
+ await addOperationToSelectedDocument(operation);
3546
+ },
3547
+ [addOperationToSelectedDocument, selectedDocument]
3548
+ );
3549
+ const onDocumentChangeHandler = useCallback(
3550
+ (documentId, document2) => {
3551
+ if (documentId !== (fileNodeDocument == null ? void 0 : fileNodeDocument.documentId)) {
3552
+ return;
3553
+ }
3554
+ setSelectedDocument(document2);
3555
+ if (!!selectedNode && document2.name !== "" && selectedNode.name !== document2.name) {
3556
+ return renameNode(
3557
+ selectedNode.driveId,
3558
+ selectedNode.id,
3559
+ document2.name
3560
+ );
3561
+ }
3562
+ },
3563
+ [
3564
+ fileNodeDocument == null ? void 0 : fileNodeDocument.documentId,
3565
+ renameNode,
3566
+ selectedNode,
3567
+ setSelectedDocument
3568
+ ]
3569
+ );
3570
+ const onClose = useCallback(() => {
3571
+ setSelectedNode(selectedParentNode);
3572
+ }, [selectedParentNode, setSelectedNode]);
3573
+ const exportDocument = useCallback(
3574
+ (document2) => {
3575
+ const validationErrors = validateDocument(document2);
3576
+ if (validationErrors.length) {
3577
+ showModal("confirmationModal", {
3578
+ title: t("modals.exportDocumentWithErrors.title"),
3579
+ body: /* @__PURE__ */ jsxs("div", { children: [
3580
+ /* @__PURE__ */ jsx("p", { children: t("modals.exportDocumentWithErrors.body") }),
3581
+ /* @__PURE__ */ jsx("ul", { className: "mt-4 flex list-disc flex-col items-start px-4 text-xs", children: validationErrors.map((error, index) => /* @__PURE__ */ jsx("li", { children: error.message }, index)) })
3582
+ ] }),
3583
+ cancelLabel: t("common.cancel"),
3584
+ continueLabel: t("common.export"),
3585
+ onCancel(closeModal) {
3586
+ closeModal();
3587
+ },
3588
+ onContinue(closeModal) {
3589
+ closeModal();
3590
+ return exportFile(document2, getDocumentModelModule);
3591
+ }
3592
+ });
3593
+ } else {
3594
+ return exportFile(document2, getDocumentModelModule);
3595
+ }
3596
+ },
3597
+ [getDocumentModelModule, showModal, t]
3598
+ );
3599
+ const onExport = useCallback(() => {
3600
+ if (selectedDocument) {
3601
+ return exportDocument(selectedDocument);
3602
+ }
3603
+ }, [exportDocument, selectedDocument]);
3604
+ const onOpenSwitchboardLink = useMemo(() => {
3605
+ return isRemoteDrive ? () => openSwitchboardLink(selectedNode) : void 0;
3606
+ }, [isRemoteDrive, openSwitchboardLink, selectedNode]);
3607
+ if (!fileNodeDocument) return null;
3608
+ return /* @__PURE__ */ jsx(
3609
+ "div",
3610
+ {
3611
+ className: "flex-1 rounded-2xl bg-gray-50 p-4",
3612
+ children: /* @__PURE__ */ jsx(
3613
+ DocumentEditor,
3614
+ {
3615
+ fileNodeDocument,
3616
+ document: selectedDocument,
3617
+ onChange: onDocumentChangeHandler,
3618
+ onClose,
3619
+ onExport,
3620
+ onAddOperation: handleAddOperationToSelectedDocument,
3621
+ onOpenSwitchboardLink
3622
+ }
3623
+ )
3624
+ },
3625
+ fileNodeDocument.documentId
3626
+ );
3627
+ }
3628
+ function getDocumentSpec(doc) {
3629
+ if ("documentModelState" in doc) {
3630
+ return doc.documentModelState;
3631
+ }
3632
+ return doc.documentModel;
3633
+ }
3634
+ const CreateDocument = ({ documentModels, createDocument }) => {
3635
+ return jsxs("div", { className: "px-6", children: [jsx("h3", { className: "mb-3 mt-4 text-xl font-bold text-gray-600", children: "New document" }), jsx("div", { className: "flex w-full flex-wrap gap-4", children: documentModels == null ? void 0 : documentModels.map((doc) => {
3636
+ const spec = getDocumentSpec(doc);
3637
+ return jsx(Button, { color: "light", "aria-details": spec.description, onClick: () => createDocument(doc), children: jsx("span", { className: "text-sm", children: spec.name }) }, spec.id);
3638
+ }) })] });
3639
+ };
3640
+ function sortUiNodesByName(a, b) {
3641
+ return a.name.localeCompare(b.name);
3642
+ }
3643
+ const GAP = 8;
3644
+ const ITEM_WIDTH = 256;
3645
+ const ITEM_HEIGHT = 48;
3646
+ const USED_SPACE = 420;
3647
+ function FileContentView(props) {
3648
+ const parentRef = useRef(null);
3649
+ const { t } = useTranslation();
3650
+ const windowSize = useWindowSize();
3651
+ const { fileNodes, ...fileProps } = props;
3652
+ const availableWidth = windowSize.innerWidth - USED_SPACE;
3653
+ const columnCount = Math.floor(availableWidth / (ITEM_WIDTH + GAP)) || 1;
3654
+ const rowCount = Math.ceil(fileNodes.length / columnCount);
3655
+ const rowVirtualizer = useVirtualizer({
3656
+ count: rowCount,
3657
+ getScrollElement: () => parentRef.current,
3658
+ estimateSize: (index) => {
3659
+ if (index > 0) {
3660
+ return ITEM_HEIGHT + GAP;
3661
+ }
3662
+ return ITEM_HEIGHT;
3663
+ },
3664
+ overscan: 5
3665
+ });
3666
+ const columnVirtualizer = useVirtualizer({
3667
+ horizontal: true,
3668
+ count: columnCount,
3669
+ getScrollElement: () => parentRef.current,
3670
+ estimateSize: (index) => {
3671
+ if (index > 0) {
3672
+ return ITEM_WIDTH + GAP;
3673
+ }
3674
+ return ITEM_WIDTH;
3675
+ },
3676
+ overscan: 5
3677
+ });
3678
+ const getItemIndex = (rowIndex, columnIndex) => rowIndex * columnCount + columnIndex;
3679
+ const getItem = (rowIndex, columnIndex) => {
3680
+ const index = getItemIndex(rowIndex, columnIndex);
3681
+ return fileNodes[index] || null;
3682
+ };
3683
+ if (fileNodes.length === 0) {
3684
+ return jsx("div", { className: "mb-8 text-sm text-gray-400", children: t("folderView.sections.documents.empty", {
3685
+ defaultValue: "No documents or files 📄"
3686
+ }) });
3687
+ }
3688
+ const renderItem = (rowIndex, columnIndex) => {
3689
+ const fileNode = getItem(rowIndex, columnIndex);
3690
+ if (!fileNode) {
3691
+ return null;
3692
+ }
3693
+ return jsx("div", { style: {
3694
+ marginLeft: columnIndex === 0 ? 0 : GAP
3695
+ }, children: jsx(FileItem, { uiNode: fileNode, ...fileProps }, fileNode.id) });
3696
+ };
3697
+ return jsx("div", { ref: parentRef, style: {
3698
+ height: `400px`,
3699
+ width: `100%`,
3700
+ overflow: "auto"
3701
+ }, children: jsx("div", { style: {
3702
+ height: `${rowVirtualizer.getTotalSize()}px`,
3703
+ width: `${columnVirtualizer.getTotalSize()}px`,
3704
+ position: "relative"
3705
+ }, children: rowVirtualizer.getVirtualItems().map((virtualRow) => jsx(React__default.Fragment, { children: columnVirtualizer.getVirtualItems().map((virtualColumn) => jsx("div", { style: {
3706
+ position: "absolute",
3707
+ top: 0,
3708
+ left: 0,
3709
+ marginTop: virtualRow.index === 0 ? 0 : GAP,
3710
+ width: `${virtualColumn.size}px`,
3711
+ height: `${virtualRow.size}px`,
3712
+ transform: `translateX(${virtualColumn.start}px) translateY(${virtualRow.start}px)`
3713
+ }, children: renderItem(virtualRow.index, virtualColumn.index) }, virtualColumn.key)) }, virtualRow.key)) }) });
3714
+ }
3715
+ function FolderView(props) {
3716
+ const { node, className, isDropTarget, containerProps, ...nodeProps } = props;
3717
+ const { t } = useTranslation();
3718
+ const folderNodes = node.children.filter((node2) => node2.kind === FOLDER).sort(sortUiNodesByName);
3719
+ const fileNodes = node.children.filter((node2) => node2.kind === FILE).sort(sortUiNodesByName);
3720
+ const folderCallbacks = {
3721
+ onSelectNode: (node2) => nodeProps.onSelectNode(node2),
3722
+ onRenameNode: (name, node2) => nodeProps.onRenameNode(name, node2),
3723
+ onDuplicateNode: (node2) => nodeProps.onDuplicateNode(node2),
3724
+ onDeleteNode: (node2) => nodeProps.onDeleteNode(node2)
3725
+ };
3726
+ const fileCallbacks = {
3727
+ onSelectNode: (node2) => nodeProps.onSelectNode(node2),
3728
+ onRenameNode: (name, node2) => nodeProps.onRenameNode(name, node2),
3729
+ onDuplicateNode: (node2) => nodeProps.onDuplicateNode(node2),
3730
+ onDeleteNode: (node2) => nodeProps.onDeleteNode(node2)
3731
+ };
3732
+ const baseNodeCallbacks = {
3733
+ onAddFile: async (file, parentNode) => {
3734
+ await nodeProps.onAddFile(file, parentNode);
3735
+ },
3736
+ onCopyNode: async (uiNode, targetNode) => {
3737
+ await nodeProps.onCopyNode(uiNode, targetNode);
3738
+ },
3739
+ onMoveNode: async (uiNode, targetNode) => {
3740
+ await nodeProps.onMoveNode(uiNode, targetNode);
3741
+ }
3742
+ };
3743
+ return jsxs("div", { className: twMerge("rounded-md border-2 border-transparent p-2", isDropTarget && "border-dashed border-blue-100", className), ...containerProps, children: [jsx(DriveLayout.ContentSection, { title: t("folderView.sections.folders.title", {
3744
+ defaultValue: "Folders"
3745
+ }), className: "mb-4", children: folderNodes.length > 0 ? folderNodes.map((folderNode) => jsx(FolderItem, { uiNode: folderNode, ...baseNodeCallbacks, ...folderCallbacks, isAllowedToCreateDocuments: nodeProps.isAllowedToCreateDocuments }, folderNode.id)) : jsx("div", { className: "mb-8 text-sm text-gray-400", children: t("folderView.sections.folders.empty", {
3746
+ defaultValue: "No documents or files 📄"
3747
+ }) }) }), jsx(DriveLayout.ContentSection, { title: t("folderView.sections.documents.title", {
3748
+ defaultValue: "Documents and files"
3749
+ }), children: jsx("div", { className: twMerge("w-full", fileNodes.length > 0 ? "min-h-[400px]" : "min-h-14"), children: jsx(FileContentView, { fileNodes, ...fileCallbacks, isAllowedToCreateDocuments: nodeProps.isAllowedToCreateDocuments }) }) })] });
3750
+ }
3751
+ function Editor(props) {
3752
+ const { document: document2, dispatch, className, children } = props;
3753
+ const { state: { global: { id: driveId } } } = document2;
3754
+ const { showSearchBar, isAllowedToCreateDocuments, documentModels, showCreateDocumentModal } = useDriveContext();
3755
+ const { driveNodes, selectedNode, selectedNodePath, getNodeById, setSelectedNode } = useUiNodesContext();
3756
+ const driveNode = useMemo(() => driveNodes.find((n) => n.id === driveId), [driveNodes, driveId]);
3757
+ const { addDocument, addFile, addFolder, renameNode, deleteNode, moveNode, copyNode, duplicateNode } = useDriveActionsWithUiNodes(document2, dispatch);
3758
+ const onCreateDocument = useCallback(async (documentModel) => {
3759
+ const { name } = await showCreateDocumentModal(documentModel);
3760
+ const document3 = documentModel.utils.createDocument();
3761
+ await addDocument(name, documentModel.documentModel.name, document3, selectedNode == null ? void 0 : selectedNode.id);
3762
+ }, [addDocument, showCreateDocumentModal, selectedNode == null ? void 0 : selectedNode.id]);
3763
+ const { isDropTarget, dropProps } = useDrop({
3764
+ uiNode: selectedNode,
3765
+ onAddFile: addFile,
3766
+ onCopyNode: copyNode,
3767
+ onMoveNode: moveNode
3768
+ });
3769
+ const { breadcrumbs, onBreadcrumbSelected } = useBreadcrumbs({
3770
+ selectedNodePath,
3771
+ getNodeById,
3772
+ setSelectedNode
3773
+ });
3774
+ if (!driveNode) {
3775
+ return jsx("div", { children: "Drive not found" });
3776
+ } else if ((selectedNode == null ? void 0 : selectedNode.kind) === FILE$1) {
3777
+ return jsx(Fragment$1, {});
3778
+ }
3779
+ return jsxs(DriveLayout, { className, children: [children, jsxs(DriveLayout.Header, { children: [jsx(Breadcrumbs, { breadcrumbs, createEnabled: isAllowedToCreateDocuments, onCreate: addFolder, onBreadcrumbSelected }), showSearchBar && jsx(SearchBar, {})] }), jsx(DriveLayout.Content, { children: jsx(FolderView, { node: selectedNode || driveNode, onSelectNode: setSelectedNode, onRenameNode: renameNode, onDuplicateNode: duplicateNode, onDeleteNode: deleteNode, onAddFile: addFile, onCopyNode: copyNode, onMoveNode: moveNode, isDropTarget, isAllowedToCreateDocuments }) }), jsx(DriveLayout.Footer, { children: isAllowedToCreateDocuments && jsx(CreateDocument, { documentModels, createDocument: onCreateDocument }) })] });
3780
+ }
3781
+ const GenericDriveExplorer = {
3782
+ Component: Editor
3783
+ };
3784
+ function useGetDriveDocuments(props) {
3785
+ const { driveId } = props;
3786
+ const [documents, setDocuments] = useState({});
3787
+ const { getDocumentsIds, onStrandUpdate, openFile } = useDocumentDriveServer();
3788
+ const fetchDocuments = async (_driveId, _documentIds) => {
3789
+ let documentIds = _documentIds;
3790
+ if (!documentIds || documentIds.length === 0) {
3791
+ documentIds = await getDocumentsIds(_driveId);
3792
+ }
3793
+ const getDocumentsPromise = documentIds.map(async (documentId) => {
3794
+ const document2 = await openFile(_driveId, documentId);
3795
+ return [documentId, document2];
3796
+ });
3797
+ const docs = await Promise.all(getDocumentsPromise);
3798
+ const newDocumentsState = docs.reduce(
3799
+ (acc, [documentId, document2]) => {
3800
+ acc[documentId] = {
3801
+ ...document2.state,
3802
+ documentType: document2.documentType,
3803
+ revision: document2.revision,
3804
+ created: document2.created,
3805
+ lastModified: document2.lastModified
3806
+ };
3807
+ return acc;
3808
+ },
3809
+ {}
3810
+ );
3811
+ setDocuments((prevState) => ({
3812
+ ...prevState,
3813
+ ...newDocumentsState
3814
+ }));
3815
+ };
3816
+ useEffect(() => {
3817
+ if (driveId) {
3818
+ fetchDocuments(driveId).catch(console.error);
3819
+ }
3820
+ }, [driveId]);
3821
+ useEffect(() => {
3822
+ const removeListener = onStrandUpdate((update) => {
3823
+ if (driveId && update.driveId === driveId && update.documentId) {
3824
+ fetchDocuments(driveId, [update.documentId]).catch(
3825
+ console.error
3826
+ );
3827
+ }
3828
+ });
3829
+ return removeListener;
3830
+ }, [onStrandUpdate, driveId]);
3831
+ return [documents, fetchDocuments];
3832
+ }
3833
+ function DriveEditorError({ error }) {
3834
+ return /* @__PURE__ */ jsxs("div", { className: "mx-auto flex max-w-[80%] flex-1 flex-col items-center justify-center", children: [
3835
+ /* @__PURE__ */ jsx("h1", { className: "mb-2 text-xl font-semibold", children: "Error" }),
3836
+ /* @__PURE__ */ jsx("i", { children: error instanceof Error ? error.message : error }),
3837
+ /* @__PURE__ */ jsx("pre", { children: JSON.stringify(error, null, 2) })
3838
+ ] });
3839
+ }
3840
+ function useSelectedDocumentDrive() {
3841
+ const { selectedDriveNode } = useUiNodesContext();
3842
+ if (!selectedDriveNode) {
3843
+ throw new Error("No drive node selected");
3844
+ }
3845
+ const documentDrive = useDocumentDriveById(selectedDriveNode.id);
3846
+ if (!documentDrive.drive) {
3847
+ throw new Error(`Drive with id "${selectedDriveNode.id}" not found`);
3848
+ }
3849
+ return documentDrive.drive;
3850
+ }
3851
+ function DriveEditorContainer() {
3852
+ var _a;
3853
+ const {
3854
+ selectedDriveNode,
3855
+ setSelectedNode,
3856
+ selectedNode,
3857
+ selectedParentNode
3858
+ } = useUiNodesContext();
3859
+ const { addOperationToSelectedDrive } = useUiNodes();
3860
+ const documentDrive = useSelectedDocumentDrive();
3861
+ const [document2, _dispatch, error] = useDocumentDispatch(
3862
+ driveDocumentModelModule.reducer,
3863
+ documentDrive
3864
+ );
3865
+ const reactor = useAsyncReactor();
3866
+ const handleAddOperationToSelectedDrive = useCallback(
3867
+ async (operation) => {
3868
+ await addOperationToSelectedDrive(operation);
3869
+ },
3870
+ [addOperationToSelectedDrive]
3871
+ );
3872
+ const editorProps = useEditorProps(
3873
+ document2,
3874
+ selectedDriveNode,
3875
+ _dispatch,
3876
+ handleAddOperationToSelectedDrive
3877
+ );
3878
+ const { showModal } = useModal();
3879
+ const showCreateDocumentModal = useCallback(
3880
+ (documentModel) => {
3881
+ if (!selectedDriveNode) {
3882
+ throw new Error("No drive node selected");
3883
+ }
3884
+ showModal("createDocument", {
3885
+ documentModel,
3886
+ selectedParentNode,
3887
+ setSelectedNode
3888
+ });
3889
+ return Promise.resolve({ name: "New Document" });
3890
+ },
3891
+ [selectedDriveNode, selectedParentNode, setSelectedNode, showModal]
3892
+ );
3893
+ const { addFile, addDocument } = useDocumentDriveServer();
3894
+ const documentModels = useFilteredDocumentModels();
3895
+ const useDriveDocumentState = makeDriveDocumentStateHook(reactor);
3896
+ const driveContext = useMemo(
3897
+ () => ({
3898
+ showSearchBar: false,
3899
+ isAllowedToCreateDocuments: editorProps.isAllowedToCreateDocuments,
3900
+ documentModels: documentModels ?? [],
3901
+ selectedDriveNode,
3902
+ selectedNode,
3903
+ selectNode: setSelectedNode,
3904
+ addFile,
3905
+ showCreateDocumentModal,
3906
+ useSyncStatus,
3907
+ useDocumentEditorProps: useDocumentEditor,
3908
+ useDriveDocumentStates: useGetDriveDocuments,
3909
+ useDriveDocumentState,
3910
+ addDocument
3911
+ }),
3912
+ [
3913
+ reactor,
3914
+ editorProps.isAllowedToCreateDocuments,
3915
+ documentModels,
3916
+ selectedNode,
3917
+ setSelectedNode,
3918
+ addFile,
3919
+ addDocument,
3920
+ showCreateDocumentModal
3921
+ ]
3922
+ );
3923
+ const driveEditor = useDriveEditor((_a = document2 == null ? void 0 : document2.meta) == null ? void 0 : _a.preferredEditor);
3924
+ if (!document2) {
3925
+ return null;
3926
+ }
3927
+ const DriveEditorComponent = (driveEditor == null ? void 0 : driveEditor.Component) ?? GenericDriveExplorer.Component;
3928
+ return /* @__PURE__ */ jsx(DriveContextProvider, { value: driveContext, children: /* @__PURE__ */ jsx(
3929
+ ErrorBoundary,
3930
+ {
3931
+ fallbackRender: DriveEditorError,
3932
+ children: /* @__PURE__ */ jsx(
3933
+ DriveEditorComponent,
3934
+ {
3935
+ ...editorProps,
3936
+ onSwitchboardLinkClick: void 0,
3937
+ document: document2,
3938
+ error
3939
+ },
3940
+ selectedDriveNode == null ? void 0 : selectedDriveNode.id
3941
+ )
3942
+ },
3943
+ selectedDriveNode == null ? void 0 : selectedDriveNode.id
3944
+ ) }, selectedDriveNode == null ? void 0 : selectedDriveNode.id);
3945
+ }
3946
+ function Content() {
3947
+ const uiNodes = useUiNodes();
3948
+ const { fileNodeDocument, selectedDriveNode, selectedNode, addFile } = uiNodes;
3949
+ useEffect(() => {
3950
+ var _a;
3951
+ return (_a = window.electronAPI) == null ? void 0 : _a.handleFileOpen(async (file) => {
3952
+ if (!selectedDriveNode || (selectedNode == null ? void 0 : selectedNode.kind) !== FILE) {
3953
+ return;
3954
+ }
3955
+ await addFile(
3956
+ file.content,
3957
+ selectedDriveNode.id,
3958
+ file.name,
3959
+ selectedNode.parentFolder
3960
+ );
3961
+ });
3962
+ }, [selectedDriveNode, selectedNode, addFile]);
3963
+ return /* @__PURE__ */ jsx("div", { className: "flex h-full flex-col overflow-hidden", id: "content-view", children: fileNodeDocument ? /* @__PURE__ */ jsx(DocumentEditorContainer, {}, fileNodeDocument.documentId) : selectedDriveNode ? /* @__PURE__ */ jsx(DriveEditorContainer, {}, selectedDriveNode.id) : null });
3964
+ }
3965
+ export {
3966
+ Content as default
3967
+ };