You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
ORPA-pyOpenRPA/Resources/WPy64-3720/python-3.7.2.amd64/Lib/site-packages/jupyterlab/staging/webpack.config.js

313 lines
9.2 KiB

// This file is auto-generated from the corresponding file in /dev_mode
/* -----------------------------------------------------------------------------
| Copyright (c) Jupyter Development Team.
| Distributed under the terms of the Modified BSD License.
|----------------------------------------------------------------------------*/
const plib = require('path');
const fs = require('fs-extra');
const Handlebars = require('handlebars');
const HtmlWebpackPlugin = require('html-webpack-plugin');
const webpack = require('webpack');
const BundleAnalyzerPlugin = require('webpack-bundle-analyzer')
.BundleAnalyzerPlugin;
const Build = require('@jupyterlab/buildutils').Build;
const WPPlugin = require('@jupyterlab/buildutils').WPPlugin;
const package_data = require('./package.json');
// Handle the extensions.
const jlab = package_data.jupyterlab;
const extensions = jlab.extensions;
const mimeExtensions = jlab.mimeExtensions;
const { externalExtensions } = jlab;
const packageNames = Object.keys(mimeExtensions).concat(
Object.keys(extensions),
Object.keys(externalExtensions)
);
// go throught each external extension
// add to mapping of extension and mime extensions, of package name
// to path of the extension.
for (const key in externalExtensions) {
const {
jupyterlab: { extension, mimeExtension }
} = require(`${key}/package.json`);
if (extension !== undefined) {
extensions[key] = extension === true ? '' : extension;
}
if (mimeExtension !== undefined) {
mimeExtensions[key] = mimeExtension === true ? '' : mimeExtension;
}
}
// Ensure a clear build directory.
const buildDir = plib.resolve(jlab.buildDir);
if (fs.existsSync(buildDir)) {
fs.removeSync(buildDir);
}
fs.ensureDirSync(buildDir);
// Build the assets
const extraConfig = Build.ensureAssets({
packageNames: packageNames,
output: jlab.outputDir
});
// Create the entry point file.
const source = fs.readFileSync('index.js').toString();
const template = Handlebars.compile(source);
const data = {
jupyterlab_extensions: extensions,
jupyterlab_mime_extensions: mimeExtensions
};
const result = template(data);
fs.writeFileSync(plib.join(buildDir, 'index.out.js'), result);
fs.copySync('./package.json', plib.join(buildDir, 'package.json'));
fs.copySync(
plib.join(jlab.outputDir, 'imports.css'),
plib.join(buildDir, 'imports.css')
);
// Set up variables for the watch mode ignore plugins
const watched = {};
const ignoreCache = Object.create(null);
Object.keys(jlab.linkedPackages).forEach(function(name) {
if (name in watched) {
return;
}
const localPkgPath = require.resolve(plib.join(name, 'package.json'));
watched[name] = plib.dirname(localPkgPath);
});
// Set up source-map-loader to look in watched lib dirs
const sourceMapRes = Object.values(watched).reduce((res, name) => {
res.push(new RegExp(name + '/lib'));
return res;
}, []);
/**
* Sync a local path to a linked package path if they are files and differ.
* This is used by `jupyter lab --watch` to synchronize linked packages
* and has no effect in `jupyter lab --dev-mode --watch`.
*/
function maybeSync(localPath, name, rest) {
const stats = fs.statSync(localPath);
if (!stats.isFile(localPath)) {
return;
}
const source = fs.realpathSync(plib.join(jlab.linkedPackages[name], rest));
if (source === fs.realpathSync(localPath)) {
return;
}
fs.watchFile(source, { interval: 500 }, function(curr) {
if (!curr || curr.nlink === 0) {
return;
}
try {
fs.copySync(source, localPath);
} catch (err) {
console.error(err);
}
});
}
/**
* A filter function set up to exclude all files that are not
* in a package contained by the Jupyterlab repo. Used to ignore
* files during a `--watch` build.
*/
function ignored(path) {
path = plib.resolve(path);
if (path in ignoreCache) {
// Bail if already found.
return ignoreCache[path];
}
// Limit the watched files to those in our local linked package dirs.
let ignore = true;
Object.keys(watched).some(name => {
const rootPath = watched[name];
const contained = path.indexOf(rootPath + plib.sep) !== -1;
if (path !== rootPath && !contained) {
return false;
}
const rest = path.slice(rootPath.length);
if (rest.indexOf('node_modules') === -1) {
ignore = false;
maybeSync(path, name, rest);
}
return true;
});
ignoreCache[path] = ignore;
return ignore;
}
const plugins = [
new WPPlugin.NowatchDuplicatePackageCheckerPlugin({
verbose: true,
exclude(instance) {
// ignore known duplicates
return ['domelementtype', 'hash-base', 'inherits'].includes(
instance.name
);
}
}),
new HtmlWebpackPlugin({
chunksSortMode: 'none',
template: plib.join('templates', 'template.html'),
title: jlab.name || 'JupyterLab'
}),
new webpack.HashedModuleIdsPlugin(),
// custom plugin for ignoring files during a `--watch` build
new WPPlugin.FilterWatchIgnorePlugin(ignored),
// custom plugin that copies the assets to the static directory
new WPPlugin.FrontEndPlugin(buildDir, jlab.staticDir)
];
if (process.argv.includes('--analyze')) {
plugins.push(new BundleAnalyzerPlugin());
}
module.exports = [
{
mode: 'development',
entry: {
main: ['whatwg-fetch', plib.resolve(buildDir, 'index.out.js')]
},
// Map Phosphor files to Lumino files.
resolve: {
alias: {
'@phosphor/algorithm$': plib.resolve(
__dirname,
'node_modules/@lumino/algorithm/dist/index.js'
),
'@phosphor/application$': plib.resolve(
__dirname,
'node_modules/@lumino/application/dist/index.js'
),
'@phosphor/commands$': plib.resolve(
__dirname,
'node_modules/@lumino/commands/dist/index.js'
),
'@phosphor/coreutils$': plib.resolve(
__dirname,
'node_modules/@lumino/coreutils/dist/index.js'
),
'@phosphor/disposable$': plib.resolve(
__dirname,
'node_modules/@lumino/disposable/dist/index.js'
),
'@phosphor/domutils$': plib.resolve(
__dirname,
'node_modules/@lumino/domutils/dist/index.js'
),
'@phosphor/dragdrop$': plib.resolve(
__dirname,
'node_modules/@lumino/dragdrop/dist/index.js'
),
'@phosphor/dragdrop/style': plib.resolve(
__dirname,
'node_modules/@lumino/widgets/style'
),
'@phosphor/messaging$': plib.resolve(
__dirname,
'node_modules/@lumino/messaging/dist/index.js'
),
'@phosphor/properties$': plib.resolve(
__dirname,
'node_modules/@lumino/properties/lib'
),
'@phosphor/signaling': plib.resolve(
__dirname,
'node_modules/@lumino/signaling/dist/index.js'
),
'@phosphor/widgets/style': plib.resolve(
__dirname,
'node_modules/@lumino/widgets/style'
),
'@phosphor/virtualdom$': plib.resolve(
__dirname,
'node_modules/@lumino/virtualdom/dist/index.js'
),
'@phosphor/widgets$': plib.resolve(
__dirname,
'node_modules/@lumino/widgets/dist/index.js'
)
}
},
output: {
path: plib.resolve(buildDir),
publicPath: '{{page_config.fullStaticUrl}}/',
filename: '[name].[chunkhash].js'
},
optimization: {
splitChunks: {
chunks: 'all'
}
},
module: {
rules: [
{ test: /\.css$/, use: ['style-loader', 'css-loader'] },
{ test: /\.md$/, use: 'raw-loader' },
{ test: /\.txt$/, use: 'raw-loader' },
{
test: /\.js$/,
include: sourceMapRes,
use: ['source-map-loader'],
enforce: 'pre'
},
{ test: /\.(jpg|png|gif)$/, use: 'file-loader' },
{ test: /\.js.map$/, use: 'file-loader' },
{
test: /\.woff2(\?v=\d+\.\d+\.\d+)?$/,
use: 'url-loader?limit=10000&mimetype=application/font-woff'
},
{
test: /\.woff(\?v=\d+\.\d+\.\d+)?$/,
use: 'url-loader?limit=10000&mimetype=application/font-woff'
},
{
test: /\.ttf(\?v=\d+\.\d+\.\d+)?$/,
use: 'url-loader?limit=10000&mimetype=application/octet-stream'
},
{
test: /\.otf(\?v=\d+\.\d+\.\d+)?$/,
use: 'url-loader?limit=10000&mimetype=application/octet-stream'
},
{ test: /\.eot(\?v=\d+\.\d+\.\d+)?$/, use: 'file-loader' },
{
// In .css files, svg is loaded as a data URI.
test: /\.svg(\?v=\d+\.\d+\.\d+)?$/,
issuer: { test: /\.css$/ },
use: {
loader: 'svg-url-loader',
options: { encoding: 'none', limit: 10000 }
}
},
{
// In .ts and .tsx files (both of which compile to .js), svg files
// must be loaded as a raw string instead of data URIs.
test: /\.svg(\?v=\d+\.\d+\.\d+)?$/,
issuer: { test: /\.js$/ },
use: {
loader: 'raw-loader'
}
}
]
},
watchOptions: {
poll: 500,
aggregateTimeout: 1000
},
node: {
fs: 'empty'
},
bail: true,
devtool: 'inline-source-map',
externals: ['node-fetch', 'ws'],
plugins
}
].concat(extraConfig);