minor tweaks

This commit is contained in:
Reinaldo Neto 2023-01-18 17:11:25 -03:00
parent 8903c52ddb
commit a5da4999e1
7 changed files with 63 additions and 48 deletions

View File

@ -9,6 +9,7 @@ import { useTheme } from '../../theme';
import { BUTTON_HIT_SLOP } from '../message/utils'; import { BUTTON_HIT_SLOP } from '../message/utils';
import { useAppSelector } from '../../lib/hooks'; import { useAppSelector } from '../../lib/hooks';
import { compareServerVersion } from '../../lib/methods/helpers'; import { compareServerVersion } from '../../lib/methods/helpers';
import sharedStyles from '../../views/Styles';
const styles = StyleSheet.create({ const styles = StyleSheet.create({
editAvatarButton: { editAvatarButton: {
@ -20,7 +21,7 @@ const styles = StyleSheet.create({
}, },
textButton: { textButton: {
fontSize: 12, fontSize: 12,
fontWeight: '600' ...sharedStyles.textSemibold
} }
}); });
@ -72,7 +73,7 @@ const AvatarWithEdit = ({
onPress={handleEdit} onPress={handleEdit}
testID='avatar-edit-button' testID='avatar-edit-button'
style={styles.editAvatarButton} style={styles.editAvatarButton}
styleText={[styles.textButton]} styleText={styles.textButton}
color={colors.titleText} color={colors.titleText}
hitSlop={BUTTON_HIT_SLOP} hitSlop={BUTTON_HIT_SLOP}
/> />

View File

@ -14,7 +14,7 @@ interface IButtonProps extends PlatformTouchableProps {
loading?: boolean; loading?: boolean;
color?: string; color?: string;
fontSize?: number; fontSize?: number;
styleText?: StyleProp<TextStyle>[]; styleText?: StyleProp<TextStyle> | StyleProp<TextStyle>[];
} }
const styles = StyleSheet.create({ const styles = StyleSheet.create({

View File

@ -1,6 +1,6 @@
import { Image } from 'react-native'; import { Image } from 'react-native';
export const isImageURL = async (url: string) => { export const isImageURL = async (url: string): Promise<boolean> => {
try { try {
const result = await Image.prefetch(url); const result = await Image.prefetch(url);
return result; return result;

View File

@ -17,6 +17,7 @@ import styles from './styles';
import { useAppSelector } from '../../lib/hooks'; import { useAppSelector } from '../../lib/hooks';
import { getUserSelector } from '../../selectors/login'; import { getUserSelector } from '../../selectors/login';
import Avatar from '../../containers/Avatar'; import Avatar from '../../containers/Avatar';
import AvatarPresentational from '../../containers/Avatar/Avatar';
import AvatarUrl from './AvatarUrl'; import AvatarUrl from './AvatarUrl';
import Button from '../../containers/Button'; import Button from '../../containers/Button';
import I18n from '../../i18n'; import I18n from '../../i18n';
@ -24,7 +25,7 @@ import { ChatsStackParamList } from '../../stacks/types';
import { IAvatar } from '../../definitions'; import { IAvatar } from '../../definitions';
import AvatarSuggestion from './AvatarSuggestion'; import AvatarSuggestion from './AvatarSuggestion';
import log from '../../lib/methods/helpers/log'; import log from '../../lib/methods/helpers/log';
import { changeRoomsAvatar, changeUserAvatar, resetUserAvatar } from './submitHelpers'; import { changeRoomsAvatar, changeUserAvatar, resetUserAvatar } from './submitServices';
enum AvatarStateActions { enum AvatarStateActions {
CHANGE_AVATAR = 'CHANGE_AVATAR', CHANGE_AVATAR = 'CHANGE_AVATAR',
@ -64,10 +65,11 @@ const ChangeAvatarView = () => {
const [state, dispatch] = useReducer(reducer, initialState); const [state, dispatch] = useReducer(reducer, initialState);
const [saving, setSaving] = useState(false); const [saving, setSaving] = useState(false);
const { colors } = useTheme(); const { colors } = useTheme();
const { userId, username } = useAppSelector( const { userId, username, server } = useAppSelector(
state => ({ state => ({
userId: getUserSelector(state).id, userId: getUserSelector(state).id,
username: getUserSelector(state).username username: getUserSelector(state).username,
server: state.server.server
}), }),
shallowEqual shallowEqual
); );
@ -149,7 +151,7 @@ const ChangeAvatarView = () => {
} }
}; };
const deletingRoomAvatar = context === 'room' && state.data === null ? {} : { rid: room?.rid }; const deletingRoomAvatar = context === 'room' && state.data === null;
return ( return (
<KeyboardView <KeyboardView
@ -165,14 +167,25 @@ const ChangeAvatarView = () => {
{...scrollPersistTaps} {...scrollPersistTaps}
> >
<View style={styles.avatarContainer} testID='change-avatar-view-avatar'> <View style={styles.avatarContainer} testID='change-avatar-view-avatar'>
<Avatar {deletingRoomAvatar ? (
text={room?.name || state.resetUserAvatar || username} <AvatarPresentational
avatar={state?.url} text={room?.name || state.resetUserAvatar || username}
isStatic={state?.url} avatar={state?.url}
size={120} isStatic={state?.url}
type={t} size={120}
{...deletingRoomAvatar} type={t}
/> server={server}
/>
) : (
<Avatar
text={room?.name || state.resetUserAvatar || username}
avatar={state?.url}
isStatic={state?.url}
size={120}
type={t}
rid={room?.rid}
/>
)}
</View> </View>
{context === 'profile' ? ( {context === 'profile' ? (
<AvatarUrl <AvatarUrl

View File

@ -1,34 +1,6 @@
import { Services } from '../../lib/services';
import log from '../../lib/methods/helpers/log';
import { IAvatar } from '../../definitions';
import I18n from '../../i18n'; import I18n from '../../i18n';
export const changeRoomsAvatar = async (rid: string, roomAvatar: string | null) => { export const handleError = (e: any, action: string) => {
try {
await Services.saveRoomSettings(rid, { roomAvatar });
} catch (e) {
log(e);
return handleError(e, 'changing_avatar');
}
};
export const changeUserAvatar = async (avatarUpload: IAvatar) => {
try {
await Services.setAvatarFromService(avatarUpload);
} catch (e) {
return handleError(e, 'changing_avatar');
}
};
export const resetUserAvatar = async (userId: string) => {
try {
await Services.resetAvatar(userId);
} catch (e) {
return handleError(e, 'changing_avatar');
}
};
const handleError = (e: any, action: string) => {
if (e.data && e.data.error.includes('[error-too-many-requests]')) { if (e.data && e.data.error.includes('[error-too-many-requests]')) {
throw new Error(e.data.error); throw new Error(e.data.error);
} }

View File

@ -0,0 +1,29 @@
import { Services } from '../../lib/services';
import log from '../../lib/methods/helpers/log';
import { IAvatar } from '../../definitions';
import { handleError } from './submitHelpers';
export const changeRoomsAvatar = async (rid: string, roomAvatar: string | null) => {
try {
await Services.saveRoomSettings(rid, { roomAvatar });
} catch (e) {
log(e);
return handleError(e, 'changing_avatar');
}
};
export const changeUserAvatar = async (avatarUpload: IAvatar) => {
try {
await Services.setAvatarFromService(avatarUpload);
} catch (e) {
return handleError(e, 'changing_avatar');
}
};
export const resetUserAvatar = async (userId: string) => {
try {
await Services.resetAvatar(userId);
} catch (e) {
return handleError(e, 'changing_avatar');
}
};

View File

@ -254,7 +254,7 @@ class ProfileView extends React.Component<IProfileViewProps, IProfileViewState>
} }
logEvent(events.PROFILE_SAVE_CHANGES_F); logEvent(events.PROFILE_SAVE_CHANGES_F);
this.setState({ saving: false, currentPassword: null, twoFactorCode: null }); this.setState({ saving: false, currentPassword: null, twoFactorCode: null });
this.handleError(e, 'saveUserProfile', 'saving_profile'); this.handleError(e, 'saving_profile');
} }
}; };
@ -271,11 +271,11 @@ class ProfileView extends React.Component<IProfileViewProps, IProfileViewState>
EventEmitter.emit(LISTENER, { message: I18n.t('Avatar_changed_successfully') }); EventEmitter.emit(LISTENER, { message: I18n.t('Avatar_changed_successfully') });
this.init(); this.init();
} catch (e) { } catch (e) {
this.handleError(e, 'resetAvatar', 'changing_avatar'); this.handleError(e, 'changing_avatar');
} }
}; };
handleError = (e: any, _func: string, action: string) => { handleError = (e: any, action: string) => {
if (e.data && e.data.error.includes('[error-too-many-requests]')) { if (e.data && e.data.error.includes('[error-too-many-requests]')) {
return showErrorAlert(e.data.error); return showErrorAlert(e.data.error);
} }