mirror of
https://github.com/n8n-io/n8n.git
synced 2026-06-04 10:39:23 +02:00
* Add codex search properties to node types
* implement basic styles
* update header designs
* update node list designs
* add trigger icon
* refactor node creator list
* implement categories and subcategories
* fix up spacing
* add arrows
* implement navigatable list
* implement more of feature
* implement navigation
* add transitions
* fix lint issues
* fix overlay
* ⚡ Get and add codex categories
* fix up design
* update borders
* implement no-matches view
* fix preview bug
* add color to search
* clean up borders
* add comma
* Revert "Merge branch 'add-codex-data' of github.com:n8n-io/n8n into PROD-819-nodes-panel-redesign"
38b7d7ead1
* use new impl
* remove empty categories
* update scrolling, hide start node
* make scrollable
* remove text while subcategory panel is open
* fix up spacing
* fix lint issues
* update descriptions
* update path
* update images
* fix tags manager
* give min height to image
* gst
* update clear color
* update font size
* fix firefox spacing
* close on click outside
* add external link icon
* update iterator key
* add client side caching for images
* update caching header
* ⚡️ Add properties to codex for nodes panel (#1854)
* ⚡ Get and add codex categories
* ⚡ Add parens to evaluation + destructuring
* 🔥 Remove non-existing class reference
* ⚡ Add alias to codex property
* move constants
* 🔨 Rename CodexCategories to CodexData
* ✏️ Update getCodex documentation
* refactor and move
* refactor no results view
* more refactoring
* refactor subcategory panel
* more refactoring
* update text
* update no results view
* add miscellaneous to end of list
* address design feedback
* reimplement node search
* fix up clear
* update placeholder color
* impl transition
* focus on tab
* update spacing
* fix transition bug on start
* fix up x
* fix position
* build
* safari fix
* remove input changes
* css bleed issue with image
* update css value
* clean up
* simplify impl
* rename again
* rename again
* rename all
* fix hover bug
* remove keep alive
* delete icon
* update interface type
* refactor components
* update scss to module
* clean up impl
* clean up colors as vars
* fix indentation
* clean up scss
* clean up scss
* clean up scss
* clean up scss
* Clean up files
* update logic to be more efficient
* fix search bug
* update type
* remove unused
* clean up js
* update scrollable, border impl, transition
* fix simicolon
* build
* update search
* address max's comments
* change icon border radius
* change margin
* update icon size
* update icon size
* update slide transition out
* add comma
* remove full
* update trigger icon size
* fix image size
* address design feedback
* update external link icons
* address codacy issues
* support custom nodes without codex file
* address jan's feedback
* address Ben's comments
* add subcategory index
* open/close categories with arrow keys
* add lint comment
* Address latest comments
* ⚡ Minor changes
Co-authored-by: Iván Ovejero <ivov.src@gmail.com>
Co-authored-by: Mutasem <mutdmour@gmail.com>
Co-authored-by: Mutasem Aldmour <4711238+mutdmour@users.noreply.github.com>
Co-authored-by: Jan Oberhauser <jan.oberhauser@gmail.com>
133 lines
3.6 KiB
TypeScript
133 lines
3.6 KiB
TypeScript
import { ChildProcess, spawn } from 'child_process';
|
|
const copyfiles = require('copyfiles');
|
|
|
|
import {
|
|
readFile as fsReadFile,
|
|
} from 'fs/promises';
|
|
import {
|
|
write as fsWrite,
|
|
} from 'fs';
|
|
|
|
import { join } from 'path';
|
|
import { file } from 'tmp-promise';
|
|
import { promisify } from 'util';
|
|
|
|
const fsReadFileAsync = promisify(fsReadFile);
|
|
const fsWriteAsync = promisify(fsWrite);
|
|
|
|
import { IBuildOptions } from '.';
|
|
|
|
import {
|
|
UserSettings,
|
|
} from 'n8n-core';
|
|
|
|
|
|
/**
|
|
* Create a custom tsconfig file as tsc currently has no way to define a base
|
|
* directory:
|
|
* https://github.com/Microsoft/TypeScript/issues/25430
|
|
*
|
|
* @export
|
|
* @returns
|
|
*/
|
|
export async function createCustomTsconfig () {
|
|
|
|
// Get path to simple tsconfig file which should be used for build
|
|
const tsconfigPath = join(__dirname, '../../src/tsconfig-build.json');
|
|
|
|
// Read the tsconfi file
|
|
const tsConfigString = await fsReadFile(tsconfigPath, { encoding: 'utf8'}) as string;
|
|
const tsConfig = JSON.parse(tsConfigString);
|
|
|
|
// Set absolute include paths
|
|
const newIncludeFiles = [];
|
|
for (const includeFile of tsConfig.include) {
|
|
newIncludeFiles.push(join(process.cwd(), includeFile));
|
|
}
|
|
tsConfig.include = newIncludeFiles;
|
|
|
|
// Write new custom tsconfig file
|
|
const { fd, path, cleanup } = await file({ dir: process.cwd() });
|
|
await fsWriteAsync(fd, Buffer.from(JSON.stringify(tsConfig, null, 2), 'utf8'));
|
|
|
|
return {
|
|
path,
|
|
cleanup,
|
|
};
|
|
}
|
|
|
|
|
|
/**
|
|
* Builds and copies credentials and nodes
|
|
*
|
|
* @export
|
|
* @param {IBuildOptions} [options] Options to overwrite default behaviour
|
|
* @returns {Promise<string>}
|
|
*/
|
|
export async function buildFiles (options?: IBuildOptions): Promise<string> {
|
|
options = options || {};
|
|
|
|
let typescriptPath;
|
|
|
|
// Check for OS to designate correct tsc path
|
|
if (process.platform === 'win32') {
|
|
typescriptPath = '../../node_modules/TypeScript/lib/tsc';
|
|
} else {
|
|
typescriptPath = '../../node_modules/.bin/tsc';
|
|
}
|
|
const tscPath = join(__dirname, typescriptPath);
|
|
|
|
const tsconfigData = await createCustomTsconfig();
|
|
|
|
const outputDirectory = options.destinationFolder || UserSettings.getUserN8nFolderCustomExtensionPath();
|
|
|
|
// Supply a node base path so that it finds n8n-core and n8n-workflow
|
|
const nodeModulesPath = join(__dirname, '../../node_modules/');
|
|
let buildCommand = `${tscPath} --p ${tsconfigData.path} --outDir ${outputDirectory} --rootDir ${process.cwd()} --baseUrl ${nodeModulesPath}`;
|
|
if (options.watch === true) {
|
|
buildCommand += ' --watch';
|
|
}
|
|
|
|
let buildProcess: ChildProcess;
|
|
try {
|
|
buildProcess = spawn('node', buildCommand.split(' '), { windowsVerbatimArguments: true, cwd: process.cwd() });
|
|
|
|
// Forward the output of the child process to the main one
|
|
// that the user can see what is happening
|
|
//@ts-ignore
|
|
buildProcess.stdout.pipe(process.stdout);
|
|
//@ts-ignore
|
|
buildProcess.stderr.pipe(process.stderr);
|
|
|
|
// Make sure that the child process gets also always terminated
|
|
// when the main process does
|
|
process.on('exit', () => {
|
|
buildProcess.kill();
|
|
});
|
|
} catch (error) {
|
|
let errorMessage = error.message;
|
|
|
|
if (error.stdout !== undefined) {
|
|
errorMessage = `${errorMessage}\nGot following output:\n${error.stdout}`;
|
|
}
|
|
|
|
// Remove the tmp tsconfig file
|
|
tsconfigData.cleanup();
|
|
|
|
throw new Error(errorMessage);
|
|
}
|
|
|
|
return new Promise((resolve, reject) => {
|
|
['*.png', '*.node.json'].forEach(filenamePattern => {
|
|
copyfiles(
|
|
[join(process.cwd(), `./${filenamePattern}`), outputDirectory],
|
|
{ up: true },
|
|
() => resolve(outputDirectory));
|
|
});
|
|
buildProcess.on('exit', code => {
|
|
// Remove the tmp tsconfig file
|
|
tsconfigData.cleanup();
|
|
});
|
|
});
|
|
}
|