How do I install Crisp Live Chat on Next.js ?
Are you using Next.js / React to create your new web application? Here is how you can add the Crisp chatbox widget on it in less than 2 minutes.
➡️ To know more about Crisp chat widget click here
Create an account on Crisp.
Go to Settings. Then, Workspace Settings, Setup Instructions
Click on Chatbox setup instructions.
Select HTML.
data:image/s3,"s3://crabby-images/dc1a0/dc1a0efe1bba41b8d2da5dba5f7ed04b9c62ffa0" alt=""
Copy the JavaScript code to retrieve your CRISP_WEBSITE_ID.
Install Crisp in your React project:
Inside your components folder, create a file crisp.js and paste this code below. Replace the CRISP_WEBSITE_ID with yours.
Make sure to replace CRISP_WEBSITE_ID with yours. Otherwise, this will not work!
Then, we tell can import Crisp in our component.
and Finally include it in your App:
Starting from Next.js 13, you will need to make some minor adjustments to the code provided above:
In the crisp.js file, we need to change the class component to a functional component, and we also need to add use client at the beginning:
In the layout.js file, remove { ssr: false }:
➡️ To know more about Crisp chat widget click here
Create an account on Crisp.
Go to Settings. Then, Workspace Settings, Setup Instructions
Click on Chatbox setup instructions.
Select HTML.
data:image/s3,"s3://crabby-images/dc1a0/dc1a0efe1bba41b8d2da5dba5f7ed04b9c62ffa0" alt=""
Copy the JavaScript code to retrieve your CRISP_WEBSITE_ID.
Install Crisp in your React project:
npm install crisp-sdk-web
Inside your components folder, create a file crisp.js and paste this code below. Replace the CRISP_WEBSITE_ID with yours.
import React, { Component } from "react";
import { Crisp } from "crisp-sdk-web";
class CrispChat extends Component {
componentDidMount () {
Crisp.configure("MY_CRISP_WEBSITE_ID");
}
render () {
return null;
}
}
export default CrispChat
Make sure to replace CRISP_WEBSITE_ID with yours. Otherwise, this will not work!
Then, we tell can import Crisp in our component.
import dynamic from 'next/dynamic'
const CrispWithNoSSR = dynamic(
() => import('../components/crisp'),
{ ssr: false }
)
and Finally include it in your App:
class App extends React.Component {
render () {
return (
<Router>
<CrispWithNoSSR />
</Router>)
}
}
export default App
Next.js 13
Starting from Next.js 13, you will need to make some minor adjustments to the code provided above:
In the crisp.js file, we need to change the class component to a functional component, and we also need to add use client at the beginning:
"use client"
import { useEffect } from "react";
import { Crisp } from "crisp-sdk-web";
const CrispChat = () => {
useEffect(() => {
Crisp.configure("MY_CRISP_WEBSITE_ID");
});
return null;
}
export default CrispChat;
In the layout.js file, remove { ssr: false }:
import dynamic from 'next/dynamic'
export default function RootLayout({ children }) {
const CrispWithNoSSR = dynamic(
() => import('../components/crisp')
)
return (
<html lang="en">
<CrispWithNoSSR />
<body>
{children}
</body>
</html>
)
}
Updated on: 02/11/2024
Thank you!