From 247b5bdada0081fa1577bb725b76030e8b3d1281 Mon Sep 17 00:00:00 2001 From: Bokdol11859 <2019147551@yonsei.ac.kr> Date: Sat, 20 Jan 2024 19:44:34 +0900 Subject: [PATCH] feat: implement toast on ticker delete --- package.json | 3 ++ pnpm-lock.yaml | 31 +++++++++++++ src/app/layout.tsx | 12 +++-- .../{drawer.tsx => ticker-drawer.tsx} | 0 src/app/ticker/_components/ticker-list.tsx | 41 +++++++++++++++++ src/app/ticker/page.tsx | 8 ++-- .../{NavigationBar.tsx => navigation-bar.tsx} | 0 src/components/common/toast/toast.tsx | 39 ++++++++++++++++ src/components/ui/button.tsx | 46 +++++++++++++++++++ src/components/ui/sonner.tsx | 31 +++++++++++++ 10 files changed, 204 insertions(+), 7 deletions(-) rename src/app/ticker/_components/{drawer.tsx => ticker-drawer.tsx} (100%) create mode 100644 src/app/ticker/_components/ticker-list.tsx rename src/components/common/{NavigationBar.tsx => navigation-bar.tsx} (100%) create mode 100644 src/components/common/toast/toast.tsx create mode 100644 src/components/ui/button.tsx create mode 100644 src/components/ui/sonner.tsx diff --git a/package.json b/package.json index a089d7c..e078076 100644 --- a/package.json +++ b/package.json @@ -11,6 +11,7 @@ "dependencies": { "@lukemorales/query-key-factory": "^1.3.2", "@radix-ui/react-dialog": "^1.0.5", + "@radix-ui/react-slot": "^1.0.2", "@tanstack/react-query": "^5.17.9", "@tanstack/react-query-devtools": "^5.17.9", "class-variance-authority": "^0.7.0", @@ -18,8 +19,10 @@ "eslint-plugin-tailwindcss": "^3.13.1", "lucide-react": "^0.312.0", "next": "14.0.4", + "next-themes": "^0.2.1", "react": "^18", "react-dom": "^18", + "sonner": "^1.3.1", "tailwind-merge": "^2.2.0", "vaul": "^0.8.0", "zustand": "^4.4.7" diff --git a/pnpm-lock.yaml b/pnpm-lock.yaml index 1914e25..3347e4e 100644 --- a/pnpm-lock.yaml +++ b/pnpm-lock.yaml @@ -11,6 +11,9 @@ dependencies: '@radix-ui/react-dialog': specifier: ^1.0.5 version: 1.0.5(@types/react-dom@18.2.18)(@types/react@18.2.47)(react-dom@18.2.0)(react@18.2.0) + '@radix-ui/react-slot': + specifier: ^1.0.2 + version: 1.0.2(@types/react@18.2.47)(react@18.2.0) '@tanstack/react-query': specifier: ^5.17.9 version: 5.17.9(react@18.2.0) @@ -32,12 +35,18 @@ dependencies: next: specifier: 14.0.4 version: 14.0.4(react-dom@18.2.0)(react@18.2.0) + next-themes: + specifier: ^0.2.1 + version: 0.2.1(next@14.0.4)(react-dom@18.2.0)(react@18.2.0) react: specifier: ^18 version: 18.2.0 react-dom: specifier: ^18 version: 18.2.0(react@18.2.0) + sonner: + specifier: ^1.3.1 + version: 1.3.1(react-dom@18.2.0)(react@18.2.0) tailwind-merge: specifier: ^2.2.0 version: 2.2.0 @@ -2332,6 +2341,18 @@ packages: resolution: {integrity: sha512-OWND8ei3VtNC9h7V60qff3SVobHr996CTwgxubgyQYEpg290h9J0buyECNNJexkFm5sOajh5G116RYA1c8ZMSw==} dev: true + /next-themes@0.2.1(next@14.0.4)(react-dom@18.2.0)(react@18.2.0): + resolution: {integrity: sha512-B+AKNfYNIzh0vqQQKqQItTS8evEouKD7H5Hj3kmuPERwddR2TxvDSFZuTj6T7Jfn1oyeUyJMydPl1Bkxkh0W7A==} + peerDependencies: + next: '*' + react: '*' + react-dom: '*' + dependencies: + next: 14.0.4(react-dom@18.2.0)(react@18.2.0) + react: 18.2.0 + react-dom: 18.2.0(react@18.2.0) + dev: false + /next@14.0.4(react-dom@18.2.0)(react@18.2.0): resolution: {integrity: sha512-qbwypnM7327SadwFtxXnQdGiKpkuhaRLE2uq62/nRul9cj9KhQ5LhHmlziTNqUidZotw/Q1I9OjirBROdUJNgA==} engines: {node: '>=18.17.0'} @@ -2871,6 +2892,16 @@ packages: engines: {node: '>=8'} dev: true + /sonner@1.3.1(react-dom@18.2.0)(react@18.2.0): + resolution: {integrity: sha512-+rOAO56b2eI3q5BtgljERSn2umRk63KFIvgb2ohbZ5X+Eb5u+a/7/0ZgswYqgBMg8dyl7n6OXd9KasA8QF9ToA==} + peerDependencies: + react: ^18.0.0 + react-dom: ^18.0.0 + dependencies: + react: 18.2.0 + react-dom: 18.2.0(react@18.2.0) + dev: false + /source-map-js@1.0.2: resolution: {integrity: sha512-R0XvVJ9WusLiqTCEiGCmICCMplcCkIwwR11mOSD9CR5u+IXYdiseeEuXCVAjS54zqwkLcPNnmU4OeJ6tUrWhDw==} engines: {node: '>=0.10.0'} diff --git a/src/app/layout.tsx b/src/app/layout.tsx index ac3a187..a3617d3 100644 --- a/src/app/layout.tsx +++ b/src/app/layout.tsx @@ -1,12 +1,15 @@ import type { Metadata } from "next"; -import { Inter } from "next/font/google"; +import { Inter, Poppins, DM_Sans } from "next/font/google"; import "./globals.css"; import React from "react"; import { GlobalProvider } from "./global-provider"; import { cn } from "@/utils/cn"; -import NavigationBar from "@/components/common/NavigationBar"; +import NavigationBar from "@/components/common/navigation-bar"; +import { Toaster } from "@/components/ui/sonner"; const inter = Inter({ subsets: ["latin"] }); +const poppins = Poppins({ subsets: ["latin"], weight: ["400", "500", "600", "700"] }); +const dm_sans = DM_Sans({ subsets: ["latin"], weight: ["400", "500", "600", "700"] }); export const metadata: Metadata = { title: "Create Next App", @@ -16,11 +19,12 @@ export const metadata: Metadata = { export default function RootLayout({ children }: { children: React.ReactNode }) { return ( -
+You Added 0 Tickers
-{title}
+ {isRevertable &&