0
Fork 0
mirror of https://github.com/logto-io/logto.git synced 2025-01-06 20:40:08 -05:00

fix(console): improve error handling in connector details and sender tester

This commit is contained in:
Charles Zhao 2022-07-08 18:57:33 +08:00
parent 64bb5fd159
commit d9ce4a0154
No known key found for this signature in database
GPG key ID: 4858774754C92DF2
4 changed files with 24 additions and 14 deletions

View file

@ -21,7 +21,6 @@ type Props = {
const ConnectorContent = ({ connectorData, onConnectorUpdated }: Props) => { const ConnectorContent = ({ connectorData, onConnectorUpdated }: Props) => {
const { t } = useTranslation(undefined, { keyPrefix: 'admin_console' }); const { t } = useTranslation(undefined, { keyPrefix: 'admin_console' });
const [config, setConfig] = useState<string>(); const [config, setConfig] = useState<string>();
const [saveError, setSaveError] = useState<string>();
const [isSubmitting, setIsSubmitting] = useState(false); const [isSubmitting, setIsSubmitting] = useState(false);
const api = useApi(); const api = useApi();
@ -54,10 +53,8 @@ const ConnectorContent = ({ connectorData, onConnectorUpdated }: Props) => {
}, [config, defaultConfig]); }, [config, defaultConfig]);
const handleSave = async () => { const handleSave = async () => {
setSaveError(undefined);
if (!config) { if (!config) {
setSaveError(t('connector_details.save_error_empty_config')); toast(t('connector_details.save_error_empty_config'));
return; return;
} }
@ -78,7 +75,9 @@ const ConnectorContent = ({ connectorData, onConnectorUpdated }: Props) => {
toast.success(t('general.saved')); toast.success(t('general.saved'));
} catch (error: unknown) { } catch (error: unknown) {
if (error instanceof SyntaxError) { if (error instanceof SyntaxError) {
setSaveError(t('connector_details.save_error_json_parse_error')); toast.error(t('connector_details.save_error_json_parse_error'));
} else {
toast.error(t('errors.unexpected_error'));
} }
} }
@ -105,7 +104,6 @@ const ConnectorContent = ({ connectorData, onConnectorUpdated }: Props) => {
config={config} config={config}
/> />
)} )}
{saveError && <div>{saveError}</div>}
</div> </div>
<div className={detailsStyles.footer}> <div className={detailsStyles.footer}>
<div className={detailsStyles.footerMain}> <div className={detailsStyles.footerMain}>

View file

@ -3,6 +3,7 @@ import { phoneRegEx, emailRegEx } from '@logto/shared';
import classNames from 'classnames'; import classNames from 'classnames';
import React, { useEffect, useRef, useState } from 'react'; import React, { useEffect, useRef, useState } from 'react';
import { useForm } from 'react-hook-form'; import { useForm } from 'react-hook-form';
import { toast } from 'react-hot-toast';
import { useTranslation } from 'react-i18next'; import { useTranslation } from 'react-i18next';
import Button from '@/components/Button'; import Button from '@/components/Button';
@ -55,16 +56,25 @@ const SenderTester = ({ connectorId, connectorType, config, className }: Props)
const onSubmit = handleSubmit(async (formData) => { const onSubmit = handleSubmit(async (formData) => {
const { sendTo } = formData; const { sendTo } = formData;
const configJson = config ? (JSON.parse(config) as JSON) : undefined;
const data = { config: configJson, ...(isSms ? { phone: sendTo } : { email: sendTo }) }; try {
const configJson = config ? (JSON.parse(config) as JSON) : undefined;
const data = { config: configJson, ...(isSms ? { phone: sendTo } : { email: sendTo }) };
await api await api
.post(`/api/connectors/${connectorId}/test`, { .post(`/api/connectors/${connectorId}/test`, {
json: data, json: data,
}) })
.json(); .json();
setShowTooltip(true);
setShowTooltip(true);
} catch (error: unknown) {
if (error instanceof SyntaxError) {
toast.error(t('connector_details.save_error_json_parse_error'));
} else {
toast.error(t('errors.unexpected_error'));
}
}
}); });
return ( return (

View file

@ -59,6 +59,7 @@ const translation = {
username_pattern_error: username_pattern_error:
'Username should only contain letters, numbers, or underscore and should not start with a number.', 'Username should only contain letters, numbers, or underscore and should not start with a number.',
password_pattern_error: 'Password requires a minimum of 6 characters', password_pattern_error: 'Password requires a minimum of 6 characters',
unexpected_error: 'An unexpected error occurred',
}, },
tab_sections: { tab_sections: {
overview: 'Overview', overview: 'Overview',

View file

@ -59,6 +59,7 @@ const translation = {
more_details: '查看详情', more_details: '查看详情',
username_pattern_error: '用户名只能包含英文字母、数字或下划线,且不以数字开头。', username_pattern_error: '用户名只能包含英文字母、数字或下划线,且不以数字开头。',
password_pattern_error: '密码应不少于 6 位', password_pattern_error: '密码应不少于 6 位',
unexpected_error: '发生未知错误',
}, },
tab_sections: { tab_sections: {
overview: '概览', overview: '概览',