mirror of
https://github.com/hensm/fx_cast.git
synced 2026-06-08 16:49:58 +00:00
117 lines
3.8 KiB
JavaScript
Executable File
117 lines
3.8 KiB
JavaScript
Executable File
"use strict";
|
|
|
|
const path = require("path");
|
|
|
|
const webpack = require("webpack");
|
|
const CopyWebpackPlugin = require("copy-webpack-plugin");
|
|
const HtmlWebpackPlugin = require("html-webpack-plugin");
|
|
|
|
|
|
const sourceFileExtensions = [
|
|
".js", ".jsx"
|
|
, ".ts", ".tsx"
|
|
];
|
|
|
|
module.exports = (env) => ({
|
|
entry: {
|
|
"background": `${env.includePath}/background/background.ts`
|
|
|
|
// Sender apps
|
|
, "senders/media/bundle": `${env.includePath}/senders/media/index.ts`
|
|
, "senders/media/overlay/overlayContent": `${env.includePath}/senders/media/overlay/overlayContent.ts`
|
|
, "senders/media/overlay/overlayContentLoader": `${env.includePath}/senders/media/overlay/overlayContentLoader.ts`
|
|
, "senders/mirroring": `${env.includePath}/senders/mirroring.ts`
|
|
|
|
// Shim entries
|
|
, "shim/bundle": `${env.includePath}/shim/index.ts`
|
|
, "shim/content": `${env.includePath}/shim/content.ts`
|
|
, "shim/contentBridge": `${env.includePath}/shim/contentBridge.ts`
|
|
|
|
// UI
|
|
, "ui/popup/bundle": `${env.includePath}/ui/popup/index.tsx`
|
|
, "ui/options/bundle": `${env.includePath}/ui/options/index.tsx`
|
|
}
|
|
, output: {
|
|
filename: "[name].js"
|
|
, path: env.outputPath
|
|
}
|
|
, plugins: [
|
|
new webpack.DefinePlugin({
|
|
"MIRRORING_APP_ID": JSON.stringify(env.mirroringAppId)
|
|
, "APPLICATION_NAME": JSON.stringify(env.applicationName)
|
|
, "APPLICATION_VERSION": JSON.stringify(env.applicationVersion)
|
|
})
|
|
|
|
// Copy static assets
|
|
, new CopyWebpackPlugin({
|
|
patterns: [
|
|
{
|
|
from: env.includePath
|
|
, to: env.outputPath
|
|
, globOptions: {
|
|
ignore: sourceFileExtensions.map(ext => `**${ext}`)
|
|
}
|
|
, transform (content, path) {
|
|
// Access to variables in static files
|
|
if (path.endsWith(".json")) {
|
|
return Buffer.from(content.toString()
|
|
.replace("EXTENSION_NAME", env.extensionName)
|
|
.replace("EXTENSION_ID", env.extensionId)
|
|
.replace("EXTENSION_VERSION", env.extensionVersion)
|
|
.replace("CONTENT_SECURITY_POLICY", env.contentSecurityPolicy)
|
|
.replace("AUTHOR", env.author)
|
|
.replace("AUTHOR_HOMEPAGE", env.authorHomepage));
|
|
}
|
|
|
|
return content;
|
|
}
|
|
}
|
|
]
|
|
})
|
|
|
|
, new HtmlWebpackPlugin({
|
|
inject: true
|
|
, template: `${env.includePath}/ui/template.html`
|
|
, filename: `${env.outputPath}/ui/popup/index.html`
|
|
, chunks: [ "ui/popup/bundle" ]
|
|
})
|
|
, new HtmlWebpackPlugin({
|
|
inject: true
|
|
, template: `${env.includePath}/ui/template.html`
|
|
, filename: `${env.outputPath}/ui/options/index.html`
|
|
, chunks: [ "ui/options/bundle" ]
|
|
})
|
|
]
|
|
, optimization: {
|
|
splitChunks: {
|
|
cacheGroups: {
|
|
vendor: {
|
|
test: /[\\/]node_modules[\\/](preact|preact\/compat)[\\/]/
|
|
, name: "vendor"
|
|
, chunks: "initial"
|
|
}
|
|
}
|
|
}
|
|
}
|
|
, module: {
|
|
rules: [
|
|
{
|
|
test: /\.(js|ts)x?$/
|
|
, resolve: {
|
|
extensions: sourceFileExtensions
|
|
}
|
|
, include: env.includePath
|
|
, use: {
|
|
loader: "ts-loader"
|
|
}
|
|
}
|
|
]
|
|
}
|
|
, resolve: {
|
|
alias: {
|
|
"react": "preact/compat"
|
|
, "react-dom": "preact/compat"
|
|
}
|
|
}
|
|
});
|