Page MenuHomePhorge

D8153.1768397944.diff
No OneTemporary

Size
4 KB
Referenced Files
None
Subscribers
None

D8153.1768397944.diff

diff --git a/native/avatars/edit-user-avatar-provider.react.js b/native/avatars/edit-user-avatar-provider.react.js
--- a/native/avatars/edit-user-avatar-provider.react.js
+++ b/native/avatars/edit-user-avatar-provider.react.js
@@ -36,7 +36,7 @@
+updateImageUserAvatar: (selection: NativeMediaSelection) => Promise<void>,
+setUserAvatar: (avatarRequest: UpdateUserAvatarRequest) => Promise<void>,
+setRegistrationMode: (registrationMode: RegistrationMode) => void,
- +registrationModeEnabled: boolean,
+ +getRegistrationModeEnabled: () => boolean,
};
const EditUserAvatarContext: React.Context<?EditUserAvatarContextType> =
@@ -60,8 +60,8 @@
function EditUserAvatarProvider(props: Props): React.Node {
const { children } = props;
- const [registrationMode, setRegistrationMode] =
- React.useState<RegistrationMode>(registrationModeOff);
+ const registrationModeRef =
+ React.useRef<RegistrationMode>(registrationModeOff);
const dispatchActionPromise = useDispatchActionPromise();
const updateUserAvatarCall = useServerCall(updateUserAvatar);
@@ -83,8 +83,8 @@
const updateImageUserAvatar = React.useCallback(
async (selection: NativeMediaSelection) => {
- if (registrationMode.registrationMode === 'on') {
- registrationMode.successCallback({
+ if (registrationModeRef.current.registrationMode === 'on') {
+ registrationModeRef.current.successCallback({
needsUpload: true,
mediaSelection: selection,
});
@@ -108,12 +108,7 @@
dispatchActionPromise(updateUserAvatarActionTypes, promise);
await promise;
},
- [
- registrationMode,
- uploadSelectedMedia,
- updateUserAvatarCall,
- dispatchActionPromise,
- ],
+ [uploadSelectedMedia, updateUserAvatarCall, dispatchActionPromise],
);
const selectFromGalleryAndUpdateUserAvatar = React.useCallback(async () => {
@@ -126,8 +121,9 @@
const setUserAvatar = React.useCallback(
async (request: UpdateUserAvatarRequest) => {
- if (registrationMode.registrationMode === 'on') {
- registrationMode.successCallback({
+ const regMode = registrationModeRef.current;
+ if (regMode.registrationMode === 'on') {
+ regMode.successCallback({
needsUpload: false,
updateUserAvatarRequest: request,
});
@@ -145,10 +141,17 @@
dispatchActionPromise(updateUserAvatarActionTypes, promise);
await promise;
},
- [registrationMode, updateUserAvatarCall, dispatchActionPromise],
+ [updateUserAvatarCall, dispatchActionPromise],
+ );
+
+ const setRegistrationMode = React.useCallback((mode: RegistrationMode) => {
+ registrationModeRef.current = mode;
+ }, []);
+ const getRegistrationModeEnabled = React.useCallback(
+ () => registrationModeRef.current.registrationMode === 'on',
+ [],
);
- const registrationModeEnabled = registrationMode.registrationMode === 'on';
const context = React.useMemo(
() => ({
userAvatarSaveInProgress,
@@ -156,7 +159,7 @@
updateImageUserAvatar,
setUserAvatar,
setRegistrationMode,
- registrationModeEnabled,
+ getRegistrationModeEnabled,
}),
[
userAvatarSaveInProgress,
@@ -164,7 +167,7 @@
updateImageUserAvatar,
setUserAvatar,
setRegistrationMode,
- registrationModeEnabled,
+ getRegistrationModeEnabled,
],
);
diff --git a/native/avatars/edit-user-avatar.react.js b/native/avatars/edit-user-avatar.react.js
--- a/native/avatars/edit-user-avatar.react.js
+++ b/native/avatars/edit-user-avatar.react.js
@@ -36,7 +36,7 @@
userAvatarSaveInProgress,
selectFromGalleryAndUpdateUserAvatar,
setUserAvatar,
- registrationModeEnabled,
+ getRegistrationModeEnabled,
} = editUserAvatarContext;
const currentUserInfo = useSelector(state => state.currentUserInfo);
@@ -54,7 +54,7 @@
const usernameOrEthAddress = userInfo?.username;
const navigateToEmojiSelection = React.useCallback(() => {
- if (!registrationModeEnabled) {
+ if (!getRegistrationModeEnabled()) {
navigate(EmojiUserAvatarCreationRouteName);
return;
}
@@ -62,15 +62,15 @@
name: EmojiAvatarSelectionRouteName,
params: { usernameOrEthAddress },
});
- }, [navigate, registrationModeEnabled, usernameOrEthAddress]);
+ }, [navigate, getRegistrationModeEnabled, usernameOrEthAddress]);
const navigateToCamera = React.useCallback(() => {
navigate(
- registrationModeEnabled
+ getRegistrationModeEnabled()
? RegistrationUserAvatarCameraModalRouteName
: UserAvatarCameraModalRouteName,
);
- }, [navigate, registrationModeEnabled]);
+ }, [navigate, getRegistrationModeEnabled]);
const setENSUserAvatar = React.useCallback(() => {
setUserAvatar({ type: 'ens' });

File Metadata

Mime Type
text/plain
Expires
Wed, Jan 14, 1:39 PM (18 h, 23 m)
Storage Engine
blob
Storage Format
Raw Data
Storage Handle
5932252
Default Alt Text
D8153.1768397944.diff (4 KB)

Event Timeline