Skip to content

Commit

Permalink
Fix redirect permalink issue
Browse files Browse the repository at this point in the history
* Add Hcaptcha error display
* Update texts
  • Loading branch information
AdityaKhatri authored and barshathakuri committed Dec 9, 2024
1 parent 05030f3 commit ab1deff
Show file tree
Hide file tree
Showing 11 changed files with 90 additions and 30 deletions.
12 changes: 8 additions & 4 deletions src/App/index.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -115,18 +115,22 @@ function App() {
setCurrentLanguage(language ?? 'en');
}, []);

const {
loading: meLoading,
} = useQuery<MeQuery>(
const [ready, setReady] = useState(false);

useQuery<MeQuery>(
ME,
{
onCompleted: (response) => {
setReady(true);
if (response.public.me) {
setUserAuth(response.public.me);
} else {
removeUserAuth();
}
},
onError: () => {
setReady(true);
},
},
);

Expand Down Expand Up @@ -251,7 +255,7 @@ function App() {
removeAlert,
}), [alerts, addAlert, updateAlert, removeAlert]);

if (meLoading) {
if (!ready) {
return (
// FIXME: Use translation
<div className={styles.loading}>
Expand Down
4 changes: 2 additions & 2 deletions src/App/redirects/ActivationRedirect.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -17,8 +17,8 @@ export function Component() {
const { userId, token } = useParams<ActivationParams>();
const navigate = useNavigate();

const activationLink = (userId && token && routes.activation.path) ? ({
pathname: (generatePath(routes.activation.path, { userId, token })),
const activationLink = (userId && token) ? ({
pathname: (generatePath(routes.activation.absolutePath, { userId, token })),
})
: routes.pageNotFound.path;

Expand Down
7 changes: 5 additions & 2 deletions src/App/redirects/RecoverAccountRedirect.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -17,8 +17,11 @@ export function Component() {
const { userId, resetToken } = useParams<ResetPasswordParams>();
const navigate = useNavigate();

const resetPasswordLink = (userId && resetToken && routes.recoverAccountConfirm.path) ? ({
pathname: (generatePath(routes.recoverAccountConfirm.path, { userId, resetToken })),
const resetPasswordLink = (userId && resetToken) ? ({
pathname: (generatePath(
routes.recoverAccountConfirm.absolutePath,
{ userId, resetToken },
)),
})
: routes.pageNotFound.path;

Expand Down
9 changes: 8 additions & 1 deletion src/components/Captcha/index.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -10,6 +10,7 @@ import { hCaptchaKey } from '#config';
export type HCaptchaProps<T> = Omit<InputContainerProps, 'input'> & {
name: T,
onChange: (value: string | undefined, name: T) => void;
onError: (errorString: string) => void;
elementRef?: React.RefObject<HCaptcha>;
};

Expand All @@ -28,6 +29,7 @@ function HCaptchaInput<T extends string>(props: HCaptchaProps<T>) {
inputSectionClassName,
label,
readOnly,
onError,
name,
onChange,
elementRef,
Expand All @@ -43,9 +45,14 @@ function HCaptchaInput<T extends string>(props: HCaptchaProps<T>) {
(err: string) => {
// eslint-disable-next-line no-console
console.error(err);
onError(err);
onChange(undefined, name);
},
[onChange, name],
[
onChange,
name,
onError,
],
);
const handleExpire = useCallback(
() => {
Expand Down
9 changes: 5 additions & 4 deletions src/views/Login/index.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -127,10 +127,11 @@ export function Component() {
);
navigate('/');
} else {
alert.show(
strings.loginFailureMessage,
{ variant: 'danger' },
);
const errorMessages = response?.errors
?.map((errors: { messages: string; }) => errors.messages)
.filter((message: string) => message)
.join(', ');
alert.show(errorMessages, { variant: 'danger' });
}
},
onError: () => {
Expand Down
18 changes: 10 additions & 8 deletions src/views/MySubscriptions/index.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -222,10 +222,11 @@ export function Component() {
refetch();
}
} else {
alert.show(
strings.subscriptionFailedToUpdate,
{ variant: 'danger' },
);
const errorMessages = response?.errors
?.map((error: { messages: string; }) => error.messages)
.filter((message: string) => message)
.join(', ');
alert.show(errorMessages, { variant: 'danger' });
}
},
onError: () => {
Expand Down Expand Up @@ -260,10 +261,11 @@ export function Component() {
{ variant: 'success' },
);
} else {
alert.show(
strings.subscriptionFailedToDelete,
{ variant: 'danger' },
);
const errorMessages = response?.errors
?.map((error: { messages: string; }) => error.messages)
.filter((message: string) => message)
.join(', ');
alert.show(errorMessages, { variant: 'danger' });
}
},
onError: () => {
Expand Down
2 changes: 1 addition & 1 deletion src/views/NewSubscriptionModal/i18n.json
Original file line number Diff line number Diff line change
Expand Up @@ -18,10 +18,10 @@
"filterRegionsLabel": "Regions",
"filterRegionsPlaceholder": "All Regions",
"newSubscriptionHeading": "New Subscription",
"editSubscriptionHeading": "Edit Subscription",
"newSubscriptionTitle": "Title",
"newSubscriptionCreatedSuccessfully": "Subscription created successfully.",
"newSubscriptionFailed": "Failed to create subscription",
"newSubscriptionLimitExceeded": "You have reached the maximum limit of 10 subscriptions",
"subscriptionUpdatedSuccessfully": "Subscription updated successfully.",
"failedToUpdateSubscription": "Failed to update subscription."
}
Expand Down
11 changes: 8 additions & 3 deletions src/views/NewSubscriptionModal/index.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -17,7 +17,10 @@ import {
TextInput,
} from '@ifrc-go/ui';
import { useTranslation } from '@ifrc-go/ui/hooks';
import { isNotDefined } from '@togglecorp/fujs';
import {
isDefined,
isNotDefined,
} from '@togglecorp/fujs';
import {
createSubmitHandler,
getErrorObject,
Expand Down Expand Up @@ -312,11 +315,11 @@ function NewSubscriptionModal(props: Props) {
}

if (response.ok) {
onCloseModal();
alert.show(
strings.newSubscriptionCreatedSuccessfully,
{ variant: 'success' },
);
onCloseModal();
if (onSuccess) {
onSuccess();
}
Expand Down Expand Up @@ -456,7 +459,9 @@ function NewSubscriptionModal(props: Props) {
return (
<Modal
className={styles.subscriptionModal}
heading={strings.newSubscriptionHeading}
heading={(isDefined(subscription?.id)
? strings.editSubscriptionHeading : strings.newSubscriptionHeading
)}
footerContent={(
<Button
name={undefined}
Expand Down
12 changes: 12 additions & 0 deletions src/views/RecoverAccount/index.tsx
Original file line number Diff line number Diff line change
@@ -1,4 +1,5 @@
import {
useCallback,
useMemo,
useState,
} from 'react';
Expand Down Expand Up @@ -131,6 +132,16 @@ export function Component() {

const fieldError = getErrorObject(formError);

const onCaptchaError = useCallback((errorString: string) => {
setError((oldErrors) => {
const fieldErrors = getErrorObject(oldErrors);
return ({
...fieldErrors,
captcha: errorString,
});
});
}, [setError]);

if (isSubmitted) {
return (
<Page>
Expand Down Expand Up @@ -171,6 +182,7 @@ export function Component() {
<HCaptcha
name="captcha"
onChange={setFieldValue}
onError={onCaptchaError}
/>
<Button
name={undefined}
Expand Down
20 changes: 16 additions & 4 deletions src/views/RecoverAccountConfirm/index.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -137,10 +137,11 @@ export function Component() {
setError(transformToFormError(
data.public.passwordResetConfirm.errors,
));
alert.show(
strings.failureMessageTitle,
{ variant: 'danger' },
);
const errorMessages = data.public.passwordResetConfirm?.errors
?.map((error: { messages: string; }) => error.messages)
.filter((message: string) => message)
.join(', ');
alert.show(errorMessages, { variant: 'danger' });
}
},
onError: () => {
Expand Down Expand Up @@ -180,6 +181,16 @@ export function Component() {
[passwordResetConfirm, userId, resetToken, alert, strings],
);

const onCaptchaError = useCallback((errorString: string) => {
setError((oldErrors) => {
const fieldErrors = getErrorObject(oldErrors);
return ({
...fieldErrors,
captcha: errorString,
});
});
}, [setError]);

const handleFormSubmit = createSubmitHandler(validate, setError, handleChangePassword);

const fieldError = getErrorObject(formError);
Expand Down Expand Up @@ -221,6 +232,7 @@ export function Component() {
<HCaptcha
name="captcha"
onChange={setFieldValue}
onError={onCaptchaError}
/>
<Button
name={undefined}
Expand Down
16 changes: 15 additions & 1 deletion src/views/Register/index.tsx
Original file line number Diff line number Diff line change
@@ -1,4 +1,7 @@
import { useState } from 'react';
import {
useCallback,
useState,
} from 'react';
import { useNavigate } from 'react-router-dom';
import {
gql,
Expand Down Expand Up @@ -196,6 +199,16 @@ export function Component() {
),
});

const onCaptchaError = useCallback((errorString: string) => {
setError((oldErrors) => {
const fieldErrors = getErrorObject(oldErrors);
return ({
...fieldErrors,
captcha: errorString,
});
});
}, [setError]);

return (
<Page
className={styles.register}
Expand Down Expand Up @@ -253,6 +266,7 @@ export function Component() {
<HCaptcha
name="captcha"
onChange={setFieldValue}
onError={onCaptchaError}
/>
<Button
name={undefined}
Expand Down

0 comments on commit ab1deff

Please sign in to comment.