[Update] Config Page: Others Tab: Add EnableSendReceivedMessageToVrc(Speaker2Chatbox).
This commit is contained in:
@@ -270,7 +270,7 @@
|
|||||||
},
|
},
|
||||||
"send_received_message_to_vrc": {
|
"send_received_message_to_vrc": {
|
||||||
"label": "Send Received Message To VRChat",
|
"label": "Send Received Message To VRChat",
|
||||||
"desc": "Send the message you received from the speaker's sound to VRChat's chatbox. However, this feature is intended for users who genuinely need it. Please consult with the developer."
|
"desc": "Send the message you received from the speaker's sound to VRChat's chatbox."
|
||||||
},
|
},
|
||||||
"osc_ip_address": {
|
"osc_ip_address": {
|
||||||
"label": "OSC IP Address"
|
"label": "OSC IP Address"
|
||||||
|
|||||||
@@ -8,6 +8,7 @@ import {
|
|||||||
useEnableAutoExportMessageLogs,
|
useEnableAutoExportMessageLogs,
|
||||||
useEnableVrcMicMuteSync,
|
useEnableVrcMicMuteSync,
|
||||||
useEnableSendMessageToVrc,
|
useEnableSendMessageToVrc,
|
||||||
|
useEnableSendReceivedMessageToVrc,
|
||||||
} from "@logics_configs";
|
} from "@logics_configs";
|
||||||
|
|
||||||
import {
|
import {
|
||||||
@@ -18,19 +19,26 @@ import {
|
|||||||
LabelComponent,
|
LabelComponent,
|
||||||
Checkbox,
|
Checkbox,
|
||||||
ActionButton,
|
ActionButton,
|
||||||
|
SectionLabelComponent,
|
||||||
} from "../_components/";
|
} from "../_components/";
|
||||||
|
|
||||||
import OpenFolderSvg from "@images/open_folder.svg?react";
|
import OpenFolderSvg from "@images/open_folder.svg?react";
|
||||||
|
|
||||||
export const Others = () => {
|
export const Others = () => {
|
||||||
return (
|
return (
|
||||||
<>
|
<div className={styles.container}>
|
||||||
<AutoClearMessageInputBoxContainer />
|
<div>
|
||||||
<SendOnlyTranslatedMessagesContainer />
|
<AutoClearMessageInputBoxContainer />
|
||||||
<AutoExportMessageLogsContainer />
|
<SendOnlyTranslatedMessagesContainer />
|
||||||
<VrcMicMuteSyncContainer />
|
<AutoExportMessageLogsContainer />
|
||||||
<SendMessageToVrcContainer />
|
<VrcMicMuteSyncContainer />
|
||||||
</>
|
<SendMessageToVrcContainer />
|
||||||
|
</div>
|
||||||
|
<div>
|
||||||
|
<SectionLabelComponent label="Speaker2Chatbox" />
|
||||||
|
<SendReceivedMessageToVrcContainer />
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
);
|
);
|
||||||
};
|
};
|
||||||
|
|
||||||
@@ -64,12 +72,12 @@ const AutoExportMessageLogsContainer = () => {
|
|||||||
const { openFolder_MessageLogs } = useOpenFolder();
|
const { openFolder_MessageLogs } = useOpenFolder();
|
||||||
|
|
||||||
return (
|
return (
|
||||||
<div className={styles.container}>
|
<div className={styles.auto_export_message_logs_container}>
|
||||||
<LabelComponent
|
<LabelComponent
|
||||||
label={t("config_page.auto_export_message_logs.label")}
|
label={t("config_page.auto_export_message_logs.label")}
|
||||||
desc={t("config_page.auto_export_message_logs.desc")}
|
desc={t("config_page.auto_export_message_logs.desc")}
|
||||||
/>
|
/>
|
||||||
<div className={styles.switch_section_container}>
|
<div className={styles.auto_export_message_logs_switch_section_container}>
|
||||||
<ActionButton
|
<ActionButton
|
||||||
IconComponent={OpenFolderSvg}
|
IconComponent={OpenFolderSvg}
|
||||||
onclickFunction={openFolder_MessageLogs}
|
onclickFunction={openFolder_MessageLogs}
|
||||||
@@ -107,4 +115,19 @@ const SendMessageToVrcContainer = () => {
|
|||||||
toggleFunction={toggleEnableSendMessageToVrc}
|
toggleFunction={toggleEnableSendMessageToVrc}
|
||||||
/>
|
/>
|
||||||
);
|
);
|
||||||
|
};
|
||||||
|
|
||||||
|
|
||||||
|
const SendReceivedMessageToVrcContainer = () => {
|
||||||
|
const { t } = useTranslation();
|
||||||
|
const { currentEnableSendReceivedMessageToVrc, toggleEnableSendReceivedMessageToVrc } = useEnableSendReceivedMessageToVrc();
|
||||||
|
|
||||||
|
return (
|
||||||
|
<CheckboxContainer
|
||||||
|
label={t("config_page.send_received_message_to_vrc.label")}
|
||||||
|
desc={t("config_page.send_received_message_to_vrc.desc")}
|
||||||
|
variable={currentEnableSendReceivedMessageToVrc}
|
||||||
|
toggleFunction={toggleEnableSendReceivedMessageToVrc}
|
||||||
|
/>
|
||||||
|
);
|
||||||
};
|
};
|
||||||
@@ -1,4 +1,10 @@
|
|||||||
.container {
|
.container {
|
||||||
|
display: flex;
|
||||||
|
gap: 6.4rem;
|
||||||
|
flex-direction: column;
|
||||||
|
}
|
||||||
|
|
||||||
|
.auto_export_message_logs_container {
|
||||||
display: flex;
|
display: flex;
|
||||||
width: 100%;
|
width: 100%;
|
||||||
justify-content: space-between;
|
justify-content: space-between;
|
||||||
@@ -12,7 +18,7 @@
|
|||||||
border-bottom: solid 0.1rem var(--dark_800_color);
|
border-bottom: solid 0.1rem var(--dark_800_color);
|
||||||
}
|
}
|
||||||
|
|
||||||
.switch_section_container {
|
.auto_export_message_logs_switch_section_container {
|
||||||
display: flex;
|
display: flex;
|
||||||
width: 100%;
|
width: 100%;
|
||||||
justify-content: space-between;
|
justify-content: space-between;
|
||||||
|
|||||||
@@ -19,6 +19,7 @@ export { useUiScaling } from "./appearance/useUiScaling";
|
|||||||
export { useEnableAutoClearMessageInputBox } from "./others/useEnableAutoClearMessageInputBox";
|
export { useEnableAutoClearMessageInputBox } from "./others/useEnableAutoClearMessageInputBox";
|
||||||
export { useEnableAutoExportMessageLogs } from "./others/useEnableAutoExportMessageLogs";
|
export { useEnableAutoExportMessageLogs } from "./others/useEnableAutoExportMessageLogs";
|
||||||
export { useEnableSendMessageToVrc } from "./others/useEnableSendMessageToVrc";
|
export { useEnableSendMessageToVrc } from "./others/useEnableSendMessageToVrc";
|
||||||
|
export { useEnableSendReceivedMessageToVrc } from "./others/useEnableSendReceivedMessageToVrc";
|
||||||
export { useEnableSendOnlyTranslatedMessages } from "./others/useEnableSendOnlyTranslatedMessages";
|
export { useEnableSendOnlyTranslatedMessages } from "./others/useEnableSendOnlyTranslatedMessages";
|
||||||
export { useEnableVrcMicMuteSync } from "./others/useEnableVrcMicMuteSync";
|
export { useEnableVrcMicMuteSync } from "./others/useEnableVrcMicMuteSync";
|
||||||
|
|
||||||
|
|||||||
@@ -0,0 +1,28 @@
|
|||||||
|
import { useStore_EnableSendReceivedMessageToVrc } from "@store";
|
||||||
|
import { useStdoutToPython } from "@logics/useStdoutToPython";
|
||||||
|
|
||||||
|
export const useEnableSendReceivedMessageToVrc = () => {
|
||||||
|
const { asyncStdoutToPython } = useStdoutToPython();
|
||||||
|
const { currentEnableSendReceivedMessageToVrc, updateEnableSendReceivedMessageToVrc, pendingEnableSendReceivedMessageToVrc } = useStore_EnableSendReceivedMessageToVrc();
|
||||||
|
|
||||||
|
const getEnableSendReceivedMessageToVrc = () => {
|
||||||
|
pendingEnableSendReceivedMessageToVrc();
|
||||||
|
asyncStdoutToPython("/get/data/send_received_message_to_vrc");
|
||||||
|
};
|
||||||
|
|
||||||
|
const toggleEnableSendReceivedMessageToVrc = () => {
|
||||||
|
pendingEnableSendReceivedMessageToVrc();
|
||||||
|
if (currentEnableSendReceivedMessageToVrc.data) {
|
||||||
|
asyncStdoutToPython("/set/disable/send_received_message_to_vrc");
|
||||||
|
} else {
|
||||||
|
asyncStdoutToPython("/set/enable/send_received_message_to_vrc");
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
return {
|
||||||
|
currentEnableSendReceivedMessageToVrc,
|
||||||
|
getEnableSendReceivedMessageToVrc,
|
||||||
|
toggleEnableSendReceivedMessageToVrc,
|
||||||
|
updateEnableSendReceivedMessageToVrc,
|
||||||
|
};
|
||||||
|
};
|
||||||
@@ -32,6 +32,7 @@ import {
|
|||||||
useEnableAutoExportMessageLogs,
|
useEnableAutoExportMessageLogs,
|
||||||
useEnableVrcMicMuteSync,
|
useEnableVrcMicMuteSync,
|
||||||
useEnableSendMessageToVrc,
|
useEnableSendMessageToVrc,
|
||||||
|
useEnableSendReceivedMessageToVrc,
|
||||||
useSelectedFontFamily,
|
useSelectedFontFamily,
|
||||||
useUiLanguage,
|
useUiLanguage,
|
||||||
useUiScaling,
|
useUiScaling,
|
||||||
@@ -97,6 +98,7 @@ export const useReceiveRoutes = () => {
|
|||||||
const { updateEnableAutoExportMessageLogs } = useEnableAutoExportMessageLogs();
|
const { updateEnableAutoExportMessageLogs } = useEnableAutoExportMessageLogs();
|
||||||
const { updateEnableVrcMicMuteSync } = useEnableVrcMicMuteSync();
|
const { updateEnableVrcMicMuteSync } = useEnableVrcMicMuteSync();
|
||||||
const { updateEnableSendMessageToVrc } = useEnableSendMessageToVrc();
|
const { updateEnableSendMessageToVrc } = useEnableSendMessageToVrc();
|
||||||
|
const { updateEnableSendReceivedMessageToVrc } = useEnableSendReceivedMessageToVrc();
|
||||||
|
|
||||||
const { updateSendMessageButtonType } = useSendMessageButtonType();
|
const { updateSendMessageButtonType } = useSendMessageButtonType();
|
||||||
const { updateUiLanguage } = useUiLanguage();
|
const { updateUiLanguage } = useUiLanguage();
|
||||||
@@ -396,6 +398,10 @@ export const useReceiveRoutes = () => {
|
|||||||
"/set/enable/send_message_to_vrc": updateEnableSendMessageToVrc,
|
"/set/enable/send_message_to_vrc": updateEnableSendMessageToVrc,
|
||||||
"/set/disable/send_message_to_vrc": updateEnableSendMessageToVrc,
|
"/set/disable/send_message_to_vrc": updateEnableSendMessageToVrc,
|
||||||
|
|
||||||
|
"/get/data/send_received_message_to_vrc": updateEnableSendReceivedMessageToVrc,
|
||||||
|
"/set/enable/send_received_message_to_vrc": updateEnableSendReceivedMessageToVrc,
|
||||||
|
"/set/disable/send_received_message_to_vrc": updateEnableSendReceivedMessageToVrc,
|
||||||
|
|
||||||
// Advanced Settings
|
// Advanced Settings
|
||||||
"/get/data/osc_ip_address": updateOscIpAddress,
|
"/get/data/osc_ip_address": updateOscIpAddress,
|
||||||
"/set/data/osc_ip_address": updateOscIpAddress,
|
"/set/data/osc_ip_address": updateOscIpAddress,
|
||||||
|
|||||||
@@ -227,6 +227,7 @@ export const { atomInstance: Atom_EnableSendOnlyTranslatedMessages, useHook: use
|
|||||||
export const { atomInstance: Atom_EnableAutoExportMessageLogs, useHook: useStore_EnableAutoExportMessageLogs } = createAtomWithHook(false, "EnableAutoExportMessageLogs");
|
export const { atomInstance: Atom_EnableAutoExportMessageLogs, useHook: useStore_EnableAutoExportMessageLogs } = createAtomWithHook(false, "EnableAutoExportMessageLogs");
|
||||||
export const { atomInstance: Atom_EnableVrcMicMuteSync, useHook: useStore_EnableVrcMicMuteSync } = createAtomWithHook(false, "EnableVrcMicMuteSync");
|
export const { atomInstance: Atom_EnableVrcMicMuteSync, useHook: useStore_EnableVrcMicMuteSync } = createAtomWithHook(false, "EnableVrcMicMuteSync");
|
||||||
export const { atomInstance: Atom_EnableSendMessageToVrc, useHook: useStore_EnableSendMessageToVrc } = createAtomWithHook(true, "EnableSendMessageToVrc");
|
export const { atomInstance: Atom_EnableSendMessageToVrc, useHook: useStore_EnableSendMessageToVrc } = createAtomWithHook(true, "EnableSendMessageToVrc");
|
||||||
|
export const { atomInstance: Atom_EnableSendReceivedMessageToVrc, useHook: useStore_EnableSendReceivedMessageToVrc } = createAtomWithHook(false, "EnableSendReceivedMessageToVrc");
|
||||||
|
|
||||||
// Advanced Settings
|
// Advanced Settings
|
||||||
export const { atomInstance: Atom_OscIpAddress, useHook: useStore_OscIpAddress } = createAtomWithHook("127.0.0.1", "OscIpAddress");
|
export const { atomInstance: Atom_OscIpAddress, useHook: useStore_OscIpAddress } = createAtomWithHook("127.0.0.1", "OscIpAddress");
|
||||||
|
|||||||
Reference in New Issue
Block a user