import { usePathname, useRouter } from "next/navigation"; import { useCompatSearchParams } from "@calcom/lib/hooks/useCompatSearchParams"; import { useLocale } from "@calcom/lib/hooks/useLocale"; import type { ButtonColor } from "@calcom/ui"; import { Avatar, Button, Dropdown, DropdownItem, DropdownMenuContent, DropdownMenuItem, DropdownMenuLabel, DropdownMenuTrigger, } from "@calcom/ui"; export interface Option { platform?: boolean; teamId: number | null | undefined; // if undefined, then it's a profile label: string | null; image: string | null; slug: string | null; } export type CreateBtnProps = { options: Option[]; createDialog?: () => JSX.Element; createFunction?: (teamId?: number, platform?: boolean) => void; subtitle?: string; buttonText?: string; isPending?: boolean; disableMobileButton?: boolean; "data-testid"?: string; color?: ButtonColor; }; /** * @deprecated use CreateButtonWithTeamsList instead */ export function CreateButton(props: CreateBtnProps) { const { t } = useLocale(); const router = useRouter(); const searchParams = useCompatSearchParams(); const pathname = usePathname(); const { createDialog, options, isPending, createFunction, buttonText, disableMobileButton, subtitle, ...restProps } = props; const CreateDialog = createDialog ? createDialog() : null; const hasTeams = !!options.find((option) => option.teamId); const platform = !!options.find((option) => option.platform); // inject selection data into url for correct router history const openModal = (option: Option) => { const _searchParams = new URLSearchParams(searchParams ?? undefined); function setParamsIfDefined(key: string, value: string | number | boolean | null | undefined) { if (value !== undefined && value !== null) _searchParams.set(key, value.toString()); } setParamsIfDefined("dialog", "new"); setParamsIfDefined("eventPage", option.slug); setParamsIfDefined("teamId", option.teamId); if (!option.teamId) { _searchParams.delete("teamId"); } router.push(`${pathname}?${_searchParams.toString()}`); }; return ( <> {!hasTeams && !platform ? ( ) : (
{subtitle}
{options.map((option, idx) => ( } onClick={() => !!CreateDialog ? openModal(option) : createFunction ? createFunction(option.teamId || undefined, option.platform) : null }> {" "} {/*improve this code */} {option.label} ))}
)} {searchParams?.get("dialog") === "new" && CreateDialog} ); }