mirror of
https://gitee.com/vant-contrib/vant-weapp.git
synced 2025-04-05 19:41:45 +08:00
[Doc] temporary remove some components
This commit is contained in:
parent
28b95839d4
commit
cbe9eb27d6
@ -1,5 +1,5 @@
|
||||
const path = require('path');
|
||||
const extracter = require('./utils/extracter');
|
||||
const extracter = require('./extracter');
|
||||
|
||||
extracter({
|
||||
src: path.resolve(__dirname, '../packages'),
|
||||
|
@ -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
|
||||
})
|
||||
]
|
||||
};
|
||||
|
30
dist/button/behaviors.js
vendored
30
dist/button/behaviors.js
vendored
@ -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 || {});
|
||||
}
|
||||
}
|
||||
});
|
2
dist/card/index.wxss
vendored
2
dist/card/index.wxss
vendored
@ -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}
|
2
dist/cell/index.wxss
vendored
2
dist/cell/index.wxss
vendored
@ -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}
|
29
dist/checkbox-group/index.js
vendored
29
dist/checkbox-group/index.js
vendored
@ -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 });
|
||||
});
|
||||
}
|
||||
}
|
||||
});
|
3
dist/checkbox-group/index.json
vendored
3
dist/checkbox-group/index.json
vendored
@ -1,3 +0,0 @@
|
||||
{
|
||||
"component": true
|
||||
}
|
3
dist/checkbox-group/index.wxml
vendored
3
dist/checkbox-group/index.wxml
vendored
@ -1,3 +0,0 @@
|
||||
<view class="checkbox-group">
|
||||
<slot></slot>
|
||||
</view>
|
1
dist/checkbox-group/index.wxss
vendored
1
dist/checkbox-group/index.wxss
vendored
@ -1 +0,0 @@
|
||||
.checkbox-group{padding-bottom:10px;background-color:#fff}.checkbox-group .van-checkbox{margin-top:10px}
|
44
dist/checkbox/index.js
vendored
44
dist/checkbox/index.js
vendored
@ -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);
|
||||
}
|
||||
}
|
||||
});
|
6
dist/checkbox/index.json
vendored
6
dist/checkbox/index.json
vendored
@ -1,6 +0,0 @@
|
||||
{
|
||||
"component": true,
|
||||
"usingComponents": {
|
||||
"van-icon": "../icon/index"
|
||||
}
|
||||
}
|
13
dist/checkbox/index.wxml
vendored
13
dist/checkbox/index.wxml
vendored
@ -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>
|
1
dist/checkbox/index.wxss
vendored
1
dist/checkbox/index.wxss
vendored
@ -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
102
dist/common/helper.js
vendored
@ -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
|
||||
};
|
35
dist/datetime-picker/date-picker-view.wxml
vendored
35
dist/datetime-picker/date-picker-view.wxml
vendored
@ -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>
|
105
dist/datetime-picker/date-picker.js
vendored
105
dist/datetime-picker/date-picker.js
vendored
@ -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;
|
||||
}();
|
216
dist/datetime-picker/index.js
vendored
216
dist/datetime-picker/index.js
vendored
@ -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);
|
||||
}
|
||||
}
|
||||
});
|
6
dist/datetime-picker/index.json
vendored
6
dist/datetime-picker/index.json
vendored
@ -1,6 +0,0 @@
|
||||
{
|
||||
"component": true,
|
||||
"usingComponents": {
|
||||
"pop-manager": "../common/pop-manager/index"
|
||||
}
|
||||
}
|
18
dist/datetime-picker/index.wxml
vendored
18
dist/datetime-picker/index.wxml
vendored
@ -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>
|
53
dist/datetime-picker/index.wxss
vendored
53
dist/datetime-picker/index.wxss
vendored
@ -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;
|
||||
}
|
6
dist/datetime-picker/picker-view-column.wxml
vendored
6
dist/datetime-picker/picker-view-column.wxml
vendored
@ -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>
|
124
dist/datetime-picker/utils.js
vendored
124
dist/datetime-picker/utils.js
vendored
@ -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
26
dist/dialog/data.js
vendored
@ -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
104
dist/dialog/dialog.js
vendored
@ -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
133
dist/dialog/index.js
vendored
@ -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 });
|
||||
}
|
||||
}
|
||||
});
|
7
dist/dialog/index.json
vendored
7
dist/dialog/index.json
vendored
@ -1,7 +0,0 @@
|
||||
{
|
||||
"component": true,
|
||||
"usingComponents": {
|
||||
"pop-manager": "../common/pop-manager/index",
|
||||
"van-button": "../button/index"
|
||||
}
|
||||
}
|
40
dist/dialog/index.wxml
vendored
40
dist/dialog/index.wxml
vendored
@ -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>
|
1
dist/dialog/index.wxss
vendored
1
dist/dialog/index.wxss
vendored
@ -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}
|
2
dist/field/index.wxss
vendored
2
dist/field/index.wxss
vendored
@ -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}
|
2
dist/notice-bar/index.wxss
vendored
2
dist/notice-bar/index.wxss
vendored
@ -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
33
dist/radio/index.js
vendored
@ -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 });
|
||||
}
|
||||
}
|
||||
});
|
6
dist/radio/index.json
vendored
6
dist/radio/index.json
vendored
@ -1,6 +0,0 @@
|
||||
{
|
||||
"component": true,
|
||||
"usingComponents": {
|
||||
"van-icon": "../icon/index"
|
||||
}
|
||||
}
|
28
dist/radio/index.wxml
vendored
28
dist/radio/index.wxml
vendored
@ -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>
|
1
dist/radio/index.wxss
vendored
1
dist/radio/index.wxss
vendored
@ -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}
|
2
dist/search/index.wxss
vendored
2
dist/search/index.wxss
vendored
@ -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
4
dist/steps/index.js
vendored
@ -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)
|
||||
});
|
||||
});
|
||||
|
2
dist/steps/index.wxss
vendored
2
dist/steps/index.wxss
vendored
@ -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
61
dist/tab/index.js
vendored
@ -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
3
dist/tab/index.json
vendored
@ -1,3 +0,0 @@
|
||||
{
|
||||
"component": true
|
||||
}
|
51
dist/tab/index.wxml
vendored
51
dist/tab/index.wxml
vendored
@ -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
1
dist/tab/index.wxss
vendored
@ -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
10
dist/toast/index.js
vendored
@ -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
10
dist/toast/toast.js
vendored
@ -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
54
dist/toptips/index.js
vendored
@ -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
|
||||
});
|
||||
}
|
||||
}
|
||||
});
|
3
dist/toptips/index.json
vendored
3
dist/toptips/index.json
vendored
@ -1,3 +0,0 @@
|
||||
{
|
||||
"component": true
|
||||
}
|
1
dist/toptips/index.wxml
vendored
1
dist/toptips/index.wxml
vendored
@ -1 +0,0 @@
|
||||
<view class="van-toptips {{ isShow ? 'van-toptips--show' : '' }}" style="background-color:{{ backgroundColor }}">{{ content }}</view>
|
1
dist/toptips/index.wxss
vendored
1
dist/toptips/index.wxss
vendored
@ -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}
|
28
dist/toptips/toptips.js
vendored
28
dist/toptips/toptips.js
vendored
@ -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;
|
24
dist/tree-select/index.js
vendored
24
dist/tree-select/index.js
vendored
@ -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 });
|
||||
},
|
||||
|
||||
|
||||
|
@ -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
37
docs/src/Preview.vue
Normal 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>
|
@ -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 轻提示'
|
||||
}
|
||||
]
|
||||
},
|
||||
|
@ -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
7
docs/src/preview.js
Normal file
@ -0,0 +1,7 @@
|
||||
import Vue from 'vue';
|
||||
import Preview from './Preview.vue';
|
||||
|
||||
new Vue({
|
||||
el: '#app',
|
||||
render: h => h(Preview)
|
||||
});
|
@ -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"
|
||||
|
@ -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)
|
||||
}
|
||||
});
|
@ -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"
|
||||
}
|
||||
}
|
@ -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>
|
@ -1,4 +0,0 @@
|
||||
.checkbox-demo {
|
||||
display: block;
|
||||
margin: 15px 0;
|
||||
}
|
@ -1 +0,0 @@
|
||||
Page({});
|
@ -1,6 +0,0 @@
|
||||
{
|
||||
"navigationBarTitleText": "内置样式",
|
||||
"usingComponents": {
|
||||
"demo-block": "../../components/demo-block/index"
|
||||
}
|
||||
}
|
@ -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>
|
@ -1,14 +0,0 @@
|
||||
.ellipsis {
|
||||
font-size: 13px;
|
||||
margin-left: 15px;
|
||||
max-width: 250px;
|
||||
}
|
||||
|
||||
.hairline {
|
||||
height: 30px;
|
||||
background-color: #fff;
|
||||
}
|
||||
|
||||
.hairline::after {
|
||||
top: 15px;
|
||||
}
|
@ -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'
|
||||
}
|
||||
]
|
||||
},
|
||||
|
@ -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)
|
||||
}
|
||||
})
|
@ -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"
|
||||
}
|
||||
}
|
@ -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>
|
||||
|
@ -1,9 +0,0 @@
|
||||
.my-customer-class {
|
||||
font-size: 16px;
|
||||
margin-top: 15px;
|
||||
margin-left: 15px;
|
||||
}
|
||||
.picker-panel-demo {
|
||||
display: block;
|
||||
margin-top: 15px;
|
||||
}
|
@ -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'
|
||||
};
|
||||
},
|
||||
});
|
@ -1,8 +0,0 @@
|
||||
{
|
||||
"navigationBarTitleText": "Dialog 弹出框",
|
||||
"usingComponents": {
|
||||
"van-dialog": "../../dist/dialog/index",
|
||||
"van-button": "../../dist/button/index",
|
||||
"van-toast": "../../dist/toast/index"
|
||||
}
|
||||
}
|
@ -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>
|
@ -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)
|
||||
}
|
||||
});
|
@ -1,8 +0,0 @@
|
||||
{
|
||||
"navigationBarTitleText": "Radio 单选框",
|
||||
"usingComponents": {
|
||||
"van-radio": "../../dist/radio/index",
|
||||
"van-panel": "../../dist/panel/index",
|
||||
"van-cell": "../../dist/cell/index"
|
||||
}
|
||||
}
|
@ -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>
|
@ -1,8 +0,0 @@
|
||||
.radio-demo {
|
||||
font-size: 12px !important;
|
||||
}
|
||||
|
||||
.radio-color {
|
||||
background-color: red !important;
|
||||
border-color: red !important;
|
||||
}
|
@ -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
|
||||
}
|
||||
}
|
||||
});
|
@ -1,6 +0,0 @@
|
||||
{
|
||||
"navigationBarTitleText": "Tab 标签",
|
||||
"usingComponents": {
|
||||
"van-tab": "../../dist/tab/index"
|
||||
}
|
||||
}
|
@ -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>
|
@ -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'
|
||||
});
|
||||
}
|
||||
});
|
@ -1,7 +0,0 @@
|
||||
{
|
||||
"navigationBarTitleText": "Toast 轻提示",
|
||||
"usingComponents": {
|
||||
"van-button": "../../dist/button/index",
|
||||
"van-toast": "../../dist/toast/index"
|
||||
}
|
||||
}
|
@ -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>
|
@ -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秒'
|
||||
})
|
||||
}
|
||||
});
|
@ -1,7 +0,0 @@
|
||||
{
|
||||
"navigationBarTitleText": "Toptips 顶部提示",
|
||||
"usingComponents": {
|
||||
"van-button": "../../dist/button/index",
|
||||
"van-toptips": "../../dist/toptips/index"
|
||||
}
|
||||
}
|
@ -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 }}"
|
||||
/>
|
||||
|
||||
|
@ -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": [
|
||||
|
@ -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 });
|
||||
});
|
||||
}
|
||||
}
|
||||
});
|
@ -1,3 +0,0 @@
|
||||
{
|
||||
"component": true
|
||||
}
|
@ -1,7 +0,0 @@
|
||||
.checkbox-group {
|
||||
padding-bottom: 10px;
|
||||
background-color: #fff;
|
||||
}
|
||||
.checkbox-group .van-checkbox {
|
||||
margin-top: 10px;
|
||||
}
|
@ -1,3 +0,0 @@
|
||||
<view class="checkbox-group">
|
||||
<slot></slot>
|
||||
</view>
|
@ -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值|
|
@ -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);
|
||||
}
|
||||
}
|
||||
});
|
@ -1,6 +0,0 @@
|
||||
{
|
||||
"component": true,
|
||||
"usingComponents": {
|
||||
"van-icon": "../icon/index"
|
||||
}
|
||||
}
|
@ -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;
|
||||
}
|
||||
}
|
@ -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>
|
@ -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 | 设置选中的时间显示的格式,支持 _YYYY,yyyy,YY,yy,MM,M,DD,dd,D,d,HH, hh,H,h,mm,m,ss,s_ |
|
||||
| bindchange | `String` | `是` | 无 | 用户点击`确认`触发该事件,返回值为按“年,月,日,时,分,秒”顺序的数组,可以通过`detail.value`获取;3.0.8 后新增 date 值,表示当前选择时间的对象 |
|
||||
| bindcancel | `String` | `否` | 无 | 用户点击`取消`触发该事件 |
|
||||
|
||||
### 方法
|
||||
|
||||
| 名称 | 参数 | 描述 |
|
||||
| ------------ | ---- | --------------------------------------------------------------- |
|
||||
| getFormatStr | 无 | 返回 `format` 格式的字符串,在 `picker-view` 为 true 时比较实用 |
|
||||
|
||||
### 增强优化
|
||||
|
||||
支持可选择时间区域限制
|
@ -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>
|
@ -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]
|
||||
}
|
||||
]
|
||||
}
|
||||
}
|
@ -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);
|
||||
}
|
||||
}
|
||||
});
|
@ -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
Loading…
x
Reference in New Issue
Block a user