代码拉取完成,页面将自动刷新
同步操作将从 days2020/iview-uieditor 强制同步,此操作会覆盖自 Fork 仓库以来所做的任何修改,且无法恢复!!!
确定后同步将在后台操作,完成时将刷新页面,请耐心等待。
const path = require('path');
const fs = require('fs');
const CopyWebpackPlugin = require('copy-webpack-plugin');
const uieditorName = 'iview-uieditor';
const publicPath = './';
const filename = '[name].[hash].js';
const assetPath = path.join(uieditorName, './assets').replace(/\\/g, '/');
const cssPath = path.join(assetPath, 'css').replace(/\\/g, '/');
const isPrdt = process.env.NODE_ENV === 'production';
const rawArgv = process.argv.slice(2)
const isLib = (rawArgv || []).includes('-lib');
const package = require('./package.json');
process.env.VUE_APP_UE_NAME = package.name;
process.env.VUE_APP_UE_VERSION = package.version;
process.env.VUE_APP_UE_HOMEPAGE = package.homepage;
process.env.VUE_APP_UE_DESC = package.description;
// vue.config.js
module.exports = {
publicPath,
lintOnSave: true,
outputDir: path.resolve(__dirname, isLib ? './lib' : (isPrdt ? './pages' : './dist')),
assetsDir: assetPath,
runtimeCompiler: true,
parallel: true,
productionSourceMap: false,
devServer: {
open: false,
overlay: {
warning: false,
errors: false
}
},
css: {
extract: {
publicPath: cssPath,
filename: path.join(cssPath, '[name].css'),
chunkFilename: path.join(cssPath, '[name].[contenthash:8].css')
},
loaderOptions: {
less: {
// localIdentName: '[name]_[local]'
},
css: {
// localIdentName: '[name]_[local]'
}
}
},
configureWebpack: config => {
// config.output.chunkFilename = '[name].[hash].chunk.js';
if (isLib) {
Object.assign(config.output, {
filename: 'index.js',
chunkFilename: `./${uieditorName}/${filename}`,
libraryTarget: 'umd',
library: 'VueUieditor',
umdNamedDefine: true
});
if (!config.externals) config.externals = {};
Object.assign(config.externals, {
vue: {
root: 'Vue',
commonjs: 'vue',
commonjs2: 'vue',
amd: 'vue'
},
lodash: {
root: '_',
commonjs: 'lodash',
commonjs2: 'lodash',
amd: 'lodash'
},
'vue-template-compiler': 'vue-template-compiler',
'@vue/composition-api': '@vue/composition-api',
'vue-uieditor': 'vue-uieditor',
'view-design': 'view-design'
});
}
},
chainWebpack: config => {
// console.log('process.env.NODE_ENV', process.env.NODE_ENV);
// // 不编译 layui
config.module
.rule('js')
.test(/\.jsx?$/)
.exclude
.add(path.resolve(__dirname, './src/iview-uieditor/layui'))
.end();
// config.plugin('copy-assets').use(CopyWebpackPlugin, [
// [{
// from: './src/iview-uieditor/assets/',
// to: './iview-uieditor/assets/'
// }]
// ]);
if (isLib) {
// 为生产环境修改配置...
config.entry('app').clear();
const entryFile = path.resolve(__dirname, `./src/${uieditorName}/index.ts`);
config.entry('app').add(entryFile).end();
const tsConfigFile = path.resolve(__dirname, './tsconfig.json');
const declarationDir = path.resolve(__dirname, './lib/@types-build');
//pack 输出 types
config.module.rule('ts')
.use('ts-loader')
.loader('ts-loader')
.tap(options => {
Object.assign(options, {
context: __dirname,
configFile: tsConfigFile,
transpileOnly: false,
happyPackMode: false,
compilerOptions: {
"declaration": true,
"declarationDir": declarationDir
}
});
return options;
});
config.module.rule('ts').uses.delete('thread-loader');
config.module.rule('ts').uses.delete('cache-loader');
config.plugins.delete('html');
config.plugins.delete('preload');
config.plugins.delete('prefetch');
config.plugins.delete('copy');
const packageFile = (function saveLibPackage() {
// const package = require('./package.json');
const { name, version, author, description, main, keyword, types, homepage } = package;
const newPackage = {
name, version, author, description, main, keyword, types, homepage,
"scripts": {},
"dependencies": {
"vue": "^2.6.10",
"vue-template-compiler": "^2.6.10",
"vue-uieditor": "^1.1.0",
"view-design": "^4.5.0",
"@vue/composition-api": "^1.4.0",
"lodash": "^4.17.21"
},
"devDependencies": {}
};
const os = require('os');
const newPath = path.resolve(os.tmpdir(), './iview-uieditor');
if (!fs.existsSync(newPath)) fs.mkdirSync(newPath);
const newFile = path.resolve(newPath, 'package.json');
fs.writeFileSync(newFile, JSON.stringify(newPackage, null, 2), 'utf-8');
return newFile;
})();
config.plugin('copy-lib-files').use(CopyWebpackPlugin, [
[
{
from: packageFile,
to: './'
},
{
from: './README.md',
to: './'
}
]
]);
} else {
// 为开发环境修改配置...
config.plugin('copy-vue-uieditor-assets').use(CopyWebpackPlugin, [
[{
from: './node_modules/vue-uieditor/vue-uieditor',
to: './vue-uieditor/'
}]
]);
// config.plugins.delete('html');
// config.plugins.delete('copy');
}
}
}
此处可能存在不合适展示的内容,页面不予展示。您可通过相关编辑功能自查并修改。
如您确认内容无涉及 不当用语 / 纯广告导流 / 暴力 / 低俗色情 / 侵权 / 盗版 / 虚假 / 无价值内容或违法国家有关法律法规的内容,可点击提交进行申诉,我们将尽快为您处理。