-
-
Notifications
You must be signed in to change notification settings - Fork 9.8k
feat(plugin-vercel-analytics): add new vercel analytics plugin #9687
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Merged
Merged
Changes from all commits
Commits
Show all changes
23 commits
Select commit
Hold shift + click to select a range
aace0bc
wip: vercel analytics
OzakIOne e6d2bf8
wip
OzakIOne 9dfea26
enable plugin without options
OzakIOne 76dd26c
add vercel documentation
OzakIOne 0164c90
remove from preset
OzakIOne 522f73e
wip
OzakIOne fcabc25
remove from preset
OzakIOne 16242ff
feat: plugin options in config
OzakIOne 6dc660e
feat: config validation
OzakIOne 772f1bf
feat: multi instance check
OzakIOne 9461ad7
remove log
OzakIOne 9d761ee
review
OzakIOne 3847883
review
OzakIOne 67576cb
export validate options
OzakIOne 097f2b4
adds doc
OzakIOne b243a96
fix doc
OzakIOne 3c1d5b1
refactor: review
OzakIOne 9730346
feat: tests
OzakIOne db11c27
wip: tests
OzakIOne 065f686
fix docs table issues
slorber b5a2efb
use DEFAULT_PLUGIN_ID constant
slorber f85345b
Improve APITable error message in case of invalid Markdown table
slorber 42bb53b
Change way to reject usage of custom plugin id with Vercel Analytics …
slorber File filter
Filter by extension
Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
There are no files selected for viewing
This file contains hidden or bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
| Original file line number | Diff line number | Diff line change |
|---|---|---|
| @@ -0,0 +1,3 @@ | ||
| .tsbuildinfo* | ||
| tsconfig* | ||
| __tests__ |
This file contains hidden or bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
| Original file line number | Diff line number | Diff line change |
|---|---|---|
| @@ -0,0 +1,7 @@ | ||
| # `@docusaurus/plugin-vercel-analytics` | ||
|
|
||
| [Vercel analytics](https://vercel.com/docs/analytics) plugin for Docusaurus. | ||
|
|
||
| ## Usage | ||
|
|
||
| See [plugin-vercel-analytics documentation](https://docusaurus.io/docs/api/plugins/@docusaurus/plugin-vercel-analytics). |
This file contains hidden or bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
| Original file line number | Diff line number | Diff line change |
|---|---|---|
| @@ -0,0 +1,36 @@ | ||
| { | ||
| "name": "@docusaurus/plugin-vercel-analytics", | ||
| "version": "3.0.0", | ||
| "description": "Global vercel analytics plugin for Docusaurus.", | ||
| "main": "lib/index.js", | ||
| "types": "lib/index.d.ts", | ||
| "publishConfig": { | ||
| "access": "public" | ||
| }, | ||
| "scripts": { | ||
| "build": "tsc --build", | ||
| "watch": "tsc --build --watch" | ||
| }, | ||
| "repository": { | ||
| "type": "git", | ||
| "url": "https://github.com/facebook/docusaurus.git", | ||
| "directory": "packages/docusaurus-plugin-vercel-analytics" | ||
| }, | ||
| "license": "MIT", | ||
| "dependencies": { | ||
| "@docusaurus/core": "3.0.0", | ||
| "@docusaurus/logger": "3.0.0", | ||
| "@docusaurus/types": "3.0.0", | ||
| "@docusaurus/utils-validation": "3.0.0", | ||
| "@docusaurus/utils": "3.0.0", | ||
| "@vercel/analytics": "^1.1.1", | ||
| "tslib": "^2.6.0" | ||
| }, | ||
| "peerDependencies": { | ||
| "react": "^18.0.0", | ||
| "react-dom": "^18.0.0" | ||
| }, | ||
| "engines": { | ||
| "node": ">=18.0" | ||
| } | ||
| } |
135 changes: 135 additions & 0 deletions
135
packages/docusaurus-plugin-vercel-analytics/src/__tests__/options.test.ts
This file contains hidden or bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
| Original file line number | Diff line number | Diff line change |
|---|---|---|
| @@ -0,0 +1,135 @@ | ||
| /** | ||
| * Copyright (c) Facebook, Inc. and its affiliates. | ||
| * | ||
| * This source code is licensed under the MIT license found in the | ||
| * LICENSE file in the root directory of this source tree. | ||
| */ | ||
|
|
||
| import {normalizePluginOptions} from '@docusaurus/utils-validation'; | ||
| import {validateOptions, type PluginOptions, type Options} from '../options'; | ||
| import type {Validate} from '@docusaurus/types'; | ||
|
|
||
| function testValidateOptions(options: Options) { | ||
| return validateOptions({ | ||
| validate: normalizePluginOptions as Validate<Options, PluginOptions>, | ||
| options, | ||
| }); | ||
| } | ||
|
|
||
| function validationResult(options: Options) { | ||
| return { | ||
| id: 'default', | ||
| ...options, | ||
| }; | ||
| } | ||
|
|
||
| describe('validateOptions', () => { | ||
| it('accepts for undefined options', () => { | ||
| // @ts-expect-error: TS should error | ||
| expect(testValidateOptions(undefined)).toEqual(validationResult(undefined)); | ||
| }); | ||
|
|
||
| it('throws for custom id', () => { | ||
| const config: Options = {id: 'custom', mode: 'auto', debug: false}; | ||
| expect(() => testValidateOptions(config)) | ||
| .toThrowErrorMatchingInlineSnapshot(` | ||
| "You site uses the Vercel Analytics plugin with a custom plugin id (custom). | ||
| But this plugin is only supposed to be used at most once per site. Therefore providing a custom plugin id is unsupported." | ||
| `); | ||
| }); | ||
|
|
||
| it('accept for default id', () => { | ||
| const config: Options = {id: 'default', mode: 'auto', debug: false}; | ||
| expect(testValidateOptions(config)).toEqual(validationResult(config)); | ||
| }); | ||
|
|
||
| it('throws for null options', () => { | ||
| // @ts-expect-error: TS should error | ||
| expect(() => testValidateOptions(null)).toThrowErrorMatchingInlineSnapshot( | ||
| `""value" must be of type object"`, | ||
| ); | ||
| }); | ||
|
|
||
| it('accept for empty object options', () => { | ||
| const config: Options = {}; | ||
| expect(testValidateOptions(config)).toEqual(validationResult(config)); | ||
| }); | ||
|
|
||
| it('throws for number options', () => { | ||
| expect( | ||
| // @ts-expect-error: TS should error | ||
| () => testValidateOptions(42), | ||
| ).toThrowErrorMatchingInlineSnapshot(`""value" must be of type object"`); | ||
| }); | ||
|
|
||
| it('throws for null mode', () => { | ||
| expect( | ||
| // @ts-expect-error: TS should error | ||
| () => testValidateOptions({mode: null}), | ||
| ).toThrowErrorMatchingInlineSnapshot( | ||
| `""mode" must be one of [auto, production, development]"`, | ||
| ); | ||
| }); | ||
| it('throws for number mode', () => { | ||
| expect( | ||
| // @ts-expect-error: TS should error | ||
| () => testValidateOptions({mode: 42}), | ||
| ).toThrowErrorMatchingInlineSnapshot( | ||
| `""mode" must be one of [auto, production, development]"`, | ||
| ); | ||
| }); | ||
| it('throws for empty mode', () => { | ||
| expect(() => | ||
| // @ts-expect-error: TS should error | ||
| testValidateOptions({mode: ''}), | ||
| ).toThrowErrorMatchingInlineSnapshot( | ||
| `""mode" must be one of [auto, production, development]"`, | ||
| ); | ||
| }); | ||
|
|
||
| it('accepts debug true', () => { | ||
| const config: Options = { | ||
| debug: true, | ||
| }; | ||
| expect(testValidateOptions(config)).toEqual(validationResult(config)); | ||
| }); | ||
|
|
||
| it('accepts debug false', () => { | ||
| const config: Options = { | ||
| debug: false, | ||
| }; | ||
| expect(testValidateOptions(config)).toEqual(validationResult(config)); | ||
| }); | ||
|
|
||
| it('accepts mode prod', () => { | ||
| const config: Options = { | ||
| mode: 'production', | ||
| debug: false, | ||
| }; | ||
| expect(testValidateOptions(config)).toEqual(validationResult(config)); | ||
| }); | ||
|
|
||
| it('accepts mode dev', () => { | ||
| const config: Options = { | ||
| mode: 'development', | ||
| debug: false, | ||
| }; | ||
| expect(testValidateOptions(config)).toEqual(validationResult(config)); | ||
| }); | ||
|
|
||
| it('accepts mode prod with debug', () => { | ||
| const config: Options = { | ||
| mode: 'production', | ||
| debug: true, | ||
| }; | ||
| expect(testValidateOptions(config)).toEqual(validationResult(config)); | ||
| }); | ||
|
|
||
| it('accepts mode dev with debug', () => { | ||
| const config: Options = { | ||
| mode: 'development', | ||
| debug: true, | ||
| }; | ||
| expect(testValidateOptions(config)).toEqual(validationResult(config)); | ||
| }); | ||
| }); |
17 changes: 17 additions & 0 deletions
17
packages/docusaurus-plugin-vercel-analytics/src/analytics.ts
This file contains hidden or bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
| Original file line number | Diff line number | Diff line change |
|---|---|---|
| @@ -0,0 +1,17 @@ | ||
| /** | ||
| * Copyright (c) Facebook, Inc. and its affiliates. | ||
| * | ||
| * This source code is licensed under the MIT license found in the | ||
| * LICENSE file in the root directory of this source tree. | ||
| */ | ||
| import {inject} from '@vercel/analytics'; | ||
| import globalData from '@generated/globalData'; | ||
| import type {PluginOptions} from './options'; | ||
|
|
||
| const {debug, mode} = globalData['docusaurus-plugin-vercel-analytics'] | ||
| ?.default as PluginOptions; | ||
|
|
||
| inject({ | ||
| mode, | ||
| debug, | ||
| }); | ||
This file contains hidden or bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
| Original file line number | Diff line number | Diff line change |
|---|---|---|
| @@ -0,0 +1,32 @@ | ||
| /** | ||
| * Copyright (c) Facebook, Inc. and its affiliates. | ||
| * | ||
| * This source code is licensed under the MIT license found in the | ||
| * LICENSE file in the root directory of this source tree. | ||
| */ | ||
|
|
||
| import type {LoadContext, Plugin} from '@docusaurus/types'; | ||
| import type {PluginOptions, Options} from './options'; | ||
|
|
||
| export default function pluginVercelAnalytics( | ||
| context: LoadContext, | ||
| options: PluginOptions, | ||
| ): Plugin { | ||
| const isProd = process.env.NODE_ENV === 'production'; | ||
|
|
||
| return { | ||
| name: 'docusaurus-plugin-vercel-analytics', | ||
|
|
||
| getClientModules() { | ||
| return isProd ? ['./analytics'] : []; | ||
| }, | ||
|
|
||
| contentLoaded({actions}) { | ||
| actions.setGlobalData(options); | ||
| }, | ||
| }; | ||
| } | ||
|
|
||
| export {validateOptions} from './options'; | ||
|
|
||
| export type {PluginOptions, Options}; |
42 changes: 42 additions & 0 deletions
42
packages/docusaurus-plugin-vercel-analytics/src/options.ts
This file contains hidden or bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
| Original file line number | Diff line number | Diff line change |
|---|---|---|
| @@ -0,0 +1,42 @@ | ||
| /** | ||
| * Copyright (c) Facebook, Inc. and its affiliates. | ||
| * | ||
| * This source code is licensed under the MIT license found in the | ||
| * LICENSE file in the root directory of this source tree. | ||
| */ | ||
| import {DEFAULT_PLUGIN_ID} from '@docusaurus/utils'; | ||
| import logger from '@docusaurus/logger'; | ||
| import {Joi} from '@docusaurus/utils-validation'; | ||
| import type {OptionValidationContext} from '@docusaurus/types'; | ||
|
|
||
| export type PluginOptions = { | ||
| id: string; | ||
| mode: 'auto' | 'production' | 'development' | undefined; | ||
| debug: boolean | undefined; | ||
| }; | ||
|
|
||
| export type Options = Partial<PluginOptions>; | ||
|
|
||
| const pluginOptionsSchema = Joi.object<PluginOptions>({ | ||
| mode: Joi.string().valid('auto', 'production', 'development').optional(), | ||
| debug: Joi.boolean().optional(), | ||
| }); | ||
|
|
||
| // We can't validate this through the schema | ||
| // Docusaurus core auto registers the id field to the schema already | ||
| function ensureNoMultiInstance(options: Options) { | ||
| if (options?.id && options.id !== DEFAULT_PLUGIN_ID) { | ||
| throw new Error( | ||
| logger.interpolate`You site uses the Vercel Analytics plugin with a custom plugin id (name=${options.id}). | ||
| But this plugin is only supposed to be used at most once per site. Therefore providing a custom plugin id is unsupported.`, | ||
| ); | ||
| } | ||
| } | ||
|
|
||
| export function validateOptions({ | ||
| validate, | ||
| options, | ||
| }: OptionValidationContext<Options, PluginOptions>): PluginOptions { | ||
| ensureNoMultiInstance(options); | ||
| return validate(pluginOptionsSchema, options); | ||
| } |
This file contains hidden or bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
| Original file line number | Diff line number | Diff line change |
|---|---|---|
| @@ -0,0 +1,8 @@ | ||
| /** | ||
| * Copyright (c) Facebook, Inc. and its affiliates. | ||
| * | ||
| * This source code is licensed under the MIT license found in the | ||
| * LICENSE file in the root directory of this source tree. | ||
| */ | ||
|
|
||
| /// <reference types="@docusaurus/module-type-aliases" /> |
16 changes: 16 additions & 0 deletions
16
packages/docusaurus-plugin-vercel-analytics/tsconfig.client.json
This file contains hidden or bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
| Original file line number | Diff line number | Diff line change |
|---|---|---|
| @@ -0,0 +1,16 @@ | ||
| { | ||
| "extends": "../../tsconfig.json", | ||
| "compilerOptions": { | ||
| "noEmit": false, | ||
| "composite": true, | ||
| "incremental": true, | ||
| "tsBuildInfoFile": "./lib/.tsbuildinfo-client", | ||
| "moduleResolution": "bundler", | ||
| "module": "esnext", | ||
| "target": "esnext", | ||
| "rootDir": "src", | ||
| "outDir": "lib" | ||
| }, | ||
| "include": ["src/analytics.ts", "src/options.ts", "src/*.d.ts"], | ||
| "exclude": ["**/__tests__/**"] | ||
| } |
This file contains hidden or bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
| Original file line number | Diff line number | Diff line change |
|---|---|---|
| @@ -0,0 +1,13 @@ | ||
| { | ||
| "extends": "../../tsconfig.json", | ||
| "references": [{"path": "./tsconfig.client.json"}], | ||
| "compilerOptions": { | ||
| "noEmit": false, | ||
| "incremental": true, | ||
| "tsBuildInfoFile": "./lib/.tsbuildinfo", | ||
| "rootDir": "src", | ||
| "outDir": "lib" | ||
| }, | ||
| "include": ["src"], | ||
| "exclude": ["src/analytics.ts", "**/__tests__/**"] | ||
| } |
This file contains hidden or bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
| Original file line number | Diff line number | Diff line change |
|---|---|---|
| @@ -0,0 +1,57 @@ | ||
| --- | ||
| sidebar_position: 11 | ||
| slug: /api/plugins/@docusaurus/plugin-vercel-analytics | ||
| --- | ||
|
|
||
| # 📦 plugin-vercel-analytics | ||
|
|
||
| import APITable from '@site/src/components/APITable'; | ||
|
|
||
| [Vercel Analytics](https://vercel.com/docs/analytics) provides comprehensive insights into your website's visitors, tracking top pages, referrers, and demographics like location, operating systems, and browser info. | ||
|
|
||
| :::warning production only | ||
|
|
||
| This plugin is always inactive in development and **only active in production** (`docusaurus build`) to avoid polluting the analytics statistics. | ||
|
|
||
| ::: | ||
|
|
||
| ## Installation {#installation} | ||
|
|
||
| ```bash npm2yarn | ||
| npm install --save @docusaurus/plugin-vercel-analytics | ||
| ``` | ||
|
|
||
| ## Configuration {#configuration} | ||
|
|
||
| Accepted fields: | ||
|
|
||
| ```mdx-code-block | ||
| <APITable> | ||
| ``` | ||
|
|
||
| | Name | Type | Default | Description | | ||
| | --- | --- | --- | --- | | ||
| | `mode` | `string` | `'auto'` | Override the automatic environment detection. Read the [official docs](https://vercel.com/docs/analytics/package#mode) for details. | | ||
| | `debug` | `boolean` | `undefined` | Enable browser console logging of analytics events. SRead the [official docs](https://vercel.com/docs/analytics/package#debug) for details. | | ||
|
|
||
| ```mdx-code-block | ||
| </APITable> | ||
| ``` | ||
|
|
||
| ### Example configuration {#ex-config} | ||
|
|
||
| You can configure this plugin through plugin options. | ||
|
|
||
| ```js title="docusaurus.config.js" | ||
| export default { | ||
| plugins: [ | ||
| [ | ||
| 'vercel-analytics', | ||
| { | ||
| debug: true, | ||
| mode: 'auto', | ||
| }, | ||
| ], | ||
| ], | ||
| }; | ||
| ``` |
Oops, something went wrong.
Add this suggestion to a batch that can be applied as a single commit.
This suggestion is invalid because no changes were made to the code.
Suggestions cannot be applied while the pull request is closed.
Suggestions cannot be applied while viewing a subset of changes.
Only one suggestion per line can be applied in a batch.
Add this suggestion to a batch that can be applied as a single commit.
Applying suggestions on deleted lines is not supported.
You must change the existing code in this line in order to create a valid suggestion.
Outdated suggestions cannot be applied.
This suggestion has been applied or marked resolved.
Suggestions cannot be applied from pending reviews.
Suggestions cannot be applied on multi-line comments.
Suggestions cannot be applied while the pull request is queued to merge.
Suggestion cannot be applied right now. Please check back later.
Uh oh!
There was an error while loading. Please reload this page.