mirror of
https://github.com/wavetermdev/waveterm.git
synced 2025-01-21 21:32:13 +01:00
33f05c6e0c
Going forward for new installations, config and data files will be stored at the platform default paths, as defined by [env-paths](https://www.npmjs.com/package/env-paths). For backwards compatibility, if the `~/.waveterm` or `WAVETERM_HOME` directory exists and contains valid data, it will be used. If this check fails, then `WAVETERM_DATA_HOME` and `WAVETERM_CONFIG_HOME` will be used. If these are not defined, then `XDG_DATA_HOME` and `XDG_CONFIG_HOME` will be used. Finally, if none of these are defined, the [env-paths](https://www.npmjs.com/package/env-paths) defaults will be used. As with the existing app, dev instances will write to `waveterm-dev` directories, while all others will write to `waveterm`.
63 lines
3.6 KiB
TypeScript
63 lines
3.6 KiB
TypeScript
// Copyright 2024, Command Line Inc.
|
|
// SPDX-License-Identifier: Apache-2.0
|
|
|
|
import { contextBridge, ipcRenderer, WebviewTag } from "electron";
|
|
|
|
contextBridge.exposeInMainWorld("api", {
|
|
getAuthKey: () => ipcRenderer.sendSync("get-auth-key"),
|
|
getIsDev: () => ipcRenderer.sendSync("get-is-dev"),
|
|
getPlatform: () => ipcRenderer.sendSync("get-platform"),
|
|
getCursorPoint: () => ipcRenderer.sendSync("get-cursor-point"),
|
|
getUserName: () => ipcRenderer.sendSync("get-user-name"),
|
|
getHostName: () => ipcRenderer.sendSync("get-host-name"),
|
|
getDataDir: () => ipcRenderer.sendSync("get-data-dir"),
|
|
getConfigDir: () => ipcRenderer.sendSync("get-config-dir"),
|
|
getAboutModalDetails: () => ipcRenderer.sendSync("get-about-modal-details"),
|
|
getDocsiteUrl: () => ipcRenderer.sendSync("get-docsite-url"),
|
|
getWebviewPreload: () => ipcRenderer.sendSync("get-webview-preload"),
|
|
openNewWindow: () => ipcRenderer.send("open-new-window"),
|
|
showContextMenu: (menu, position) => ipcRenderer.send("contextmenu-show", menu, position),
|
|
onContextMenuClick: (callback) => ipcRenderer.on("contextmenu-click", (_event, id) => callback(id)),
|
|
downloadFile: (filePath) => ipcRenderer.send("download", { filePath }),
|
|
openExternal: (url) => {
|
|
if (url && typeof url === "string") {
|
|
ipcRenderer.send("open-external", url);
|
|
} else {
|
|
console.error("Invalid URL passed to openExternal:", url);
|
|
}
|
|
},
|
|
getEnv: (varName) => ipcRenderer.sendSync("get-env", varName),
|
|
onFullScreenChange: (callback) =>
|
|
ipcRenderer.on("fullscreen-change", (_event, isFullScreen) => callback(isFullScreen)),
|
|
onUpdaterStatusChange: (callback) => ipcRenderer.on("app-update-status", (_event, status) => callback(status)),
|
|
getUpdaterStatus: () => ipcRenderer.sendSync("get-app-update-status"),
|
|
getUpdaterChannel: () => ipcRenderer.sendSync("get-updater-channel"),
|
|
installAppUpdate: () => ipcRenderer.send("install-app-update"),
|
|
onMenuItemAbout: (callback) => ipcRenderer.on("menu-item-about", callback),
|
|
updateWindowControlsOverlay: (rect) => ipcRenderer.send("update-window-controls-overlay", rect),
|
|
onReinjectKey: (callback) => ipcRenderer.on("reinject-key", (_event, waveEvent) => callback(waveEvent)),
|
|
setWebviewFocus: (focused: number) => ipcRenderer.send("webview-focus", focused),
|
|
registerGlobalWebviewKeys: (keys) => ipcRenderer.send("register-global-webview-keys", keys),
|
|
onControlShiftStateUpdate: (callback) =>
|
|
ipcRenderer.on("control-shift-state-update", (_event, state) => callback(state)),
|
|
setActiveTab: (tabId) => ipcRenderer.send("set-active-tab", tabId),
|
|
createTab: () => ipcRenderer.send("create-tab"),
|
|
closeTab: (tabId) => ipcRenderer.send("close-tab", tabId),
|
|
setWindowInitStatus: (status) => ipcRenderer.send("set-window-init-status", status),
|
|
onWaveInit: (callback) => ipcRenderer.on("wave-init", (_event, initOpts) => callback(initOpts)),
|
|
sendLog: (log) => ipcRenderer.send("fe-log", log),
|
|
onQuicklook: (filePath: string) => ipcRenderer.send("quicklook", filePath),
|
|
});
|
|
|
|
// Custom event for "new-window"
|
|
ipcRenderer.on("webview-new-window", (e, webContentsId, details) => {
|
|
const event = new CustomEvent("new-window", { detail: details });
|
|
document.getElementById("webview").dispatchEvent(event);
|
|
});
|
|
|
|
ipcRenderer.on("webcontentsid-from-blockid", (e, blockId, responseCh) => {
|
|
const webviewElem: WebviewTag = document.querySelector("div[data-blockid='" + blockId + "'] webview");
|
|
const wcId = webviewElem?.dataset?.webcontentsid;
|
|
ipcRenderer.send(responseCh, wcId);
|
|
});
|