mirror of
https://github.com/Abdulazizzn/n8n-enterprise-unlocked.git
synced 2025-12-16 09:36:44 +00:00
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:
@@ -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",
|
||||
|
||||
@@ -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;
|
||||
}
|
||||
|
||||
@@ -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;
|
||||
};
|
||||
|
||||
@@ -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;
|
||||
}
|
||||
|
||||
@@ -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;
|
||||
};
|
||||
|
||||
@@ -1,4 +1,3 @@
|
||||
{
|
||||
"files": ["./src/index.ts"],
|
||||
"references": [{ "path": "./tsconfig.backend.json" }, { "path": "./tsconfig.frontend.json" }]
|
||||
}
|
||||
|
||||
@@ -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
24
packages/extensions/insights/.gitignore
vendored
Normal 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?
|
||||
1
packages/extensions/insights/LICENSE
Normal file
1
packages/extensions/insights/LICENSE
Normal file
@@ -0,0 +1 @@
|
||||
See LICENSE.md in the root of this repository for more information.
|
||||
1
packages/extensions/insights/README.md
Normal file
1
packages/extensions/insights/README.md
Normal file
@@ -0,0 +1 @@
|
||||
# @n8n/n8n-extension-insights
|
||||
23
packages/extensions/insights/n8n.manifest.json
Normal file
23
packages/extensions/insights/n8n.manifest.json
Normal 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"
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
56
packages/extensions/insights/package.json
Normal file
56
packages/extensions/insights/package.json
Normal 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"
|
||||
}
|
||||
}
|
||||
7
packages/extensions/insights/src/backend/index.ts
Normal file
7
packages/extensions/insights/src/backend/index.ts
Normal file
@@ -0,0 +1,7 @@
|
||||
import { defineBackendExtension } from '@n8n/extension-sdk/backend';
|
||||
|
||||
export default defineBackendExtension({
|
||||
setup(n8n) {
|
||||
console.log(n8n);
|
||||
},
|
||||
});
|
||||
@@ -0,0 +1,6 @@
|
||||
<script lang="ts" setup></script>
|
||||
<template>
|
||||
<div>
|
||||
<h1>INSIGHTS DASHBOARD</h1>
|
||||
</div>
|
||||
</template>
|
||||
9
packages/extensions/insights/src/frontend/index.ts
Normal file
9
packages/extensions/insights/src/frontend/index.ts
Normal 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));
|
||||
},
|
||||
});
|
||||
1
packages/extensions/insights/src/shims.d.ts
vendored
Normal file
1
packages/extensions/insights/src/shims.d.ts
vendored
Normal file
@@ -0,0 +1 @@
|
||||
/// <reference types="vite/client" />
|
||||
9
packages/extensions/insights/tsconfig.backend.json
Normal file
9
packages/extensions/insights/tsconfig.backend.json
Normal 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"]
|
||||
}
|
||||
7
packages/extensions/insights/tsconfig.frontend.json
Normal file
7
packages/extensions/insights/tsconfig.frontend.json
Normal 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"]
|
||||
}
|
||||
8
packages/extensions/insights/tsconfig.json
Normal file
8
packages/extensions/insights/tsconfig.json
Normal file
@@ -0,0 +1,8 @@
|
||||
{
|
||||
"files": [],
|
||||
"references": [
|
||||
{ "path": "./tsconfig.backend.json" },
|
||||
{ "path": "./tsconfig.frontend.json" },
|
||||
{ "path": "./tsconfig.vite.json" }
|
||||
]
|
||||
}
|
||||
20
packages/extensions/insights/tsconfig.vite.json
Normal file
20
packages/extensions/insights/tsconfig.vite.json
Normal 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"]
|
||||
}
|
||||
15
packages/extensions/insights/tsup.config.ts
Normal file
15
packages/extensions/insights/tsup.config.ts
Normal 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',
|
||||
});
|
||||
42
packages/extensions/insights/vite.config.ts
Normal file
42
packages/extensions/insights/vite.config.ts
Normal 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
33
pnpm-lock.yaml
generated
@@ -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
|
||||
|
||||
@@ -2,6 +2,7 @@ packages:
|
||||
- packages/*
|
||||
- packages/@n8n/*
|
||||
- packages/frontend/**
|
||||
- packages/extensions/**
|
||||
- cypress
|
||||
|
||||
catalog:
|
||||
|
||||
Reference in New Issue
Block a user