import type ComponentRepresentation from "@keycloak/keycloak-admin-client/lib/defs/componentRepresentation"; import { Button, ButtonVariant, DataList, DataListCell, DataListControl, DataListDragButton, DataListItem, DataListItemCells, DataListItemRow, Modal, ModalVariant, Text, TextContent, } from "@patternfly/react-core"; import { sortBy } from "lodash-es"; import { useState } from "react"; import { useTranslation } from "react-i18next"; import { adminClient } from "../admin-client"; import { useAlerts } from "../components/alert/Alerts"; type ManagePriorityDialogProps = { components: ComponentRepresentation[]; onClose: () => void; }; export const ManagePriorityDialog = ({ components, onClose, }: ManagePriorityDialogProps) => { const { t } = useTranslation("user-federation"); const { addAlert, addError } = useAlerts(); const [id, setId] = useState(""); const [liveText, setLiveText] = useState(""); const [order, setOrder] = useState( components.map((component) => component.name!) ); const onDragStart = (id: string) => { setId(id); setLiveText(t("common:onDragStart", { item: id })); }; const onDragMove = () => { setLiveText(t("common:onDragMove", { item: id })); }; const onDragCancel = () => { setLiveText(t("common:onDragCancel")); }; const onDragFinish = (providerOrder: string[]) => { setLiveText(t("common:onDragFinish", { list: providerOrder })); setOrder(providerOrder); }; return ( { const updates = order.map((name, index) => { const component = components!.find((c) => c.name === name)!; component.config!.priority = [index.toString()]; return adminClient.components.update( { id: component.id! }, component ); }); try { await Promise.all(updates); addAlert(t("orderChangeSuccess")); } catch (error) { addError("orderChangeError", error); } onClose(); }} > {t("common:save")} , , ]} > {t("managePriorityInfo")} {sortBy(components, "config.priority", "name").map((component) => ( {component.name} , ]} /> ))}
{liveText}
); };