import { FormGroup, Select, SelectOption, SelectVariant, Split, SplitItem, } from "@patternfly/react-core"; import { useState } from "react"; import { Controller, useFormContext } from "react-hook-form-v7"; import { useTranslation } from "react-i18next"; import { HelpItem } from "../../components/help-enabler/HelpItem"; import { TimeSelector, Unit, } from "../../components/time-selector/TimeSelector"; type TokenLifespanProps = { id: string; name: string; defaultValue?: number; units?: Unit[]; }; const inherited = "tokenLifespan.inherited"; const never = "tokenLifespan.never"; const expires = "tokenLifespan.expires"; export const TokenLifespan = ({ id, name, defaultValue, units, }: TokenLifespanProps) => { const { t } = useTranslation("clients"); const [open, setOpen] = useState(false); const [focused, setFocused] = useState(false); const onFocus = () => setFocused(true); const onBlur = () => setFocused(false); const { control } = useFormContext(); const isExpireSet = (value: string | number) => (typeof value === "number" && value !== -1) || (typeof value === "string" && value !== "" && value !== "-1") || focused; return ( } > ( {field.value !== "-1" && field.value !== -1 && ( )} )} /> ); };