From 5be4abf4f85f720b500b1cadd234d6f7b4a5a6f1 Mon Sep 17 00:00:00 2001 From: Vijayasingam Thanasekaran Date: Wed, 18 Sep 2024 09:18:07 +0100 Subject: [PATCH 1/3] Added menu bar for smaller screens and updated some spacing --- README.md | 2 +- .../dashboard-subscription-card-group.tsx | 7 ++++-- .../landing/dashboard-landing-page.tsx | 4 ++-- .../layout/dashboard-page-header.tsx | 6 ++++- .../dashboard/layout/mobile-sidebar.tsx | 22 +++++++++++++++++++ .../dashboard/payments/components/columns.tsx | 14 +++++++----- .../components/payment-method-section.tsx | 4 ++-- .../components/subscription-cards.tsx | 9 ++++++-- .../components/subscription-detail.tsx | 6 ++--- .../components/subscription-header.tsx | 7 +++--- .../subscription-next-payment-card.tsx | 4 ++-- .../views/multiple-subscriptions-view.tsx | 2 +- .../home/footer/powered-by-paddle.tsx | 2 +- .../home/hero-section/hero-section.tsx | 4 ++-- 14 files changed, 65 insertions(+), 28 deletions(-) create mode 100644 src/components/dashboard/layout/mobile-sidebar.tsx diff --git a/README.md b/README.md index 0fc95da..ba42c8c 100644 --- a/README.md +++ b/README.md @@ -53,7 +53,7 @@ This starter kit is built with: Click this button to clone this repo and create a new project in your Vercel account: -[![Deploy with Vercel](https://vercel.com/button)](https://vercel.com/new/clone?repository-url=https%3A%2F%2Fgithub.com%2FPaddleHQ%2Fpaddle-nextjs-starter-kit&env=PADDLE_API_KEY,PADDLE_NOTIFICATION_WEBHOOK_SECRET,NEXT_PUBLIC_PADDLE_ENV,NEXT_PUBLIC_PADDLE_CLIENT_TOKEN&integration-ids=oac_VqOgBHqhEoFTPzGkPd7L0iH6) +[![Deploy with Vercel](https://vercel.com/button)](https://vercel.com/new/clone?repository-url=https%3A%2F%2Fgithub.com%2FPaddleHQ%2Fpaddle-nextjs-starter-kit&env=PADDLE_API_KEY,NEXT_PUBLIC_PADDLE_ENV,NEXT_PUBLIC_PADDLE_CLIENT_TOKEN&integration-ids=oac_VqOgBHqhEoFTPzGkPd7L0iH6&external-id=https%3A%2F%2Fgithub.com%2FPaddleHQ%2Fpaddle-nextjs-starter-kit%2Ftree%2Fmain) You can also [create a new application manually](https://vercel.com/new). diff --git a/src/components/dashboard/landing/components/dashboard-subscription-card-group.tsx b/src/components/dashboard/landing/components/dashboard-subscription-card-group.tsx index b915200..8f41bcf 100644 --- a/src/components/dashboard/landing/components/dashboard-subscription-card-group.tsx +++ b/src/components/dashboard/landing/components/dashboard-subscription-card-group.tsx @@ -17,9 +17,12 @@ export async function DashboardSubscriptionCardGroup() { - + {subscriptions?.data ? ( - + ) : ( )} diff --git a/src/components/dashboard/landing/dashboard-landing-page.tsx b/src/components/dashboard/landing/dashboard-landing-page.tsx index d729247..d0cf388 100644 --- a/src/components/dashboard/landing/dashboard-landing-page.tsx +++ b/src/components/dashboard/landing/dashboard-landing-page.tsx @@ -6,11 +6,11 @@ import { DashboardTeamMembersCard } from '@/components/dashboard/landing/compone export function DashboardLandingPage() { return (
-
+
-
+
diff --git a/src/components/dashboard/layout/dashboard-page-header.tsx b/src/components/dashboard/layout/dashboard-page-header.tsx index 341c1e1..c8ec8be 100644 --- a/src/components/dashboard/layout/dashboard-page-header.tsx +++ b/src/components/dashboard/layout/dashboard-page-header.tsx @@ -1,4 +1,5 @@ import { Separator } from '@/components/ui/separator'; +import { MobileSidebar } from '@/components/dashboard/layout/mobile-sidebar'; interface Props { pageTitle: string; @@ -7,7 +8,10 @@ interface Props { export function DashboardPageHeader({ pageTitle }: Props) { return (
-

{pageTitle}

+
+ +

{pageTitle}

+
); diff --git a/src/components/dashboard/layout/mobile-sidebar.tsx b/src/components/dashboard/layout/mobile-sidebar.tsx new file mode 100644 index 0000000..cbc8fa8 --- /dev/null +++ b/src/components/dashboard/layout/mobile-sidebar.tsx @@ -0,0 +1,22 @@ +import { Sheet, SheetContent, SheetTrigger } from '@/components/ui/sheet'; +import { Button } from '@/components/ui/button'; +import { Menu } from 'lucide-react'; +import { Sidebar } from '@/components/dashboard/layout/sidebar'; +import { SidebarUserInfo } from '@/components/dashboard/layout/sidebar-user-info'; + +export function MobileSidebar() { + return ( + + + + + + + + + + ); +} diff --git a/src/components/dashboard/payments/components/columns.tsx b/src/components/dashboard/payments/components/columns.tsx index 29cf4c5..5d28aa8 100644 --- a/src/components/dashboard/payments/components/columns.tsx +++ b/src/components/dashboard/payments/components/columns.tsx @@ -44,12 +44,14 @@ export const columns: ColumnDef[] = [ size: columnSize, cell: ({ row }) => { return ( -
- {getPaymentReason(row.original.origin)} - {row.original.details?.lineItems[0].product?.name} - {row.original.details?.lineItems && row.original.details?.lineItems.length > 1 && ( - +{row.original.details?.lineItems.length - 1} more - )} +
+
+ {getPaymentReason(row.original.origin)} + {row.original.details?.lineItems[0].product?.name} + {row.original.details?.lineItems && row.original.details?.lineItems.length > 1 && ( + +{row.original.details?.lineItems.length - 1} more + )} +
); }, diff --git a/src/components/dashboard/subscriptions/components/payment-method-section.tsx b/src/components/dashboard/subscriptions/components/payment-method-section.tsx index 116f253..16f1531 100644 --- a/src/components/dashboard/subscriptions/components/payment-method-section.tsx +++ b/src/components/dashboard/subscriptions/components/payment-method-section.tsx @@ -20,7 +20,7 @@ export function PaymentMethodSection({ transactions, updatePaymentMethodUrl }: P return null; } return ( -
+
Payment method
@@ -31,7 +31,7 @@ export function PaymentMethodSection({ transactions, updatePaymentMethodUrl }: P
diff --git a/src/components/dashboard/subscriptions/components/subscription-cards.tsx b/src/components/dashboard/subscriptions/components/subscription-cards.tsx index c575100..670abb3 100644 --- a/src/components/dashboard/subscriptions/components/subscription-cards.tsx +++ b/src/components/dashboard/subscriptions/components/subscription-cards.tsx @@ -21,7 +21,7 @@ export function SubscriptionCards({ subscriptions, className }: Props) { {subscriptions.map((subscription) => { const subscriptionItem = subscription.items[0]; const price = subscriptionItem.quantity * parseFloat(subscriptionItem.price.unitPrice.amount); - const formattedPrice = parseMoney(price.toString(), subscriptionItem.price.unitPrice.currencyCode); + const formattedPrice = parseMoney(price.toString(), subscription.currencyCode); const frequency = subscription.billingCycle.frequency === 1 ? `/${subscription.billingCycle.interval}` @@ -30,7 +30,12 @@ export function SubscriptionCards({ subscriptions, className }: Props) { -
+
{subscriptionItem.product.imageUrl && (
-
-
+
+
-
+
diff --git a/src/components/dashboard/subscriptions/components/subscription-header.tsx b/src/components/dashboard/subscriptions/components/subscription-header.tsx index 6da9172..9b88317 100644 --- a/src/components/dashboard/subscriptions/components/subscription-header.tsx +++ b/src/components/dashboard/subscriptions/components/subscription-header.tsx @@ -4,8 +4,8 @@ import { Status } from '@/components/shared/status/status'; import { parseMoney } from '@/utils/paddle/parse-money'; import dayjs from 'dayjs'; import { SubscriptionHeaderActionButton } from '@/components/dashboard/subscriptions/components/subscription-header-action-button'; -import { Alert } from '@/components/ui/alert'; import { SubscriptionAlerts } from '@/components/dashboard/subscriptions/components/subscription-alerts'; +import { MobileSidebar } from '@/components/dashboard/layout/mobile-sidebar'; interface Props { subscription: Subscription; @@ -24,16 +24,17 @@ export function SubscriptionHeader({ subscription }: Props) { const formattedStartedDate = dayjs(subscription.startedAt).format('MMM DD, YYYY'); return ( -
+
+ {subscriptionItem.product.imageUrl && ( {subscriptionItem.product.name} )} {subscriptionItem.product.name}
-
+
{formattedPrice} {frequency} diff --git a/src/components/dashboard/subscriptions/components/subscription-next-payment-card.tsx b/src/components/dashboard/subscriptions/components/subscription-next-payment-card.tsx index fc74d1f..ffca369 100644 --- a/src/components/dashboard/subscriptions/components/subscription-next-payment-card.tsx +++ b/src/components/dashboard/subscriptions/components/subscription-next-payment-card.tsx @@ -14,10 +14,10 @@ export function SubscriptionNextPaymentCard({ subscription, transactions }: Prop return null; } return ( - +
Next payment
-
+
{parseMoney(subscription?.nextTransaction?.details.totals.total, subscription?.currencyCode)} diff --git a/src/components/dashboard/subscriptions/views/multiple-subscriptions-view.tsx b/src/components/dashboard/subscriptions/views/multiple-subscriptions-view.tsx index b958d08..38cc3e3 100644 --- a/src/components/dashboard/subscriptions/views/multiple-subscriptions-view.tsx +++ b/src/components/dashboard/subscriptions/views/multiple-subscriptions-view.tsx @@ -10,7 +10,7 @@ export function MultipleSubscriptionsView({ subscriptions }: Props) { return ( <> - + ); } diff --git a/src/components/home/footer/powered-by-paddle.tsx b/src/components/home/footer/powered-by-paddle.tsx index 4e08acf..b3d613c 100644 --- a/src/components/home/footer/powered-by-paddle.tsx +++ b/src/components/home/footer/powered-by-paddle.tsx @@ -16,7 +16,7 @@ export function PoweredByPaddle() { A Next.js template by {'Paddle
-
+
Explore Paddle diff --git a/src/components/home/hero-section/hero-section.tsx b/src/components/home/hero-section/hero-section.tsx index 675f986..3014365 100644 --- a/src/components/home/hero-section/hero-section.tsx +++ b/src/components/home/hero-section/hero-section.tsx @@ -2,12 +2,12 @@ export function HeroSection() { return (
-

+

Powerful design tools.
Simple pricing.

-

+

Plans for teams of every size — from start-up to enterprise.

From 7ed70f9c48435b149021a7287edac6ad9914363c Mon Sep 17 00:00:00 2001 From: heymcgovern <25659933+heymcgovern@users.noreply.github.com> Date: Wed, 18 Sep 2024 09:21:07 +0100 Subject: [PATCH 2/3] Update README * Clarify how to add a notification destination * Fix links to tutorial --- README.md | 16 ++++++++-------- 1 file changed, 8 insertions(+), 8 deletions(-) diff --git a/README.md b/README.md index ba42c8c..22f5301 100644 --- a/README.md +++ b/README.md @@ -45,7 +45,7 @@ This starter kit is built with: ## Step-by-step setup -> **Important:** If you're totally new to Next.js and Paddle, we have a more complete tutorial on our dev docs: [Build and deploy Next.js app with Vercel and Supabase](https://developer.paddle.com/build/vercel-starter-kit?utm_source=dx&utm_medium=paddle-nextjs-starter-kit) +> **Important:** If you're totally new to Next.js and Paddle, we have a more complete tutorial on our dev docs: [Build and deploy Next.js app with Vercel and Supabase](https://developer.paddle.com/build/nextjs-supabase-vercel-starter-kit?utm_source=dx&utm_medium=paddle-nextjs-starter-kit) ### 1. Deploy on Vercel @@ -63,12 +63,12 @@ Click **Add** to walk through integrating with Supabase. You'll be asked to auth Then, enter Paddle environment variables: -| Variable | Used for | How to get it | -| ------------------------------------ | -------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------- | -------------------------------------------------------------------------------------------------------------------------------------------------------------------------------- | -| `PADDLE_API_KEY` | An [API key](https://developer.paddle.com/api-reference/about/authentication?utm_source=dx&utm_medium=paddle-nextjs-starter-kit), used for interacting with Paddle data in the backend. For example, syncing customer and subscription data with Supabase. | Go to [**Paddle > Developer tools > Authentication**](https://sandbox-vendors.paddle.com/authentication-v2) and create a new API key. | -| `NEXT_PUBLIC_PADDLE_CLIENT_TOKEN` | A [client-side key](https://developer.paddle.com/api-reference/about/authentication?utm_source=dx&utm_medium=paddle-nextjs-starter-kit), used for interacting with Paddle in the frontend. For example, getting localized prices for pricing pages and opening a checkout. | Go to [**Paddle > Developer tools > Authentication**](https://sandbox-vendors.paddle.com/authentication-v2) and create a new client-side token. | -| `PADDLE_NOTIFICATION_WEBHOOK_SECRET` | A secret key used for verifying that [webhooks](https://developer.paddle.com/webhooks/notification-destinations?utm_source=dx&utm_medium=paddle-nextjs-starter-kit) came from Paddle and haven't been tampered with in transit. Important for security. | Go to [**Paddle > Developer tools > Notifications**](https://sandbox-vendors.paddle.com/notifications), create a new notification destination, then edit to copy the secret key. | -| `NEXT_PUBLIC_PADDLE_ENV` | Environment for our Paddle account. This should match the kind of Paddle account you signed up for. | Enter `sandbox` for sandbox accounts or `production` for live accounts. | +| Variable | Used for | How to get it | +| ------------------------------------ | -------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------- |-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| +| `PADDLE_API_KEY` | An [API key](https://developer.paddle.com/api-reference/about/authentication?utm_source=dx&utm_medium=paddle-nextjs-starter-kit), used for interacting with Paddle data in the backend. For example, syncing customer and subscription data with Supabase. | Go to [**Paddle > Developer tools > Authentication**](https://sandbox-vendors.paddle.com/authentication-v2) and create a new API key. | +| `NEXT_PUBLIC_PADDLE_CLIENT_TOKEN` | A [client-side key](https://developer.paddle.com/api-reference/about/authentication?utm_source=dx&utm_medium=paddle-nextjs-starter-kit), used for interacting with Paddle in the frontend. For example, getting localized prices for pricing pages and opening a checkout. | Go to [**Paddle > Developer tools > Authentication**](https://sandbox-vendors.paddle.com/authentication-v2) and create a new client-side token. | +| `PADDLE_NOTIFICATION_WEBHOOK_SECRET` | A secret key used for verifying that [webhooks](https://developer.paddle.com/webhooks/notification-destinations?utm_source=dx&utm_medium=paddle-nextjs-starter-kit) came from Paddle and haven't been tampered with in transit. Important for security. | Go to [**Paddle > Developer tools > Notifications**](https://sandbox-vendors.paddle.com/notifications), create a new notification destination for `https://.vercel.app/api/webhook`, then edit to copy the secret key. | +| `NEXT_PUBLIC_PADDLE_ENV` | Environment for our Paddle account. This should match the kind of Paddle account you signed up for. | Enter `sandbox` for sandbox accounts or `production` for live accounts. | You can use `https://.vercel.app/api/webhook` as the endpoint URL for your notification destination, where `` is the name of your project in Vercel. This may change if your project name isn't unique, but we can update this later. @@ -163,6 +163,6 @@ For help, contact the Paddle DX team at `team-dx@paddle.com`. ## Learn more -- [Build and deploy Next.js app with Vercel and Supabase](https://developer.paddle.com/build/vercel-starter-kit?utm_source=dx&utm_medium=paddle-nextjs-starter-kit) +- [Build and deploy Next.js app with Vercel and Supabase](https://developer.paddle.com/build/nextjs-supabase-vercel-starter-kit?utm_source=dx&utm_medium=paddle-nextjs-starter-kit) - [Paddle API reference](https://developer.paddle.com/api-reference/overview?utm_source=dx&utm_medium=paddle-nextjs-starter-kit) - [Sign up for Paddle Billing](https://sandbox-login.paddle.com/signup?utm_source=dx&utm_medium=paddle-nextjs-starter-kit) From ee8f57a97b68a1cd7ab68bcbbb2f7c7754895897 Mon Sep 17 00:00:00 2001 From: Vijayasingam Thanasekaran Date: Wed, 18 Sep 2024 09:27:50 +0100 Subject: [PATCH 3/3] Added menu bar for smaller screens and updated some spacing --- README.md | 12 ++++++------ 1 file changed, 6 insertions(+), 6 deletions(-) diff --git a/README.md b/README.md index 22f5301..53b5089 100644 --- a/README.md +++ b/README.md @@ -53,7 +53,7 @@ This starter kit is built with: Click this button to clone this repo and create a new project in your Vercel account: -[![Deploy with Vercel](https://vercel.com/button)](https://vercel.com/new/clone?repository-url=https%3A%2F%2Fgithub.com%2FPaddleHQ%2Fpaddle-nextjs-starter-kit&env=PADDLE_API_KEY,NEXT_PUBLIC_PADDLE_ENV,NEXT_PUBLIC_PADDLE_CLIENT_TOKEN&integration-ids=oac_VqOgBHqhEoFTPzGkPd7L0iH6&external-id=https%3A%2F%2Fgithub.com%2FPaddleHQ%2Fpaddle-nextjs-starter-kit%2Ftree%2Fmain) +[![Deploy with Vercel](https://vercel.com/button)](https://vercel.com/new/clone?repository-url=https%3A%2F%2Fgithub.com%2FPaddleHQ%2Fpaddle-nextjs-starter-kit&env=PADDLE_API_KEY,PADDLE_NOTIFICATION_WEBHOOK_SECRET,NEXT_PUBLIC_PADDLE_ENV,NEXT_PUBLIC_PADDLE_CLIENT_TOKEN&integration-ids=oac_VqOgBHqhEoFTPzGkPd7L0iH6&external-id=https%3A%2F%2Fgithub.com%2FPaddleHQ%2Fpaddle-nextjs-starter-kit%2Ftree%2Fmain) You can also [create a new application manually](https://vercel.com/new). @@ -63,12 +63,12 @@ Click **Add** to walk through integrating with Supabase. You'll be asked to auth Then, enter Paddle environment variables: -| Variable | Used for | How to get it | -| ------------------------------------ | -------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------- |-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| -| `PADDLE_API_KEY` | An [API key](https://developer.paddle.com/api-reference/about/authentication?utm_source=dx&utm_medium=paddle-nextjs-starter-kit), used for interacting with Paddle data in the backend. For example, syncing customer and subscription data with Supabase. | Go to [**Paddle > Developer tools > Authentication**](https://sandbox-vendors.paddle.com/authentication-v2) and create a new API key. | -| `NEXT_PUBLIC_PADDLE_CLIENT_TOKEN` | A [client-side key](https://developer.paddle.com/api-reference/about/authentication?utm_source=dx&utm_medium=paddle-nextjs-starter-kit), used for interacting with Paddle in the frontend. For example, getting localized prices for pricing pages and opening a checkout. | Go to [**Paddle > Developer tools > Authentication**](https://sandbox-vendors.paddle.com/authentication-v2) and create a new client-side token. | +| Variable | Used for | How to get it | +| ------------------------------------ | -------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------- | ----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------- | +| `PADDLE_API_KEY` | An [API key](https://developer.paddle.com/api-reference/about/authentication?utm_source=dx&utm_medium=paddle-nextjs-starter-kit), used for interacting with Paddle data in the backend. For example, syncing customer and subscription data with Supabase. | Go to [**Paddle > Developer tools > Authentication**](https://sandbox-vendors.paddle.com/authentication-v2) and create a new API key. | +| `NEXT_PUBLIC_PADDLE_CLIENT_TOKEN` | A [client-side key](https://developer.paddle.com/api-reference/about/authentication?utm_source=dx&utm_medium=paddle-nextjs-starter-kit), used for interacting with Paddle in the frontend. For example, getting localized prices for pricing pages and opening a checkout. | Go to [**Paddle > Developer tools > Authentication**](https://sandbox-vendors.paddle.com/authentication-v2) and create a new client-side token. | | `PADDLE_NOTIFICATION_WEBHOOK_SECRET` | A secret key used for verifying that [webhooks](https://developer.paddle.com/webhooks/notification-destinations?utm_source=dx&utm_medium=paddle-nextjs-starter-kit) came from Paddle and haven't been tampered with in transit. Important for security. | Go to [**Paddle > Developer tools > Notifications**](https://sandbox-vendors.paddle.com/notifications), create a new notification destination for `https://.vercel.app/api/webhook`, then edit to copy the secret key. | -| `NEXT_PUBLIC_PADDLE_ENV` | Environment for our Paddle account. This should match the kind of Paddle account you signed up for. | Enter `sandbox` for sandbox accounts or `production` for live accounts. | +| `NEXT_PUBLIC_PADDLE_ENV` | Environment for our Paddle account. This should match the kind of Paddle account you signed up for. | Enter `sandbox` for sandbox accounts or `production` for live accounts. | You can use `https://.vercel.app/api/webhook` as the endpoint URL for your notification destination, where `` is the name of your project in Vercel. This may change if your project name isn't unique, but we can update this later.