2020-11-25 16:17:50 +00:00
|
|
|
import { FormGroup, Switch, TextInput } from "@patternfly/react-core";
|
2020-10-30 20:15:37 +00:00
|
|
|
import { useTranslation } from "react-i18next";
|
|
|
|
import React from "react";
|
|
|
|
import { HelpItem } from "../components/help-enabler/HelpItem";
|
2020-11-25 14:50:40 +00:00
|
|
|
import { useForm, Controller } from "react-hook-form";
|
|
|
|
import ComponentRepresentation from "keycloak-admin/lib/defs/componentRepresentation";
|
2020-11-25 16:17:50 +00:00
|
|
|
import { FormAccess } from "../components/form-access/FormAccess";
|
2020-10-30 20:15:37 +00:00
|
|
|
|
|
|
|
export const LdapSettingsSynchronization = () => {
|
|
|
|
const { t } = useTranslation("user-federation");
|
|
|
|
const helpText = useTranslation("user-federation-help").t;
|
|
|
|
|
2020-11-25 16:17:50 +00:00
|
|
|
const { register, control } = useForm<ComponentRepresentation>();
|
2020-11-25 14:50:40 +00:00
|
|
|
|
2020-10-30 20:15:37 +00:00
|
|
|
return (
|
|
|
|
<>
|
|
|
|
{/* Synchronization settings */}
|
2020-11-25 16:17:50 +00:00
|
|
|
<FormAccess role="manage-realm" isHorizontal>
|
2020-10-30 20:15:37 +00:00
|
|
|
<FormGroup
|
|
|
|
label={t("importUsers")}
|
|
|
|
labelIcon={
|
|
|
|
<HelpItem
|
|
|
|
helpText={helpText("importUsersHelp")}
|
|
|
|
forLabel={t("importUsers")}
|
|
|
|
forID="kc-import-users"
|
|
|
|
/>
|
|
|
|
}
|
|
|
|
fieldId="kc-import-users"
|
|
|
|
hasNoPaddingTop
|
|
|
|
>
|
2020-11-25 14:50:40 +00:00
|
|
|
<Controller
|
|
|
|
name="importUsers"
|
|
|
|
defaultValue={false}
|
|
|
|
control={control}
|
|
|
|
render={({ onChange, value }) => (
|
|
|
|
<Switch
|
|
|
|
id={"kc-import-users"}
|
|
|
|
isChecked={value}
|
|
|
|
isDisabled={false}
|
|
|
|
onChange={onChange}
|
|
|
|
aria-label={t("importUsers") + " " + t("common:on")}
|
|
|
|
/>
|
|
|
|
)}
|
|
|
|
></Controller>
|
2020-10-30 20:15:37 +00:00
|
|
|
</FormGroup>
|
|
|
|
<FormGroup
|
|
|
|
label={t("batchSize")}
|
|
|
|
labelIcon={
|
|
|
|
<HelpItem
|
|
|
|
helpText={helpText("batchSizeHelp")}
|
|
|
|
forLabel={t("batchSize")}
|
|
|
|
forID="kc-batch-size"
|
|
|
|
/>
|
|
|
|
}
|
|
|
|
fieldId="kc-batch-size"
|
|
|
|
>
|
2020-11-25 14:50:40 +00:00
|
|
|
<TextInput
|
|
|
|
type="text"
|
|
|
|
id="kc-batch-size"
|
|
|
|
name="batchSize"
|
|
|
|
ref={register}
|
|
|
|
/>
|
2020-10-30 20:15:37 +00:00
|
|
|
</FormGroup>
|
|
|
|
<FormGroup
|
|
|
|
label={t("periodicFullSync")}
|
|
|
|
labelIcon={
|
|
|
|
<HelpItem
|
|
|
|
helpText={helpText("periodicFullSyncHelp")}
|
|
|
|
forLabel={t("periodicFullSync")}
|
|
|
|
forID="kc-periodic-full-sync"
|
|
|
|
/>
|
|
|
|
}
|
|
|
|
fieldId="kc-periodic-full-sync"
|
|
|
|
hasNoPaddingTop
|
|
|
|
>
|
2020-11-25 14:50:40 +00:00
|
|
|
<Controller
|
|
|
|
name="periodicFullSync"
|
|
|
|
defaultValue={false}
|
|
|
|
control={control}
|
|
|
|
render={({ onChange, value }) => (
|
|
|
|
<Switch
|
|
|
|
id={"kc-periodic-full-sync"}
|
|
|
|
isChecked={value}
|
|
|
|
isDisabled={false}
|
|
|
|
onChange={onChange}
|
|
|
|
label={t("common:on")}
|
|
|
|
labelOff={t("common:off")}
|
|
|
|
/>
|
|
|
|
)}
|
|
|
|
></Controller>
|
2020-10-30 20:15:37 +00:00
|
|
|
</FormGroup>
|
|
|
|
<FormGroup
|
|
|
|
label={t("periodicChangedUsersSync")}
|
|
|
|
labelIcon={
|
|
|
|
<HelpItem
|
|
|
|
helpText={helpText("periodicChangedUsersSyncHelp")}
|
|
|
|
forLabel={t("periodicChangedUsersSync")}
|
|
|
|
forID="kc-periodic-changed-users-sync"
|
|
|
|
/>
|
|
|
|
}
|
|
|
|
fieldId="kc-periodic-changed-users-sync"
|
|
|
|
hasNoPaddingTop
|
|
|
|
>
|
2020-11-25 14:50:40 +00:00
|
|
|
<Controller
|
|
|
|
name="periodicChangedUsersSync"
|
|
|
|
defaultValue={false}
|
|
|
|
control={control}
|
|
|
|
render={({ onChange, value }) => (
|
|
|
|
<Switch
|
|
|
|
id={"kc-periodic-changed-users-sync"}
|
|
|
|
isChecked={value}
|
|
|
|
isDisabled={false}
|
|
|
|
onChange={onChange}
|
|
|
|
label={t("common:on")}
|
|
|
|
labelOff={t("common:off")}
|
|
|
|
/>
|
|
|
|
)}
|
|
|
|
></Controller>
|
2020-10-30 20:15:37 +00:00
|
|
|
</FormGroup>
|
2020-11-25 16:17:50 +00:00
|
|
|
</FormAccess>
|
2020-10-30 20:15:37 +00:00
|
|
|
</>
|
|
|
|
);
|
|
|
|
};
|