@fde-desktop/fde-core 0.4.7 → 0.4.9

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 (284) hide show
  1. package/dist/AccordionChevron-DxpOyInK.js +26 -0
  2. package/dist/AccordionChevron-kn5kSrEc.cjs +1 -0
  3. package/dist/ActionIcon-Drh4p6Fv.js +145 -0
  4. package/dist/ActionIcon-alk2zZD6.cjs +1 -0
  5. package/dist/AppEmptyState-BWCUbf-B.cjs +1 -0
  6. package/dist/AppEmptyState-Bxpit0JV.js +49 -0
  7. package/dist/AppIcon-BU7a3ZNH.cjs +1 -0
  8. package/dist/AppIcon-XumS3bIG.js +80 -0
  9. package/dist/AppMenuBar-B9U0n1Vv.cjs +1 -0
  10. package/dist/AppMenuBar-CnIEVjr8.js +2049 -0
  11. package/dist/Box-DSKR_qaa.js +1579 -0
  12. package/dist/Box-zW6Twge8.cjs +1 -0
  13. package/dist/Button-DMlnrqyx.cjs +1 -0
  14. package/dist/Button-wTOTQKxF.js +178 -0
  15. package/dist/CalendarApp-B_e1B1Yn.cjs +1 -0
  16. package/dist/CalendarApp-C-l9D6nd.cjs +1 -0
  17. package/dist/CalendarApp-D0ftTCTG.js +1399 -0
  18. package/dist/Center-CmxXB9ql.js +25 -0
  19. package/dist/Center-DKUE2pER.cjs +1 -0
  20. package/dist/CheckIcon-CZhtJD1O.cjs +1 -0
  21. package/dist/CheckIcon-N5qBqXQJ.js +25 -0
  22. package/dist/CodeServerApp-BOoGwZ7r.cjs +1 -0
  23. package/dist/CodeServerApp-Be3I5EGg.cjs +1 -0
  24. package/dist/CodeServerApp-DW18EZxa.js +150 -0
  25. package/dist/ColorPicker-BCNqi02x.js +997 -0
  26. package/dist/ColorPicker-BrDE7tMO.cjs +1 -0
  27. package/dist/Colors-ClnDxnyA.js +15 -0
  28. package/dist/Colors-zP2AFgU3.cjs +1 -0
  29. package/dist/CreateItemApp-B12M1E_1.cjs +1 -0
  30. package/dist/CreateItemApp-TAAprby3.js +400 -0
  31. package/dist/CreateItemApp-ePB6ujNl.cjs +1 -0
  32. package/dist/DeviceInfoApp-BMF18BGo.cjs +1 -0
  33. package/dist/DeviceInfoApp-DRy0H3aT.cjs +1 -0
  34. package/dist/DeviceInfoApp-lgpwkeRR.js +223 -0
  35. package/dist/DownloadProgress-EoyCaD5O.js +174 -0
  36. package/dist/DownloadProgress-VNdj22U8.cjs +1 -0
  37. package/dist/FileIcon-7JaSR3Gn.js +89 -0
  38. package/dist/FileIcon-CIXopWLv.cjs +1 -0
  39. package/dist/FilePickerApp-DaMgEqKh.js +409 -0
  40. package/dist/FilePickerApp-DjmuSFqa.cjs +1 -0
  41. package/dist/FilesApp-Bp7wfrBZ.cjs +1 -0
  42. package/dist/FilesApp-BpJJRKhi.cjs +1 -0
  43. package/dist/FilesApp-Cj94QG5o.js +225 -0
  44. package/dist/Group-CtBJSfCo.js +48 -0
  45. package/dist/Group-Dsrf6lEK.cjs +1 -0
  46. package/dist/ImageViewerApp-BaLP3gkO.js +69 -0
  47. package/dist/ImageViewerApp-DlHGeB3S.cjs +1 -0
  48. package/dist/ImageViewerApp-DoXd_Swu.cjs +1 -0
  49. package/dist/ImageViewerMenuBar-CabGSi9r.js +87 -0
  50. package/dist/ImageViewerMenuBar-SAI7UNz7.cjs +1 -0
  51. package/dist/ImageViewerMenuBar-_Jr29gii.cjs +1 -0
  52. package/dist/MenuEditApp-BJjlPTOa.cjs +1 -0
  53. package/dist/MenuEditApp-BTRppYnD.js +497 -0
  54. package/dist/MenuEditApp-JPsGT-S3.cjs +1 -0
  55. package/dist/MenuEditMenuBar-BydGkqMw.cjs +1 -0
  56. package/dist/MenuEditMenuBar-DptlwVPQ.cjs +1 -0
  57. package/dist/MenuEditMenuBar-x1IQrHP2.js +60 -0
  58. package/dist/NotesApp-BOcRGO7w.cjs +1 -0
  59. package/dist/NotesApp-CQe7UfBC.js +364 -0
  60. package/dist/NotesApp-OL07JXRE.cjs +1 -0
  61. package/dist/NotesMenuBar-BSI_2Y7p.cjs +1 -0
  62. package/dist/NotesMenuBar-Df6aW85J.cjs +1 -0
  63. package/dist/NotesMenuBar-VhpIe68v.js +62 -0
  64. package/dist/Paper-BX_9odR6.js +30 -0
  65. package/dist/Paper-D8-BaBx2.cjs +1 -0
  66. package/dist/PdfApp-CNEbty5v.cjs +1 -0
  67. package/dist/PdfApp-CVv3ZCaM.cjs +1 -0
  68. package/dist/PdfApp-DL_R9-Nc.js +39 -0
  69. package/dist/PdfMenuBar--E6kDyrT.cjs +1 -0
  70. package/dist/PdfMenuBar-DZCLSOpR.js +39 -0
  71. package/dist/PdfMenuBar-Dj5cJUkg.cjs +1 -0
  72. package/dist/SettingsApp-BlmHuAjT.js +1831 -0
  73. package/dist/SettingsApp-CNvIgf5B.cjs +1 -0
  74. package/dist/SettingsApp-DWxanNE4.cjs +1 -0
  75. package/dist/SettingsMenuBar-CBoOBCfx.cjs +1 -0
  76. package/dist/SettingsMenuBar-DQooFkZN.cjs +1 -0
  77. package/dist/SettingsMenuBar-YWiJHaxq.js +42 -0
  78. package/dist/Slider-BUiHxjKO.cjs +1 -0
  79. package/dist/Slider-t-NcD60t.js +1176 -0
  80. package/dist/Stack-Bp1Ek2Gp.js +34 -0
  81. package/dist/Stack-D4jAiRfc.cjs +1 -0
  82. package/dist/StorybookApp-CDLV_kja.cjs +1 -0
  83. package/dist/StorybookApp-DKwlPCmo.js +10 -0
  84. package/dist/TerminalApp-BCB7i1lR.cjs +1 -0
  85. package/dist/TerminalApp-BYc_gHLe.js +326 -0
  86. package/dist/TerminalApp-Dviz6aP2.cjs +1 -0
  87. package/dist/TerminalMenuBar-D5tPmgR_.js +113 -0
  88. package/dist/TerminalMenuBar-DNshPmCa.cjs +1 -0
  89. package/dist/TerminalMenuBar-HzMSR7XP.cjs +1 -0
  90. package/dist/TextInput-C-JtGWn1.js +981 -0
  91. package/dist/TextInput-CrsmcOip.cjs +1 -0
  92. package/dist/Tooltip-D5Cd9wtz.cjs +1 -0
  93. package/dist/Tooltip-DOeIvhrO.js +1142 -0
  94. package/dist/UnstyledButton-DGaG-e_G.js +25 -0
  95. package/dist/UnstyledButton-DX2pTahr.cjs +1 -0
  96. package/dist/UploaderApp-C6xA5Rrf2.cjs +1 -0
  97. package/dist/UploaderApp-DnHIRxB_.cjs +1 -0
  98. package/dist/UploaderApp-qBfpukR_.js +488 -0
  99. package/dist/VscIcon-CcMdrFoJ.cjs +1 -0
  100. package/dist/VscIcon-DBfVnArE.js +8 -0
  101. package/dist/create-safe-context-Bboj0GWC.cjs +1 -0
  102. package/dist/create-safe-context-XT2cxc14.js +12 -0
  103. package/dist/desktopStore-CZoA9VHO.cjs +1 -0
  104. package/dist/desktopStore-F8bgLqFl.js +1768 -0
  105. package/dist/getRuntime-BFK0-8R1.cjs +1 -0
  106. package/dist/getRuntime-DAPqFH2W.js +63 -0
  107. package/dist/imageViewerStore-BB_tssZR.cjs +1 -0
  108. package/dist/imageViewerStore-C5kWz0o7.js +50 -0
  109. package/dist/index.cjs +1 -5642
  110. package/dist/index.css +2 -9192
  111. package/dist/index.d.ts +2258 -2019
  112. package/dist/index.js +4826 -4798
  113. package/dist/is-element-Bu_JY8Qy.js +7 -0
  114. package/dist/is-element-CdV0xajp.cjs +1 -0
  115. package/dist/menuEditStore-CTeM_dns.cjs +1 -0
  116. package/dist/menuEditStore-Cj1zAwxQ.js +38 -0
  117. package/dist/notesStore-BCEl1D_v.cjs +1 -0
  118. package/dist/notesStore-BPyRTHEc.js +36 -0
  119. package/dist/rolldown-runtime-CAFD8bLK.js +11 -0
  120. package/dist/settingsAppStore-BDQ3ts1y.js +29 -0
  121. package/dist/settingsAppStore-CMBc13VU.cjs +1 -0
  122. package/dist/terminalStore-IWdf4Mm6.js +30 -0
  123. package/dist/terminalStore-iIuyodfK.cjs +1 -0
  124. package/dist/use-merged-ref-BT8_u6vW.js +25 -0
  125. package/dist/use-merged-ref-n9Gw9LNn.cjs +1 -0
  126. package/dist/use-resolved-styles-api-8OXE2oRq.cjs +1 -0
  127. package/dist/use-resolved-styles-api-DNUlJJZf.js +21 -0
  128. package/dist/use-uncontrolled-A4hm9ATM.js +23 -0
  129. package/dist/use-uncontrolled-DDJVQiM_.cjs +1 -0
  130. package/dist/useAdaptiveDimensions-AVDc_qPa.js +40 -0
  131. package/dist/useAdaptiveDimensions-CfITBJ_m.cjs +1 -0
  132. package/dist/useCloseInterceptor-BZd3VILp.js +51 -0
  133. package/dist/useCloseInterceptor-yntBEzNc.cjs +1 -0
  134. package/dist/useDynamicIcon-Bf0t2foA.js +22 -0
  135. package/dist/useDynamicIcon-DJ_il30E.cjs +1 -0
  136. package/dist/useMenuBarUtils-nJIPJGIQ.cjs +1 -0
  137. package/dist/useMenuBarUtils-nmu9yehT.js +6 -0
  138. package/dist/useOpenApp-CBIm7Gzl.js +279 -0
  139. package/dist/useOpenApp-DW4x79Zg.cjs +1 -0
  140. package/dist/useResolvedUrl-BkMPM1fM.cjs +1 -0
  141. package/dist/useResolvedUrl-DQpLqOoL.js +30 -0
  142. package/package.json +7 -3
  143. package/dist/CalendarApp-CHLUCAI7.css +0 -744
  144. package/dist/CalendarApp-K7ZOUZ6C.js +0 -2
  145. package/dist/CalendarApp-OTGEERSS.cjs +0 -8
  146. package/dist/CodeServerApp-5KZGO7HL.css +0 -75
  147. package/dist/CodeServerApp-LUZFCQBI.js +0 -3
  148. package/dist/CodeServerApp-P3TMJPLY.cjs +0 -9
  149. package/dist/CreateItemApp-ESQ42VHH.js +0 -8
  150. package/dist/CreateItemApp-PQB5GTFG.css +0 -107
  151. package/dist/CreateItemApp-RFE3REWZ.cjs +0 -14
  152. package/dist/DeviceInfoApp-XNIS6ZY6.js +0 -5
  153. package/dist/DeviceInfoApp-ZNLQNOKI.cjs +0 -11
  154. package/dist/DeviceInfoApp-ZSMRSITP.css +0 -7
  155. package/dist/FilesApp-4GEU64QN.js +0 -8
  156. package/dist/FilesApp-E6L5W3T2.css +0 -1817
  157. package/dist/FilesApp-QSLB5IWR.cjs +0 -14
  158. package/dist/ImageViewerApp-N2Q7E7WZ.css +0 -215
  159. package/dist/ImageViewerApp-NCVDKLB3.js +0 -11
  160. package/dist/ImageViewerApp-QB373H5Z.cjs +0 -17
  161. package/dist/ImageViewerMenuBar-I3TFKQPS.cjs +0 -14
  162. package/dist/ImageViewerMenuBar-TV5C6TM2.js +0 -5
  163. package/dist/ImageViewerMenuBar-XLK4LIHW.css +0 -56
  164. package/dist/MenuEditApp-5EFYAPFC.cjs +0 -15
  165. package/dist/MenuEditApp-V5XOPIHX.js +0 -9
  166. package/dist/MenuEditApp-YA6HSAMJ.css +0 -94
  167. package/dist/MenuEditMenuBar-7VHMZNRM.css +0 -56
  168. package/dist/MenuEditMenuBar-GF6L4PGZ.cjs +0 -15
  169. package/dist/MenuEditMenuBar-IUXFPZE5.js +0 -6
  170. package/dist/NotesApp-2YNT7Y3D.js +0 -10
  171. package/dist/NotesApp-IAEE7YHU.cjs +0 -16
  172. package/dist/NotesApp-TQ6IHDNX.css +0 -302
  173. package/dist/NotesMenuBar-25LKN3SE.cjs +0 -15
  174. package/dist/NotesMenuBar-MXLOX7OT.css +0 -56
  175. package/dist/NotesMenuBar-SRV3AIAL.js +0 -6
  176. package/dist/PdfApp-67XIX6AM.js +0 -10
  177. package/dist/PdfApp-BUIC5U5H.css +0 -206
  178. package/dist/PdfApp-GZ6RHTBR.cjs +0 -16
  179. package/dist/PdfMenuBar-NLZC6JHS.js +0 -4
  180. package/dist/PdfMenuBar-QUM72EE4.css +0 -56
  181. package/dist/PdfMenuBar-WBRTKMLN.cjs +0 -13
  182. package/dist/SettingsApp-BPLMGPNK.cjs +0 -20
  183. package/dist/SettingsApp-JVOSEFH3.css +0 -283
  184. package/dist/SettingsApp-LUDIXCYY.js +0 -14
  185. package/dist/SettingsMenuBar-5CBSSMVM.css +0 -56
  186. package/dist/SettingsMenuBar-VLT6TTCM.js +0 -6
  187. package/dist/SettingsMenuBar-Y5QEXDEO.cjs +0 -15
  188. package/dist/StorybookApp-NQ244BER.css +0 -7
  189. package/dist/StorybookApp-NZDV4X3Y.js +0 -1
  190. package/dist/StorybookApp-VF3KIMU3.cjs +0 -7
  191. package/dist/TerminalApp-CDGWRBFJ.cjs +0 -10
  192. package/dist/TerminalApp-EAATMIMX.css +0 -77
  193. package/dist/TerminalApp-GCKJCM55.js +0 -4
  194. package/dist/TerminalMenuBar-3J26O26Q.css +0 -56
  195. package/dist/TerminalMenuBar-7BH7MGNJ.cjs +0 -14
  196. package/dist/TerminalMenuBar-7JAEQUZ4.js +0 -5
  197. package/dist/UploaderApp-6KV3TGCT.css +0 -1817
  198. package/dist/UploaderApp-FJC2J4I5.js +0 -10
  199. package/dist/UploaderApp-HLXJYJZQ.cjs +0 -16
  200. package/dist/chunk-2PSTHGTD.cjs +0 -42
  201. package/dist/chunk-2RQX7QBP.cjs +0 -148
  202. package/dist/chunk-43W6UDUZ.cjs +0 -19
  203. package/dist/chunk-4E45FBAH.js +0 -223
  204. package/dist/chunk-4E4U2A25.cjs +0 -237
  205. package/dist/chunk-4QHX7CMN.cjs +0 -38
  206. package/dist/chunk-4XURSNM4.js +0 -43
  207. package/dist/chunk-4ZCRYHL6.js +0 -407
  208. package/dist/chunk-5C6IQE42.cjs +0 -35
  209. package/dist/chunk-5HUYQDQF.js +0 -36
  210. package/dist/chunk-5NOHYJNH.js +0 -84
  211. package/dist/chunk-5QFZW6HW.js +0 -2241
  212. package/dist/chunk-5YH6AKEO.js +0 -146
  213. package/dist/chunk-756GPSPM.js +0 -283
  214. package/dist/chunk-7WUYUTPN.js +0 -2293
  215. package/dist/chunk-7XCMBW64.js +0 -162
  216. package/dist/chunk-7Y7HB7FB.cjs +0 -53
  217. package/dist/chunk-ABIAPZ6S.cjs +0 -45
  218. package/dist/chunk-ACHGJKCI.cjs +0 -286
  219. package/dist/chunk-BQCD5RAF.cjs +0 -48
  220. package/dist/chunk-BQL3YXMV.js +0 -17429
  221. package/dist/chunk-C3XER4N3.js +0 -442
  222. package/dist/chunk-C6BEZNAM.cjs +0 -45
  223. package/dist/chunk-CILU6BWC.cjs +0 -548
  224. package/dist/chunk-CV5PUHAE.cjs +0 -86
  225. package/dist/chunk-D5MVFFID.js +0 -42
  226. package/dist/chunk-D7R55WWT.js +0 -1601
  227. package/dist/chunk-DFYDUXWP.cjs +0 -34
  228. package/dist/chunk-DWP2SYF7.js +0 -55
  229. package/dist/chunk-E55VXNLK.cjs +0 -17498
  230. package/dist/chunk-E5FW77FG.js +0 -77
  231. package/dist/chunk-EAELL43F.js +0 -42
  232. package/dist/chunk-EX5V2ZTU.js +0 -40
  233. package/dist/chunk-FD7QZCTN.cjs +0 -2329
  234. package/dist/chunk-FH4ILMKF.js +0 -38
  235. package/dist/chunk-FRHBM2U7.js +0 -33
  236. package/dist/chunk-FX2TPX3L.cjs +0 -45
  237. package/dist/chunk-GPXNLTPI.cjs +0 -451
  238. package/dist/chunk-GRYCUBJZ.js +0 -9
  239. package/dist/chunk-HPHHS7FJ.cjs +0 -49
  240. package/dist/chunk-HWHBSAUC.js +0 -40
  241. package/dist/chunk-IDHP3R4I.js +0 -31
  242. package/dist/chunk-IHWGT3DL.js +0 -86
  243. package/dist/chunk-JEBKLIMU.cjs +0 -123
  244. package/dist/chunk-KDZLBI6F.cjs +0 -324
  245. package/dist/chunk-KQHICFX3.js +0 -121
  246. package/dist/chunk-LMJE6V4N.cjs +0 -42
  247. package/dist/chunk-MCHPDWVH.js +0 -444
  248. package/dist/chunk-MVDGM5Y4.js +0 -68
  249. package/dist/chunk-N36HBL53.cjs +0 -165
  250. package/dist/chunk-NV5GNFA3.js +0 -541
  251. package/dist/chunk-NVEGEK3N.js +0 -31
  252. package/dist/chunk-OJIDKDKF.js +0 -68
  253. package/dist/chunk-PGGNSLM7.js +0 -215
  254. package/dist/chunk-PKPQA5NR.js +0 -15
  255. package/dist/chunk-PNDBLFJW.cjs +0 -50
  256. package/dist/chunk-Q3WA72BF.cjs +0 -70
  257. package/dist/chunk-RDIDAZ3S.cjs +0 -9
  258. package/dist/chunk-RGJPRXYY.js +0 -48
  259. package/dist/chunk-RPSYXORB.cjs +0 -219
  260. package/dist/chunk-RQ6OZRUW.cjs +0 -41
  261. package/dist/chunk-SBE4SZAN.cjs +0 -226
  262. package/dist/chunk-TAFNCDUI.js +0 -234
  263. package/dist/chunk-TFIDSENE.cjs +0 -88
  264. package/dist/chunk-TGWMOHAO.js +0 -17
  265. package/dist/chunk-UA6XSTW6.js +0 -48
  266. package/dist/chunk-UIQCTAVM.cjs +0 -59
  267. package/dist/chunk-UKYESVDS.cjs +0 -50
  268. package/dist/chunk-V4N255NL.cjs +0 -2309
  269. package/dist/chunk-VO6KXO2I.js +0 -32
  270. package/dist/chunk-WXSTSC3D.cjs +0 -83
  271. package/dist/chunk-XSK7BWYO.js +0 -47
  272. package/dist/chunk-XVAPJ4PP.cjs +0 -449
  273. package/dist/chunk-XVASHRCE.cjs +0 -70
  274. package/dist/chunk-XYSMVQQD.cjs +0 -1608
  275. package/dist/chunk-YAIWI4Z5.js +0 -7
  276. package/dist/chunk-YGYOLDKR.js +0 -280
  277. package/dist/chunk-YP2PLNOF.cjs +0 -34
  278. package/dist/chunk-YSOLW4FS.cjs +0 -11
  279. package/dist/chunk-YY6OUR2U.js +0 -44
  280. package/dist/chunk-YZWS7FDT.cjs +0 -409
  281. package/dist/chunk-Z5YGWL65.cjs +0 -39
  282. package/dist/chunk-ZHNDXNL4.js +0 -45
  283. package/dist/chunk-ZX3EDZ5C.cjs +0 -17
  284. package/dist/index.d.cts +0 -2019
@@ -1,226 +0,0 @@
1
- 'use strict';
2
-
3
- var chunk7Y7HB7FB_cjs = require('./chunk-7Y7HB7FB.cjs');
4
- var chunkE55VXNLK_cjs = require('./chunk-E55VXNLK.cjs');
5
- var jsxRuntime = require('react/jsx-runtime');
6
- var react = require('react');
7
-
8
- var DirtyIndicator = ({ size = 16 }) => {
9
- const icon = chunk7Y7HB7FB_cjs.useFcIconElement("FcSynchronize", { size });
10
- return /* @__PURE__ */ jsxRuntime.jsx(
11
- "span",
12
- {
13
- style: {
14
- color: "orange",
15
- fontWeight: "bold",
16
- marginLeft: "8px",
17
- display: "flex",
18
- alignItems: "center"
19
- },
20
- title: "Unsaved changes",
21
- children: icon
22
- }
23
- );
24
- };
25
- var DirtyIndicator_default = DirtyIndicator;
26
-
27
- // src/components/AppMenuBar/AppMenuBar.module.css
28
- var AppMenuBar_default = {};
29
- var ICON_PROPS = { size: 16, style: { display: "block" } };
30
- var FcIcon = ({ name }) => chunk7Y7HB7FB_cjs.useFcIconElement(name, ICON_PROPS);
31
- var MenuDropdownElement = ({
32
- label,
33
- icon,
34
- items,
35
- rightSection
36
- }) => {
37
- const [opened, setOpened] = react.useState(false);
38
- const TriggerIcon = () => chunk7Y7HB7FB_cjs.useFcIconElement(icon ?? "", ICON_PROPS);
39
- return /* @__PURE__ */ jsxRuntime.jsxs(
40
- chunkE55VXNLK_cjs.Menu,
41
- {
42
- opened,
43
- onClose: () => setOpened(false),
44
- withinPortal: true,
45
- keepMounted: true,
46
- closeOnItemClick: true,
47
- closeOnEscape: true,
48
- closeOnClickOutside: true,
49
- position: "bottom-start",
50
- children: [
51
- /* @__PURE__ */ jsxRuntime.jsx(chunkE55VXNLK_cjs.Menu.Target, { children: /* @__PURE__ */ jsxRuntime.jsxs("button", { className: AppMenuBar_default.menuTrigger, onClick: () => setOpened((o) => !o), children: [
52
- icon && /* @__PURE__ */ jsxRuntime.jsx(TriggerIcon, {}),
53
- /* @__PURE__ */ jsxRuntime.jsx("span", { children: label }),
54
- rightSection && /* @__PURE__ */ jsxRuntime.jsx("span", { style: { marginLeft: "auto" }, children: rightSection })
55
- ] }) }),
56
- /* @__PURE__ */ jsxRuntime.jsx(chunkE55VXNLK_cjs.Menu.Dropdown, { children: items.map((item, idx) => {
57
- if (item.type === "divider") {
58
- return /* @__PURE__ */ jsxRuntime.jsx(chunkE55VXNLK_cjs.Menu.Divider, {}, idx);
59
- }
60
- if (item.type === "slider") {
61
- return /* @__PURE__ */ jsxRuntime.jsx(chunkE55VXNLK_cjs.Menu.Item, { closeMenuOnClick: false, children: /* @__PURE__ */ jsxRuntime.jsxs("div", { style: { minWidth: 120 }, children: [
62
- item.label && /* @__PURE__ */ jsxRuntime.jsx("div", { style: { marginBottom: 4 }, children: item.label }),
63
- /* @__PURE__ */ jsxRuntime.jsx(
64
- chunkE55VXNLK_cjs.Slider,
65
- {
66
- min: item.min,
67
- max: item.max,
68
- value: item.value,
69
- onChange: item.onChange,
70
- size: "sm"
71
- }
72
- )
73
- ] }) }, idx);
74
- }
75
- return /* @__PURE__ */ jsxRuntime.jsx(
76
- chunkE55VXNLK_cjs.Menu.Item,
77
- {
78
- disabled: item.disabled,
79
- onClick: item.onClick,
80
- leftSection: item.icon ? /* @__PURE__ */ jsxRuntime.jsx(FcIcon, { name: item.icon }) : void 0,
81
- children: item.label
82
- },
83
- idx
84
- );
85
- }) })
86
- ]
87
- }
88
- );
89
- };
90
- var AppMenuBar = ({ elements }) => {
91
- const [sliderStates, setSliderStates] = react.useState({});
92
- const setSliderState = (idx, state) => {
93
- setSliderStates((prev) => ({
94
- ...prev,
95
- [idx]: { ...prev[idx] ?? { isHovered: false, isDragging: false }, ...state }
96
- }));
97
- };
98
- return /* @__PURE__ */ jsxRuntime.jsx("div", { className: AppMenuBar_default.root, role: "menubar", "aria-label": "Application menu", children: elements.map((el, idx) => {
99
- switch (el.type) {
100
- case "menu":
101
- return /* @__PURE__ */ jsxRuntime.jsx(
102
- MenuDropdownElement,
103
- {
104
- label: el.label,
105
- icon: el.icon,
106
- items: el.items,
107
- rightSection: el.rightSection
108
- },
109
- idx
110
- );
111
- case "combobox":
112
- return /* @__PURE__ */ jsxRuntime.jsx("div", { className: AppMenuBar_default.element, children: /* @__PURE__ */ jsxRuntime.jsx(
113
- chunkE55VXNLK_cjs.Select,
114
- {
115
- data: el.options,
116
- value: el.value,
117
- onChange: (v) => v && el.onChange(v),
118
- placeholder: el.label,
119
- size: "sm",
120
- className: AppMenuBar_default.select,
121
- comboboxProps: { withinPortal: true }
122
- }
123
- ) }, idx);
124
- case "switch":
125
- return /* @__PURE__ */ jsxRuntime.jsx("div", { className: AppMenuBar_default.element, children: /* @__PURE__ */ jsxRuntime.jsx(
126
- chunkE55VXNLK_cjs.Switch,
127
- {
128
- label: el.label,
129
- checked: el.checked,
130
- onChange: (e) => el.onChange(e.currentTarget.checked),
131
- size: "sm"
132
- }
133
- ) }, idx);
134
- case "slider": {
135
- const sliderState = sliderStates[idx] ?? { isHovered: false, isDragging: false };
136
- const isTooltipOpen = sliderState.isHovered || sliderState.isDragging;
137
- const labelFormat = el.labelFormat ?? ((val) => String(val));
138
- return /* @__PURE__ */ jsxRuntime.jsx(
139
- chunkE55VXNLK_cjs.Tooltip,
140
- {
141
- label: labelFormat(el.value),
142
- position: "bottom",
143
- withArrow: true,
144
- opened: isTooltipOpen,
145
- children: /* @__PURE__ */ jsxRuntime.jsxs(
146
- "div",
147
- {
148
- className: AppMenuBar_default.element,
149
- onMouseEnter: () => setSliderState(idx, { isHovered: true }),
150
- onMouseLeave: () => setSliderState(idx, { isHovered: false }),
151
- children: [
152
- el.label && /* @__PURE__ */ jsxRuntime.jsx("span", { className: AppMenuBar_default.sliderLabel, children: el.label }),
153
- /* @__PURE__ */ jsxRuntime.jsx(
154
- chunkE55VXNLK_cjs.Slider,
155
- {
156
- min: el.min,
157
- max: el.max,
158
- value: el.value,
159
- onChange: (val) => {
160
- el.onChange(val);
161
- setSliderState(idx, { isDragging: true });
162
- },
163
- onChangeEnd: (val) => {
164
- el.onChange(val);
165
- setSliderState(idx, { isDragging: false });
166
- },
167
- size: "sm",
168
- className: AppMenuBar_default.slider,
169
- marks: el.marks
170
- }
171
- )
172
- ]
173
- }
174
- )
175
- },
176
- idx
177
- );
178
- }
179
- case "text-input":
180
- return /* @__PURE__ */ jsxRuntime.jsx("div", { className: AppMenuBar_default.element, children: /* @__PURE__ */ jsxRuntime.jsx(
181
- chunkE55VXNLK_cjs.TextInput,
182
- {
183
- placeholder: el.placeholder,
184
- value: el.value,
185
- onChange: (e) => el.onChange(e.currentTarget.value),
186
- size: "sm",
187
- className: AppMenuBar_default.textInput
188
- }
189
- ) }, idx);
190
- case "number-input":
191
- return /* @__PURE__ */ jsxRuntime.jsx("div", { className: AppMenuBar_default.element, children: /* @__PURE__ */ jsxRuntime.jsx(
192
- chunkE55VXNLK_cjs.NumberInput,
193
- {
194
- label: el.label,
195
- value: el.value,
196
- onChange: (v) => el.onChange(typeof v === "number" ? v : 0),
197
- min: el.min,
198
- max: el.max,
199
- step: el.step ?? 1,
200
- placeholder: el.placeholder,
201
- size: "sm",
202
- className: AppMenuBar_default.numberInput
203
- }
204
- ) }, idx);
205
- case "select":
206
- return /* @__PURE__ */ jsxRuntime.jsx("div", { className: AppMenuBar_default.element, children: /* @__PURE__ */ jsxRuntime.jsx(
207
- chunkE55VXNLK_cjs.Select,
208
- {
209
- label: el.label,
210
- data: el.options,
211
- value: el.value,
212
- onChange: (v) => v && el.onChange(v),
213
- size: "sm",
214
- className: AppMenuBar_default.select,
215
- comboboxProps: { withinPortal: true }
216
- }
217
- ) }, idx);
218
- case "dirty-indicator":
219
- return /* @__PURE__ */ jsxRuntime.jsx("span", { style: { marginLeft: "auto" }, children: /* @__PURE__ */ jsxRuntime.jsx(DirtyIndicator_default, {}) }, idx);
220
- }
221
- }) });
222
- };
223
- var AppMenuBar_default2 = AppMenuBar;
224
-
225
- exports.AppMenuBar_default = AppMenuBar_default2;
226
- exports.DirtyIndicator_default = DirtyIndicator_default;
@@ -1,234 +0,0 @@
1
- import { useOpenApp } from './chunk-YGYOLDKR.js';
2
- import { DownloadProgress_default } from './chunk-HWHBSAUC.js';
3
- import { FolderPickerModal } from './chunk-MCHPDWVH.js';
4
- import { useDesktopStore, fileSystem, getAppIdForMime } from './chunk-5QFZW6HW.js';
5
- import { useFcIconElement } from './chunk-YY6OUR2U.js';
6
- import { Paper, Box, Text, Group, Button, Stepper, FileButton } from './chunk-BQL3YXMV.js';
7
- import { useState, useCallback } from 'react';
8
- import { useTranslation } from 'react-i18next';
9
- import { jsx, jsxs } from 'react/jsx-runtime';
10
-
11
- // src/utils/formatBytes.ts
12
- function formatBytes(bytes) {
13
- if (bytes === 0) return "0 B";
14
- const k = 1024;
15
- const sizes = ["B", "KB", "MB", "GB", "TB"];
16
- const i = Math.floor(Math.log(bytes) / Math.log(k));
17
- const index = Math.min(i, sizes.length - 1);
18
- return `${parseFloat((bytes / Math.pow(k, index)).toFixed(1))} ${sizes[index]}`;
19
- }
20
-
21
- // src/components/Apps/UploaderApp/UploaderApp.module.css
22
- var UploaderApp_default = {};
23
- var UploaderApp = ({ window: win }) => {
24
- const { t } = useTranslation("apps");
25
- const createFile = useDesktopStore((state) => state.createFile);
26
- const openApp = useOpenApp();
27
- const [activeStep, setActiveStep] = useState(0);
28
- const [file, setFile] = useState(null);
29
- const [selectedFolderId, setSelectedFolderId] = useState(null);
30
- const [folderSelected, setFolderSelected] = useState(false);
31
- const [pickerOpen, setPickerOpen] = useState(false);
32
- const [uploadStarted, setUploadStarted] = useState(false);
33
- const [uploadState, setUploadState] = useState({
34
- status: "idle",
35
- progress: { status: "idle", loaded: 0, total: null, percent: null, error: null }
36
- });
37
- const [createdFileId, setCreatedFileId] = useState(null);
38
- const uploadIcon = useFcIconElement("FcUpload", { size: 120 });
39
- const checkIconLg = useFcIconElement("FcCheckmark", { size: 64 });
40
- const checkIconSm = useFcIconElement("FcCheckmark", { size: 14 });
41
- const infoIcon = useFcIconElement("FcInfo", { size: 64 });
42
- const handleFileChange = useCallback((selectedFile) => {
43
- if (selectedFile) {
44
- setFile(selectedFile);
45
- setActiveStep(1);
46
- }
47
- }, []);
48
- const handleFolderSelect = useCallback((folderId) => {
49
- setSelectedFolderId(folderId);
50
- setFolderSelected(true);
51
- setPickerOpen(false);
52
- setActiveStep(2);
53
- }, []);
54
- const handleUpload = useCallback(async () => {
55
- if (!file) return;
56
- console.log("[UploaderApp] Starting upload for file:", file.name, "size:", file.size);
57
- setUploadStarted(true);
58
- setUploadState({
59
- status: "reading",
60
- progress: { status: "downloading", loaded: 0, total: file.size, percent: 0, error: null }
61
- });
62
- try {
63
- setUploadState((prev) => ({
64
- ...prev,
65
- progress: {
66
- status: "downloading",
67
- loaded: 0,
68
- total: file.size,
69
- percent: 0,
70
- error: null
71
- }
72
- }));
73
- for (let i = 0; i <= 50; i += 10) {
74
- await new Promise((resolve) => setTimeout(resolve, 50));
75
- setUploadState((prev) => ({
76
- ...prev,
77
- progress: {
78
- status: "downloading",
79
- loaded: Math.floor(file.size * i / 100),
80
- total: file.size,
81
- percent: i,
82
- error: null
83
- }
84
- }));
85
- }
86
- console.log("[UploaderApp] Calling saveBlob...");
87
- const saveBlobStart = Date.now();
88
- const idbUrl = await fileSystem.saveBlob(file);
89
- console.log(
90
- "[UploaderApp] saveBlob completed in",
91
- Date.now() - saveBlobStart,
92
- "ms, url:",
93
- idbUrl
94
- );
95
- setUploadState((prev) => ({
96
- ...prev,
97
- progress: {
98
- status: "downloading",
99
- loaded: Math.floor(file.size * 80 / 100),
100
- total: file.size,
101
- percent: 80,
102
- error: null
103
- }
104
- }));
105
- console.log("[UploaderApp] Calling createFile with folderId:", selectedFolderId);
106
- const createStart = Date.now();
107
- const createdFile = await createFile(file.name, "", selectedFolderId, idbUrl);
108
- console.log(
109
- "[UploaderApp] createFile completed in",
110
- Date.now() - createStart,
111
- "ms, id:",
112
- createdFile.id
113
- );
114
- setCreatedFileId(createdFile.id);
115
- setUploadState({
116
- status: "done",
117
- progress: {
118
- status: "done",
119
- loaded: file.size,
120
- total: file.size,
121
- percent: 100,
122
- error: null
123
- }
124
- });
125
- await new Promise((resolve) => setTimeout(resolve, 1e3));
126
- setActiveStep(3);
127
- } catch (err) {
128
- console.error("[UploaderApp] Upload FAILED:", err);
129
- setUploadState((prev) => ({
130
- ...prev,
131
- status: "error",
132
- error: err instanceof Error ? err.message : "Upload failed"
133
- }));
134
- await new Promise((resolve) => setTimeout(resolve, 1e3));
135
- setActiveStep(3);
136
- }
137
- }, [file, selectedFolderId, createFile]);
138
- const handleShowFile = useCallback(() => {
139
- if (!selectedFolderId) {
140
- openApp("files");
141
- } else {
142
- openApp("files", { contentData: { initialFolderId: selectedFolderId } });
143
- }
144
- }, [selectedFolderId, openApp]);
145
- const handleOpenFile = useCallback(() => {
146
- if (!createdFileId) return;
147
- const createdNode = useDesktopStore.getState().fsNodes.find((n) => n.id === createdFileId);
148
- if (!createdNode || createdNode.type !== "file") return;
149
- const fileNode = createdNode;
150
- const result = getAppIdForMime(fileNode);
151
- if (result) {
152
- openApp(result.appId, { contentData: result.contentData });
153
- }
154
- }, [createdFileId, openApp]);
155
- if (!win) return null;
156
- const isSuccess = uploadState.status === "done";
157
- const errorMessage = uploadState.error;
158
- if (activeStep === 3) {
159
- return /* @__PURE__ */ jsx("div", { className: UploaderApp_default.container, children: /* @__PURE__ */ jsxs(Paper, { shadow: "sm", className: UploaderApp_default.resultPaper, children: [
160
- /* @__PURE__ */ jsx(Box, { className: UploaderApp_default.resultIcon, children: isSuccess ? checkIconLg : infoIcon }),
161
- /* @__PURE__ */ jsx(Text, { size: "lg", fw: 500, ta: "center", children: isSuccess ? t("uploader.uploadComplete") : `${t("uploader.uploadFailed")}: ${errorMessage}` }),
162
- isSuccess && /* @__PURE__ */ jsxs(Group, { mt: "md", justify: "center", children: [
163
- /* @__PURE__ */ jsx(
164
- Button,
165
- {
166
- variant: "default",
167
- size: "sm",
168
- onClick: handleShowFile,
169
- "data-testid": "uploader-show-file",
170
- children: t("uploader.showFile")
171
- }
172
- ),
173
- /* @__PURE__ */ jsx(Button, { size: "sm", onClick: handleOpenFile, "data-testid": "uploader-open-file", children: t("uploader.openFile") })
174
- ] })
175
- ] }) });
176
- }
177
- return /* @__PURE__ */ jsxs("div", { className: UploaderApp_default.container, children: [
178
- uploadIcon && /* @__PURE__ */ jsx("div", { className: UploaderApp_default.backgroundIcon, children: uploadIcon }),
179
- /* @__PURE__ */ jsxs(Stepper, { active: activeStep, orientation: "horizontal", size: "sm", className: UploaderApp_default.stepper, children: [
180
- /* @__PURE__ */ jsx(Stepper.Step, { label: t("uploader.stepSelect"), description: t("uploader.clickToUpload"), children: /* @__PURE__ */ jsx(FileButton, { accept: "*", onChange: handleFileChange, children: (props) => /* @__PURE__ */ jsx(Button, { ...props, size: "sm", "data-testid": "uploader-select-file", children: t("uploader.clickToUpload") }) }) }),
181
- /* @__PURE__ */ jsxs(
182
- Stepper.Step,
183
- {
184
- label: t("uploader.stepDestination"),
185
- description: folderSelected ? /* @__PURE__ */ jsxs(Group, { gap: 4, align: "center", style: { display: "inline-flex" }, children: [
186
- checkIconSm,
187
- /* @__PURE__ */ jsx("span", { children: t("uploader.folderSelected") })
188
- ] }) : t("uploader.selectDestination"),
189
- children: [
190
- file && /* @__PURE__ */ jsxs(Box, { className: UploaderApp_default.fileInfo, children: [
191
- /* @__PURE__ */ jsx(Text, { size: "sm", fw: 500, children: file.name }),
192
- /* @__PURE__ */ jsx(Text, { size: "xs", c: "dimmed", children: formatBytes(file.size) })
193
- ] }),
194
- /* @__PURE__ */ jsxs(Group, { mt: "md", children: [
195
- /* @__PURE__ */ jsx(
196
- Button,
197
- {
198
- variant: "default",
199
- size: "xs",
200
- onClick: () => setPickerOpen(true),
201
- "data-testid": "uploader-select-folder",
202
- children: t("uploader.selectDestination")
203
- }
204
- ),
205
- /* @__PURE__ */ jsx(Button, { size: "xs", onClick: () => setActiveStep(2), "data-testid": "uploader-skip-folder", children: t("uploader.next", { defaultValue: "Next" }) })
206
- ] }),
207
- /* @__PURE__ */ jsx(Text, { size: "xs", c: "dimmed", mt: "xs", children: selectedFolderId ? `${t("uploader.uploadTo")}: ${useDesktopStore.getState().fsNodes.find((n) => n.id === selectedFolderId)?.name || ""}` : t("uploader.uploadToRoot") })
208
- ]
209
- }
210
- ),
211
- /* @__PURE__ */ jsx(Stepper.Step, { label: t("uploader.stepUpload"), description: t("uploader.uploading"), children: !uploadStarted ? /* @__PURE__ */ jsxs(Box, { className: UploaderApp_default.readyContainer, children: [
212
- /* @__PURE__ */ jsx(Text, { size: "sm", ta: "center", children: t("uploader.readyToUpload") }),
213
- /* @__PURE__ */ jsx(Group, { justify: "center", children: /* @__PURE__ */ jsx(Button, { size: "sm", onClick: handleUpload, "data-testid": "uploader-upload", children: t("uploader.upload") }) })
214
- ] }) : /* @__PURE__ */ jsx(
215
- DownloadProgress_default,
216
- {
217
- state: uploadState.progress,
218
- ariaLabel: t("uploader.uploadProgress")
219
- }
220
- ) })
221
- ] }),
222
- /* @__PURE__ */ jsx(
223
- FolderPickerModal,
224
- {
225
- opened: pickerOpen,
226
- onConfirm: handleFolderSelect,
227
- onCancel: () => setPickerOpen(false)
228
- }
229
- )
230
- ] });
231
- };
232
- var UploaderApp_default2 = UploaderApp;
233
-
234
- export { UploaderApp_default2 as UploaderApp_default, formatBytes };
@@ -1,88 +0,0 @@
1
- 'use strict';
2
-
3
- var chunkUIQCTAVM_cjs = require('./chunk-UIQCTAVM.cjs');
4
- var chunkBQCD5RAF_cjs = require('./chunk-BQCD5RAF.cjs');
5
- var chunkUKYESVDS_cjs = require('./chunk-UKYESVDS.cjs');
6
- var chunkGPXNLTPI_cjs = require('./chunk-GPXNLTPI.cjs');
7
- var chunkV4N255NL_cjs = require('./chunk-V4N255NL.cjs');
8
- var react = require('react');
9
- var reactI18next = require('react-i18next');
10
- var jsxRuntime = require('react/jsx-runtime');
11
-
12
- // src/components/Apps/ImageViewerApp/ImageViewerApp.module.css
13
- var ImageViewerApp_default = {};
14
- var ACCEPTED_IMAGE_TYPES = [...chunkV4N255NL_cjs.IMAGE_MIME_TYPES, "image/*"];
15
- var ImageViewerApp = ({ window, notifyReady }) => {
16
- const { t } = reactI18next.useTranslation("apps");
17
- const win = window;
18
- const windowId = win?.id ?? "";
19
- const initialSrc = win?.contentData?.src;
20
- const [src, setSrc] = react.useState(initialSrc);
21
- const [pickerOpen, setPickerOpen] = react.useState(false);
22
- const [imageDimensions, setImageDimensions] = react.useState(null);
23
- const containerRef = react.useRef(null);
24
- const displayZoom = chunkUIQCTAVM_cjs.useImageViewerStore((s) => s.getDisplayZoom(windowId));
25
- const fitToWindow = chunkUIQCTAVM_cjs.useImageViewerStore((s) => s.getFitToWindow(windowId));
26
- const updateCalculatedZoom = chunkUIQCTAVM_cjs.useImageViewerStore((s) => s.updateCalculatedZoom);
27
- const reset = chunkUIQCTAVM_cjs.useImageViewerStore((s) => s.reset);
28
- const resolvedSrc = chunkUKYESVDS_cjs.useResolvedUrl(src);
29
- react.useEffect(() => {
30
- reset(windowId);
31
- }, [windowId, reset]);
32
- react.useEffect(() => {
33
- if (!fitToWindow || !imageDimensions || !containerRef.current) return;
34
- const observer = new ResizeObserver((entries) => {
35
- for (const entry of entries) {
36
- const { width, height } = entry.contentRect;
37
- updateCalculatedZoom(windowId, imageDimensions, { width, height });
38
- }
39
- });
40
- observer.observe(containerRef.current);
41
- return () => observer.disconnect();
42
- }, [fitToWindow, imageDimensions, windowId, updateCalculatedZoom]);
43
- react.useEffect(() => {
44
- notifyReady?.({
45
- ...win?.contentData ?? {},
46
- setPickerOpen: () => setPickerOpen(true)
47
- });
48
- }, [win, notifyReady]);
49
- const handleFileSelected = react.useCallback(
50
- (node) => {
51
- setSrc(node.url ?? node.name);
52
- setPickerOpen(false);
53
- reset(windowId);
54
- setImageDimensions(null);
55
- },
56
- [windowId, reset]
57
- );
58
- const handleImageLoad = react.useCallback((e) => {
59
- const img = e.currentTarget;
60
- setImageDimensions({ width: img.naturalWidth, height: img.naturalHeight });
61
- }, []);
62
- const imgStyle = fitToWindow ? void 0 : { transform: `scale(${displayZoom / 100})` };
63
- const content = resolvedSrc ? /* @__PURE__ */ jsxRuntime.jsx(
64
- "img",
65
- {
66
- src: resolvedSrc,
67
- alt: resolvedSrc.split("/").pop() ?? "image",
68
- className: ImageViewerApp_default.image,
69
- style: imgStyle,
70
- onLoad: handleImageLoad
71
- }
72
- ) : /* @__PURE__ */ jsxRuntime.jsx(chunkBQCD5RAF_cjs.AppEmptyState_default, { label: t("imageViewer.noImage") });
73
- return /* @__PURE__ */ jsxRuntime.jsxs("div", { ref: containerRef, className: ImageViewerApp_default.container, "data-windowid": win?.id, children: [
74
- content,
75
- /* @__PURE__ */ jsxRuntime.jsx(
76
- chunkGPXNLTPI_cjs.FilePickerModal,
77
- {
78
- opened: pickerOpen,
79
- acceptedMimeTypes: ACCEPTED_IMAGE_TYPES,
80
- onConfirm: handleFileSelected,
81
- onCancel: () => setPickerOpen(false)
82
- }
83
- )
84
- ] });
85
- };
86
- var ImageViewerApp_default2 = ImageViewerApp;
87
-
88
- exports.ImageViewerApp_default = ImageViewerApp_default2;
@@ -1,17 +0,0 @@
1
- import { jsx } from 'react/jsx-runtime';
2
-
3
- // src/components/Apps/StorybookApp/StorybookApp.module.css
4
- var StorybookApp_default = {};
5
- var STORYBOOK_URL = "https://frannunpal.github.io/storybook/";
6
- var StorybookApp = () => /* @__PURE__ */ jsx(
7
- "iframe",
8
- {
9
- src: STORYBOOK_URL,
10
- className: StorybookApp_default.frame,
11
- title: "Storybook",
12
- "aria-label": "Storybook component explorer"
13
- }
14
- );
15
- var StorybookApp_default2 = StorybookApp;
16
-
17
- export { StorybookApp_default2 as StorybookApp_default };
@@ -1,48 +0,0 @@
1
- import { fileSystem, getBaseUrl } from './chunk-5QFZW6HW.js';
2
- import { isDocker } from './chunk-FRHBM2U7.js';
3
- import { useMemo, useState, useRef, useEffect } from 'react';
4
-
5
- function useResolvedUrl(url) {
6
- const needsBlobResolution = useMemo(
7
- () => (url?.startsWith("idb://") || isDocker() && url?.startsWith("/api/fs")) ?? false,
8
- [url]
9
- );
10
- const isApiFsUrl = useMemo(() => url?.startsWith("/api/fs") ?? false, [url]);
11
- const [blobUrl, setBlobUrl] = useState(void 0);
12
- const revokeRef = useRef(void 0);
13
- useEffect(() => {
14
- if (!url || !needsBlobResolution) return;
15
- let cancelled = false;
16
- fileSystem.toBlobUrl(url).then((result) => {
17
- if (cancelled) {
18
- if (result) URL.revokeObjectURL(result);
19
- return;
20
- }
21
- revokeRef.current = result ?? void 0;
22
- setBlobUrl(result ?? void 0);
23
- });
24
- return () => {
25
- cancelled = true;
26
- if (revokeRef.current) {
27
- URL.revokeObjectURL(revokeRef.current);
28
- revokeRef.current = void 0;
29
- }
30
- setBlobUrl(void 0);
31
- };
32
- }, [url, needsBlobResolution]);
33
- if (!url) return void 0;
34
- if (isApiFsUrl && needsBlobResolution) {
35
- return blobUrl;
36
- }
37
- if (!needsBlobResolution) {
38
- if (url.startsWith("/") || url.startsWith("http://") || url.startsWith("https://")) {
39
- return url;
40
- }
41
- const base = getBaseUrl();
42
- const normalizedBase = base.endsWith("/") ? base : `${base}/`;
43
- return `${normalizedBase}${url}`;
44
- }
45
- return blobUrl;
46
- }
47
-
48
- export { useResolvedUrl };
@@ -1,59 +0,0 @@
1
- 'use strict';
2
-
3
- var zustand = require('zustand');
4
-
5
- // src/components/Apps/ImageViewerApp/imageViewerStore.ts
6
- var DEFAULT_STATE = {
7
- userZoom: 100,
8
- calculatedZoom: 100,
9
- fitToWindow: true
10
- };
11
- var useImageViewerStore = zustand.create((set, get) => ({
12
- states: {},
13
- getUserZoom: (id) => get().states[id]?.userZoom ?? 100,
14
- getCalculatedZoom: (id) => get().states[id]?.calculatedZoom ?? 100,
15
- getFitToWindow: (id) => get().states[id]?.fitToWindow ?? true,
16
- getDisplayZoom: (id) => {
17
- const state = get().states[id];
18
- if (!state) return 100;
19
- return state.fitToWindow ? state.calculatedZoom : state.userZoom;
20
- },
21
- setUserZoom: (id, zoom) => set((s) => ({
22
- states: {
23
- ...s.states,
24
- [id]: { ...s.states[id] ?? DEFAULT_STATE, userZoom: zoom, fitToWindow: false }
25
- }
26
- })),
27
- setFitToWindow: (id, fitToWindow) => set((s) => ({
28
- states: {
29
- ...s.states,
30
- [id]: { ...s.states[id] ?? DEFAULT_STATE, fitToWindow }
31
- }
32
- })),
33
- updateCalculatedZoom: (id, imageDims, containerDims) => {
34
- const scale = Math.min(
35
- containerDims.width / imageDims.width,
36
- containerDims.height / imageDims.height
37
- );
38
- const calculatedZoom = Math.round(scale * 100);
39
- set((s) => ({
40
- states: {
41
- ...s.states,
42
- [id]: { ...s.states[id] ?? DEFAULT_STATE, calculatedZoom }
43
- }
44
- }));
45
- },
46
- reset: (id) => set((s) => ({
47
- states: { ...s.states, [id]: DEFAULT_STATE }
48
- }))
49
- }));
50
- var useFitToWindow = (windowId) => useImageViewerStore((s) => s.states[windowId]?.fitToWindow ?? true);
51
- var useDisplayZoom = (windowId) => useImageViewerStore((s) => {
52
- const state = s.states[windowId];
53
- if (!state) return 100;
54
- return state.fitToWindow ? state.calculatedZoom : state.userZoom;
55
- });
56
-
57
- exports.useDisplayZoom = useDisplayZoom;
58
- exports.useFitToWindow = useFitToWindow;
59
- exports.useImageViewerStore = useImageViewerStore;