
* added base logic for team billing - moved Stripe customer related logic to customer.ts - implemented unstable logic for team owner upgrading, downgrading and adding/removing seats * logic improvements * - improved Alert style - hide free team members on public team page - upgraded textarea to ui component TextArea in SAML setup - added Alert on team settings for hidden members - hide CreateEventTypeButton if not admin - fixed missing locale strings in team settings * remove random import * - show hidden status on team list - refactor team pill * - improved logic (mostly functional) - added Alerts for members & owners - added local strings - created upgrade modal - added info notice on invite member modal - fixed router redirect after leaving team * - improved logic in team-billing - error display on upgrade modal - added better launch.json for VSCode debugger - fixed bug with missing inviteeUserId * code cleanup * nit pick fixes i should sleep now * fixed leave team bug - quantity would not decrease upon leave or removal * added stripe billing callback handler * - better launch.json - teams empty component * - fixed error not removing after successful pro upgrade - fixed silent fail on team create name conflict - fixed input border radius on member invite modal * updated local strings * improved logic for edge cases, such as: - team owned by member sponsored by another team can smoothly upgrade to pro if kicked from sponsored team - logic to calculate if owner is specifically missing pro subscription (ownerIsMissingSeat) - corrected calculation of members missing seats, shouldn't care for proPaidForByTeamId as that only matters for removing member and preserving pro if they pay for it themselves - added react query devtools - added missing locale string * - allow type override for LinkIconButton - consolidate filter logic for getMembersMissingSeats * - only activate team billing for hosted cal - fix prod price keys * fix requiresUpgrade when not hosted by cal * added HOSTED_CAL_FEATURES * fixed failing build - fixed broken import path - added support for premium price plan. (will consider premium as a valid seat) - remove rouge console log * fix customer id type error Co-authored-by: Peer Richelsen <peeroke@gmail.com> Co-authored-by: kodiakhq[bot] <49736102+kodiakhq[bot]@users.noreply.github.com>
44 lines
1.5 KiB
TypeScript
44 lines
1.5 KiB
TypeScript
import { CheckCircleIcon, InformationCircleIcon, XCircleIcon } from "@heroicons/react/solid";
|
|
import classNames from "classnames";
|
|
import { ReactNode } from "react";
|
|
|
|
export interface AlertProps {
|
|
title?: ReactNode;
|
|
message?: ReactNode;
|
|
actions?: ReactNode;
|
|
className?: string;
|
|
severity: "success" | "warning" | "error";
|
|
}
|
|
export function Alert(props: AlertProps) {
|
|
const { severity } = props;
|
|
|
|
return (
|
|
<div
|
|
className={classNames(
|
|
"rounded-sm p-3 border border-opacity-20",
|
|
props.className,
|
|
severity === "error" && "bg-red-50 text-red-800 border-red-900",
|
|
severity === "warning" && "bg-yellow-50 text-yellow-700 border-yellow-700",
|
|
severity === "success" && "bg-gray-900 text-white"
|
|
)}>
|
|
<div className="flex">
|
|
<div className="flex-shrink-0">
|
|
{severity === "error" && (
|
|
<XCircleIcon className={classNames("h-5 w-5 text-red-400")} aria-hidden="true" />
|
|
)}
|
|
{severity === "warning" && (
|
|
<InformationCircleIcon className={classNames("h-5 w-5 text-yellow-400")} aria-hidden="true" />
|
|
)}
|
|
{severity === "success" && (
|
|
<CheckCircleIcon className={classNames("h-5 w-5 text-gray-400")} aria-hidden="true" />
|
|
)}
|
|
</div>
|
|
<div className="flex-grow ml-3">
|
|
<h3 className="text-sm font-medium">{props.title}</h3>
|
|
<div className="text-sm">{props.message}</div>
|
|
</div>
|
|
{props.actions && <div className="text-sm">{props.actions}</div>}
|
|
</div>
|
|
</div>
|
|
);
|
|
}
|