| 
									
										
										
										
											2021-09-14 08:20:24 +00:00
										 |  |  |  | // TODO: replace headlessui with radix-ui
 | 
					
						
							| 
									
										
										
										
											2021-10-15 19:07:00 +00:00
										 |  |  |  | import { Menu, Transition } from "@headlessui/react"; | 
					
						
							|  |  |  |  | import { UsersIcon } from "@heroicons/react/solid"; | 
					
						
							| 
									
										
										
										
											2021-10-12 13:11:33 +00:00
										 |  |  |  | import { ChevronDownIcon, PlusIcon } from "@heroicons/react/solid"; | 
					
						
							| 
									
										
										
										
											2021-10-15 19:07:00 +00:00
										 |  |  |  | import { DotsHorizontalIcon, ExternalLinkIcon, LinkIcon } from "@heroicons/react/solid"; | 
					
						
							|  |  |  |  | import { SchedulingType } from "@prisma/client"; | 
					
						
							| 
									
										
										
										
											2021-09-22 19:52:38 +00:00
										 |  |  |  | import Head from "next/head"; | 
					
						
							| 
									
										
										
										
											2021-10-15 19:07:00 +00:00
										 |  |  |  | import Link from "next/link"; | 
					
						
							| 
									
										
										
										
											2021-09-22 19:52:38 +00:00
										 |  |  |  | import { useRouter } from "next/router"; | 
					
						
							|  |  |  |  | import React, { Fragment, useRef } from "react"; | 
					
						
							|  |  |  |  | import { useMutation } from "react-query"; | 
					
						
							|  |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-10-15 19:07:00 +00:00
										 |  |  |  | import { QueryCell } from "@lib/QueryCell"; | 
					
						
							|  |  |  |  | import classNames from "@lib/classNames"; | 
					
						
							| 
									
										
										
										
											2021-09-15 12:33:00 +00:00
										 |  |  |  | import { HttpError } from "@lib/core/http/error"; | 
					
						
							| 
									
										
										
										
											2021-09-23 08:49:17 +00:00
										 |  |  |  | import { useLocale } from "@lib/hooks/useLocale"; | 
					
						
							| 
									
										
										
										
											2021-09-15 12:33:00 +00:00
										 |  |  |  | import { useToggleQuery } from "@lib/hooks/useToggleQuery"; | 
					
						
							|  |  |  |  | import createEventType from "@lib/mutations/event-types/create-event-type"; | 
					
						
							|  |  |  |  | import showToast from "@lib/notification"; | 
					
						
							| 
									
										
										
										
											2021-10-15 19:07:00 +00:00
										 |  |  |  | import { inferQueryOutput, trpc } from "@lib/trpc"; | 
					
						
							|  |  |  |  | import { CreateEventType } from "@lib/types/event-type"; | 
					
						
							| 
									
										
										
										
											2021-09-22 19:52:38 +00:00
										 |  |  |  | 
 | 
					
						
							|  |  |  |  | import { Dialog, DialogClose, DialogContent } from "@components/Dialog"; | 
					
						
							|  |  |  |  | import Shell from "@components/Shell"; | 
					
						
							| 
									
										
										
										
											2021-10-15 19:07:00 +00:00
										 |  |  |  | import { Tooltip } from "@components/Tooltip"; | 
					
						
							|  |  |  |  | import EventTypeDescription from "@components/eventtype/EventTypeDescription"; | 
					
						
							| 
									
										
										
										
											2021-09-22 19:52:38 +00:00
										 |  |  |  | import { Alert } from "@components/ui/Alert"; | 
					
						
							|  |  |  |  | import Avatar from "@components/ui/Avatar"; | 
					
						
							| 
									
										
										
										
											2021-10-15 19:07:00 +00:00
										 |  |  |  | import AvatarGroup from "@components/ui/AvatarGroup"; | 
					
						
							|  |  |  |  | import Badge from "@components/ui/Badge"; | 
					
						
							| 
									
										
										
										
											2021-09-22 19:52:38 +00:00
										 |  |  |  | import { Button } from "@components/ui/Button"; | 
					
						
							|  |  |  |  | import Dropdown, { | 
					
						
							|  |  |  |  |   DropdownMenuContent, | 
					
						
							|  |  |  |  |   DropdownMenuItem, | 
					
						
							|  |  |  |  |   DropdownMenuLabel, | 
					
						
							|  |  |  |  |   DropdownMenuSeparator, | 
					
						
							|  |  |  |  |   DropdownMenuTrigger, | 
					
						
							|  |  |  |  | } from "@components/ui/Dropdown"; | 
					
						
							|  |  |  |  | import * as RadioArea from "@components/ui/form/radio-area"; | 
					
						
							|  |  |  |  | import UserCalendarIllustration from "@components/ui/svg/UserCalendarIllustration"; | 
					
						
							| 
									
										
										
										
											2021-07-30 23:05:38 +00:00
										 |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-10-15 19:07:00 +00:00
										 |  |  |  | type Profiles = inferQueryOutput<"viewer.eventTypes">["profiles"]; | 
					
						
							| 
									
										
										
										
											2021-09-15 12:33:00 +00:00
										 |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-10-15 19:07:00 +00:00
										 |  |  |  | interface CreateEventTypeProps { | 
					
						
							|  |  |  |  |   canAddEvents: boolean; | 
					
						
							|  |  |  |  |   profiles: Profiles; | 
					
						
							|  |  |  |  | } | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  | const CreateFirstEventTypeView = ({ canAddEvents, profiles }: CreateEventTypeProps) => { | 
					
						
							| 
									
										
										
										
											2021-10-12 13:11:33 +00:00
										 |  |  |  |   const { t } = useLocale(); | 
					
						
							| 
									
										
										
										
											2021-09-23 08:49:17 +00:00
										 |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-10-15 19:07:00 +00:00
										 |  |  |  |   return ( | 
					
						
							| 
									
										
										
										
											2021-09-14 08:45:28 +00:00
										 |  |  |  |     <div className="md:py-20"> | 
					
						
							|  |  |  |  |       <UserCalendarIllustration /> | 
					
						
							| 
									
										
										
										
											2021-09-15 12:33:00 +00:00
										 |  |  |  |       <div className="block mx-auto text-center md:max-w-screen-sm"> | 
					
						
							| 
									
										
										
										
											2021-10-11 13:42:43 +00:00
										 |  |  |  |         <h3 className="mt-2 text-xl font-bold text-neutral-900">{t("new_event_type_heading")}</h3> | 
					
						
							|  |  |  |  |         <p className="mt-1 mb-2 text-md text-neutral-600">{t("new_event_type_description")}</p> | 
					
						
							| 
									
										
										
										
											2021-10-15 19:07:00 +00:00
										 |  |  |  |         <CreateNewEventButton canAddEvents={canAddEvents} profiles={profiles} /> | 
					
						
							| 
									
										
										
										
											2021-09-14 08:45:28 +00:00
										 |  |  |  |       </div> | 
					
						
							|  |  |  |  |     </div> | 
					
						
							|  |  |  |  |   ); | 
					
						
							| 
									
										
										
										
											2021-10-15 19:07:00 +00:00
										 |  |  |  | }; | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  | type EventTypeGroup = inferQueryOutput<"viewer.eventTypes">["eventTypeGroups"][number]; | 
					
						
							|  |  |  |  | type EventType = EventTypeGroup["eventTypes"][number]; | 
					
						
							|  |  |  |  | interface EventTypeListProps { | 
					
						
							|  |  |  |  |   profile: { slug: string | null }; | 
					
						
							|  |  |  |  |   readOnly: boolean; | 
					
						
							|  |  |  |  |   types: EventType[]; | 
					
						
							|  |  |  |  | } | 
					
						
							|  |  |  |  | const EventTypeList = ({ readOnly, types, profile }: EventTypeListProps): JSX.Element => { | 
					
						
							|  |  |  |  |   const { t } = useLocale(); | 
					
						
							|  |  |  |  |   return ( | 
					
						
							|  |  |  |  |     <div className="mb-16 -mx-4 overflow-hidden bg-white border border-gray-200 rounded-sm sm:mx-0"> | 
					
						
							|  |  |  |  |       <ul className="divide-y divide-neutral-200" data-testid="event-types"> | 
					
						
							|  |  |  |  |         {types.map((type) => ( | 
					
						
							|  |  |  |  |           <li | 
					
						
							|  |  |  |  |             key={type.id} | 
					
						
							|  |  |  |  |             className={classNames( | 
					
						
							|  |  |  |  |               type.$disabled && "opacity-30 cursor-not-allowed pointer-events-none select-none" | 
					
						
							|  |  |  |  |             )} | 
					
						
							|  |  |  |  |             data-disabled={type.$disabled ? 1 : 0}> | 
					
						
							|  |  |  |  |             <div | 
					
						
							|  |  |  |  |               className={classNames( | 
					
						
							|  |  |  |  |                 "hover:bg-neutral-50 flex justify-between items-center ", | 
					
						
							|  |  |  |  |                 type.$disabled && "pointer-events-none" | 
					
						
							|  |  |  |  |               )}> | 
					
						
							|  |  |  |  |               <div className="flex items-center justify-between w-full px-4 py-4 sm:px-6 hover:bg-neutral-50"> | 
					
						
							|  |  |  |  |                 <Link href={"/event-types/" + type.id}> | 
					
						
							|  |  |  |  |                   <a | 
					
						
							|  |  |  |  |                     className="flex-grow text-sm truncate" | 
					
						
							|  |  |  |  |                     title={`${type.title} ${type.description ? `– ${type.description}` : ""}`}> | 
					
						
							|  |  |  |  |                     <div> | 
					
						
							|  |  |  |  |                       <span className="font-medium truncate text-neutral-900">{type.title}</span> | 
					
						
							|  |  |  |  |                       {type.hidden && ( | 
					
						
							|  |  |  |  |                         <span className="ml-2 inline items-center px-1.5 py-0.5 rounded-sm text-xs font-medium bg-yellow-100 text-yellow-800"> | 
					
						
							|  |  |  |  |                           {t("hidden")} | 
					
						
							|  |  |  |  |                         </span> | 
					
						
							|  |  |  |  |                       )} | 
					
						
							|  |  |  |  |                       {readOnly && ( | 
					
						
							|  |  |  |  |                         <span className="ml-2 inline items-center px-1.5 py-0.5 rounded-sm text-xs font-medium bg-gray-100 text-gray-800"> | 
					
						
							|  |  |  |  |                           {t("readonly")} | 
					
						
							|  |  |  |  |                         </span> | 
					
						
							|  |  |  |  |                       )} | 
					
						
							|  |  |  |  |                     </div> | 
					
						
							|  |  |  |  |                     <EventTypeDescription eventType={type} /> | 
					
						
							|  |  |  |  |                   </a> | 
					
						
							|  |  |  |  |                 </Link> | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |                 <div className="flex-shrink-0 hidden mt-4 sm:flex sm:mt-0 sm:ml-5"> | 
					
						
							|  |  |  |  |                   <div className="flex items-center space-x-2 overflow-hidden"> | 
					
						
							|  |  |  |  |                     {type.users?.length > 1 && ( | 
					
						
							|  |  |  |  |                       <AvatarGroup | 
					
						
							|  |  |  |  |                         size={8} | 
					
						
							|  |  |  |  |                         truncateAfter={4} | 
					
						
							|  |  |  |  |                         items={type.users.map((organizer) => ({ | 
					
						
							|  |  |  |  |                           alt: organizer.name || "", | 
					
						
							|  |  |  |  |                           image: organizer.avatar || "", | 
					
						
							|  |  |  |  |                         }))} | 
					
						
							|  |  |  |  |                       /> | 
					
						
							|  |  |  |  |                     )} | 
					
						
							|  |  |  |  |                     <Tooltip content={t("preview")}> | 
					
						
							|  |  |  |  |                       <a | 
					
						
							|  |  |  |  |                         href={`${process.env.NEXT_PUBLIC_APP_URL}/${profile.slug}/${type.slug}`} | 
					
						
							|  |  |  |  |                         target="_blank" | 
					
						
							|  |  |  |  |                         rel="noreferrer" | 
					
						
							|  |  |  |  |                         className="btn-icon"> | 
					
						
							|  |  |  |  |                         <ExternalLinkIcon className="w-5 h-5 group-hover:text-black" /> | 
					
						
							|  |  |  |  |                       </a> | 
					
						
							|  |  |  |  |                     </Tooltip> | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |                     <Tooltip content={t("copy_link")}> | 
					
						
							|  |  |  |  |                       <button | 
					
						
							|  |  |  |  |                         onClick={() => { | 
					
						
							|  |  |  |  |                           showToast(t("link_copied"), "success"); | 
					
						
							|  |  |  |  |                           navigator.clipboard.writeText( | 
					
						
							|  |  |  |  |                             `${process.env.NEXT_PUBLIC_APP_URL}/${profile.slug}/${type.slug}` | 
					
						
							|  |  |  |  |                           ); | 
					
						
							|  |  |  |  |                         }} | 
					
						
							|  |  |  |  |                         className="btn-icon"> | 
					
						
							|  |  |  |  |                         <LinkIcon className="w-5 h-5 group-hover:text-black" /> | 
					
						
							|  |  |  |  |                       </button> | 
					
						
							|  |  |  |  |                     </Tooltip> | 
					
						
							|  |  |  |  |                   </div> | 
					
						
							|  |  |  |  |                 </div> | 
					
						
							|  |  |  |  |               </div> | 
					
						
							|  |  |  |  |               <div className="flex flex-shrink-0 mr-5 sm:hidden"> | 
					
						
							|  |  |  |  |                 <Menu as="div" className="inline-block text-left"> | 
					
						
							|  |  |  |  |                   {({ open }) => ( | 
					
						
							|  |  |  |  |                     <> | 
					
						
							|  |  |  |  |                       <div> | 
					
						
							|  |  |  |  |                         <Menu.Button className="p-2 mt-1 border border-transparent text-neutral-400 hover:border-gray-200"> | 
					
						
							|  |  |  |  |                           <span className="sr-only">{t("open_options")}</span> | 
					
						
							|  |  |  |  |                           <DotsHorizontalIcon className="w-5 h-5" aria-hidden="true" /> | 
					
						
							|  |  |  |  |                         </Menu.Button> | 
					
						
							|  |  |  |  |                       </div> | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |                       <Transition | 
					
						
							|  |  |  |  |                         show={open} | 
					
						
							|  |  |  |  |                         as={Fragment} | 
					
						
							|  |  |  |  |                         enter="transition ease-out duration-100" | 
					
						
							|  |  |  |  |                         enterFrom="transform opacity-0 scale-95" | 
					
						
							|  |  |  |  |                         enterTo="transform opacity-100 scale-100" | 
					
						
							|  |  |  |  |                         leave="transition ease-in duration-75" | 
					
						
							|  |  |  |  |                         leaveFrom="transform opacity-100 scale-100" | 
					
						
							|  |  |  |  |                         leaveTo="transform opacity-0 scale-95"> | 
					
						
							|  |  |  |  |                         <Menu.Items | 
					
						
							|  |  |  |  |                           static | 
					
						
							|  |  |  |  |                           className="absolute right-0 z-10 w-56 mt-2 origin-top-right bg-white divide-y rounded-sm shadow-lg ring-1 ring-black ring-opacity-5 focus:outline-none divide-neutral-100"> | 
					
						
							|  |  |  |  |                           <div className="py-1"> | 
					
						
							|  |  |  |  |                             <Menu.Item> | 
					
						
							|  |  |  |  |                               {({ active }) => ( | 
					
						
							|  |  |  |  |                                 <a | 
					
						
							|  |  |  |  |                                   href={`${process.env.NEXT_PUBLIC_APP_URL}/${profile.slug}/${type.slug}`} | 
					
						
							|  |  |  |  |                                   target="_blank" | 
					
						
							|  |  |  |  |                                   rel="noreferrer" | 
					
						
							|  |  |  |  |                                   className={classNames( | 
					
						
							|  |  |  |  |                                     active ? "bg-neutral-100 text-neutral-900" : "text-neutral-700", | 
					
						
							|  |  |  |  |                                     "group flex items-center px-4 py-2 text-sm font-medium" | 
					
						
							|  |  |  |  |                                   )}> | 
					
						
							|  |  |  |  |                                   <ExternalLinkIcon | 
					
						
							|  |  |  |  |                                     className="w-4 h-4 mr-3 text-neutral-400 group-hover:text-neutral-500" | 
					
						
							|  |  |  |  |                                     aria-hidden="true" | 
					
						
							|  |  |  |  |                                   /> | 
					
						
							|  |  |  |  |                                   {t("preview")} | 
					
						
							|  |  |  |  |                                 </a> | 
					
						
							|  |  |  |  |                               )} | 
					
						
							|  |  |  |  |                             </Menu.Item> | 
					
						
							|  |  |  |  |                             <Menu.Item> | 
					
						
							|  |  |  |  |                               {({ active }) => ( | 
					
						
							|  |  |  |  |                                 <button | 
					
						
							|  |  |  |  |                                   onClick={() => { | 
					
						
							|  |  |  |  |                                     showToast("Link copied!", "success"); | 
					
						
							|  |  |  |  |                                     navigator.clipboard.writeText( | 
					
						
							|  |  |  |  |                                       `${process.env.NEXT_PUBLIC_APP_URL}/${profile.slug}/${type.slug}` | 
					
						
							|  |  |  |  |                                     ); | 
					
						
							|  |  |  |  |                                   }} | 
					
						
							|  |  |  |  |                                   className={classNames( | 
					
						
							|  |  |  |  |                                     active ? "bg-neutral-100 text-neutral-900" : "text-neutral-700", | 
					
						
							|  |  |  |  |                                     "group flex items-center px-4 py-2 text-sm w-full font-medium" | 
					
						
							|  |  |  |  |                                   )}> | 
					
						
							|  |  |  |  |                                   <LinkIcon | 
					
						
							|  |  |  |  |                                     className="w-4 h-4 mr-3 text-neutral-400 group-hover:text-neutral-500" | 
					
						
							|  |  |  |  |                                     aria-hidden="true" | 
					
						
							|  |  |  |  |                                   /> | 
					
						
							|  |  |  |  |                                   {t("copy_link")} | 
					
						
							|  |  |  |  |                                 </button> | 
					
						
							|  |  |  |  |                               )} | 
					
						
							|  |  |  |  |                             </Menu.Item> | 
					
						
							|  |  |  |  |                           </div> | 
					
						
							|  |  |  |  |                         </Menu.Items> | 
					
						
							|  |  |  |  |                       </Transition> | 
					
						
							|  |  |  |  |                     </> | 
					
						
							|  |  |  |  |                   )} | 
					
						
							|  |  |  |  |                 </Menu> | 
					
						
							|  |  |  |  |               </div> | 
					
						
							|  |  |  |  |             </div> | 
					
						
							|  |  |  |  |           </li> | 
					
						
							|  |  |  |  |         ))} | 
					
						
							|  |  |  |  |       </ul> | 
					
						
							|  |  |  |  |     </div> | 
					
						
							|  |  |  |  |   ); | 
					
						
							|  |  |  |  | }; | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  | interface EventTypeListHeadingProps { | 
					
						
							|  |  |  |  |   profile: Profile; | 
					
						
							|  |  |  |  |   membershipCount: number; | 
					
						
							|  |  |  |  | } | 
					
						
							|  |  |  |  | const EventTypeListHeading = ({ profile, membershipCount }: EventTypeListHeadingProps): JSX.Element => ( | 
					
						
							|  |  |  |  |   <div className="flex mb-4"> | 
					
						
							|  |  |  |  |     <Link href="/settings/teams"> | 
					
						
							|  |  |  |  |       <a> | 
					
						
							|  |  |  |  |         <Avatar | 
					
						
							|  |  |  |  |           alt={profile?.name || ""} | 
					
						
							|  |  |  |  |           imageSrc={profile?.image || undefined} | 
					
						
							|  |  |  |  |           size={8} | 
					
						
							|  |  |  |  |           className="inline mt-1 mr-2" | 
					
						
							|  |  |  |  |         /> | 
					
						
							|  |  |  |  |       </a> | 
					
						
							|  |  |  |  |     </Link> | 
					
						
							|  |  |  |  |     <div> | 
					
						
							|  |  |  |  |       <Link href="/settings/teams"> | 
					
						
							|  |  |  |  |         <a className="font-bold">{profile?.name || ""}</a> | 
					
						
							|  |  |  |  |       </Link> | 
					
						
							|  |  |  |  |       {membershipCount && ( | 
					
						
							|  |  |  |  |         <span className="relative ml-2 text-xs text-neutral-500 -top-px"> | 
					
						
							|  |  |  |  |           <Link href="/settings/teams"> | 
					
						
							|  |  |  |  |             <a> | 
					
						
							|  |  |  |  |               <Badge variant="gray"> | 
					
						
							|  |  |  |  |                 <UsersIcon className="inline w-3 h-3 mr-1 -mt-px" /> | 
					
						
							|  |  |  |  |                 {membershipCount} | 
					
						
							|  |  |  |  |               </Badge> | 
					
						
							|  |  |  |  |             </a> | 
					
						
							|  |  |  |  |           </Link> | 
					
						
							|  |  |  |  |         </span> | 
					
						
							|  |  |  |  |       )} | 
					
						
							|  |  |  |  |       {profile?.slug && ( | 
					
						
							|  |  |  |  |         <Link href={`${process.env.NEXT_PUBLIC_APP_URL}/${profile.slug}`}> | 
					
						
							|  |  |  |  |           <a className="block text-xs text-neutral-500">{`${process.env.NEXT_PUBLIC_APP_URL?.replace( | 
					
						
							|  |  |  |  |             "https://", | 
					
						
							|  |  |  |  |             "" | 
					
						
							|  |  |  |  |           )}/${profile.slug}`}</a>
 | 
					
						
							|  |  |  |  |         </Link> | 
					
						
							|  |  |  |  |       )} | 
					
						
							|  |  |  |  |     </div> | 
					
						
							|  |  |  |  |   </div> | 
					
						
							|  |  |  |  | ); | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  | const EventTypesPage = () => { | 
					
						
							|  |  |  |  |   const { t } = useLocale(); | 
					
						
							|  |  |  |  |   const query = trpc.useQuery(["viewer.eventTypes"]); | 
					
						
							| 
									
										
										
										
											2021-09-14 08:45:28 +00:00
										 |  |  |  | 
 | 
					
						
							|  |  |  |  |   return ( | 
					
						
							|  |  |  |  |     <div> | 
					
						
							|  |  |  |  |       <Head> | 
					
						
							| 
									
										
										
										
											2021-10-11 13:42:43 +00:00
										 |  |  |  |         <title>{t("event_types_page_title")}| Cal.com</title> | 
					
						
							| 
									
										
										
										
											2021-09-14 08:45:28 +00:00
										 |  |  |  |         <link rel="icon" href="/favicon.ico" /> | 
					
						
							|  |  |  |  |       </Head> | 
					
						
							|  |  |  |  |       <Shell | 
					
						
							| 
									
										
										
										
											2021-10-11 13:42:43 +00:00
										 |  |  |  |         heading={t("event_types_page_title")} | 
					
						
							|  |  |  |  |         subtitle={t("event_types_page_subtitle")} | 
					
						
							| 
									
										
										
										
											2021-09-14 08:45:28 +00:00
										 |  |  |  |         CTA={ | 
					
						
							| 
									
										
										
										
											2021-10-15 19:07:00 +00:00
										 |  |  |  |           query.data && | 
					
						
							|  |  |  |  |           query.data.eventTypeGroups.length !== 0 && ( | 
					
						
							|  |  |  |  |             <CreateNewEventButton canAddEvents={query.data.canAddEvents} profiles={query.data.profiles} /> | 
					
						
							| 
									
										
										
										
											2021-09-14 08:45:28 +00:00
										 |  |  |  |           ) | 
					
						
							|  |  |  |  |         }> | 
					
						
							| 
									
										
										
										
											2021-10-15 19:07:00 +00:00
										 |  |  |  |         <QueryCell | 
					
						
							|  |  |  |  |           query={query} | 
					
						
							|  |  |  |  |           success={({ data }) => ( | 
					
						
							|  |  |  |  |             <> | 
					
						
							|  |  |  |  |               {data.user.plan === "FREE" && !data.canAddEvents && ( | 
					
						
							|  |  |  |  |                 <Alert | 
					
						
							|  |  |  |  |                   severity="warning" | 
					
						
							|  |  |  |  |                   title={<>{t("plan_upgrade")}</>} | 
					
						
							|  |  |  |  |                   message={ | 
					
						
							|  |  |  |  |                     <> | 
					
						
							|  |  |  |  |                       {t("to_upgrade_go_to")}{" "} | 
					
						
							|  |  |  |  |                       <a href={"https://cal.com/upgrade"} className="underline"> | 
					
						
							|  |  |  |  |                         {"https://cal.com/upgrade"} | 
					
						
							|  |  |  |  |                       </a> | 
					
						
							|  |  |  |  |                     </> | 
					
						
							|  |  |  |  |                   } | 
					
						
							|  |  |  |  |                   className="my-4" | 
					
						
							| 
									
										
										
										
											2021-09-14 08:45:28 +00:00
										 |  |  |  |                 /> | 
					
						
							|  |  |  |  |               )} | 
					
						
							| 
									
										
										
										
											2021-10-15 19:07:00 +00:00
										 |  |  |  |               {data.eventTypeGroups && | 
					
						
							|  |  |  |  |                 data.eventTypeGroups.map((input) => ( | 
					
						
							|  |  |  |  |                   <Fragment key={input.profile.slug}> | 
					
						
							|  |  |  |  |                     {/* hide list heading when there is only one (current user) */} | 
					
						
							|  |  |  |  |                     {(data.eventTypeGroups.length !== 1 || input.teamId) && ( | 
					
						
							|  |  |  |  |                       <EventTypeListHeading | 
					
						
							|  |  |  |  |                         profile={input.profile} | 
					
						
							|  |  |  |  |                         membershipCount={input.metadata.membershipCount} | 
					
						
							|  |  |  |  |                       /> | 
					
						
							|  |  |  |  |                     )} | 
					
						
							|  |  |  |  |                     <EventTypeList | 
					
						
							|  |  |  |  |                       types={input.eventTypes} | 
					
						
							|  |  |  |  |                       profile={input.profile} | 
					
						
							|  |  |  |  |                       readOnly={input.metadata.readOnly} | 
					
						
							|  |  |  |  |                     /> | 
					
						
							|  |  |  |  |                   </Fragment> | 
					
						
							|  |  |  |  |                 ))} | 
					
						
							| 
									
										
										
										
											2021-09-14 08:45:28 +00:00
										 |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-10-15 19:07:00 +00:00
										 |  |  |  |               {data.eventTypeGroups.length === 0 && ( | 
					
						
							|  |  |  |  |                 <CreateFirstEventTypeView profiles={data.profiles} canAddEvents={data.canAddEvents} /> | 
					
						
							|  |  |  |  |               )} | 
					
						
							|  |  |  |  |             </> | 
					
						
							|  |  |  |  |           )} | 
					
						
							|  |  |  |  |         /> | 
					
						
							| 
									
										
										
										
											2021-09-14 08:45:28 +00:00
										 |  |  |  |       </Shell> | 
					
						
							|  |  |  |  |     </div> | 
					
						
							|  |  |  |  |   ); | 
					
						
							|  |  |  |  | }; | 
					
						
							|  |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-10-15 19:07:00 +00:00
										 |  |  |  | const CreateNewEventButton = ({ profiles, canAddEvents }: CreateEventTypeProps) => { | 
					
						
							| 
									
										
										
										
											2021-07-30 23:05:38 +00:00
										 |  |  |  |   const router = useRouter(); | 
					
						
							| 
									
										
										
										
											2021-09-14 08:45:28 +00:00
										 |  |  |  |   const teamId: number | null = Number(router.query.teamId) || null; | 
					
						
							|  |  |  |  |   const modalOpen = useToggleQuery("new"); | 
					
						
							| 
									
										
										
										
											2021-10-12 13:11:33 +00:00
										 |  |  |  |   const { t } = useLocale(); | 
					
						
							| 
									
										
										
										
											2021-09-14 08:45:28 +00:00
										 |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-08-27 12:11:24 +00:00
										 |  |  |  |   const createMutation = useMutation(createEventType, { | 
					
						
							|  |  |  |  |     onSuccess: async ({ eventType }) => { | 
					
						
							| 
									
										
										
										
											2021-09-14 08:45:28 +00:00
										 |  |  |  |       await router.push("/event-types/" + eventType.id); | 
					
						
							| 
									
										
										
										
											2021-08-27 12:11:24 +00:00
										 |  |  |  |       showToast(`${eventType.title} event type created successfully`, "success"); | 
					
						
							|  |  |  |  |     }, | 
					
						
							| 
									
										
										
										
											2021-09-09 13:51:06 +00:00
										 |  |  |  |     onError: (err: HttpError) => { | 
					
						
							|  |  |  |  |       const message = `${err.statusCode}: ${err.message}`; | 
					
						
							|  |  |  |  |       showToast(message, "error"); | 
					
						
							| 
									
										
										
										
											2021-08-27 12:11:24 +00:00
										 |  |  |  |     }, | 
					
						
							|  |  |  |  |   }); | 
					
						
							| 
									
										
										
										
											2021-07-30 23:05:38 +00:00
										 |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-09-06 13:51:15 +00:00
										 |  |  |  |   const slugRef = useRef<HTMLInputElement>(null); | 
					
						
							| 
									
										
										
										
											2021-08-04 16:06:05 +00:00
										 |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-09-14 08:45:28 +00:00
										 |  |  |  |   return ( | 
					
						
							| 
									
										
										
										
											2021-08-23 12:45:25 +00:00
										 |  |  |  |     <Dialog | 
					
						
							| 
									
										
										
										
											2021-09-06 13:51:15 +00:00
										 |  |  |  |       open={modalOpen.isOn} | 
					
						
							| 
									
										
										
										
											2021-08-23 12:45:25 +00:00
										 |  |  |  |       onOpenChange={(isOpen) => { | 
					
						
							| 
									
										
										
										
											2021-09-06 13:51:15 +00:00
										 |  |  |  |         router.push(isOpen ? modalOpen.hrefOn : modalOpen.hrefOff); | 
					
						
							| 
									
										
										
										
											2021-08-23 12:45:25 +00:00
										 |  |  |  |       }}> | 
					
						
							| 
									
										
										
										
											2021-09-14 08:45:28 +00:00
										 |  |  |  |       {!profiles.filter((profile) => profile.teamId).length && ( | 
					
						
							|  |  |  |  |         <Button | 
					
						
							|  |  |  |  |           data-testid="new-event-type" | 
					
						
							|  |  |  |  |           {...(canAddEvents | 
					
						
							|  |  |  |  |             ? { | 
					
						
							| 
									
										
										
										
											2021-09-21 10:36:29 +00:00
										 |  |  |  |                 href: modalOpen.hrefOn, | 
					
						
							|  |  |  |  |               } | 
					
						
							| 
									
										
										
										
											2021-09-14 08:45:28 +00:00
										 |  |  |  |             : { | 
					
						
							| 
									
										
										
										
											2021-09-21 10:36:29 +00:00
										 |  |  |  |                 disabled: true, | 
					
						
							|  |  |  |  |               })} | 
					
						
							| 
									
										
										
										
											2021-09-14 08:45:28 +00:00
										 |  |  |  |           StartIcon={PlusIcon}> | 
					
						
							| 
									
										
										
										
											2021-10-08 11:43:48 +00:00
										 |  |  |  |           {t("new_event_type_btn")} | 
					
						
							| 
									
										
										
										
											2021-09-14 08:45:28 +00:00
										 |  |  |  |         </Button> | 
					
						
							|  |  |  |  |       )} | 
					
						
							|  |  |  |  |       {profiles.filter((profile) => profile.teamId).length > 0 && ( | 
					
						
							| 
									
										
										
										
											2021-09-15 12:33:00 +00:00
										 |  |  |  |         <Dropdown> | 
					
						
							|  |  |  |  |           <DropdownMenuTrigger asChild> | 
					
						
							| 
									
										
										
										
											2021-10-08 11:43:48 +00:00
										 |  |  |  |             <Button EndIcon={ChevronDownIcon}>{t("new_event_type_btn")}</Button> | 
					
						
							| 
									
										
										
										
											2021-09-15 12:33:00 +00:00
										 |  |  |  |           </DropdownMenuTrigger> | 
					
						
							|  |  |  |  |           <DropdownMenuContent align="end"> | 
					
						
							| 
									
										
										
										
											2021-10-11 13:42:43 +00:00
										 |  |  |  |             <DropdownMenuLabel>{t("new_event_subtitle")}</DropdownMenuLabel> | 
					
						
							| 
									
										
										
										
											2021-09-15 12:33:00 +00:00
										 |  |  |  |             <DropdownMenuSeparator className="h-px bg-gray-200" /> | 
					
						
							| 
									
										
										
										
											2021-09-14 08:45:28 +00:00
										 |  |  |  |             {profiles.map((profile) => ( | 
					
						
							| 
									
										
										
										
											2021-09-15 12:33:00 +00:00
										 |  |  |  |               <DropdownMenuItem | 
					
						
							| 
									
										
										
										
											2021-09-14 08:45:28 +00:00
										 |  |  |  |                 key={profile.slug} | 
					
						
							| 
									
										
										
										
											2021-09-14 13:27:41 +00:00
										 |  |  |  |                 className="px-3 py-2 cursor-pointer hover:bg-neutral-100 focus:outline-none" | 
					
						
							| 
									
										
										
										
											2021-09-14 08:45:28 +00:00
										 |  |  |  |                 onSelect={() => | 
					
						
							|  |  |  |  |                   router.push({ | 
					
						
							|  |  |  |  |                     pathname: router.pathname, | 
					
						
							|  |  |  |  |                     query: { | 
					
						
							|  |  |  |  |                       ...router.query, | 
					
						
							|  |  |  |  |                       new: "1", | 
					
						
							|  |  |  |  |                       eventPage: profile.slug, | 
					
						
							|  |  |  |  |                       ...(profile.teamId | 
					
						
							|  |  |  |  |                         ? { | 
					
						
							| 
									
										
										
										
											2021-09-21 10:36:29 +00:00
										 |  |  |  |                             teamId: profile.teamId, | 
					
						
							|  |  |  |  |                           } | 
					
						
							| 
									
										
										
										
											2021-09-14 08:45:28 +00:00
										 |  |  |  |                         : {}), | 
					
						
							|  |  |  |  |                     }, | 
					
						
							|  |  |  |  |                   }) | 
					
						
							|  |  |  |  |                 }> | 
					
						
							| 
									
										
										
										
											2021-10-15 19:07:00 +00:00
										 |  |  |  |                 <Avatar alt={profile.name || ""} imageSrc={profile.image} size={6} className="inline mr-2" /> | 
					
						
							| 
									
										
										
										
											2021-09-22 10:43:08 +00:00
										 |  |  |  |                 {profile.name ? profile.name : profile.slug} | 
					
						
							| 
									
										
										
										
											2021-09-15 12:33:00 +00:00
										 |  |  |  |               </DropdownMenuItem> | 
					
						
							| 
									
										
										
										
											2021-09-14 08:45:28 +00:00
										 |  |  |  |             ))} | 
					
						
							| 
									
										
										
										
											2021-09-15 12:33:00 +00:00
										 |  |  |  |           </DropdownMenuContent> | 
					
						
							|  |  |  |  |         </Dropdown> | 
					
						
							| 
									
										
										
										
											2021-09-14 08:45:28 +00:00
										 |  |  |  |       )} | 
					
						
							| 
									
										
										
										
											2021-08-03 17:36:55 +00:00
										 |  |  |  |       <DialogContent> | 
					
						
							| 
									
										
										
										
											2021-08-05 11:36:24 +00:00
										 |  |  |  |         <div className="mb-8"> | 
					
						
							| 
									
										
										
										
											2021-09-15 12:33:00 +00:00
										 |  |  |  |           <h3 className="text-lg font-bold leading-6 text-gray-900" id="modal-title"> | 
					
						
							| 
									
										
										
										
											2021-10-11 13:42:43 +00:00
										 |  |  |  |             {teamId ? t("add_new_team_event_type") : t("add_new_event_type")} | 
					
						
							| 
									
										
										
										
											2021-08-03 17:36:55 +00:00
										 |  |  |  |           </h3> | 
					
						
							|  |  |  |  |           <div> | 
					
						
							| 
									
										
										
										
											2021-10-11 13:42:43 +00:00
										 |  |  |  |             <p className="text-sm text-gray-500">{t("new_event_type_to_book_description")}</p> | 
					
						
							| 
									
										
										
										
											2021-08-03 17:36:55 +00:00
										 |  |  |  |           </div> | 
					
						
							|  |  |  |  |         </div> | 
					
						
							| 
									
										
										
										
											2021-09-06 13:51:15 +00:00
										 |  |  |  |         <form | 
					
						
							|  |  |  |  |           onSubmit={(e) => { | 
					
						
							|  |  |  |  |             e.preventDefault(); | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |             const target = e.target as unknown as Record< | 
					
						
							| 
									
										
										
										
											2021-09-14 08:45:28 +00:00
										 |  |  |  |               "title" | "slug" | "description" | "length" | "schedulingType", | 
					
						
							| 
									
										
										
										
											2021-09-06 13:51:15 +00:00
										 |  |  |  |               { value: string } | 
					
						
							|  |  |  |  |             >; | 
					
						
							|  |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-10-15 19:07:00 +00:00
										 |  |  |  |             const payload: CreateEventType = { | 
					
						
							| 
									
										
										
										
											2021-09-06 13:51:15 +00:00
										 |  |  |  |               title: target.title.value, | 
					
						
							|  |  |  |  |               slug: target.slug.value, | 
					
						
							|  |  |  |  |               description: target.description.value, | 
					
						
							|  |  |  |  |               length: parseInt(target.length.value), | 
					
						
							|  |  |  |  |             }; | 
					
						
							|  |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-09-14 08:45:28 +00:00
										 |  |  |  |             if (router.query.teamId) { | 
					
						
							| 
									
										
										
										
											2021-10-15 19:07:00 +00:00
										 |  |  |  |               payload.teamId = parseInt(`${router.query.teamId}`, 10); | 
					
						
							|  |  |  |  |               payload.schedulingType = target.schedulingType.value as SchedulingType; | 
					
						
							| 
									
										
										
										
											2021-09-14 08:45:28 +00:00
										 |  |  |  |             } | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |             createMutation.mutate(payload); | 
					
						
							| 
									
										
										
										
											2021-09-06 13:51:15 +00:00
										 |  |  |  |           }}> | 
					
						
							| 
									
										
										
										
											2021-08-03 17:36:55 +00:00
										 |  |  |  |           <div> | 
					
						
							|  |  |  |  |             <div className="mb-4"> | 
					
						
							|  |  |  |  |               <label htmlFor="title" className="block text-sm font-medium text-gray-700"> | 
					
						
							| 
									
										
										
										
											2021-10-11 13:42:43 +00:00
										 |  |  |  |                 {t("title")} | 
					
						
							| 
									
										
										
										
											2021-08-03 17:36:55 +00:00
										 |  |  |  |               </label> | 
					
						
							|  |  |  |  |               <div className="mt-1"> | 
					
						
							|  |  |  |  |                 <input | 
					
						
							| 
									
										
										
										
											2021-09-06 13:51:15 +00:00
										 |  |  |  |                   onChange={(e) => { | 
					
						
							|  |  |  |  |                     if (!slugRef.current) { | 
					
						
							|  |  |  |  |                       return; | 
					
						
							|  |  |  |  |                     } | 
					
						
							| 
									
										
										
										
											2021-09-14 08:45:28 +00:00
										 |  |  |  |                     slugRef.current.value = e.target.value.replace(/\s+/g, "-").toLowerCase(); | 
					
						
							| 
									
										
										
										
											2021-09-06 13:51:15 +00:00
										 |  |  |  |                   }} | 
					
						
							| 
									
										
										
										
											2021-08-03 17:36:55 +00:00
										 |  |  |  |                   type="text" | 
					
						
							|  |  |  |  |                   name="title" | 
					
						
							|  |  |  |  |                   id="title" | 
					
						
							|  |  |  |  |                   required | 
					
						
							| 
									
										
										
										
											2021-09-15 12:33:00 +00:00
										 |  |  |  |                   className="block w-full border-gray-300 rounded-sm shadow-sm focus:ring-neutral-900 focus:border-neutral-900 sm:text-sm" | 
					
						
							| 
									
										
										
										
											2021-10-11 13:42:43 +00:00
										 |  |  |  |                   placeholder={t("quick_chat")} | 
					
						
							| 
									
										
										
										
											2021-08-03 17:36:55 +00:00
										 |  |  |  |                 /> | 
					
						
							|  |  |  |  |               </div> | 
					
						
							|  |  |  |  |             </div> | 
					
						
							|  |  |  |  |             <div className="mb-4"> | 
					
						
							|  |  |  |  |               <label htmlFor="slug" className="block text-sm font-medium text-gray-700"> | 
					
						
							| 
									
										
										
										
											2021-10-11 13:42:43 +00:00
										 |  |  |  |                 {t("url")} | 
					
						
							| 
									
										
										
										
											2021-08-03 17:36:55 +00:00
										 |  |  |  |               </label> | 
					
						
							|  |  |  |  |               <div className="mt-1"> | 
					
						
							|  |  |  |  |                 <div className="flex rounded-sm shadow-sm"> | 
					
						
							| 
									
										
										
										
											2021-09-15 12:33:00 +00:00
										 |  |  |  |                   <span className="inline-flex items-center px-3 text-gray-500 border border-r-0 border-gray-300 rounded-l-md bg-gray-50 sm:text-sm"> | 
					
						
							| 
									
										
										
										
											2021-09-24 10:16:46 +00:00
										 |  |  |  |                     {process.env.NEXT_PUBLIC_APP_URL}/{router.query.eventPage || profiles[0].slug}/ | 
					
						
							| 
									
										
										
										
											2021-08-03 17:36:55 +00:00
										 |  |  |  |                   </span> | 
					
						
							|  |  |  |  |                   <input | 
					
						
							| 
									
										
										
										
											2021-09-14 08:45:28 +00:00
										 |  |  |  |                     ref={slugRef} | 
					
						
							| 
									
										
										
										
											2021-08-03 17:36:55 +00:00
										 |  |  |  |                     type="text" | 
					
						
							|  |  |  |  |                     name="slug" | 
					
						
							|  |  |  |  |                     id="slug" | 
					
						
							|  |  |  |  |                     required | 
					
						
							| 
									
										
										
										
											2021-09-15 12:33:00 +00:00
										 |  |  |  |                     className="flex-1 block w-full min-w-0 border-gray-300 rounded-none focus:ring-neutral-900 focus:border-neutral-900 rounded-r-md sm:text-sm" | 
					
						
							| 
									
										
										
										
											2021-08-03 17:36:55 +00:00
										 |  |  |  |                   /> | 
					
						
							|  |  |  |  |                 </div> | 
					
						
							|  |  |  |  |               </div> | 
					
						
							|  |  |  |  |             </div> | 
					
						
							|  |  |  |  |             <div className="mb-4"> | 
					
						
							|  |  |  |  |               <label htmlFor="description" className="block text-sm font-medium text-gray-700"> | 
					
						
							| 
									
										
										
										
											2021-10-11 13:42:43 +00:00
										 |  |  |  |                 {t("description")} | 
					
						
							| 
									
										
										
										
											2021-08-03 17:36:55 +00:00
										 |  |  |  |               </label> | 
					
						
							|  |  |  |  |               <div className="mt-1"> | 
					
						
							|  |  |  |  |                 <textarea | 
					
						
							|  |  |  |  |                   name="description" | 
					
						
							|  |  |  |  |                   id="description" | 
					
						
							| 
									
										
										
										
											2021-09-15 12:33:00 +00:00
										 |  |  |  |                   className="block w-full border-gray-300 rounded-sm shadow-sm focus:ring-neutral-900 focus:border-neutral-900 sm:text-sm" | 
					
						
							| 
									
										
										
										
											2021-10-11 13:42:43 +00:00
										 |  |  |  |                   placeholder={t("quick_video_meeting")} | 
					
						
							| 
									
										
										
										
											2021-09-14 08:45:28 +00:00
										 |  |  |  |                 /> | 
					
						
							| 
									
										
										
										
											2021-08-03 17:36:55 +00:00
										 |  |  |  |               </div> | 
					
						
							|  |  |  |  |             </div> | 
					
						
							|  |  |  |  |             <div className="mb-4"> | 
					
						
							|  |  |  |  |               <label htmlFor="length" className="block text-sm font-medium text-gray-700"> | 
					
						
							| 
									
										
										
										
											2021-10-11 13:42:43 +00:00
										 |  |  |  |                 {t("length")} | 
					
						
							| 
									
										
										
										
											2021-08-03 17:36:55 +00:00
										 |  |  |  |               </label> | 
					
						
							| 
									
										
										
										
											2021-09-15 12:33:00 +00:00
										 |  |  |  |               <div className="relative mt-1 rounded-sm shadow-sm"> | 
					
						
							| 
									
										
										
										
											2021-08-03 17:36:55 +00:00
										 |  |  |  |                 <input | 
					
						
							|  |  |  |  |                   type="number" | 
					
						
							|  |  |  |  |                   name="length" | 
					
						
							|  |  |  |  |                   id="length" | 
					
						
							|  |  |  |  |                   required | 
					
						
							| 
									
										
										
										
											2021-09-15 12:33:00 +00:00
										 |  |  |  |                   className="block w-full pr-20 border-gray-300 rounded-sm focus:ring-neutral-900 focus:border-neutral-900 sm:text-sm" | 
					
						
							| 
									
										
										
										
											2021-08-03 17:36:55 +00:00
										 |  |  |  |                   placeholder="15" | 
					
						
							| 
									
										
										
										
											2021-10-07 15:43:20 +00:00
										 |  |  |  |                   defaultValue={15} | 
					
						
							| 
									
										
										
										
											2021-08-03 17:36:55 +00:00
										 |  |  |  |                 /> | 
					
						
							| 
									
										
										
										
											2021-09-15 12:33:00 +00:00
										 |  |  |  |                 <div className="absolute inset-y-0 right-0 flex items-center pr-3 text-sm text-gray-400"> | 
					
						
							| 
									
										
										
										
											2021-10-11 13:42:43 +00:00
										 |  |  |  |                   {t("minutes")} | 
					
						
							| 
									
										
										
										
											2021-08-03 17:36:55 +00:00
										 |  |  |  |                 </div> | 
					
						
							|  |  |  |  |               </div> | 
					
						
							|  |  |  |  |             </div> | 
					
						
							|  |  |  |  |           </div> | 
					
						
							| 
									
										
										
										
											2021-09-14 08:45:28 +00:00
										 |  |  |  |           {teamId && ( | 
					
						
							|  |  |  |  |             <div className="mb-4"> | 
					
						
							|  |  |  |  |               <label htmlFor="schedulingType" className="block text-sm font-medium text-gray-700"> | 
					
						
							| 
									
										
										
										
											2021-10-11 13:42:43 +00:00
										 |  |  |  |                 {t("scheduling_type")} | 
					
						
							| 
									
										
										
										
											2021-09-14 08:45:28 +00:00
										 |  |  |  |               </label> | 
					
						
							|  |  |  |  |               <RadioArea.Group | 
					
						
							|  |  |  |  |                 name="schedulingType" | 
					
						
							| 
									
										
										
										
											2021-09-15 12:33:00 +00:00
										 |  |  |  |                 className="relative flex mt-1 space-x-6 rounded-sm shadow-sm"> | 
					
						
							|  |  |  |  |                 <RadioArea.Item value={SchedulingType.COLLECTIVE} className="w-1/2 text-sm"> | 
					
						
							| 
									
										
										
										
											2021-10-11 13:42:43 +00:00
										 |  |  |  |                   <strong className="block mb-1">{t("collective")}</strong> | 
					
						
							|  |  |  |  |                   <p>{t("collective_description")}</p> | 
					
						
							| 
									
										
										
										
											2021-09-14 08:45:28 +00:00
										 |  |  |  |                 </RadioArea.Item> | 
					
						
							| 
									
										
										
										
											2021-09-15 12:33:00 +00:00
										 |  |  |  |                 <RadioArea.Item value={SchedulingType.ROUND_ROBIN} className="w-1/2 text-sm"> | 
					
						
							| 
									
										
										
										
											2021-10-11 13:42:43 +00:00
										 |  |  |  |                   <strong className="block mb-1">{t("round_robin")}</strong> | 
					
						
							|  |  |  |  |                   <p>{t("round_robin_description")}</p> | 
					
						
							| 
									
										
										
										
											2021-09-14 08:45:28 +00:00
										 |  |  |  |                 </RadioArea.Item> | 
					
						
							|  |  |  |  |               </RadioArea.Group> | 
					
						
							|  |  |  |  |             </div> | 
					
						
							|  |  |  |  |           )} | 
					
						
							|  |  |  |  |           <div className="mt-8 sm:flex sm:flex-row-reverse gap-x-2"> | 
					
						
							| 
									
										
										
										
											2021-09-06 13:51:15 +00:00
										 |  |  |  |             <Button type="submit" loading={createMutation.isLoading}> | 
					
						
							| 
									
										
										
										
											2021-10-11 13:42:43 +00:00
										 |  |  |  |               {t("continue")} | 
					
						
							| 
									
										
										
										
											2021-09-06 13:51:15 +00:00
										 |  |  |  |             </Button> | 
					
						
							| 
									
										
										
										
											2021-09-15 12:33:00 +00:00
										 |  |  |  |             <DialogClose asChild> | 
					
						
							| 
									
										
										
										
											2021-10-11 13:42:43 +00:00
										 |  |  |  |               <Button color="secondary">{t("cancel")}</Button> | 
					
						
							| 
									
										
										
										
											2021-09-14 08:45:28 +00:00
										 |  |  |  |             </DialogClose> | 
					
						
							| 
									
										
										
										
											2021-08-03 17:36:55 +00:00
										 |  |  |  |           </div> | 
					
						
							|  |  |  |  |         </form> | 
					
						
							|  |  |  |  |       </DialogContent> | 
					
						
							|  |  |  |  |     </Dialog> | 
					
						
							|  |  |  |  |   ); | 
					
						
							| 
									
										
										
										
											2021-08-27 12:11:24 +00:00
										 |  |  |  | }; | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  | export default EventTypesPage; |