Getting Started with Next.js
Kitchn only support Next.js Pages Router for now, we are working on supporting Next.js App Router (opens in a new tab).
Automatic Installation
Template
To generate the starter template for your Next.js project, run the following command:
npx create-next-app@latest --example https://github.com/tonightpass/kitchn/tree/master/examples/next-typescript my-next-kitchn-app
cd my-next-kitchn-app
npm run dev
What's Included
This template is similar to the default Next.js template, but with Kitchn pre-installed.
Pre-install dependencies
kitchn
next
react
react-dom
Manual Installation
Installation
In your Next.js project, install Kitchn by running either of the following:
npm i kitchn --save
Provider Setup
After installing Kitchn, you need to set up the KitchnProvider
at the root
of your application.
Go to pages/_app.js
or pages/_app.tsx
(create it if it doesn't exist) and
wrap the Component
with the KitchnProvider
:
// pages/_app.js
import { KitchnProvider } from "kitchn";
function App({ Component, pageProps }) {
return (
<KitchnProvider>
<Component {...pageProps} />
</KitchnProvider>
);
}
export default App;
Server Side Rendering
Now that everything is working you should be interested in Server Side Rendering.
Go to the next.config.js
file and add the following:
// next.config.js
const { withKitchnConfig } = require("kitchn/next");
const config = {
// your next config
};
module.exports = withKitchnConfig(config);
Then, go to the pages/_document.js
or create it if it doesn't exist and add the following:
// pages/_document.js
import { KitchnDocument } from "kitchn/next";
export default class Document extends KitchnDocument {
// your document
}
Deploy your own
Deploy the example using Vercel (opens in a new tab) or preview live with StackBlitz (opens in a new tab) or CodeSandbox (opens in a new tab).
In addition, here is a complete project example (opens in a new tab) using Kitchn with Next.js.