diff --git a/README.md b/README.md index 5d36469..b2c3aff 100644 --- a/README.md +++ b/README.md @@ -11,6 +11,7 @@ - 😋 Effortless installation - 🦅 Track errors seamlessly across your Nuxt app - 💼 Composable for manually sending errors and logs +- 💌 Sends release info with source maps ## Quick Setup @@ -29,7 +30,7 @@ export default defineNuxtConfig({ '@hawk.so/nuxt' ], hawk: { - tokenClient: process.env.HAWK_TOKEN_CLIENT, + token: process.env.HAWK_TOKEN, }, }) ``` diff --git a/package-lock.json b/package-lock.json index fc8789b..2e2a2de 100644 --- a/package-lock.json +++ b/package-lock.json @@ -1,15 +1,16 @@ { "name": "@hawk.so/nuxt", - "version": "1.0.0", + "version": "0.0.2", "lockfileVersion": 3, "requires": true, "packages": { "": { "name": "@hawk.so/nuxt", - "version": "1.0.0", + "version": "0.0.2", "license": "MIT", "dependencies": { "@hawk.so/javascript": "^3.0.2", + "@hawk.so/vite-plugin": "^1.0.3", "@nuxt/kit": "^3.13.2" }, "devDependencies": { @@ -1220,6 +1221,14 @@ "@types/mongodb": "^3.5.34" } }, + "node_modules/@hawk.so/vite-plugin": { + "version": "1.0.3", + "resolved": "https://registry.npmjs.org/@hawk.so/vite-plugin/-/vite-plugin-1.0.3.tgz", + "integrity": "sha512-yBn2pwWwj2ytZoibp3dhPefGDNv3IqUIlZ1/K0VJxGAvDQ13Fg0lBM6+xR9pPOGOFsxg7pYzxwep90iaI8tojw==", + "dependencies": { + "magic-string": "^0.30.5" + } + }, "node_modules/@humanwhocodes/module-importer": { "version": "1.0.1", "resolved": "https://registry.npmjs.org/@humanwhocodes/module-importer/-/module-importer-1.0.1.tgz", diff --git a/package.json b/package.json index a07e988..67551e1 100644 --- a/package.json +++ b/package.json @@ -1,6 +1,6 @@ { "name": "@hawk.so/nuxt", - "version": "0.0.2", + "version": "0.0.3", "description": "Hawk error tracker integration to Nuxt app", "repository": "https://github.com/codex-team/hawk.nuxt", "license": "MIT", @@ -30,6 +30,7 @@ }, "dependencies": { "@hawk.so/javascript": "^3.0.2", + "@hawk.so/vite-plugin": "^1.0.3", "@nuxt/kit": "^3.13.2" }, "devDependencies": { diff --git a/playground/.env.example b/playground/.env.example index d2ca030..2709ebf 100644 --- a/playground/.env.example +++ b/playground/.env.example @@ -1,2 +1,2 @@ -# Hawk error tracker Integration Token for client-side errors -HAWK_TOKEN_CLIENT= +# Hawk error tracker Integration Token +HAWK_TOKEN= diff --git a/playground/nuxt.config.ts b/playground/nuxt.config.ts index 7d6917d..82e32da 100644 --- a/playground/nuxt.config.ts +++ b/playground/nuxt.config.ts @@ -1,7 +1,7 @@ export default defineNuxtConfig({ modules: ['../src/module'], hawk: { - tokenClient: process.env.HAWK_TOKEN_CLIENT, + token: process.env.HAWK_TOKEN, }, devtools: { enabled: true }, }) diff --git a/src/module.ts b/src/module.ts index 1faa321..860ebc3 100644 --- a/src/module.ts +++ b/src/module.ts @@ -1,4 +1,5 @@ import { defineNuxtModule, addPlugin, createResolver, updateRuntimeConfig, useRuntimeConfig, addImportsDir } from '@nuxt/kit' +import hawkVitePlugin from '@hawk.so/vite-plugin' import type { HawkModuleConfig } from './types' export default defineNuxtModule({ @@ -6,9 +7,8 @@ export default defineNuxtModule({ name: '@hawk.so/nuxt', configKey: 'hawk', }, - // Default configuration options of the Nuxt module defaults: {}, - setup(config, _nuxt) { + setup(config, nuxt) { const resolver = createResolver(import.meta.url) const runtimeConfig = useRuntimeConfig() @@ -32,5 +32,18 @@ export default defineNuxtModule({ }) addImportsDir(resolver.resolve('./runtime/composables')) + + /** + * Add @hawk.so/vite-plugin for source maps sending + */ + nuxt.hook('vite:extendConfig', (viteConfig) => { + viteConfig.plugins = viteConfig.plugins || [] + + viteConfig.plugins.push( + hawkVitePlugin({ + token: config.token, + }), + ) + }) }, }) diff --git a/src/runtime/plugin.client.ts b/src/runtime/plugin.client.ts index 69f066e..f8b7377 100644 --- a/src/runtime/plugin.client.ts +++ b/src/runtime/plugin.client.ts @@ -2,13 +2,38 @@ import HawkCatcher from '@hawk.so/javascript' import type { HawkModuleConfig } from '../types' import { defineNuxtPlugin, useRuntimeConfig } from '#app' +/** + * Returns the global object depending on the environment + */ +function getGlobal(): typeof globalThis { + return typeof window !== 'undefined' + ? window + : typeof global !== 'undefined' + ? global + : typeof self !== 'undefined' + ? self + : {} as typeof globalThis +} + +/** + * Returns the release ID from the global context + * This variable is injected by the @hawk.so/vite-plugin + */ +function getReleaseId(): string | undefined { + // eslint-disable-next-line @typescript-eslint/no-explicit-any + const global = getGlobal() as any + + return global.HAWK_RELEASE +} + export default defineNuxtPlugin((nuxtApp) => { const runtimeConfig = useRuntimeConfig() const hawkConfig = runtimeConfig.public.hawk as HawkModuleConfig const hawkInstance = new HawkCatcher({ - token: hawkConfig.tokenClient, + token: hawkConfig.token, vue: nuxtApp.vueApp, + release: getReleaseId(), }) /** diff --git a/src/types.ts b/src/types.ts index eb6cea5..8fdb121 100644 --- a/src/types.ts +++ b/src/types.ts @@ -3,7 +3,7 @@ */ export interface HawkModuleConfig { /** - * Hawk Integration token for client-side errors + * Hawk Integration token */ - tokenClient: string + token: string }