@fde-desktop/fde-core 0.4.7 → 0.4.8
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/AccordionChevron-CJXAq5o5.js +26 -0
- package/dist/AccordionChevron-DBXp38Lm.cjs +1 -0
- package/dist/ActionIcon-C_SfdBfx.cjs +1 -0
- package/dist/ActionIcon-CtVbYlGY.js +145 -0
- package/dist/AppEmptyState-BTujnL_b.js +4962 -0
- package/dist/AppEmptyState-Dc4GaDfu.cjs +1 -0
- package/dist/AppIcon--qzR4sgf.cjs +1 -0
- package/dist/AppIcon-DCDuaU-t.js +80 -0
- package/dist/AppMenuBar-BiHbNg9V.cjs +9 -0
- package/dist/AppMenuBar-CHJy8OF0.js +2639 -0
- package/dist/Box-DRm8EabO.js +1593 -0
- package/dist/Box-D_64wv6n.cjs +1 -0
- package/dist/Button-D0FXpkur.cjs +1 -0
- package/dist/Button-k7SxX1Xl.js +178 -0
- package/dist/CalendarApp-C1HvuJoa.cjs +1 -0
- package/dist/CalendarApp-DBEQqsS_.js +1721 -0
- package/dist/Center-CyryG5zn.js +25 -0
- package/dist/Center-T4No_FAa.cjs +1 -0
- package/dist/CheckIcon-C3WjIR2i.js +25 -0
- package/dist/CheckIcon-CBMLR6Gc.cjs +1 -0
- package/dist/CodeServerApp-B3l5QPuG.cjs +1 -0
- package/dist/CodeServerApp-BpeALSaX.js +2 -0
- package/dist/CodeServerApp-CRjCngFv.cjs +1 -0
- package/dist/CodeServerApp-DY94cy1a.js +149 -0
- package/dist/ColorPicker-BL4UbKCV.cjs +1 -0
- package/dist/ColorPicker-DvRR-wlQ.js +997 -0
- package/dist/Colors-BxX4G8kX.cjs +1 -0
- package/dist/Colors-hca6raEG.js +15 -0
- package/dist/CreateItemApp-BU9wmjKM.cjs +1 -0
- package/dist/CreateItemApp-CtdH1K1g.js +400 -0
- package/dist/CreateItemApp-t9F-a6wD.cjs +1 -0
- package/dist/DeviceInfoApp-C306YvtZ.js +223 -0
- package/dist/DeviceInfoApp-Cdju_LIB.cjs +1 -0
- package/dist/DeviceInfoApp-CyB01v4D.cjs +1 -0
- package/dist/DownloadProgress-IRw1dzLX.cjs +1 -0
- package/dist/DownloadProgress-hdupSUBT.js +174 -0
- package/dist/FileIcon-BCpGMI5U.js +88 -0
- package/dist/FileIcon-BCrsxmtt.cjs +1 -0
- package/dist/FilePickerApp-DMGuvahM.js +409 -0
- package/dist/FilePickerApp-Eu0cr2Cm.cjs +1 -0
- package/dist/FilesApp-30OjnOuP.cjs +1 -0
- package/dist/FilesApp-BvlzPNuO.cjs +1 -0
- package/dist/FilesApp-VXrmtt63.js +225 -0
- package/dist/Group-BzwlMeob.js +48 -0
- package/dist/Group-DhwePB84.cjs +1 -0
- package/dist/ImageViewerApp-BOz59TGc.cjs +1 -0
- package/dist/ImageViewerApp-BeqY6voE.cjs +1 -0
- package/dist/ImageViewerApp-CWiP6zx-.js +68 -0
- package/dist/ImageViewerApp-DBAfJPSo.js +2 -0
- package/dist/ImageViewerMenuBar-BULkh_Ku.js +86 -0
- package/dist/ImageViewerMenuBar-Cb0Nr5-M.js +2 -0
- package/dist/ImageViewerMenuBar-CoEp0RxK.cjs +1 -0
- package/dist/ImageViewerMenuBar-zOkJtqKo.cjs +1 -0
- package/dist/MenuEditApp-BoKtj2GH.js +2 -0
- package/dist/MenuEditApp-D21sEp86.js +2615 -0
- package/dist/MenuEditApp-k3cPfTG9.cjs +1 -0
- package/dist/MenuEditApp-sz9GlLVH.cjs +5 -0
- package/dist/MenuEditMenuBar-6QxlIDpl.cjs +1 -0
- package/dist/MenuEditMenuBar-B94z4Umw.js +59 -0
- package/dist/MenuEditMenuBar-Bv6R42lf.js +2 -0
- package/dist/MenuEditMenuBar-CBsmH_-T.cjs +1 -0
- package/dist/NotesApp-BtR55Hva.cjs +207 -0
- package/dist/NotesApp-C59exz_9.js +16154 -0
- package/dist/NotesApp-D47I5LS_.js +2 -0
- package/dist/NotesApp-lOwsi2sg.cjs +1 -0
- package/dist/NotesMenuBar-BB4NkKGf.js +61 -0
- package/dist/NotesMenuBar-BZITC74y.cjs +1 -0
- package/dist/NotesMenuBar-Bp0sPqyR.cjs +1 -0
- package/dist/NotesMenuBar-xlfODmMA.js +2 -0
- package/dist/Paper-DtUYKmYn.js +30 -0
- package/dist/Paper-DwCpwWwH.cjs +1 -0
- package/dist/PdfApp-1XbFGfoY.cjs +1 -0
- package/dist/PdfApp-BhIoJWeK.cjs +1 -0
- package/dist/PdfApp-C5Rt1Zaw.js +2 -0
- package/dist/PdfApp-C8Hwxxqh.js +38 -0
- package/dist/PdfMenuBar-BA9rKuMP.cjs +1 -0
- package/dist/PdfMenuBar-JXHqwxhZ.cjs +1 -0
- package/dist/PdfMenuBar-R0fu7oYF.js +2 -0
- package/dist/PdfMenuBar-sd-9Vk3h.js +38 -0
- package/dist/SettingsApp-BA-5B4RA.cjs +1 -0
- package/dist/SettingsApp-B_rev1xh.cjs +1 -0
- package/dist/SettingsApp-Ck4aUXs5.js +2 -0
- package/dist/SettingsApp-DUMKSA3K.js +2425 -0
- package/dist/SettingsMenuBar-BPwv8JQK.js +41 -0
- package/dist/SettingsMenuBar-D8R7hOik.js +2 -0
- package/dist/SettingsMenuBar-DDrjZLmg.cjs +1 -0
- package/dist/SettingsMenuBar-DQjUa8g1.cjs +1 -0
- package/dist/Slider-BNO-vDFn.js +1175 -0
- package/dist/Slider-Bg_EIBg6.cjs +1 -0
- package/dist/Stack-BOaJgV3N.cjs +1 -0
- package/dist/Stack-CuDEaP7e.js +34 -0
- package/dist/StorybookApp-Bkr-7mXp.cjs +1 -0
- package/dist/StorybookApp-WYninkJo.js +10 -0
- package/dist/TerminalApp-8XbsKAWa.js +10041 -0
- package/dist/TerminalApp-Bq2e7QQu.cjs +1 -0
- package/dist/TerminalApp-CVu3Axc9.js +2 -0
- package/dist/TerminalApp-b7_d0jRO.cjs +36 -0
- package/dist/TerminalMenuBar-Cb8x9laS.js +2 -0
- package/dist/TerminalMenuBar-De-FH5AE.cjs +1 -0
- package/dist/TerminalMenuBar-iKLydNda.js +112 -0
- package/dist/TerminalMenuBar-yOaWd-hn.cjs +1 -0
- package/dist/TextInput-C3qfxxWI.js +980 -0
- package/dist/TextInput-DcYns3hz.cjs +1 -0
- package/dist/Tooltip-CAOO-qdx.js +3185 -0
- package/dist/Tooltip-DDh_x-CB.cjs +1 -0
- package/dist/UnstyledButton-CI3kyRck.js +25 -0
- package/dist/UnstyledButton-Cl5RuIid.cjs +1 -0
- package/dist/UploaderApp-BZXW75A0.cjs +1 -0
- package/dist/UploaderApp-C9W_yCT-.js +487 -0
- package/dist/UploaderApp-CPpStgP5.cjs +1 -0
- package/dist/UploaderApp-DHsMQN-f.js +2 -0
- package/dist/VscIcon-CxEmqD80.cjs +1 -0
- package/dist/VscIcon-DueRJVTe.js +8 -0
- package/dist/chunk-BQCxAhux.js +23 -0
- package/dist/chunk-CiTBaPhY.cjs +1 -0
- package/dist/create-safe-context-95P-Bfg3.cjs +1 -0
- package/dist/create-safe-context-XT2cxc14.js +12 -0
- package/dist/desktopStore-B0R1-BeA.js +1905 -0
- package/dist/desktopStore-Cox-Og1z.cjs +1 -0
- package/dist/fc-DejOsQyD.cjs +1 -0
- package/dist/fc-kd8WzIER.js +20536 -0
- package/dist/fc-xJ_v2ayq.cjs +184 -0
- package/dist/fi-BahYsbim.js +9993 -0
- package/dist/fi-BkhyTcZo.cjs +1 -0
- package/dist/getRuntime-BLXyQZBB.cjs +1 -0
- package/dist/getRuntime-CCRXVzJH.js +63 -0
- package/dist/iconBase-B4UCuSvv.cjs +1 -0
- package/dist/iconBase-D7iPes7B.js +108 -0
- package/dist/imageViewerStore-CH1qW6md.cjs +1 -0
- package/dist/imageViewerStore-CJMRXaQh.js +50 -0
- package/dist/index.cjs +53 -5642
- package/dist/index.css +2 -9192
- package/dist/index.d.ts +2258 -2019
- package/dist/index.js +8983 -4780
- package/dist/is-element-BocgicRg.cjs +1 -0
- package/dist/is-element-Bu_JY8Qy.js +7 -0
- package/dist/menuEditStore-C8S_EedM.js +38 -0
- package/dist/menuEditStore-CU7IAg3L.cjs +1 -0
- package/dist/notesStore-DKRgTTFn.js +36 -0
- package/dist/notesStore-zKmChTfF.cjs +1 -0
- package/dist/react-DYmzHD0X.js +27 -0
- package/dist/react-Dldg32sN.cjs +1 -0
- package/dist/settingsAppStore-BrlImdAH.cjs +1 -0
- package/dist/settingsAppStore-KOeWRO6h.js +29 -0
- package/dist/terminalStore-LWWjCvCe.js +30 -0
- package/dist/terminalStore-fZe5t7Ty.cjs +1 -0
- package/dist/use-merged-ref-BI9n1hUK.cjs +1 -0
- package/dist/use-merged-ref-BT8_u6vW.js +25 -0
- package/dist/use-resolved-styles-api-AVDygMKo.cjs +1 -0
- package/dist/use-resolved-styles-api-pEOi2wiK.js +21 -0
- package/dist/use-uncontrolled-A4hm9ATM.js +23 -0
- package/dist/use-uncontrolled-BPrfGv0W.cjs +1 -0
- package/dist/useAdaptiveDimensions-Btp0m5Pm.cjs +1 -0
- package/dist/useAdaptiveDimensions-CunsU0mn.js +40 -0
- package/dist/useCloseInterceptor-CuKAAFnj.js +51 -0
- package/dist/useCloseInterceptor-a_6Lcuqj.cjs +1 -0
- package/dist/useDynamicIcon-GJg3vWsJ.js +22 -0
- package/dist/useDynamicIcon-SytdL1Tu.cjs +1 -0
- package/dist/useMenuBarUtils-Bp5PiztD.cjs +1 -0
- package/dist/useMenuBarUtils-ChmpZjwu.js +6 -0
- package/dist/useOpenApp-BdarhIgl.cjs +1 -0
- package/dist/useOpenApp-JHCPTBWa.js +279 -0
- package/dist/useResolvedUrl-Be5ZlCX7.cjs +1 -0
- package/dist/useResolvedUrl-DFKXq598.js +30 -0
- package/dist/useTranslation-DMRGdqZi.js +279 -0
- package/dist/useTranslation-D_O7S4RJ.cjs +1 -0
- package/dist/vsc-Ciibqbxo.cjs +1 -0
- package/dist/vsc-DGKSpOAR.js +9574 -0
- package/package.json +7 -3
- package/dist/CalendarApp-CHLUCAI7.css +0 -744
- package/dist/CalendarApp-K7ZOUZ6C.js +0 -2
- package/dist/CalendarApp-OTGEERSS.cjs +0 -8
- package/dist/CodeServerApp-5KZGO7HL.css +0 -75
- package/dist/CodeServerApp-LUZFCQBI.js +0 -3
- package/dist/CodeServerApp-P3TMJPLY.cjs +0 -9
- package/dist/CreateItemApp-ESQ42VHH.js +0 -8
- package/dist/CreateItemApp-PQB5GTFG.css +0 -107
- package/dist/CreateItemApp-RFE3REWZ.cjs +0 -14
- package/dist/DeviceInfoApp-XNIS6ZY6.js +0 -5
- package/dist/DeviceInfoApp-ZNLQNOKI.cjs +0 -11
- package/dist/DeviceInfoApp-ZSMRSITP.css +0 -7
- package/dist/FilesApp-4GEU64QN.js +0 -8
- package/dist/FilesApp-E6L5W3T2.css +0 -1817
- package/dist/FilesApp-QSLB5IWR.cjs +0 -14
- package/dist/ImageViewerApp-N2Q7E7WZ.css +0 -215
- package/dist/ImageViewerApp-NCVDKLB3.js +0 -11
- package/dist/ImageViewerApp-QB373H5Z.cjs +0 -17
- package/dist/ImageViewerMenuBar-I3TFKQPS.cjs +0 -14
- package/dist/ImageViewerMenuBar-TV5C6TM2.js +0 -5
- package/dist/ImageViewerMenuBar-XLK4LIHW.css +0 -56
- package/dist/MenuEditApp-5EFYAPFC.cjs +0 -15
- package/dist/MenuEditApp-V5XOPIHX.js +0 -9
- package/dist/MenuEditApp-YA6HSAMJ.css +0 -94
- package/dist/MenuEditMenuBar-7VHMZNRM.css +0 -56
- package/dist/MenuEditMenuBar-GF6L4PGZ.cjs +0 -15
- package/dist/MenuEditMenuBar-IUXFPZE5.js +0 -6
- package/dist/NotesApp-2YNT7Y3D.js +0 -10
- package/dist/NotesApp-IAEE7YHU.cjs +0 -16
- package/dist/NotesApp-TQ6IHDNX.css +0 -302
- package/dist/NotesMenuBar-25LKN3SE.cjs +0 -15
- package/dist/NotesMenuBar-MXLOX7OT.css +0 -56
- package/dist/NotesMenuBar-SRV3AIAL.js +0 -6
- package/dist/PdfApp-67XIX6AM.js +0 -10
- package/dist/PdfApp-BUIC5U5H.css +0 -206
- package/dist/PdfApp-GZ6RHTBR.cjs +0 -16
- package/dist/PdfMenuBar-NLZC6JHS.js +0 -4
- package/dist/PdfMenuBar-QUM72EE4.css +0 -56
- package/dist/PdfMenuBar-WBRTKMLN.cjs +0 -13
- package/dist/SettingsApp-BPLMGPNK.cjs +0 -20
- package/dist/SettingsApp-JVOSEFH3.css +0 -283
- package/dist/SettingsApp-LUDIXCYY.js +0 -14
- package/dist/SettingsMenuBar-5CBSSMVM.css +0 -56
- package/dist/SettingsMenuBar-VLT6TTCM.js +0 -6
- package/dist/SettingsMenuBar-Y5QEXDEO.cjs +0 -15
- package/dist/StorybookApp-NQ244BER.css +0 -7
- package/dist/StorybookApp-NZDV4X3Y.js +0 -1
- package/dist/StorybookApp-VF3KIMU3.cjs +0 -7
- package/dist/TerminalApp-CDGWRBFJ.cjs +0 -10
- package/dist/TerminalApp-EAATMIMX.css +0 -77
- package/dist/TerminalApp-GCKJCM55.js +0 -4
- package/dist/TerminalMenuBar-3J26O26Q.css +0 -56
- package/dist/TerminalMenuBar-7BH7MGNJ.cjs +0 -14
- package/dist/TerminalMenuBar-7JAEQUZ4.js +0 -5
- package/dist/UploaderApp-6KV3TGCT.css +0 -1817
- package/dist/UploaderApp-FJC2J4I5.js +0 -10
- package/dist/UploaderApp-HLXJYJZQ.cjs +0 -16
- package/dist/chunk-2PSTHGTD.cjs +0 -42
- package/dist/chunk-2RQX7QBP.cjs +0 -148
- package/dist/chunk-43W6UDUZ.cjs +0 -19
- package/dist/chunk-4E45FBAH.js +0 -223
- package/dist/chunk-4E4U2A25.cjs +0 -237
- package/dist/chunk-4QHX7CMN.cjs +0 -38
- package/dist/chunk-4XURSNM4.js +0 -43
- package/dist/chunk-4ZCRYHL6.js +0 -407
- package/dist/chunk-5C6IQE42.cjs +0 -35
- package/dist/chunk-5HUYQDQF.js +0 -36
- package/dist/chunk-5NOHYJNH.js +0 -84
- package/dist/chunk-5QFZW6HW.js +0 -2241
- package/dist/chunk-5YH6AKEO.js +0 -146
- package/dist/chunk-756GPSPM.js +0 -283
- package/dist/chunk-7WUYUTPN.js +0 -2293
- package/dist/chunk-7XCMBW64.js +0 -162
- package/dist/chunk-7Y7HB7FB.cjs +0 -53
- package/dist/chunk-ABIAPZ6S.cjs +0 -45
- package/dist/chunk-ACHGJKCI.cjs +0 -286
- package/dist/chunk-BQCD5RAF.cjs +0 -48
- package/dist/chunk-BQL3YXMV.js +0 -17429
- package/dist/chunk-C3XER4N3.js +0 -442
- package/dist/chunk-C6BEZNAM.cjs +0 -45
- package/dist/chunk-CILU6BWC.cjs +0 -548
- package/dist/chunk-CV5PUHAE.cjs +0 -86
- package/dist/chunk-D5MVFFID.js +0 -42
- package/dist/chunk-D7R55WWT.js +0 -1601
- package/dist/chunk-DFYDUXWP.cjs +0 -34
- package/dist/chunk-DWP2SYF7.js +0 -55
- package/dist/chunk-E55VXNLK.cjs +0 -17498
- package/dist/chunk-E5FW77FG.js +0 -77
- package/dist/chunk-EAELL43F.js +0 -42
- package/dist/chunk-EX5V2ZTU.js +0 -40
- package/dist/chunk-FD7QZCTN.cjs +0 -2329
- package/dist/chunk-FH4ILMKF.js +0 -38
- package/dist/chunk-FRHBM2U7.js +0 -33
- package/dist/chunk-FX2TPX3L.cjs +0 -45
- package/dist/chunk-GPXNLTPI.cjs +0 -451
- package/dist/chunk-GRYCUBJZ.js +0 -9
- package/dist/chunk-HPHHS7FJ.cjs +0 -49
- package/dist/chunk-HWHBSAUC.js +0 -40
- package/dist/chunk-IDHP3R4I.js +0 -31
- package/dist/chunk-IHWGT3DL.js +0 -86
- package/dist/chunk-JEBKLIMU.cjs +0 -123
- package/dist/chunk-KDZLBI6F.cjs +0 -324
- package/dist/chunk-KQHICFX3.js +0 -121
- package/dist/chunk-LMJE6V4N.cjs +0 -42
- package/dist/chunk-MCHPDWVH.js +0 -444
- package/dist/chunk-MVDGM5Y4.js +0 -68
- package/dist/chunk-N36HBL53.cjs +0 -165
- package/dist/chunk-NV5GNFA3.js +0 -541
- package/dist/chunk-NVEGEK3N.js +0 -31
- package/dist/chunk-OJIDKDKF.js +0 -68
- package/dist/chunk-PGGNSLM7.js +0 -215
- package/dist/chunk-PKPQA5NR.js +0 -15
- package/dist/chunk-PNDBLFJW.cjs +0 -50
- package/dist/chunk-Q3WA72BF.cjs +0 -70
- package/dist/chunk-RDIDAZ3S.cjs +0 -9
- package/dist/chunk-RGJPRXYY.js +0 -48
- package/dist/chunk-RPSYXORB.cjs +0 -219
- package/dist/chunk-RQ6OZRUW.cjs +0 -41
- package/dist/chunk-SBE4SZAN.cjs +0 -226
- package/dist/chunk-TAFNCDUI.js +0 -234
- package/dist/chunk-TFIDSENE.cjs +0 -88
- package/dist/chunk-TGWMOHAO.js +0 -17
- package/dist/chunk-UA6XSTW6.js +0 -48
- package/dist/chunk-UIQCTAVM.cjs +0 -59
- package/dist/chunk-UKYESVDS.cjs +0 -50
- package/dist/chunk-V4N255NL.cjs +0 -2309
- package/dist/chunk-VO6KXO2I.js +0 -32
- package/dist/chunk-WXSTSC3D.cjs +0 -83
- package/dist/chunk-XSK7BWYO.js +0 -47
- package/dist/chunk-XVAPJ4PP.cjs +0 -449
- package/dist/chunk-XVASHRCE.cjs +0 -70
- package/dist/chunk-XYSMVQQD.cjs +0 -1608
- package/dist/chunk-YAIWI4Z5.js +0 -7
- package/dist/chunk-YGYOLDKR.js +0 -280
- package/dist/chunk-YP2PLNOF.cjs +0 -34
- package/dist/chunk-YSOLW4FS.cjs +0 -11
- package/dist/chunk-YY6OUR2U.js +0 -44
- package/dist/chunk-YZWS7FDT.cjs +0 -409
- package/dist/chunk-Z5YGWL65.cjs +0 -39
- package/dist/chunk-ZHNDXNL4.js +0 -45
- package/dist/chunk-ZX3EDZ5C.cjs +0 -17
- package/dist/index.d.cts +0 -2019
package/dist/chunk-4ZCRYHL6.js
DELETED
|
@@ -1,407 +0,0 @@
|
|
|
1
|
-
import { useScrollback, useShell, useTerminalStore } from './chunk-NVEGEK3N.js';
|
|
2
|
-
import { getRuntime } from './chunk-FRHBM2U7.js';
|
|
3
|
-
import { Center, Stack, Text } from './chunk-BQL3YXMV.js';
|
|
4
|
-
import { useRef, useState, useEffect, useCallback } from 'react';
|
|
5
|
-
import { Terminal } from '@xterm/xterm';
|
|
6
|
-
import { FitAddon } from '@xterm/addon-fit';
|
|
7
|
-
import { ClipboardAddon } from '@xterm/addon-clipboard';
|
|
8
|
-
import '@xterm/xterm/css/xterm.css';
|
|
9
|
-
import { jsx, jsxs } from 'react/jsx-runtime';
|
|
10
|
-
import { FcInfo } from 'react-icons/fc';
|
|
11
|
-
import { useTranslation } from 'react-i18next';
|
|
12
|
-
|
|
13
|
-
// src/components/Apps/TerminalApp/Terminal.module.css
|
|
14
|
-
var Terminal_default = {};
|
|
15
|
-
var MAX_RETRIES = 5;
|
|
16
|
-
var BASE_RETRY_DELAY_MS = 1e3;
|
|
17
|
-
var XTermTerminal = ({
|
|
18
|
-
shell,
|
|
19
|
-
scrollback,
|
|
20
|
-
onTerminalReady,
|
|
21
|
-
onConnectionChange
|
|
22
|
-
}) => {
|
|
23
|
-
const containerRef = useRef(null);
|
|
24
|
-
const terminalRef = useRef(null);
|
|
25
|
-
const fitAddonRef = useRef(null);
|
|
26
|
-
const clipboardAddonRef = useRef(null);
|
|
27
|
-
const wsRef = useRef(null);
|
|
28
|
-
const retryCountRef = useRef(0);
|
|
29
|
-
const mountedRef = useRef(false);
|
|
30
|
-
const connectingRef = useRef(false);
|
|
31
|
-
const shellRef = useRef(shell);
|
|
32
|
-
const abortControllerRef = useRef(null);
|
|
33
|
-
const initializedRef = useRef(false);
|
|
34
|
-
const [status, setStatus] = useState("idle");
|
|
35
|
-
const [canReconnect, setCanReconnect] = useState(false);
|
|
36
|
-
const onTerminalReadyRef = useRef(onTerminalReady);
|
|
37
|
-
const onConnectionChangeRef = useRef(onConnectionChange);
|
|
38
|
-
useEffect(() => {
|
|
39
|
-
onTerminalReadyRef.current = onTerminalReady;
|
|
40
|
-
}, [onTerminalReady]);
|
|
41
|
-
useEffect(() => {
|
|
42
|
-
onConnectionChangeRef.current = onConnectionChange;
|
|
43
|
-
}, [onConnectionChange]);
|
|
44
|
-
useEffect(() => {
|
|
45
|
-
shellRef.current = shell;
|
|
46
|
-
}, [shell]);
|
|
47
|
-
const updateStatus = useCallback((newStatus) => {
|
|
48
|
-
if (!mountedRef.current) return;
|
|
49
|
-
setStatus(newStatus);
|
|
50
|
-
onConnectionChangeRef.current?.(newStatus);
|
|
51
|
-
}, []);
|
|
52
|
-
const disconnect = useCallback(() => {
|
|
53
|
-
abortControllerRef.current?.abort();
|
|
54
|
-
abortControllerRef.current = null;
|
|
55
|
-
const ws = wsRef.current;
|
|
56
|
-
if (ws) {
|
|
57
|
-
wsRef.current = null;
|
|
58
|
-
if (ws.readyState === WebSocket.OPEN || ws.readyState === WebSocket.CONNECTING) {
|
|
59
|
-
try {
|
|
60
|
-
ws.send(JSON.stringify({ type: "kill" }));
|
|
61
|
-
} catch {
|
|
62
|
-
}
|
|
63
|
-
ws.close();
|
|
64
|
-
}
|
|
65
|
-
}
|
|
66
|
-
connectingRef.current = false;
|
|
67
|
-
}, []);
|
|
68
|
-
const connect = useCallback(() => {
|
|
69
|
-
if (!mountedRef.current) return;
|
|
70
|
-
if (connectingRef.current) return;
|
|
71
|
-
if (wsRef.current?.readyState === WebSocket.OPEN) return;
|
|
72
|
-
connectingRef.current = true;
|
|
73
|
-
const abortController = new AbortController();
|
|
74
|
-
abortControllerRef.current = abortController;
|
|
75
|
-
const protocol = window.location.protocol === "https:" ? "wss:" : "ws:";
|
|
76
|
-
const wsUrl = `${protocol}//${window.location.host}/api/pty`;
|
|
77
|
-
console.log(`[XTermTerminal] Connecting (attempt ${retryCountRef.current + 1}/${MAX_RETRIES})`);
|
|
78
|
-
updateStatus("connecting");
|
|
79
|
-
const ws = new WebSocket(wsUrl);
|
|
80
|
-
wsRef.current = ws;
|
|
81
|
-
ws.onopen = () => {
|
|
82
|
-
if (!mountedRef.current) return;
|
|
83
|
-
console.log("[XTermTerminal] WebSocket opened");
|
|
84
|
-
};
|
|
85
|
-
ws.onmessage = (event) => {
|
|
86
|
-
if (!mountedRef.current) return;
|
|
87
|
-
if (typeof event.data !== "string") return;
|
|
88
|
-
try {
|
|
89
|
-
const data = JSON.parse(event.data);
|
|
90
|
-
switch (data.type) {
|
|
91
|
-
case "ready":
|
|
92
|
-
console.log("[XTermTerminal] Server ready, sending start");
|
|
93
|
-
ws.send(
|
|
94
|
-
JSON.stringify({
|
|
95
|
-
type: "start",
|
|
96
|
-
shell: shellRef.current,
|
|
97
|
-
cwd: "/app/workspace",
|
|
98
|
-
cols: terminalRef.current?.cols || 80,
|
|
99
|
-
rows: terminalRef.current?.rows || 24
|
|
100
|
-
})
|
|
101
|
-
);
|
|
102
|
-
break;
|
|
103
|
-
case "started":
|
|
104
|
-
console.log("[XTermTerminal] PTY started");
|
|
105
|
-
retryCountRef.current = 0;
|
|
106
|
-
connectingRef.current = false;
|
|
107
|
-
setCanReconnect(false);
|
|
108
|
-
updateStatus("connected");
|
|
109
|
-
break;
|
|
110
|
-
case "exit":
|
|
111
|
-
console.log("[XTermTerminal] PTY exited:", data.code);
|
|
112
|
-
wsRef.current = null;
|
|
113
|
-
connectingRef.current = false;
|
|
114
|
-
updateStatus("disconnected");
|
|
115
|
-
setCanReconnect(true);
|
|
116
|
-
break;
|
|
117
|
-
case "error":
|
|
118
|
-
console.error("[XTermTerminal] Server error:", data.message);
|
|
119
|
-
connectingRef.current = false;
|
|
120
|
-
updateStatus("error");
|
|
121
|
-
setCanReconnect(true);
|
|
122
|
-
break;
|
|
123
|
-
}
|
|
124
|
-
} catch {
|
|
125
|
-
if (terminalRef.current) {
|
|
126
|
-
terminalRef.current.write(event.data);
|
|
127
|
-
}
|
|
128
|
-
}
|
|
129
|
-
};
|
|
130
|
-
ws.onclose = () => {
|
|
131
|
-
if (!mountedRef.current || abortController.signal.aborted) return;
|
|
132
|
-
console.log("[XTermTerminal] WebSocket closed");
|
|
133
|
-
wsRef.current = null;
|
|
134
|
-
connectingRef.current = false;
|
|
135
|
-
if (retryCountRef.current < MAX_RETRIES) {
|
|
136
|
-
retryCountRef.current++;
|
|
137
|
-
const delay = BASE_RETRY_DELAY_MS * Math.pow(2, retryCountRef.current - 1);
|
|
138
|
-
console.log(`[XTermTerminal] Retrying in ${delay}ms`);
|
|
139
|
-
setTimeout(() => {
|
|
140
|
-
if (mountedRef.current && !wsRef.current && !abortController.signal.aborted) {
|
|
141
|
-
connect();
|
|
142
|
-
}
|
|
143
|
-
}, delay);
|
|
144
|
-
} else {
|
|
145
|
-
updateStatus("disconnected");
|
|
146
|
-
setCanReconnect(true);
|
|
147
|
-
}
|
|
148
|
-
};
|
|
149
|
-
ws.onerror = () => {
|
|
150
|
-
if (!mountedRef.current) return;
|
|
151
|
-
console.error("[XTermTerminal] WebSocket error");
|
|
152
|
-
connectingRef.current = false;
|
|
153
|
-
ws.close();
|
|
154
|
-
updateStatus("error");
|
|
155
|
-
setCanReconnect(true);
|
|
156
|
-
};
|
|
157
|
-
}, [updateStatus]);
|
|
158
|
-
useEffect(() => {
|
|
159
|
-
if (initializedRef.current) return void 0;
|
|
160
|
-
initializedRef.current = true;
|
|
161
|
-
mountedRef.current = true;
|
|
162
|
-
if (!containerRef.current) return void 0;
|
|
163
|
-
const terminal = new Terminal({
|
|
164
|
-
fontFamily: "'Operator Mono', 'SFMono-Regular', Consolas, 'Liberation Mono', Menlo, monospace",
|
|
165
|
-
fontSize: 14,
|
|
166
|
-
theme: {
|
|
167
|
-
background: "#1e1e1e",
|
|
168
|
-
foreground: "#d4d4d4",
|
|
169
|
-
cursor: "#ffffff",
|
|
170
|
-
selectionBackground: "#264f78"
|
|
171
|
-
},
|
|
172
|
-
cursorStyle: "underline",
|
|
173
|
-
cursorBlink: true,
|
|
174
|
-
scrollback
|
|
175
|
-
});
|
|
176
|
-
const fitAddon = new FitAddon();
|
|
177
|
-
const clipboardAddon = new ClipboardAddon();
|
|
178
|
-
terminal.loadAddon(fitAddon);
|
|
179
|
-
terminal.loadAddon(clipboardAddon);
|
|
180
|
-
terminal.open(containerRef.current);
|
|
181
|
-
fitAddon.fit();
|
|
182
|
-
terminalRef.current = terminal;
|
|
183
|
-
fitAddonRef.current = fitAddon;
|
|
184
|
-
clipboardAddonRef.current = clipboardAddon;
|
|
185
|
-
terminal.onData((data) => {
|
|
186
|
-
if (wsRef.current?.readyState === WebSocket.OPEN) {
|
|
187
|
-
wsRef.current.send(JSON.stringify({ type: "input", data }));
|
|
188
|
-
}
|
|
189
|
-
});
|
|
190
|
-
terminal.onResize(({ cols, rows }) => {
|
|
191
|
-
if (wsRef.current?.readyState === WebSocket.OPEN) {
|
|
192
|
-
wsRef.current.send(JSON.stringify({ type: "resize", cols, rows }));
|
|
193
|
-
}
|
|
194
|
-
});
|
|
195
|
-
onTerminalReadyRef.current?.({
|
|
196
|
-
clear: () => terminal.clear(),
|
|
197
|
-
reset: () => terminal.reset(),
|
|
198
|
-
write: (data) => terminal.write(data),
|
|
199
|
-
copy: async () => {
|
|
200
|
-
const selection = terminal.getSelection();
|
|
201
|
-
console.log("[XTermTerminal] Copy called, selection length:", selection?.length ?? 0);
|
|
202
|
-
if (!selection) {
|
|
203
|
-
console.log("[XTermTerminal] No selection to copy");
|
|
204
|
-
return;
|
|
205
|
-
}
|
|
206
|
-
try {
|
|
207
|
-
if (!navigator.clipboard) {
|
|
208
|
-
console.warn("[XTermTerminal] Clipboard API not available (non-secure context?)");
|
|
209
|
-
fallbackCopy(selection);
|
|
210
|
-
return;
|
|
211
|
-
}
|
|
212
|
-
await navigator.clipboard.writeText(selection);
|
|
213
|
-
console.log("[XTermTerminal] Copied to clipboard successfully");
|
|
214
|
-
} catch (err) {
|
|
215
|
-
console.error("[XTermTerminal] Clipboard write failed:", err);
|
|
216
|
-
fallbackCopy(selection);
|
|
217
|
-
}
|
|
218
|
-
},
|
|
219
|
-
paste: async () => {
|
|
220
|
-
console.log("[XTermTerminal] Paste called");
|
|
221
|
-
try {
|
|
222
|
-
if (!navigator.clipboard) {
|
|
223
|
-
console.warn("[XTermTerminal] Clipboard API not available");
|
|
224
|
-
return;
|
|
225
|
-
}
|
|
226
|
-
const text = await navigator.clipboard.readText();
|
|
227
|
-
console.log("[XTermTerminal] Paste text length:", text.length);
|
|
228
|
-
terminal.paste(text);
|
|
229
|
-
} catch (err) {
|
|
230
|
-
console.error("[XTermTerminal] Paste failed:", err);
|
|
231
|
-
}
|
|
232
|
-
},
|
|
233
|
-
reconnect
|
|
234
|
-
});
|
|
235
|
-
requestAnimationFrame(() => {
|
|
236
|
-
if (mountedRef.current) {
|
|
237
|
-
connect();
|
|
238
|
-
}
|
|
239
|
-
});
|
|
240
|
-
return () => {
|
|
241
|
-
console.log("[XTermTerminal] Cleanup");
|
|
242
|
-
mountedRef.current = false;
|
|
243
|
-
abortControllerRef.current?.abort();
|
|
244
|
-
abortControllerRef.current = null;
|
|
245
|
-
if (terminalRef.current) {
|
|
246
|
-
terminalRef.current.clear();
|
|
247
|
-
}
|
|
248
|
-
disconnect();
|
|
249
|
-
terminal.dispose();
|
|
250
|
-
terminalRef.current = null;
|
|
251
|
-
fitAddonRef.current = null;
|
|
252
|
-
};
|
|
253
|
-
}, []);
|
|
254
|
-
const reconnect = useCallback(() => {
|
|
255
|
-
console.log("[XTermTerminal] Reconnect triggered");
|
|
256
|
-
retryCountRef.current = 0;
|
|
257
|
-
setCanReconnect(false);
|
|
258
|
-
disconnect();
|
|
259
|
-
setTimeout(() => connect(), 100);
|
|
260
|
-
}, [disconnect, connect]);
|
|
261
|
-
useEffect(() => {
|
|
262
|
-
if (terminalRef.current) {
|
|
263
|
-
terminalRef.current.options.scrollback = scrollback;
|
|
264
|
-
}
|
|
265
|
-
}, [scrollback]);
|
|
266
|
-
useEffect(() => {
|
|
267
|
-
if (!containerRef.current) return void 0;
|
|
268
|
-
const observer = new ResizeObserver(() => {
|
|
269
|
-
fitAddonRef.current?.fit();
|
|
270
|
-
});
|
|
271
|
-
observer.observe(containerRef.current);
|
|
272
|
-
return () => observer.disconnect();
|
|
273
|
-
}, []);
|
|
274
|
-
return /* @__PURE__ */ jsxs("div", { className: Terminal_default.terminalContainer, children: [
|
|
275
|
-
/* @__PURE__ */ jsx("div", { className: Terminal_default.terminalWrapper, children: /* @__PURE__ */ jsx("div", { ref: containerRef, className: Terminal_default.terminal, "data-testid": "xterm-terminal" }) }),
|
|
276
|
-
/* @__PURE__ */ jsxs("div", { className: Terminal_default.statusBar, children: [
|
|
277
|
-
/* @__PURE__ */ jsxs("span", { className: Terminal_default.statusIndicator, "data-status": status, children: [
|
|
278
|
-
status === "idle" && "\u25CB",
|
|
279
|
-
status === "connecting" && "\u25CF",
|
|
280
|
-
status === "connected" && "\u25CF",
|
|
281
|
-
status === "disconnected" && "\u25CB",
|
|
282
|
-
status === "error" && "\u25CF"
|
|
283
|
-
] }),
|
|
284
|
-
/* @__PURE__ */ jsxs("span", { className: Terminal_default.statusText, children: [
|
|
285
|
-
status === "idle" && "Idle",
|
|
286
|
-
status === "connecting" && "Connecting...",
|
|
287
|
-
status === "connected" && "Connected",
|
|
288
|
-
status === "disconnected" && "Disconnected",
|
|
289
|
-
status === "error" && "Error"
|
|
290
|
-
] }),
|
|
291
|
-
canReconnect && /* @__PURE__ */ jsx("button", { onClick: reconnect, className: Terminal_default.reconnectButton, children: "Reconnect" })
|
|
292
|
-
] })
|
|
293
|
-
] });
|
|
294
|
-
};
|
|
295
|
-
function fallbackCopy(text) {
|
|
296
|
-
const textarea = document.createElement("textarea");
|
|
297
|
-
textarea.value = text;
|
|
298
|
-
textarea.style.position = "fixed";
|
|
299
|
-
textarea.style.left = "-9999px";
|
|
300
|
-
textarea.style.opacity = "0";
|
|
301
|
-
document.body.appendChild(textarea);
|
|
302
|
-
textarea.select();
|
|
303
|
-
textarea.setSelectionRange(0, text.length);
|
|
304
|
-
try {
|
|
305
|
-
const success = document.execCommand("copy");
|
|
306
|
-
console.log("[XTermTerminal] Fallback copy result:", success ? "success" : "failed");
|
|
307
|
-
} catch (err) {
|
|
308
|
-
console.error("[XTermTerminal] Fallback copy failed:", err);
|
|
309
|
-
} finally {
|
|
310
|
-
document.body.removeChild(textarea);
|
|
311
|
-
}
|
|
312
|
-
}
|
|
313
|
-
var XTermTerminal_default = XTermTerminal;
|
|
314
|
-
var TerminalNotSupported = () => {
|
|
315
|
-
const { t } = useTranslation("apps");
|
|
316
|
-
return /* @__PURE__ */ jsx(Center, { "data-testid": "terminal-not-supported", style: { width: "100%", height: "100%" }, children: /* @__PURE__ */ jsxs(Stack, { align: "center", gap: "lg", p: "xl", maw: 400, children: [
|
|
317
|
-
/* @__PURE__ */ jsx(Text, { size: "3rem", children: /* @__PURE__ */ jsx(FcInfo, {}) }),
|
|
318
|
-
/* @__PURE__ */ jsx(Text, { size: "lg", fw: 700, ta: "center", children: t("terminal.notAvailable") }),
|
|
319
|
-
/* @__PURE__ */ jsx(Text, { size: "sm", c: "dimmed", ta: "center", children: t("terminal.notAvailableMessage") }),
|
|
320
|
-
/* @__PURE__ */ jsx(Text, { size: "sm", c: "dimmed", ta: "center", children: t("terminal.dockerRequired") })
|
|
321
|
-
] }) });
|
|
322
|
-
};
|
|
323
|
-
var TerminalNotSupported_default = TerminalNotSupported;
|
|
324
|
-
var TerminalApp = ({ window: window2, notifyReady }) => {
|
|
325
|
-
const win = window2;
|
|
326
|
-
const windowId = win?.id ?? "";
|
|
327
|
-
const runtime = getRuntime();
|
|
328
|
-
const scrollback = useScrollback(windowId);
|
|
329
|
-
const storedShell = useShell(windowId);
|
|
330
|
-
const { setScrollback, setShell, reset } = useTerminalStore();
|
|
331
|
-
const terminalActionsRef = useRef(null);
|
|
332
|
-
const hasNotifiedRef = useRef(false);
|
|
333
|
-
const hasFetchedShellRef = useRef(false);
|
|
334
|
-
const [connectionStatus, setConnectionStatus] = useState("idle");
|
|
335
|
-
const [shellInfo, setShellInfo] = useState(null);
|
|
336
|
-
useEffect(() => {
|
|
337
|
-
if (runtime !== "docker" || hasFetchedShellRef.current) return;
|
|
338
|
-
hasFetchedShellRef.current = true;
|
|
339
|
-
const fetchShellInfo = async () => {
|
|
340
|
-
try {
|
|
341
|
-
const response = await fetch("/api/shell");
|
|
342
|
-
if (response.ok) {
|
|
343
|
-
const info = await response.json();
|
|
344
|
-
setShellInfo(info);
|
|
345
|
-
if (!storedShell || storedShell === "/bin/zsh") {
|
|
346
|
-
setShell(windowId, info.default);
|
|
347
|
-
}
|
|
348
|
-
}
|
|
349
|
-
} catch (err) {
|
|
350
|
-
console.error("[TerminalApp] Failed to fetch shell info:", err);
|
|
351
|
-
if (!storedShell) {
|
|
352
|
-
setShell(windowId, "/bin/zsh");
|
|
353
|
-
}
|
|
354
|
-
}
|
|
355
|
-
};
|
|
356
|
-
fetchShellInfo();
|
|
357
|
-
}, [runtime, storedShell, setShell, windowId]);
|
|
358
|
-
useEffect(() => {
|
|
359
|
-
reset(windowId);
|
|
360
|
-
}, [windowId, reset]);
|
|
361
|
-
const handleTerminalReady = useCallback((actions) => {
|
|
362
|
-
terminalActionsRef.current = actions;
|
|
363
|
-
}, []);
|
|
364
|
-
const handleConnectionChange = useCallback((status) => {
|
|
365
|
-
setConnectionStatus(status);
|
|
366
|
-
}, []);
|
|
367
|
-
useEffect(() => {
|
|
368
|
-
if (!hasNotifiedRef.current && notifyReady) {
|
|
369
|
-
hasNotifiedRef.current = true;
|
|
370
|
-
notifyReady({
|
|
371
|
-
...win?.contentData ?? {},
|
|
372
|
-
clear: () => terminalActionsRef.current?.clear(),
|
|
373
|
-
reset: () => terminalActionsRef.current?.reset(),
|
|
374
|
-
copy: () => terminalActionsRef.current?.copy(),
|
|
375
|
-
paste: () => terminalActionsRef.current?.paste(),
|
|
376
|
-
reconnect: () => terminalActionsRef.current?.reconnect(),
|
|
377
|
-
setScrollback: (value) => setScrollback(windowId, value),
|
|
378
|
-
setShell: (value) => setShell(windowId, value),
|
|
379
|
-
connectionStatus
|
|
380
|
-
});
|
|
381
|
-
}
|
|
382
|
-
}, [notifyReady, setScrollback, setShell, windowId, win?.contentData, connectionStatus]);
|
|
383
|
-
useEffect(() => {
|
|
384
|
-
if (hasNotifiedRef.current && notifyReady) {
|
|
385
|
-
notifyReady({
|
|
386
|
-
...win?.contentData ?? {},
|
|
387
|
-
connectionStatus
|
|
388
|
-
});
|
|
389
|
-
}
|
|
390
|
-
}, [connectionStatus, notifyReady, win?.contentData]);
|
|
391
|
-
if (runtime !== "docker") {
|
|
392
|
-
return /* @__PURE__ */ jsx(TerminalNotSupported_default, {});
|
|
393
|
-
}
|
|
394
|
-
const activeShell = storedShell || shellInfo?.default || "/bin/zsh";
|
|
395
|
-
return /* @__PURE__ */ jsx(
|
|
396
|
-
XTermTerminal_default,
|
|
397
|
-
{
|
|
398
|
-
shell: activeShell,
|
|
399
|
-
scrollback,
|
|
400
|
-
onTerminalReady: handleTerminalReady,
|
|
401
|
-
onConnectionChange: handleConnectionChange
|
|
402
|
-
}
|
|
403
|
-
);
|
|
404
|
-
};
|
|
405
|
-
var TerminalApp_default = TerminalApp;
|
|
406
|
-
|
|
407
|
-
export { TerminalApp_default };
|
package/dist/chunk-5C6IQE42.cjs
DELETED
|
@@ -1,35 +0,0 @@
|
|
|
1
|
-
'use strict';
|
|
2
|
-
|
|
3
|
-
var zustand = require('zustand');
|
|
4
|
-
|
|
5
|
-
// src/components/Apps/TerminalApp/terminalStore.ts
|
|
6
|
-
var DEFAULT_STATE = {
|
|
7
|
-
scrollback: 5e3,
|
|
8
|
-
shell: "/bin/zsh"
|
|
9
|
-
};
|
|
10
|
-
var useTerminalStore = zustand.create((set, get) => ({
|
|
11
|
-
states: {},
|
|
12
|
-
getScrollback: (id) => get().states[id]?.scrollback ?? DEFAULT_STATE.scrollback,
|
|
13
|
-
getShell: (id) => get().states[id]?.shell ?? DEFAULT_STATE.shell,
|
|
14
|
-
setScrollback: (id, scrollback) => set((s) => ({
|
|
15
|
-
states: {
|
|
16
|
-
...s.states,
|
|
17
|
-
[id]: { ...s.states[id] ?? DEFAULT_STATE, scrollback }
|
|
18
|
-
}
|
|
19
|
-
})),
|
|
20
|
-
setShell: (id, shell) => set((s) => ({
|
|
21
|
-
states: {
|
|
22
|
-
...s.states,
|
|
23
|
-
[id]: { ...s.states[id] ?? DEFAULT_STATE, shell }
|
|
24
|
-
}
|
|
25
|
-
})),
|
|
26
|
-
reset: (id) => set((s) => ({
|
|
27
|
-
states: { ...s.states, [id]: { ...DEFAULT_STATE } }
|
|
28
|
-
}))
|
|
29
|
-
}));
|
|
30
|
-
var useScrollback = (windowId) => useTerminalStore((s) => s.states[windowId]?.scrollback ?? DEFAULT_STATE.scrollback);
|
|
31
|
-
var useShell = (windowId) => useTerminalStore((s) => s.states[windowId]?.shell ?? DEFAULT_STATE.shell);
|
|
32
|
-
|
|
33
|
-
exports.useScrollback = useScrollback;
|
|
34
|
-
exports.useShell = useShell;
|
|
35
|
-
exports.useTerminalStore = useTerminalStore;
|
package/dist/chunk-5HUYQDQF.js
DELETED
|
@@ -1,36 +0,0 @@
|
|
|
1
|
-
import { BREAKPOINTS } from './chunk-5QFZW6HW.js';
|
|
2
|
-
import { useState, useCallback, useEffect } from 'react';
|
|
3
|
-
|
|
4
|
-
var DIMENSIONS = {
|
|
5
|
-
mobile: { defaultWidth: 300, defaultHeight: 500, minWidth: 280, minHeight: 400 },
|
|
6
|
-
tablet: { defaultWidth: 600, defaultHeight: 450, minWidth: 400, minHeight: 350 },
|
|
7
|
-
desktop: { defaultWidth: 800, defaultHeight: 600, minWidth: 640, minHeight: 480 },
|
|
8
|
-
largeDesktop: { defaultWidth: 1e3, defaultHeight: 700, minWidth: 800, minHeight: 600 }
|
|
9
|
-
};
|
|
10
|
-
var LARGE_DESKTOP = 1440;
|
|
11
|
-
var getAdaptiveDimensions = () => {
|
|
12
|
-
const width = window.innerWidth;
|
|
13
|
-
if (width < BREAKPOINTS.MOBILE) {
|
|
14
|
-
return DIMENSIONS.mobile;
|
|
15
|
-
}
|
|
16
|
-
if (width < BREAKPOINTS.TABLET) {
|
|
17
|
-
return DIMENSIONS.tablet;
|
|
18
|
-
}
|
|
19
|
-
if (width < LARGE_DESKTOP) {
|
|
20
|
-
return DIMENSIONS.desktop;
|
|
21
|
-
}
|
|
22
|
-
return DIMENSIONS.largeDesktop;
|
|
23
|
-
};
|
|
24
|
-
function useAdaptiveDimensions() {
|
|
25
|
-
const [dimensions, setDimensions] = useState(() => getAdaptiveDimensions());
|
|
26
|
-
const updateDimensions = useCallback(() => {
|
|
27
|
-
setDimensions(getAdaptiveDimensions());
|
|
28
|
-
}, []);
|
|
29
|
-
useEffect(() => {
|
|
30
|
-
window.addEventListener("resize", updateDimensions);
|
|
31
|
-
return () => window.removeEventListener("resize", updateDimensions);
|
|
32
|
-
}, [updateDimensions]);
|
|
33
|
-
return dimensions;
|
|
34
|
-
}
|
|
35
|
-
|
|
36
|
-
export { useAdaptiveDimensions };
|
package/dist/chunk-5NOHYJNH.js
DELETED
|
@@ -1,84 +0,0 @@
|
|
|
1
|
-
import { AppMenuBar_default } from './chunk-4E45FBAH.js';
|
|
2
|
-
import { useDisplayZoom, useFitToWindow, useImageViewerStore } from './chunk-DWP2SYF7.js';
|
|
3
|
-
import { memo, useCallback, useMemo } from 'react';
|
|
4
|
-
import { useTranslation } from 'react-i18next';
|
|
5
|
-
import { jsx } from 'react/jsx-runtime';
|
|
6
|
-
|
|
7
|
-
var ZOOM_MARKS = [
|
|
8
|
-
{ value: 25, label: "25%" },
|
|
9
|
-
{ value: 50, label: "50%" },
|
|
10
|
-
{ value: 75, label: "75%" },
|
|
11
|
-
{ value: 100, label: "100%" },
|
|
12
|
-
{ value: 200, label: "200%" }
|
|
13
|
-
];
|
|
14
|
-
var useImageViewerMenuBarElements = (options) => {
|
|
15
|
-
const { windowId, onOpenPicker, onExit } = options;
|
|
16
|
-
const { t } = useTranslation("common");
|
|
17
|
-
const { t: tApps } = useTranslation("apps");
|
|
18
|
-
const displayZoom = useDisplayZoom(windowId);
|
|
19
|
-
const fitToWindow = useFitToWindow(windowId);
|
|
20
|
-
const setUserZoom = useImageViewerStore((s) => s.setUserZoom);
|
|
21
|
-
const setFitToWindow = useImageViewerStore((s) => s.setFitToWindow);
|
|
22
|
-
const handleFitChange = useCallback(
|
|
23
|
-
(checked) => setFitToWindow(windowId, checked),
|
|
24
|
-
[windowId, setFitToWindow]
|
|
25
|
-
);
|
|
26
|
-
const handleZoomChange = useCallback(
|
|
27
|
-
(value) => setUserZoom(windowId, value),
|
|
28
|
-
[windowId, setUserZoom]
|
|
29
|
-
);
|
|
30
|
-
return useMemo(() => {
|
|
31
|
-
const zoomLabel = `${tApps("imageViewer.zoom")}: ${displayZoom}%`;
|
|
32
|
-
return [
|
|
33
|
-
{
|
|
34
|
-
type: "menu",
|
|
35
|
-
label: t("menu.file"),
|
|
36
|
-
items: [
|
|
37
|
-
{
|
|
38
|
-
type: "item",
|
|
39
|
-
label: t("actions.open"),
|
|
40
|
-
icon: "FcOpenedFolder",
|
|
41
|
-
onClick: onOpenPicker ?? (() => {
|
|
42
|
-
})
|
|
43
|
-
},
|
|
44
|
-
{ type: "divider" },
|
|
45
|
-
{
|
|
46
|
-
type: "item",
|
|
47
|
-
label: t("actions.exit"),
|
|
48
|
-
icon: "FcLeft",
|
|
49
|
-
onClick: onExit
|
|
50
|
-
}
|
|
51
|
-
]
|
|
52
|
-
},
|
|
53
|
-
{
|
|
54
|
-
type: "switch",
|
|
55
|
-
label: tApps("imageViewer.fitToWindow"),
|
|
56
|
-
checked: fitToWindow,
|
|
57
|
-
onChange: handleFitChange
|
|
58
|
-
},
|
|
59
|
-
{
|
|
60
|
-
type: "slider",
|
|
61
|
-
label: zoomLabel,
|
|
62
|
-
min: 10,
|
|
63
|
-
max: 200,
|
|
64
|
-
value: displayZoom,
|
|
65
|
-
onChange: handleZoomChange,
|
|
66
|
-
marks: ZOOM_MARKS,
|
|
67
|
-
labelFormat: (value) => `${value}%`
|
|
68
|
-
}
|
|
69
|
-
];
|
|
70
|
-
}, [t, tApps, onOpenPicker, onExit, displayZoom, fitToWindow, handleFitChange, handleZoomChange]);
|
|
71
|
-
};
|
|
72
|
-
var ImageViewerMenuBar = memo(
|
|
73
|
-
({ windowId, contentData, onExit }) => {
|
|
74
|
-
const elements = useImageViewerMenuBarElements({
|
|
75
|
-
windowId,
|
|
76
|
-
onOpenPicker: contentData?.setPickerOpen,
|
|
77
|
-
onExit
|
|
78
|
-
});
|
|
79
|
-
return /* @__PURE__ */ jsx(AppMenuBar_default, { elements });
|
|
80
|
-
}
|
|
81
|
-
);
|
|
82
|
-
ImageViewerMenuBar.displayName = "ImageViewerMenuBar";
|
|
83
|
-
|
|
84
|
-
export { ImageViewerMenuBar };
|