From 04572a8e5081b1e4871e273cde9dbaaa44c52fe0 Mon Sep 17 00:00:00 2001 From: MohamedBassem Date: Wed, 13 Mar 2024 21:43:44 +0000 Subject: structure: Create apps dir and copy tooling dir from t3-turbo repo --- apps/web/components/ui/action-button.tsx | 25 ++++ apps/web/components/ui/back-button.tsx | 9 ++ apps/web/components/ui/badge.tsx | 36 ++++++ apps/web/components/ui/button.tsx | 56 +++++++++ apps/web/components/ui/card.tsx | 86 +++++++++++++ apps/web/components/ui/dialog.tsx | 122 +++++++++++++++++++ apps/web/components/ui/dropdown-menu.tsx | 200 +++++++++++++++++++++++++++++++ apps/web/components/ui/form.tsx | 177 +++++++++++++++++++++++++++ apps/web/components/ui/imageCard.tsx | 70 +++++++++++ apps/web/components/ui/input.tsx | 25 ++++ apps/web/components/ui/label.tsx | 26 ++++ apps/web/components/ui/popover.tsx | 31 +++++ apps/web/components/ui/scroll-area.tsx | 48 ++++++++ apps/web/components/ui/select.tsx | 160 +++++++++++++++++++++++++ apps/web/components/ui/separator.tsx | 31 +++++ apps/web/components/ui/skeleton.tsx | 15 +++ apps/web/components/ui/spinner.tsx | 20 ++++ apps/web/components/ui/table.tsx | 117 ++++++++++++++++++ apps/web/components/ui/tabs.tsx | 55 +++++++++ apps/web/components/ui/textarea.tsx | 24 ++++ apps/web/components/ui/toast.tsx | 127 ++++++++++++++++++++ apps/web/components/ui/toaster.tsx | 35 ++++++ apps/web/components/ui/use-toast.ts | 189 +++++++++++++++++++++++++++++ 23 files changed, 1684 insertions(+) create mode 100644 apps/web/components/ui/action-button.tsx create mode 100644 apps/web/components/ui/back-button.tsx create mode 100644 apps/web/components/ui/badge.tsx create mode 100644 apps/web/components/ui/button.tsx create mode 100644 apps/web/components/ui/card.tsx create mode 100644 apps/web/components/ui/dialog.tsx create mode 100644 apps/web/components/ui/dropdown-menu.tsx create mode 100644 apps/web/components/ui/form.tsx create mode 100644 apps/web/components/ui/imageCard.tsx create mode 100644 apps/web/components/ui/input.tsx create mode 100644 apps/web/components/ui/label.tsx create mode 100644 apps/web/components/ui/popover.tsx create mode 100644 apps/web/components/ui/scroll-area.tsx create mode 100644 apps/web/components/ui/select.tsx create mode 100644 apps/web/components/ui/separator.tsx create mode 100644 apps/web/components/ui/skeleton.tsx create mode 100644 apps/web/components/ui/spinner.tsx create mode 100644 apps/web/components/ui/table.tsx create mode 100644 apps/web/components/ui/tabs.tsx create mode 100644 apps/web/components/ui/textarea.tsx create mode 100644 apps/web/components/ui/toast.tsx create mode 100644 apps/web/components/ui/toaster.tsx create mode 100644 apps/web/components/ui/use-toast.ts (limited to 'apps/web/components/ui') diff --git a/apps/web/components/ui/action-button.tsx b/apps/web/components/ui/action-button.tsx new file mode 100644 index 00000000..42e16f65 --- /dev/null +++ b/apps/web/components/ui/action-button.tsx @@ -0,0 +1,25 @@ +import { Button, ButtonProps } from "./button"; +import LoadingSpinner from "./spinner"; + +export function ActionButton({ + children, + loading, + spinner, + disabled, + ...props +}: ButtonProps & { + loading: boolean; + spinner?: React.ReactNode; +}) { + spinner ||= ; + if (disabled !== undefined) { + disabled ||= loading; + } else if (loading) { + disabled = true; + } + return ( + + ); +} diff --git a/apps/web/components/ui/back-button.tsx b/apps/web/components/ui/back-button.tsx new file mode 100644 index 00000000..685930df --- /dev/null +++ b/apps/web/components/ui/back-button.tsx @@ -0,0 +1,9 @@ +"use client"; + +import { useRouter } from "next/navigation"; +import { Button, ButtonProps } from "./button"; + +export function BackButton({ ...props }: ButtonProps) { + const router = useRouter(); + return