[FIX] Message parser switch not updating field properly (#3576)
This commit is contained in:
parent
bff99d5c0b
commit
e68485bccd
|
@ -1,8 +1,9 @@
|
||||||
import { StackNavigationProp } from '@react-navigation/stack';
|
import { StackNavigationProp } from '@react-navigation/stack';
|
||||||
import React, { useEffect, useState } from 'react';
|
import React, { useEffect } from 'react';
|
||||||
import { Switch } from 'react-native';
|
import { Switch } from 'react-native';
|
||||||
import { useSelector } from 'react-redux';
|
import { useDispatch, useSelector } from 'react-redux';
|
||||||
|
|
||||||
|
import { setUser } from '../../actions/login';
|
||||||
import I18n from '../../i18n';
|
import I18n from '../../i18n';
|
||||||
import log, { logEvent, events } from '../../utils/log';
|
import log, { logEvent, events } from '../../utils/log';
|
||||||
import SafeAreaView from '../../containers/SafeAreaView';
|
import SafeAreaView from '../../containers/SafeAreaView';
|
||||||
|
@ -18,8 +19,8 @@ interface IUserPreferencesViewProps {
|
||||||
}
|
}
|
||||||
|
|
||||||
const UserPreferencesView = ({ navigation }: IUserPreferencesViewProps): JSX.Element => {
|
const UserPreferencesView = ({ navigation }: IUserPreferencesViewProps): JSX.Element => {
|
||||||
const user = useSelector(state => getUserSelector(state));
|
const { enableMessageParserEarlyAdoption, id } = useSelector(state => getUserSelector(state));
|
||||||
const [enableParser, setEnableParser] = useState(user.enableMessageParserEarlyAdoption);
|
const dispatch = useDispatch();
|
||||||
|
|
||||||
useEffect(() => {
|
useEffect(() => {
|
||||||
navigation.setOptions({
|
navigation.setOptions({
|
||||||
|
@ -34,15 +35,15 @@ const UserPreferencesView = ({ navigation }: IUserPreferencesViewProps): JSX.Ele
|
||||||
|
|
||||||
const toggleMessageParser = async (value: boolean) => {
|
const toggleMessageParser = async (value: boolean) => {
|
||||||
try {
|
try {
|
||||||
await RocketChat.saveUserPreferences({ id: user.id, enableMessageParserEarlyAdoption: value });
|
dispatch(setUser({ enableMessageParserEarlyAdoption: value }));
|
||||||
setEnableParser(value);
|
await RocketChat.saveUserPreferences({ id, enableMessageParserEarlyAdoption: value });
|
||||||
} catch (e) {
|
} catch (e) {
|
||||||
log(e);
|
log(e);
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
const renderMessageParserSwitch = () => (
|
const renderMessageParserSwitch = (value: boolean) => (
|
||||||
<Switch value={enableParser} trackColor={SWITCH_TRACK_COLOR} onValueChange={toggleMessageParser} />
|
<Switch value={value} trackColor={SWITCH_TRACK_COLOR} onValueChange={toggleMessageParser} />
|
||||||
);
|
);
|
||||||
|
|
||||||
return (
|
return (
|
||||||
|
@ -64,7 +65,7 @@ const UserPreferencesView = ({ navigation }: IUserPreferencesViewProps): JSX.Ele
|
||||||
<List.Item
|
<List.Item
|
||||||
title='Enable_Message_Parser'
|
title='Enable_Message_Parser'
|
||||||
testID='preferences-view-enable-message-parser'
|
testID='preferences-view-enable-message-parser'
|
||||||
right={() => renderMessageParserSwitch()}
|
right={() => renderMessageParserSwitch(enableMessageParserEarlyAdoption)}
|
||||||
/>
|
/>
|
||||||
<List.Separator />
|
<List.Separator />
|
||||||
</List.Section>
|
</List.Section>
|
||||||
|
|
Loading…
Reference in New Issue