mirror of
https://github.com/logto-io/logto.git
synced 2025-01-06 20:40:08 -05:00
chore: reorg webhook-related file structures (#4447)
This commit is contained in:
parent
2dfce739b1
commit
fd08426935
16 changed files with 16 additions and 22 deletions
|
@ -1,4 +1,4 @@
|
||||||
import { HookEvent } from '@logto/schemas';
|
import { HookEvent, type Hook, type HookConfig } from '@logto/schemas';
|
||||||
import { Controller, useFormContext } from 'react-hook-form';
|
import { Controller, useFormContext } from 'react-hook-form';
|
||||||
import { useTranslation } from 'react-i18next';
|
import { useTranslation } from 'react-i18next';
|
||||||
|
|
||||||
|
@ -8,8 +8,6 @@ import FormField from '@/ds-components/FormField';
|
||||||
import TextInput from '@/ds-components/TextInput';
|
import TextInput from '@/ds-components/TextInput';
|
||||||
import { uriValidator } from '@/utils/validator';
|
import { uriValidator } from '@/utils/validator';
|
||||||
|
|
||||||
import { type BasicWebhookFormType } from '../../types';
|
|
||||||
|
|
||||||
import * as styles from './index.module.scss';
|
import * as styles from './index.module.scss';
|
||||||
|
|
||||||
const hookEventOptions = Object.values(HookEvent).map((event) => ({
|
const hookEventOptions = Object.values(HookEvent).map((event) => ({
|
||||||
|
@ -17,6 +15,12 @@ const hookEventOptions = Object.values(HookEvent).map((event) => ({
|
||||||
value: event,
|
value: event,
|
||||||
}));
|
}));
|
||||||
|
|
||||||
|
export type BasicWebhookFormType = {
|
||||||
|
name: Hook['name'];
|
||||||
|
events: HookEvent[];
|
||||||
|
url: HookConfig['url'];
|
||||||
|
};
|
||||||
|
|
||||||
function BasicWebhookForm() {
|
function BasicWebhookForm() {
|
||||||
const { t } = useTranslation(undefined, { keyPrefix: 'admin_console' });
|
const { t } = useTranslation(undefined, { keyPrefix: 'admin_console' });
|
||||||
const {
|
const {
|
|
@ -4,20 +4,20 @@ import { toast } from 'react-hot-toast';
|
||||||
import { useTranslation } from 'react-i18next';
|
import { useTranslation } from 'react-i18next';
|
||||||
import { useOutletContext } from 'react-router-dom';
|
import { useOutletContext } from 'react-router-dom';
|
||||||
|
|
||||||
|
import BasicWebhookForm from '@/components/BasicWebhookForm';
|
||||||
import DetailsForm from '@/components/DetailsForm';
|
import DetailsForm from '@/components/DetailsForm';
|
||||||
import FormCard from '@/components/FormCard';
|
import FormCard from '@/components/FormCard';
|
||||||
import UnsavedChangesAlertModal from '@/components/UnsavedChangesAlertModal';
|
import UnsavedChangesAlertModal from '@/components/UnsavedChangesAlertModal';
|
||||||
import useApi from '@/hooks/use-api';
|
import useApi from '@/hooks/use-api';
|
||||||
import useDocumentationUrl from '@/hooks/use-documentation-url';
|
import useDocumentationUrl from '@/hooks/use-documentation-url';
|
||||||
import BasicWebhookForm from '@/pages/Webhooks/components/BasicWebhookForm';
|
|
||||||
import { trySubmitSafe } from '@/utils/form';
|
import { trySubmitSafe } from '@/utils/form';
|
||||||
|
|
||||||
import { type WebhookDetailsFormType, type WebhookDetailsOutletContext } from '../types';
|
import { type WebhookDetailsFormType, type WebhookDetailsOutletContext } from '../types';
|
||||||
import { webhookDetailsParser } from '../utils';
|
import { webhookDetailsParser } from '../utils';
|
||||||
|
|
||||||
import CustomHeaderField from './components/CustomHeaderField';
|
import CustomHeaderField from './CustomHeaderField';
|
||||||
import SigningKeyField from './components/SigningKeyField';
|
import SigningKeyField from './SigningKeyField';
|
||||||
import TestWebhook from './components/TestWebhook';
|
import TestWebhook from './TestWebhook';
|
||||||
|
|
||||||
function WebhookSettings() {
|
function WebhookSettings() {
|
||||||
const { t } = useTranslation(undefined, { keyPrefix: 'admin_console' });
|
const { t } = useTranslation(undefined, { keyPrefix: 'admin_console' });
|
||||||
|
|
|
@ -15,6 +15,7 @@ import WebhookDark from '@/assets/icons/webhook-dark.svg';
|
||||||
import Webhook from '@/assets/icons/webhook.svg';
|
import Webhook from '@/assets/icons/webhook.svg';
|
||||||
import DetailsPage from '@/components/DetailsPage';
|
import DetailsPage from '@/components/DetailsPage';
|
||||||
import PageMeta from '@/components/PageMeta';
|
import PageMeta from '@/components/PageMeta';
|
||||||
|
import SuccessRate from '@/components/SuccessRate';
|
||||||
import { WebhookDetailsTabs } from '@/consts';
|
import { WebhookDetailsTabs } from '@/consts';
|
||||||
import ActionMenu, { ActionMenuItem } from '@/ds-components/ActionMenu';
|
import ActionMenu, { ActionMenuItem } from '@/ds-components/ActionMenu';
|
||||||
import Card from '@/ds-components/Card';
|
import Card from '@/ds-components/Card';
|
||||||
|
@ -28,8 +29,6 @@ import useTenantPathname from '@/hooks/use-tenant-pathname';
|
||||||
import useTheme from '@/hooks/use-theme';
|
import useTheme from '@/hooks/use-theme';
|
||||||
import { buildUrl } from '@/utils/url';
|
import { buildUrl } from '@/utils/url';
|
||||||
|
|
||||||
import SuccessRate from '../Webhooks/components/SuccessRate';
|
|
||||||
|
|
||||||
import * as styles from './index.module.scss';
|
import * as styles from './index.module.scss';
|
||||||
import { type WebhookDetailsOutletContext } from './types';
|
import { type WebhookDetailsOutletContext } from './types';
|
||||||
|
|
||||||
|
|
|
@ -1,6 +1,6 @@
|
||||||
import { type HookResponse, type Hook } from '@logto/schemas';
|
import { type HookResponse, type Hook } from '@logto/schemas';
|
||||||
|
|
||||||
import { type BasicWebhookFormType } from '../Webhooks/types';
|
import { type BasicWebhookFormType } from '@/components/BasicWebhookForm';
|
||||||
|
|
||||||
export type WebhookDetailsOutletContext = {
|
export type WebhookDetailsOutletContext = {
|
||||||
hook: HookResponse;
|
hook: HookResponse;
|
||||||
|
|
|
@ -3,6 +3,7 @@ import { useContext } from 'react';
|
||||||
import { FormProvider, useForm } from 'react-hook-form';
|
import { FormProvider, useForm } from 'react-hook-form';
|
||||||
import { Trans, useTranslation } from 'react-i18next';
|
import { Trans, useTranslation } from 'react-i18next';
|
||||||
|
|
||||||
|
import BasicWebhookForm, { type BasicWebhookFormType } from '@/components/BasicWebhookForm';
|
||||||
import ContactUsPhraseLink from '@/components/ContactUsPhraseLink';
|
import ContactUsPhraseLink from '@/components/ContactUsPhraseLink';
|
||||||
import PlanName from '@/components/PlanName';
|
import PlanName from '@/components/PlanName';
|
||||||
import QuotaGuardFooter from '@/components/QuotaGuardFooter';
|
import QuotaGuardFooter from '@/components/QuotaGuardFooter';
|
||||||
|
@ -14,9 +15,6 @@ import useSubscriptionPlan from '@/hooks/use-subscription-plan';
|
||||||
import { trySubmitSafe } from '@/utils/form';
|
import { trySubmitSafe } from '@/utils/form';
|
||||||
import { hasReachedQuotaLimit } from '@/utils/quota';
|
import { hasReachedQuotaLimit } from '@/utils/quota';
|
||||||
|
|
||||||
import { type BasicWebhookFormType } from '../../types';
|
|
||||||
import BasicWebhookForm from '../BasicWebhookForm';
|
|
||||||
|
|
||||||
type Props = {
|
type Props = {
|
||||||
totalWebhookCount: number;
|
totalWebhookCount: number;
|
||||||
onClose: (createdHook?: Hook) => void;
|
onClose: (createdHook?: Hook) => void;
|
|
@ -13,6 +13,7 @@ import WebhooksEmptyDark from '@/assets/images/webhooks-empty-dark.svg';
|
||||||
import WebhooksEmpty from '@/assets/images/webhooks-empty.svg';
|
import WebhooksEmpty from '@/assets/images/webhooks-empty.svg';
|
||||||
import ItemPreview from '@/components/ItemPreview';
|
import ItemPreview from '@/components/ItemPreview';
|
||||||
import ListPage from '@/components/ListPage';
|
import ListPage from '@/components/ListPage';
|
||||||
|
import SuccessRate from '@/components/SuccessRate';
|
||||||
import { defaultPageSize } from '@/consts';
|
import { defaultPageSize } from '@/consts';
|
||||||
import { hookEventLabel } from '@/consts/webhooks';
|
import { hookEventLabel } from '@/consts/webhooks';
|
||||||
import Button from '@/ds-components/Button';
|
import Button from '@/ds-components/Button';
|
||||||
|
@ -25,8 +26,7 @@ import useTenantPathname from '@/hooks/use-tenant-pathname';
|
||||||
import useTheme from '@/hooks/use-theme';
|
import useTheme from '@/hooks/use-theme';
|
||||||
import { buildUrl } from '@/utils/url';
|
import { buildUrl } from '@/utils/url';
|
||||||
|
|
||||||
import CreateFormModal from './components/CreateFormModal';
|
import CreateFormModal from './CreateFormModal';
|
||||||
import SuccessRate from './components/SuccessRate';
|
|
||||||
import * as styles from './index.module.scss';
|
import * as styles from './index.module.scss';
|
||||||
|
|
||||||
const pageSize = defaultPageSize;
|
const pageSize = defaultPageSize;
|
||||||
|
|
|
@ -1,7 +0,0 @@
|
||||||
import { type Hook, type HookConfig, type HookEvent } from '@logto/schemas';
|
|
||||||
|
|
||||||
export type BasicWebhookFormType = {
|
|
||||||
name: Hook['name'];
|
|
||||||
events: HookEvent[];
|
|
||||||
url: HookConfig['url'];
|
|
||||||
};
|
|
Loading…
Reference in a new issue