mirror of
https://github.com/logto-io/logto.git
synced 2025-01-06 20:40:08 -05:00
fix(console): switch component (#3736)
This commit is contained in:
parent
9f14e065e8
commit
dbbd766220
2 changed files with 8 additions and 17 deletions
|
@ -3,16 +3,16 @@ import { forwardRef } from 'react';
|
|||
|
||||
import * as styles from './index.module.scss';
|
||||
|
||||
type Props = Omit<HTMLProps<HTMLInputElement>, 'value'> & {
|
||||
type Props = HTMLProps<HTMLInputElement> & {
|
||||
label?: ReactNode;
|
||||
};
|
||||
|
||||
function Switch({ label, checked = false, ...rest }: Props, ref?: Ref<HTMLInputElement>) {
|
||||
function Switch({ label, ...rest }: Props, ref?: Ref<HTMLInputElement>) {
|
||||
return (
|
||||
<div className={styles.wrapper}>
|
||||
<div className={styles.label}>{label}</div>
|
||||
<label className={styles.switch}>
|
||||
<input type="checkbox" checked={checked} {...rest} ref={ref} />
|
||||
<input type="checkbox" {...rest} ref={ref} />
|
||||
<span className={styles.slider} />
|
||||
</label>
|
||||
</div>
|
||||
|
|
|
@ -1,6 +1,6 @@
|
|||
import type { Application, SnakeCaseOidcConfig } from '@logto/schemas';
|
||||
import { ApplicationType } from '@logto/schemas';
|
||||
import { Controller, useFormContext } from 'react-hook-form';
|
||||
import { useFormContext } from 'react-hook-form';
|
||||
import { Trans, useTranslation } from 'react-i18next';
|
||||
|
||||
import CopyToClipboard from '@/components/CopyToClipboard';
|
||||
|
@ -17,7 +17,7 @@ type Props = {
|
|||
};
|
||||
|
||||
function AdvancedSettings({ applicationType, oidcConfig }: Props) {
|
||||
const { control } = useFormContext<Application & { isAdmin: boolean }>();
|
||||
const { register } = useFormContext<Application & { isAdmin?: boolean }>();
|
||||
const { t } = useTranslation(undefined, { keyPrefix: 'admin_console' });
|
||||
|
||||
return (
|
||||
|
@ -66,18 +66,9 @@ function AdvancedSettings({ applicationType, oidcConfig }: Props) {
|
|||
</FormField>
|
||||
{applicationType === ApplicationType.MachineToMachine && (
|
||||
<FormField title="application_details.enable_admin_access">
|
||||
<Controller
|
||||
name="isAdmin"
|
||||
control={control}
|
||||
render={({ field: { onChange, value } }) => (
|
||||
<Switch
|
||||
label={t('application_details.enable_admin_access_label')}
|
||||
checked={value}
|
||||
onChange={({ currentTarget: { checked } }) => {
|
||||
onChange(checked);
|
||||
}}
|
||||
/>
|
||||
)}
|
||||
{...register('isAdmin')}
|
||||
/>
|
||||
</FormField>
|
||||
)}
|
||||
|
|
Loading…
Reference in a new issue