Learn about installing the Frontend SDK.
The Frontend SDK, its integrations, components, and dependencies are ready to use out-of-the-box and should not require further installation.
To confirm the SDK's setup within your project repository, inspect the
sdk
directory located at the one of the following paths:- For B2B projects:
packages/PROJECT_NAME/frontend/src/sdk/
- For B2C projects:
packages/PROJECT_NAME/frontend/sdk/
The presence of this directory indicates that your project includes the SDK. By default, this folder should contain the following files:
index.ts
CommercetoolsSDK.ts
templatecomposable-commerce
folder for B2C projectscomposable-commerce-b2b
folder for B2B projects
Install the SDK
To install the SDK, follow these steps:
-
Install the base SDK npm package in your commercetools Frontend project by running
yarn add @commercetools/frontend-sdk
in the project directory.
We recommend installing the latest version of this package to ensure you get all features and full compatibility with your integrations. -
The Composable Commerce integration, config, and template files are distributed as editable code, and set up within an
sdk
folder. Download the code from one of the following: -
Import and configure the SDK in an index location within your project. The
SDK.configure
method needs to be called only once because the SDK is exported as a singleton. However, the SDK must be configured for both client-side and server-side rendering.The following examples import and configure the SDK in a Next.js 12 project.
For client-side configuration, add the below to yourpackages/PROJECT_NAME/frontend/pages/_app.tsx
file.import { AppProps } from 'next/app'; import { useRouter } from 'next/router'; import { sdk } from '../sdk'; const Starter = ({ Component, pageProps }: AppProps) => { const router = useRouter(); sdk.defaultConfigure(router.locale as string); return <Component {...pageProps} />; }; export default Starter;
For server-side configuration, add the below to yourpackages/PROJECT_NAME/frontend/pages/[[...slug]].tsx
file in thegetServerSideProps
function.import { GetServerSideProps, Redirect } from 'next'; import { sdk } from '../sdk'; ... ... export const getServerSideProps: GetServerSideProps | Redirect = async ({ params, locale, query, req, res }) => { sdk.defaultConfigure(locale as string); ... };
In Next.js 13, the client-side index location ispackages/PROJECT_NAME/frontend/src/app/[locale]/[[...slug]]/page.tsx
and server-side is in any of the API routes or server components.
The SDK and Composable Commerce integration is now set up.