[Doc] temporary remove some components

This commit is contained in:
陈嘉涵 2018-08-09 21:15:18 +08:00
parent 28b95839d4
commit cbe9eb27d6
128 changed files with 100 additions and 4132 deletions

View File

@ -1,5 +1,5 @@
const path = require('path');
const extracter = require('./utils/extracter');
const extracter = require('./extracter');
extracter({
src: path.resolve(__dirname, '../packages'),

View File

@ -6,7 +6,8 @@ const { VueLoaderPlugin } = require('vue-loader');
module.exports = {
mode: 'development',
entry: {
'vant-docs': './docs/src/index.js'
'vant-docs': './docs/src/index.js',
'vant-preview': './docs/src/preview.js'
},
output: {
path: path.join(__dirname, '../docs/dist'),
@ -82,6 +83,12 @@ module.exports = {
template: 'docs/src/index.tpl',
filename: 'index.html',
inject: true
}),
new HtmlWebpackPlugin({
chunks: ['vant-preview'],
template: 'docs/src/index.tpl',
filename: 'preview.html',
inject: true
})
]
};

View File

@ -37,39 +37,29 @@ module.exports = Behavior({
methods: {
bindgetuserinfo: function bindgetuserinfo() {
var _ref = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {},
_ref$detail = _ref.detail,
detail = _ref$detail === undefined ? {} : _ref$detail;
var event = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};
this.triggerEvent('getuserinfo', detail);
this.triggerEvent('getuserinfo', event.detail || {});
},
bindcontact: function bindcontact() {
var _ref2 = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {},
_ref2$detail = _ref2.detail,
detail = _ref2$detail === undefined ? {} : _ref2$detail;
var event = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};
this.triggerEvent('contact', detail);
this.triggerEvent('contact', event.detail || {});
},
bindgetphonenumber: function bindgetphonenumber() {
var _ref3 = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {},
_ref3$detail = _ref3.detail,
detail = _ref3$detail === undefined ? {} : _ref3$detail;
var event = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};
this.triggerEvent('getphonenumber', detail);
this.triggerEvent('getphonenumber', event.detail || {});
},
bindopensetting: function bindopensetting() {
var _ref4 = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {},
_ref4$detail = _ref4.detail,
detail = _ref4$detail === undefined ? {} : _ref4$detail;
var event = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};
this.triggerEvent('opensetting', detail);
this.triggerEvent('opensetting', event.detail || {});
},
binderror: function binderror() {
var _ref5 = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {},
_ref5$detail = _ref5.detail,
detail = _ref5$detail === undefined ? {} : _ref5$detail;
var event = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};
this.triggerEvent('error', detail);
this.triggerEvent('error', event.detail || {});
}
}
});

View File

@ -1 +1 @@
.van-ellipsis{overflow:hidden;white-space:nowrap;text-overflow:ellipsis}.van-clearfix::after{content:'';display:table;clear:both}.van-hairline,.van-hairline--bottom,.van-hairline--left,.van-hairline--right,.van-hairline--surround,.van-hairline--top,.van-hairline--top-bottom{position:relative}.van-hairline--bottom::after,.van-hairline--left::after,.van-hairline--right::after,.van-hairline--surround::after,.van-hairline--top-bottom::after,.van-hairline--top::after,.van-hairline::after{content:'';position:absolute;top:0;left:0;width:200%;height:200%;-webkit-transform:scale(.5);transform:scale(.5);-webkit-transform-origin:0 0;transform-origin:0 0;pointer-events:none;box-sizing:border-box;border:0 solid #e5e5e5}.van-hairline--top::after{border-top-width:1px}.van-hairline--left::after{border-left-width:1px}.van-hairline--right::after{border-right-width:1px}.van-hairline--bottom::after{border-bottom-width:1px}.van-hairline--top-bottom::after{border-width:1px 0}.van-hairline--surround::after{border-width:1px}@-webkit-keyframes van-slide-bottom-enter{from{-webkit-transform:translate3d(0,100%,0);transform:translate3d(0,100%,0)}}@keyframes van-slide-bottom-enter{from{-webkit-transform:translate3d(0,100%,0);transform:translate3d(0,100%,0)}}@-webkit-keyframes van-slide-bottom-leave{to{-webkit-transform:translate3d(0,100%,0);transform:translate3d(0,100%,0)}}@keyframes van-slide-bottom-leave{to{-webkit-transform:translate3d(0,100%,0);transform:translate3d(0,100%,0)}}@-webkit-keyframes van-fade-in{from{opacity:0}to{opacity:1}}@keyframes van-fade-in{from{opacity:0}to{opacity:1}}@-webkit-keyframes van-fade-out{from{opacity:1}to{opacity:0}}@keyframes van-fade-out{from{opacity:1}to{opacity:0}}@-webkit-keyframes van-rotate{from{-webkit-transform:rotate(0);transform:rotate(0)}to{-webkit-transform:rotate(360deg);transform:rotate(360deg)}}@keyframes van-rotate{from{-webkit-transform:rotate(0);transform:rotate(0)}to{-webkit-transform:rotate(360deg);transform:rotate(360deg)}}.van-fade-enter-active{-webkit-animation:.3s van-fade-in;animation:.3s van-fade-in}.van-fade-leave-active{-webkit-animation:.3s van-fade-out;animation:.3s van-fade-out}.van-slide-bottom-enter-active{-webkit-animation:van-slide-bottom-enter .3s both ease;animation:van-slide-bottom-enter .3s both ease}.van-slide-bottom-leave-active{-webkit-animation:van-slide-bottom-leave .3s both ease;animation:van-slide-bottom-leave .3s both ease}.van-card{color:#333;height:100px;font-size:16px;background:#fafafa;position:relative;box-sizing:border-box;padding:5px 15px 5px 115px}.van-card--center,.van-card__thumb{-webkit-box-align:center;align-items:center;-webkit-box-pack:center;justify-content:center}.van-card__thumb{top:5px;left:15px;width:90px;height:90px;position:absolute}.van-card__img{border:none;max-width:100%;max-height:100%}.van-card,.van-card__row,.van-card__thumb{display:-webkit-box;display:flex}.van-card__content{width:100%}.van-card__content--center{height:90px;-webkit-box-align:center;align-items:center}.van-card__desc,.van-card__title{line-height:20px;word-break:break-all}.van-card__title{max-height:40px;overflow:hidden;text-overflow:ellipsis;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical}.van-card__desc{color:#666;font-size:12px;max-height:20px;overflow:hidden;white-space:nowrap;text-overflow:ellipsis}.van-card__num,.van-card__price{-webkit-box-flex:1;flex:1;min-width:80px;line-height:20px;text-align:right}.van-card__price{font-size:14px}.van-card__num{color:#666;font-size:12px}.van-card__footer{right:15px;bottom:5px;position:absolute}.van-card__footer .van-button{margin-left:5px}
.van-ellipsis{overflow:hidden;white-space:nowrap;text-overflow:ellipsis}.van-clearfix::after{content:'';display:table;clear:both}.van-hairline,.van-hairline--bottom,.van-hairline--left,.van-hairline--right,.van-hairline--surround,.van-hairline--top,.van-hairline--top-bottom{position:relative}.van-hairline--bottom::after,.van-hairline--left::after,.van-hairline--right::after,.van-hairline--surround::after,.van-hairline--top-bottom::after,.van-hairline--top::after,.van-hairline::after{content:'';position:absolute;top:0;left:0;width:200%;height:200%;-webkit-transform:scale(.5);transform:scale(.5);-webkit-transform-origin:0 0;transform-origin:0 0;pointer-events:none;box-sizing:border-box;border:0 solid #e5e5e5}.van-hairline--top::after{border-top-width:1px}.van-hairline--left::after{border-left-width:1px}.van-hairline--right::after{border-right-width:1px}.van-hairline--bottom::after{border-bottom-width:1px}.van-hairline--top-bottom::after{border-width:1px 0}.van-hairline--surround::after{border-width:1px}@-webkit-keyframes van-slide-bottom-enter{from{-webkit-transform:translate3d(0,100%,0);transform:translate3d(0,100%,0)}}@keyframes van-slide-bottom-enter{from{-webkit-transform:translate3d(0,100%,0);transform:translate3d(0,100%,0)}}@-webkit-keyframes van-slide-bottom-leave{to{-webkit-transform:translate3d(0,100%,0);transform:translate3d(0,100%,0)}}@keyframes van-slide-bottom-leave{to{-webkit-transform:translate3d(0,100%,0);transform:translate3d(0,100%,0)}}@-webkit-keyframes van-fade-in{from{opacity:0}to{opacity:1}}@keyframes van-fade-in{from{opacity:0}to{opacity:1}}@-webkit-keyframes van-fade-out{from{opacity:1}to{opacity:0}}@keyframes van-fade-out{from{opacity:1}to{opacity:0}}@-webkit-keyframes van-rotate{from{-webkit-transform:rotate(0);transform:rotate(0)}to{-webkit-transform:rotate(360deg);transform:rotate(360deg)}}@keyframes van-rotate{from{-webkit-transform:rotate(0);transform:rotate(0)}to{-webkit-transform:rotate(360deg);transform:rotate(360deg)}}.van-fade-enter-active{-webkit-animation:.3s van-fade-in;animation:.3s van-fade-in}.van-fade-leave-active{-webkit-animation:.3s van-fade-out;animation:.3s van-fade-out}.van-slide-bottom-enter-active{-webkit-animation:van-slide-bottom-enter .3s both ease;animation:van-slide-bottom-enter .3s both ease}.van-slide-bottom-leave-active{-webkit-animation:van-slide-bottom-leave .3s both ease;animation:van-slide-bottom-leave .3s both ease}.van-card{color:#333;height:100px;font-size:16px;background:#fafafa;position:relative;box-sizing:border-box;padding:5px 15px 5px 115px}.van-card--center,.van-card__thumb{-webkit-box-align:center;-webkit-align-items:center;align-items:center;-webkit-box-pack:center;-webkit-justify-content:center;justify-content:center}.van-card__thumb{top:5px;left:15px;width:90px;height:90px;position:absolute}.van-card__img{border:none;max-width:100%;max-height:100%}.van-card,.van-card__row,.van-card__thumb{display:-webkit-box;display:-webkit-flex;display:flex}.van-card__content{width:100%}.van-card__content--center{height:90px;-webkit-box-align:center;-webkit-align-items:center;align-items:center}.van-card__desc,.van-card__title{line-height:20px;word-break:break-all}.van-card__title{max-height:40px;overflow:hidden;text-overflow:ellipsis;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical}.van-card__desc{color:#666;font-size:12px;max-height:20px;overflow:hidden;white-space:nowrap;text-overflow:ellipsis}.van-card__num,.van-card__price{-webkit-box-flex:1;-webkit-flex:1;flex:1;min-width:80px;line-height:20px;text-align:right}.van-card__price{font-size:14px}.van-card__num{color:#666;font-size:12px}.van-card__footer{right:15px;bottom:5px;position:absolute}.van-card__footer .van-button{margin-left:5px}

View File

@ -1 +1 @@
.van-ellipsis{overflow:hidden;white-space:nowrap;text-overflow:ellipsis}.van-clearfix::after{content:'';display:table;clear:both}.van-hairline,.van-hairline--bottom,.van-hairline--left,.van-hairline--right,.van-hairline--surround,.van-hairline--top,.van-hairline--top-bottom{position:relative}.van-hairline--bottom::after,.van-hairline--left::after,.van-hairline--right::after,.van-hairline--surround::after,.van-hairline--top-bottom::after,.van-hairline--top::after,.van-hairline::after{content:'';position:absolute;top:0;left:0;width:200%;height:200%;-webkit-transform:scale(.5);transform:scale(.5);-webkit-transform-origin:0 0;transform-origin:0 0;pointer-events:none;box-sizing:border-box;border:0 solid #e5e5e5}.van-hairline--top::after{border-top-width:1px}.van-hairline--left::after{border-left-width:1px}.van-hairline--right::after{border-right-width:1px}.van-hairline--bottom::after{border-bottom-width:1px}.van-hairline--top-bottom::after{border-width:1px 0}.van-hairline--surround::after{border-width:1px}@-webkit-keyframes van-slide-bottom-enter{from{-webkit-transform:translate3d(0,100%,0);transform:translate3d(0,100%,0)}}@keyframes van-slide-bottom-enter{from{-webkit-transform:translate3d(0,100%,0);transform:translate3d(0,100%,0)}}@-webkit-keyframes van-slide-bottom-leave{to{-webkit-transform:translate3d(0,100%,0);transform:translate3d(0,100%,0)}}@keyframes van-slide-bottom-leave{to{-webkit-transform:translate3d(0,100%,0);transform:translate3d(0,100%,0)}}@-webkit-keyframes van-fade-in{from{opacity:0}to{opacity:1}}@keyframes van-fade-in{from{opacity:0}to{opacity:1}}@-webkit-keyframes van-fade-out{from{opacity:1}to{opacity:0}}@keyframes van-fade-out{from{opacity:1}to{opacity:0}}@-webkit-keyframes van-rotate{from{-webkit-transform:rotate(0);transform:rotate(0)}to{-webkit-transform:rotate(360deg);transform:rotate(360deg)}}@keyframes van-rotate{from{-webkit-transform:rotate(0);transform:rotate(0)}to{-webkit-transform:rotate(360deg);transform:rotate(360deg)}}.van-fade-enter-active{-webkit-animation:.3s van-fade-in;animation:.3s van-fade-in}.van-fade-leave-active{-webkit-animation:.3s van-fade-out;animation:.3s van-fade-out}.van-slide-bottom-enter-active{-webkit-animation:van-slide-bottom-enter .3s both ease;animation:van-slide-bottom-enter .3s both ease}.van-slide-bottom-leave-active{-webkit-animation:van-slide-bottom-leave .3s both ease;animation:van-slide-bottom-leave .3s both ease}.van-cell{width:100%;display:-webkit-box;display:flex;padding:10px 15px;box-sizing:border-box;line-height:24px;position:relative;background-color:#fff;color:#333;font-size:14px}.van-cell::after{left:15px;right:0;width:auto;-webkit-transform:scale(1,.5);transform:scale(1,.5);border-bottom-width:1px}.van-cell-group{background-color:#fff}.van-cell__label{font-size:12px;line-height:1.2;color:#666}.van-cell__title,.van-cell__value{-webkit-box-flex:1;flex:1}.van-cell__value{overflow:hidden;text-align:right;vertical-align:middle}.van-cell__left-icon{font-size:16px;line-height:24px;margin-right:5px;vertical-align:middle}.van-cell__right-icon{color:#999;font-size:12px;line-height:24px;margin-left:5px}.van-cell__right-icon--left::before{-webkit-transform:rotate(180deg);transform:rotate(180deg)}.van-cell__right-icon--up::before{-webkit-transform:rotate(-90deg);transform:rotate(-90deg)}.van-cell__right-icon--down::before{-webkit-transform:rotate(90deg);transform:rotate(90deg)}.van-cell--tapable:active{background-color:#e8e8e8}.van-cell--required{overflow:visible}.van-cell--required::before{content:'*';position:absolute;left:7px;font-size:14px;color:#f44}.van-cell--center{-webkit-box-align:center;align-items:center}
.van-ellipsis{overflow:hidden;white-space:nowrap;text-overflow:ellipsis}.van-clearfix::after{content:'';display:table;clear:both}.van-hairline,.van-hairline--bottom,.van-hairline--left,.van-hairline--right,.van-hairline--surround,.van-hairline--top,.van-hairline--top-bottom{position:relative}.van-hairline--bottom::after,.van-hairline--left::after,.van-hairline--right::after,.van-hairline--surround::after,.van-hairline--top-bottom::after,.van-hairline--top::after,.van-hairline::after{content:'';position:absolute;top:0;left:0;width:200%;height:200%;-webkit-transform:scale(.5);transform:scale(.5);-webkit-transform-origin:0 0;transform-origin:0 0;pointer-events:none;box-sizing:border-box;border:0 solid #e5e5e5}.van-hairline--top::after{border-top-width:1px}.van-hairline--left::after{border-left-width:1px}.van-hairline--right::after{border-right-width:1px}.van-hairline--bottom::after{border-bottom-width:1px}.van-hairline--top-bottom::after{border-width:1px 0}.van-hairline--surround::after{border-width:1px}@-webkit-keyframes van-slide-bottom-enter{from{-webkit-transform:translate3d(0,100%,0);transform:translate3d(0,100%,0)}}@keyframes van-slide-bottom-enter{from{-webkit-transform:translate3d(0,100%,0);transform:translate3d(0,100%,0)}}@-webkit-keyframes van-slide-bottom-leave{to{-webkit-transform:translate3d(0,100%,0);transform:translate3d(0,100%,0)}}@keyframes van-slide-bottom-leave{to{-webkit-transform:translate3d(0,100%,0);transform:translate3d(0,100%,0)}}@-webkit-keyframes van-fade-in{from{opacity:0}to{opacity:1}}@keyframes van-fade-in{from{opacity:0}to{opacity:1}}@-webkit-keyframes van-fade-out{from{opacity:1}to{opacity:0}}@keyframes van-fade-out{from{opacity:1}to{opacity:0}}@-webkit-keyframes van-rotate{from{-webkit-transform:rotate(0);transform:rotate(0)}to{-webkit-transform:rotate(360deg);transform:rotate(360deg)}}@keyframes van-rotate{from{-webkit-transform:rotate(0);transform:rotate(0)}to{-webkit-transform:rotate(360deg);transform:rotate(360deg)}}.van-fade-enter-active{-webkit-animation:.3s van-fade-in;animation:.3s van-fade-in}.van-fade-leave-active{-webkit-animation:.3s van-fade-out;animation:.3s van-fade-out}.van-slide-bottom-enter-active{-webkit-animation:van-slide-bottom-enter .3s both ease;animation:van-slide-bottom-enter .3s both ease}.van-slide-bottom-leave-active{-webkit-animation:van-slide-bottom-leave .3s both ease;animation:van-slide-bottom-leave .3s both ease}.van-cell{width:100%;display:-webkit-box;display:-webkit-flex;display:flex;padding:10px 15px;box-sizing:border-box;line-height:24px;position:relative;background-color:#fff;color:#333;font-size:14px}.van-cell::after{left:15px;right:0;width:auto;-webkit-transform:scale(1,.5);transform:scale(1,.5);border-bottom-width:1px}.van-cell-group{background-color:#fff}.van-cell__label{font-size:12px;line-height:1.2;color:#666}.van-cell__title,.van-cell__value{-webkit-box-flex:1;-webkit-flex:1;flex:1}.van-cell__value{overflow:hidden;text-align:right;vertical-align:middle}.van-cell__left-icon{font-size:16px;line-height:24px;margin-right:5px;vertical-align:middle}.van-cell__right-icon{color:#999;font-size:12px;line-height:24px;margin-left:5px}.van-cell__right-icon--left::before{-webkit-transform:rotate(180deg);transform:rotate(180deg)}.van-cell__right-icon--up::before{-webkit-transform:rotate(-90deg);transform:rotate(-90deg)}.van-cell__right-icon--down::before{-webkit-transform:rotate(90deg);transform:rotate(90deg)}.van-cell--tapable:active{background-color:#e8e8e8}.van-cell--required{overflow:visible}.van-cell--required::before{content:'*';position:absolute;left:7px;font-size:14px;color:#f44}.van-cell--center{-webkit-box-align:center;-webkit-align-items:center;align-items:center}

View File

@ -1,29 +0,0 @@
'use strict';
var _relations;
var CHECKBOX_PATH = '../checkbox/index';
Component({
relations: (_relations = {}, _relations[CHECKBOX_PATH] = {
type: 'child',
linked: function linked() {
this.updateChildren(CHECKBOX_PATH);
}
}, _relations),
data: {
elementUpdateTimeout: 0
},
methods: {
updateChildren: function updateChildren(childPath) {
// 把checkbox标记为在group中设置不同样式
var elements = this.getRelationNodes(childPath);
elements.forEach(function (checkbox, index) {
checkbox.updateData({ isInGroup: true });
});
}
}
});

View File

@ -1,3 +0,0 @@
{
"component": true
}

View File

@ -1,3 +0,0 @@
<view class="checkbox-group">
<slot></slot>
</view>

View File

@ -1 +0,0 @@
.checkbox-group{padding-bottom:10px;background-color:#fff}.checkbox-group .van-checkbox{margin-top:10px}

View File

@ -1,44 +0,0 @@
'use strict';
var _relations;
var CHECKBOX_GROUP_PATH = '../checkbox-group/index';
Component({
externalClasses: ['checkbox-class'],
relations: (_relations = {}, _relations[CHECKBOX_GROUP_PATH] = {
type: 'parent'
}, _relations),
properties: {
checked: Boolean,
disabled: Boolean,
isInGroup: Boolean,
labelDisabled: Boolean,
type: String
},
data: function data() {
return {
isInGroup: false,
isInCell: false
};
},
methods: {
handleClick: function handleClick() {
if (this.data.disabled) {
return;
}
var checked = !this.data.checked;
this.triggerEvent('change', checked);
this.setData({ checked: checked });
},
updateData: function updateData(data) {
this.setData(data);
}
}
});

View File

@ -1,6 +0,0 @@
{
"component": true,
"usingComponents": {
"van-icon": "../icon/index"
}
}

View File

@ -1,13 +0,0 @@
<view
class="checkbox-class van-checkbox {{ isInGroup ? 'van-checkbox__item' : ''}} {{ type === 'list' ? 'van-checkbox__list-item' : ''}}"
bindtap="{{ labelDisabled ? '' : 'handleClick' }}"
>
<van-icon
type="{{ checked ? 'checked' : 'check'}}"
class="van-checkbox__icon {{ disabled ? 'van-checkbox--disabled' : '' }} {{ checked ? 'van-checkbox--checked' : '' }}"
bindtap="{{ labelDisabled ? 'handleClick': '' }}"
></van-icon>
<text class="van-checkbox__label">
<slot></slot>
</text>
</view>

View File

@ -1 +0,0 @@
.van-checkbox{display:inline-block;padding:0 10px;font-size:14px}.van-checkbox__item{display:block;margin-top:10px}.van-checkbox__list-item{display:block;padding:10px 10px 10px 0;margin-left:10px;border-bottom:1px solid #e5e5e5}.van-checkbox__list-item .van-checkbox__icon{float:right}.van-checkbox__icon{display:-webkit-inline-box;display:inline-flex;-webkit-box-align:center;align-items:center;color:#aaa}.van-checkbox__icon.van-checkbox--checked{color:#06bf04}.van-checkbox__icon.van-checkbox--disabled{color:#e5e5e5}.van-checkbox__label{display:inline-block;margin-left:10px}

102
dist/common/helper.js vendored
View File

@ -1,102 +0,0 @@
'use strict';
// 从事件对象中解析得到 componentId
// 需要在元素上声明 data-component-id
function extractComponentId() {
var event = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};
var _ref = event.currentTarget || {},
componentId = _ref.dataset.componentId;
return componentId;
}
/*
默认合并所有生命周期函数
配置合并指定的生命周期 or 忽略指定字段
const extend = extendCreator({
life: ['onLoad', 'onPullDownRefresh'],
exclude: ['binder']
});
Page(extend({}, {
onLoad() {},
...
}));
*/
var LIFE_CYCLE = ['onLoad', 'onReady', 'onShow', 'onHide', 'onUnload', 'onPullDownRefresh', 'onReachBottom', 'onShareAppMessage', 'onPageScroll'];
var extendCreator = function extendCreator() {
var config = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};
var _config$life = config.life,
life = _config$life === undefined ? LIFE_CYCLE : _config$life,
_config$exclude = config.exclude,
exclude = _config$exclude === undefined ? [] : _config$exclude;
var excludeList = exclude.concat(LIFE_CYCLE.map(getFuncArrayName));
if (!Array.isArray(life) || !Array.isArray(exclude)) throw new Error('Invalid Extend Config');
var lifeCycleList = life.filter(function (item) {
return LIFE_CYCLE.indexOf(item) >= 0;
});
return function extend(target) {
for (var _len = arguments.length, objList = Array(_len > 1 ? _len - 1 : 0), _key = 1; _key < _len; _key++) {
objList[_key - 1] = arguments[_key];
}
objList.forEach(function (source) {
if (source) {
var keys = Object.keys(source);
keys.forEach(function (key) {
var value = source[key];
if (excludeList.indexOf(key) >= 0) return;
if (lifeCycleList.indexOf(key) >= 0 && typeof value === 'function') {
var funcArrayName = getFuncArrayName(key);
if (!target[funcArrayName]) {
target[funcArrayName] = [];
if (target[key]) {
target[funcArrayName].push(target[key]);
}
target[key] = function () {
var _this = this;
for (var _len2 = arguments.length, rest = Array(_len2), _key2 = 0; _key2 < _len2; _key2++) {
rest[_key2] = arguments[_key2];
}
target[funcArrayName].forEach(function (func) {
return func.apply(_this, rest);
});
};
}
if (source[funcArrayName]) {
var _target$funcArrayName;
// 经过生命周期合并的组件直接整合函数列表
(_target$funcArrayName = target[funcArrayName]).push.apply(_target$funcArrayName, source[funcArrayName]);
} else {
// 添加生命周期函数进入函数列表
target[funcArrayName].push(value);
}
} else {
target[key] = value;
}
});
}
});
return target;
};
};
var getFuncArrayName = function getFuncArrayName(name) {
return '__$' + name;
};
module.exports = {
extractComponentId: extractComponentId,
extend: Object.assign,
extendCreator: extendCreator
};

View File

@ -1,35 +0,0 @@
<import src="./picker-view-column.wxml" />
<template name="date-picker-view">
<picker-view
value="{{ selected }}"
bindchange="change"
indicator-style="height: 50px;"
class="picker-visible">
<template
is="picker-view-column"
data="{{ data: dataList[0], className: 'year-view-column', hidden: !use['years'], tip: '年' }}"
/>
<template
is="picker-view-column"
data="{{ data: dataList[1], hidden: !use['months'], tip: '月' }}"
/>
<template
is="picker-view-column"
data="{{ data: dataList[2], hidden: !use['days'], tip: '日' }}"
/>
<template
is="picker-view-column"
data="{{ data: dataList[3], hidden: !use['hours'], tip: '时' }}"
/>
<template
is="picker-view-column"
data="{{ data: dataList[4], hidden: !use['minutes'], tip: '分' }}"
/>
<template
is="picker-view-column"
data="{{ data: dataList[5], hidden: !use['seconds'], tip: '秒' }}"
/>
</picker-view>
</template>

View File

@ -1,105 +0,0 @@
'use strict';
function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } }
var LIMIT_YEAR_COUNT = 50;
var _require = require('./utils'),
genNumber = _require.genNumber,
iso2utc = _require.iso2utc;
module.exports = function () {
function DatePicker() {
var date = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : new Date();
_classCallCheck(this, DatePicker);
this.types = ['year', 'month', 'day', 'hour', 'minute', 'second'];
this.months = genNumber(1, 12, 2);
this.hours = genNumber(0, 23, 2);
this.seconds = genNumber(0, 59, 2);
this.minutes = genNumber(0, 59, 2);
this._date = date;
}
DatePicker.prototype.getYears = function getYears(year) {
var mid = Math.floor(LIMIT_YEAR_COUNT / 2);
var min = year - mid;
var max = year + (LIMIT_YEAR_COUNT - mid);
return genNumber(min, max, 4);
};
DatePicker.prototype.lastDay = function lastDay(year, month) {
return month !== 12 ? new Date(new Date(year + '/' + (month + 1) + '/1').getTime() - 24 * 60 * 60 * 1000).getDate() : 31;
};
DatePicker.prototype.getData = function getData(date) {
date = date || this._date || new Date();
// toUTCString ISO 格式部分 ios 手机会失败
if (new Date(date).toString() === 'Invalid Date' && typeof date === 'string' && date.indexOf('-') > 0) {
date = iso2utc(date);
}
var d = new Date(date);
var y = d.getFullYear();
var m = d.getMonth() + 1;
var years = this.getYears(y);
var lastDay = this.lastDay(y, m);
var days = genNumber(1, lastDay, 2);
this._years = years;
this._dataList = [years, this.months, days, this.hours, this.minutes, this.seconds];
this._indexs = [25, m - 1, d.getDate() - 1, d.getHours(), d.getMinutes(), d.getSeconds()];
return {
dataList: this._dataList,
selected: this._indexs
};
};
DatePicker.prototype.update = function update(col, index) {
var type = this.types[col];
switch (type) {
case 'year':
return this._updateYear(col, index);
case 'month':
return this._updateMonth(col, index);
default:
this._indexs[col] = index;
return [{ col: col, index: index }];
}
};
DatePicker.prototype._updateYear = function _updateYear(col, index, cb) {
var years = this._dataList[col];
var year = years[index];
this._dataList[col] = this.getYears(+year);
this._indexs[col] = Math.floor(LIMIT_YEAR_COUNT / 2);
return [{ col: 0, index: this._indexs[col], data: this._dataList[col] }];
};
DatePicker.prototype._updateMonth = function _updateMonth(col, index) {
var month = this._dataList[col][index];
var year = this._dataList[0][this._indexs[0]];
var lastDay = this.lastDay(+year, +month);
this._indexs[col] = index;
this._dataList[2] = genNumber(1, lastDay, 2);
this._indexs[2] = this._indexs[2] >= this._dataList[2].length ? this._dataList[2].length - 1 : this._indexs[2];
return [{
col: 1,
index: index
}, {
col: 2,
index: this._indexs[2],
data: this._dataList[2]
}];
};
return DatePicker;
}();

View File

@ -1,216 +0,0 @@
'use strict';
var DatePicker = require('./date-picker');
var _require = require('./utils'),
genNumber = _require.genNumber,
moment = _require.moment;
Component({
properties: {
placeholder: {
type: String,
value: '请选择时间'
},
format: {
type: String,
value: 'YYYY-MM-DD HH:mm:ss'
},
pickerView: {
type: Boolean
},
date: {
type: String,
observer: function observer(value) {
if (value === {}.toString()) {
throw new Error('参数必须是一个字符串');
}
if (/^[0-9]+$/.test(value)) {
value = +value;
}
!this._inited && this._init();
this.updateDate(value);
}
},
notUse: {
type: Array
}
},
externalClasses: ['placeholder-class'],
data: {
transPos: [0, 0, 0, 0, 0, 0]
},
attached: function attached() {
!this._inited && this._init();
},
methods: {
_init: function _init() {
var _this = this;
this._inited = true;
this.use = {};
['years', 'months', 'days', 'hours', 'minutes', 'seconds'].forEach(function (item) {
if ((_this.data.notUse || []).indexOf(item) === -1) {
_this.use[item] = true;
}
});
this.picker = new DatePicker(this.data.date);
var _picker$getData = this.picker.getData(this.data.date),
dataList = _picker$getData.dataList,
selected = _picker$getData.selected;
// 鬼他么知道为什么 dataList, selected 不能一起 setData
this.setData({
use: this.use,
dataList: dataList
}, function () {
_this.setData({
selected: selected
});
});
this._indexs = selected;
},
updatePicker: function updatePicker() {
var updateData = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : [];
var _updateData = {};
for (var _iterator = updateData, _isArray = Array.isArray(_iterator), _i = 0, _iterator = _isArray ? _iterator : _iterator[Symbol.iterator]();;) {
var _ref2;
if (_isArray) {
if (_i >= _iterator.length) break;
_ref2 = _iterator[_i++];
} else {
_i = _iterator.next();
if (_i.done) break;
_ref2 = _i.value;
}
var _ref = _ref2;
var col = _ref.col,
index = _ref.index,
data = _ref.data;
if (~index && this._indexs[col] !== index || col === 0) {
_updateData['selected[' + col + ']'] = index; // 更新索引
this._indexs[col] = index;
}
if (data) {
_updateData['dataList[' + col + ']'] = data;
}
}
this.setData(_updateData);
},
updateDate: function updateDate(date) {
var _this2 = this;
var _picker$getData2 = this.picker.getData(date),
dataList = _picker$getData2.dataList,
selected = _picker$getData2.selected;
this._indexs = selected;
// 好像必须要等到 datalist 完成
this.setData({ dataList: dataList }, function () {
_this2.setData({
selected: selected,
text: _this2.getFormatStr()
});
});
},
getFormatStr: function getFormatStr() {
var _this3 = this;
var date = new Date();
['FullYear', 'Month', 'Date', 'Hours', 'Minutes', 'Seconds'].forEach(function (key, index) {
var value = _this3.data.dataList[index][_this3._indexs[index]];
if (key === 'Month') {
value = +_this3.data.dataList[index][_this3._indexs[index]] - 1;
}
date['set' + key](+value);
});
return moment(date, this.data.format);
},
showPicker: function showPicker() {
this.setData({
show: true
});
},
hidePicker: function hidePicker(e) {
var action = e.currentTarget.dataset.action;
this.setData({
show: false
});
if (action === 'cancel') {
this.cancel({
detail: {}
});
} else {
this.change({
detail: {
value: this._indexs
}
});
}
},
columnchange: function columnchange(e) {
var _e$detail = e.detail,
column = _e$detail.column,
value = _e$detail.value;
var updateData = this.picker.update(column, value);
this.updatePicker(updateData);
},
change: function change(e) {
var value = e.detail.value;
var data = this.data.dataList.map(function (item, index) {
return +item[value[index]];
});
var day = data.slice(0, 3);
var time = data.slice(3, 6);
var date = new Date(day.join('/') + ' ' + time.join(':'));
this.triggerEvent('change', {
value: data,
date: date
});
// 手动触发 columnchange
for (var index = 0; index < value.length; index++) {
if (this._indexs[index] !== value[index]) {
this.columnchange({
detail: {
column: index,
value: value[index]
}
});
}
}
this.setData({
text: this.getFormatStr()
});
},
cancel: function cancel(e) {
this.triggerEvent('cancel', e.detail);
}
}
});

View File

@ -1,6 +0,0 @@
{
"component": true,
"usingComponents": {
"pop-manager": "../common/pop-manager/index"
}
}

View File

@ -1,18 +0,0 @@
<import src="./date-picker-view.wxml" />
<view wx:if="{{ !pickerView }}" bindtap="showPicker" class="placeholder-class">{{text || placeholder}}</view>
<view wx:if="{{ pickerView }}" class="picker-view">
<template is="date-picker-view" data="{{ dataList, selected, use }}" />
</view>
<view wx:else>
<pop-manager show="{{ show }}" type="bottom" >
<view class="picker">
<view class="picker-action">
<view data-action="cancel" bindtap="hidePicker">取消</view>
<view data-action="change" bindtap="hidePicker">确认</view>
</view>
<template is="date-picker-view" data="{{ dataList, selected, use }}" />
</view>
</pop-manager>
</view>

View File

@ -1,53 +0,0 @@
.picker-visible {
height: 236px;
bottom: 0;
}
picker-view-column.year-view-column {
width: 50px;
flex: 2;
}
picker-view-column {
width: 30px;
text-align: center;
}
.hidden {
display: none;
}
.view-column-tip {
height: 235px;
line-height: 235px;
margin: 0 5px;
}
.picker {
width: 100vw;
height: 100vh;
top: 0;
left: 0;
z-index: 12;
}
.picker .picker-action {
height: 36px;
bottom: 235px;
padding: 0 15px;
width: 100%;
display: flex;
align-items: center;
position: absolute;
background: #fff;
box-sizing: border-box;
border-bottom: 1rpx solid #e5e5e5;
justify-content: space-between;
}
.picker-action view:last-child {
color: #1aad16;
}
.picker picker-view {
position: absolute;
bottom: 0;
background: #fff;
width: 100vw;
}

View File

@ -1,6 +0,0 @@
<template name="picker-view-column">
<picker-view-column class="{{ className }} {{ hidden && 'hidden'}}">
<view wx:for="{{ data }}" style="line-height: 50px" wx:key="*this">{{item}}</view>
</picker-view-column>
<view class="view-column-tip {{ hidden && 'hidden'}}">{{ tip }}</view>
</template>

View File

@ -1,124 +0,0 @@
'use strict';
function partStartWithZero(num, strlen) {
var zeros = '';
while (zeros.length < strlen) {
zeros += '0';
}
return (zeros + num).slice(-strlen);
}
module.exports.genNumber = function genNumber(begin, end, strlen) {
var nums = [];
while (begin <= end) {
nums.push(partStartWithZero(begin, strlen));
begin++;
}
return nums;
};
module.exports.moment = function moment(date) {
var formatStr = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : 'YYYY:MM:DD';
if (!date && date !== 0) date = new Date();
date = new Date(date);
if (date.toString() === 'Invalid Date') throw new Error('Invalid Date');
var getDateValue = function getDateValue(method, fn) {
return fn ? fn(date['get' + method]()) : date['get' + method]();
};
var map = new Map();
map.set(/(Y+)/i, function () {
return getDateValue('FullYear', function (year) {
return (year + '').substr(4 - RegExp.$1.length);
});
});
map.set(/(M+)/, function () {
return getDateValue('Month', function (month) {
return partStartWithZero(month + 1, RegExp.$1.length);
});
});
map.set(/(D+)/i, function () {
return getDateValue('Date', function (date) {
return partStartWithZero(date, RegExp.$1.length);
});
});
map.set(/(H+)/i, function () {
return getDateValue('Hours', function (hour) {
return partStartWithZero(hour, RegExp.$1.length);
});
});
map.set(/(m+)/, function () {
return getDateValue('Minutes', function (minute) {
return partStartWithZero(minute, RegExp.$1.length);
});
});
map.set(/(s+)/, function () {
return getDateValue('Seconds', function (second) {
return partStartWithZero(second, RegExp.$1.length);
});
});
for (var _iterator = map, _isArray = Array.isArray(_iterator), _i = 0, _iterator = _isArray ? _iterator : _iterator[Symbol.iterator]();;) {
var _ref2;
if (_isArray) {
if (_i >= _iterator.length) break;
_ref2 = _iterator[_i++];
} else {
_i = _iterator.next();
if (_i.done) break;
_ref2 = _i.value;
}
var _ref = _ref2;
var reg = _ref[0];
var fn = _ref[1];
if (reg.test(formatStr)) {
formatStr = formatStr.replace(RegExp.$1, fn.call(null));
}
}
return formatStr;
};
module.exports.iso2utc = function (string) {
var regexp = "([0-9]{4})(-([0-9]{2})(-([0-9]{2})(T([0-9]{2}):([0-9]{2})(:([0-9]{2})(\.([0-9]+))?)?(Z|(([-+])([0-9]{2}):([0-9]{2})))?)?)?)?";
if (string) {
var d = string.match(new RegExp(regexp));
var offset = 0;
var date = new Date(d[1], 0, 1);
if (d[3]) {
date.setMonth(d[3] - 1);
}
if (d[5]) {
date.setDate(+d[5]);
}
if (d[7]) {
date.setHours(d[7]);
}
if (d[8]) {
date.setMinutes(d[8]);
}
if (d[10]) {
date.setSeconds(d[10]);
}
if (d[12]) {
date.setMilliseconds(Number("0." + d[12]) * 1000);
}
if (d[14]) {
offset = Number(d[16]) * 60 + Number(d[17]);
offset *= d[15] == '-' ? 1 : -1;
}
offset -= date.getTimezoneOffset();
return Number(date) + offset * 60 * 1000;
} else {
return string;
}
};

26
dist/dialog/data.js vendored
View File

@ -1,26 +0,0 @@
'use strict';
module.exports = {
// 标题
title: '',
// 内容
message: ' ',
// 选择节点
selector: '#van-dialog',
// 按钮是否展示为纵向
buttonsShowVertical: false,
// 是否展示确定
showConfirmButton: true,
// 确认按钮文案
confirmButtonText: '确定',
// 确认按钮颜色
confirmButtonColor: '#3CC51F',
// 是否展示取消
showCancelButton: false,
// 取消按钮文案
cancelButtonText: '取消',
// 取消按钮颜色
cancelButtonColor: '#333',
// 点击按钮自动关闭 dialog
autoClose: true
};

104
dist/dialog/dialog.js vendored
View File

@ -1,104 +0,0 @@
'use strict';
var defaultData = require('./data');
function getDialogCtx(_ref) {
var selector = _ref.selector,
pageCtx = _ref.pageCtx;
var ctx = pageCtx;
if (!ctx) {
var pages = getCurrentPages();
ctx = pages[pages.length - 1];
}
return ctx.selectComponent(selector);
}
function getParsedOptions() {
var options = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};
return Object.assign({
// 自定义 button 列表
// { type: 按钮类型回调时以此作为区分依据text: 按钮文案, color: 按钮文字颜色 }
buttons: []
}, defaultData, options);
}
// options 使用参数
// pageCtx 页面 page 上下文
function Dialog(options, pageCtx) {
var parsedOptions = getParsedOptions(options);
var dialogCtx = getDialogCtx({
selector: parsedOptions.selector,
pageCtx: pageCtx
});
if (!dialogCtx) {
console.error('无法找到对应的dialog组件请于页面中注册并在 wxml 中声明 dialog 自定义组件');
return Promise.reject({ type: 'component error' });
}
// 处理默认按钮的展示
// 纵向排布确认按钮在上方
var _parsedOptions$button = parsedOptions.buttons,
buttons = _parsedOptions$button === undefined ? [] : _parsedOptions$button;
var showCustomBtns = false;
if (buttons.length === 0) {
if (parsedOptions.showConfirmButton) {
buttons.push({
type: 'confirm',
text: parsedOptions.confirmButtonText,
color: parsedOptions.confirmButtonColor
});
}
if (parsedOptions.showCancelButton) {
var cancelButton = {
type: 'cancel',
text: parsedOptions.cancelButtonText,
color: parsedOptions.cancelButtonColor
};
if (parsedOptions.buttonsShowVertical) {
buttons.push(cancelButton);
} else {
buttons.unshift(cancelButton);
}
}
} else {
showCustomBtns = true;
}
return new Promise(function (resolve, reject) {
dialogCtx.setData(Object.assign({}, parsedOptions, {
buttons: buttons,
showCustomBtns: showCustomBtns,
key: '' + new Date().getTime(),
show: true,
promiseFunc: { resolve: resolve, reject: reject },
openTypePromiseFunc: null
}));
});
}
Dialog.close = function (options, pageCtx) {
var parsedOptions = getParsedOptions(options);
var dialogCtx = getDialogCtx({
selector: parsedOptions.selector,
pageCtx: pageCtx
});
if (!dialogCtx) {
return;
}
dialogCtx.setData({
show: false,
promiseFunc: null,
openTypePromiseFunc: null
});
};
module.exports = Dialog;

133
dist/dialog/index.js vendored
View File

@ -1,133 +0,0 @@
'use strict';
var _f = function _f() {};
var needResponseOpenTypes = ['getUserInfo', 'getPhoneNumber', 'openSetting'];
Component({
properties: {},
data: {
// 标题
title: '',
// 自定义 button 列表
// { type: 按钮类型回调时以此作为区分依据text: 按钮文案, color: 按钮文字颜色, openType: 微信开放能力 }
buttons: [],
// 内容
message: ' ',
// 选择节点
selector: '#van-dialog',
// 按钮是否展示为纵向
buttonsShowVertical: false,
// 是否展示确定
showConfirmButton: true,
// 确认按钮文案
confirmButtonText: '确定',
// 确认按钮颜色
confirmButtonColor: '#3CC51F',
// 是否展示取消
showCancelButton: false,
// 取消按钮文案
cancelButtonText: '取消',
// 取消按钮颜色
cancelButtonColor: '#333',
key: '',
autoClose: true,
show: false,
showCustomBtns: false,
promiseFunc: {},
openTypePromiseFunc: {}
},
methods: {
handleButtonClick: function handleButtonClick(e) {
var _this = this;
var _e$currentTarget = e.currentTarget,
currentTarget = _e$currentTarget === undefined ? {} : _e$currentTarget;
var _currentTarget$datase = currentTarget.dataset,
dataset = _currentTarget$datase === undefined ? {} : _currentTarget$datase;
// 获取当次弹出框的信息
var _ref = this.data.promiseFunc || {},
_ref$resolve = _ref.resolve,
resolve = _ref$resolve === undefined ? _f : _ref$resolve,
_ref$reject = _ref.reject,
reject = _ref$reject === undefined ? _f : _ref$reject;
// 重置展示
if (this.data.autoClose) {
this.setData({ show: false });
}
// 自定义按钮,全部 resolve 形式返回,根据 type 区分点击按钮
if (this.data.showCustomBtns) {
var isNeedOpenDataButton = needResponseOpenTypes.indexOf(dataset.openType) > -1;
var resolveData = { type: dataset.type };
// 如果需要 openData就额外返回一个 promise用于后续 open 数据返回
if (isNeedOpenDataButton) {
resolveData.openDataPromise = new Promise(function (resolve, reject) {
_this.setData({ openTypePromiseFunc: { resolve: resolve, reject: reject } });
});
resolveData.hasOpenDataPromise = true;
}
resolve(resolveData);
return;
}
// 默认按钮,确认为 resolve取消为 reject
if (dataset.type === 'confirm') {
resolve({
type: 'confirm'
});
} else {
reject({
type: 'cancel'
});
}
this.setData({ promiseFunc: {} });
},
// 以下为处理微信按钮开放能力的逻辑
handleUserInfoResponse: function handleUserInfoResponse(_ref2) {
var detail = _ref2.detail;
this.__handleOpenDataResponse({
type: detail.errMsg === 'getUserInfo:ok' ? 'resolve' : 'reject',
data: detail
});
},
handlePhoneResponse: function handlePhoneResponse(_ref3) {
var detail = _ref3.detail;
this.__handleOpenDataResponse({
type: detail.errMsg === 'getPhoneNumber:ok' ? 'resolve' : 'reject',
data: detail
});
},
handleOpenSettingResponse: function handleOpenSettingResponse(_ref4) {
var detail = _ref4.detail;
this.__handleOpenDataResponse({
type: detail.errMsg === 'openSetting:ok' ? 'resolve' : 'reject',
data: detail
});
},
__handleOpenDataResponse: function __handleOpenDataResponse(_ref5) {
var _ref5$type = _ref5.type,
type = _ref5$type === undefined ? 'resolve' : _ref5$type,
_ref5$data = _ref5.data,
data = _ref5$data === undefined ? {} : _ref5$data;
var promiseFuncs = this.data.openTypePromiseFunc || {};
var responseFunc = promiseFuncs[type] || _f;
responseFunc(data);
this.setData({ openTypePromiseFunc: null });
}
}
});

View File

@ -1,7 +0,0 @@
{
"component": true,
"usingComponents": {
"pop-manager": "../common/pop-manager/index",
"van-button": "../button/index"
}
}

View File

@ -1,40 +0,0 @@
<pop-manager
show="{{ show }}"
type="center"
>
<view class="van-dialog--container">
<view
wx:if="{{ title }}"
class="van-dialog__header"
>{{ title }}</view>
<view
class="van-dialog__content {{ title ? 'van-dialog__content--title' : '' }}"
>
<text>{{ message }}</text>
</view>
<view
class="van-dialog__footer {{ buttonsShowVertical ? 'van-dialog__footer--vertical' : 'van-dialog__footer--horizon' }}"
>
<block
wx:for="{{ buttons }}"
wx:key="{{ item.text }}-{{ item.type }}"
>
<van-button
class="van-dialog__button"
custom-class="{{ index === 0 ? 'van-dialog__button-inside--first' : 'van-dialog__button-inside' }}"
data-type="{{ item.type }}"
data-open-type="{{ item.openType }}"
open-type="{{ item.openType }}"
bind:tap="handleButtonClick"
bind:getuserinfo="handleUserInfoResponse"
bind:getphonenumber="handlePhoneResponse"
bind:opensetting="handleOpenSettingResponse"
>
<view
style="color: {{ item.color || '#333' }}"
>{{ item.text }}</view>
</van-button>
</block>
</view>
</view>
</pop-manager>

View File

@ -1 +0,0 @@
.van-dialog--container{width:80vw;font-size:16px;overflow:hidden;border-radius:4px;background-color:#fff;color:#333}.van-dialog__header{padding:15px 0 0;text-align:center}.van-dialog__content{position:relative;padding:15px 20px;line-height:1.5;min-height:40px}.van-dialog__content::after{border-bottom-width:1px}.van-dialog__content--title{color:#999;font-size:14px}.van-dialog__footer{overflow:hidden}.van-dialog__button{-webkit-box-flex:1;flex:1}.van-dialog__button-inside,.van-dialog__button-inside--first{margin-bottom:0;line-height:50px;height:50px}.van-dialog__button-inside--first::after,.van-dialog__button-inside::after{border-width:0;border-radius:0}.van-dialog__footer--horizon{display:-webkit-box;display:flex}.van-dialog__footer--horizon .van-dialog__button-inside::after{border-left-width:1px}.van-dialog__footer--vertical .van-dialog__button-inside::after{border-top-width:1px}

View File

@ -1 +1 @@
.van-ellipsis{overflow:hidden;white-space:nowrap;text-overflow:ellipsis}.van-clearfix::after{content:'';display:table;clear:both}.van-hairline,.van-hairline--bottom,.van-hairline--left,.van-hairline--right,.van-hairline--surround,.van-hairline--top,.van-hairline--top-bottom{position:relative}.van-hairline--bottom::after,.van-hairline--left::after,.van-hairline--right::after,.van-hairline--surround::after,.van-hairline--top-bottom::after,.van-hairline--top::after,.van-hairline::after{content:'';position:absolute;top:0;left:0;width:200%;height:200%;-webkit-transform:scale(.5);transform:scale(.5);-webkit-transform-origin:0 0;transform-origin:0 0;pointer-events:none;box-sizing:border-box;border:0 solid #e5e5e5}.van-hairline--top::after{border-top-width:1px}.van-hairline--left::after{border-left-width:1px}.van-hairline--right::after{border-right-width:1px}.van-hairline--bottom::after{border-bottom-width:1px}.van-hairline--top-bottom::after{border-width:1px 0}.van-hairline--surround::after{border-width:1px}@-webkit-keyframes van-slide-bottom-enter{from{-webkit-transform:translate3d(0,100%,0);transform:translate3d(0,100%,0)}}@keyframes van-slide-bottom-enter{from{-webkit-transform:translate3d(0,100%,0);transform:translate3d(0,100%,0)}}@-webkit-keyframes van-slide-bottom-leave{to{-webkit-transform:translate3d(0,100%,0);transform:translate3d(0,100%,0)}}@keyframes van-slide-bottom-leave{to{-webkit-transform:translate3d(0,100%,0);transform:translate3d(0,100%,0)}}@-webkit-keyframes van-fade-in{from{opacity:0}to{opacity:1}}@keyframes van-fade-in{from{opacity:0}to{opacity:1}}@-webkit-keyframes van-fade-out{from{opacity:1}to{opacity:0}}@keyframes van-fade-out{from{opacity:1}to{opacity:0}}@-webkit-keyframes van-rotate{from{-webkit-transform:rotate(0);transform:rotate(0)}to{-webkit-transform:rotate(360deg);transform:rotate(360deg)}}@keyframes van-rotate{from{-webkit-transform:rotate(0);transform:rotate(0)}to{-webkit-transform:rotate(360deg);transform:rotate(360deg)}}.van-fade-enter-active{-webkit-animation:.3s van-fade-in;animation:.3s van-fade-in}.van-fade-leave-active{-webkit-animation:.3s van-fade-out;animation:.3s van-fade-out}.van-slide-bottom-enter-active{-webkit-animation:van-slide-bottom-enter .3s both ease;animation:van-slide-bottom-enter .3s both ease}.van-slide-bottom-leave-active{-webkit-animation:van-slide-bottom-leave .3s both ease;animation:van-slide-bottom-leave .3s both ease}.van-field__body{display:-webkit-box;display:flex;-webkit-box-align:center;align-items:center}.van-field__body--textarea{min-height:24px}.van-field__control{border:0;margin:0;padding:0;width:100%;resize:none;display:block;text-align:left;box-sizing:border-box;line-height:inherit;background-color:transparent}.van-field__control--disabled{opacity:1;color:#666;background-color:transparent}.van-field__control--center{text-align:center}.van-field__control--right{text-align:right}.van-field__button,.van-field__clear,.van-field__icon-container{flex-shrink:0}.van-field__clear,.van-field__icon-container{padding:0 10px;color:#999;line-height:inherit;margin-right:-10px;vertical-align:middle}.van-field__icon{display:block;font-size:16px;line-height:inherit}.van-field__button{padding-left:10px}.van-field__error-message{color:#f44;font-size:12px;text-align:left}.van-field--error{color:#f44}.van-field--label-center .van-cell__title{text-align:center}.van-field--label-right .van-cell__title{text-align:right}
.van-ellipsis{overflow:hidden;white-space:nowrap;text-overflow:ellipsis}.van-clearfix::after{content:'';display:table;clear:both}.van-hairline,.van-hairline--bottom,.van-hairline--left,.van-hairline--right,.van-hairline--surround,.van-hairline--top,.van-hairline--top-bottom{position:relative}.van-hairline--bottom::after,.van-hairline--left::after,.van-hairline--right::after,.van-hairline--surround::after,.van-hairline--top-bottom::after,.van-hairline--top::after,.van-hairline::after{content:'';position:absolute;top:0;left:0;width:200%;height:200%;-webkit-transform:scale(.5);transform:scale(.5);-webkit-transform-origin:0 0;transform-origin:0 0;pointer-events:none;box-sizing:border-box;border:0 solid #e5e5e5}.van-hairline--top::after{border-top-width:1px}.van-hairline--left::after{border-left-width:1px}.van-hairline--right::after{border-right-width:1px}.van-hairline--bottom::after{border-bottom-width:1px}.van-hairline--top-bottom::after{border-width:1px 0}.van-hairline--surround::after{border-width:1px}@-webkit-keyframes van-slide-bottom-enter{from{-webkit-transform:translate3d(0,100%,0);transform:translate3d(0,100%,0)}}@keyframes van-slide-bottom-enter{from{-webkit-transform:translate3d(0,100%,0);transform:translate3d(0,100%,0)}}@-webkit-keyframes van-slide-bottom-leave{to{-webkit-transform:translate3d(0,100%,0);transform:translate3d(0,100%,0)}}@keyframes van-slide-bottom-leave{to{-webkit-transform:translate3d(0,100%,0);transform:translate3d(0,100%,0)}}@-webkit-keyframes van-fade-in{from{opacity:0}to{opacity:1}}@keyframes van-fade-in{from{opacity:0}to{opacity:1}}@-webkit-keyframes van-fade-out{from{opacity:1}to{opacity:0}}@keyframes van-fade-out{from{opacity:1}to{opacity:0}}@-webkit-keyframes van-rotate{from{-webkit-transform:rotate(0);transform:rotate(0)}to{-webkit-transform:rotate(360deg);transform:rotate(360deg)}}@keyframes van-rotate{from{-webkit-transform:rotate(0);transform:rotate(0)}to{-webkit-transform:rotate(360deg);transform:rotate(360deg)}}.van-fade-enter-active{-webkit-animation:.3s van-fade-in;animation:.3s van-fade-in}.van-fade-leave-active{-webkit-animation:.3s van-fade-out;animation:.3s van-fade-out}.van-slide-bottom-enter-active{-webkit-animation:van-slide-bottom-enter .3s both ease;animation:van-slide-bottom-enter .3s both ease}.van-slide-bottom-leave-active{-webkit-animation:van-slide-bottom-leave .3s both ease;animation:van-slide-bottom-leave .3s both ease}.van-field__body{display:-webkit-box;display:-webkit-flex;display:flex;-webkit-box-align:center;-webkit-align-items:center;align-items:center}.van-field__body--textarea{min-height:24px}.van-field__control{border:0;margin:0;padding:0;width:100%;resize:none;display:block;text-align:left;box-sizing:border-box;line-height:inherit;background-color:transparent}.van-field__control--disabled{opacity:1;color:#666;background-color:transparent}.van-field__control--center{text-align:center}.van-field__control--right{text-align:right}.van-field__button,.van-field__clear,.van-field__icon-container{-webkit-flex-shrink:0;flex-shrink:0}.van-field__clear,.van-field__icon-container{padding:0 10px;color:#999;line-height:inherit;margin-right:-10px;vertical-align:middle}.van-field__icon{display:block;font-size:16px;line-height:inherit}.van-field__button{padding-left:10px}.van-field__error-message{color:#f44;font-size:12px;text-align:left}.van-field--error{color:#f44}.van-field--label-center .van-cell__title{text-align:center}.van-field--label-right .van-cell__title{text-align:right}

View File

@ -1 +1 @@
.van-notice-bar{display:-webkit-box;display:flex;padding:9px 10px;font-size:12px;line-height:1.5}.van-notice-bar--within-icon{position:relative;padding-right:30px}.van-notice-bar__left-icon{height:18px;min-width:20px;padding-top:1px;box-sizing:border-box}.van-notice-bar__left-icon>image{width:16px;height:16px}.van-notice-bar__right-icon{position:absolute;top:10px;right:10px;font-size:15px;line-height:1}.van-notice-bar__content-wrap{position:relative;-webkit-box-flex:1;flex:1;height:18px;overflow:hidden}.van-notice-bar__content{position:absolute;white-space:nowrap}
.van-notice-bar{display:-webkit-box;display:-webkit-flex;display:flex;padding:9px 10px;font-size:12px;line-height:1.5}.van-notice-bar--within-icon{position:relative;padding-right:30px}.van-notice-bar__left-icon{height:18px;min-width:20px;padding-top:1px;box-sizing:border-box}.van-notice-bar__left-icon>image{width:16px;height:16px}.van-notice-bar__right-icon{position:absolute;top:10px;right:10px;font-size:15px;line-height:1}.van-notice-bar__content-wrap{position:relative;-webkit-box-flex:1;-webkit-flex:1;flex:1;height:18px;overflow:hidden}.van-notice-bar__content{position:absolute;white-space:nowrap}

33
dist/radio/index.js vendored
View File

@ -1,33 +0,0 @@
'use strict';
Component({
behaviors: ['wx://form-field'],
externalClasses: ['radio-class', 'radio-color'],
properties: {
items: Array,
type: String
},
methods: {
radioChange: function radioChange(e) {
this.selectItem(e.detail.value);
this.triggerEvent('change', e);
},
selectItem: function selectItem(value) {
var items = this.data.items;
items.forEach(function (item) {
if (item.name === value) {
item.checked = true;
} else {
item.checked = false;
}
});
this.setData({ items: items });
}
}
});

View File

@ -1,6 +0,0 @@
{
"component": true,
"usingComponents": {
"van-icon": "../icon/index"
}
}

28
dist/radio/index.wxml vendored
View File

@ -1,28 +0,0 @@
<radio-group
class="van-radio radio-class"
bindchange="radioChange"
wx:if="{{ items && items.length }}"
>
<label
class="van-radio__label {{ type === 'list' ? 'van-radio__list-item' : 'van-radio__item'}}"
wx:for="{{ items }}"
wx:key="{{ item.value }}"
wx:for-item="item"
wx:for-index="index"
>
<view class="van-radio__icon-wrap">
<view class="van-radio__icon {{ item.disabled ? 'van-radio--disabled' : '' }} {{ item.checked ? 'van-radio--checked radio-color' : '' }}">
<view class="van-radio__icon-inside"></view>
</view>
<radio
class="van-radio__origin"
value="{{ item.name }}"
checked="{{ item.checked }}"
disabled="{{ item.disabled }}"
/>
</view>
<view class="van-radio__name">
{{item.value}}
</view>
</label>
</radio-group>

View File

@ -1 +0,0 @@
.van-radio{display:block;padding:0 10px;font-size:14px}.van-radio__item{display:block;margin-top:10px;height:20px}.van-radio__item:last-child{margin-bottom:10px}.van-radio__list-item{display:block;padding:10px 10px 10px 0;border-bottom:1px solid #e5e5e5}.van-radio__list-item .van-radio__icon-wrap{float:right;margin-top:3px}.van-radio__icon-wrap{position:relative;width:14px;height:15px;display:-webkit-inline-box;display:inline-flex;-webkit-box-align:center;align-items:center;color:#aaa}.van-radio__icon-wrap .van-radio__origin{opacity:0;width:14px;height:20px}.van-radio__icon-wrap .van-radio__icon{position:absolute;left:50%;top:50%;-webkit-transform:translate(-50%,-50%);transform:translate(-50%,-50%);border:1px solid #dcdfe6;border-radius:100%;width:14px;height:14px;background-color:#fff;cursor:pointer;box-sizing:border-box}.van-radio__icon-wrap .van-radio__icon .van-radio__icon-inside{position:absolute;left:50%;top:50%;-webkit-transform:translate(-50%,-50%);transform:translate(-50%,-50%);width:4px;height:4px;border-radius:50%}.van-radio__icon-wrap .van-radio__icon.van-radio--checked{border-color:#06bf04;background:#06bf04}.van-radio__icon-wrap .van-radio__icon.van-radio--checked .van-radio__icon-inside{background-color:#fff}.van-radio__icon-wrap .van-radio__icon.van-radio--disabled{opacity:.6}.van-radio__name{display:inline-block;margin-left:10px}

View File

@ -1 +1 @@
.van-ellipsis{overflow:hidden;white-space:nowrap;text-overflow:ellipsis}.van-clearfix::after{content:'';display:table;clear:both}.van-hairline,.van-hairline--bottom,.van-hairline--left,.van-hairline--right,.van-hairline--surround,.van-hairline--top,.van-hairline--top-bottom{position:relative}.van-hairline--bottom::after,.van-hairline--left::after,.van-hairline--right::after,.van-hairline--surround::after,.van-hairline--top-bottom::after,.van-hairline--top::after,.van-hairline::after{content:'';position:absolute;top:0;left:0;width:200%;height:200%;-webkit-transform:scale(.5);transform:scale(.5);-webkit-transform-origin:0 0;transform-origin:0 0;pointer-events:none;box-sizing:border-box;border:0 solid #e5e5e5}.van-hairline--top::after{border-top-width:1px}.van-hairline--left::after{border-left-width:1px}.van-hairline--right::after{border-right-width:1px}.van-hairline--bottom::after{border-bottom-width:1px}.van-hairline--top-bottom::after{border-width:1px 0}.van-hairline--surround::after{border-width:1px}@-webkit-keyframes van-slide-bottom-enter{from{-webkit-transform:translate3d(0,100%,0);transform:translate3d(0,100%,0)}}@keyframes van-slide-bottom-enter{from{-webkit-transform:translate3d(0,100%,0);transform:translate3d(0,100%,0)}}@-webkit-keyframes van-slide-bottom-leave{to{-webkit-transform:translate3d(0,100%,0);transform:translate3d(0,100%,0)}}@keyframes van-slide-bottom-leave{to{-webkit-transform:translate3d(0,100%,0);transform:translate3d(0,100%,0)}}@-webkit-keyframes van-fade-in{from{opacity:0}to{opacity:1}}@keyframes van-fade-in{from{opacity:0}to{opacity:1}}@-webkit-keyframes van-fade-out{from{opacity:1}to{opacity:0}}@keyframes van-fade-out{from{opacity:1}to{opacity:0}}@-webkit-keyframes van-rotate{from{-webkit-transform:rotate(0);transform:rotate(0)}to{-webkit-transform:rotate(360deg);transform:rotate(360deg)}}@keyframes van-rotate{from{-webkit-transform:rotate(0);transform:rotate(0)}to{-webkit-transform:rotate(360deg);transform:rotate(360deg)}}.van-fade-enter-active{-webkit-animation:.3s van-fade-in;animation:.3s van-fade-in}.van-fade-leave-active{-webkit-animation:.3s van-fade-out;animation:.3s van-fade-out}.van-slide-bottom-enter-active{-webkit-animation:van-slide-bottom-enter .3s both ease;animation:van-slide-bottom-enter .3s both ease}.van-slide-bottom-leave-active{-webkit-animation:van-slide-bottom-leave .3s both ease;animation:van-slide-bottom-leave .3s both ease}.van-search{display:-webkit-box;display:flex;padding:7px 15px;-webkit-box-align:center;align-items:center;box-sizing:border-box}.van-search__field{-webkit-box-flex:1;flex:1;border-radius:4px}.van-search__field__left-icon{color:#999}.van-search--show-action{padding-right:0}.van-search input::-webkit-search-cancel-button,.van-search input::-webkit-search-decoration,.van-search input::-webkit-search-results-button,.van-search input::-webkit-search-results-decoration{display:none}.van-search__action{padding:0 10px;font-size:14px;line-height:30px;color:#666}.van-search__action:active{background-color:#e8e8e8}
.van-ellipsis{overflow:hidden;white-space:nowrap;text-overflow:ellipsis}.van-clearfix::after{content:'';display:table;clear:both}.van-hairline,.van-hairline--bottom,.van-hairline--left,.van-hairline--right,.van-hairline--surround,.van-hairline--top,.van-hairline--top-bottom{position:relative}.van-hairline--bottom::after,.van-hairline--left::after,.van-hairline--right::after,.van-hairline--surround::after,.van-hairline--top-bottom::after,.van-hairline--top::after,.van-hairline::after{content:'';position:absolute;top:0;left:0;width:200%;height:200%;-webkit-transform:scale(.5);transform:scale(.5);-webkit-transform-origin:0 0;transform-origin:0 0;pointer-events:none;box-sizing:border-box;border:0 solid #e5e5e5}.van-hairline--top::after{border-top-width:1px}.van-hairline--left::after{border-left-width:1px}.van-hairline--right::after{border-right-width:1px}.van-hairline--bottom::after{border-bottom-width:1px}.van-hairline--top-bottom::after{border-width:1px 0}.van-hairline--surround::after{border-width:1px}@-webkit-keyframes van-slide-bottom-enter{from{-webkit-transform:translate3d(0,100%,0);transform:translate3d(0,100%,0)}}@keyframes van-slide-bottom-enter{from{-webkit-transform:translate3d(0,100%,0);transform:translate3d(0,100%,0)}}@-webkit-keyframes van-slide-bottom-leave{to{-webkit-transform:translate3d(0,100%,0);transform:translate3d(0,100%,0)}}@keyframes van-slide-bottom-leave{to{-webkit-transform:translate3d(0,100%,0);transform:translate3d(0,100%,0)}}@-webkit-keyframes van-fade-in{from{opacity:0}to{opacity:1}}@keyframes van-fade-in{from{opacity:0}to{opacity:1}}@-webkit-keyframes van-fade-out{from{opacity:1}to{opacity:0}}@keyframes van-fade-out{from{opacity:1}to{opacity:0}}@-webkit-keyframes van-rotate{from{-webkit-transform:rotate(0);transform:rotate(0)}to{-webkit-transform:rotate(360deg);transform:rotate(360deg)}}@keyframes van-rotate{from{-webkit-transform:rotate(0);transform:rotate(0)}to{-webkit-transform:rotate(360deg);transform:rotate(360deg)}}.van-fade-enter-active{-webkit-animation:.3s van-fade-in;animation:.3s van-fade-in}.van-fade-leave-active{-webkit-animation:.3s van-fade-out;animation:.3s van-fade-out}.van-slide-bottom-enter-active{-webkit-animation:van-slide-bottom-enter .3s both ease;animation:van-slide-bottom-enter .3s both ease}.van-slide-bottom-leave-active{-webkit-animation:van-slide-bottom-leave .3s both ease;animation:van-slide-bottom-leave .3s both ease}.van-search{display:-webkit-box;display:-webkit-flex;display:flex;padding:7px 15px;-webkit-box-align:center;-webkit-align-items:center;align-items:center;box-sizing:border-box}.van-search__field{-webkit-box-flex:1;-webkit-flex:1;flex:1;border-radius:4px}.van-search__field__left-icon{color:#999}.van-search--show-action{padding-right:0}.van-search input::-webkit-search-cancel-button,.van-search input::-webkit-search-decoration,.van-search input::-webkit-search-results-button,.van-search input::-webkit-search-results-decoration{display:none}.van-search__action{padding:0 10px;font-size:14px;line-height:30px;color:#666}.van-search__action:active{background-color:#e8e8e8}

4
dist/steps/index.js vendored
View File

@ -1,5 +1,7 @@
'use strict';
var _extends = Object.assign || function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; };
Component({
externalClasses: ['custom-class'],
@ -39,7 +41,7 @@ Component({
var steps = this.data.steps;
var formattedSteps = steps.map(function (step, index) {
return Object.assign({}, step, {
return _extends({}, step, {
status: _this.getStatus(index)
});
});

View File

@ -1 +1 @@
.van-ellipsis{overflow:hidden;white-space:nowrap;text-overflow:ellipsis}.van-clearfix::after{content:'';display:table;clear:both}.van-hairline,.van-hairline--bottom,.van-hairline--left,.van-hairline--right,.van-hairline--surround,.van-hairline--top,.van-hairline--top-bottom{position:relative}.van-hairline--bottom::after,.van-hairline--left::after,.van-hairline--right::after,.van-hairline--surround::after,.van-hairline--top-bottom::after,.van-hairline--top::after,.van-hairline::after{content:'';position:absolute;top:0;left:0;width:200%;height:200%;-webkit-transform:scale(.5);transform:scale(.5);-webkit-transform-origin:0 0;transform-origin:0 0;pointer-events:none;box-sizing:border-box;border:0 solid #e5e5e5}.van-hairline--top::after{border-top-width:1px}.van-hairline--left::after{border-left-width:1px}.van-hairline--right::after{border-right-width:1px}.van-hairline--bottom::after{border-bottom-width:1px}.van-hairline--top-bottom::after{border-width:1px 0}.van-hairline--surround::after{border-width:1px}@-webkit-keyframes van-slide-bottom-enter{from{-webkit-transform:translate3d(0,100%,0);transform:translate3d(0,100%,0)}}@keyframes van-slide-bottom-enter{from{-webkit-transform:translate3d(0,100%,0);transform:translate3d(0,100%,0)}}@-webkit-keyframes van-slide-bottom-leave{to{-webkit-transform:translate3d(0,100%,0);transform:translate3d(0,100%,0)}}@keyframes van-slide-bottom-leave{to{-webkit-transform:translate3d(0,100%,0);transform:translate3d(0,100%,0)}}@-webkit-keyframes van-fade-in{from{opacity:0}to{opacity:1}}@keyframes van-fade-in{from{opacity:0}to{opacity:1}}@-webkit-keyframes van-fade-out{from{opacity:1}to{opacity:0}}@keyframes van-fade-out{from{opacity:1}to{opacity:0}}@-webkit-keyframes van-rotate{from{-webkit-transform:rotate(0);transform:rotate(0)}to{-webkit-transform:rotate(360deg);transform:rotate(360deg)}}@keyframes van-rotate{from{-webkit-transform:rotate(0);transform:rotate(0)}to{-webkit-transform:rotate(360deg);transform:rotate(360deg)}}.van-fade-enter-active{-webkit-animation:.3s van-fade-in;animation:.3s van-fade-in}.van-fade-leave-active{-webkit-animation:.3s van-fade-out;animation:.3s van-fade-out}.van-slide-bottom-enter-active{-webkit-animation:van-slide-bottom-enter .3s both ease;animation:van-slide-bottom-enter .3s both ease}.van-slide-bottom-leave-active{-webkit-animation:van-slide-bottom-leave .3s both ease;animation:van-slide-bottom-leave .3s both ease}.van-steps{overflow:hidden;background-color:#fff}.van-steps--horizontal{display:-webkit-box;display:flex;overflow:hidden;position:relative;padding:10px 10px 15px}.van-steps--vertical{padding:0 0 0 35px}.van-step{-webkit-box-flex:1;flex:1;font-size:14px;position:relative;color:#999}.van-step--finish{color:#333}.van-step__circle{width:5px;height:5px;background-color:#999;border-radius:50%}.van-step--horizontal{float:left;padding-bottom:10px}.van-step--horizontal:first-child .van-step__title{-webkit-transform:none;transform:none;margin-left:0}.van-step--horizontal:last-child{position:absolute;right:10px;width:auto}.van-step--horizontal:last-child .van-step__title{-webkit-transform:none;transform:none;margin-left:0;text-align:right}.van-step--horizontal:last-child .van-step__circle-container{left:auto;right:-9px}.van-step--horizontal:last-child .van-step__line{width:0}.van-step--horizontal .van-step__circle-container{position:absolute;bottom:0;left:-8px;padding:0 8px;background-color:#fff;z-index:1}.van-step--horizontal .van-step__title{font-size:12px;-webkit-transform:translate3d(-50%,0,0);transform:translate3d(-50%,0,0);display:inline-block;margin-left:3px}.van-step--horizontal .van-step__line{position:absolute;left:0;bottom:2px;width:100%;height:1px;background-color:#e5e5e5}.van-step--horizontal.van-step--process{color:#333}.van-step--horizontal.van-step--process .van-step__circle-container{bottom:-4px}.van-step--horizontal.van-step--process .van-step__active{font-size:12px;color:#06bf04;display:block;line-height:1}.van-step--vertical{font-size:14px;line-height:18px;padding:10px 10px 10px 0}.van-step--vertical:not(:last-child)::after{border-bottom-width:1px}.van-step--vertical:first-child::before{content:'';position:absolute;width:1px;height:20px;background-color:#fff;top:0;left:-15px;z-index:1}.van-step--vertical .van-step__active,.van-step--vertical .van-step__circle{z-index:2;position:absolute}.van-step--vertical .van-step__active{top:12px;left:-20px;line-height:1;font-size:12px}.van-step--vertical .van-step__circle{top:16px;left:-17px}.van-step--vertical .van-step__line{position:absolute;top:0;left:-15px;width:1px;height:100%;background-color:#e5e5e5}
.van-ellipsis{overflow:hidden;white-space:nowrap;text-overflow:ellipsis}.van-clearfix::after{content:'';display:table;clear:both}.van-hairline,.van-hairline--bottom,.van-hairline--left,.van-hairline--right,.van-hairline--surround,.van-hairline--top,.van-hairline--top-bottom{position:relative}.van-hairline--bottom::after,.van-hairline--left::after,.van-hairline--right::after,.van-hairline--surround::after,.van-hairline--top-bottom::after,.van-hairline--top::after,.van-hairline::after{content:'';position:absolute;top:0;left:0;width:200%;height:200%;-webkit-transform:scale(.5);transform:scale(.5);-webkit-transform-origin:0 0;transform-origin:0 0;pointer-events:none;box-sizing:border-box;border:0 solid #e5e5e5}.van-hairline--top::after{border-top-width:1px}.van-hairline--left::after{border-left-width:1px}.van-hairline--right::after{border-right-width:1px}.van-hairline--bottom::after{border-bottom-width:1px}.van-hairline--top-bottom::after{border-width:1px 0}.van-hairline--surround::after{border-width:1px}@-webkit-keyframes van-slide-bottom-enter{from{-webkit-transform:translate3d(0,100%,0);transform:translate3d(0,100%,0)}}@keyframes van-slide-bottom-enter{from{-webkit-transform:translate3d(0,100%,0);transform:translate3d(0,100%,0)}}@-webkit-keyframes van-slide-bottom-leave{to{-webkit-transform:translate3d(0,100%,0);transform:translate3d(0,100%,0)}}@keyframes van-slide-bottom-leave{to{-webkit-transform:translate3d(0,100%,0);transform:translate3d(0,100%,0)}}@-webkit-keyframes van-fade-in{from{opacity:0}to{opacity:1}}@keyframes van-fade-in{from{opacity:0}to{opacity:1}}@-webkit-keyframes van-fade-out{from{opacity:1}to{opacity:0}}@keyframes van-fade-out{from{opacity:1}to{opacity:0}}@-webkit-keyframes van-rotate{from{-webkit-transform:rotate(0);transform:rotate(0)}to{-webkit-transform:rotate(360deg);transform:rotate(360deg)}}@keyframes van-rotate{from{-webkit-transform:rotate(0);transform:rotate(0)}to{-webkit-transform:rotate(360deg);transform:rotate(360deg)}}.van-fade-enter-active{-webkit-animation:.3s van-fade-in;animation:.3s van-fade-in}.van-fade-leave-active{-webkit-animation:.3s van-fade-out;animation:.3s van-fade-out}.van-slide-bottom-enter-active{-webkit-animation:van-slide-bottom-enter .3s both ease;animation:van-slide-bottom-enter .3s both ease}.van-slide-bottom-leave-active{-webkit-animation:van-slide-bottom-leave .3s both ease;animation:van-slide-bottom-leave .3s both ease}.van-steps{overflow:hidden;background-color:#fff}.van-steps--horizontal{display:-webkit-box;display:-webkit-flex;display:flex;overflow:hidden;position:relative;padding:10px 10px 15px}.van-steps--vertical{padding:0 0 0 35px}.van-step{-webkit-box-flex:1;-webkit-flex:1;flex:1;font-size:14px;position:relative;color:#999}.van-step--finish{color:#333}.van-step__circle{width:5px;height:5px;background-color:#999;border-radius:50%}.van-step--horizontal{float:left;padding-bottom:10px}.van-step--horizontal:first-child .van-step__title{-webkit-transform:none;transform:none;margin-left:0}.van-step--horizontal:last-child{position:absolute;right:10px;width:auto}.van-step--horizontal:last-child .van-step__title{-webkit-transform:none;transform:none;margin-left:0;text-align:right}.van-step--horizontal:last-child .van-step__circle-container{left:auto;right:-9px}.van-step--horizontal:last-child .van-step__line{width:0}.van-step--horizontal .van-step__circle-container{position:absolute;bottom:0;left:-8px;padding:0 8px;background-color:#fff;z-index:1}.van-step--horizontal .van-step__title{font-size:12px;-webkit-transform:translate3d(-50%,0,0);transform:translate3d(-50%,0,0);display:inline-block;margin-left:3px}.van-step--horizontal .van-step__line{position:absolute;left:0;bottom:2px;width:100%;height:1px;background-color:#e5e5e5}.van-step--horizontal.van-step--process{color:#333}.van-step--horizontal.van-step--process .van-step__circle-container{bottom:-4px}.van-step--horizontal.van-step--process .van-step__active{font-size:12px;color:#06bf04;display:block;line-height:1}.van-step--vertical{font-size:14px;line-height:18px;padding:10px 10px 10px 0}.van-step--vertical:not(:last-child)::after{border-bottom-width:1px}.van-step--vertical:first-child::before{content:'';position:absolute;width:1px;height:20px;background-color:#fff;top:0;left:-15px;z-index:1}.van-step--vertical .van-step__active,.van-step--vertical .van-step__circle{z-index:2;position:absolute}.van-step--vertical .van-step__active{top:12px;left:-20px;line-height:1;font-size:12px}.van-step--vertical .van-step__circle{top:16px;left:-17px}.van-step--vertical .van-step__line{position:absolute;top:0;left:-15px;width:1px;height:100%;background-color:#e5e5e5}

61
dist/tab/index.js vendored
View File

@ -1,61 +0,0 @@
'use strict';
Component({
externalClasses: 'class',
properties: {
scroll: {
type: Boolean,
value: false
},
fixed: {
type: Boolean,
value: false
},
height: {
type: Number,
value: 0
},
list: {
type: Array,
value: []
},
selectedId: {
type: [String, Number],
value: ''
}
},
data: {
scrollLeft: 0
},
methods: {
_handleScroll: function _handleScroll(selectedId) {
var _this = this;
var query = wx.createSelectorQuery().in(this);
query.select('#item-' + selectedId).boundingClientRect();
query.select('#scroll-view').boundingClientRect();
query.select('#scroll-view').scrollOffset();
query.exec(function (res) {
_this.setData({
scrollLeft: res[2].scrollLeft + res[0].left + res[0].width / 2 - res[1].width / 2
});
});
},
_handleZanTabChange: function _handleZanTabChange(e) {
var selectedId = e.currentTarget.dataset.itemId;
if (this.data.scroll) {
this._handleScroll(selectedId);
}
this.setData({
selectedId: selectedId
});
this.triggerEvent('tabchange', selectedId);
}
}
});

3
dist/tab/index.json vendored
View File

@ -1,3 +0,0 @@
{
"component": true
}

51
dist/tab/index.wxml vendored
View File

@ -1,51 +0,0 @@
<view
class="van-tab"
style="{{ height ? 'height:' + height + 'px' : '' }}"
>
<block wx:if="{{ scroll }}">
<scroll-view
id="scroll-view"
class="van-tab__bd van-tab__bd--scroll {{ fixed ? 'van-tab__bd--fixed' : '' }}"
scroll-x
scroll-with-animation
scroll-left="{{ scrollLeft }}"
style="height: {{ height ? height + 'px' : 'auto' }}"
>
<template
is="van-tab-list"
data="{{ list, selectedId, height }}"
/>
</scroll-view>
</block>
<block wx:else>
<view
class="van-tab__bd {{ fixed ? 'van-tab__bd--fixed' : '' }}"
style="height: {{ height ? height + 'px' : 'auto' }}"
>
<template
is="van-tab-list"
data="{{ list, selectedId, height }}"
/>
</view>
</block>
</view>
<!-- 插入内容 -->
<slot></slot>
<template name="van-tab-list">
<view
wx:for="{{ list }}"
wx:key="id"
class="van-tab__item {{ selectedId == item.id ? 'van-tab__item--selected' : '' }}"
id="item-{{ item.id }}"
data-item-id="{{ item.id }}"
bindtap="_handleZanTabChange"
>
<view
class="van-tab__title"
style="{{ height ? 'height:' + height + 'px;line-height:' + height + 'px' : '' }}"
>
{{ item.title }}
</view>
</view>
</template>

1
dist/tab/index.wxss vendored
View File

@ -1 +0,0 @@
.van-tab{height:45px}.van-tab__bd{width:100%;display:-webkit-box;display:flex;-webkit-box-orient:horizontal;-webkit-box-direction:normal;flex-direction:row;border-bottom:1rpx solid #e5e5e5;background:#fff}.van-tab__bd--fixed{position:fixed;top:0;z-index:2}.van-tab__item{-webkit-box-flex:1;flex:1;display:inline-block;padding:0 5px;line-height:0;box-sizing:border-box;overflow:hidden;text-align:center}.van-tab__title{display:inline-block;max-width:100%;height:44px;line-height:44px;overflow:hidden;text-overflow:ellipsis;box-sizing:border-box;word-break:keep-all;font-size:14px;color:#666}.van-tab__item--selected .van-tab__title{color:#f44;border-bottom:2px solid #f44}.van-tab__bd--scroll{display:block;white-space:nowrap}.van-tab__bd--scroll .van-tab__item{min-width:80px}

10
dist/toast/index.js vendored
View File

@ -1,5 +1,7 @@
'use strict';
var _extends = Object.assign || function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; };
var DEFAULT_DATA = {
show: false,
message: '',
@ -11,11 +13,11 @@ var DEFAULT_DATA = {
var SUPPORT_TYPE = ['loading', 'success', 'fail'];
Component({
data: Object.assign({}, DEFAULT_DATA),
data: _extends({}, DEFAULT_DATA),
methods: {
show: function show(options) {
var toastOptions = Object.assign({}, options);
var toastOptions = _extends({}, options);
var icon = options.icon || '';
var image = options.image || '';
@ -24,13 +26,13 @@ Component({
image = '';
}
this.setData(Object.assign({}, toastOptions, {
this.setData(_extends({}, toastOptions, {
icon: icon,
image: image
}));
},
clear: function clear() {
this.setData(Object.assign({}, DEFAULT_DATA));
this.setData(_extends({}, DEFAULT_DATA));
}
}
});

10
dist/toast/toast.js vendored
View File

@ -1,5 +1,7 @@
'use strict';
var _extends = Object.assign || function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; };
var TOAST_CONFIG_KEY = 'vant.__zanToastPageConfig';
var DEFAULT_SHOW_TOAST_TIME = 3000;
@ -39,7 +41,7 @@ function Toast(optionsOrMsg, pageCtx) {
var ctx = getPageCtx(pageCtx);
var pageToastUserSetting = getPageToastConfig(ctx);
var parsedOptions = Object.assign({}, globalToastUserConfig, pageToastUserSetting, options);
var parsedOptions = _extends({}, globalToastUserConfig, pageToastUserSetting, options);
var toastCtx = ctx.selectComponent(parsedOptions.selector);
if (!toastCtx) {
@ -51,7 +53,7 @@ function Toast(optionsOrMsg, pageCtx) {
Toast.clear();
}
toastCtx.show(Object.assign({}, parsedOptions, {
toastCtx.show(_extends({}, parsedOptions, {
show: true
}));
@ -85,7 +87,7 @@ Toast.setDefaultOptions = function () {
};
if (type === 'global') {
globalToastUserConfig = Object.assign({}, parsedDefaultOptions);
globalToastUserConfig = _extends({}, parsedDefaultOptions);
} else if (type === 'page') {
var _ctx$setData;
@ -126,7 +128,7 @@ Toast.clear = function () {
Toast.loading = function () {
var options = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};
Toast(Object.assign({}, options, {
Toast(_extends({}, options, {
type: 'loading'
}));
};

54
dist/toptips/index.js vendored
View File

@ -1,54 +0,0 @@
'use strict';
var FONT_COLOR = '#fff';
var BG_COLOR = '#e64340';
Component({
properties: {
content: String,
color: {
type: String,
value: FONT_COLOR
},
backgroundColor: {
type: String,
value: BG_COLOR
},
isShow: {
type: Boolean,
value: false
},
duration: {
type: Number,
value: 3000
}
},
methods: {
show: function show() {
var _this = this;
var duration = this.data.duration;
this._timer && clearTimeout(this._timer);
this.setData({
isShow: true
});
if (duration > 0 && duration !== Infinity) {
this._timer = setTimeout(function () {
_this.hide();
}, duration);
}
},
hide: function hide() {
this._timer = clearTimeout(this._timer);
this.setData({
isShow: false,
backgroundColor: BG_COLOR
});
}
}
});

View File

@ -1,3 +0,0 @@
{
"component": true
}

View File

@ -1 +0,0 @@
<view class="van-toptips {{ isShow ? 'van-toptips--show' : '' }}" style="background-color:{{ backgroundColor }}">{{ content }}</view>

View File

@ -1 +0,0 @@
.van-toptips{display:block;position:fixed;-webkit-transform:translateZ(0) translateY(-100%);width:100%;min-height:32px;top:0;line-height:2.3;font-size:14px;text-align:center;color:#fff;background-color:#e64340;z-index:110;opacity:0;-webkit-transition:all .4s ease;transition:all .4s ease}.van-toptips--show{-webkit-transform:translateZ(0) translateY(0);opacity:1}

View File

@ -1,28 +0,0 @@
'use strict';
function Toptips() {
var options = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};
var pages = getCurrentPages();
var ctx = pages[pages.length - 1];
var defaultOptions = {
selector: '#van-toptips',
duration: 3000
};
options = Object.assign(defaultOptions, parseParam(options));
var $toptips = ctx.selectComponent(options.selector);
delete options.selector;
$toptips.setData(Object.assign({}, options));
$toptips && $toptips.show();
}
function parseParam() {
var params = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : '';
return typeof params === 'object' ? params : { content: params };
}
module.exports = Toptips;

View File

@ -1,5 +1,7 @@
'use strict';
var _extends = Object.assign || function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; };
var ITEM_HEIGHT = 44;
Component({
@ -40,24 +42,22 @@ Component({
methods: {
// 当一个子项被选择时
onItemSelect: function onItemSelect(_ref) {
var _ref$currentTarget = _ref.currentTarget,
currentTarget = _ref$currentTarget === undefined ? {} : _ref$currentTarget;
var _currentTarget$datase = currentTarget.dataset,
data = _currentTarget$datase === undefined ? {} : _currentTarget$datase;
onItemSelect: function onItemSelect(event) {
var _ref = event.currentTarget || {},
_ref$dataset = _ref.dataset,
dataset = _ref$dataset === undefined ? {} : _ref$dataset;
this.triggerEvent('itemclick', Object.assign({}, data.item || {}));
this.triggerEvent('itemclick', _extends({}, dataset.item || {}));
},
// 当一个导航被点击时
handleNavClick: function handleNavClick(_ref2) {
var _ref2$currentTarget = _ref2.currentTarget,
currentTarget = _ref2$currentTarget === undefined ? {} : _ref2$currentTarget;
var _currentTarget$datase2 = currentTarget.dataset,
data = _currentTarget$datase2 === undefined ? {} : _currentTarget$datase2;
handleNavClick: function handleNavClick(event) {
var _ref2 = event.currentTarget || {},
_ref2$dataset = _ref2.dataset,
dataset = _ref2$dataset === undefined ? {} : _ref2$dataset;
this.triggerEvent('navclick', { index: data.index });
this.triggerEvent('navclick', { index: dataset.index });
},

View File

@ -1,5 +1,5 @@
<template>
<van-doc :config="config">
<van-doc :config="config" simulator="./preview.html">
<router-view />
</van-doc>
</template>

37
docs/src/Preview.vue Normal file
View File

@ -0,0 +1,37 @@
<template>
<div>
<img :src="image">
</div>
</template>
<script>
const PREFIX = 'https://img.yzcdn.cn/vant-weapp/';
const MAP = {
index: 'index-201808090730.png'
};
export default {
computed: {
image() {
return PREFIX + MAP.index;
}
}
};
</script>
<style>
body {
margin: 0;
color: #333;
line-height: 1;
background-color: #f8f8f8;
font-family: 'PingFang SC', Helvetica, 'STHeiti STXihei', 'Microsoft YaHei', Tohoma, Arial, sans-serif;
-webkit-font-smoothing: antialiased;
}
img {
width: 100%;
display: block;
margin-top: -62px;
}
</style>

View File

@ -81,10 +81,6 @@ module.exports = {
path: '/steps',
title: 'Steps 步骤条'
},
{
path: '/tab',
title: 'Tab 标签页'
},
{
path: '/tag',
title: 'Tag 标记'
@ -94,18 +90,10 @@ module.exports = {
{
groupName: '表单组件',
list: [
{
path: '/checkbox',
title: 'Checkbox 复选框'
},
{
path: '/field',
title: 'Field 输入框'
},
{
path: '/radio',
title: 'Radio 单选框'
},
{
path: '/search',
title: 'Search 搜索'
@ -126,18 +114,6 @@ module.exports = {
{
path: '/actionsheet',
title: 'Actionsheet 上拉菜单'
},
{
path: '/datetime-picker',
title: 'DatetimePicker 时间选择'
},
{
path: '/dialog',
title: 'Dialog 弹出框'
},
{
path: '/toast',
title: 'Toast 轻提示'
}
]
},

View File

@ -8,25 +8,19 @@ export default {
'button': () => import('../../packages/button/README.md'),
'card': () => import('../../packages/card/README.md'),
'cell': () => import('../../packages/cell/README.md'),
'checkbox': () => import('../../packages/checkbox/README.md'),
'col': () => import('../../packages/col/README.md'),
'common': () => import('../../packages/common/README.md'),
'datetime-picker': () => import('../../packages/datetime-picker/README.md'),
'dialog': () => import('../../packages/dialog/README.md'),
'field': () => import('../../packages/field/README.md'),
'icon': () => import('../../packages/icon/README.md'),
'loading': () => import('../../packages/loading/README.md'),
'notice-bar': () => import('../../packages/notice-bar/README.md'),
'panel': () => import('../../packages/panel/README.md'),
'popup': () => import('../../packages/popup/README.md'),
'radio': () => import('../../packages/radio/README.md'),
'search': () => import('../../packages/search/README.md'),
'stepper': () => import('../../packages/stepper/README.md'),
'steps': () => import('../../packages/steps/README.md'),
'switch': () => import('../../packages/switch/README.md'),
'tab': () => import('../../packages/tab/README.md'),
'tag': () => import('../../packages/tag/README.md'),
'toast': () => import('../../packages/toast/README.md'),
'toptips': () => import('../../packages/toptips/README.md'),
'tree-select': () => import('../../packages/tree-select/README.md')
};

7
docs/src/preview.js Normal file
View File

@ -0,0 +1,7 @@
import Vue from 'vue';
import Preview from './Preview.vue';
new Vue({
el: '#app',
render: h => h(Preview)
});

View File

@ -3,34 +3,26 @@
"pages/dashboard/index",
"pages/actionsheet/index",
"pages/button/index",
"pages/checkbox/index",
"pages/badge/index",
"pages/card/index",
"pages/cell/index",
"pages/dialog/index",
"pages/field/index",
"pages/common/index",
"pages/icon/index",
"pages/layout/index",
"pages/loading/index",
"pages/notice-bar/index",
"pages/panel/index",
"pages/popup/index",
"pages/radio/index",
"pages/stepper/index",
"pages/steps/index",
"pages/switch/index",
"pages/search/index",
"pages/tab/index",
"pages/tag/index",
"pages/toptips/index",
"pages/toast/index",
"pages/tree-select/index",
"pages/datetime/index"
"pages/tree-select/index"
],
"window": {
"navigationBarBackgroundColor": "#FAFAFA",
"navigationBarTitleText": "vant-weapp",
"navigationBarTitleText": "Vant Weapp",
"navigationBarTextStyle": "black",
"backgroundTextStyle": "dark",
"backgroundColor": "#f8f8f8"

View File

@ -1,17 +0,0 @@
var Zan = require('../../dist/index');
Page({
data: {
items: [
{value: 'a'},
{value: 'b', checked: true},
{value: 'c'},
]
},
handleCheckboxChange: function(e) {
console.log('checkbox发生change事件携带value值为', e.detail)
console.log('items:', this.data.items)
}
});

View File

@ -1,9 +0,0 @@
{
"navigationBarTitleText": "Checkbox 选择",
"usingComponents": {
"van-checkbox-group": "../../dist/checkbox-group/index",
"van-checkbox": "../../dist/checkbox/index",
"van-panel": "../../dist/panel/index",
"van-cell": "../../dist/cell/index"
}
}

View File

@ -1,41 +0,0 @@
<van-panel title='基本用法'>
<van-checkbox
checkbox-class="checkbox-demo"
bindchange="handleCheckboxChange"
>复选框</van-checkbox>
</van-panel>
<van-panel title='禁用状态'>
<van-checkbox
checkbox-class="checkbox-demo"
disabled
checked="{{ true }}"
>复选框</van-checkbox>
</van-panel>
<van-panel title='禁用内容部分点击事件'>
<van-checkbox
checkbox-class="checkbox-demo"
label-disabled
>复选框</van-checkbox>
</van-panel>
<van-panel title='Checkbox组'>
<van-checkbox-group>
<van-checkbox
wx:for="{{ items }}"
wx:for-item="item"
wx:for-index="index"
wx:key="{{ value }}"
checked="{{ item.checked }}"
data-index="{{ index }}"
bindchange="handleCheckboxChange"
>复选框 {{ item.value }}</van-checkbox>
</van-checkbox-group>
</van-panel>
<van-panel title='列表模式'>
<van-checkbox type="list">复选框 a</van-checkbox>
<van-checkbox type="list">复选框 b</van-checkbox>
<van-checkbox type="list">复选框 c</van-checkbox>
</van-panel>

View File

@ -1,4 +0,0 @@
.checkbox-demo {
display: block;
margin: 15px 0;
}

View File

@ -1 +0,0 @@
Page({});

View File

@ -1,6 +0,0 @@
{
"navigationBarTitleText": "内置样式",
"usingComponents": {
"demo-block": "../../components/demo-block/index"
}
}

View File

@ -1,7 +0,0 @@
<demo-block title="文字省略">
<view class="van-ellipsis ellipsis">这是一段宽度限制 250px 的文字,后面的内容会省略</view>
</demo-block>
<demo-block title="1px 边框">
<view class="van-hairline--top hairline" />
</demo-block>

View File

@ -1,14 +0,0 @@
.ellipsis {
font-size: 13px;
margin-left: 15px;
max-width: 250px;
}
.hairline {
height: 30px;
background-color: #fff;
}
.hairline::after {
top: 15px;
}

View File

@ -2,10 +2,6 @@ export default {
base: {
title: '基础组件',
content: [
{
name: '内置样式',
path: '/pages/common/index'
},
{
name: 'Layout 布局',
path: '/pages/layout/index'
@ -46,10 +42,6 @@ export default {
name: 'Steps 步骤条',
path: '/pages/steps/index'
},
{
name: 'Tab 标签',
path: '/pages/tab/index'
},
{
name: 'Tag 标记',
path: '/pages/tag/index'
@ -59,18 +51,10 @@ export default {
form: {
title: '表单',
content: [
{
name: 'Checkbox 复选框',
path: '/pages/checkbox/index'
},
{
name: 'Field 输入框',
path: '/pages/field/index'
},
{
name: 'Radio 单选框',
path: '/pages/radio/index'
},
{
name: 'Search 搜索',
path: '/pages/search/index'
@ -91,22 +75,6 @@ export default {
{
name: 'Actionsheet 上拉菜单',
path: '/pages/actionsheet/index'
},
{
name: 'Dialog 弹出框',
path: '/pages/dialog/index'
},
{
name: 'DatetimePicker 时间选择器',
path: '/pages/datetime/index'
},
{
name: 'Toast 轻提示',
path: '/pages/toast/index'
},
{
name: 'TopTips 顶部提示',
path: '/pages/toptips/index'
}
]
},

View File

@ -1,21 +0,0 @@
Page({
onLoad () {
setTimeout(() => {
this.setData({
date: new Date('2300/12/12').getTime()
})
}, 100)
},
customChange ({detail}) {
this.setData({pickerView1: detail.value.join('-')})
},
nativeChange ({detail}) {
this.setData({pickerView2: detail.value.join('-')})
},
change ({ detail: { value, date } }) {
console.log('value is', value, 'and date is', date)
}
})

View File

@ -1,9 +0,0 @@
{
"navigationBarTitleText": "时间选择器",
"usingComponents": {
"van-date-picker": "../../dist/datetime-picker/index",
"van-cell": "../../dist/cell/index",
"van-cell-group": "../../dist/cell-group/index",
"van-panel": "../../dist/panel/index"
}
}

View File

@ -1,55 +0,0 @@
<van-panel class="picker-panel-demo">
<van-cell-group>
<van-cell title="选择时间">
<van-date-picker
slot="footer"
date="{{ date }}"
bindchange="change"
bindcancel="cancel"
placeholder="异步初始值"
placeholder-class="my-customer-class-name"
/>
</van-cell>
<van-cell title="选择时间">
<van-date-picker
slot="footer"
not-use="{{['years', 'seconds']}}"
bindchange="change"
bindcancel="cancel"
placeholder="只显示部分列的 picker"
/>
</van-cell>
<van-cell title="选择时间">
<van-date-picker
slot="footer"
bindchange="change"
bindcancel="cancel"
placeholder="自定义显示格式的 picker"
format="选择的是YYYY-MM-DD HH:mm:ss"
/>
</van-cell>
</van-cell-group>
</van-panel>
<van-panel class="picker-panel-demo">
<van-cell title="选择时间" value="{{pickerView1 || '自定义组件'}}"></van-cell>
<van-date-picker
picker-view
bindchange="customChange"
bindcancel="cancel"
/>
</van-panel>
<van-panel class="picker-panel-demo">
<van-cell title="选择时间" value="{{ pickerView2 || '只显示部分列'}}"></van-cell>
<van-date-picker
picker-view
bindchange="nativeChange"
bindcancel="cancel"
not-use="{{['years', 'seconds']}}"
/>
</van-panel>

View File

@ -1,9 +0,0 @@
.my-customer-class {
font-size: 16px;
margin-top: 15px;
margin-left: 15px;
}
.picker-panel-demo {
display: block;
margin-top: 15px;
}

View File

@ -1,140 +0,0 @@
const Dialog = require('../../dist/dialog/dialog');
const Toast = require('../../dist/toast/toast');
Page({
toggleBaseDialog() {
Dialog({
title: '弹窗',
message: '这是一个模态弹窗\n换行',
selector: '#van-base-dialog',
showCancelButton: true
}).then(() => {
console.log('=== dialog resolve ===', 'type: confirm');
}).catch(() => {
console.log('=== dialog reject ===', 'type: cancel');
});
},
toggleWithoutTitleDialog() {
Dialog({
message: '这是一个模态弹窗',
selector: '#van-no-title-dialog'
}).then(() => {
console.log('=== dialog ===', 'type: confirm');
});
},
toggleButtonDialog() {
Dialog({
title: '弹窗',
message: '这是一个模态弹窗',
selector: '#van-button-dialog',
buttons: [{
text: '现金支付',
color: 'red',
type: 'cash'
}, {
text: '分享',
type: 'share',
openType: 'share'
}, {
text: '微信支付',
color: '#3CC51F',
type: 'wechat'
}, {
text: '取消',
type: 'cancel'
}]
}).then(({ type }) => {
console.log('=== dialog with custom buttons ===', `type: ${type}`);
});
},
toggleVerticalDialog() {
Dialog({
title: '弹窗',
message: '这是一个模态弹窗',
selector: '#van-vertical-dialog',
buttonsShowVertical: true,
buttons: [{
text: '现金支付',
color: 'red',
type: 'cash'
}, {
text: '微信支付',
color: '#3CC51F',
type: 'wechat'
}, {
text: '分享',
type: 'share',
openType: 'share'
}, {
text: '取消',
type: 'cancel'
}]
}).then(({ type }) => {
console.log('=== dialog with vertical buttons ===', `type: ${type}`);
});
},
toggleOpenDialog() {
Dialog({
title: '弹窗',
message: '获取用户数据',
selector: '#van-open-dialog',
buttons: [{
text: '用户信息',
type: 'userInfo',
openType: 'getUserInfo'
}, {
text: '获取手机号',
type: 'tel',
openType: 'getPhoneNumber'
}, {
text: '打开授权页',
type: 'setting',
openType: 'openSetting'
}]
}).then(({ type, hasOpenDataPromise, openDataPromise }) => {
console.log(type);
// 如果没有 open 数据返回,就不处理
if (!hasOpenDataPromise) {
return;
}
openDataPromise.then((data) => {
console.log('成功获取信息', data);
}).catch((data) => {
console.log('获取信息失败', data);
});
});
},
toggleCloseDialog() {
Dialog({
title: '弹窗',
message: '这是一个自由控制关闭的弹窗',
selector: '#van-close-dialog',
autoClose: false
}).then(() => {
console.log('=== dialog resolve ===', 'type: confirm');
Toast.loading({
selector: '#van-toast'
});
// 2s 后自动关闭弹窗
setTimeout(() => {
Dialog.close({ selector: '#van-close-dialog' });
Toast.clear();
}, 2000);
});
},
onShareAppMessage() {
return {
title: 'vant-weapp',
imageUrl: 'https://img.yzcdn.cn/public_files/2017/02/06/ee0ebced79a80457d77ce71c7d414c74.png'
};
},
});

View File

@ -1,8 +0,0 @@
{
"navigationBarTitleText": "Dialog 弹出框",
"usingComponents": {
"van-dialog": "../../dist/dialog/index",
"van-button": "../../dist/button/index",
"van-toast": "../../dist/toast/index"
}
}

View File

@ -1,17 +0,0 @@
<van-button bindtap="toggleBaseDialog">基础 Dialog</van-button>
<van-button bindtap="toggleWithoutTitleDialog">Dialog - 无标题</van-button>
<van-button bindtap="toggleButtonDialog">Dialog - 自定义显示按钮</van-button>
<van-button bindtap="toggleVerticalDialog">Dialog - 按钮纵向排布</van-button>
<van-button bindtap="toggleOpenDialog">Dialog - 获取 Open 数据的弹窗</van-button>
<van-button bindtap="toggleCloseDialog">Dialog - 控制弹窗关闭</van-button>
<van-dialog id="van-base-dialog"></van-dialog>
<van-dialog id="van-no-title-dialog"></van-dialog>
<van-dialog id="van-button-dialog"></van-dialog>
<van-dialog id="van-vertical-dialog"></van-dialog>
<van-dialog id="van-open-dialog"></van-dialog>
<van-dialog id="van-close-dialog"></van-dialog>
<van-toast id="van-toast"></van-toast>

View File

@ -1,19 +0,0 @@
Page({
data: {
items: [
{name: 'USA', value: '美国'},
{name: 'CHN', value: '中国', checked: 'true'}
],
items1: [
{name: 'USA', value: '美国'},
{name: 'BRA', value: '巴西', disabled: true },
{name: 'CHN', value: '中国', checked: 'true'}
]
},
handleRadioChange: function(e) {
console.log('radio发生change事件携带value值为', e.detail)
}
});

View File

@ -1,8 +0,0 @@
{
"navigationBarTitleText": "Radio 单选框",
"usingComponents": {
"van-radio": "../../dist/radio/index",
"van-panel": "../../dist/panel/index",
"van-cell": "../../dist/cell/index"
}
}

View File

@ -1,33 +0,0 @@
<van-panel title='基本用法'>
<van-radio
items="{{ items }}"
></van-radio>
</van-panel>
<van-panel title='禁用状态'>
<van-radio
items="{{ items1 }}"
></van-radio>
</van-panel>
<van-panel title='事件'>
<van-radio
items="{{ items }}"
bind:change="handleRadioChange"
></van-radio>
</van-panel>
<van-panel title='自定义样式'>
<van-radio
items="{{ items }}"
radio-color="radio-color"
radio-class="radio-demo"
></van-radio>
</van-panel>
<van-panel title='列表模式'>
<van-radio
items="{{ items }}"
type="list"
></van-radio>
</van-panel>

View File

@ -1,8 +0,0 @@
.radio-demo {
font-size: 12px !important;
}
.radio-color {
background-color: red !important;
border-color: red !important;
}

View File

@ -1,57 +0,0 @@
Page({
data: {
tab: {
list: [{
id: 1,
title: '选项1'
}, {
id: 2,
title: '选项2'
}, {
id: 3,
title: '选项3'
}],
selectedId: 1
},
tab1: {
list: [{
id: 'all',
title: '全部'
}, {
id: 'topay',
title: '待付款'
}, {
id: 'tosend',
title: '待发货'
}, {
id: 'send',
title: '待收货'
}],
selectedId: 'all'
},
tab2: {
list: [{
id: '1',
title: '最新商品1'
}, {
id: '2',
title: '最新商品2'
}, {
id: '3',
title: '最新商品3'
}, {
id: '4',
title: '最新商品4'
}, {
id: '5',
title: '最新商品5'
}, {
id: '6',
title: '最新商品6'
}],
selectedId: '1',
scroll: true,
height: 45
}
}
});

View File

@ -1,6 +0,0 @@
{
"navigationBarTitleText": "Tab 标签",
"usingComponents": {
"van-tab": "../../dist/tab/index"
}
}

View File

@ -1,22 +0,0 @@
<view style="margin: 30px 0">
<van-tab
list="{{ tab.list }}"
selected-id="{{ tab.selectedId }}"
/>
</view>
<view style="margin: 30px 0">
<van-tab
list="{{ tab1.list }}"
selected-id="{{ tab1.selectedId }}"
/>
</view>
<view style="margin: 30px 0">
<van-tab
list="{{ tab2.list }}"
selected-id="{{ tab2.selectedId }}"
scroll="{{ tab2.scroll }}"
height="{{ tab2.height }}"
/>
</view>

View File

@ -1,59 +0,0 @@
const Toast = require('../../dist/toast/toast');
Page({
data: {},
showToast() {
Toast.setDefaultOptions({
selector: '#van-toast-test'
});
Toast('toast的内容');
},
showIconToast() {
Toast({
type: 'fail',
message: 'toast的内容',
selector: '#van-toast-test'
});
},
showImageToast() {
Toast({
message: 'toast的内容',
selector: '#van-toast-test',
image: 'https://b.yzcdn.cn/v2/image/dashboard/secured_transaction/suc_green@2x.png'
});
},
showLoadingToast() {
Toast({
type: 'loading',
message: 'toast的内容',
selector: '#van-toast-test'
});
},
showOnlyIcon() {
Toast({
type: 'fail',
selector: '#van-toast-test'
});
},
showEverToast() {
Toast({
message: 'toast的内容',
selector: '#van-toast-test',
timeout: -1
});
},
showLoading() {
Toast.loading({
message: '加载中',
selector: '#van-toast-test'
});
}
});

View File

@ -1,7 +0,0 @@
{
"navigationBarTitleText": "Toast 轻提示",
"usingComponents": {
"van-button": "../../dist/button/index",
"van-toast": "../../dist/toast/index"
}
}

View File

@ -1,34 +0,0 @@
<import src="/dist/toast/index.wxml" />
<view class="container">
<van-button bind:tap="showToast">
显示toast
</van-button>
<van-button bind:tap="showIconToast">
显示 Icon 图标的toast
</van-button>
<van-button bind:tap="showImageToast">
自定义图片作为图标的toast
</van-button>
<van-button bind:tap="showLoadingToast">
显示 Loading toast
</van-button>
<van-button bind:tap="showOnlyIcon">
只显示图标的toast
</van-button>
<van-button bind:tap="showEverToast">
不消失的的toast
</van-button>
<van-button bind:tap="showLoading">
显示 Loading
</van-button>
</view>
<!-- <template is="van-toast" data="{{ zanToast }}"></template> -->
<van-toast id="van-toast-test"></van-toast>

View File

@ -1,44 +0,0 @@
const Toptips = require('../../dist/toptips/toptips');
Page({
data: {
content: '测试toptips',
duration: 2000,
$vant: {
toptips: {
show: false
}
}
},
showTopTips() {
this.setData({
$vant: {
toptips: {
show: true
}
}
});
setTimeout(() => {
this.setData({
$vant: {
toptips: {
show: false
}
}
});
},this.data.duration);
},
showTopTips2() {
Toptips('测试内容');
},
showTopTips3() {
Toptips({
duration: 1000,
content: '测试时间1秒'
})
}
});

View File

@ -1,7 +0,0 @@
{
"navigationBarTitleText": "Toptips 顶部提示",
"usingComponents": {
"van-button": "../../dist/button/index",
"van-toptips": "../../dist/toptips/index"
}
}

View File

@ -1,25 +0,0 @@
<view style="margin-top: 30vh;">
<van-button bind:tap="showTopTips">
显示toptips声明式调用
</van-button>
</view>
<view style="margin-top: 30px;">
<van-button bind:tap="showTopTips2">
显示toptips命令式调用
</van-button>
</view>
<view style="margin-top: 30px;">
<van-button bind:tap="showTopTips3">
显示toptips持续一秒
</van-button>
</view>
<van-toptips
id="van-toptips"
content="{{ content }}"
is-show="{{ $vant.toptips.show }}"
/>

View File

@ -10,7 +10,7 @@
"lint": "eslint ./packages --ext .js",
"release": "sh scripts/release.sh",
"build": "sh scripts/deploy.sh",
"build:lib": "cross-env NODE_ENV=production node scripts/build-components.js --color",
"build:lib": "cross-env NODE_ENV=production node build/build-components.js --color",
"build:site": "rm -rf docs/dist && cross-env NODE_ENV=production webpack --config build/webpack.doc.js && gh-pages -d docs/dist"
},
"files": [

View File

@ -1,26 +0,0 @@
const CHECKBOX_PATH = '../checkbox/index';
Component({
relations: {
[CHECKBOX_PATH]: {
type: 'child',
linked() {
this.updateChildren(CHECKBOX_PATH);
}
}
},
data: {
elementUpdateTimeout: 0
},
methods: {
updateChildren(childPath) { // 把checkbox标记为在group中设置不同样式
const elements = this.getRelationNodes(childPath);
elements.forEach((checkbox, index) => {
checkbox.updateData({ isInGroup: true });
});
}
}
});

View File

@ -1,3 +0,0 @@
{
"component": true
}

View File

@ -1,7 +0,0 @@
.checkbox-group {
padding-bottom: 10px;
background-color: #fff;
}
.checkbox-group .van-checkbox {
margin-top: 10px;
}

View File

@ -1,3 +0,0 @@
<view class="checkbox-group">
<slot></slot>
</view>

View File

@ -1,100 +0,0 @@
## Checkbox 复选框
### 使用指南
在 index.json 中引入组件
```json
{
"usingComponents": {
"van-checkbox": "/packages/checkbox/index"
}
}
```
### 代码演示
#### 基础用法
```html
<van-checkbox
checkbox-class="checkbox-demo"
bindchange="handleCheckboxChange"
>复选框</van-checkbox>
```
#### 基础用法
```html
<van-checkbox
checkbox-class="checkbox-demo"
bindchange="handleCheckboxChange"
>复选框</van-checkbox>
```
#### 禁用状态
```html
<van-checkbox
checkbox-class="checkbox-demo"
disabled
checked="{{ true }}"
>复选框</van-checkbox>
```
#### 禁用内容部分点击事件
```html
<van-checkbox
checkbox-class="checkbox-demo"
label-disabled
>复选框</van-checkbox>
```
#### Checkbox组
```html
<van-checkbox-group>
<van-checkbox
wx:for="{{ items }}"
wx:for-item="item"
wx:for-index="index"
wx:key="{{ value }}"
checked="{{ item.checked }}"
data-index="{{ index }}"
bindchange="handleCheckboxChange"
>复选框 {{ item.name }}</van-checkbox>
</van-checkbox-group>
```
```js
Page({
data: {
items: [
{value: 'a'},
{value: 'b', checked: true},
{value: 'c'},
]
}
});
```
#### 列表模式
```html
<van-checkbox type="list">复选框 a</van-checkbox>
<van-checkbox type="list">复选框 b</van-checkbox>
<van-checkbox type="list">复选框 c</van-checkbox>
```
### 参数
| 参数 | 说明 | 类型 | 默认值 | 必须 |
|-----------|-----------|-----------|-------------|-------------|
| checked | 是否选中 | Boolean| false | |
| disabled | 是否可用 | Boolean| false | |
| labelDisabled | 文字区域是否可选 | Boolean | false | |
| type | 显示类型 | String | - | |
### 事件
| 事件名称 | 说明 | 回调参数 |
| ---- | --- | ---|
| change | 数值改变时修改 | checked值|

View File

@ -1,42 +0,0 @@
const CHECKBOX_GROUP_PATH = '../checkbox-group/index';
Component({
externalClasses: ['checkbox-class'],
relations: {
[CHECKBOX_GROUP_PATH]: {
type: 'parent'
}
},
properties: {
checked: Boolean,
disabled: Boolean,
isInGroup: Boolean,
labelDisabled: Boolean,
type: String
},
data() {
return {
isInGroup: false,
isInCell: false
};
},
methods: {
handleClick() {
if (this.data.disabled) {
return;
}
const checked = !this.data.checked;
this.triggerEvent('change', checked);
this.setData({ checked });
},
updateData(data) {
this.setData(data);
}
}
});

View File

@ -1,6 +0,0 @@
{
"component": true,
"usingComponents": {
"van-icon": "../icon/index"
}
}

View File

@ -1,39 +0,0 @@
.van-checkbox {
display: inline-block;
padding: 0 10px;
font-size: 14px;
&__item {
display: block;
margin-top: 10px;
}
&__list-item {
display: block;
padding: 10px 10px 10px 0;
margin-left: 10px;
border-bottom: 1px solid #e5e5e5;
.van-checkbox__icon {
float: right;
}
}
&__icon {
display: inline-flex;
align-items: center;
color: #aaa;
&.van-checkbox--checked {
color: #06bf04;
}
&.van-checkbox--disabled {
color: #e5e5e5;
}
}
&__label {
display: inline-block;
margin-left: 10px;
}
}

View File

@ -1,13 +0,0 @@
<view
class="checkbox-class van-checkbox {{ isInGroup ? 'van-checkbox__item' : ''}} {{ type === 'list' ? 'van-checkbox__list-item' : ''}}"
bindtap="{{ labelDisabled ? '' : 'handleClick' }}"
>
<van-icon
type="{{ checked ? 'checked' : 'check'}}"
class="van-checkbox__icon {{ disabled ? 'van-checkbox--disabled' : '' }} {{ checked ? 'van-checkbox--checked' : '' }}"
bindtap="{{ labelDisabled ? 'handleClick': '' }}"
></van-icon>
<text class="van-checkbox__label">
<slot></slot>
</text>
</view>

View File

@ -1,49 +0,0 @@
## DatetimePicker 时间选择
使用 picker 组件开发的时间日期组件,弥补小程序 picker 自身对于快速时间选择的不支持。
### 使用指南
在 index.json 中引入组件
```json
{
"usingComponents": {
"van-date-picker": "path/to/vant-weapp/dist/datetime-picker/index"
}
}
```
### 代码演示
可以在任意位置上使用 van-date-picker 标签。
```wxml
<van-date-picker
bindchange="change"
bindcancel="cancel"
placeholder="请选择一个时间"
placeholder-class="my-customer-class-name"
format="你选择了YYYY年MM月DD日HH点mm分ss秒"
/>
```
### 属性与事件
| 名称 | 类型 | 是否必须 | 默认 | 描述 |
| ----------------- | --------- | -------- | ------------------- | ----------------------------------------------------------------------------------------------------- |
| date | `String` | `否` | 当前时间 | 初始化时间,传入的值会被 Date 构造函数转换为一个 Date 对象,不合法的值将抛出一个错误 |
| placeholder-class | `String` | `否` | 无 | 自定义类,可改变 placeholder 样式,其他类无效,`picker-view` 为 true 时不支持 |
| placeholder | `String` | `否` | 请选择时间 | 设置 picker 的 placeholder,`picker-view` 为 true 时不支持 |
| not-use | `Array` | `否` | 无 | 不需要显示的列 可选择`years`, `months`, `days`, `hours`, `minutes`, `seconds`中的多个 |
| picker-view | `Boolean` | `否` | 无 | 如果为 true相当于 picker-view 组件 |
| format | `String` | `否` | YYYY-MM-DD HH:mm:ss | 设置选中的时间显示的格式,支持 _YYYYyyyyYYyyMMMDDddDdHH hhHhmmmsss_ |
| bindchange | `String` | `是` | 无 | 用户点击`确认`触发该事件,返回值为按“年,月,日,时,分,秒”顺序的数组,可以通过`detail.value`获取3.0.8 后新增 date 值,表示当前选择时间的对象 |
| bindcancel | `String` | `否` | 无 | 用户点击`取消`触发该事件 |
### 方法
| 名称 | 参数 | 描述 |
| ------------ | ---- | --------------------------------------------------------------- |
| getFormatStr | 无 | 返回 `format` 格式的字符串,在 `picker-view` 为 true 时比较实用 |
### 增强优化
支持可选择时间区域限制

View File

@ -1,35 +0,0 @@
<import src="./picker-view-column.wxml" />
<template name="date-picker-view">
<picker-view
value="{{ selected }}"
bindchange="change"
indicator-style="height: 50px;"
class="picker-visible">
<template
is="picker-view-column"
data="{{ data: dataList[0], className: 'year-view-column', hidden: !use['years'], tip: '年' }}"
/>
<template
is="picker-view-column"
data="{{ data: dataList[1], hidden: !use['months'], tip: '月' }}"
/>
<template
is="picker-view-column"
data="{{ data: dataList[2], hidden: !use['days'], tip: '日' }}"
/>
<template
is="picker-view-column"
data="{{ data: dataList[3], hidden: !use['hours'], tip: '时' }}"
/>
<template
is="picker-view-column"
data="{{ data: dataList[4], hidden: !use['minutes'], tip: '分' }}"
/>
<template
is="picker-view-column"
data="{{ data: dataList[5], hidden: !use['seconds'], tip: '秒' }}"
/>
</picker-view>
</template>

View File

@ -1,97 +0,0 @@
const LIMIT_YEAR_COUNT = 50;
const { genNumber, iso2utc } = require('./utils')
module.exports = class DatePicker {
constructor(date = new Date()) {
this.types = ['year', 'month', 'day', 'hour', 'minute', 'second'];
this.months = genNumber(1, 12, 2);
this.hours = genNumber(0, 23, 2);
this.seconds = genNumber(0, 59, 2);
this.minutes = genNumber(0, 59, 2);
this._date = date
}
getYears(year) {
let mid = Math.floor(LIMIT_YEAR_COUNT / 2);
let min = year - mid;
let max = year + (LIMIT_YEAR_COUNT - mid);
return genNumber(min, max, 4);
}
lastDay(year, month) {
return month !== 12 ? new Date(
new Date(`${year}/${month + 1}/1`).getTime() - (24 * 60 * 60 * 1000)
).getDate() : 31;
}
getData (date) {
date = date || this._date || new Date
// toUTCString ISO 格式部分 ios 手机会失败
if (new Date(date).toString() === 'Invalid Date' && typeof date === 'string' && date.indexOf('-') > 0) {
date = iso2utc(date)
}
let d = new Date(date);
let y = d.getFullYear();
let m = d.getMonth() + 1;
let years = this.getYears(y);
let lastDay = this.lastDay(y, m);
let days = genNumber(1, lastDay, 2);
this._years = years;
this._dataList = [years, this.months, days, this.hours, this.minutes, this.seconds];
this._indexs = [25, m - 1, d.getDate() - 1, d.getHours(), d.getMinutes(), d.getSeconds()];
return {
dataList: this._dataList,
selected: this._indexs
}
}
update(col, index) {
let type = this.types[col];
switch (type) {
case 'year':
return this._updateYear(col, index);
case 'month':
return this._updateMonth(col, index);
default:
this._indexs[col] = index;
return [{ col, index }]
}
}
_updateYear(col, index, cb) {
let years = this._dataList[col];
let year = years[index];
this._dataList[col] = this.getYears(+year);
this._indexs[col] = Math.floor(LIMIT_YEAR_COUNT / 2);
return [{ col: 0, index: this._indexs[col], data: this._dataList[col] }]
}
_updateMonth(col, index) {
let month = this._dataList[col][index];
let year = this._dataList[0][this._indexs[0]];
let lastDay = this.lastDay(+year, +month);
this._indexs[col] = index;
this._dataList[2] = genNumber(1, lastDay, 2);
this._indexs[2] = this._indexs[2] >= this._dataList[2].length ? this._dataList[2].length - 1 : this._indexs[2];
return [
{
col: 1,
index
},
{
col: 2,
index: this._indexs[2],
data: this._dataList[2]
}
]
}
}

View File

@ -1,181 +0,0 @@
const DatePicker = require('./date-picker')
const { genNumber, moment } = require('./utils')
Component({
properties: {
placeholder: {
type: String,
value: '请选择时间'
},
format: {
type: String,
value: 'YYYY-MM-DD HH:mm:ss'
},
pickerView: {
type: Boolean
},
date: {
type: String,
observer(value) {
if (value === ({}).toString()) {
throw new Error('参数必须是一个字符串')
}
if (/^[0-9]+$/.test(value)) {
value = +value
}
!this._inited && this._init()
this.updateDate(value)
}
},
notUse: {
type: Array
}
},
externalClasses: ['placeholder-class'],
data: {
transPos: [0, 0, 0, 0, 0, 0]
},
attached() {
!this._inited && this._init()
},
methods: {
_init () {
this._inited = true
this.use = {};
['years', 'months', 'days', 'hours', 'minutes', 'seconds'].forEach((item) => {
if ((this.data.notUse || []).indexOf(item) === -1) {
this.use[item] = true
}
});
this.picker = new DatePicker(this.data.date)
let { dataList, selected } = this.picker.getData(this.data.date)
// 鬼他么知道为什么 dataList, selected 不能一起 setData
this.setData({
use: this.use,
dataList
}, () => {
this.setData({
selected
})
});
this._indexs = selected
},
updatePicker(updateData = []) {
let _updateData = {};
for (const { col, index, data } of updateData) {
if (~index && this._indexs[col] !== index || col === 0) {
_updateData[`selected[${col}]`] = index // 更新索引
this._indexs[col] = index
}
if (data) {
_updateData[`dataList[${col}]`] = data;
}
}
this.setData(_updateData);
},
updateDate (date) {
let { dataList, selected } = this.picker.getData(date)
this._indexs = selected
// 好像必须要等到 datalist 完成
this.setData({ dataList }, () => {
this.setData({
selected,
text: this.getFormatStr()
})
})
},
getFormatStr() {
let date = new Date();
['FullYear', 'Month', 'Date', 'Hours', 'Minutes', 'Seconds'].forEach((key, index) => {
let value = this.data.dataList[index][this._indexs[index]];
if (key === 'Month') {
value = +this.data.dataList[index][this._indexs[index]] - 1;
}
date[`set${key}`](+value);
});
return moment(date, this.data.format);
},
showPicker() {
this.setData({
show: true
});
},
hidePicker(e) {
let { action } = e.currentTarget.dataset;
this.setData({
show: false
});
if (action === 'cancel') {
this.cancel({
detail: {}
});
} else {
this.change({
detail: {
value: this._indexs
}
});
}
},
columnchange(e) {
let { column, value } = e.detail;
let updateData = this.picker.update(column, value);
this.updatePicker(updateData)
},
change(e) {
let { value } = e.detail;
let data = this.data.dataList.map((item, index) => {
return +item[value[index]];
});
let day = data.slice(0, 3)
let time = data.slice(3, 6)
let date = new Date(`${ day.join('/') } ${ time.join(':') }`)
this.triggerEvent('change', {
value: data,
date
});
// 手动触发 columnchange
for (let index = 0; index < value.length; index++) {
if (this._indexs[index] !== value[index]) {
this.columnchange({
detail: {
column: index,
value: value[index]
}
})
}
}
this.setData({
text: this.getFormatStr()
});
},
cancel(e) {
this.triggerEvent('cancel', e.detail);
}
}
});

View File

@ -1,6 +0,0 @@
{
"component": true,
"usingComponents": {
"pop-manager": "../common/pop-manager/index"
}
}

Some files were not shown because too many files have changed in this diff Show More