2022-10-12 08:39:14 +00:00
|
|
|
import { SchedulingType } from "@prisma/client";
|
2022-11-28 18:14:01 +00:00
|
|
|
import { FC, ReactNode, useEffect } from "react";
|
2022-10-12 08:39:14 +00:00
|
|
|
|
2022-12-05 12:12:14 +00:00
|
|
|
import dayjs from "@calcom/dayjs";
|
2022-10-12 08:39:14 +00:00
|
|
|
import { classNames } from "@calcom/lib";
|
|
|
|
import { useLocale } from "@calcom/lib/hooks/useLocale";
|
2022-11-28 18:14:01 +00:00
|
|
|
import { Icon, Badge } from "@calcom/ui";
|
|
|
|
|
|
|
|
import useRouterQuery from "@lib/hooks/useRouterQuery";
|
2022-10-12 08:39:14 +00:00
|
|
|
|
|
|
|
import { UserAvatars } from "@components/booking/UserAvatars";
|
|
|
|
import EventTypeDescriptionSafeHTML from "@components/eventtype/EventTypeDescriptionSafeHTML";
|
|
|
|
|
|
|
|
import type { AvailabilityPageProps } from "../../pages/[user]/[type]";
|
|
|
|
import type { BookPageProps } from "../../pages/[user]/book";
|
|
|
|
import type { DynamicAvailabilityPageProps } from "../../pages/d/[link]/[slug]";
|
|
|
|
import type { HashLinkPageProps } from "../../pages/d/[link]/book";
|
|
|
|
import type { AvailabilityTeamPageProps } from "../../pages/team/[slug]/[type]";
|
|
|
|
import type { TeamBookingPageProps } from "../../pages/team/[slug]/book";
|
|
|
|
import { AvailableEventLocations } from "./AvailableEventLocations";
|
|
|
|
|
|
|
|
interface Props {
|
|
|
|
profile:
|
|
|
|
| AvailabilityPageProps["profile"]
|
|
|
|
| HashLinkPageProps["profile"]
|
|
|
|
| TeamBookingPageProps["profile"]
|
|
|
|
| BookPageProps["profile"]
|
|
|
|
| AvailabilityTeamPageProps["profile"]
|
|
|
|
| DynamicAvailabilityPageProps["profile"];
|
|
|
|
eventType:
|
|
|
|
| AvailabilityPageProps["eventType"]
|
|
|
|
| HashLinkPageProps["eventType"]
|
|
|
|
| TeamBookingPageProps["eventType"]
|
|
|
|
| BookPageProps["eventType"]
|
|
|
|
| AvailabilityTeamPageProps["eventType"]
|
|
|
|
| DynamicAvailabilityPageProps["eventType"];
|
|
|
|
isBookingPage?: boolean;
|
|
|
|
children: ReactNode;
|
|
|
|
isMobile?: boolean;
|
2022-10-17 13:47:11 +00:00
|
|
|
rescheduleUid?: string;
|
2022-10-12 08:39:14 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
const BookingDescription: FC<Props> = (props) => {
|
|
|
|
const { profile, eventType, isBookingPage = false, children } = props;
|
2022-12-05 12:12:14 +00:00
|
|
|
const { date: bookingDate } = useRouterQuery("date");
|
2022-10-12 08:39:14 +00:00
|
|
|
const { t } = useLocale();
|
2022-11-28 18:14:01 +00:00
|
|
|
const { duration, setQuery: setDuration } = useRouterQuery("duration");
|
|
|
|
useEffect(() => {
|
|
|
|
if (eventType.metadata?.multipleDuration !== undefined) {
|
|
|
|
if (!duration) {
|
|
|
|
setDuration(eventType.length);
|
|
|
|
} else {
|
|
|
|
if (!eventType.metadata?.multipleDuration.includes(Number(duration))) {
|
|
|
|
setDuration(eventType.length);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
2022-12-21 10:14:56 +00:00
|
|
|
}, [setDuration, eventType.length, eventType.metadata?.multipleDuration, duration]);
|
2022-12-05 12:12:14 +00:00
|
|
|
let requiresConfirmation = eventType?.requiresConfirmation;
|
|
|
|
let requiresConfirmationText = t("requires_confirmation");
|
|
|
|
const rcThreshold = eventType?.metadata?.requiresConfirmationThreshold;
|
|
|
|
if (rcThreshold) {
|
|
|
|
if (isBookingPage) {
|
|
|
|
if (dayjs(bookingDate).diff(dayjs(), rcThreshold.unit) > rcThreshold.time) {
|
|
|
|
requiresConfirmation = false;
|
|
|
|
}
|
|
|
|
} else {
|
|
|
|
requiresConfirmationText = t("requires_confirmation_threshold", {
|
|
|
|
...rcThreshold,
|
|
|
|
unit: rcThreshold.unit.slice(0, -1),
|
|
|
|
});
|
|
|
|
}
|
|
|
|
}
|
2022-10-12 08:39:14 +00:00
|
|
|
return (
|
|
|
|
<>
|
|
|
|
<UserAvatars
|
|
|
|
profile={profile}
|
|
|
|
users={eventType.users}
|
|
|
|
showMembers={eventType.schedulingType !== SchedulingType.ROUND_ROBIN}
|
|
|
|
size={10}
|
|
|
|
truncateAfter={3}
|
|
|
|
/>
|
|
|
|
<h2 className="mt-2 break-words text-sm font-medium text-gray-600 dark:text-gray-300">
|
|
|
|
{profile.name}
|
|
|
|
</h2>
|
|
|
|
<h1 className="font-cal dark:text-darkgray-900 mb-6 break-words text-2xl font-semibold text-gray-900">
|
|
|
|
{eventType.title}
|
|
|
|
</h1>
|
2022-11-22 12:04:06 +00:00
|
|
|
<div className="dark:text-darkgray-600 flex flex-col space-y-4 text-sm font-medium text-gray-600">
|
2022-10-12 08:39:14 +00:00
|
|
|
{eventType?.description && (
|
|
|
|
<div
|
|
|
|
className={classNames(
|
|
|
|
"flex",
|
|
|
|
isBookingPage && "dark:text-darkgray-600 text-sm font-medium text-gray-600"
|
|
|
|
)}>
|
|
|
|
<div>
|
|
|
|
<Icon.FiInfo
|
|
|
|
className={classNames(
|
|
|
|
"mr-[10px] ml-[2px] inline-block h-4 w-4",
|
|
|
|
isBookingPage && "dark:text-darkgray-600 -mt-1 text-gray-500"
|
|
|
|
)}
|
|
|
|
/>
|
|
|
|
</div>
|
2022-10-27 08:04:33 +00:00
|
|
|
<div className="max-w-[calc(100%_-_2rem)] flex-shrink break-words">
|
|
|
|
<EventTypeDescriptionSafeHTML eventType={eventType} />
|
|
|
|
</div>
|
2022-10-12 08:39:14 +00:00
|
|
|
</div>
|
|
|
|
)}
|
2022-12-05 12:12:14 +00:00
|
|
|
{requiresConfirmation && (
|
2022-10-12 08:39:14 +00:00
|
|
|
<div
|
|
|
|
className={classNames(
|
2022-12-05 12:12:14 +00:00
|
|
|
"items-top flex",
|
2022-10-12 08:39:14 +00:00
|
|
|
isBookingPage && "dark:text-darkgray-600 text-sm font-medium text-gray-600"
|
|
|
|
)}>
|
|
|
|
<div>
|
2022-12-05 12:12:14 +00:00
|
|
|
<Icon.FiCheckSquare className="mr-[10px] ml-[2px] inline-block h-4 w-4 " />
|
2022-10-12 08:39:14 +00:00
|
|
|
</div>
|
2022-12-05 12:12:14 +00:00
|
|
|
{requiresConfirmationText}
|
2022-10-12 08:39:14 +00:00
|
|
|
</div>
|
|
|
|
)}
|
2022-10-19 15:54:18 +00:00
|
|
|
<AvailableEventLocations
|
|
|
|
locations={eventType.locations as AvailabilityPageProps["eventType"]["locations"]}
|
|
|
|
/>
|
2022-11-28 18:14:01 +00:00
|
|
|
<div
|
2022-10-12 08:39:14 +00:00
|
|
|
className={classNames(
|
2022-11-28 18:14:01 +00:00
|
|
|
"flex flex-nowrap text-sm font-medium",
|
2022-10-12 08:39:14 +00:00
|
|
|
isBookingPage && "dark:text-darkgray-600 text-gray-600"
|
|
|
|
)}>
|
2022-11-28 18:14:01 +00:00
|
|
|
<Icon.FiClock
|
|
|
|
className={classNames(
|
|
|
|
"min-h-4 min-w-4 mr-[10px] ml-[2px] inline-block",
|
|
|
|
isBookingPage && "mt-[2px]"
|
|
|
|
)}
|
|
|
|
/>
|
|
|
|
{eventType.metadata?.multipleDuration !== undefined ? (
|
|
|
|
!isBookingPage ? (
|
|
|
|
<ul className="-mt-1 flex flex-wrap gap-1">
|
|
|
|
{eventType.metadata.multipleDuration.map((dur, idx) => (
|
|
|
|
<li key={idx}>
|
|
|
|
<Badge
|
|
|
|
variant="gray"
|
|
|
|
size="lg"
|
|
|
|
className={classNames(
|
|
|
|
duration === dur.toString()
|
|
|
|
? "bg-darkgray-200 text-darkgray-900 dark:bg-darkmodebrand dark:!text-darkmodebrandcontrast"
|
|
|
|
: "hover:bg-darkgray-200 dark:hover:bg-darkmodebrand hover:text-darkgray-900 dark:hover:text-darkmodebrandcontrast dark:bg-darkgray-200 bg-gray-200 text-gray-900 dark:text-white",
|
|
|
|
"cursor-pointer"
|
|
|
|
)}
|
|
|
|
onClick={() => {
|
|
|
|
setDuration(dur);
|
|
|
|
}}>
|
|
|
|
{dur} {t("minute_timeUnit")}
|
|
|
|
</Badge>
|
|
|
|
</li>
|
|
|
|
))}
|
|
|
|
</ul>
|
|
|
|
) : (
|
|
|
|
`${duration} ${t("minutes")}`
|
|
|
|
)
|
|
|
|
) : (
|
|
|
|
`${eventType.length} ${t("minutes")}`
|
|
|
|
)}
|
|
|
|
</div>
|
2022-10-12 08:39:14 +00:00
|
|
|
{children}
|
|
|
|
</div>
|
|
|
|
</>
|
|
|
|
);
|
|
|
|
};
|
|
|
|
|
|
|
|
export default BookingDescription;
|