import { useEffect, useRef } from "react"; import { useStartPython } from "@logics/useStartPython"; import { WindowTitleBar } from "./window_title_bar/WindowTitleBar"; import { MainPage } from "./main_page/MainPage"; import { ConfigPage } from "./config_page/ConfigPage"; import styles from "./App.module.scss"; export const App = () => { const { WindowGeometryController } = useWindow(); return (
); }; import { useWindow, useVolume, useIsOpenedConfigPage, } from "@logics_common"; import { useUiLanguage, useUiScaling, useSelectedFontFamily, useTransparency, } from "@logics_configs"; import { useMainFunction, } from "@logics_main"; const StartPythonFacadeComponent = () => { const { asyncStartPython } = useStartPython(); const hasRunRef = useRef(false); const { asyncFetchFonts } = useAsyncFetchFonts(); useEffect(() => { if (!hasRunRef.current) { asyncStartPython().then(() => { startFeedingToWatchDog(); asyncFetchFonts(); }).catch((err) => { console.error(err); }); } return () => hasRunRef.current = true; }, []); return null; }; import { useTranslation } from "react-i18next"; const UiLanguageController = () => { const { currentUiLanguage } = useUiLanguage(); const { i18n } = useTranslation(); useEffect(() => { i18n.changeLanguage(currentUiLanguage.data); }, [currentUiLanguage.data]); return null; }; import { useStore_MainFunctionsStateMemory } from "@store"; const ConfigPageCloseTrigger = () => { const { currentIsOpenedConfigPage } = useIsOpenedConfigPage(); const { currentMainFunctionsStateMemory, updateMainFunctionsStateMemory} = useStore_MainFunctionsStateMemory(); const { currentTranscriptionSendStatus, setTranscriptionSend, currentTranscriptionReceiveStatus, setTranscriptionReceive, } = useMainFunction(); const { currentMicThresholdCheckStatus, volumeCheckStop_Mic, currentSpeakerThresholdCheckStatus, volumeCheckStop_Speaker, } = useVolume(); const memorizeLatestMainFunctionsState = () => { updateMainFunctionsStateMemory({ transcription_send: currentTranscriptionSendStatus.data, transcription_receive: currentTranscriptionReceiveStatus.data, }); }; const restoreMainFunctionState = () => { if (currentMainFunctionsStateMemory.data.transcription_send === true) setTranscriptionSend(true); if (currentMainFunctionsStateMemory.data.transcription_receive === true) setTranscriptionReceive(true); }; useEffect(() => { if (currentIsOpenedConfigPage.data === true) { // When config page is opened. memorizeLatestMainFunctionsState(); if (currentTranscriptionSendStatus.data === true) setTranscriptionSend(false); if (currentTranscriptionReceiveStatus.data === true) setTranscriptionReceive(false); } else if (currentIsOpenedConfigPage.data === false) { // When config page is closed. if (currentMicThresholdCheckStatus.data === true) volumeCheckStop_Mic(); if (currentSpeakerThresholdCheckStatus.data === true) volumeCheckStop_Speaker(); restoreMainFunctionState(); } }, [currentIsOpenedConfigPage.data]); return null; }; import React from "react"; const UiSizeController = () => { const { currentUiScaling } = useUiScaling(); const font_size = 62.5 * currentUiScaling.data / 100; useEffect(() => { document.documentElement.style.setProperty("font-size", `${font_size}%`); document.documentElement.style.setProperty("font-family", `Yu Gothic UI`); }, [currentUiScaling.data]); return null; }; const FontFamilyController = () => { const { currentSelectedFontFamily } = useSelectedFontFamily(); useEffect(() => { document.documentElement.style.setProperty("font-family", `${currentSelectedFontFamily.data}`); }, [currentSelectedFontFamily.data]); return null; }; import { useStore_SelectableFontFamilyList } from "@store"; import { arrayToObject } from "@utils/arrayToObject"; import { invoke } from "@tauri-apps/api/tauri"; const useAsyncFetchFonts = () => { const { updateSelectableFontFamilyList } = useStore_SelectableFontFamilyList(); const asyncFetchFonts = async () => { try { let fonts = await invoke("get_font_list"); fonts = fonts.sort((a, b) => a.localeCompare(b, undefined, { sensitivity: "base" })); updateSelectableFontFamilyList(arrayToObject(fonts)); } catch (error) { console.error("Error fetching fonts:", error); } }; return { asyncFetchFonts }; }; const TransparencyController = () => { const { currentTransparency } = useTransparency(); useEffect(() => { document.documentElement.style.setProperty("opacity", `${currentTransparency.data / 100}`); }, [currentTransparency.data]); return null; }; import { useStdoutToPython } from "@logics/useStdoutToPython"; const startFeedingToWatchDog = () => { const { asyncStdoutToPython } = useStdoutToPython(); setInterval(() => { asyncStdoutToPython("/run/feed_watchdog"); }, 20000); // 20000ミリ秒 = 20秒 };