import classNames from "classnames"; import React, { useEffect, useState } from "react"; import Select from "react-select"; import { useLocale } from "@calcom/lib/hooks/useLocale"; import { trpc } from "@lib/trpc"; interface Props { onChange: (value: { externalId: string; integration: string }) => void; isLoading?: boolean; hidePlaceholder?: boolean; /** The external Id of the connected calendar */ value: string | undefined; } const DestinationCalendarSelector = ({ onChange, isLoading, value, hidePlaceholder, }: Props): JSX.Element | null => { const { t } = useLocale(); const query = trpc.useQuery(["viewer.connectedCalendars"]); const [selectedOption, setSelectedOption] = useState<{ value: string; label: string } | null>(null); // Extra styles to show prefixed text in react-select const content = (hidePlaceholder = false) => { if (!hidePlaceholder) { return { alignItems: "center", display: "flex", ":before": { content: `'${t("select_destination_calendar")}:'`, display: "block", marginRight: 8, }, }; } return {}; }; useEffect(() => { const selected = query.data?.connectedCalendars .map((connected) => connected.calendars ?? []) .flat() .find((cal) => cal.externalId === value); if (selected) { setSelectedOption({ value: `${selected.integration}:${selected.externalId}`, label: selected.name || "", }); } }, [query.data?.connectedCalendars, value]); if (!query.data?.connectedCalendars.length) { return null; } const options = query.data.connectedCalendars.map((selectedCalendar) => ({ key: selectedCalendar.credentialId, label: `${selectedCalendar.integration.title} (${selectedCalendar.primary?.name})`, options: (selectedCalendar.calendars ?? []) .filter((cal) => cal.readOnly === false) .map((cal) => ({ label: cal.name || "", value: `${cal.integration}:${cal.externalId}`, })), })) ?? []; return (