feat: Add example @n8n/n8n-extension-insights extension package (#14360)

Co-authored-by: Iván Ovejero <ivov.src@gmail.com>
This commit is contained in:
Alex Grozav
2025-04-03 13:10:00 +03:00
committed by GitHub
parent 3d64d140e9
commit b91be496c3
24 changed files with 300 additions and 22 deletions

View File

@@ -7,7 +7,15 @@
"LICENSE",
"README.md"
],
"main": "./dist/index.cjs",
"module": "./dist/index.js",
"types": "./dist/index.d.ts",
"exports": {
".": {
"types": "./dist/index.d.ts",
"import": "./dist/index.js",
"require": "./dist/index.cjs"
},
"./backend": {
"types": "./dist/backend/index.d.ts",
"import": "./dist/backend/index.js",

View File

@@ -1,5 +1,5 @@
import type { BackendModule } from './types.ts';
import type { BackendExtension } from './types.ts';
export function defineBackendModule(module: BackendModule): BackendModule {
return module;
export function defineBackendExtension(extension: BackendExtension): BackendExtension {
return extension;
}

View File

@@ -1,7 +1,9 @@
export type BackendModuleContext = {};
export type BackendModuleSetupFn = (context: BackendModule) => void;
export type BackendModule = {
setup: BackendModuleSetupFn;
export type BackendExtensionContext = {
example?: string;
};
export type BackendExtensionSetupFn = (context: BackendExtension) => void;
export type BackendExtension = {
setup: BackendExtensionSetupFn;
};

View File

@@ -1,5 +1,5 @@
import type { FrontendModule } from './types.ts';
import type { FrontendExtension } from './types.ts';
export function defineFrontendModule(module: FrontendModule): FrontendModule {
return module;
export function defineFrontendExtension(extension: FrontendExtension): FrontendExtension {
return extension;
}

View File

@@ -1,13 +1,14 @@
import type { RouteRecordRaw } from 'vue-router';
import type { App } from 'vue';
import type { App, Component } from 'vue';
export type FrontendModuleContext = {
export type FrontendExtensionContext = {
app: App;
defineRoutes: (routes: RouteRecordRaw[]) => void;
registerComponent: (name: string, component: Component) => void;
};
export type FrontendModuleSetupFn = (context: FrontendModuleContext) => void;
export type FrontendExtensionSetupFn = (context: FrontendExtensionContext) => void;
export type FrontendModule = {
setup: FrontendModuleSetupFn;
export type FrontendExtension = {
setup: FrontendExtensionSetupFn;
};

View File

@@ -1,4 +1,3 @@
{
"files": ["./src/index.ts"],
"references": [{ "path": "./tsconfig.backend.json" }, { "path": "./tsconfig.frontend.json" }]
}

View File

@@ -2,7 +2,16 @@ import { defineConfig } from 'tsup';
export default defineConfig([
{
clean: true,
clean: false,
entry: ['src/index.ts'],
outDir: 'dist',
format: ['cjs', 'esm'],
dts: true,
sourcemap: true,
tsconfig: 'tsconfig.json',
},
{
clean: false,
entry: [
'src/backend/**/*.ts',
'!src/backend/**/*.test.ts',
@@ -16,7 +25,7 @@ export default defineConfig([
tsconfig: 'tsconfig.backend.json',
},
{
clean: true,
clean: false,
entry: [
'src/frontend/**/*.ts',
'!src/frontend/**/*.test.ts',

24
packages/extensions/insights/.gitignore vendored Normal file
View File

@@ -0,0 +1,24 @@
# Logs
logs
*.log
npm-debug.log*
yarn-debug.log*
yarn-error.log*
pnpm-debug.log*
lerna-debug.log*
node_modules
dist
dist-ssr
*.local
# Editor directories and files
.vscode/*
!.vscode/extensions.json
.idea
.DS_Store
*.suo
*.ntvs*
*.njsproj
*.sln
*.sw?

View File

@@ -0,0 +1 @@
See LICENSE.md in the root of this repository for more information.

View File

@@ -0,0 +1 @@
# @n8n/n8n-extension-insights

View File

@@ -0,0 +1,23 @@
{
"name": "@n8n/n8n-extension-insights",
"version": "1.0.0",
"author": "n8n",
"category": "Internal",
"minSDKVersion": "0.0.0",
"permissions": {
"frontend": [],
"backend": []
},
"events": ["workflow:started"],
"setup": {
"backend": "./dist/backend/index.js",
"frontend": "./dist/frontend/index.js"
},
"extends": {
"views": {
"workflows": {
"header": "InsightsDashboard"
}
}
}
}

View File

@@ -0,0 +1,56 @@
{
"name": "@n8n/n8n-extension-insights",
"version": "0.0.0",
"type": "module",
"files": [
"dist",
"n8n.manifest.json",
"LICENSE",
"README.md"
],
"main": "./n8n.manifest.json",
"module": "./n8n.manifest.json",
"exports": {
".": {
"import": "./n8n.manifest.json",
"require": "./n8n.manifest.json"
},
"./backend": {
"types": "./dist/backend/index.d.ts",
"import": "./dist/backend/index.js",
"require": "./dist/backend/index.cjs"
},
"./frontend": {
"types": "./dist/frontend/index.d.ts",
"import": "./dist/frontend/index.js",
"require": "./dist/frontend/index.umd.cjs"
},
"./*": "./*"
},
"scripts": {
"cleanup": "rimraf dist",
"dev": "vite",
"typecheck": "vue-tsc --noEmit",
"build:backend": "tsup",
"build:frontend": "vite build",
"build": "pnpm cleanup && pnpm run \"/^build:.*/\"",
"preview": "vite preview"
},
"peerDependencies": {
"vue": "catalog:frontend",
"vue-router": "catalog:frontend"
},
"dependencies": {
"@n8n/extension-sdk": "workspace:*"
},
"devDependencies": {
"@n8n/typescript-config": "workspace:*",
"@vitejs/plugin-vue": "catalog:frontend",
"@vue/tsconfig": "catalog:frontend",
"rimraf": "catalog:",
"vite": "catalog:frontend",
"vue": "catalog:frontend",
"vue-router": "catalog:frontend",
"vue-tsc": "catalog:frontend"
}
}

View File

@@ -0,0 +1,7 @@
import { defineBackendExtension } from '@n8n/extension-sdk/backend';
export default defineBackendExtension({
setup(n8n) {
console.log(n8n);
},
});

View File

@@ -0,0 +1,6 @@
<script lang="ts" setup></script>
<template>
<div>
<h1>INSIGHTS DASHBOARD</h1>
</div>
</template>

View File

@@ -0,0 +1,9 @@
import { markRaw } from 'vue';
import { defineFrontendExtension } from '@n8n/extension-sdk/frontend';
import InsightsDashboard from './InsightsDashboard.vue';
export default defineFrontendExtension({
setup(n8n) {
n8n.registerComponent('InsightsDashboard', markRaw(InsightsDashboard));
},
});

View File

@@ -0,0 +1 @@
/// <reference types="vite/client" />

View File

@@ -0,0 +1,9 @@
{
"extends": "@n8n/typescript-config/tsconfig.common.json",
"compilerOptions": {
"tsBuildInfoFile": "./node_modules/.tmp/tsconfig.app.tsbuildinfo",
"moduleResolution": "bundler",
"module": "esnext"
},
"include": ["src/backend/**/*.ts", "src/index.ts"]
}

View File

@@ -0,0 +1,7 @@
{
"extends": "@vue/tsconfig/tsconfig.dom.json",
"compilerOptions": {
"tsBuildInfoFile": "./node_modules/.tmp/tsconfig.app.tsbuildinfo"
},
"include": ["src/frontend/**/*.ts", "src/frontend/**/*.vue"]
}

View File

@@ -0,0 +1,8 @@
{
"files": [],
"references": [
{ "path": "./tsconfig.backend.json" },
{ "path": "./tsconfig.frontend.json" },
{ "path": "./tsconfig.vite.json" }
]
}

View File

@@ -0,0 +1,20 @@
{
"compilerOptions": {
"composite": true,
"tsBuildInfoFile": "./node_modules/.tmp/tsconfig.node.tsbuildinfo",
"target": "ES2022",
"lib": ["ES2023"],
"module": "ESNext",
"skipLibCheck": true,
"moduleResolution": "bundler",
"allowImportingTsExtensions": true,
"isolatedModules": true,
"moduleDetection": "force",
"strict": true,
"noUnusedLocals": true,
"noUnusedParameters": true,
"noFallthroughCasesInSwitch": true,
"noUncheckedSideEffectImports": true
},
"include": ["vite.config.ts"]
}

View File

@@ -0,0 +1,15 @@
import { defineConfig } from 'tsup';
export default defineConfig({
entry: [
'src/backend/**/*.ts',
'!src/backend/**/*.test.ts',
'!src/backend/**/*.d.ts',
'!src/backend/__tests__**/*',
],
outDir: 'dist/backend',
format: ['cjs', 'esm'],
dts: true,
sourcemap: true,
tsconfig: 'tsconfig.backend.json',
});

View File

@@ -0,0 +1,42 @@
import { resolve } from 'path';
import { defineConfig } from 'vite';
import vue from '@vitejs/plugin-vue';
import dts from 'vite-plugin-dts';
import { configDefaults as vitestConfig } from 'vitest/config';
const cwd = process.cwd();
export default defineConfig({
plugins: [
vue(),
dts({
rollupTypes: true,
tsconfigPath: resolve(cwd, 'tsconfig.frontend.json'),
}),
],
build: {
emptyOutDir: false,
outDir: resolve(cwd, 'dist', 'frontend'),
lib: {
entry: resolve(cwd, 'src', 'frontend', 'index.ts'),
name: 'n8nFrontEndSdk',
fileName: 'index',
},
rollupOptions: {
external: ['vue'],
output: {
preserveModules: false,
globals: {
vue: 'Vue',
},
},
},
},
test: {
globals: true,
environment: 'jsdom',
setupFiles: ['src/__tests__/setup.ts'],
include: ['src/**/*.spec.ts'],
exclude: vitestConfig.exclude,
},
});

33
pnpm-lock.yaml generated
View File

@@ -1348,6 +1348,37 @@ importers:
specifier: 'catalog:'
version: 0.4.14
packages/extensions/insights:
dependencies:
'@n8n/extension-sdk':
specifier: workspace:*
version: link:../../@n8n/extension-sdk
devDependencies:
'@n8n/typescript-config':
specifier: workspace:*
version: link:../../@n8n/typescript-config
'@vitejs/plugin-vue':
specifier: catalog:frontend
version: 5.2.1(vite@6.2.1(@types/node@18.16.16)(jiti@1.21.0)(sass@1.64.1)(terser@5.16.1))(vue@3.5.13(typescript@5.8.2))
'@vue/tsconfig':
specifier: catalog:frontend
version: 0.7.0(typescript@5.8.2)(vue@3.5.13(typescript@5.8.2))
rimraf:
specifier: 'catalog:'
version: 6.0.1
vite:
specifier: catalog:frontend
version: 6.2.1(@types/node@18.16.16)(jiti@1.21.0)(sass@1.64.1)(terser@5.16.1)
vue:
specifier: catalog:frontend
version: 3.5.13(typescript@5.8.2)
vue-router:
specifier: catalog:frontend
version: 4.5.0(vue@3.5.13(typescript@5.8.2))
vue-tsc:
specifier: ^2.2.8
version: 2.2.8(patch_hash=e2aee939ccac8a57fe449bfd92bedd8117841579526217bc39aca26c6b8c317f)(typescript@5.8.2)
packages/frontend/@n8n/chat:
dependencies:
'@vueuse/core':
@@ -26033,8 +26064,6 @@ snapshots:
onetime: 5.1.2
signal-exit: 3.0.7
ret@0.1.15: {}
retry-axios@2.6.0(axios@1.8.2):
dependencies:
axios: 1.8.2

View File

@@ -2,6 +2,7 @@ packages:
- packages/*
- packages/@n8n/*
- packages/frontend/**
- packages/extensions/**
- cypress
catalog: