Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/4lejandrito/next-plausible
Simple integration for https://nextjs.org and https://plausible.io analytics
https://github.com/4lejandrito/next-plausible
nextjs plausible plausible-analytics
Last synced: 5 days ago
JSON representation
Simple integration for https://nextjs.org and https://plausible.io analytics
- Host: GitHub
- URL: https://github.com/4lejandrito/next-plausible
- Owner: 4lejandrito
- License: mit
- Created: 2020-08-27T09:19:07.000Z (over 4 years ago)
- Default Branch: master
- Last Pushed: 2024-11-08T22:40:39.000Z (2 months ago)
- Last Synced: 2025-01-06T05:30:44.134Z (7 days ago)
- Topics: nextjs, plausible, plausible-analytics
- Language: TypeScript
- Homepage: https://next-plausible.vercel.app
- Size: 2.16 MB
- Stars: 615
- Watchers: 8
- Forks: 33
- Open Issues: 22
-
Metadata Files:
- Readme: README.md
- Changelog: CHANGELOG.md
- Funding: .github/FUNDING.yml
- License: LICENSE
Awesome Lists containing this project
README
# Next-Plausible · [![npm version](https://img.shields.io/npm/v/next-plausible.svg?style=flat)](https://www.npmjs.com/package/next-plausible)
Simple integration for https://nextjs.org and https://plausible.io analytics.
See it in action at https://next-plausible.vercel.app, and [this commit](https://github.com/4lejandrito/react-guitar/commit/a634d43cab5c4da5da5aeabaa792a5f42c21a1ed) for a real world example.
**Important:** If you're using a version of next lower than `11.1.0` please use `next-plausible@2` to avoid type checking errors (see https://github.com/4lejandrito/next-plausible/issues/25).
## Usage
### Include the Analytics Script
To enable Plausible analytics in your Next.js app you'll need to expose the Plausible context, ``, at the top level of your application inside [`_app.js`](https://nextjs.org/docs/advanced-features/custom-app):
```jsx
// pages/_app.js
import PlausibleProvider from 'next-plausible'export default function MyApp({ Component, pageProps }) {
return (
)
}
```If you want to enable Plausible analytics only on a single page you can wrap the page in a `PlausibleProvider` component:
```jsx
// pages/home.js
import PlausibleProvider from 'next-plausible'export default Home() {
return (
My Site
{/* ... */}
)
}
```If are using [the app directory](https://beta.nextjs.org/docs/routing/fundamentals#the-app-directory) include `PlausibleProvider` inside the root layout:
```jsx
// app/layout.js
import PlausibleProvider from 'next-plausible'export default function RootLayout({ children }) {
return (
{children}
)
}
```#### `PlausibleProvider` Props
| Name | Description |
| -------------------- | -------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------- |
| `domain` | The domain of the site you want to monitor. |
| `customDomain` | Set this if you use a custom domain to serve the analytics script. Defaults to https://plausible.io. See https://plausible.io/docs/custom-domain for more details. |
| `trackOutboundLinks` | Set this to `true` if you want to enable [outbound link click tracking](https://plausible.io/docs/outbound-link-click-tracking#see-all-the-outbound-link-clicks-in-your-dashboard). |
| `trackFileDownloads` | Set this to `true` if you want to enable [file download tracking](https://plausible.io/docs/file-downloads-tracking). |
| `taggedEvents` | Set this to `true` if you want to enable [custom event tracking in HTML elements](https://plausible.io/docs/custom-event-goals). |
| `trackLocalhost` | Set this to `true` if you want to enable [localhost tracking](https://plausible.io/docs/script-extensions). |
| `manualPageviews` | Set this to `true` if you want to disable [automatic pageview events](https://plausible.io/docs/script-extensions#plausiblemanualjs). |
| `pageviewProps` | Set the [custom properties for pageviews](https://plausible.io/docs/custom-pageview-props). The `event-` prefix will be added automatically. See [an example](test/page/pages/pageViewPropsAsObject.js). |
| `revenue` | Set this to `true` if you want to enable [ecommerce revenue tracking](https://plausible.io/docs/ecommerce-revenue-tracking). |
| `hash` | Set this to `true` if you want to [use hash-based routing](https://plausible.io/docs/hash-based-routing). |
| `exclude` | Set this if you want to exclude a set of pages from being tracked. See https://plausible.io/docs/excluding-pages for more details. |
| `selfHosted` | Set this to `true` if you are self hosting your Plausible instance. Otherwise you will get a 404 when requesting the script. |
| `enabled` | Use this to explicitly decide whether or not to render script. If not passed the script will be rendered in production environments (checking NODE_ENV and VERCEL_ENV). |
| `integrity` | Optionally define the [subresource integrity](https://infosec.mozilla.org/guidelines/web_security#subresource-integrity) attribute for extra security. |
| `scriptProps` | Optionally override any of the props passed to the script element. See [example](test/page/pages/scriptProps.js). |### Proxy the Analytics Script
To avoid being blocked by adblockers plausible [recommends proxying the script](https://plausible.io/docs/proxy/introduction). To do this you need to wrap your `next.config.js` with the `withPlausibleProxy` function:
```js
const { withPlausibleProxy } = require('next-plausible')module.exports = withPlausibleProxy()({
// ...your next js config, if any
// Important! it is mandatory to pass a config object, even if empty
})
```This will set up the necessary rewrites as described [here](https://plausible.io/docs/proxy/guides/nextjs#using-raw-nextjs-config) and configure `PlausibleProvider` to use the local URLs so you can keep using it like this:
```jsx
...
}
```Optionally you can overwrite the proxied script subdirectory and name, as well as the custom domain for the original script:
```js
const { withPlausibleProxy } = require('next-plausible')module.exports = withPlausibleProxy({
subdirectory: 'yoursubdirectory',
scriptName: 'scriptName',
customDomain: 'http://example.com',
})({
// ...your next js config, if any
// Important! it is mandatory to pass a config object, even if empty
})
```This will load the script from `/yoursubdirectory/js/scriptName.js` and fetch it from `http://example.com/js/script.js`.
**Notes:**
- Proxying will only work if you serve your site using `next start`. Statically generated sites won't be able to rewrite the requests.
- If you are self hosting plausible, you need to set `customDomain` to your instance otherwise no data will be sent.
- Bear in mind that tracking requests will be made to the same domain, so cookies will be forwarded. See https://github.com/4lejandrito/next-plausible/issues/67. If this is an issue for you, from `[email protected]` you can use [middleware](https://nextjs.org/docs/advanced-features/middleware#setting-headers) to strip the cookies like this:```js
import { NextResponse } from 'next/server'export function middleware(request) {
const requestHeaders = new Headers(request.headers)
requestHeaders.set('cookie', '')
return NextResponse.next({
request: {
headers: requestHeaders,
},
})
}export const config = {
matcher: '/proxy/api/event',
}
```### Send Custom Events
Plausible supports custom events as described at https://plausible.io/docs/custom-event-goals. This package provides the `usePlausible` hook to safely access the `plausible` function like this:
```jsx
import { usePlausible } from 'next-plausible'export default function PlausibleButton() {
const plausible = usePlausible()return (
<>
plausible('customEventName')}>Send
plausible('customEventName', {
props: {
buttonId: 'foo',
},
})
}
>
Send with props
>
)
}
```If you use Typescript you can type check your custom events like this:
```tsx
import { usePlausible } from 'next-plausible'type MyEvents = {
event1: { prop1: string }
event2: { prop2: string }
event3: never
}const plausible = usePlausible()
```Only those events with the right props will be allowed to be sent using the `plausible` function.
## Developing
- `npm run build` will generate the production scripts under the `dist` folder.