2020-09-17 13:51:40 +00:00
|
|
|
import React from "react";
|
2020-09-22 12:43:51 +00:00
|
|
|
import { useTranslation } from "react-i18next";
|
2020-08-31 18:26:25 +00:00
|
|
|
import {
|
|
|
|
FormGroup,
|
|
|
|
Switch,
|
|
|
|
Checkbox,
|
|
|
|
Grid,
|
|
|
|
GridItem,
|
2020-09-17 13:51:40 +00:00
|
|
|
Form,
|
2020-08-31 18:26:25 +00:00
|
|
|
} from "@patternfly/react-core";
|
2020-09-17 13:51:40 +00:00
|
|
|
import { UseFormMethods, Controller } from "react-hook-form";
|
2020-08-31 18:26:25 +00:00
|
|
|
|
2020-09-22 12:43:51 +00:00
|
|
|
type CapabilityConfigProps = {
|
2020-09-17 13:51:40 +00:00
|
|
|
form: UseFormMethods;
|
2020-08-31 18:26:25 +00:00
|
|
|
};
|
|
|
|
|
2020-09-22 12:43:51 +00:00
|
|
|
export const CapabilityConfig = ({ form }: CapabilityConfigProps) => {
|
2020-09-17 13:51:40 +00:00
|
|
|
const { t } = useTranslation("clients");
|
|
|
|
return (
|
|
|
|
<Form isHorizontal>
|
|
|
|
<FormGroup label={t("clientAuthentication")} fieldId="kc-authentication">
|
|
|
|
<Controller
|
|
|
|
name="publicClient"
|
|
|
|
control={form.control}
|
|
|
|
render={({ onChange, value }) => (
|
|
|
|
<Switch
|
|
|
|
id="kc-authentication"
|
|
|
|
name="publicClient"
|
|
|
|
label={t("common:on")}
|
|
|
|
labelOff={t("common:off")}
|
|
|
|
isChecked={value}
|
|
|
|
onChange={onChange}
|
|
|
|
/>
|
|
|
|
)}
|
|
|
|
/>
|
|
|
|
</FormGroup>
|
2020-09-22 12:43:51 +00:00
|
|
|
<FormGroup label={t("clientAuthorization")} fieldId="kc-authorization">
|
2020-09-17 13:51:40 +00:00
|
|
|
<Controller
|
|
|
|
name="authorizationServicesEnabled"
|
|
|
|
control={form.control}
|
|
|
|
render={({ onChange, value }) => (
|
|
|
|
<Switch
|
2020-09-22 12:43:51 +00:00
|
|
|
id="kc-authorization"
|
2020-09-17 13:51:40 +00:00
|
|
|
name="authorizationServicesEnabled"
|
|
|
|
label={t("common:on")}
|
|
|
|
labelOff={t("common:off")}
|
|
|
|
isChecked={value}
|
|
|
|
onChange={onChange}
|
|
|
|
/>
|
|
|
|
)}
|
|
|
|
/>
|
|
|
|
</FormGroup>
|
|
|
|
<FormGroup label={t("authenticationFlow")} fieldId="kc-flow">
|
|
|
|
<Grid>
|
2020-09-23 19:19:02 +00:00
|
|
|
<GridItem lg={4} sm={6}>
|
2020-09-17 13:51:40 +00:00
|
|
|
<Controller
|
|
|
|
name="standardFlowEnabled"
|
|
|
|
control={form.control}
|
|
|
|
render={({ onChange, value }) => (
|
|
|
|
<Checkbox
|
|
|
|
label={t("standardFlow")}
|
|
|
|
id="kc-flow-standard"
|
|
|
|
name="standardFlowEnabled"
|
|
|
|
isChecked={value}
|
|
|
|
onChange={onChange}
|
|
|
|
/>
|
|
|
|
)}
|
|
|
|
/>
|
|
|
|
</GridItem>
|
2020-09-23 19:19:02 +00:00
|
|
|
<GridItem lg={8} sm={6}>
|
2020-09-17 13:51:40 +00:00
|
|
|
<Controller
|
|
|
|
name="directAccessGrantsEnabled"
|
|
|
|
control={form.control}
|
|
|
|
render={({ onChange, value }) => (
|
|
|
|
<Checkbox
|
|
|
|
label={t("directAccess")}
|
|
|
|
id="kc-flow-direct"
|
|
|
|
name="directAccessGrantsEnabled"
|
|
|
|
isChecked={value}
|
|
|
|
onChange={onChange}
|
|
|
|
/>
|
|
|
|
)}
|
|
|
|
/>
|
|
|
|
</GridItem>
|
2020-09-23 19:19:02 +00:00
|
|
|
<GridItem lg={4} sm={6}>
|
2020-09-17 13:51:40 +00:00
|
|
|
<Controller
|
|
|
|
name="implicitFlowEnabled"
|
|
|
|
control={form.control}
|
|
|
|
render={({ onChange, value }) => (
|
|
|
|
<Checkbox
|
2020-09-22 12:43:51 +00:00
|
|
|
label={t("implicitFlow")}
|
|
|
|
id="kc-flow-implicit"
|
2020-09-17 13:51:40 +00:00
|
|
|
name="implicitFlowEnabled"
|
|
|
|
isChecked={value}
|
|
|
|
onChange={onChange}
|
|
|
|
/>
|
|
|
|
)}
|
|
|
|
/>
|
|
|
|
</GridItem>
|
2020-09-23 19:19:02 +00:00
|
|
|
<GridItem lg={8} sm={6}>
|
2020-09-17 13:51:40 +00:00
|
|
|
<Controller
|
|
|
|
name="serviceAccountsEnabled"
|
|
|
|
control={form.control}
|
|
|
|
render={({ onChange, value }) => (
|
|
|
|
<Checkbox
|
|
|
|
label={t("serviceAccount")}
|
|
|
|
id="kc-flow-service-account"
|
|
|
|
name="serviceAccountsEnabled"
|
|
|
|
isChecked={value}
|
|
|
|
onChange={onChange}
|
|
|
|
/>
|
|
|
|
)}
|
|
|
|
/>
|
|
|
|
</GridItem>
|
|
|
|
</Grid>
|
|
|
|
</FormGroup>
|
|
|
|
</Form>
|
|
|
|
);
|
|
|
|
};
|