From 11ce2a602f6065507df2d5e8ead45d6adea27398 Mon Sep 17 00:00:00 2001 From: neverland Date: Sat, 3 Nov 2018 21:08:06 +0800 Subject: [PATCH] [breaking change] rebuild style struct (#2021) --- .github/CONTRIBUTING.md | 1 - README.md | 9 +- README.zh-CN.md | 9 +- build/build-components.js | 79 +- build/build-iconfont.js | 7 +- build/build-lib.js | 2 +- build/build-style-entry.js | 41 +- build/build-style.js | 16 + build/get-components.js | 10 +- build/release.sh | 7 - build/webpack.dev.js | 5 +- docs/markdown/changelog.en-US.md | 6 +- docs/markdown/changelog.zh-CN.md | 6 +- docs/markdown/contribution.zh-CN.md | 8 +- docs/markdown/quickstart.en-US.md | 7 +- docs/markdown/quickstart.zh-CN.md | 7 +- docs/markdown/theme.en-US.md | 12 +- docs/markdown/theme.zh-CN.md | 14 +- docs/src/DocsApp.vue | 2 +- docs/src/WapApp.vue | 2 +- docs/src/components/DemoList.vue | 10 +- docs/src/components/DemoPages.vue | 2 +- docs/src/components/MobileNav.vue | 2 +- docs/src/demo-entry.js | 2 +- docs/src/doc.config.js | 4 +- docs/src/docs-entry.js | 4 +- docs/src/mobile.js | 2 +- jest.config.js | 2 +- package.json | 29 +- packages/actionsheet/demo/index.vue | 2 +- .../index.less} | 20 +- .../index.less} | 4 +- .../index.less} | 12 +- packages/badge-group/index.less | 5 + packages/badge/demo/index.vue | 2 +- .../src/badge.css => badge/index.less} | 18 +- packages/button/demo/index.vue | 2 +- .../src/button.css => button/index.less} | 44 +- .../src/card.css => card/index.less} | 16 +- packages/cell-group/index.less | 5 + packages/cell/demo/index.vue | 2 +- .../src/cell.css => cell/index.less} | 22 +- packages/checkbox/demo/index.vue | 2 +- .../src/checkbox.css => checkbox/index.less} | 26 +- packages/circle/demo/index.vue | 2 +- .../src/circle.css => circle/index.less} | 4 +- packages/col/demo/index.vue | 2 +- packages/col/index.less | 13 + .../collapse.css => collapse-item/index.less} | 8 +- packages/collapse/demo/index.vue | 8 +- packages/contact-card/demo/index.vue | 2 +- .../index.less} | 8 +- .../index.less} | 2 +- .../index.less} | 6 +- packages/coupon-list/demo/index.vue | 2 +- .../index.less} | 30 +- packages/dialog/demo/index.vue | 2 +- .../src/dialog.css => dialog/index.less} | 8 +- packages/field/demo/index.vue | 6 +- .../src/field.css => field/index.less} | 14 +- packages/goods-action-big-btn/index.less | 10 + packages/goods-action-mini-btn/index.less | 32 + packages/goods-action/demo/index.vue | 2 +- .../index.less} | 8 +- packages/icon/config/template-local.js | 2 +- .../config/{template.css => template.tpl} | 2 +- packages/icon/demo/index.vue | 2 +- packages/icon/en-US.md | 2 +- .../src/icon.css => icon/index.less} | 2 +- .../src/icon-local.css => icon/local.less} | 2 +- packages/icon/vant-icon-872dd0.ttf | Bin 25388 -> 25388 bytes packages/icon/zh-CN.md | 2 +- packages/image-preview/demo/index.vue | 2 +- .../index.less} | 4 +- packages/index.less | 70 + .../src/info.css => info/index.less} | 6 +- packages/lazyload/demo/index.vue | 2 +- packages/list/demo/index.vue | 2 +- .../src/list.css => list/index.less} | 4 +- packages/loading/demo/index.vue | 2 +- .../src/loading.css => loading/index.less} | 16 +- .../src/nav-bar.css => nav-bar/index.less} | 10 +- packages/notice-bar/demo/index.vue | 2 +- .../notice-bar.css => notice-bar/index.less} | 6 +- packages/number-keyboard/demo/index.vue | 2 +- .../index.less} | 38 +- packages/pagination/demo/index.vue | 2 +- .../pagination.css => pagination/index.less} | 20 +- packages/panel/demo/index.vue | 2 +- .../src/panel.css => panel/index.less} | 6 +- .../index.less} | 10 +- .../src/picker.css => picker/index.less} | 14 +- packages/popup/demo/index.vue | 2 +- .../src/popup.css => popup/index.less} | 4 +- packages/progress/demo/index.vue | 2 +- .../src/progress.css => progress/index.less} | 6 +- packages/pull-refresh/demo/index.vue | 2 +- .../index.less} | 4 +- packages/radio/demo/index.vue | 2 +- .../src/radio.css => radio/index.less} | 16 +- packages/rate/demo/index.vue | 2 +- .../src/rate.css => rate/index.less} | 2 +- .../{vant-css/src/row.css => row/index.less} | 2 +- .../src/search.css => search/index.less} | 8 +- packages/sku/demo/index.vue | 2 +- .../{vant-css/src/sku.css => sku/index.less} | 42 +- packages/slider/demo/index.vue | 2 +- .../src/slider.css => slider/index.less} | 8 +- .../src/steps.css => step/index.less} | 73 +- packages/stepper/demo/index.vue | 2 +- .../src/stepper.css => stepper/index.less} | 24 +- packages/steps/demo/index.vue | 6 +- packages/steps/index.less | 52 + .../animation.css => style/animation.less} | 0 packages/style/base.less | 16 + packages/style/clearfix.less | 5 + packages/{vant-css => style}/demo/index.vue | 6 +- packages/style/ellipsis.less | 5 + packages/{vant-css => style}/en-US.md | 0 .../hairline.css => style/hairline.less} | 4 +- .../mixins/clearfix.less} | 2 +- .../mixins/ellipsis.less} | 7 +- packages/style/mixins/hairline.less | 27 + .../normalize.css => style/normalize.less} | 0 .../src/reset.css => style/reset.less} | 6 +- packages/style/var.less | 54 + packages/{vant-css => style}/zh-CN.md | 0 packages/submit-bar/demo/index.vue | 6 +- .../submit-bar.css => submit-bar/index.less} | 8 +- packages/swipe-cell/demo/index.vue | 8 +- .../swipe-cell.css => swipe-cell/index.less} | 2 +- packages/swipe-item/index.less | 6 + packages/swipe/demo/index.vue | 2 +- .../src/swipe.css => swipe/index.less} | 20 +- .../index.less} | 2 +- packages/switch/demo/index.vue | 2 +- .../src/switch.css => switch/index.less} | 8 +- packages/tab/demo/index.vue | 2 +- packages/tab/index.less | 27 + packages/tabbar-item/index.less | 44 + packages/tabbar/demo/index.vue | 2 +- packages/tabbar/index.less | 14 + .../{vant-css/src/tab.css => tabs/index.less} | 59 +- packages/tag/demo/index.vue | 2 +- .../{vant-css/src/tag.css => tag/index.less} | 4 +- packages/toast/demo/index.vue | 2 +- .../src/toast.css => toast/index.less} | 4 +- .../index.less} | 10 +- packages/uploader/demo/index.vue | 2 +- .../src/uploader.css => uploader/index.less} | 2 +- packages/vant-css/gulpfile.js | 22 - packages/vant-css/package.json | 25 - packages/vant-css/src/base.css | 15 - packages/vant-css/src/col.css | 11 - packages/vant-css/src/common/clearfix.css | 5 - packages/vant-css/src/common/ellipsis.css | 5 - packages/vant-css/src/common/var.css | 38 - packages/vant-css/src/index.css | 63 - packages/vant-css/src/mixins/hairline.css | 27 - packages/vant-css/src/tabbar.css | 57 - packages/vant-css/src/vant-icon-243435.ttf | Bin 26116 -> 0 bytes packages/vant-css/yarn.lock | 3285 ----------------- packages/waterfall/demo/index.vue | 2 +- postcss.config.js | 2 - yarn.lock | 1018 +++-- 165 files changed, 1371 insertions(+), 4729 deletions(-) create mode 100644 build/build-style.js rename packages/{vant-css/src/actionsheet.css => actionsheet/index.less} (72%) rename packages/{vant-css/src/address-edit.css => address-edit/index.less} (89%) rename packages/{vant-css/src/address-list.css => address-list/index.less} (89%) create mode 100644 packages/badge-group/index.less rename packages/{vant-css/src/badge.css => badge/index.less} (69%) rename packages/{vant-css/src/button.css => button/index.less} (64%) rename packages/{vant-css/src/card.css => card/index.less} (83%) create mode 100644 packages/cell-group/index.less rename packages/{vant-css/src/cell.css => cell/index.less} (78%) rename packages/{vant-css/src/checkbox.css => checkbox/index.less} (62%) rename packages/{vant-css/src/circle.css => circle/index.less} (90%) create mode 100644 packages/col/index.less rename packages/{vant-css/src/collapse.css => collapse-item/index.less} (83%) rename packages/{vant-css/src/contact-card.css => contact-card/index.less} (88%) rename packages/{vant-css/src/contact-edit.css => contact-edit/index.less} (85%) rename packages/{vant-css/src/contact-list.css => contact-list/index.less} (92%) rename packages/{vant-css/src/coupon-list.css => coupon-list/index.less} (78%) rename packages/{vant-css/src/dialog.css => dialog/index.less} (89%) rename packages/{vant-css/src/field.css => field/index.less} (89%) create mode 100644 packages/goods-action-big-btn/index.less create mode 100644 packages/goods-action-mini-btn/index.less rename packages/{vant-css/src/goods-action.css => goods-action/index.less} (83%) rename packages/icon/config/{template.css => template.tpl} (94%) rename packages/{vant-css/src/icon.css => icon/index.less} (99%) rename packages/{vant-css/src/icon-local.css => icon/local.less} (58%) rename packages/{vant-css/src/image-preview.css => image-preview/index.less} (91%) create mode 100644 packages/index.less rename packages/{vant-css/src/info.css => info/index.less} (82%) rename packages/{vant-css/src/list.css => list/index.less} (85%) rename packages/{vant-css/src/loading.css => loading/index.less} (85%) rename packages/{vant-css/src/nav-bar.css => nav-bar/index.less} (85%) rename packages/{vant-css/src/notice-bar.css => notice-bar/index.less} (92%) rename packages/{vant-css/src/number-keyboard.css => number-keyboard/index.less} (71%) rename packages/{vant-css/src/pagination.css => pagination/index.less} (72%) rename packages/{vant-css/src/panel.css => panel/index.less} (60%) rename packages/{vant-css/src/password-input.css => password-input/index.less} (84%) rename packages/{vant-css/src/picker.css => picker/index.less} (85%) rename packages/{vant-css/src/popup.css => popup/index.less} (96%) rename packages/{vant-css/src/progress.css => progress/index.less} (86%) rename packages/{vant-css/src/pull-refresh.css => pull-refresh/index.less} (91%) rename packages/{vant-css/src/radio.css => radio/index.less} (73%) rename packages/{vant-css/src/rate.css => rate/index.less} (82%) rename packages/{vant-css/src/row.css => row/index.less} (94%) rename packages/{vant-css/src/search.css => search/index.less} (82%) rename packages/{vant-css/src/sku.css => sku/index.less} (84%) rename packages/{vant-css/src/slider.css => slider/index.less} (82%) rename packages/{vant-css/src/steps.css => step/index.less} (66%) rename packages/{vant-css/src/stepper.css => stepper/index.less} (73%) create mode 100644 packages/steps/index.less rename packages/{vant-css/src/common/animation.css => style/animation.less} (100%) create mode 100644 packages/style/base.less create mode 100644 packages/style/clearfix.less rename packages/{vant-css => style}/demo/index.vue (96%) create mode 100644 packages/style/ellipsis.less rename packages/{vant-css => style}/en-US.md (100%) rename packages/{vant-css/src/common/hairline.css => style/hairline.less} (87%) rename packages/{vant-css/src/mixins/clearfix.css => style/mixins/clearfix.less} (80%) rename packages/{vant-css/src/mixins/ellipsis.css => style/mixins/ellipsis.less} (63%) create mode 100644 packages/style/mixins/hairline.less rename packages/{vant-css/src/common/normalize.css => style/normalize.less} (100%) rename packages/{vant-css/src/reset.css => style/reset.less} (94%) create mode 100644 packages/style/var.less rename packages/{vant-css => style}/zh-CN.md (100%) rename packages/{vant-css/src/submit-bar.css => submit-bar/index.less} (86%) rename packages/{vant-css/src/swipe-cell.css => swipe-cell/index.less} (91%) create mode 100644 packages/swipe-item/index.less rename packages/{vant-css/src/swipe.css => swipe/index.less} (62%) rename packages/{vant-css/src/switch-cell.css => switch-cell/index.less} (78%) rename packages/{vant-css/src/switch.css => switch/index.less} (85%) create mode 100644 packages/tab/index.less create mode 100644 packages/tabbar-item/index.less create mode 100644 packages/tabbar/index.less rename packages/{vant-css/src/tab.css => tabs/index.less} (56%) rename packages/{vant-css/src/tag.css => tag/index.less} (91%) rename packages/{vant-css/src/toast.css => toast/index.less} (95%) rename packages/{vant-css/src/tree-select.css => tree-select/index.less} (84%) rename packages/{vant-css/src/uploader.css => uploader/index.less} (91%) delete mode 100644 packages/vant-css/gulpfile.js delete mode 100644 packages/vant-css/package.json delete mode 100644 packages/vant-css/src/base.css delete mode 100644 packages/vant-css/src/col.css delete mode 100644 packages/vant-css/src/common/clearfix.css delete mode 100644 packages/vant-css/src/common/ellipsis.css delete mode 100644 packages/vant-css/src/common/var.css delete mode 100644 packages/vant-css/src/index.css delete mode 100644 packages/vant-css/src/mixins/hairline.css delete mode 100644 packages/vant-css/src/tabbar.css delete mode 100644 packages/vant-css/src/vant-icon-243435.ttf delete mode 100644 packages/vant-css/yarn.lock diff --git a/.github/CONTRIBUTING.md b/.github/CONTRIBUTING.md index 0b4b13558..dbf811bb7 100644 --- a/.github/CONTRIBUTING.md +++ b/.github/CONTRIBUTING.md @@ -38,6 +38,5 @@ npm run dev ## Component Developing Guidelines - Create new directory under `packages` for a new component. -- All the style code are located under `packages/vant-css/src`. - Refer to `Sku` for nested components. - Refer to `Button` for components that depend on other components. diff --git a/README.md b/README.md index 0dff553e1..db98cec38 100644 --- a/README.md +++ b/README.md @@ -13,7 +13,7 @@ Build Status downloads JS Gzip Size - CSS Gzip Size + CSS Gzip Size issue Coverage Status

@@ -53,7 +53,7 @@ yarn add vant ```html - + @@ -95,8 +95,7 @@ import { Button } from 'vant'; ```js import Button from 'vant/lib/button'; -import 'vant/lib/vant-css/base.css'; -import 'vant/lib/vant-css/button.css'; +import 'vant/lib/button/style'; ``` #### 3. Import all components @@ -104,7 +103,7 @@ import 'vant/lib/vant-css/button.css'; ```js import Vue from 'vue'; import Vant from 'vant'; -import 'vant/lib/vant-css/index.css'; +import 'vant/lib/index.css'; Vue.use(Vant); ``` diff --git a/README.zh-CN.md b/README.zh-CN.md index ff93ce2ea..0a4148d9e 100644 --- a/README.zh-CN.md +++ b/README.zh-CN.md @@ -12,7 +12,7 @@ Build Status downloads JS Gzip Size - CSS Gzip Size + CSS Gzip Size issue Coverage Status

@@ -54,7 +54,7 @@ yarn add vant ```html - + @@ -100,8 +100,7 @@ import { Button } from 'vant'; ```js import Button from 'vant/lib/button'; -import 'vant/lib/vant-css/base.css'; -import 'vant/lib/vant-css/button.css'; +import 'vant/lib/button/style'; ``` #### 方式三. 导入所有组件 @@ -109,7 +108,7 @@ import 'vant/lib/vant-css/button.css'; ```js import Vue from 'vue'; import Vant from 'vant'; -import 'vant/lib/vant-css/index.css'; +import 'vant/lib/index.css'; Vue.use(Vant); ``` diff --git a/build/build-components.js b/build/build-components.js index 2e0a5ae1d..164ff0bc4 100644 --- a/build/build-components.js +++ b/build/build-components.js @@ -15,51 +15,56 @@ const compilerOption = { } }; -const whiteList = /(demo|vant-css|test|\.md)$/; +const isDir = dir => fs.lstatSync(dir).isDirectory(); +const isJs = path => /\.js$/.test(isJs); +const isSfc = path => /\.vue$/.test(path); +const isCode = path => !/(demo|test|\.md)$/.test(path); + +function compile(dir) { + const files = fs.readdirSync(dir); + + files.forEach(file => { + const filePath = path.join(dir, file); + + // reomve unnecessary files + if (!isCode(file)) { + return fs.removeSync(filePath); + } + + // scan dir + if (isDir(filePath)) { + return compile(filePath); + } + + // compile sfc + if (isSfc(file)) { + const source = fs.readFileSync(filePath, 'utf-8'); + fs.removeSync(filePath); + + const jsPath = filePath.replace('.vue', '.js'); + const vuePath = filePath + '.js'; + const output = fs.existsSync(jsPath) ? vuePath : jsPath; + + return fs.outputFileSync(output, compiler(source, compilerOption).js); + } + + // compile js + if (isJs(file)) { + const { code } = babel.transformFileSync(filePath, compilerOption.babel); + fs.outputFileSync(filePath, code); + } + }); +} // clear dir fs.emptyDirSync(esDir); fs.emptyDirSync(libDir); -// copy packages +// compile es dir fs.copySync(srcDir, esDir); - compile(esDir); -function compile(dir, jsOnly = false) { - const files = fs.readdirSync(dir); - - files.forEach(file => { - const absolutePath = path.join(dir, file); - - // reomve unnecessary files - if (whiteList.test(file)) { - fs.removeSync(absolutePath); - // scan dir - } else if (isDir(absolutePath)) { - return compile(absolutePath); - // compile sfc - } else if (/\.vue$/.test(file) && !jsOnly) { - const source = fs.readFileSync(absolutePath, 'utf-8'); - fs.removeSync(absolutePath); - - const outputVuePath = absolutePath + '.js'; - const outputJsPath = absolutePath.replace('.vue', '.js'); - const output = fs.existsSync(outputJsPath) ? outputVuePath : outputJsPath; - - fs.outputFileSync(output, compiler(source, compilerOption).js); - } else if (/\.js$/.test(file)) { - const { code } = babel.transformFileSync(absolutePath, compilerOption.babel); - fs.outputFileSync(absolutePath, code); - } - }); -} - +// compile lib dir process.env.BABEL_MODULE = 'commonjs'; - fs.copySync(srcDir, libDir); compile(libDir); - -function isDir(dir) { - return fs.lstatSync(dir).isDirectory(); -} diff --git a/build/build-iconfont.js b/build/build-iconfont.js index 0f8fce51b..5b242d709 100644 --- a/build/build-iconfont.js +++ b/build/build-iconfont.js @@ -13,10 +13,9 @@ const config = require('../packages/icon/config'); const local = require('../packages/icon/config/template-local'); const iconDir = path.join(__dirname, '../packages/icon'); -const cssDir = path.join(__dirname, '../packages/vant-css/src'); const svgDir = path.join(iconDir, 'svg'); const sketch = path.join(iconDir, 'assets/icons.sketch'); -const template = path.join(iconDir, 'config/template.css'); +const template = path.join(iconDir, 'config/template.tpl'); // get md5 from sketch const md5 = md5File.sync(sketch).slice(0, 6); @@ -49,7 +48,7 @@ gulp.task('ttf', () => { iconfontCss({ fontName: config.name, path: template, - targetPath: '../vant-css/src/icon.css', + targetPath: '../icon/index.css', normalize: true, firstGlyph: 0xf000, cssClass: ttf // this is a trick to pass ttf to template @@ -67,7 +66,7 @@ gulp.task('ttf', () => { gulp.task('default', ['ttf'], () => { // generate icon-local.css fs.writeFileSync( - path.join(cssDir, 'icon-local.css'), + path.join(iconDir, 'local.css'), local(config.name, ttf) ); diff --git a/build/build-lib.js b/build/build-lib.js index adbfb3bf3..6114ebc0d 100644 --- a/build/build-lib.js +++ b/build/build-lib.js @@ -9,7 +9,7 @@ const tasks = [ 'lint', 'build:entry', 'build:components', - 'build:vant-css', + 'build:style', 'build:style-entry', 'build:vant' ]; diff --git a/build/build-style-entry.js b/build/build-style-entry.js index 2fef42fcc..805cdddaf 100644 --- a/build/build-style-entry.js +++ b/build/build-style-entry.js @@ -6,15 +6,17 @@ const fs = require('fs-extra'); const path = require('path'); const components = require('./get-components')(); const dependencyTree = require('dependency-tree'); -const whiteList = ['info', 'icon', 'loading', 'cell', 'button']; +const whiteList = ['info', 'icon', 'loading', 'cell', 'cell-group', 'button']; const dir = path.join(__dirname, '../es'); components.forEach(component => { - const deps = analyzeDependencies(component); + const deps = analyzeDependencies(component).map(dep => + getStyleRelativePath(component, dep) + ); const esEntry = path.join(dir, component, 'style/index.js'); const libEntry = path.join(__dirname, '../lib', component, 'style/index.js'); - const esContent = deps.map(dep => `import '../../vant-css/${dep}.css';`).join('\n'); - const libContent = deps.map(dep => `require('../../vant-css/${dep}.css');`).join('\n'); + const esContent = deps.map(dep => `import '${dep}';`).join('\n'); + const libContent = deps.map(dep => `require('${dep}');`).join('\n'); fs.outputFileSync(esEntry, esContent); fs.outputFileSync(libEntry, libContent); @@ -45,17 +47,38 @@ function search(tree, component, checkList) { Object.keys(tree).forEach(key => { search(tree[key], component, checkList); components - .filter(item => key.replace(dir, '').split('/').includes(item)) + .filter(item => + key + .replace(dir, '') + .split('/') + .includes(item) + ) .forEach(item => { - if (!checkList.includes(item) && !whiteList.includes(item) && item !== component) { + if ( + !checkList.includes(item) && + !whiteList.includes(item) && + item !== component + ) { checkList.push(item); } }); }); } -function checkComponentHasStyle(component) { - return fs.existsSync( - path.join(__dirname, `../es/vant-css/`, `${component}.css`) +function getStylePath(component) { + if (component === 'base') { + return path.join(__dirname, '../es/style/base.css'); + } + return path.join(__dirname, `../es/${component}/index.css`); +} + +function getStyleRelativePath(component, style) { + return path.relative( + path.join(__dirname, `../es/${component}/style`), + getStylePath(style) ); } + +function checkComponentHasStyle(component) { + return fs.existsSync(getStylePath(component)); +} diff --git a/build/build-style.js b/build/build-style.js new file mode 100644 index 000000000..1621fbe95 --- /dev/null +++ b/build/build-style.js @@ -0,0 +1,16 @@ +const gulp = require('gulp'); +const less = require('gulp-less'); +const postcss = require('gulp-postcss'); +const cssmin = require('gulp-clean-css'); + +// compile component css +gulp.task('compile', () => { + return gulp + .src(['../es/**/*.less', '../lib/**/*.less']) + .pipe(less()) + .pipe(postcss()) + .pipe(cssmin()) + .pipe(gulp.dest(file => file.base.replace('.less', '.css'))); +}); + +gulp.task('default', ['compile']); diff --git a/build/get-components.js b/build/get-components.js index 62a7483a4..3476940b5 100644 --- a/build/get-components.js +++ b/build/get-components.js @@ -1,8 +1,16 @@ const fs = require('fs'); const path = require('path'); +const excludes = [ + 'index.js', + 'index.less', + 'style', + 'mixins', + 'utils', + '.DS_Store' +]; + module.exports = function() { const dirs = fs.readdirSync(path.resolve(__dirname, '../packages')); - const excludes = ['index.js', 'vant-css', 'mixins', 'utils', '.DS_Store']; return dirs.filter(dirName => excludes.indexOf(dirName) === -1); }; diff --git a/build/release.sh b/build/release.sh index 16dc48d66..98b9246b1 100644 --- a/build/release.sh +++ b/build/release.sh @@ -14,13 +14,6 @@ then npm version $VERSION --no-git-tag-version VERSION=$VERSION npm run build:lib - # publish vant-css - echo "Releasing vant-css $VERSION ..." - cd packages/vant-css - npm version $VERSION - npm publish - cd ../.. - # commit git tag v$VERSION git commit -am "[release] $VERSION" diff --git a/build/webpack.dev.js b/build/webpack.dev.js index e853a6434..41a5c9089 100644 --- a/build/webpack.dev.js +++ b/build/webpack.dev.js @@ -56,11 +56,12 @@ module.exports = { use: 'babel-loader' }, { - test: /\.(css|postcss)$/, + test: /\.less$/, use: [ 'style-loader', 'css-loader', - 'postcss-loader' + 'postcss-loader', + 'less-loader' ] }, { diff --git a/docs/markdown/changelog.en-US.md b/docs/markdown/changelog.en-US.md index 3e888def8..0babb1af0 100644 --- a/docs/markdown/changelog.en-US.md +++ b/docs/markdown/changelog.en-US.md @@ -339,7 +339,7 @@ - fix Progress text empty [\#1411](https://github.com/youzan/vant/pull/1411) - fix Tab random insert order [\#1429](https://github.com/youzan/vant/pull/1429) - fix error when use Vue.use in typescript [\#1410](https://github.com/youzan/vant/pull/1410) -- fix vant-css missing dependencies [\#1426](https://github.com/youzan/vant/pull/1426) +- fix style missing dependencies [\#1426](https://github.com/youzan/vant/pull/1426) ## [v1.1.11](https://github.com/youzan/vant/tree/v1.1.11) @@ -1332,7 +1332,7 @@ **Breaking changes** -* remove reset.css in vant-css [\#192](https://github.com/youzan/vant/issues/192) [\#196](https://github.com/youzan/vant/pull/196) +* remove reset.css in style [\#192](https://github.com/youzan/vant/issues/192) [\#196](https://github.com/youzan/vant/pull/196) * reconstruct Swipe component, adjust some API [#174](https://github.com/youzan/vant/issues/174) [#180](https://github.com/youzan/vant/issues/180) [\#194](https://github.com/youzan/vant/pull/194) [\#200](https://github.com/youzan/vant/pull/200) * optimize Search component,adjust struct [\#198](https://github.com/youzan/vant/pull/198) @@ -1388,7 +1388,7 @@ * fix Button active border color [\#150](https://github.com/youzan/vant/issues/150) * fix Stepper input style [\#159](https://github.com/youzan/vant/pull/159) * fix Waterfall disable props not work when display none [\#166](https://github.com/youzan/vant/pull/166) -* fix vant-css not compile calc property after build +* fix style not compile calc property after build * fix npm run dev error in MacOS [\#152](https://github.com/youzan/vant/issues/152) * fix document router not work in some browsers [\#158](https://github.com/youzan/vant/pull/158) diff --git a/docs/markdown/changelog.zh-CN.md b/docs/markdown/changelog.zh-CN.md index c0433de99..377305ae7 100644 --- a/docs/markdown/changelog.zh-CN.md +++ b/docs/markdown/changelog.zh-CN.md @@ -339,7 +339,7 @@ - 修复 Progress 文字为空时样式错误的问题 [\#1411](https://github.com/youzan/vant/pull/1411) - 修复 Tab 同时进行插入和删除时顺序错误的问题 [\#1429](https://github.com/youzan/vant/pull/1429) - 修复 Vue.use 方法 TypeScript 类型错误 [\#1410](https://github.com/youzan/vant/pull/1410) -- 修复 vant-css 依赖丢失 [\#1426](https://github.com/youzan/vant/pull/1426) +- 修复 style 依赖丢失 [\#1426](https://github.com/youzan/vant/pull/1426) ## [v1.1.11](https://github.com/youzan/vant/tree/v1.1.11) @@ -1325,7 +1325,7 @@ **Breaking changes** -* 移除 vant-css 中对 reset.css 的默认引用 [\#192](https://github.com/youzan/vant/issues/192) [\#196](https://github.com/youzan/vant/pull/196) +* 移除 style 中对 reset.css 的默认引用 [\#192](https://github.com/youzan/vant/issues/192) [\#196](https://github.com/youzan/vant/pull/196) * 重写 Swipe 组件,调整部分 API [#174](https://github.com/youzan/vant/issues/174) [#180](https://github.com/youzan/vant/issues/180) [\#194](https://github.com/youzan/vant/pull/194) [\#200](https://github.com/youzan/vant/pull/200) * 优化 Search 组件,修改原有结构 [\#198](https://github.com/youzan/vant/pull/198) @@ -1381,7 +1381,7 @@ * 修复 Button active 状态下边框样式问题 [\#150](https://github.com/youzan/vant/issues/150) * 修复 Stepper 组件输入框样式错误 [\#159](https://github.com/youzan/vant/pull/159) * 修复 Waterfall 未显示时 disable 属性无法生效的问题 [\#166](https://github.com/youzan/vant/pull/166) -* 修复 vant-css 构建过程中未编译 calc 属性的问题 +* 修复 style 构建过程中未编译 calc 属性的问题 * 修复 MacOS 下 npm run dev 报错的问题 [\#152](https://github.com/youzan/vant/issues/152) * 修复文档在部分低版本浏览器路由失效的问题 [\#158](https://github.com/youzan/vant/pull/158) * 修复文档中遗漏 SwipeItem 组件引入方式的问题 [\#167](https://github.com/youzan/vant/pull/167) diff --git a/docs/markdown/contribution.zh-CN.md b/docs/markdown/contribution.zh-CN.md index ebdc6e822..139922d60 100644 --- a/docs/markdown/contribution.zh-CN.md +++ b/docs/markdown/contribution.zh-CN.md @@ -34,7 +34,6 @@ npm run dev ### 目录结构 - 仓库的组件代码位于 packages 下,每个组件一个文件夹 -- 组件样式代码位于 packages/vant-css/src 下,vant-css 也会在发布时单独发包 - docs 目录下是文档网站的代码,本地开发时可以在目录下运行 npm run dev 开启文档网站 项目目录大致如下: @@ -59,10 +58,11 @@ packages | ├─ test # 单元测试 | ├─ zh-CN.md # 中文文档 | ├─ en-US.md # 英文文档 +| ├─ index.less # 组件样式 | └─ index.vue # 组件入口 -└─ vant-css - ├─ index.css # 样式入口 - └─ button.css # 组件样式 +| +├─ index.js # 所有组件入口 +└─ index.less # 所有组件样式 ``` ### 组件文档 diff --git a/docs/markdown/quickstart.en-US.md b/docs/markdown/quickstart.en-US.md index 901edf0f6..73a9c0a1f 100644 --- a/docs/markdown/quickstart.en-US.md +++ b/docs/markdown/quickstart.en-US.md @@ -41,7 +41,7 @@ yarn add vant ```html - + @@ -94,8 +94,7 @@ import { Button } from 'vant'; ```js import Button from 'vant/lib/button'; -import 'vant/lib/vant-css/base.css'; -import 'vant/lib/vant-css/button.css'; +import 'vant/lib/button/style'; ``` #### 3. Import all components @@ -103,7 +102,7 @@ import 'vant/lib/vant-css/button.css'; ```js import Vue from 'vue'; import Vant from 'vant'; -import 'vant/lib/vant-css/index.css'; +import 'vant/lib/index.css'; Vue.use(Vant); ``` diff --git a/docs/markdown/quickstart.zh-CN.md b/docs/markdown/quickstart.zh-CN.md index 273fcc10c..f1a4a7fb3 100644 --- a/docs/markdown/quickstart.zh-CN.md +++ b/docs/markdown/quickstart.zh-CN.md @@ -47,7 +47,7 @@ yarn add vant ```html - + @@ -104,8 +104,7 @@ import { Button, Cell } from 'vant'; ```js import Button from 'vant/lib/button'; -import 'vant/lib/vant-css/base.css'; -import 'vant/lib/vant-css/button.css'; +import 'vant/lib/button/style'; ``` #### 方式三. 导入所有组件 @@ -113,7 +112,7 @@ import 'vant/lib/vant-css/button.css'; ```js import Vue from 'vue'; import Vant from 'vant'; -import 'vant/lib/vant-css/index.css'; +import 'vant/lib/index.css'; Vue.use(Vant); ``` diff --git a/docs/markdown/theme.en-US.md b/docs/markdown/theme.en-US.md index c144975e1..a1c310234 100644 --- a/docs/markdown/theme.en-US.md +++ b/docs/markdown/theme.en-US.md @@ -7,14 +7,14 @@ You can import the postcss source code in your own project, then use [postcss-th ```javascript // import base style -import 'vant/packages/vant-css/src/base.css'; +import 'vant/packages/style/base.css'; // import component style -import 'vant/packages/vant-css/src/button.css'; -import 'vant/packages/vant-css/src/checkbox.css'; +import 'vant/packages/button/index.css'; +import 'vant/packages/checkbox/index.css'; ``` -Then require the plugin in the postcss.config.js, and configure the variables according to project needs, you can view all the available variables in [profile](https://github.com/youzan/vant/blob/dev/packages/vant-css/src/common/var.css). +Then require the plugin in the postcss.config.js, and configure the variables according to project needs, you can view all the available variables in [profile](https://github.com/youzan/vant/blob/dev/packages/style/var.less). ```javascript module.exports = { @@ -45,10 +45,10 @@ Vant also support local build to custom themes. ```bash # Clone the repository git clone git@github.com:youzan/vant.git -cd packages/vant-css +cd packages/style ``` -In the local vant-css repository, modify the variables in src/common/var.css, then execute the following build command to generate the style file. +In the local style repository, modify the variables in src/var.less, then execute the following build command to generate the style file. ```bash npm run build ``` diff --git a/docs/markdown/theme.zh-CN.md b/docs/markdown/theme.zh-CN.md index cfdccdac2..398681b63 100644 --- a/docs/markdown/theme.zh-CN.md +++ b/docs/markdown/theme.zh-CN.md @@ -7,14 +7,14 @@ ```javascript // 引入基础样式 -import 'vant/packages/vant-css/src/base.css'; +import 'vant/packages/style/base.css'; // 引入组件对应的样式 -import 'vant/packages/vant-css/src/button.css'; -import 'vant/packages/vant-css/src/checkbox.css'; +import 'vant/packages/style/button/index.css'; +import 'vant/packages/style/checkbox/index.css'; ``` -接着在 postcss.config.js 中引入所需的 postcss 插件,并根据项目需求配置颜色变量,所有可用的颜色变量请参考 [配置文件](https://github.com/youzan/vant/blob/dev/packages/vant-css/src/common/var.css) +接着在 postcss.config.js 中引入所需的 postcss 插件,并根据项目需求配置颜色变量,所有可用的颜色变量请参考 [配置文件](https://github.com/youzan/vant/blob/dev/packages/style/var.less) ```javascript module.exports = { @@ -37,15 +37,15 @@ module.exports = { ``` ### 方案二. 本地构建 -可以通过在本地构建 vant-css 的方式生成所需的主题 +可以通过在本地构建 style 的方式生成所需的主题 ```bash # 克隆仓库 git clone git@github.com:youzan/vant.git -cd packages/vant-css +cd packages/style ``` -在本地 vant-css 仓库中,修改 src/common/var.css 中的颜色变量,然后执行以下构建命令,即可生成对应的样式文件 +在本地 style 仓库中,修改 src/var.less 中的颜色变量,然后执行以下构建命令,即可生成对应的样式文件 ```bash npm run build ``` diff --git a/docs/src/DocsApp.vue b/docs/src/DocsApp.vue index 6a8059bae..394bd9b91 100644 --- a/docs/src/DocsApp.vue +++ b/docs/src/DocsApp.vue @@ -46,7 +46,7 @@ export default { }; - diff --git a/packages/vant-css/src/field.css b/packages/field/index.less similarity index 89% rename from packages/vant-css/src/field.css rename to packages/field/index.less index f5f4beddf..a0cbbe671 100644 --- a/packages/vant-css/src/field.css +++ b/packages/field/index.less @@ -1,4 +1,4 @@ -@import './common/var.css'; +@import '../style/var'; .van-field { .van-cell__title { @@ -22,7 +22,7 @@ &:disabled { opacity: 1; - color: $gray-darker; + color: @gray-darker; background-color: transparent; } @@ -55,14 +55,14 @@ } &__clear { - color: $gray; + color: @gray; font-size: 16px; } &__icon .van-icon { display: block; font-size: 16px; - color: $gray-dark; + color: @gray-dark; line-height: inherit; } @@ -71,14 +71,14 @@ } &__error-message { - color: $red; + color: @red; font-size: 12px; text-align: left; } &--disabled { .van-field__control { - color: $gray-dark; + color: @gray-dark; } } @@ -86,7 +86,7 @@ .van-field__control { &, &::placeholder { - color: $red; + color: @red; } } } diff --git a/packages/goods-action-big-btn/index.less b/packages/goods-action-big-btn/index.less new file mode 100644 index 000000000..3b69930be --- /dev/null +++ b/packages/goods-action-big-btn/index.less @@ -0,0 +1,10 @@ +@import '../style/var'; + +.van-goods-action-big-btn { + flex: 1; + padding: 0; + + @media (max-width: 321px) { + font-size: 15px; + } +} diff --git a/packages/goods-action-mini-btn/index.less b/packages/goods-action-mini-btn/index.less new file mode 100644 index 000000000..ae350ffd4 --- /dev/null +++ b/packages/goods-action-mini-btn/index.less @@ -0,0 +1,32 @@ +@import '../style/var'; + +.van-goods-action-mini-btn { + color: @gray-darker; + display: flex; + height: 50px; + font-size: 10px; + min-width: 15%; + line-height: 1; + text-align: center; + background-color: @white; + flex-direction: column; + justify-content: center; + + &::after { + border-width: 1px 0 0 1px; + } + + &:first-child::after { + border-left-width: 0; + } + + &:active { + background-color: @active-color; + } + + &__icon { + width: 1em; + font-size: 20px; + margin: 0 auto 5px; + } +} diff --git a/packages/goods-action/demo/index.vue b/packages/goods-action/demo/index.vue index 0ca7cee42..d97c0683f 100644 --- a/packages/goods-action/demo/index.vue +++ b/packages/goods-action/demo/index.vue @@ -58,7 +58,7 @@ export default { }; -