mirror of
https://github.com/netbox-community/netbox.git
synced 2024-05-10 07:54:54 +00:00
36771e821c
* 10520 remove all Napalm code references * 10520 remove lldp * 10520 remove config, status - rebuild js * 10520 re-add config parameters * 10520 re-add serializer * 10520 update docs
130 lines
3.0 KiB
JavaScript
130 lines
3.0 KiB
JavaScript
const esbuild = require('esbuild');
|
|
const { sassPlugin } = require('esbuild-sass-plugin');
|
|
|
|
// Bundler options common to all bundle jobs.
|
|
const options = {
|
|
outdir: './dist',
|
|
bundle: true,
|
|
minify: true,
|
|
sourcemap: 'external',
|
|
sourcesContent: false,
|
|
logLevel: 'error',
|
|
};
|
|
|
|
// Get CLI arguments for optional overrides.
|
|
const ARGS = process.argv.slice(2);
|
|
|
|
async function bundleGraphIQL() {
|
|
try {
|
|
const result = await esbuild.build({
|
|
...options,
|
|
entryPoints: {
|
|
graphiql: 'netbox-graphiql/index.ts',
|
|
},
|
|
target: 'es2016',
|
|
define: {
|
|
global: 'window',
|
|
},
|
|
});
|
|
if (result.errors.length === 0) {
|
|
console.log(`✅ Bundled source file 'netbox-graphiql/index.ts' to 'graphiql.js'`);
|
|
}
|
|
} catch (err) {
|
|
console.error(err);
|
|
}
|
|
}
|
|
|
|
/**
|
|
* Bundle Core NetBox JavaScript.
|
|
*/
|
|
async function bundleNetBox() {
|
|
const entryPoints = {
|
|
netbox: 'src/index.ts',
|
|
};
|
|
try {
|
|
const result = await esbuild.build({
|
|
...options,
|
|
entryPoints,
|
|
target: 'es2016',
|
|
});
|
|
if (result.errors.length === 0) {
|
|
for (const [targetName, sourceName] of Object.entries(entryPoints)) {
|
|
const source = sourceName.split('/')[1];
|
|
console.log(`✅ Bundled source file '${source}' to '${targetName}.js'`);
|
|
}
|
|
}
|
|
} catch (err) {
|
|
console.error(err);
|
|
}
|
|
}
|
|
|
|
/**
|
|
* Run script bundle jobs.
|
|
*/
|
|
async function bundleScripts() {
|
|
for (const bundle of [bundleNetBox, bundleGraphIQL]) {
|
|
await bundle();
|
|
}
|
|
}
|
|
|
|
/**
|
|
* Run style bundle jobs.
|
|
*/
|
|
async function bundleStyles() {
|
|
try {
|
|
const entryPoints = {
|
|
'netbox-external': 'styles/_external.scss',
|
|
'netbox-light': 'styles/_light.scss',
|
|
'netbox-dark': 'styles/_dark.scss',
|
|
'netbox-print': 'styles/_print.scss',
|
|
rack_elevation: 'styles/_rack_elevation.scss',
|
|
cable_trace: 'styles/_cable_trace.scss',
|
|
graphiql: 'netbox-graphiql/graphiql.scss',
|
|
};
|
|
const pluginOptions = { outputStyle: 'compressed' };
|
|
// Allow cache disabling.
|
|
if (ARGS.includes('--no-cache')) {
|
|
pluginOptions.cache = false;
|
|
}
|
|
let result = await esbuild.build({
|
|
...options,
|
|
// Disable sourcemaps for CSS/SCSS files, see #7068
|
|
sourcemap: false,
|
|
entryPoints,
|
|
plugins: [sassPlugin(pluginOptions)],
|
|
loader: {
|
|
'.eot': 'file',
|
|
'.woff': 'file',
|
|
'.woff2': 'file',
|
|
'.svg': 'file',
|
|
'.ttf': 'file',
|
|
},
|
|
});
|
|
if (result.errors.length === 0) {
|
|
for (const [targetName, sourceName] of Object.entries(entryPoints)) {
|
|
const source = sourceName.split('/')[1];
|
|
console.log(`✅ Bundled source file '${source}' to '${targetName}.css'`);
|
|
}
|
|
}
|
|
} catch (err) {
|
|
console.error(err);
|
|
}
|
|
}
|
|
|
|
/**
|
|
* Run all bundle jobs.
|
|
*/
|
|
async function bundleAll() {
|
|
if (ARGS.includes('--styles')) {
|
|
// Only run style jobs.
|
|
return await bundleStyles();
|
|
} else if (ARGS.includes('--scripts')) {
|
|
// Only run script jobs.
|
|
return await bundleScripts();
|
|
}
|
|
await bundleStyles();
|
|
await bundleScripts();
|
|
}
|
|
|
|
bundleAll();
|