You cannot select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
session-desktop/ts/components/settings/section/CategoryConversations.tsx

137 lines
4.3 KiB
TypeScript

import { useDispatch, useSelector } from 'react-redux';
import useUpdate from 'react-use/lib/useUpdate';
import { SettingsKey } from '../../../data/settings-key';
import { ToastUtils } from '../../../session/utils';
import { toggleAudioAutoplay } from '../../../state/ducks/userConfig';
import { useHasEnterSendEnabled } from '../../../state/selectors/settings';
import { getAudioAutoplay } from '../../../state/selectors/userConfig';
import { SessionRadioGroup, SessionRadioItems } from '../../basic/SessionRadioGroup';
import { BlockedContactsList } from '../BlockedList';
import {
SessionSettingsItemWrapper,
SessionToggleWithDescription,
} from '../SessionSettingListItem';
async function toggleCommunitiesPruning() {
try {
const newValue = !(await window.getOpengroupPruning());
// make sure to write it here too, as this is the value used on the UI to mark the toggle as true/false
await window.setSettingValue(SettingsKey.settingsOpengroupPruning, newValue);
await window.setOpengroupPruning(newValue);
ToastUtils.pushRestartNeeded();
} catch (e) {
window.log.warn('toggleCommunitiesPruning change error:', e);
}
}
const CommunitiesPruningSetting = () => {
const forceUpdate = useUpdate();
const isOpengroupPruningEnabled = Boolean(
window.getSettingValue(SettingsKey.settingsOpengroupPruning)
);
return (
<SessionToggleWithDescription
// eslint-disable-next-line @typescript-eslint/no-misused-promises
onClickToggle={async () => {
await toggleCommunitiesPruning();
forceUpdate();
}}
title={window.i18n('conversationsMessageTrimmingTrimCommunities')}
description={window.i18n('conversationsMessageTrimmingTrimCommunitiesDescription')}
active={isOpengroupPruningEnabled}
/>
);
};
const SpellCheckSetting = () => {
const forceUpdate = useUpdate();
const isSpellCheckActive =
window.getSettingValue(SettingsKey.settingsSpellCheck) === undefined
? true
: window.getSettingValue(SettingsKey.settingsSpellCheck);
return (
<SessionToggleWithDescription
onClickToggle={() => {
window.toggleSpellCheck();
forceUpdate();
}}
title={window.i18n('conversationsSpellCheck')}
description={window.i18n('conversationsSpellCheckDescription')}
active={isSpellCheckActive}
/>
);
};
const AudioMessageAutoPlaySetting = () => {
const audioAutoPlay = useSelector(getAudioAutoplay);
const dispatch = useDispatch();
const forceUpdate = useUpdate();
return (
<SessionToggleWithDescription
onClickToggle={() => {
dispatch(toggleAudioAutoplay());
forceUpdate();
}}
title={window.i18n('conversationsAutoplayAudioMessage')}
description={window.i18n('conversationsAutoplayAudioMessageDescription')}
active={audioAutoPlay}
/>
);
};
const EnterKeyFunctionSetting = () => {
const initialSetting = useHasEnterSendEnabled();
const selectedWithSettingTrue = 'enterForNewLine';
const items: SessionRadioItems = [
{
label: window.i18n('conversationsEnterSends'),
value: 'enterForSend',
inputDataTestId: 'input-enterForSend',
labelDataTestId: 'label-enterForSend',
},
{
label: window.i18n('conversationsEnterNewLine'),
value: selectedWithSettingTrue,
inputDataTestId: `input-${selectedWithSettingTrue}`,
labelDataTestId: `label-${selectedWithSettingTrue}`,
},
];
return (
<SessionSettingsItemWrapper
title={window.i18n('conversationsEnter')}
description={window.i18n('conversationsEnterDescription')}
inline={false}
>
<SessionRadioGroup
initialItem={initialSetting ? 'enterForNewLine' : 'enterForSend'}
group={SettingsKey.hasShiftSendEnabled} // make sure to define this key in your SettingsKey enum
items={items}
onClick={(selectedRadioValue: string) => {
void window.setSettingValue(
SettingsKey.hasShiftSendEnabled,
selectedRadioValue === selectedWithSettingTrue
);
}}
/>
</SessionSettingsItemWrapper>
);
};
export const CategoryConversations = () => {
return (
<>
<CommunitiesPruningSetting />
<SpellCheckSetting />
<AudioMessageAutoPlaySetting />
<EnterKeyFunctionSetting />
<BlockedContactsList />
</>
);
};