mirror of
https://gitee.com/vant-contrib/vant-weapp.git
synced 2025-04-05 02:12:43 +08:00
182 lines
5.5 KiB
JavaScript
182 lines
5.5 KiB
JavaScript
const fs = require('fs');
|
|
const gulp = require('gulp');
|
|
const path = require('path');
|
|
const less = require('gulp-less');
|
|
const insert = require('gulp-insert');
|
|
const rename = require('gulp-rename');
|
|
const postcss = require('gulp-postcss');
|
|
const ts = require('gulp-typescript');
|
|
const util = require('util');
|
|
const merge2 = require('merge2');
|
|
const exec = util.promisify(require('child_process').exec);
|
|
|
|
const src = path.resolve(__dirname, '../packages');
|
|
const icons = path.resolve(__dirname, '../node_modules/@vant/icons');
|
|
|
|
const libConfig = path.resolve(__dirname, '../tsconfig.lib.json');
|
|
const esConfig = path.resolve(__dirname, '../tsconfig.json');
|
|
const exampleConfig = path.resolve(__dirname, '../tsconfig.example.json');
|
|
|
|
const libDir = path.resolve(__dirname, '../lib');
|
|
const esDir = path.resolve(__dirname, '../dist');
|
|
const exampleDistDir = path.resolve(__dirname, '../example/dist');
|
|
const examplePagesDir = path.resolve(__dirname, '../example/pages');
|
|
|
|
const exampleAppJsonPath = path.resolve(__dirname, '../example/app.json');
|
|
const baseCssPath = path.resolve(__dirname, '../packages/common/index.wxss');
|
|
|
|
const lessCompiler = (dist) =>
|
|
function compileLess() {
|
|
const srcPath = [`${src}/**/*.less`];
|
|
if ([esDir, libDir].indexOf(dist) !== -1) {
|
|
srcPath.push(`!${src}/**/demo/**/*.less`);
|
|
}
|
|
return gulp
|
|
.src(srcPath)
|
|
.pipe(less())
|
|
.pipe(postcss())
|
|
.pipe(
|
|
insert.transform((contents, file) => {
|
|
if (!file.path.includes('packages' + path.sep + 'common')) {
|
|
const relativePath = path
|
|
.relative(
|
|
path.normalize(`${file.path}${path.sep}..`),
|
|
baseCssPath
|
|
)
|
|
.replace(/\\/g, '/');
|
|
contents = `@import '${relativePath}';${contents}`;
|
|
}
|
|
return contents;
|
|
})
|
|
)
|
|
.pipe(rename({ extname: '.wxss' }))
|
|
.pipe(gulp.dest(dist));
|
|
};
|
|
|
|
const tsCompiler = (dist, config) =>
|
|
function compileTs() {
|
|
const tsProject = ts.createProject(config, {
|
|
declaration: true,
|
|
});
|
|
const tsResult = tsProject.src().pipe(tsProject());
|
|
|
|
return merge2(
|
|
tsResult.js
|
|
.pipe(
|
|
insert.transform((contents, file) => {
|
|
if (dist === exampleDistDir && file.path.includes(`${path.sep}demo${path.sep}`)) {
|
|
const iconConfig = '@vant/icons/src/config';
|
|
contents = contents.replace(
|
|
iconConfig,
|
|
path.relative(
|
|
path.dirname(file.path),
|
|
`${exampleDistDir}/${iconConfig}`
|
|
).replace(/\\/g, '/')
|
|
);
|
|
}
|
|
return contents;
|
|
})
|
|
)
|
|
.pipe(gulp.dest(dist)),
|
|
tsResult.dts.pipe(gulp.dest(dist))
|
|
);
|
|
};
|
|
|
|
const copier = (dist, ext) =>
|
|
function copy() {
|
|
const srcPath = [`${src}/**/*.${ext}`];
|
|
if ([esDir, libDir].indexOf(dist) !== -1) {
|
|
srcPath.push(`!${src}/**/demo/**/*.${ext}`);
|
|
}
|
|
return gulp
|
|
.src(srcPath)
|
|
.pipe(
|
|
insert.transform((contents, file) => {
|
|
if (ext === 'json' && file.path.includes(`${path.sep}demo${path.sep}`) ) {
|
|
contents = contents.replace('/example', '');
|
|
}
|
|
return contents;
|
|
})
|
|
)
|
|
.pipe(gulp.dest(dist));
|
|
};
|
|
|
|
const staticCopier = (dist) =>
|
|
gulp.parallel(
|
|
copier(dist, 'wxml'),
|
|
copier(dist, 'wxs'),
|
|
copier(dist, 'json')
|
|
);
|
|
|
|
const cleaner = (path) =>
|
|
function clean() {
|
|
return exec(`npx rimraf ${path}`);
|
|
};
|
|
|
|
const tasks = [
|
|
['buildEs', esDir, esConfig],
|
|
['buildLib', libDir, libConfig],
|
|
].reduce((prev, [name, ...args]) => {
|
|
prev[name] = gulp.series(
|
|
cleaner(...args),
|
|
gulp.parallel(
|
|
tsCompiler(...args),
|
|
lessCompiler(...args),
|
|
staticCopier(...args)
|
|
)
|
|
);
|
|
return prev;
|
|
}, {});
|
|
|
|
tasks.buildExample = gulp.series(
|
|
cleaner(exampleDistDir),
|
|
gulp.parallel(
|
|
tsCompiler(exampleDistDir, exampleConfig),
|
|
lessCompiler(exampleDistDir),
|
|
staticCopier(exampleDistDir),
|
|
() =>
|
|
gulp
|
|
.src(`${icons}/**/*`)
|
|
.pipe(gulp.dest(`${exampleDistDir}/@vant/icons`)),
|
|
() => {
|
|
const appJson = JSON.parse(fs.readFileSync(exampleAppJsonPath));
|
|
const excludePages = ['pages/dashboard/index'];
|
|
appJson.pages
|
|
.filter((page) => page.indexOf(excludePages) === -1)
|
|
.forEach((path) => {
|
|
const component = path.replace(/(pages\/|\/index)/g, '');
|
|
const writeFiles = [
|
|
{
|
|
path: `${examplePagesDir}/${component}/index.js`,
|
|
contents: "import Page from '../../common/page';\n\nPage();",
|
|
},
|
|
{
|
|
path: `${examplePagesDir}/${component}/index.wxml`,
|
|
contents: `<van-${component}-demo />`,
|
|
},
|
|
];
|
|
writeFiles.forEach((writeFile) => {
|
|
fs.access(writeFile.path, fs.constants.F_OK, (fileNotExists) => {
|
|
if (fileNotExists) {
|
|
fs.writeFile(writeFile.path, writeFile.contents, (err) => {
|
|
if (err) {
|
|
throw err;
|
|
}
|
|
});
|
|
}
|
|
});
|
|
});
|
|
});
|
|
},
|
|
() => {
|
|
gulp.watch(`${src}/**/*.less`, lessCompiler(exampleDistDir));
|
|
gulp.watch(`${src}/**/*.wxml`, copier(exampleDistDir, 'wxml'));
|
|
gulp.watch(`${src}/**/*.wxs`, copier(exampleDistDir, 'wxs'));
|
|
gulp.watch(`${src}/**/*.ts`, tsCompiler(exampleDistDir, exampleConfig));
|
|
gulp.watch(`${src}/**/*.json`, copier(exampleDistDir, 'json'));
|
|
}
|
|
)
|
|
);
|
|
|
|
module.exports = tasks;
|