Skip to content

Commit

Permalink
chore(core): bump next-intl (bigcommerce#1491)
Browse files Browse the repository at this point in the history
* chore(core): bump next-intl

* fix: compare link needs to be set as pathname/query

* fix: pass in default channels in routes
  • Loading branch information
jorgemoya authored Oct 21, 2024
1 parent a22233f commit 313a591
Show file tree
Hide file tree
Showing 30 changed files with 99 additions and 157 deletions.
9 changes: 9 additions & 0 deletions .changeset/silent-rats-hear.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,9 @@
---
"@bigcommerce/catalyst-core": minor
---

Bump `next-intl` which includes [some minor changes and updated APIs]((https://next-intl-docs.vercel.app/blog/next-intl-3-22)):

+ Use new `createNavigation` api.
+ Pass `locale` to redirects.
+ `setRequestLocale` is no longer unstable.
5 changes: 3 additions & 2 deletions core/app/[locale]/(default)/(auth)/change-password/page.tsx
Original file line number Diff line number Diff line change
@@ -1,4 +1,4 @@
import { useTranslations } from 'next-intl';
import { useLocale, useTranslations } from 'next-intl';
import { getTranslations } from 'next-intl/server';

import { redirect } from '~/i18n/routing';
Expand All @@ -22,12 +22,13 @@ interface Props {

export default function ChangePassword({ searchParams }: Props) {
const t = useTranslations('ChangePassword');
const locale = useLocale();

const customerId = searchParams.c;
const customerToken = searchParams.t;

if (!customerId || !customerToken) {
redirect('/login');
redirect({ href: '/login', locale });
}

if (customerId && customerToken) {
Expand Down
5 changes: 4 additions & 1 deletion core/app/[locale]/(default)/(auth)/login/_actions/login.ts
Original file line number Diff line number Diff line change
@@ -1,12 +1,15 @@
'use server';

import { isRedirectError } from 'next/dist/client/components/redirect';
import { getLocale } from 'next-intl/server';

import { Credentials, signIn } from '~/auth';
import { redirect } from '~/i18n/routing';

export const login = async (_previousState: unknown, formData: FormData) => {
try {
const locale = await getLocale();

const credentials = Credentials.parse({
email: formData.get('email'),
password: formData.get('password'),
Expand All @@ -19,7 +22,7 @@ export const login = async (_previousState: unknown, formData: FormData) => {
redirect: false,
});

redirect('/account');
redirect({ href: '/account', locale });
} catch (error: unknown) {
// We need to throw this error to trigger the redirect as Next.js uses error boundaries to redirect.
if (isRedirectError(error)) {
Expand Down
4 changes: 2 additions & 2 deletions core/app/[locale]/(default)/(auth)/login/page.tsx
Original file line number Diff line number Diff line change
@@ -1,5 +1,5 @@
import { useTranslations } from 'next-intl';
import { getTranslations, unstable_setRequestLocale } from 'next-intl/server';
import { getTranslations, setRequestLocale } from 'next-intl/server';

import { Link } from '~/components/link';
import { Button } from '~/components/ui/button';
Expand All @@ -20,7 +20,7 @@ interface Props {
}

export default function Login({ params: { locale } }: Props) {
unstable_setRequestLocale(locale);
setRequestLocale(locale);

const t = useTranslations('Login');

Expand Down
Original file line number Diff line number Diff line change
@@ -1,11 +1,14 @@
'use server';

import { isRedirectError } from 'next/dist/client/components/redirect';
import { getLocale } from 'next-intl/server';

import { Credentials, signIn } from '~/auth';
import { redirect } from '~/i18n/routing';

export const login = async (formData: FormData) => {
const locale = await getLocale();

try {
const credentials = Credentials.parse({
email: formData.get('customer-email'),
Expand All @@ -19,7 +22,7 @@ export const login = async (formData: FormData) => {
redirect: false,
});

redirect('/account');
redirect({ href: '/account', locale });
} catch (error: unknown) {
if (isRedirectError(error)) {
throw error;
Expand Down
4 changes: 2 additions & 2 deletions core/app/[locale]/(default)/(faceted)/brand/[slug]/page.tsx
Original file line number Diff line number Diff line change
@@ -1,6 +1,6 @@
import type { Metadata } from 'next';
import { notFound } from 'next/navigation';
import { getTranslations, unstable_setRequestLocale } from 'next-intl/server';
import { getTranslations, setRequestLocale } from 'next-intl/server';

import { ProductCard } from '~/components/product-card';
import { Pagination } from '~/components/ui/pagination';
Expand Down Expand Up @@ -40,7 +40,7 @@ export async function generateMetadata({ params }: Props): Promise<Metadata> {
}

export default async function Brand({ params: { slug, locale }, searchParams }: Props) {
unstable_setRequestLocale(locale);
setRequestLocale(locale);

const t = await getTranslations('Brand');

Expand Down
Original file line number Diff line number Diff line change
@@ -1,6 +1,6 @@
import type { Metadata } from 'next';
import { notFound } from 'next/navigation';
import { getTranslations, unstable_setRequestLocale } from 'next-intl/server';
import { getTranslations, setRequestLocale } from 'next-intl/server';

import { Breadcrumbs } from '~/components/breadcrumbs';
import { ProductCard } from '~/components/product-card';
Expand Down Expand Up @@ -48,7 +48,7 @@ export async function generateMetadata({ params }: Props): Promise<Metadata> {
}

export default async function Category({ params: { locale, slug }, searchParams }: Props) {
unstable_setRequestLocale(locale);
setRequestLocale(locale);

const t = await getTranslations('Category');

Expand Down
4 changes: 2 additions & 2 deletions core/app/[locale]/(default)/account/(tabs)/layout.tsx
Original file line number Diff line number Diff line change
@@ -1,5 +1,5 @@
import { useTranslations } from 'next-intl';
import { unstable_setRequestLocale } from 'next-intl/server';
import { setRequestLocale } from 'next-intl/server';
import { PropsWithChildren } from 'react';

import { Link } from '~/components/link';
Expand All @@ -15,7 +15,7 @@ interface Props extends PropsWithChildren {
}

export default function AccountTabLayout({ children, params: { locale } }: Props) {
unstable_setRequestLocale(locale);
setRequestLocale(locale);

const t = useTranslations('Account.Home');

Expand Down
Original file line number Diff line number Diff line change
@@ -1,4 +1,4 @@
import { getTranslations, unstable_setRequestLocale } from 'next-intl/server';
import { getTranslations, setRequestLocale } from 'next-intl/server';

import { locales, LocaleType } from '~/i18n/routing';

Expand All @@ -19,7 +19,7 @@ interface Props {
}

export default function ChangePassword({ params: { locale } }: Props) {
unstable_setRequestLocale(locale);
setRequestLocale(locale);

return (
<>
Expand Down
4 changes: 3 additions & 1 deletion core/app/[locale]/(default)/account/layout.tsx
Original file line number Diff line number Diff line change
@@ -1,13 +1,15 @@
import { getLocale } from 'next-intl/server';
import { PropsWithChildren } from 'react';

import { auth } from '~/auth';
import { redirect } from '~/i18n/routing';

export default async function AccountLayout({ children }: PropsWithChildren) {
const locale = await getLocale();
const session = await auth();

if (!session) {
redirect('/login');
redirect({ href: '/login', locale });
}

return children;
Expand Down
Original file line number Diff line number Diff line change
@@ -1,5 +1,6 @@
'use server';

import { getLocale } from 'next-intl/server';
import { z } from 'zod';

import { getSessionCustomerId } from '~/auth';
Expand All @@ -20,6 +21,7 @@ const CheckoutRedirectMutation = graphql(`
`);

export const redirectToCheckout = async (formData: FormData) => {
const locale = await getLocale();
const cartId = z.string().parse(formData.get('cartId'));
const customerId = await getSessionCustomerId();

Expand All @@ -36,5 +38,5 @@ export const redirectToCheckout = async (formData: FormData) => {
throw new Error('Invalid checkout url.');
}

redirect(url);
redirect({ href: url, locale });
};
4 changes: 2 additions & 2 deletions core/app/[locale]/(default)/layout.tsx
Original file line number Diff line number Diff line change
@@ -1,4 +1,4 @@
import { unstable_setRequestLocale } from 'next-intl/server';
import { setRequestLocale } from 'next-intl/server';
import { PropsWithChildren, Suspense } from 'react';

import { Footer } from '~/components/footer/footer';
Expand All @@ -11,7 +11,7 @@ interface Props extends PropsWithChildren {
}

export default function DefaultLayout({ children, params: { locale } }: Props) {
unstable_setRequestLocale(locale);
setRequestLocale(locale);

return (
<>
Expand Down
4 changes: 2 additions & 2 deletions core/app/[locale]/(default)/page.tsx
Original file line number Diff line number Diff line change
@@ -1,5 +1,5 @@
import { removeEdgesAndNodes } from '@bigcommerce/catalyst-client';
import { getTranslations, unstable_setRequestLocale } from 'next-intl/server';
import { getTranslations, setRequestLocale } from 'next-intl/server';

import { getSessionCustomerId } from '~/auth';
import { client } from '~/client';
Expand Down Expand Up @@ -41,7 +41,7 @@ interface Props {
}

export default async function Home({ params: { locale } }: Props) {
unstable_setRequestLocale(locale);
setRequestLocale(locale);

const t = await getTranslations('Home');

Expand Down
4 changes: 2 additions & 2 deletions core/app/[locale]/(default)/product/[slug]/page.tsx
Original file line number Diff line number Diff line change
@@ -1,7 +1,7 @@
import { removeEdgesAndNodes } from '@bigcommerce/catalyst-client';
import { Metadata } from 'next';
import { notFound } from 'next/navigation';
import { getTranslations, unstable_setRequestLocale } from 'next-intl/server';
import { getTranslations, setRequestLocale } from 'next-intl/server';
import { Suspense } from 'react';

import { Breadcrumbs } from '~/components/breadcrumbs';
Expand Down Expand Up @@ -69,7 +69,7 @@ export async function generateMetadata({ params, searchParams }: Props): Promise
}

export default async function Product({ params: { locale, slug }, searchParams }: Props) {
unstable_setRequestLocale(locale);
setRequestLocale(locale);

const t = await getTranslations('Product');

Expand Down
6 changes: 3 additions & 3 deletions core/app/[locale]/layout.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -3,7 +3,7 @@ import { SpeedInsights } from '@vercel/speed-insights/next';
import type { Metadata } from 'next';
import { Inter } from 'next/font/google';
import { NextIntlClientProvider, useMessages } from 'next-intl';
import { unstable_setRequestLocale } from 'next-intl/server';
import { setRequestLocale } from 'next-intl/server';
import { PropsWithChildren } from 'react';

import '../globals.css';
Expand Down Expand Up @@ -82,8 +82,8 @@ interface Props extends PropsWithChildren {

export default function RootLayout({ children, params: { locale } }: Props) {
// need to call this method everywhere where static rendering is enabled
// https://next-intl-docs.vercel.app/docs/getting-started/app-router#add-unstable_setrequestlocale-to-all-layouts-and-pages
unstable_setRequestLocale(locale);
// https://next-intl-docs.vercel.app/docs/getting-started/app-router#add-setRequestLocale-to-all-layouts-and-pages
setRequestLocale(locale);

const messages = useMessages();

Expand Down
4 changes: 2 additions & 2 deletions core/app/[locale]/maintenance/page.tsx
Original file line number Diff line number Diff line change
@@ -1,5 +1,5 @@
import { Phone } from 'lucide-react';
import { getTranslations, unstable_setRequestLocale } from 'next-intl/server';
import { getTranslations, setRequestLocale } from 'next-intl/server';
import { ReactNode } from 'react';

import { client } from '~/client';
Expand Down Expand Up @@ -42,7 +42,7 @@ interface Props {
}

export default async function Maintenance({ params: { locale } }: Props) {
unstable_setRequestLocale(locale);
setRequestLocale(locale);

const t = await getTranslations('Maintenance');

Expand Down
4 changes: 2 additions & 2 deletions core/app/[locale]/store-selector/page.tsx
Original file line number Diff line number Diff line change
@@ -1,4 +1,4 @@
import { getTranslations, unstable_setRequestLocale } from 'next-intl/server';
import { getTranslations, setRequestLocale } from 'next-intl/server';

import { client } from '~/client';
import { graphql } from '~/client/graphql';
Expand Down Expand Up @@ -35,7 +35,7 @@ interface Props {
}

export default async function StoreSelector({ params: { locale: selectedLocale } }: Props) {
unstable_setRequestLocale(selectedLocale);
setRequestLocale(selectedLocale);

const t = await getTranslations('StoreSelector');

Expand Down
11 changes: 6 additions & 5 deletions core/app/admin/route.ts
Original file line number Diff line number Diff line change
@@ -1,4 +1,4 @@
import { redirect } from '~/i18n/routing';
import { defaultLocale, redirect } from '~/i18n/routing';

const canonicalDomain: string = process.env.BIGCOMMERCE_GRAPHQL_API_DOMAIN ?? 'mybigcommerce.com';
const BIGCOMMERCE_STORE_HASH = process.env.BIGCOMMERCE_STORE_HASH;
Expand All @@ -7,14 +7,15 @@ const ENABLE_ADMIN_ROUTE = process.env.ENABLE_ADMIN_ROUTE;
export const GET = () => {
// This route should not work unless explicitly enabled
if (ENABLE_ADMIN_ROUTE !== 'true') {
return redirect('/');
return redirect({ href: '/', locale: defaultLocale });
}

return redirect(
BIGCOMMERCE_STORE_HASH
return redirect({
href: BIGCOMMERCE_STORE_HASH
? `https://store-${BIGCOMMERCE_STORE_HASH}.${canonicalDomain}/admin`
: 'https://login.bigcommerce.com',
);
locale: defaultLocale,
});
};

export const runtime = 'edge';
4 changes: 3 additions & 1 deletion core/app/sitemap.xml/route.ts
Original file line number Diff line number Diff line change
Expand Up @@ -3,10 +3,12 @@
* Proxy to the existing BigCommerce sitemap index on the canonical URL
*/

import { getChannelIdFromLocale } from '~/channels.config';
import { client } from '~/client';
import { defaultLocale } from '~/i18n/routing';

export const GET = async () => {
const sitemapIndex = await client.fetchSitemapIndex();
const sitemapIndex = await client.fetchSitemapIndex(getChannelIdFromLocale(defaultLocale));

return new Response(sitemapIndex, {
headers: {
Expand Down
6 changes: 4 additions & 2 deletions core/app/xmlsitemap.php/route.ts
Original file line number Diff line number Diff line change
@@ -1,5 +1,5 @@
/* eslint-disable check-file/folder-naming-convention */
import { permanentRedirect } from '~/i18n/routing';
import { defaultLocale, permanentRedirect } from '~/i18n/routing';

/*
* This route is used to redirect the legacy Stencil sitemap that lives on /xmlsitemap.php
Expand All @@ -8,6 +8,8 @@ import { permanentRedirect } from '~/i18n/routing';
* on /xmlsitemap.php
*/

export const GET = () => permanentRedirect('/sitemap.xml');
export const GET = () => {
permanentRedirect({ href: '/sitemap.xml', locale: defaultLocale });
};

export const runtime = 'edge';
2 changes: 1 addition & 1 deletion core/client/index.ts
Original file line number Diff line number Diff line change
Expand Up @@ -23,7 +23,7 @@ export const client = createClient({
* - Requests in middlewares
* - Requests in `generateStaticParams`
* - Request in api routes
* - Requests in static sites without `unstable_setRequestLocale`
* - Requests in static sites without `setRequestLocale`
*
* We use the default channelId as a fallback, but it is not ideal in some scenarios.
* */
Expand Down
6 changes: 5 additions & 1 deletion core/components/header/_actions/logout.ts
Original file line number Diff line number Diff line change
@@ -1,10 +1,14 @@
'use server';

import { getLocale } from 'next-intl/server';

import { signOut } from '~/auth';
import { redirect } from '~/i18n/routing';

export const logout = async () => {
const locale = await getLocale();

await signOut({ redirect: false });

redirect('/login');
redirect({ href: '/login', locale });
};
Loading

0 comments on commit 313a591

Please sign in to comment.