// Copyright 2024, Command Line Inc. // SPDX-License-Identifier: Apache-2.0 import Logo from "@/app/asset/logo.svg"; import { Button } from "@/app/element/button"; import { Toggle } from "@/app/element/toggle"; import * as services from "@/store/services"; import { OverlayScrollbarsComponent } from "overlayscrollbars-react"; import { useEffect, useRef, useState } from "react"; import { FlexiModal } from "./modal"; import { QuickTips } from "@/app/element/quicktips"; import { atoms, getApi } from "@/app/store/global"; import { modalsModel } from "@/app/store/modalmodel"; import { fireAndForget } from "@/util/util"; import { atom, PrimitiveAtom, useAtom, useAtomValue, useSetAtom } from "jotai"; import "./tos.scss"; const pageNumAtom: PrimitiveAtom = atom(1); const ModalPage1 = () => { const settings = useAtomValue(atoms.settingsAtom); const clientData = useAtomValue(atoms.client); const [telemetryEnabled, setTelemetryEnabled] = useState(!!settings["telemetry:enabled"]); const setPageNum = useSetAtom(pageNumAtom); const acceptTos = () => { if (!clientData.tosagreed) { fireAndForget(services.ClientService.AgreeTos); } setPageNum(2); }; const setTelemetry = (value: boolean) => { fireAndForget(() => services.ClientService.TelemetryUpdate(value).then(() => { setTelemetryEnabled(value); }) ); }; const label = telemetryEnabled ? "Telemetry Enabled" : "Telemetry Disabled"; return ( <>
Welcome to Wave Terminal
Support us on GitHub
We're open source and committed to providing a free terminal for individual users. Please show your support by giving us a star on{" "} Github (wavetermdev/waveterm)
Join our Community
Get help, submit feature requests, report bugs, or just chat with fellow terminal enthusiasts.
Join the Wave Discord Channel
Telemetry
We collect minimal anonymous{" "} telemetry data {" "} to help us understand how people are using Wave ( Privacy Policy ).
); }; const ModalPage2 = () => { const [tosOpen, setTosOpen] = useAtom(modalsModel.tosOpen); const handleGetStarted = () => { setTosOpen(false); }; return ( <>
Icons and Keybindings
); }; const ModalPageLegacy = () => { const setPageNum = useSetAtom(pageNumAtom); const handleContinue = () => { setPageNum(1); }; const handleDownloadLegacy = () => { getApi().openExternal("https://waveterm.dev/download-legacy?ref=v7upgrade"); }; return ( <>
Welcome to Wave v0.9
We’re excited to announce the release of Wave Terminal v0.9. This update introduces a brand-new layout engine, featuring drag-and-drop screen splitting with flexible block sizing and positioning. We've also integrated powerful tools like file previews, an editor, web integration, and AI, all designed to keep you focused and minimize context switching. And for the first time, Wave Terminal runs natively on Windows!
Wave v0.9 is less opinionated, giving you the freedom to use your standard terminal prompt and command completions, while supporting all shells (not just bash/zsh). We've also improved compatibility with ohmyzsh packages, removing some of the friction users experienced. It’s faster, more performant, and provides a stronger foundation for you to build your own blocks and widgets in the future.
The new build is a fresh start, and a clean break from the current version. As such, your history, settings, and configuration will not be carried over. If you'd like to continue to run the legacy version, you will need to download it separately.
); }; const TosModal = () => { const modalRef = useRef(null); const [pageNum, setPageNum] = useAtom(pageNumAtom); const clientData = useAtomValue(atoms.client); const updateModalHeight = () => { const windowHeight = window.innerHeight; if (modalRef.current) { const modalHeight = modalRef.current.offsetHeight; const maxHeight = windowHeight * 0.9; if (maxHeight < modalHeight) { modalRef.current.style.height = `${maxHeight}px`; } else { modalRef.current.style.height = "auto"; } } }; useEffect(() => { // on unmount, always reset pagenum if (!clientData.tosagreed && clientData.hasoldhistory) { setPageNum(0); } else if (clientData.tosagreed) { setPageNum(2); } return () => { setPageNum(1); }; }, []); useEffect(() => { updateModalHeight(); // Run on initial render window.addEventListener("resize", updateModalHeight); // Run on window resize return () => { window.removeEventListener("resize", updateModalHeight); }; }, []); let pageComp: React.JSX.Element = null; switch (pageNum) { case 0: pageComp = ; break; case 1: pageComp = ; break; case 2: pageComp = ; break; } if (pageComp == null) { return null; } return ( {pageComp} ); }; TosModal.displayName = "TosModal"; export { TosModal };