mirror of
https://github.com/WeBankFinTech/fes.js.git
synced 2025-04-06 03:59:53 +08:00
refactor: 梳理构建配置
This commit is contained in:
parent
049c9532de
commit
ec1ba22616
10
packages/fes-build-vite/types.d.ts
vendored
10
packages/fes-build-vite/types.d.ts
vendored
@ -6,9 +6,9 @@ import {createHtmlPlugin} from 'vite-plugin-html'
|
||||
|
||||
|
||||
export interface ViteBuildConfig {
|
||||
viteOption: UserConfig;
|
||||
viteVuePlugin: Options;
|
||||
viteVueJsx: Parameters<typeof createPlugin>[0];
|
||||
viteLegacy: PolyfillOptions;
|
||||
viteHtml: Parameters<typeof createHtmlPlugin>[0]
|
||||
viteOption?: UserConfig;
|
||||
viteVuePlugin?: Options;
|
||||
viteVueJsx?: Parameters<typeof createPlugin>[0];
|
||||
viteLegacy?: PolyfillOptions;
|
||||
viteHtml?: Parameters<typeof createHtmlPlugin>[0]
|
||||
}
|
||||
|
@ -3,15 +3,13 @@ export default function () {
|
||||
plugins: [
|
||||
// register methods
|
||||
require.resolve('./plugins/registerMethods'),
|
||||
require.resolve('./plugins/registerType'),
|
||||
|
||||
// bundle configs
|
||||
require.resolve('./plugins/features/alias'),
|
||||
require.resolve('./plugins/features/analyze'),
|
||||
require.resolve('./plugins/features/autoprefixer'),
|
||||
require.resolve('./plugins/features/chainWebpack'),
|
||||
require.resolve('./plugins/features/cssLoader'),
|
||||
require.resolve('./plugins/features/copy'),
|
||||
require.resolve('./plugins/features/define'),
|
||||
require.resolve('./plugins/features/devServer'),
|
||||
require.resolve('./plugins/features/devtool'),
|
||||
require.resolve('./plugins/features/externals'),
|
||||
@ -20,12 +18,8 @@ export default function () {
|
||||
require.resolve('./plugins/features/extraBabelPresets'),
|
||||
require.resolve('./plugins/features/extraPostCSSPlugins'),
|
||||
require.resolve('./plugins/features/html'),
|
||||
require.resolve('./plugins/features/inlineLimit'),
|
||||
require.resolve('./plugins/features/lessLoader'),
|
||||
require.resolve('./plugins/features/outputPath'),
|
||||
require.resolve('./plugins/features/postcssLoader'),
|
||||
require.resolve('./plugins/features/publicPath'),
|
||||
require.resolve('./plugins/features/terserOptions'),
|
||||
require.resolve('./plugins/features/nodeModulesTransform'),
|
||||
require.resolve('./plugins/features/vueLoader'),
|
||||
|
||||
|
@ -38,6 +38,17 @@ function genTranspileDepRegex(exclude) {
|
||||
return deps.length ? new RegExp(deps.join('|')) : null;
|
||||
}
|
||||
|
||||
function handleAlias({ api, webpackConfig }) {
|
||||
const config = api.config;
|
||||
if (config.alias) {
|
||||
Object.keys(config.alias).forEach((key) => {
|
||||
webpackConfig.resolve.alias.set(key, config.alias[key]);
|
||||
});
|
||||
}
|
||||
webpackConfig.resolve.alias.set('@', api.paths.absSrcPath);
|
||||
webpackConfig.resolve.alias.set('@@', api.paths.absTmpPath);
|
||||
}
|
||||
|
||||
export default async function getConfig({ api, cwd, config, env, entry = {}, modifyBabelOpts, modifyBabelPresetOpts, chainWebpack, headScripts, publicPath }) {
|
||||
const isDev = env === 'development';
|
||||
const isProd = env === 'production';
|
||||
@ -68,11 +79,7 @@ export default async function getConfig({ api, cwd, config, env, entry = {}, mod
|
||||
// --------------- resolve -----------
|
||||
webpackConfig.resolve.extensions.merge(['.mjs', '.js', '.jsx', '.vue', '.ts', '.tsx', '.json', '.wasm']);
|
||||
|
||||
if (config.alias) {
|
||||
Object.keys(config.alias).forEach((key) => {
|
||||
webpackConfig.resolve.alias.set(key, config.alias[key]);
|
||||
});
|
||||
}
|
||||
handleAlias({ api, webpackConfig });
|
||||
|
||||
// --------------- module -----------
|
||||
webpackConfig.module
|
||||
|
@ -1,21 +0,0 @@
|
||||
export default (api) => {
|
||||
const { paths } = api;
|
||||
|
||||
api.describe({
|
||||
key: 'alias',
|
||||
config: {
|
||||
schema(joi) {
|
||||
return joi.object();
|
||||
},
|
||||
default: {},
|
||||
},
|
||||
});
|
||||
|
||||
api.chainWebpack(async (memo) => {
|
||||
// 选择在 chainWebpack 中进行以上 alias 的初始化,是为了支持用户使用 modifyPaths API 对 paths 进行改写
|
||||
memo.resolve.alias.set('@', paths.absSrcPath);
|
||||
memo.resolve.alias.set('@@', paths.absTmpPath);
|
||||
|
||||
return memo;
|
||||
});
|
||||
};
|
8
packages/fes-build-webpack/src/plugins/registerType.js
Normal file
8
packages/fes-build-webpack/src/plugins/registerType.js
Normal file
@ -0,0 +1,8 @@
|
||||
import { name } from '../package.json';
|
||||
|
||||
export default function (api) {
|
||||
api.addConfigType(() => ({
|
||||
source: name,
|
||||
build: ['WebpackBuildConfig'],
|
||||
}));
|
||||
}
|
54
packages/fes-build-webpack/types.d.ts
vendored
54
packages/fes-build-webpack/types.d.ts
vendored
@ -1,5 +1,57 @@
|
||||
import Config from 'webpack-chain'
|
||||
import webpack from 'webpack';
|
||||
import HtmlWebpackPlugin from 'html-webpack-plugin'
|
||||
|
||||
interface CopyFileType {
|
||||
from: string;
|
||||
to: string;
|
||||
}
|
||||
|
||||
export interface WebpackBuildConfig {
|
||||
|
||||
analyze?: {
|
||||
analyzerMode?: 'server' | 'static' | 'disabled';
|
||||
analyzerHost?: string;
|
||||
analyzerPort?: number | 'auto';
|
||||
openAnalyzer?: boolean;
|
||||
generateStatsFile?: boolean;
|
||||
statsFilename?: string;
|
||||
logLevel?: 'info' | 'warn' | 'error' | 'silent';
|
||||
defaultSizes?: 'stat' | 'parsed' | 'gzip'
|
||||
};
|
||||
chainWebpack?: (memo: Config, args: {env: string, webpack: typeof webpack}) => void;
|
||||
copy?: CopyFileType | CopyFileType[];
|
||||
cssLoader?: {
|
||||
url?: boolean | ((url: string, resourcePath: string) => boolean);
|
||||
import?: boolean | ({ filter: (url: string, media: string, resourcePath: string) => boolean });
|
||||
modules?: boolean | string | object;
|
||||
sourceMap?: boolean;
|
||||
importLoaders?: number;
|
||||
onlyLocals?: boolean;
|
||||
esModule?: boolean;
|
||||
localsConvention?: 'asIs' | 'camelCase' | 'camelCaseOnly' | 'dashes' | 'dashesOnly';
|
||||
};
|
||||
devServer?: {
|
||||
port?: number;
|
||||
host?: string;
|
||||
https?: boolean;
|
||||
headers?: object;
|
||||
[key: string]: any;
|
||||
};
|
||||
devtool?: string;
|
||||
exportStatic?: {
|
||||
htmlSuffix?: boolean;
|
||||
dynamicRoot?: boolean;
|
||||
};
|
||||
externals?: object | string | Function;
|
||||
extraBabelPlugins?: [];
|
||||
extraBabelPresets?: [];
|
||||
extraPostCSSPlugins?: [];
|
||||
html?: HtmlWebpackPlugin.Options;
|
||||
lessLoader?: Record<string, any>;
|
||||
nodeModulesTransform?: {
|
||||
exclude: string[]
|
||||
};
|
||||
postcssLoader?: Record<string, any>;
|
||||
vueLoader?: object;
|
||||
|
||||
}
|
@ -57,7 +57,7 @@ export default function (api) {
|
||||
|
||||
const { main: options } = api.config?.qiankun || {};
|
||||
const masterHistoryType = api.config?.router?.mode || defaultHistoryType;
|
||||
const base = api.config.base;
|
||||
const base = api.config.router?.base;
|
||||
api.writeTmpFile({
|
||||
path: absMasterOptionsPath,
|
||||
content: `
|
||||
|
@ -36,7 +36,7 @@ export default function (api) {
|
||||
|
||||
const shouldNotModifyDefaultBase = api.userConfig.qiankun?.slave?.shouldNotModifyDefaultBase ?? initialMicroOptions.shouldNotModifyDefaultBase;
|
||||
if (!shouldNotModifyDefaultBase) {
|
||||
modifiedDefaultConfig.base = `/${api.pkg.name}`;
|
||||
modifiedDefaultConfig.router.base = `/${api.pkg.name}`;
|
||||
}
|
||||
|
||||
return modifiedDefaultConfig;
|
||||
|
@ -12,16 +12,22 @@ export default function () {
|
||||
require.resolve('./plugins/generateFiles/genType'),
|
||||
|
||||
// bundle configs
|
||||
require.resolve('./plugins/features/base'),
|
||||
require.resolve('./plugins/features/alias'),
|
||||
require.resolve('./plugins/features/autoprefixer'),
|
||||
require.resolve('./plugins/features/checkVuePackage'),
|
||||
require.resolve('./plugins/features/define'),
|
||||
require.resolve('./plugins/features/dynamicImport'),
|
||||
require.resolve('./plugins/features/globalCSS'),
|
||||
require.resolve('./plugins/features/inlineLimit'),
|
||||
require.resolve('./plugins/features/mountElementId'),
|
||||
require.resolve('./plugins/features/mock'),
|
||||
require.resolve('./plugins/features/outputPath'),
|
||||
require.resolve('./plugins/features/plugins'),
|
||||
require.resolve('./plugins/features/proxy'),
|
||||
require.resolve('./plugins/features/publicPath'),
|
||||
require.resolve('./plugins/features/singular'),
|
||||
require.resolve('./plugins/features/targets'),
|
||||
require.resolve('./plugins/features/terserOptions'),
|
||||
|
||||
// route
|
||||
require.resolve('./plugins/route'),
|
||||
|
@ -1,11 +1,11 @@
|
||||
export default (api) => {
|
||||
api.describe({
|
||||
key: 'base',
|
||||
key: 'alias',
|
||||
config: {
|
||||
default: '',
|
||||
schema(joi) {
|
||||
return joi.string().allow('');
|
||||
return joi.object();
|
||||
},
|
||||
default: {},
|
||||
},
|
||||
});
|
||||
};
|
@ -263,6 +263,7 @@ export default function (api) {
|
||||
config: {
|
||||
schema(joi) {
|
||||
return joi.object({
|
||||
base: joi.string(),
|
||||
routes: joi.array(),
|
||||
mode: joi.string(),
|
||||
});
|
||||
@ -328,7 +329,7 @@ export default function (api) {
|
||||
content: Mustache.render(routeExportsTpl, {
|
||||
runtimePath,
|
||||
config: api.config,
|
||||
routerBase: api.config.base,
|
||||
routerBase: api.config.router?.base,
|
||||
CREATE_HISTORY: historyType[api.config.router.mode] || 'createWebHashHistory',
|
||||
}),
|
||||
});
|
||||
|
62
packages/fes/types.d.ts
vendored
62
packages/fes/types.d.ts
vendored
@ -47,20 +47,66 @@ export function defineRuntimeConfig(config: InnerRuntimeConfig & PluginRuntimeCo
|
||||
|
||||
|
||||
interface InnerBuildConfig {
|
||||
base: string;
|
||||
dynamicImport: boolean;
|
||||
mock: boolean | {
|
||||
prefix: string;
|
||||
alias?: Record<string, string>,
|
||||
autoprefixer?: {
|
||||
/** environment for `Browserslist` */
|
||||
env?: string
|
||||
|
||||
/** should Autoprefixer use Visual Cascade, if CSS is uncompressed */
|
||||
cascade?: boolean
|
||||
|
||||
/** should Autoprefixer add prefixes. */
|
||||
add?: boolean
|
||||
|
||||
/** should Autoprefixer [remove outdated] prefixes */
|
||||
remove?: boolean
|
||||
|
||||
/** should Autoprefixer add prefixes for @supports parameters. */
|
||||
supports?: boolean
|
||||
|
||||
/** should Autoprefixer add prefixes for flexbox properties */
|
||||
flexbox?: boolean | 'no-2009'
|
||||
|
||||
/** should Autoprefixer add IE 10-11 prefixes for Grid Layout properties */
|
||||
grid?: boolean | GridValue
|
||||
|
||||
/** custom usage statistics for > 10% in my stats browsers query */
|
||||
stats?: Stats
|
||||
|
||||
/**
|
||||
* list of queries for target browsers.
|
||||
* Try to not use it.
|
||||
* The best practice is to use `.browserslistrc` config or `browserslist` key in `package.json`
|
||||
* to share target browsers with Babel, ESLint and Stylelint
|
||||
*/
|
||||
overrideBrowserslist?: string | string[]
|
||||
|
||||
/** do not raise error on unknown browser version in `Browserslist` config. */
|
||||
ignoreUnknownVersions?: boolean
|
||||
};
|
||||
mountElementId: string;
|
||||
plugins: string[];
|
||||
proxy: {
|
||||
define?: Record<string, string | object>,
|
||||
router?: {
|
||||
base?: string;
|
||||
routes?: RouteRecordRaw[];
|
||||
mode?: 'hash' | 'history' | 'memory'
|
||||
};
|
||||
dynamicImport?: boolean;
|
||||
inlineLimit?: number;
|
||||
mock?: boolean | {
|
||||
prefix?: string;
|
||||
};
|
||||
mountElementId?: string;
|
||||
plugins?: string[];
|
||||
proxy?: {
|
||||
[apiPrefix: string]: {
|
||||
target: string;
|
||||
changeOrigin?: boolean;
|
||||
}
|
||||
};
|
||||
singular: boolean;
|
||||
publicPath?: string;
|
||||
singular?: boolean;
|
||||
targets?: object;
|
||||
terserOptions?: object;
|
||||
}
|
||||
|
||||
export function defineBuildConfig(config: InnerBuildConfig & PluginBuildConfig ): InnerBuildConfig & PluginBuildConfig;
|
||||
|
Loading…
x
Reference in New Issue
Block a user