mirror of
https://github.com/Abdulazizzn/n8n-enterprise-unlocked.git
synced 2025-12-21 11:49:59 +00: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" 38b7d7ead19ab069f3f00a1ae6b6267eee55122a * 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();
|
|
});
|
|
});
|
|
}
|