blob: fa13a1d020393d33bf7899ee1bd2dcb6081e5dff [file] [log] [blame] [edit]
// Copyright 2022 The ChromiumOS Authors
// Use of this source code is governed by a BSD-style license that can be
// found in the LICENSE file.
//@ts-check
'use strict';
const path = require('path');
const CopyPlugin = require('copy-webpack-plugin');
const {GitRevisionPlugin} = require('git-revision-webpack-plugin');
//@ts-check
/** @typedef {import('webpack').Configuration} WebpackConfig **/
/** @type WebpackConfig */
const commonConfig = {
// This leaves the source code as close as possible to the
// original (when packaging we set this to "production").
mode: 'none',
resolve: {
// Support reading TypeScript and JavaScript files.
// https://github.com/TypeStrong/ts-loader
extensions: ['.ts', '.js'],
},
devtool: 'nosources-source-map',
infrastructureLogging: {
// Enable logging required for problem matchers.
level: 'log',
},
};
/** @type WebpackConfig */
const extensionConfig = {
...commonConfig,
// VSCode extensions run in a Node.js context.
// https://webpack.js.org/configuration/node/
target: 'node',
// The entry point of this extension.
// https://webpack.js.org/configuration/entry-context/
entry: './src/extension.ts',
output: {
// The bundle is stored in the dist folder.
// package.json specifies dist/extension.js as the extension entry point.
// https://webpack.js.org/configuration/output/
path: path.resolve(__dirname, 'dist'),
filename: 'extension.js',
libraryTarget: 'commonjs2',
},
externals: {
// The vscode module is created on-the-fly and must be excluded.
// Add other modules that cannot be webpack'ed.
// https://webpack.js.org/configuration/externals/
// Modules added here also need to be added in the .vscodeignore file.
vscode: 'commonjs vscode',
},
module: {
rules: [
{
test: /\.ts$/,
exclude: /node_modules/,
loader: 'esbuild-loader',
options: {
loader: 'ts',
target: 'es2020',
},
},
],
},
plugins: [
new GitRevisionPlugin({
versionCommand: 'describe --always --dirty',
}),
],
};
/** @type WebpackConfig */
const viewsConfig = {
...commonConfig,
// WebView scripts run in the web context.
target: 'web',
// TODO(joelbecker): move to common config? Check implications.
mode: 'development',
// Entry points.
// https://webpack.js.org/configuration/entry-context/
entry: {
vnc: './views/src/vnc.ts',
syslog_view: './views/src/features/device_management/syslog/view.tsx',
add_owned_device_view:
'./views/src/features/device_management/owned/add_owned_device_view.tsx',
flash_device_view:
'./views/src/features/device_management/flash_device_view.tsx',
builds_browser_view:
'./views/src/features/device_management/builds_browser_view.tsx',
},
output: {
path: path.resolve(__dirname, 'dist', 'views'),
filename: '[name].js',
libraryTarget: 'commonjs2',
},
resolve: {
// Support TypeScript, JavaScript, and JSX-enabled TypeScript and
// JavaScript for use with React.
extensions: ['.ts', '.js', '.tsx', '.jsx'],
},
module: {
rules: [
{
test: /\.tsx?$/,
exclude: /node_modules/,
loader: 'esbuild-loader',
options: {
loader: 'tsx',
target: 'es2020',
tsconfigRaw: require('./views/tsconfig.json'),
},
},
],
},
plugins: [
new CopyPlugin({
patterns: [
// Copy webview static files to dist/views/.
{from: 'views/static', to: '.'},
// Copy @vscode/codicons's dist files to dist/views/vscode/.
{
from: 'node_modules/@vscode/codicons/dist/',
to: './vscode/',
},
],
}),
],
};
module.exports = [extensionConfig, viewsConfig];