75 lines
2.2 KiB
TypeScript
75 lines
2.2 KiB
TypeScript
|
import { useState } from "react";
|
||
|
import { UseFormReturn } from "react-hook-form";
|
||
|
|
||
|
import { useLocale } from "@calcom/lib/hooks/useLocale";
|
||
|
import {
|
||
|
Dropdown,
|
||
|
DropdownMenuContent,
|
||
|
DropdownMenuItem,
|
||
|
DropdownMenuTrigger,
|
||
|
Icon,
|
||
|
TextField,
|
||
|
} from "@calcom/ui";
|
||
|
|
||
|
import { getWorkflowTimeUnitOptions } from "../lib/getOptions";
|
||
|
import type { FormValues } from "../pages/workflow";
|
||
|
|
||
|
type Props = {
|
||
|
form: UseFormReturn<FormValues>;
|
||
|
};
|
||
|
|
||
|
export const TimeTimeUnitInput = (props: Props) => {
|
||
|
const { form } = props;
|
||
|
const { t } = useLocale();
|
||
|
const timeUnitOptions = getWorkflowTimeUnitOptions(t);
|
||
|
|
||
|
const [timeUnit, setTimeUnit] = useState(form.getValues("timeUnit"));
|
||
|
|
||
|
return (
|
||
|
<div className="flex">
|
||
|
<div className="grow">
|
||
|
<TextField
|
||
|
type="number"
|
||
|
min="1"
|
||
|
label=""
|
||
|
defaultValue={form.getValues("time") || 24}
|
||
|
className="-mt-2 rounded-r-none text-sm focus:ring-0"
|
||
|
{...form.register("time", { valueAsNumber: true })}
|
||
|
/>
|
||
|
</div>
|
||
|
<div>
|
||
|
<Dropdown>
|
||
|
<DropdownMenuTrigger asChild>
|
||
|
<button className="-ml-1 h-9 w-24 rounded-none rounded-r-md border border-gray-300 bg-gray-50 px-3 py-1 text-sm">
|
||
|
<div className="flex">
|
||
|
<div className="w-3/4">
|
||
|
{timeUnit ? t(`${timeUnit.toLowerCase()}_timeUnit`) : "undefined"}{" "}
|
||
|
</div>
|
||
|
<div className="w-1/4 pt-1">
|
||
|
<Icon.FiChevronDown />
|
||
|
</div>
|
||
|
</div>
|
||
|
</button>
|
||
|
</DropdownMenuTrigger>
|
||
|
<DropdownMenuContent>
|
||
|
{timeUnitOptions.map((option, index) => (
|
||
|
<DropdownMenuItem key={index} className="outline-none">
|
||
|
<button
|
||
|
key={index}
|
||
|
type="button"
|
||
|
className="h-8 w-20 justify-start pl-3 text-left text-sm"
|
||
|
onClick={() => {
|
||
|
setTimeUnit(option.value);
|
||
|
form.setValue("timeUnit", option.value);
|
||
|
}}>
|
||
|
{option.label}
|
||
|
</button>
|
||
|
</DropdownMenuItem>
|
||
|
))}
|
||
|
</DropdownMenuContent>
|
||
|
</Dropdown>
|
||
|
</div>
|
||
|
</div>
|
||
|
);
|
||
|
};
|