[bugfix] Card: currency default value (#525)

This commit is contained in:
neverland 2018-09-07 10:32:16 +08:00 committed by GitHub
parent 4f5b777360
commit c176dee9a2
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
44 changed files with 418 additions and 375 deletions

View File

@ -1,9 +1,7 @@
Component({
options: {
addGlobalClass: true
},
import { create } from '../common/create';
properties: {
create({
props: {
show: Boolean,
title: String,
cancelText: String,
@ -26,16 +24,16 @@ Component({
const { index } = event.currentTarget.dataset;
const item = this.data.actions[index];
if (item && !item.disabled && !item.loading) {
this.triggerEvent('select', item);
this.$emit('select', item);
}
},
onCancel() {
this.triggerEvent('cancel');
this.$emit('cancel');
},
onClose() {
this.triggerEvent('close');
this.$emit('close');
}
}
});

View File

@ -1,14 +1,8 @@
const BADGE_PATH = '../badge/index';
Component({
options: {
addGlobalClass: true
},
externalClasses: ['custom-class'],
import { create } from '../common/create';
create({
relations: {
[BADGE_PATH]: {
'../badge/index': {
type: 'descendant',
linked(target) {
@ -23,13 +17,11 @@ Component({
}
},
properties: {
props: {
active: {
type: Number,
value: 0,
observer() {
this.setActive();
}
observer: 'setActive'
}
},
@ -53,7 +45,7 @@ Component({
}
if (this.currentActive !== -1) {
this.triggerEvent('change', active);
this.$emit('change', active);
}
this.currentActive = active;

16
dist/badge/index.js vendored
View File

@ -1,26 +1,20 @@
const BADGE_GROUP_PATH = '../badge-group/index';
Component({
options: {
addGlobalClass: true
},
externalClasses: ['custom-class'],
import { create } from '../common/create';
create({
relations: {
[BADGE_GROUP_PATH]: {
'../badge-group/index': {
type: 'ancestor'
}
},
properties: {
props: {
info: Number,
title: String
},
methods: {
onClick() {
const group = this.getRelationNodes(BADGE_GROUP_PATH)[0];
const group = this.getRelationNodes('../badge-group/index')[0];
if (group) {
group.setActive(this);
}

21
dist/button/index.js vendored
View File

@ -1,21 +1,16 @@
import buttonBehaviors from '../behaviors/button';
import classnames from '../common/classnames';
import { create } from '../common/create';
import { classNames } from '../common/class-names';
import { button } from '../mixins/button';
const booleanProp = {
type: Boolean,
observer: 'setClasses'
};
Component({
options: {
addGlobalClass: true
},
create({
mixins: [button],
externalClasses: ['custom-class', 'loading-class'],
behaviors: [buttonBehaviors],
properties: {
props: {
type: {
type: String,
value: 'default',
@ -40,14 +35,14 @@ Component({
methods: {
onClick() {
if (!this.data.disabled && !this.data.loading) {
this.triggerEvent('click');
this.$emit('click');
}
},
setClasses() {
const { type, size, plain, disabled, loading, square, block } = this.data;
this.setData({
classes: classnames(`van-button--${type}`, `van-button--${size}`, {
classes: classNames(`van-button--${type}`, `van-button--${size}`, {
'van-button--block': block,
'van-button--plain': plain,
'van-button--square': square,

14
dist/card/index.js vendored
View File

@ -1,11 +1,7 @@
Component({
options: {
multipleSlots: true,
addGlobalClass: true
},
import { create } from '../common/create';
externalClasses: [
'custom-class',
create({
classes: [
'thumb-class',
'title-class',
'price-class',
@ -13,7 +9,7 @@ Component({
'num-class'
],
properties: {
props: {
num: String,
desc: String,
thumb: String,
@ -22,7 +18,7 @@ Component({
centered: Boolean,
currency: {
type: String,
default: '¥'
value: '¥'
}
}
});

View File

@ -1,11 +1,7 @@
Component({
options: {
addGlobalClass: true
},
import { create } from '../common/create';
externalClasses: ['custom-class'],
properties: {
create({
props: {
border: {
type: Boolean,
value: true

16
dist/cell/index.js vendored
View File

@ -1,6 +1,7 @@
Component({
externalClasses: [
'custom-class',
import { create } from '../common/create';
create({
classes: [
'title-class',
'label-class',
'value-class',
@ -8,12 +9,7 @@ Component({
'right-icon-class'
],
options: {
multipleSlots: true,
addGlobalClass: true
},
properties: {
props: {
title: null,
value: null,
url: String,
@ -42,7 +38,7 @@ Component({
if (url) {
wx[this.data.linkType]({ url });
}
this.triggerEvent('click');
this.$emit('click');
}
}
});

14
dist/col/index.js vendored
View File

@ -1,19 +1,13 @@
const ROW_PATH = '../row/index';
Component({
options: {
addGlobalClass: true
},
externalClasses: ['custom-class'],
import { create } from '../common/create';
create({
relations: {
[ROW_PATH]: {
'../row/index': {
type: 'ancestor'
}
},
properties: {
props: {
span: Number,
offset: Number
},

29
dist/common/class-names.js vendored Normal file
View File

@ -0,0 +1,29 @@
const hasOwn = {}.hasOwnProperty;
export function classNames() {
const classes = [];
for (let i = 0; i < arguments.length; i++) {
const arg = arguments[i];
if (!arg) continue;
const argType = typeof arg;
if (argType === 'string' || argType === 'number') {
classes.push(arg);
} else if (Array.isArray(arg) && arg.length) {
const inner = classNames.apply(null, arg);
if (inner) {
classes.push(inner);
}
} else if (argType === 'object') {
for (const key in arg) {
if (hasOwn.call(arg, key) && arg[key]) {
classes.push(key);
}
}
}
}
return classes.join(' ');
};

39
dist/common/create.js vendored Normal file
View File

@ -0,0 +1,39 @@
function $emit() {
this.triggerEvent.apply(this, arguments);
}
export function create(sfc) {
// map props to properties
if (sfc.props) {
sfc.properties = sfc.props;
delete sfc.props;
}
// map mixins to behaviors
if (sfc.mixins) {
sfc.behaviors = sfc.mixins;
delete sfc.mixins;
}
// map field to form-field behavior
if (sfc.field) {
sfc.behaviors = sfc.behaviors || [];
sfc.behaviors.push('wx://form-field');
}
// add default options
sfc.options = sfc.options || {};
sfc.options.multipleSlots = true;
sfc.options.addGlobalClass = true;
// add default externalClasses
sfc.externalClasses = sfc.classes || [];
sfc.externalClasses.push('custom-class');
// add default methods
sfc.methods = sfc.methods || {};
sfc.methods.$emit = $emit;
Component(sfc);
};

13
dist/common/utils.js vendored Normal file
View File

@ -0,0 +1,13 @@
function isDef(value) {
return value !== undefined && value !== null;
}
function isObj(x) {
const type = typeof x;
return x !== null && (type === 'object' || type === 'function');
}
export {
isObj,
isDef
};

12
dist/dialog/index.js vendored
View File

@ -1,9 +1,7 @@
Component({
options: {
addGlobalClass: true
},
import { create } from '../common/create';
properties: {
create({
props: {
title: String,
message: String,
useSlot: Boolean,
@ -79,8 +77,8 @@ Component({
if (!this.data.asyncClose) {
this.setData({ show: false });
}
this.triggerEvent('close', action);
this.triggerEvent(action);
this.$emit('close', action);
this.$emit(action);
}
}
});

40
dist/field/index.js vendored
View File

@ -1,16 +1,11 @@
Component({
behaviors: ['wx://form-field'],
import { create } from '../common/create';
externalClasses: [
'input-class'
],
create({
field: true,
options: {
multipleSlots: true,
addGlobalClass: true
},
classes: ['input-class'],
properties: {
props: {
icon: String,
label: String,
error: Boolean,
@ -68,8 +63,8 @@ Component({
methods: {
onInput(event) {
const { value = '' } = event.detail || {};
this.triggerEvent('input', value);
this.triggerEvent('change', value);
this.$emit('input', value);
this.$emit('change', value);
this.setData({
value,
showClear: this.getShowClear({ value })
@ -77,7 +72,7 @@ Component({
},
onFocus(event) {
this.triggerEvent('focus', event);
this.$emit('focus', event);
this.setData({
focused: true,
showClear: this.getShowClear({ focused: true })
@ -86,7 +81,7 @@ Component({
onBlur(event) {
this.focused = false;
this.triggerEvent('blur', event);
this.$emit('blur', event);
this.setData({
focused: false,
showClear: this.getShowClear({ focused: false })
@ -94,16 +89,15 @@ Component({
},
onClickIcon() {
this.triggerEvent('click-icon');
this.$emit('click-icon');
},
getShowClear(options) {
const {
focused = this.data.focused,
value = this.data.value
} = options;
const { focused = this.data.focused, value = this.data.value } = options;
return this.data.clearable && focused && value !== '' && !this.data.readonly;
return (
this.data.clearable && focused && value !== '' && !this.data.readonly
);
},
onClear() {
@ -111,12 +105,12 @@ Component({
value: '',
showClear: this.getShowClear({ value: '' })
});
this.triggerEvent('input', '');
this.triggerEvent('change', '');
this.$emit('input', '');
this.$emit('change', '');
},
onConfirm() {
this.triggerEvent('confirm', this.data.value);
this.$emit('confirm', this.data.value);
}
}
});

12
dist/icon/index.js vendored
View File

@ -1,11 +1,7 @@
Component({
options: {
addGlobalClass: true
},
import { create } from '../common/create';
externalClasses: ['custom-class'],
properties: {
create({
props: {
info: null,
name: String,
size: String,
@ -18,7 +14,7 @@ Component({
methods: {
onClick() {
this.triggerEvent('click');
this.$emit('click');
}
}
});

10
dist/loading/index.js vendored
View File

@ -1,11 +1,7 @@
Component({
options: {
addGlobalClass: true
},
import { create } from '../common/create';
externalClasses: ['custom-class'],
properties: {
create({
props: {
size: {
type: String,
value: '30px'

57
dist/mixins/button.js vendored Normal file
View File

@ -0,0 +1,57 @@
export const button = Behavior({
properties: {
loading: Boolean,
// 在自定义组件中,无法与外界的 form 组件联动,暂时不开放
// formType: String,
openType: String,
appParameter: String,
// 暂时不开放,直接传入无法设置样式
// hoverClass: {
// type: String,
// value: 'button-hover'
// },
hoverStopPropagation: Boolean,
hoverStartTime: {
type: Number,
value: 20
},
hoverStayTime: {
type: Number,
value: 70
},
lang: {
type: String,
value: 'en'
},
sessionFrom: {
type: String,
value: ''
},
sendMessageTitle: String,
sendMessagePath: String,
sendMessageImg: String,
showMessageCard: String
},
methods: {
bindgetuserinfo(event = {}) {
this.$emit('getuserinfo', event.detail || {});
},
bindcontact(event = {}) {
this.$emit('contact', event.detail || {});
},
bindgetphonenumber(event = {}) {
this.$emit('getphonenumber', event.detail || {});
},
bindopensetting(event = {}) {
this.$emit('opensetting', event.detail || {});
},
binderror(event = {}) {
this.$emit('error', event.detail || {});
}
}
});

22
dist/mixins/touch.js vendored Normal file
View File

@ -0,0 +1,22 @@
export const touch = Behavior({
methods: {
touchStart(event) {
this.direction = '';
this.deltaX = 0;
this.deltaY = 0;
this.offsetX = 0;
this.offsetY = 0;
this.startX = event.touches[0].clientX;
this.startY = event.touches[0].clientY;
},
touchMove(event) {
const touch = event.touches[0];
this.deltaX = touch.clientX - this.startX;
this.deltaY = touch.clientY - this.startY;
this.offsetX = Math.abs(this.deltaX);
this.offsetY = Math.abs(this.deltaY);
this.direction = this.offsetX > this.offsetY ? 'horizontal' : this.offsetX < this.offsetY ? 'vertical' : '';
}
}
});

54
dist/mixins/transition.js vendored Normal file
View File

@ -0,0 +1,54 @@
export const transition = function(showDefaultValue) {
return Behavior({
properties: {
customStyle: String,
show: {
value: showDefaultValue,
type: Boolean,
observer(value) {
if (value) {
this.show();
} else {
this.setData({
type: 'leave'
});
}
}
},
duration: {
type: Number,
value: 300
}
},
data: {
type: '',
inited: false,
display: false
},
attached() {
if (this.data.show) {
this.show();
}
},
methods: {
show() {
this.setData({
inited: true,
display: true,
type: 'enter'
});
},
onAnimationEnd() {
if (!this.data.show) {
this.setData({
display: false
});
}
}
}
});
};

18
dist/nav-bar/index.js vendored
View File

@ -1,15 +1,9 @@
Component({
externalClasses: [
'custom-class',
'title-class'
],
import { create } from '../common/create';
options: {
multipleSlots: true,
addGlobalClass: true
},
create({
classes: ['title-class'],
properties: {
props: {
title: String,
leftText: String,
rightText: String,
@ -23,11 +17,11 @@ Component({
methods: {
onClickLeft() {
this.triggerEvent('click-left');
this.$emit('click-left');
},
onClickRight() {
this.triggerEvent('click-right');
this.$emit('click-right');
}
}
});

View File

@ -1,20 +1,15 @@
const VALID_MODE = ['closeable', 'link'];
import { create } from '../common/create';
const FONT_COLOR = '#f60';
const BG_COLOR = '#fff7cc';
Component({
options: {
addGlobalClass: true
},
externalClasses: ['custom-class'],
properties: {
create({
props: {
text: {
type: String,
value: '',
observer() {
this.setData({}, this._init);
this.setData({}, this.init);
}
},
mode: {
@ -67,8 +62,7 @@ Component({
},
attached() {
const { mode } = this.data;
if (mode && this._checkMode(mode)) {
if (this.data.mode) {
this.setData({
hasRightIcon: true
});
@ -81,15 +75,7 @@ Component({
},
methods: {
_checkMode(val) {
const isValidMode = ~VALID_MODE.indexOf(val);
if (!isValidMode) {
console.warn(`mode only accept value of ${VALID_MODE}, now get ${val}.`);
}
return isValidMode;
},
_init() {
init() {
wx.createSelectorQuery()
.in(this)
.select('.van-notice-bar__content')
@ -132,7 +118,7 @@ Component({
animation,
resetAnimation
}, () => {
this._scroll();
this.scroll();
});
}
})
@ -141,7 +127,7 @@ Component({
.exec();
},
_scroll() {
scroll() {
const {
animation, resetAnimation, wrapWidth, elapse, speed
} = this.data;
@ -157,7 +143,7 @@ Component({
}, 100);
const timer = setTimeout(() => {
this._scroll();
this.scroll();
}, elapse);
this.setData({
@ -165,7 +151,7 @@ Component({
});
},
_handleButtonClick() {
onClickIcon() {
const { timer } = this.data;
timer && clearTimeout(timer);
this.setData({
@ -175,7 +161,7 @@ Component({
},
onClick(event) {
this.triggerEvent('click', event);
this.$emit('click', event);
}
}
});

View File

@ -18,7 +18,7 @@
wx:if="{{ mode === 'closeable' }}"
class="van-notice-bar__right-icon"
name="close"
bind:tap="_handleButtonClick"
bind:tap="onClickIcon"
/>
<navigator
wx:if="{{ mode === 'link' }}"

12
dist/notify/index.js vendored
View File

@ -1,11 +1,7 @@
import Notify from './notify';
import { create } from '../common/create';
Component({
options: {
addGlobalClass: true
},
properties: {
create({
props: {
text: String,
color: {
type: String,
@ -45,5 +41,3 @@ Component({
}
}
});
export default Notify;

10
dist/overlay/index.js vendored
View File

@ -1,9 +1,7 @@
Component({
options: {
addGlobalClass: true
},
import { create } from '../common/create';
properties: {
create({
props: {
show: Boolean,
mask: Boolean,
customStyle: String,
@ -15,7 +13,7 @@ Component({
methods: {
onClick() {
this.triggerEvent('click');
this.$emit('click');
}
}
});

14
dist/panel/index.js vendored
View File

@ -1,15 +1,9 @@
Component({
externalClasses: [
'custom-class',
'footer-class'
],
import { create } from '../common/create';
options: {
multipleSlots: true,
addGlobalClass: true
},
create({
classes: ['footer-class'],
properties: {
props: {
desc: String,
title: String,
status: String,

19
dist/popup/index.js vendored
View File

@ -1,15 +1,10 @@
import transitionBehaviors from '../behaviors/transition';
import { create } from '../common/create';
import { transition } from '../mixins/transition';
Component({
options: {
addGlobalClass: true
},
create({
mixins: [transition(false)],
externalClasses: ['custom-class'],
behaviors: [transitionBehaviors(false)],
properties: {
props: {
overlayStyle: String,
overlay: {
type: Boolean,
@ -27,10 +22,10 @@ Component({
methods: {
onClickOverlay() {
this.triggerEvent('click-overlay');
this.$emit('click-overlay');
if (this.data.closeOnClickOverlay) {
this.triggerEvent('close');
this.$emit('close');
}
}
}

View File

@ -1,13 +1,7 @@
Component({
options: {
addGlobalClass: true
},
import { create } from '../common/create';
externalClasses: [
'custom-class'
],
properties: {
create({
props: {
inactive: {
type: Boolean,
observer() {

20
dist/row/index.js vendored
View File

@ -1,24 +1,16 @@
const COL_PATH = '../col/index';
Component({
options: {
addGlobalClass: true
},
externalClasses: ['custom-class'],
import { create } from '../common/create';
create({
relations: {
[COL_PATH]: {
'../col/index': {
type: 'descendant'
}
},
properties: {
props: {
gutter: {
type: Number,
observer() {
this.setGutter();
}
observer: 'setGutter'
}
},
@ -33,7 +25,7 @@ Component({
const style = gutter ? `margin-right: ${margin}; margin-left: ${margin};` : '';
this.setData({ style });
this.getRelationNodes(COL_PATH).forEach((col) => {
this.getRelationNodes('../col/index').forEach((col) => {
col.setGutter(this.data.gutter);
});
}

25
dist/search/index.js vendored
View File

@ -1,14 +1,11 @@
Component({
behaviors: ['wx://form-field'],
import { create } from '../common/create';
externalClasses: ['custom-class', 'cancel-class'],
create({
field: true,
options: {
multipleSlots: true,
addGlobalClass: true
},
classes: ['cancel-class'],
properties: {
props: {
focus: Boolean,
disabled: Boolean,
readonly: Boolean,
@ -27,25 +24,25 @@ Component({
methods: {
onChange(event) {
this.triggerEvent('change', event.detail);
this.$emit('change', event.detail);
},
onCancel() {
this.setData({ value: '' });
this.triggerEvent('cancel');
this.triggerEvent('change', '');
this.$emit('cancel');
this.$emit('change', '');
},
onSearch() {
this.triggerEvent('search', this.data.value);
this.$emit('search', this.data.value);
},
onFocus() {
this.triggerEvent('focus');
this.$emit('focus');
},
onBlur() {
this.triggerEvent('blur');
this.$emit('blur');
}
}
});

17
dist/slider/index.js vendored
View File

@ -1,15 +1,10 @@
import touchBehaviors from '../behaviors/touch';
import { create } from '../common/create';
import { touch } from '../mixins/touch';
Component({
options: {
addGlobalClass: true
},
create({
mixins: [touch],
externalClasses: ['custom-class'],
behaviors: [touchBehaviors],
properties: {
props: {
disabled: Boolean,
max: {
type: Number,
@ -86,7 +81,7 @@ Component({
});
if (end) {
this.triggerEvent('change', value);
this.$emit('change', value);
}
},

23
dist/stepper/index.js vendored
View File

@ -1,22 +1,19 @@
import { create } from '../common/create';
// Note that the bitwise operators and shift operators operate on 32-bit ints
// so in that case, the max safe integer is 2^31-1, or 2147483647
const MAX = 2147483647;
Component({
behaviors: ['wx://form-field'],
create({
field: true,
options: {
addGlobalClass: true
},
externalClasses: [
'custom-class',
classes: [
'input-class',
'plus-class',
'minus-class'
],
properties: {
props: {
integer: Boolean,
disabled: Boolean,
disableInput: Boolean,
@ -53,20 +50,20 @@ Component({
onChange(type) {
if (this[`${type}Disabled`]) {
this.triggerEvent('overlimit', type);
this.$emit('overlimit', type);
return;
}
const diff = type === 'minus' ? -this.data.step : +this.data.step;
const value = Math.round((this.data.value + diff) * 100) / 100;
this.triggerInput(this.range(value));
this.triggerEvent(type);
this.$emit(type);
},
onBlur(event) {
const value = this.range(this.data.value);
this.triggerInput(value);
this.triggerEvent('blur', event);
this.$emit('blur', event);
},
onMinus() {
@ -79,7 +76,7 @@ Component({
triggerInput(value) {
this.setData({ value });
this.triggerEvent('change', value);
this.$emit('change', value);
}
}
});

20
dist/steps/index.js vendored
View File

@ -1,25 +1,15 @@
Component({
options: {
addGlobalClass: true
},
import { create } from '../common/create';
externalClasses: [
'custom-class'
],
properties: {
create({
props: {
icon: String,
steps: {
type: Array,
observer() {
this.formatSteps();
}
observer: 'formatSteps'
},
active: {
type: Number,
observer() {
this.formatSteps();
}
observer: 'formatSteps'
},
direction: {
type: String,

View File

@ -1,11 +1,9 @@
Component({
behaviors: ['wx://form-field'],
import { create } from '../common/create';
options: {
addGlobalClass: true
},
create({
field: true,
properties: {
props: {
title: String,
border: Boolean,
loading: Boolean,
@ -28,7 +26,7 @@ Component({
methods: {
onChange(event) {
this.triggerEvent('change', event.detail);
this.$emit('change', event.detail);
}
}
});

16
dist/switch/index.js vendored
View File

@ -1,13 +1,11 @@
Component({
behaviors: ['wx://form-field'],
import { create } from '../common/create';
options: {
addGlobalClass: true
},
create({
field: true,
externalClasses: ['custom-class', 'node-class'],
classes: ['node-class'],
properties: {
props: {
loading: Boolean,
disabled: Boolean,
checked: {
@ -30,8 +28,8 @@ Component({
onClick() {
if (!this.data.disabled && !this.data.loading) {
const checked = !this.data.checked;
this.triggerEvent('input', checked);
this.triggerEvent('change', checked);
this.$emit('input', checked);
this.$emit('change', checked);
}
}
}

14
dist/tab/index.js vendored
View File

@ -1,16 +1,12 @@
const TABS_PATH = '../tabs/index';
import { create } from '../common/create';
Component({
options: {
addGlobalClass: true
},
properties: {
create({
props: {
disabled: Boolean,
title: {
type: String,
observer() {
const parent = this.getRelationNodes(TABS_PATH)[0];
const parent = this.getRelationNodes('../tabs/index')[0];
if (parent) {
parent.setLine();
}
@ -19,7 +15,7 @@ Component({
},
relations: {
[TABS_PATH]: {
'../tabs/index': {
type: 'ancestor'
}
},

View File

@ -1,19 +1,14 @@
const TABBAR_PATH = '../tabbar/index';
import { create } from '../common/create';
Component({
properties: {
create({
props: {
info: null,
icon: String,
dot: Boolean
},
options: {
multipleSlots: true,
addGlobalClass: true
},
relations: {
[TABBAR_PATH]: {
'../tabbar/index': {
type: 'ancestor'
}
},
@ -25,11 +20,11 @@ Component({
methods: {
onClick() {
const parent = this.getRelationNodes(TABBAR_PATH)[0];
const parent = this.getRelationNodes('../tabbar/index')[0];
if (parent) {
parent.onChange(this);
}
this.triggerEvent('click');
this.$emit('click');
}
}
});

16
dist/tabbar/index.js vendored
View File

@ -1,13 +1,7 @@
const ITEM_PATH = '../tabbar-item/index';
import { create } from '../common/create';
Component({
options: {
addGlobalClass: true
},
externalClasses: ['custom-class'],
properties: {
create({
props: {
active: {
type: Number,
observer(active) {
@ -35,7 +29,7 @@ Component({
},
relations: {
[ITEM_PATH]: {
'../tabbar-item/index': {
type: 'descendant',
linked(target) {
@ -63,7 +57,7 @@ Component({
onChange(child) {
const active = this.data.items.indexOf(child);
if (active !== this.data.currentActive && active !== -1) {
this.triggerEvent('change', active);
this.$emit('change', active);
this.setData({ currentActive: active });
this.setActiveItem();
}

14
dist/tabs/index.js vendored
View File

@ -1,12 +1,8 @@
const TAB_PATH = '../tab/index';
Component({
options: {
addGlobalClass: true
},
import { create } from '../common/create';
create({
relations: {
[TAB_PATH]: {
'../tab/index': {
type: 'descendant',
linked(target) {
@ -33,7 +29,7 @@ Component({
}
},
properties: {
props: {
color: {
type: String,
observer: 'setLine'
@ -78,7 +74,7 @@ Component({
methods: {
trigger(eventName, index) {
this.triggerEvent(eventName, {
this.$emit(eventName, {
index,
title: this.data.tabs[index].data.title
});

10
dist/tag/index.js vendored
View File

@ -1,11 +1,7 @@
Component({
options: {
addGlobalClass: true
},
import { create } from '../common/create';
externalClasses: ['custom-class'],
properties: {
create({
props: {
type: String,
mark: Boolean,
plain: Boolean

12
dist/toast/index.js vendored
View File

@ -1,11 +1,7 @@
import Toast from './toast';
import { create } from '../common/create';
Component({
options: {
addGlobalClass: true
},
properties: {
create({
props: {
show: Boolean,
mask: Boolean,
message: String,
@ -32,5 +28,3 @@ Component({
}
}
});
export default Toast;

2
dist/toast/toast.js vendored
View File

@ -1,4 +1,4 @@
import { isObj } from '../utils/index';
import { isObj } from '../common/utils';
const defaultOptions = {
type: 'text',

View File

@ -1,15 +1,10 @@
import transitionBehaviors from '../behaviors/transition';
import { create } from '../common/create';
import { transition } from '../mixins/transition';
Component({
options: {
addGlobalClass: true
},
create({
mixins: [transition(true)],
externalClasses: ['custom-class'],
behaviors: [transitionBehaviors(true)],
properties: {
props: {
name: {
type: String,
value: 'fade'

View File

@ -1,11 +1,9 @@
import { create } from '../common/create';
const ITEM_HEIGHT = 44;
Component({
options: {
addGlobalClass: true
},
properties: {
create({
props: {
items: {
type: Array,
observer() {
@ -16,9 +14,7 @@ Component({
mainActiveIndex: {
type: Number,
value: 0,
observer() {
this.updateSubItems();
}
observer: 'updateSubItems'
},
activeId: {
type: Number,
@ -46,7 +42,7 @@ Component({
const {
dataset = {}
} = event.currentTarget || {};
this.triggerEvent('click-item', { ...(dataset.item || {}) });
this.$emit('click-item', { ...(dataset.item || {}) });
},
// 当一个导航被点击时
@ -54,7 +50,7 @@ Component({
const {
dataset = {}
} = event.currentTarget || {};
this.triggerEvent('click-nav', { index: dataset.index });
this.$emit('click-nav', { index: dataset.index });
},
// 更新子项列表

View File

@ -1 +1 @@
.van-ellipsis{overflow:hidden;white-space:nowrap;text-overflow:ellipsis}.van-multi-ellipsis--l2{overflow:hidden;text-overflow:ellipsis;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical}.van-multi-ellipsis--l3{overflow:hidden;text-overflow:ellipsis;display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical}.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}.tree-select{-webkit-user-select:none;user-select:none;position:relative;font-size:16px}.tree-select__nav{width:143px;position:absolute;left:0;top:0;bottom:0;overflow:scroll;background-color:#fff;-webkit-overflow-scrolling:touch}.tree-select__nitem{line-height:44px;padding:0 15px;background-color:#fff}.tree-select__nitem--active{background-color:#f8f8f8}.tree-select__content{padding:0 15px;margin-left:143px;overflow:scroll;-webkit-overflow-scrolling:touch}.tree-select__item{position:relative;line-height:44px;padding-left:5px;padding-right:18px}.tree-select__item--active{color:#f44}.tree-select__selected{float:right;position:absolute;right:0;top:0;bottom:0;line-height:inherit}
.van-ellipsis{overflow:hidden;white-space:nowrap;text-overflow:ellipsis}.van-multi-ellipsis--l2{overflow:hidden;text-overflow:ellipsis;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical}.van-multi-ellipsis--l3{overflow:hidden;text-overflow:ellipsis;display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical}.tree-select{-webkit-user-select:none;user-select:none;position:relative;font-size:16px}.tree-select__nav{width:143px;position:absolute;left:0;top:0;bottom:0;overflow:scroll;background-color:#fff;-webkit-overflow-scrolling:touch}.tree-select__nitem{line-height:44px;padding:0 15px;background-color:#fff}.tree-select__nitem--active{background-color:#f8f8f8}.tree-select__content{padding:0 15px;margin-left:143px;overflow:scroll;-webkit-overflow-scrolling:touch}.tree-select__item{position:relative;line-height:44px;padding-left:5px;padding-right:18px}.tree-select__item--active{color:#f44}.tree-select__selected{float:right;position:absolute;right:0;top:0;bottom:0;line-height:inherit}

View File

@ -18,7 +18,7 @@ create({
centered: Boolean,
currency: {
type: String,
default: '¥'
value: '¥'
}
}
});