chore: add trailingComma

This commit is contained in:
陈嘉涵 2020-01-19 11:57:09 +08:00
parent e841175fe8
commit 389d68884d
269 changed files with 2706 additions and 2702 deletions

View File

@ -1,3 +1,3 @@
module.exports = {
presets: ['@vant/cli/preset']
presets: ['@vant/cli/preset'],
};

View File

@ -53,7 +53,7 @@ export default {
showTitle: '展示标题栏',
showCancel: '展示取消按钮',
showDescription: '展示描述信息',
description: '这是一段描述信息'
description: '这是一段描述信息',
},
'en-US': {
buttonText: 'Show ActionSheet',
@ -63,8 +63,8 @@ export default {
showTitle: 'ActionSheet with title',
showCancel: 'ActionSheet with cancel button',
showDescription: 'ActionSheet with description',
description: 'Description'
}
description: 'Description',
},
},
data() {
@ -73,7 +73,7 @@ export default {
show2: false,
show3: false,
show4: false,
show5: false
show5: false,
};
},
@ -82,7 +82,7 @@ export default {
return [
{ name: this.$t('option') },
{ name: this.$t('option') },
{ name: this.$t('option'), subname: this.$t('subname') }
{ name: this.$t('option'), subname: this.$t('subname') },
];
},
@ -90,9 +90,9 @@ export default {
return [
{ name: this.$t('option'), color: GREEN },
{ loading: true },
{ name: this.$t('disabledOption'), disabled: true }
{ name: this.$t('disabledOption'), disabled: true },
];
}
},
},
methods: {
@ -103,8 +103,8 @@ export default {
onCancel() {
this.$toast('cancel');
}
}
},
},
};
</script>

View File

@ -97,7 +97,7 @@ function ActionSheet(
return [
<span class={bem('name')}>{item.name}</span>,
item.subname && <span class={bem('subname')}>{item.subname}</span>
item.subname && <span class={bem('subname')}>{item.subname}</span>,
];
}
@ -162,24 +162,24 @@ ActionSheet.props = {
closeOnClickAction: Boolean,
round: {
type: Boolean,
default: true
default: true,
},
closeIcon: {
type: String,
default: 'cross'
default: 'cross',
},
safeAreaInsetBottom: {
type: Boolean,
default: true
default: true,
},
overlay: {
type: Boolean,
default: true
default: true,
},
closeOnClickOverlay: {
type: Boolean,
default: true
}
default: true,
},
};
export default createComponent<ActionSheetProps>(ActionSheet);

View File

@ -18,15 +18,15 @@ test('callback events', () => {
propsData: {
value: true,
actions,
cancelText: 'Cancel'
cancelText: 'Cancel',
},
context: {
on: {
input: onInput,
cancel: onCancel,
select: onSelect
}
}
select: onSelect,
},
},
});
const options = wrapper.findAll('.van-action-sheet__item');
@ -58,17 +58,17 @@ test('click overlay and close', async () => {
</div>
`,
components: {
ActionSheet
ActionSheet,
},
data() {
return {
getContainer: () => div
getContainer: () => div,
};
},
methods: {
onInput,
onClickOverlay
}
onClickOverlay,
},
});
await later();
@ -84,10 +84,10 @@ test('disable lazy-render', () => {
lazyRender: false,
actions: [
{ name: 'Option' },
{ name: 'Option' }
{ name: 'Option' },
],
cancelText: 'Cancel'
}
cancelText: 'Cancel',
},
});
expect(wrapper).toMatchSnapshot();
@ -97,13 +97,13 @@ test('render title and default slot', () => {
const wrapper = mount(ActionSheet, {
propsData: {
value: true,
title: 'Title'
title: 'Title',
},
scopedSlots: {
default() {
return 'Default';
}
}
},
},
});
expect(wrapper).toMatchSnapshot();
@ -113,8 +113,8 @@ test('get container', () => {
const wrapper = mount(ActionSheet, {
propsData: {
value: true,
getContainer: 'body'
}
getContainer: 'body',
},
});
expect(wrapper.vm.$el.parentNode).toEqual(document.body);
@ -126,13 +126,13 @@ test('close-on-click-action prop', () => {
propsData: {
value: true,
actions: [{ name: 'Option' }],
closeOnClickAction: true
closeOnClickAction: true,
},
context: {
on: {
input: onInput
}
}
input: onInput,
},
},
});
const option = wrapper.find('.van-action-sheet__item');
@ -146,8 +146,8 @@ test('round prop', () => {
propsData: {
value: true,
round: true,
actions: [{ name: 'Option' }]
}
actions: [{ name: 'Option' }],
},
});
expect(wrapper).toMatchSnapshot();
@ -157,8 +157,8 @@ test('color option', () => {
const wrapper = mount(ActionSheet, {
propsData: {
value: true,
actions: [{ name: 'Option', color: 'red' }]
}
actions: [{ name: 'Option', color: 'red' }],
},
});
expect(wrapper).toMatchSnapshot();
@ -169,8 +169,8 @@ test('description prop', () => {
propsData: {
value: true,
description: 'This is a description',
actions: [{ name: 'Option' }]
}
actions: [{ name: 'Option' }],
},
});
expect(wrapper).toMatchSnapshot();
@ -181,8 +181,8 @@ test('close-icon prop', () => {
propsData: {
value: true,
title: 'Title',
closeIcon: 'cross'
}
closeIcon: 'cross',
},
});
expect(wrapper).toMatchSnapshot();

View File

@ -14,13 +14,13 @@ export default createComponent({
detailRows: Number,
searchResult: Array,
detailMaxlength: Number,
showSearchResult: Boolean
showSearchResult: Boolean,
},
computed: {
shouldShowSearchResult() {
return this.focused && this.searchResult && this.showSearchResult;
}
},
},
methods: {
@ -71,12 +71,12 @@ export default createComponent({
return <div domPropsInnerHTML={text} />;
}
}
},
}}
/>
));
}
}
},
},
render() {
@ -100,5 +100,5 @@ export default createComponent({
{this.genSearchResult()}
</Cell>
);
}
},
});

View File

@ -26,32 +26,32 @@ export default {
areaColumnsPlaceholder: ['请选择', '请选择', '请选择'],
searchResult: [{
name: '黄龙万科中心',
address: '杭州市西湖区'
address: '杭州市西湖区',
}, {
name: '黄龙万科中心G座'
name: '黄龙万科中心G座',
}, {
name: '黄龙万科中心H座',
address: '杭州市西湖区'
}]
address: '杭州市西湖区',
}],
},
'en-US': {
areaColumnsPlaceholder: ['Choose', 'Choose', 'Choose'],
searchResult: [{
name: 'Name1',
address: 'Address'
address: 'Address',
}, {
name: 'Name2'
name: 'Name2',
}, {
name: 'Name3',
address: 'Address'
}]
}
address: 'Address',
}],
},
},
data() {
return {
areaList,
searchResult: []
searchResult: [],
};
},
@ -66,8 +66,8 @@ export default {
onChangeDetail(val) {
this.searchResult = val ? this.$t('searchResult') : [];
}
}
},
},
};
</script>

View File

@ -21,7 +21,7 @@ const defaultData = {
areaCode: '',
postalCode: '',
addressDetail: '',
isDefault: false
isDefault: false,
};
function isPostal(value) {
@ -43,36 +43,36 @@ export default createComponent({
deleteButtonText: String,
showArea: {
type: Boolean,
default: true
default: true,
},
showDetail: {
type: Boolean,
default: true
default: true,
},
detailRows: {
type: Number,
default: 1
default: 1,
},
detailMaxlength: {
type: Number,
default: 200
default: 200,
},
addressInfo: {
type: Object,
default: () => ({ ...defaultData })
default: () => ({ ...defaultData }),
},
telValidator: {
type: Function,
default: isMobile
default: isMobile,
},
postalValidator: {
type: Function,
default: isPostal
default: isPostal,
},
areaColumnsPlaceholder: {
type: Array,
default: () => []
}
default: () => [],
},
},
data() {
@ -85,8 +85,8 @@ export default createComponent({
name: '',
areaCode: '',
postalCode: '',
addressDetail: ''
}
addressDetail: '',
},
};
},
@ -105,7 +105,7 @@ export default createComponent({
return arr.filter(text => text).join('/');
}
return '';
}
},
},
watch: {
@ -113,18 +113,18 @@ export default createComponent({
handler(val) {
this.data = {
...defaultData,
...val
...val,
};
this.setAreaCode(val.areaCode);
},
deep: true,
immediate: true
immediate: true,
},
areaList() {
this.setAreaCode(this.data.areaCode);
}
},
},
methods: {
@ -209,7 +209,7 @@ export default createComponent({
onDelete() {
Dialog.confirm({
title: t('confirmDelete')
title: t('confirmDelete'),
})
.then(() => {
this.$emit('delete', this.data);
@ -243,7 +243,7 @@ export default createComponent({
setTimeout(() => {
this.detailFocused = false;
});
}
},
},
render() {
@ -368,5 +368,5 @@ export default createComponent({
</Popup>
</div>
);
}
},
});

View File

@ -11,7 +11,7 @@ const addressInfo = {
addressDetail: '详细地址',
areaCode: '110101',
postalCode: '10000',
isDefault: true
isDefault: true,
};
const createComponent = () => {
@ -20,8 +20,8 @@ const createComponent = () => {
areaList,
addressInfo,
showPostal: true,
showSetDefault: true
}
showSetDefault: true,
},
});
const button = wrapper.find('.van-button');
@ -33,7 +33,7 @@ const createComponent = () => {
field,
button,
wrapper,
errorInfo
errorInfo,
};
};
@ -48,8 +48,8 @@ test('create a AddressEdit with props', () => {
addressInfo,
showPostal: true,
showSetDefault: true,
showSearchResult: true
}
showSearchResult: true,
},
});
expect(wrapper).toMatchSnapshot();
@ -60,7 +60,7 @@ test('valid area placeholder confirm', async () => {
propsData: {
areaList,
areaColumnsPlaceholder: ['请选择', '请选择', '请选择'],
}
},
});
const { data } = wrapper.vm;
@ -100,8 +100,8 @@ test('validator props', async () => {
areaList,
validator(key, value) {
return `${key}${value}`;
}
}
},
},
});
const { errorInfo, data } = wrapper.vm;
@ -192,13 +192,13 @@ test('watch address info', () => {
test('set/get area code', async () => {
const wrapper = mount(AddressEdit, {
propsData: { areaList }
propsData: { areaList },
});
expect(wrapper.vm.getArea()).toEqual([
{ code: '110000', name: '北京市' },
{ code: '110100', name: '北京市' },
{ code: '110101', name: '东城区' }
{ code: '110101', name: '东城区' },
]);
wrapper.vm.setAreaCode('110102');
@ -208,7 +208,7 @@ test('set/get area code', async () => {
expect(wrapper.vm.getArea()).toEqual([
{ code: '110000', name: '北京市' },
{ code: '110100', name: '北京市' },
{ code: '110102', name: '西城区' }
{ code: '110102', name: '西城区' },
]);
wrapper.vm.$refs = [];
@ -221,9 +221,9 @@ test('watch area code', async () => {
propsData: {
areaList: {},
addressInfo: {
areaCode: '110101'
}
}
areaCode: '110101',
},
},
});
expect(wrapper.vm.data.city).toEqual('');
@ -240,9 +240,9 @@ test('show search result', async () => {
searchResult: [
{ name: 'name1', address: 'address1' },
{ name: 'name2' },
{ address: 'address2' }
]
}
{ address: 'address2' },
],
},
});
const field = wrapper.findAll('.van-field__control').at(3);
@ -266,8 +266,8 @@ test('delete address', async () => {
const wrapper = mount(AddressEdit, {
attachToDocument: true,
propsData: {
showDelete: true
}
showDelete: true,
},
});
const deleteButton = wrapper.findAll('.van-button').at(1);

View File

@ -77,7 +77,7 @@ function AddressItem(
{`${data.name} ${data.tel}`}
{genTag()}
</div>,
<div class={bem('address')}>{data.address}</div>
<div class={bem('address')}>{data.address}</div>,
];
if (switchable && !disabled) {
@ -99,7 +99,7 @@ function AddressItem(
clickable={switchable && !disabled}
scopedSlots={{
default: genContent,
'right-icon': genRightIcon
'right-icon': genRightIcon,
}}
onClick={onClick}
{...inherit(ctx)}
@ -111,7 +111,7 @@ AddressItem.props = {
data: Object,
disabled: Boolean,
switchable: Boolean,
defaultTagText: String
defaultTagText: String,
};
export default createComponent<AddressItemProps, AddressItemEvents>(

View File

@ -24,27 +24,27 @@ export default {
name: '张三',
tel: '13000000000',
address: '浙江省杭州市西湖区文三路 138 号东方通信大厦 7 楼 501 室',
isDefault: true
isDefault: true,
},
{
id: '2',
name: '李四',
tel: '1310000000',
address: '浙江省杭州市拱墅区莫干山路 50 号'
}
address: '浙江省杭州市拱墅区莫干山路 50 号',
},
],
disabledList: [
{
id: '3',
name: '王五',
tel: '1320000000',
address: '浙江省杭州市滨江区江南大道 15 号'
}
address: '浙江省杭州市滨江区江南大道 15 号',
},
],
add: '新增地址',
edit: '编辑地址',
disabledText: '以下地址超出配送范围',
defaultTagText: '默认'
defaultTagText: '默认',
},
'en-US': {
list: [
@ -53,33 +53,33 @@ export default {
name: 'John Snow',
tel: '13000000000',
address: 'Somewhere',
isDefault: true
isDefault: true,
},
{
id: '2',
name: 'Ned Stark',
tel: '1310000000',
address: 'Somewhere'
}
address: 'Somewhere',
},
],
disabledList: [
{
id: '3',
name: 'Tywin',
tel: '1320000000',
address: 'Somewhere'
}
address: 'Somewhere',
},
],
add: 'Add',
edit: 'Edit',
disabledText: 'The following address is out of range',
defaultTagText: 'Default'
}
defaultTagText: 'Default',
},
},
data() {
return {
chosenAddressId: '1'
chosenAddressId: '1',
};
},
@ -90,8 +90,8 @@ export default {
onEdit(item, index) {
this.$toast(`${this.$t('edit')}:${index}`);
}
}
},
},
};
</script>

View File

@ -94,8 +94,8 @@ AddressList.props = {
defaultTagText: String,
switchable: {
type: Boolean,
default: true
}
default: true,
},
};
export default createComponent<AddressListProps>(AddressList);

View File

@ -6,22 +6,22 @@ const list = [
id: '1',
name: '张三',
tel: '13000000000',
address: '浙江省杭州市西湖区文三路 138 号东方通信大厦 7 楼 501 室'
address: '浙江省杭州市西湖区文三路 138 号东方通信大厦 7 楼 501 室',
},
{
id: '2',
name: '李四',
tel: '1310000000',
address: '浙江省杭州市拱墅区莫干山路 50 号'
}
address: '浙江省杭州市拱墅区莫干山路 50 号',
},
];
test('unswitchable', () => {
const wrapper = mount(AddressList, {
propsData: {
list,
switchable: false
}
switchable: false,
},
});
expect(wrapper).toMatchSnapshot();
@ -31,13 +31,13 @@ test('select event', () => {
const onSelect = jest.fn();
const wrapper = mount(AddressList, {
propsData: {
list
list,
},
context: {
on: {
select: onSelect
}
}
select: onSelect,
},
},
});
wrapper.find('.van-radio__icon').trigger('click');
@ -49,13 +49,13 @@ test('click-item event', () => {
const onClickItem = jest.fn();
const wrapper = mount(AddressList, {
propsData: {
list
list,
},
context: {
on: {
'click-item': onClickItem
}
}
'click-item': onClickItem,
},
},
});
wrapper.find('.van-address-item').trigger('click');

View File

@ -2,7 +2,7 @@ export default {
province_list: {
110000: 'Beijing',
330000: 'Zhejiang',
810000: 'Hong Kong'
810000: 'Hong Kong',
},
city_list: {
110100: 'Beijing City',
@ -13,7 +13,7 @@ export default {
331100: 'Lishui',
810100: 'Hong Kong Island',
810200: 'Kowloon',
810300: 'New Territories'
810300: 'New Territories',
},
county_list: {
110101: 'Dongcheng',
@ -66,6 +66,6 @@ export default {
810305: 'Yuen Long',
810306: 'Tuen Mun',
810307: 'Tsuen Wan',
810309: 'Lantau Island'
}
810309: 'Lantau Island',
},
};

View File

@ -34,7 +34,7 @@ export default {
710000: '台湾省',
810000: '香港特别行政区',
820000: '澳门特别行政区',
900000: '海外'
900000: '海外',
},
city_list: {
110100: '北京市',
@ -648,7 +648,7 @@ export default {
987600: '瓦利斯和富图纳',
988200: '萨摩亚',
988700: '也门',
989400: '赞比亚'
989400: '赞比亚',
},
county_list: {
110101: '东城区',
@ -4035,6 +4035,6 @@ export default {
810308: '葵青区',
810309: '离岛区',
820101: '澳门半岛',
820201: '离岛'
}
820201: '离岛',
},
};

View File

@ -1,13 +1,13 @@
export default {
province_list: {
110000: '北京市',
120000: '天津市'
120000: '天津市',
},
city_list: {
110100: '北京市',
110200: '县',
120100: '天津市',
120200: '县'
120200: '县',
},
county_list: {
110101: '东城区',
@ -16,6 +16,6 @@ export default {
110229: '延庆县',
120101: '和平区',
120102: '河东区',
120225: '蓟县'
}
120225: '蓟县',
},
};

View File

@ -48,13 +48,13 @@ export default {
title4: 'Columns Placeholder',
columnsPlaceholder: ['Choose', 'Choose', 'Choose'],
areaList: AreaListEn,
}
},
},
data() {
return {
value: '330302'
value: '330302',
};
}
},
};
</script>

View File

@ -16,26 +16,26 @@ export default createComponent({
value: String,
areaList: {
type: Object,
default: () => ({})
default: () => ({}),
},
columnsNum: {
type: [Number, String],
default: 3
default: 3,
},
isOverseaCode: {
type: Function,
default: isOverseaCode
default: isOverseaCode,
},
columnsPlaceholder: {
type: Array,
default: () => []
}
default: () => [],
},
},
data() {
return {
code: this.value,
columns: [{ values: [] }, { values: [] }, { values: [] }]
columns: [{ values: [] }, { values: [] }, { values: [] }],
};
},
@ -60,9 +60,9 @@ export default createComponent({
return {
province: this.columnsPlaceholder[0] || '',
city: this.columnsPlaceholder[1] || '',
county: this.columnsPlaceholder[2] || ''
county: this.columnsPlaceholder[2] || '',
};
}
},
},
watch: {
@ -73,14 +73,14 @@ export default createComponent({
areaList: {
deep: true,
handler: 'setValues'
handler: 'setValues',
},
columnsNum() {
this.$nextTick(() => {
this.setValues();
});
}
},
},
mounted() {
@ -98,7 +98,7 @@ export default createComponent({
const list = this[type];
result = Object.keys(list).map(listCode => ({
code: listCode,
name: list[listCode]
name: list[listCode],
}));
if (code) {
@ -121,7 +121,7 @@ export default createComponent({
result.unshift({
code: `${code}${codeFill}`,
name: this.placeholderMap[type]
name: this.placeholderMap[type],
});
}
@ -218,7 +218,7 @@ export default createComponent({
picker.setIndexes([
this.getIndex('province', code),
this.getIndex('city', code),
this.getIndex('county', code)
this.getIndex('county', code),
]);
},
@ -236,7 +236,7 @@ export default createComponent({
country: '',
province: '',
city: '',
county: ''
county: '',
};
if (!values.length) {
@ -266,14 +266,14 @@ export default createComponent({
reset(code) {
this.code = code || '';
this.setValues();
}
},
},
render() {
const on = {
...this.$listeners,
change: this.onChange,
confirm: this.onConfirm
confirm: this.onConfirm,
};
return (
@ -293,5 +293,5 @@ export default createComponent({
{...{ on }}
/>
);
}
},
});

View File

@ -5,13 +5,13 @@ import { mount, later, triggerDrag } from '../../../test';
const firstOption = [
{ code: '110000', name: '北京市' },
{ code: '110100', name: '北京市' },
{ code: '110101', name: '东城区' }
{ code: '110101', name: '东城区' },
];
const secondOption = [
{ code: '120000', name: '天津市' },
{ code: '120100', name: '天津市' },
{ code: '120101', name: '和平区' }
{ code: '120101', name: '和平区' },
];
test('confirm & cancel event', async () => {
@ -19,12 +19,12 @@ test('confirm & cancel event', async () => {
const onCancel = jest.fn();
const wrapper = mount(Area, {
propsData: {
areaList
areaList,
},
listeners: {
confirm: onConfirm,
cancel: onCancel
}
cancel: onCancel,
},
});
await later();
@ -39,8 +39,8 @@ test('confirm & cancel event', async () => {
test('watch areaList & code', async () => {
const wrapper = mount(Area, {
propsData: {
areaList
}
areaList,
},
});
expect(wrapper).toMatchSnapshot();
@ -50,7 +50,7 @@ test('watch areaList & code', async () => {
expect(wrapper).toMatchSnapshot();
wrapper.setProps({
value: ''
value: '',
});
expect(wrapper).toMatchSnapshot();
});
@ -59,11 +59,11 @@ test('change option', () => {
const onChange = jest.fn();
const wrapper = mount(Area, {
propsData: {
areaList
areaList,
},
listeners: {
change: onChange
}
change: onChange,
},
});
const columns = wrapper.findAll('.van-picker-column');
@ -83,11 +83,11 @@ test('change option', () => {
test('getValues method', () => {
const wrapper = mount(Area, {
propsData: {
areaList
areaList,
},
created() {
expect(this.getValues()).toEqual([]);
}
},
});
expect(wrapper.vm.getValues()).toEqual(firstOption);
@ -97,8 +97,8 @@ test('reset method', async () => {
const wrapper = mount(Area, {
propsData: {
areaList,
value: '120225'
}
value: '120225',
},
});
await later();
@ -111,12 +111,12 @@ test('columns-num prop', async () => {
const wrapper = mount(Area, {
propsData: {
areaList,
columnsNum: 3
}
columnsNum: 3,
},
});
wrapper.setProps({
columnsNum: 2
columnsNum: 2,
});
await later();

View File

@ -101,7 +101,7 @@ export default {
customColor: '自定义颜色',
pure: '单色按钮',
gradient: '渐变色按钮',
blockElement: '块级元素'
blockElement: '块级元素',
},
'en-US': {
type: 'Type',
@ -130,9 +130,9 @@ export default {
customColor: 'Custom Color',
pure: 'Pure',
gradient: 'Gradient',
blockElement: 'Block Element'
}
}
blockElement: 'Block Element',
},
},
};
</script>

View File

@ -54,7 +54,7 @@ function Button(
disabled,
loading,
hairline,
loadingText
loadingText,
} = props;
const style: Record<string, string | number> = {};
@ -97,10 +97,10 @@ function Button(
hairline,
block: props.block,
round: props.round,
square: props.square
}
square: props.square,
},
]),
{ [BORDER_SURROUND]: hairline }
{ [BORDER_SURROUND]: hairline },
];
function Content() {
@ -165,20 +165,20 @@ Button.props = {
loadingType: String,
tag: {
type: String,
default: 'button'
default: 'button',
},
type: {
type: String,
default: 'default'
default: 'default',
},
size: {
type: String,
default: 'normal'
default: 'normal',
},
loadingSize: {
type: String,
default: '20px'
}
default: '20px',
},
};
export default createComponent<ButtonProps, ButtonEvents>(Button);

View File

@ -5,8 +5,8 @@ test('loading size', () => {
const wrapper = mount(Button, {
propsData: {
loading: true,
loadingSize: '10px'
}
loadingSize: '10px',
},
});
expect(wrapper).toMatchSnapshot();
});
@ -16,9 +16,9 @@ test('click event', () => {
const wrapper = mount(Button, {
context: {
on: {
click: onClick
}
}
click: onClick,
},
},
});
wrapper.trigger('click');
@ -29,13 +29,13 @@ test('not trigger click event when disabled', () => {
const onClick = jest.fn();
const wrapper = mount(Button, {
propsData: {
disabled: true
disabled: true,
},
context: {
on: {
click: onClick
}
}
click: onClick,
},
},
});
wrapper.trigger('click');
@ -46,13 +46,13 @@ test('not trigger click event when loading', () => {
const onClick = jest.fn();
const wrapper = mount(Button, {
propsData: {
loading: true
loading: true,
},
context: {
on: {
click: onClick
}
}
click: onClick,
},
},
});
wrapper.trigger('click');
@ -64,9 +64,9 @@ test('touchstart event', () => {
const wrapper = mount(Button, {
context: {
on: {
touchstart: onTouchstart
}
}
touchstart: onTouchstart,
},
},
});
wrapper.trigger('touchstart');
@ -76,8 +76,8 @@ test('touchstart event', () => {
test('hide border when color is gradient', () => {
const wrapper = mount(Button, {
propsData: {
color: 'linear-gradient(#000, #fff)'
}
color: 'linear-gradient(#000, #fff)',
},
});
expect(wrapper.element.style.border).toEqual('0px');

View File

@ -6,7 +6,7 @@ const [createComponent] = createNamespace('calendar-header');
export default createComponent({
props: {
title: String,
monthTitle: String
monthTitle: String,
},
methods: {
@ -29,7 +29,7 @@ export default createComponent({
))}
</div>
);
}
},
},
render() {
@ -40,5 +40,5 @@ export default createComponent({
{this.genWeekDays()}
</div>
);
}
},
});

View File

@ -15,12 +15,12 @@ export default createComponent({
showTitle: Boolean,
rowHeight: Number,
formatter: Function,
currentDate: [Date, Array]
currentDate: [Date, Array],
},
data() {
return {
visible: false
visible: false,
};
},
@ -43,7 +43,7 @@ export default createComponent({
Math.ceil((this.totalDay + this.offset) / 7) * this.rowHeight;
return {
paddingBottom: `${padding}px`
paddingBottom: `${padding}px`,
};
}
},
@ -61,7 +61,7 @@ export default createComponent({
date,
type,
text: day,
bottomInfo: this.getBottomInfo(type)
bottomInfo: this.getBottomInfo(type),
};
if (this.formatter) {
@ -72,7 +72,7 @@ export default createComponent({
}
return days;
}
},
},
mounted() {
@ -219,7 +219,7 @@ export default createComponent({
{BottomInfo}
</div>
);
}
},
},
render() {
@ -229,5 +229,5 @@ export default createComponent({
{this.genDays()}
</div>
);
}
},
});

View File

@ -129,7 +129,7 @@ export default {
customPosition: '自定义弹出位置',
customCalendar: '自定义日历',
confirmDisabledText: '请选择结束时间',
tiledDisplay: '平铺展示'
tiledDisplay: '平铺展示',
},
'en-US': {
in: 'In',
@ -150,8 +150,8 @@ export default {
customPosition: 'Custom Position',
customCalendar: 'Custom Calendar',
confirmDisabledText: 'Select End Time',
tiledDisplay: 'Tiled display'
}
tiledDisplay: 'Tiled display',
},
},
data() {
@ -166,7 +166,7 @@ export default {
customConfirm: [],
customRange: null,
customDayText: [],
customPosition: null
customPosition: null,
},
type: 'single',
round: true,
@ -281,7 +281,7 @@ export default {
onConfirm(date) {
this.showCalendar = false;
this.date[this.id] = date;
}
}
},
},
};
</script>

View File

@ -8,7 +8,7 @@ import {
compareMonth,
createComponent,
calcDateNum,
ROW_HEIGHT
ROW_HEIGHT,
} from './utils';
import Popup from '../popup';
@ -29,12 +29,12 @@ export default createComponent({
confirmDisabledText: String,
type: {
type: String,
default: 'single'
default: 'single',
},
minDate: {
type: Date,
validator: isDate,
default: () => new Date()
default: () => new Date(),
},
maxDate: {
type: Date,
@ -42,50 +42,50 @@ export default createComponent({
default() {
const now = new Date();
return new Date(now.getFullYear(), now.getMonth() + 6, now.getDate());
}
},
},
position: {
type: String,
default: 'bottom'
default: 'bottom',
},
rowHeight: {
type: Number,
default: ROW_HEIGHT
default: ROW_HEIGHT,
},
round: {
type: Boolean,
default: true
default: true,
},
poppable: {
type: Boolean,
default: true
default: true,
},
showMark: {
type: Boolean,
default: true
default: true,
},
showConfirm: {
type: Boolean,
default: true
default: true,
},
safeAreaInsetBottom: {
type: Boolean,
default: true
default: true,
},
closeOnClickOverlay: {
type: Boolean,
default: true
default: true,
},
maxRange: {
type: Number,
default: null
}
default: null,
},
},
data() {
return {
monthTitle: '',
currentDate: this.getInitialDate()
currentDate: this.getInitialDate(),
};
},
@ -114,7 +114,7 @@ export default createComponent({
}
return !this.currentDate;
}
},
},
watch: {
@ -129,7 +129,7 @@ export default createComponent({
defaultDate(val) {
this.currentDate = val;
}
},
},
mounted() {
@ -331,7 +331,7 @@ export default createComponent({
return (
<div
class={bem('footer', {
'safe-area-inset-bottom': this.safeAreaInsetBottom
'safe-area-inset-bottom': this.safeAreaInsetBottom,
})}
>
{this.genFooterContent()}
@ -346,7 +346,7 @@ export default createComponent({
title={this.title}
monthTitle={this.monthTitle}
scopedSlots={{
title: () => this.slots('title')
title: () => this.slots('title'),
}}
/>
<div ref="body" class={bem('body')} onScroll={this.onScroll}>
@ -355,7 +355,7 @@ export default createComponent({
{this.genFooter()}
</div>
);
}
},
},
render() {
@ -377,5 +377,5 @@ export default createComponent({
}
return this.genCalendar();
}
},
});

View File

@ -23,8 +23,8 @@ test('select event when type is single', async () => {
propsData: {
minDate,
maxDate,
poppable: false
}
poppable: false,
},
});
await later();
@ -43,8 +43,8 @@ test('select event when type is range', async () => {
type: 'range',
minDate,
maxDate,
poppable: false
}
poppable: false,
},
});
await later();
@ -68,8 +68,8 @@ test('should not trigger select event when click disabled day', async () => {
propsData: {
minDate,
maxDate,
poppable: false
}
poppable: false,
},
});
await later();
@ -87,8 +87,8 @@ test('confirm event when type is single', async () => {
propsData: {
minDate,
maxDate,
poppable: false
}
poppable: false,
},
});
await later();
@ -110,8 +110,8 @@ test('confirm event when type is range', async () => {
type: 'range',
minDate,
maxDate,
poppable: false
}
poppable: false,
},
});
await later();
@ -131,8 +131,8 @@ test('confirm event when type is range', async () => {
test('default single date', async () => {
const wrapper = mount(Calendar, {
propsData: {
poppable: false
}
poppable: false,
},
});
await later();
@ -145,8 +145,8 @@ test('default range date', async () => {
const wrapper = mount(Calendar, {
propsData: {
type: 'range',
poppable: false
}
poppable: false,
},
});
await later();
@ -163,8 +163,8 @@ test('reset method', async () => {
minDate,
maxDate,
type: 'range',
poppable: false
}
poppable: false,
},
});
await later();
@ -188,8 +188,8 @@ test('set show-confirm to false', async () => {
maxDate,
type: 'range',
poppable: false,
showConfirm: false
}
showConfirm: false,
},
});
await later();
@ -209,8 +209,8 @@ test('row-height prop', async () => {
minDate,
maxDate,
poppable: false,
rowHeight: 50
}
rowHeight: 50,
},
});
await later();
@ -243,8 +243,8 @@ test('formatter prop', async () => {
}
return day;
}
}
},
},
});
await later();
@ -257,12 +257,12 @@ test('title & footer slot', async () => {
propsData: {
minDate,
maxDate,
poppable: false
poppable: false,
},
scopedSlots: {
title: () => 'Custom Title',
footer: () => 'Custom Footer'
}
footer: () => 'Custom Footer',
},
});
await later();
@ -275,8 +275,8 @@ test('should reset when type changed', async () => {
propsData: {
minDate,
maxDate,
poppable: false
}
poppable: false,
},
});
await later();
@ -297,8 +297,8 @@ test('default-date prop in single type', async () => {
minDate,
maxDate,
defaultDate: getNextDay(minDate),
poppable: false
}
poppable: false,
},
});
await later();
@ -317,8 +317,8 @@ test('default-date prop in range type', async () => {
type: 'range',
minDate,
maxDate,
poppable: false
}
poppable: false,
},
});
await later();
@ -340,13 +340,13 @@ test('popup wrapper', async () => {
const wrapper = mount(Calendar, {
propsData: {
minDate,
maxDate
maxDate,
},
listeners: {
input(value) {
wrapper.setProps({ value });
}
}
},
},
});
await later();
@ -367,8 +367,8 @@ test('set show-mark prop to false', async () => {
minDate,
maxDate,
showMark: false,
poppable: false
}
poppable: false,
},
});
await later();
@ -382,8 +382,8 @@ test('color prop when type is single', async () => {
minDate,
maxDate,
color: 'blue',
poppable: false
}
poppable: false,
},
});
await later();
@ -399,8 +399,8 @@ test('color prop when type is range', async () => {
minDate,
maxDate,
color: 'blue',
poppable: false
}
poppable: false,
},
});
await later();
@ -414,8 +414,8 @@ test('should scroll to current month when show', async done => {
type: 'range',
minDate: new Date(2010, 0, 10),
maxDate: new Date(2010, 11, 10),
defaultDate: [new Date(2010, 3, 1), new Date(2010, 5, 1)]
}
defaultDate: [new Date(2010, 3, 1), new Date(2010, 5, 1)],
},
});
Element.prototype.scrollIntoView = function() {
@ -435,8 +435,8 @@ test('max-range prop', async () => {
minDate,
maxDate,
maxRange: 1,
poppable: false
}
poppable: false,
},
});
await later();

View File

@ -75,19 +75,19 @@ export default {
'zh-CN': {
title: '商品名称',
discountInfo: '营销信息',
customContent: '自定义内容'
customContent: '自定义内容',
},
'en-US': {
discountInfo: 'Discount Info',
customContent: 'Custom Content'
}
customContent: 'Custom Content',
},
},
data() {
return {
imageURL: 'https://img.yzcdn.cn/vant/t-thirt.jpg'
imageURL: 'https://img.yzcdn.cn/vant/t-thirt.jpg',
};
}
},
};
</script>

View File

@ -206,8 +206,8 @@ Card.props = {
originPrice: [Number, String],
currency: {
type: String,
default: '¥'
}
default: '¥',
},
};
export default createComponent<CardProps, CardEvents>(Card);

View File

@ -6,16 +6,16 @@ test('click event', () => {
const wrapper = mount(Card, {
context: {
on: {
click: onClick
}
}
click: onClick,
},
},
});
wrapper.trigger('click');
expect(onClick).toHaveBeenCalledWith(
expect.objectContaining({
isTrusted: expect.any(Boolean)
isTrusted: expect.any(Boolean),
})
);
});
@ -24,20 +24,20 @@ test('click-thumb event', () => {
const onClickThumb = jest.fn();
const wrapper = mount(Card, {
propsData: {
thumb: 'xx'
thumb: 'xx',
},
context: {
on: {
'click-thumb': onClickThumb
}
}
'click-thumb': onClickThumb,
},
},
});
wrapper.find('.van-card__thumb').trigger('click');
expect(onClickThumb).toHaveBeenCalledWith(
expect.objectContaining({
isTrusted: expect.any(Boolean)
isTrusted: expect.any(Boolean),
})
);
});
@ -46,8 +46,8 @@ test('render price & num slot', () => {
const wrapper = mount(Card, {
scopedSlots: {
num: () => 'Custom Num',
price: () => 'Custom Price'
}
price: () => 'Custom Price',
},
});
expect(wrapper).toMatchSnapshot();
@ -56,8 +56,8 @@ test('render price & num slot', () => {
test('render origin-price slot', () => {
const wrapper = mount(Card, {
scopedSlots: {
'origin-price': () => 'Custom Origin Price'
}
'origin-price': () => 'Custom Origin Price',
},
});
expect(wrapper).toMatchSnapshot();
@ -66,8 +66,8 @@ test('render origin-price slot', () => {
test('render bottom slot', () => {
const wrapper = mount(Card, {
scopedSlots: {
bottom: () => 'Custom Bottom'
}
bottom: () => 'Custom Bottom',
},
});
expect(wrapper).toMatchSnapshot();
@ -77,8 +77,8 @@ test('render thumb & tag slot', () => {
const wrapper = mount(Card, {
scopedSlots: {
tag: () => 'Custom Tag',
thumb: () => 'Custom Thumb'
}
thumb: () => 'Custom Thumb',
},
});
expect(wrapper).toMatchSnapshot();
@ -88,8 +88,8 @@ test('render title & desc slot', () => {
const wrapper = mount(Card, {
scopedSlots: {
title: () => 'Custom Title',
desc: () => 'Custom desc'
}
desc: () => 'Custom desc',
},
});
expect(wrapper).toMatchSnapshot();
@ -99,8 +99,8 @@ test('render price & price-top slot', () => {
const wrapper = mount(Card, {
scopedSlots: {
price: () => 'Custom Price',
'price-top': () => 'Custom Price-top'
}
'price-top': () => 'Custom Price-top',
},
});
expect(wrapper).toMatchSnapshot();

View File

@ -45,8 +45,8 @@ CellGroup.props = {
title: String,
border: {
type: Boolean,
default: true
}
default: true,
},
};
export default createComponent<CellGroupProps>(CellGroup);

View File

@ -76,7 +76,7 @@ export default {
urlRoute: 'URL 跳转',
vueRoute: '路由跳转',
useSlots: '使用插槽',
verticalCenter: '垂直居中'
verticalCenter: '垂直居中',
},
'en-US': {
cell: 'Cell title',
@ -90,9 +90,9 @@ export default {
urlRoute: 'URL',
vueRoute: 'Vue Router',
useSlots: 'Use Slots',
verticalCenter: 'Vertical center'
}
}
verticalCenter: 'Vertical center',
},
},
};
</script>

View File

@ -109,7 +109,7 @@ function Cell(
clickable,
center: props.center,
required: props.required,
borderless: !props.border
borderless: !props.border,
};
if (size) {
@ -135,7 +135,7 @@ function Cell(
Cell.props = {
...cellProps,
...routeProps
...routeProps,
};
export default createComponent<CellProps, CellEvents, CellSlots>(Cell);

View File

@ -33,6 +33,6 @@ export const cellProps = {
arrowDirection: String,
border: {
type: Boolean,
default: true
}
default: true,
},
};

View File

@ -7,9 +7,9 @@ test('click event', () => {
const wrapper = mount(Cell, {
context: {
on: {
click
}
}
click,
},
},
});
wrapper.trigger('click');
@ -20,8 +20,8 @@ test('arrow direction', () => {
const wrapper = mount(Cell, {
propsData: {
isLink: true,
arrowDirection: 'down'
}
arrowDirection: 'down',
},
});
expect(wrapper).toMatchSnapshot();
@ -38,8 +38,8 @@ test('render slot', () => {
</cell>
`,
components: {
Cell
}
Cell,
},
});
expect(wrapper).toMatchSnapshot();
@ -50,9 +50,9 @@ test('title-style prop', () => {
propsData: {
title: 'title',
titleStyle: {
color: 'red'
}
}
color: 'red',
},
},
});
expect(wrapper).toMatchSnapshot();
@ -61,8 +61,8 @@ test('title-style prop', () => {
test('CellGroup title slot', () => {
const wrapper = mount(CellGroup, {
scopedSlots: {
title: () => 'CustomTitle'
}
title: () => 'CustomTitle',
},
});
expect(wrapper).toMatchSnapshot();

View File

@ -13,14 +13,14 @@ export default createComponent({
checkedColor: String,
value: {
type: Array,
default: () => []
}
default: () => [],
},
},
watch: {
value(val) {
this.$emit('change', val);
}
},
},
methods: {
@ -38,10 +38,10 @@ export default createComponent({
const names = children.map(item => item.name);
this.$emit('input', names);
}
},
},
render() {
return <div class={bem()}>{this.slots()}</div>;
}
},
});

View File

@ -41,7 +41,7 @@
<van-checkbox v-model="checkbox3">
{{ $t('customIcon') }}
<template #icon="{ checked }">
<img :src="checked ? activeIcon : inactiveIcon">
<img :src="checked ? activeIcon : inactiveIcon" />
</template>
</van-checkbox>
</demo-block>
@ -110,7 +110,7 @@ export default {
toggleAll: '全选与反选',
checkAll: '全选',
inverse: '反选',
disabledLabelClick: '禁用文本点击'
disabledLabelClick: '禁用文本点击',
},
'en-US': {
checkbox: 'Checkbox',
@ -124,8 +124,8 @@ export default {
toggleAll: 'Toggle All',
checkAll: 'Check All',
inverse: 'Inverse',
disabledLabelClick: 'Disable the click event of label'
}
disabledLabelClick: 'Disable the click event of label',
},
},
data() {
@ -139,14 +139,14 @@ export default {
list: [
'a',
'b',
'c'
'c',
],
result: ['a', 'b'],
result2: [],
result3: [],
checkAllResult: [],
activeIcon: 'https://img.yzcdn.cn/vant/user-active.png',
inactiveIcon: 'https://img.yzcdn.cn/vant/user-inactive.png'
inactiveIcon: 'https://img.yzcdn.cn/vant/user-inactive.png',
};
},
@ -161,8 +161,8 @@ export default {
toggleAll() {
this.$refs.group.toggleAll();
}
}
},
},
};
</script>

View File

@ -7,7 +7,7 @@ export default createComponent({
mixins: [CheckboxMixin({
bem,
role: 'checkbox',
parent: 'vanCheckbox'
parent: 'vanCheckbox',
})],
computed: {
@ -22,14 +22,14 @@ export default createComponent({
} else {
this.$emit('input', val);
}
}
}
},
},
},
watch: {
value(val) {
this.$emit('change', val);
}
},
},
methods: {
@ -67,6 +67,6 @@ export default createComponent({
parent.$emit('input', value);
}
}
}
}
},
},
});

View File

@ -20,8 +20,8 @@ test('switch checkbox', async () => {
test('disabled', () => {
const wrapper = mount(Checkbox, {
propsData: {
disabled: true
}
disabled: true,
},
});
wrapper.find('.van-checkbox__icon').trigger('click');
@ -31,11 +31,11 @@ test('disabled', () => {
test('label disabled', () => {
const wrapper = mount(Checkbox, {
scopedSlots: {
default: () => 'Label'
default: () => 'Label',
},
propsData: {
labelDisabled: true
}
labelDisabled: true,
},
});
wrapper.find('.van-checkbox__label').trigger('click');
@ -54,9 +54,9 @@ test('checkbox group', async () => {
`,
data() {
return {
result: []
result: [],
};
}
},
});
const icons = wrapper.findAll('.van-checkbox__icon');
@ -77,8 +77,8 @@ test('click event', () => {
const onClick = jest.fn();
const wrapper = mount(Checkbox, {
listeners: {
click: onClick
}
click: onClick,
},
});
wrapper.trigger('click');
@ -92,11 +92,11 @@ test('click event', () => {
test('label-position prop', () => {
const wrapper = mount(Checkbox, {
scopedSlots: {
default: () => 'Label'
default: () => 'Label',
},
propsData: {
labelPosition: 'left'
}
labelPosition: 'left',
},
});
expect(wrapper).toMatchSnapshot();
@ -109,7 +109,7 @@ test('icon-size prop', () => {
<van-checkbox>label</van-checkbox>
<van-checkbox icon-size="5rem">label</van-checkbox>
</van-checkbox-group>
`
`,
});
expect(wrapper).toMatchSnapshot();
@ -122,7 +122,7 @@ test('checked-color prop', () => {
<van-checkbox name="a" :value="true">label</van-checkbox>
<van-checkbox name="b" :value="true" checked-color="white">label</van-checkbox>
</van-checkbox-group>
`
`,
});
expect(wrapper).toMatchSnapshot();
@ -140,9 +140,9 @@ test('bind-group prop', async () => {
return {
value: false,
result: [],
list: ['a', 'b', 'c']
list: ['a', 'b', 'c'],
};
}
},
});
const icons = wrapper.findAll('.van-checkbox__icon');
@ -163,14 +163,14 @@ test('toggleAll method', async () => {
`,
data() {
return {
result: ['a']
result: ['a'],
};
},
methods: {
toggleAll(checked) {
this.$refs.group.toggleAll(checked);
}
}
},
},
});
wrapper.vm.toggleAll();

View File

@ -85,7 +85,7 @@ export default {
customStyle: '样式定制',
customColor: '颜色定制',
customWidth: '宽度定制',
counterClockwise: '逆时针'
counterClockwise: '逆时针',
},
'en-US': {
gradient: 'Gradient',
@ -93,8 +93,8 @@ export default {
customStyle: 'Custom Style',
customColor: 'Custom Color',
customWidth: 'Custom Width',
counterClockwise: 'Counter Clockwise'
}
counterClockwise: 'Counter Clockwise',
},
},
data() {
@ -106,8 +106,8 @@ export default {
currentRate4: 70,
gradientColor: {
'0%': '#3fecff',
'100%': '#6149f6'
}
'100%': '#6149f6',
},
};
},
@ -118,8 +118,8 @@ export default {
reduce() {
this.rate = format(this.rate - 20);
}
}
},
},
};
</script>

View File

@ -24,40 +24,40 @@ export default createComponent({
strokeLinecap: String,
value: {
type: Number,
default: 0
default: 0,
},
speed: {
type: Number,
default: 0
default: 0,
},
size: {
type: [String, Number],
default: 100
default: 100,
},
fill: {
type: String,
default: 'none'
default: 'none',
},
rate: {
type: Number,
default: 100
default: 100,
},
layerColor: {
type: String,
default: WHITE
default: WHITE,
},
color: {
type: [String, Object],
default: BLUE
default: BLUE,
},
strokeWidth: {
type: Number,
default: 40
default: 40,
},
clockwise: {
type: Boolean,
default: true
}
default: true,
},
},
beforeCreate() {
@ -69,7 +69,7 @@ export default createComponent({
const size = addUnit(this.size);
return {
width: size,
height: size
height: size,
};
},
@ -88,7 +88,7 @@ export default createComponent({
stroke: `${this.color}`,
strokeWidth: `${this.strokeWidth + 1}px`,
strokeLinecap: this.strokeLinecap,
strokeDasharray: `${offset}px ${PERIMETER}px`
strokeDasharray: `${offset}px ${PERIMETER}px`,
};
},
@ -96,7 +96,7 @@ export default createComponent({
return {
fill: `${this.fill}`,
stroke: `${this.layerColor}`,
strokeWidth: `${this.strokeWidth}px`
strokeWidth: `${this.strokeWidth}px`,
};
},
@ -122,7 +122,7 @@ export default createComponent({
</linearGradient>
</defs>
);
}
},
},
watch: {
@ -143,8 +143,8 @@ export default createComponent({
this.$emit('input', this.endRate);
}
},
immediate: true
}
immediate: true,
},
},
methods: {
@ -158,7 +158,7 @@ export default createComponent({
if (this.increase ? rate < this.endRate : rate > this.endRate) {
this.rafId = raf(this.animate);
}
}
},
},
render() {
@ -178,5 +178,5 @@ export default createComponent({
(this.text && <div class={bem('text')}>{this.text}</div>)}
</div>
);
}
},
});

View File

@ -6,15 +6,15 @@ test('speed is 0', async () => {
const wrapper = mount(Circle, {
propsData: {
rate: 50,
value: 0
value: 0,
},
listeners: {
input(value) {
Vue.nextTick(() => {
wrapper.setProps({ value });
});
}
}
},
},
});
await later();
@ -26,11 +26,11 @@ test('animate', async () => {
mount(Circle, {
propsData: {
rate: 50,
speed: 100
speed: 100,
},
listeners: {
input: onInput
}
input: onInput,
},
});
await later(50);
@ -41,8 +41,8 @@ test('animate', async () => {
test('size prop', () => {
const wrapper = mount(Circle, {
propsData: {
size: 100
}
size: 100,
},
});
expect(wrapper).toMatchSnapshot();
@ -51,8 +51,8 @@ test('size prop', () => {
test('stroke-linecap prop', () => {
const wrapper = mount(Circle, {
propsData: {
strokeLinecap: 'square'
}
strokeLinecap: 'square',
},
});
expect(wrapper).toMatchSnapshot();

View File

@ -89,13 +89,13 @@ export default {
i18n: {
'zh-CN': {
title2: '在列元素之间增加间距',
title3: 'Flex 布局'
title3: 'Flex 布局',
},
'en-US': {
title2: 'Column Spacing',
title3: 'Flex Layout'
}
}
title3: 'Flex Layout',
},
},
};
</script>

View File

@ -8,8 +8,8 @@ export default createComponent({
offset: [Number, String],
tag: {
type: String,
default: 'div'
}
default: 'div',
},
},
computed: {
@ -20,13 +20,13 @@ export default createComponent({
style() {
const padding = `${this.gutter / 2}px`;
return this.gutter ? { paddingLeft: padding, paddingRight: padding } : {};
}
},
},
methods: {
onClick(event) {
this.$emit('click', event);
}
},
},
render() {
@ -40,5 +40,5 @@ export default createComponent({
{this.slots()}
</this.tag>
);
}
},
});

View File

@ -18,14 +18,14 @@ export default createComponent({
disabled: Boolean,
isLink: {
type: Boolean,
default: true
}
default: true,
},
},
data() {
return {
show: null,
inited: null
inited: null,
};
},
@ -53,7 +53,7 @@ export default createComponent({
return accordion
? value === this.currentName
: value.some(name => name === this.currentName);
}
},
},
created() {
@ -96,7 +96,7 @@ export default createComponent({
this.onTransitionEnd();
}
});
}
},
},
methods: {
@ -162,7 +162,7 @@ export default createComponent({
</div>
);
}
}
},
},
render() {
@ -172,5 +172,5 @@ export default createComponent({
{this.genContent()}
</div>
);
}
},
});

View File

@ -50,22 +50,22 @@ export default {
'zh-CN': {
accordion: '手风琴',
titleSlot: '自定义标题内容',
text: '代码是写出来给人看的,附带能在机器上运行'
text: '代码是写出来给人看的,附带能在机器上运行',
},
'en-US': {
accordion: 'Accordion',
titleSlot: 'Custom title',
text: 'Content'
}
text: 'Content',
},
},
data() {
return {
active1: [0],
active2: 0,
active3: []
active3: [],
};
}
},
};
</script>

View File

@ -12,8 +12,8 @@ export default createComponent({
value: [String, Number, Array],
border: {
type: Boolean,
default: true
}
default: true,
},
},
methods: {
@ -25,7 +25,7 @@ export default createComponent({
}
this.$emit('change', name);
this.$emit('input', name);
}
},
},
render() {
@ -34,5 +34,5 @@ export default createComponent({
{this.slots()}
</div>
);
}
},
});

View File

@ -14,14 +14,14 @@ const component = {
accordion: Boolean,
border: {
type: Boolean,
default: true
}
default: true,
},
},
data() {
return {
active: this.accordion ? '' : []
active: this.accordion ? '' : [],
};
}
},
};
test('basic mode', async () => {
@ -45,8 +45,8 @@ test('basic mode', async () => {
test('accordion', async () => {
const wrapper = mount(component, {
propsData: {
accordion: true
}
accordion: true,
},
});
const titles = wrapper.findAll('.van-collapse-item__title');
@ -78,9 +78,9 @@ test('render collapse-item slot', () => {
`,
data() {
return {
active: []
active: [],
};
}
},
});
expect(wrapper).toMatchSnapshot();
@ -89,8 +89,8 @@ test('render collapse-item slot', () => {
test('disable border', () => {
const wrapper = mount(component, {
propsData: {
border: false
}
border: false,
},
});
expect(wrapper).toMatchSnapshot();
@ -106,14 +106,14 @@ test('lazy render collapse content', async () => {
`,
components: {
Collapse,
CollapseItem
CollapseItem,
},
data() {
return {
content: '',
active: []
active: [],
};
}
},
});
const titles = wrapper.findAll('.van-collapse-item__title');
@ -136,9 +136,9 @@ test('warn when value type is incorrect', () => {
`,
data() {
return {
active: 0
active: 0,
};
}
},
});
expect(error).toHaveBeenCalledTimes(1);

View File

@ -56,13 +56,13 @@ export default {
'zh-CN': {
name: '张三',
defaultLabel: '设为默认联系人',
defaultTagText: '默认'
defaultTagText: '默认',
},
'en-US': {
name: 'John Snow',
defaultLabel: 'Set as the default contact',
defaultTagText: 'default'
}
defaultTagText: 'default',
},
},
data() {
@ -72,7 +72,7 @@ export default {
showList: false,
showEdit: false,
isEdit: false,
list: []
list: [],
};
},
@ -82,7 +82,7 @@ export default {
name: this.$t('name'),
tel: '13000000000',
id: 0,
isDefault: 1
isDefault: 1,
};
},
@ -93,7 +93,7 @@ export default {
currentContact() {
const id = this.chosenContactId;
return id !== null ? this.list.filter(item => item.id === id)[0] : {};
}
},
},
created() {
@ -135,8 +135,8 @@ export default {
if (this.chosenContactId === info.id) {
this.chosenContactId = null;
}
}
}
},
},
};
</script>

View File

@ -37,7 +37,7 @@ function ContactCard(
return [
<div>{`${t('name')}${props.name}`}</div>,
<div>{`${t('tel')}${props.tel}`}</div>
<div>{`${t('tel')}${props.tel}`}</div>,
];
}
@ -63,12 +63,12 @@ ContactCard.props = {
addText: String,
editable: {
type: Boolean,
default: true
default: true,
},
type: {
type: String,
default: 'add'
}
default: 'add',
},
};
export default createComponent<ContactCardProps>(ContactCard);

View File

@ -5,7 +5,7 @@ import { mount, later } from '../../../test';
const contactInfo = {
name: 'test',
tel: '123123213'
tel: '123123213',
};
describe('ContactCard', () => {
@ -14,9 +14,9 @@ describe('ContactCard', () => {
const wrapper = mount(ContactCard, {
context: {
on: {
click
}
}
click,
},
},
});
wrapper.trigger('click');
@ -27,13 +27,13 @@ describe('ContactCard', () => {
const click = jest.fn();
const wrapper = mount(ContactCard, {
propsData: {
editable: false
editable: false,
},
context: {
on: {
click
}
}
click,
},
},
});
wrapper.trigger('click');
@ -45,8 +45,8 @@ describe('ContactList', () => {
test('render', () => {
const wrapper = mount(ContactList, {
propsData: {
list: [contactInfo]
}
list: [contactInfo],
},
});
expect(wrapper).toMatchSnapshot();
});
@ -55,13 +55,13 @@ describe('ContactList', () => {
const onSelect = jest.fn();
const wrapper = mount(ContactList, {
propsData: {
list: [contactInfo]
list: [contactInfo],
},
context: {
on: {
select: onSelect
}
}
select: onSelect,
},
},
});
wrapper.find('.van-radio__icon').trigger('click');
@ -74,8 +74,8 @@ describe('ContactEdit', () => {
const createComponent = () => {
const wrapper = mount(ContactEdit, {
propsData: {
contactInfo
}
contactInfo,
},
});
const button = wrapper.find('.van-button');
@ -86,7 +86,7 @@ describe('ContactEdit', () => {
data,
field,
button,
errorInfo
errorInfo,
};
};
@ -114,7 +114,7 @@ describe('ContactEdit', () => {
expect(errorInfo.tel).toBeFalsy();
expect(wrapper.emitted('save')[0][0]).toEqual({
name: 'test',
tel: '13000000000'
tel: '13000000000',
});
});
@ -127,8 +127,8 @@ describe('ContactEdit', () => {
test('delete contact', async () => {
const wrapper = mount(ContactEdit, {
propsData: {
isEdit: true
}
isEdit: true,
},
});
const deleteButton = wrapper.findAll('.van-button').at(1);

View File

@ -10,7 +10,7 @@ const [createComponent, bem, t] = createNamespace('contact-edit');
const defaultContact = {
tel: '',
name: ''
name: '',
};
export default createComponent({
@ -22,24 +22,24 @@ export default createComponent({
setDefaultLabel: String,
contactInfo: {
type: Object,
default: () => ({ ...defaultContact })
default: () => ({ ...defaultContact }),
},
telValidator: {
type: Function,
default: isMobile
}
default: isMobile,
},
},
data() {
return {
data: {
...defaultContact,
...this.contactInfo
...this.contactInfo,
},
errorInfo: {
name: '',
tel: ''
}
tel: '',
},
};
},
@ -47,9 +47,9 @@ export default createComponent({
contactInfo(val) {
this.data = {
...defaultContact,
...val
...val,
};
}
},
},
methods: {
@ -83,11 +83,11 @@ export default createComponent({
onDelete() {
Dialog.confirm({
message: t('confirmDelete')
message: t('confirmDelete'),
}).then(() => {
this.$emit('delete', this.data);
});
}
},
},
render() {
@ -152,5 +152,5 @@ export default createComponent({
</div>
</div>
);
}
},
});

View File

@ -122,7 +122,7 @@ ContactList.props = {
value: null as any,
list: Array,
addText: String,
defaultTagText: String
defaultTagText: String,
};
export default createComponent(ContactList);

View File

@ -60,7 +60,7 @@ export default {
reset: '重置',
pause: '暂停',
start: '开始',
finished: '倒计时结束'
finished: '倒计时结束',
},
'en-US': {
millisecond: 'Millisecond',
@ -71,13 +71,13 @@ export default {
reset: 'Reset',
pause: 'Pause',
start: 'Start',
finished: 'Finished'
}
finished: 'Finished',
},
},
data() {
return {
time: 30 * 60 * 60 * 1000
time: 30 * 60 * 60 * 1000,
};
},
@ -92,8 +92,8 @@ export default {
reset() {
this.$refs.countDown.reset();
}
}
},
},
};
</script>

View File

@ -9,21 +9,21 @@ export default createComponent({
millisecond: Boolean,
time: {
type: Number,
default: 0
default: 0,
},
format: {
type: String,
default: 'HH:mm:ss'
default: 'HH:mm:ss',
},
autoStart: {
type: Boolean,
default: true
}
default: true,
},
},
data() {
return {
remain: 0
remain: 0,
};
},
@ -34,14 +34,14 @@ export default createComponent({
formattedTime() {
return parseFormat(this.format, this.timeData);
}
},
},
watch: {
time: {
immediate: true,
handler: 'reset'
}
handler: 'reset',
},
},
activated() {
@ -146,7 +146,7 @@ export default createComponent({
this.pause();
this.$emit('finish');
}
}
},
},
render() {
@ -155,5 +155,5 @@ export default createComponent({
{this.slots('default', this.timeData) || this.formattedTime}
</div>
);
}
},
});

View File

@ -4,8 +4,8 @@ import { mount, later } from '../../../test';
test('macro task finish event', async () => {
const wrapper = mount(CountDown, {
propsData: {
time: 1
}
time: 1,
},
});
expect(wrapper.emitted('finish')).toBeFalsy();
@ -17,8 +17,8 @@ test('micro task finish event', async () => {
const wrapper = mount(CountDown, {
propsData: {
time: 1,
millisecond: true
}
millisecond: true,
},
});
expect(wrapper.emitted('finish')).toBeFalsy();
@ -30,8 +30,8 @@ test('macro task re-render', async () => {
const wrapper = mount(CountDown, {
propsData: {
time: 1000,
format: 'SSS'
}
format: 'SSS',
},
});
const prevSnapShot = wrapper.html();
@ -46,8 +46,8 @@ test('micro task re-render', async () => {
propsData: {
time: 100,
format: 'SSS',
millisecond: true
}
millisecond: true,
},
});
const prevSnapShot = wrapper.html();
@ -62,8 +62,8 @@ test('disable auto-start prop', async () => {
propsData: {
time: 100,
format: 'SSS',
autoStart: false
}
autoStart: false,
},
});
await later(50);
@ -76,8 +76,8 @@ test('start method', async () => {
time: 100,
format: 'SSS',
autoStart: false,
millisecond: true
}
millisecond: true,
},
});
const prevSnapShot = wrapper.html();
@ -97,8 +97,8 @@ test('pause method', async () => {
propsData: {
time: 100,
format: 'SSS',
millisecond: true
}
millisecond: true,
},
});
const prevSnapShot = wrapper.html();
@ -114,8 +114,8 @@ test('reset method', async () => {
propsData: {
time: 100,
format: 'SSS',
millisecond: true
}
millisecond: true,
},
});
const prevSnapShot = wrapper.html();
@ -131,8 +131,8 @@ test('complete format prop', () => {
propsData: {
time: 30 * 60 * 60 * 1000 - 1,
autoStart: false,
format: 'DD-HH-mm-ss-SSS'
}
format: 'DD-HH-mm-ss-SSS',
},
});
expect(wrapper).toMatchSnapshot();
@ -143,8 +143,8 @@ test('milliseconds format SS', () => {
propsData: {
time: 1500,
autoStart: false,
format: 'ss-SS'
}
format: 'ss-SS',
},
});
expect(wrapper).toMatchSnapshot();
@ -155,8 +155,8 @@ test('milliseconds format S', () => {
propsData: {
time: 1500,
autoStart: false,
format: 'ss-S'
}
format: 'ss-S',
},
});
expect(wrapper).toMatchSnapshot();
@ -167,8 +167,8 @@ test('incomplate format prop', () => {
propsData: {
time: 30 * 60 * 60 * 1000 - 1,
autoStart: false,
format: 'HH-mm-ss-SSS'
}
format: 'HH-mm-ss-SSS',
},
});
expect(wrapper).toMatchSnapshot();
@ -190,14 +190,14 @@ test('pause when deactivated', async () => {
`,
data() {
return {
render: true
render: true,
};
},
methods: {
getCountDown() {
return this.$refs.countDown;
}
}
},
},
});
const countDown = wrapper.vm.getCountDown();

View File

@ -25,7 +25,7 @@ export function parseTimeData(time: number): TimeData {
hours,
minutes,
seconds,
milliseconds
milliseconds,
};
}

View File

@ -55,31 +55,31 @@ function CouponCell(
}
CouponCell.model = {
prop: 'chosenCoupon'
prop: 'chosenCoupon',
};
CouponCell.props = {
title: String,
coupons: {
type: Array,
default: () => []
default: () => [],
},
currency: {
type: String,
default: '¥'
default: '¥',
},
border: {
type: Boolean,
default: true
default: true,
},
editable: {
type: Boolean,
default: true
default: true,
},
chosenCoupon: {
type: Number,
default: -1
}
default: -1,
},
};
export default createComponent<CouponCellProps>(CouponCell);

View File

@ -33,25 +33,25 @@ export default {
coupon: {
name: '优惠券名称',
reason: '优惠券不可用原因',
description: '描述信息'
description: '描述信息',
},
exchange: '兑换成功'
exchange: '兑换成功',
},
'en-US': {
coupon: {
name: 'Coupon name',
reason: 'Coupon unavailable reason',
description: 'Description'
description: 'Description',
},
exchange: 'Success'
}
exchange: 'Success',
},
},
data() {
return {
showList: false,
chosenCoupon: -1,
exchangedCoupons: []
exchangedCoupons: [],
};
},
@ -75,7 +75,7 @@ export default {
startAt: 1489104000,
endAt: 1514592000,
valueDesc: '1.5',
unitDesc: '元'
unitDesc: '元',
};
},
@ -85,7 +85,7 @@ export default {
id: 2,
value: 12,
valueDesc: '8.8',
unitDesc: '折'
unitDesc: '折',
};
},
@ -93,7 +93,7 @@ export default {
return {
...this.coupon,
id: 3,
reason: this.$t('coupon.reason')
reason: this.$t('coupon.reason'),
};
},
@ -103,9 +103,9 @@ export default {
valueDesc: '1',
unitDesc: '折',
id: 4,
reason: this.$t('coupon.reason')
reason: this.$t('coupon.reason'),
};
}
},
},
methods: {
@ -117,12 +117,12 @@ export default {
this.$toast(this.$t('exchange'));
this.exchangedCoupons.push({
...this.coupon,
id: this.randomId()
id: this.randomId(),
});
},
randomId(max = 999999) {
return Math.floor(Math.random() * max) + 1;
}
}
},
},
};
</script>

View File

@ -10,7 +10,7 @@ const EMPTY_IMAGE = 'https://img.yzcdn.cn/vant/coupon-empty.png';
export default createComponent({
model: {
prop: 'code'
prop: 'code',
},
props: {
@ -24,51 +24,51 @@ export default createComponent({
exchangeButtonDisabled: Boolean,
exchangeMinLength: {
type: Number,
default: 1
default: 1,
},
chosenCoupon: {
type: Number,
default: -1
default: -1,
},
coupons: {
type: Array,
default: () => []
default: () => [],
},
disabledCoupons: {
type: Array,
default: () => []
default: () => [],
},
displayedCouponIndex: {
type: Number,
default: -1
default: -1,
},
showExchangeBar: {
type: Boolean,
default: true
default: true,
},
showCloseButton: {
type: Boolean,
default: true
default: true,
},
showCount: {
type: Boolean,
default: true
default: true,
},
currency: {
type: String,
default: '¥'
default: '¥',
},
emptyImage: {
type: String,
default: EMPTY_IMAGE
}
default: EMPTY_IMAGE,
},
},
data() {
return {
tab: 0,
winHeight: window.innerHeight,
currentCode: this.code || ''
currentCode: this.code || '',
};
},
@ -84,9 +84,9 @@ export default createComponent({
listStyle() {
return {
height: this.winHeight - (this.showExchangeBar ? 140 : 94) + 'px'
height: this.winHeight - (this.showExchangeBar ? 140 : 94) + 'px',
};
}
},
},
watch: {
@ -98,7 +98,7 @@ export default createComponent({
this.$emit('input', code);
},
displayedCouponIndex: 'scrollToShowCoupon'
displayedCouponIndex: 'scrollToShowCoupon',
},
mounted() {
@ -152,7 +152,7 @@ export default createComponent({
onClick={this.onClickExchangeButton}
/>
);
}
},
},
render() {
@ -234,5 +234,5 @@ export default createComponent({
</div>
</div>
);
}
},
});

View File

@ -13,17 +13,17 @@ const coupon = {
name: 'name',
description: 'description',
startAt: 1489104000,
endAt: 1514592000
endAt: 1514592000,
};
const coupon2 = {
...coupon,
denominations: 100
denominations: 100,
};
const coupon3 = {
...coupon,
denominations: 123
denominations: 123,
};
const emptyCoupon = {
@ -32,7 +32,7 @@ const emptyCoupon = {
denominations: 0,
originCondition: 0,
startAt: 1489104000,
endAt: 1514592000
endAt: 1514592000,
};
const discountCoupon = {
@ -42,7 +42,7 @@ const discountCoupon = {
denominations: 0,
originCondition: 50,
value: 12,
description: ''
description: '',
};
const discountCoupon2 = {
@ -52,28 +52,28 @@ const discountCoupon2 = {
denominations: 0,
originCondition: 50,
value: 12,
description: ''
description: '',
};
const disabledCoupon = {
...coupon,
id: 3,
reason: 'reason'
reason: 'reason',
};
const disabledDiscountCoupon = {
...discountCoupon,
discount: 10,
id: 4,
reason: ''
reason: '',
};
test('render disabled coupon', () => {
const wrapper = mount(Coupon, {
propsData: {
coupon: disabledCoupon,
disabled: true
}
disabled: true,
},
});
expect(wrapper).toMatchSnapshot();
@ -84,8 +84,8 @@ test('render coupon list', async () => {
propsData: {
chosenCoupon: 1,
coupons: [emptyCoupon, coupon, coupon2, coupon3, discountCoupon, discountCoupon2],
disabledCoupons: [disabledCoupon, disabledDiscountCoupon]
}
disabledCoupons: [disabledCoupon, disabledDiscountCoupon],
},
});
await later();
expect(wrapper).toMatchSnapshot();
@ -95,8 +95,8 @@ test('render empty coupon list', () => {
const wrapper = mount(CouponList, {
propsData: {
coupons: [],
disabledCoupons: []
}
disabledCoupons: [],
},
});
wrapper.findAll('.van-tab').at(1).trigger('click');
expect(wrapper).toMatchSnapshot();
@ -105,8 +105,8 @@ test('render empty coupon list', () => {
test('empty-image prop', () => {
const wrapper = mount(CouponList, {
propsData: {
emptyImage: 'https://img.yzcdn.com/xxx.png'
}
emptyImage: 'https://img.yzcdn.com/xxx.png',
},
});
expect(wrapper).toMatchSnapshot();
@ -118,7 +118,7 @@ test('exchange coupon', () => {
wrapper.setData({
currentCode: '1',
displayedCouponIndex: 1
displayedCouponIndex: 1,
});
exchange.trigger('click');
wrapper.setProps({ code: '2' });
@ -136,9 +136,9 @@ test('render coupon cell', () => {
const wrapper = mount(CouponCell, {
context: {
on: {
click: onClick
}
}
click: onClick,
},
},
});
expect(wrapper).toMatchSnapshot();
@ -150,8 +150,8 @@ test('render coupon cell with coupon', () => {
const wrapper = mount(CouponCell, {
propsData: {
coupons: [{ value: 100 }],
chosenCoupon: 0
}
chosenCoupon: 0,
},
});
expect(wrapper).toMatchSnapshot();
});

View File

@ -27,8 +27,8 @@ export default createComponent({
disabled: Boolean,
currency: {
type: String,
default: '¥'
}
default: '¥',
},
},
computed: {
@ -58,7 +58,7 @@ export default createComponent({
conditionMessage() {
const condition = formatAmount(this.coupon.originCondition);
return condition === '0' ? t('unlimited') : t('condition', condition);
}
},
},
render() {
@ -83,5 +83,5 @@ export default createComponent({
{description && <p class={bem('description')}>{description}</p>}
</div>
);
}
},
});

View File

@ -14,18 +14,18 @@ export default createComponent({
...sharedProps,
type: {
type: String,
default: 'datetime'
default: 'datetime',
},
minDate: {
type: Date,
default: () => new Date(currentYear - 10, 0, 1),
validator: isDate
validator: isDate,
},
maxDate: {
type: Date,
default: () => new Date(currentYear + 10, 11, 31),
validator: isDate
}
validator: isDate,
},
},
watch: {
@ -39,7 +39,7 @@ export default createComponent({
if (val.valueOf() !== this.innerValue.valueOf()) {
this.innerValue = val;
}
}
},
},
computed: {
@ -57,30 +57,30 @@ export default createComponent({
const result = [
{
type: 'year',
range: [minYear, maxYear]
range: [minYear, maxYear],
},
{
type: 'month',
range: [minMonth, maxMonth]
range: [minMonth, maxMonth],
},
{
type: 'day',
range: [minDate, maxDate]
range: [minDate, maxDate],
},
{
type: 'hour',
range: [minHour, maxHour]
range: [minHour, maxHour],
},
{
type: 'minute',
range: [minMinute, maxMinute]
}
range: [minMinute, maxMinute],
},
];
if (this.type === 'date') result.splice(3, 2);
if (this.type === 'year-month') result.splice(2, 3);
return result;
}
},
},
methods: {
@ -128,7 +128,7 @@ export default createComponent({
[`${type}Month`]: month,
[`${type}Date`]: date,
[`${type}Hour`]: hour,
[`${type}Minute`]: minute
[`${type}Minute`]: minute,
};
},
@ -179,7 +179,7 @@ export default createComponent({
let values = [
formatter('year', `${value.getFullYear()}`),
formatter('month', padZero(value.getMonth() + 1)),
formatter('day', padZero(value.getDate()))
formatter('day', padZero(value.getDate())),
];
if (this.type === 'datetime') {
@ -196,6 +196,6 @@ export default createComponent({
this.$nextTick(() => {
this.getPicker().setValues(values);
});
}
}
},
},
});

View File

@ -12,20 +12,20 @@ export default createComponent({
...sharedProps,
minHour: {
type: Number,
default: 0
default: 0,
},
maxHour: {
type: Number,
default: 23
default: 23,
},
minMinute: {
type: Number,
default: 0
default: 0,
},
maxMinute: {
type: Number,
default: 59
}
default: 59,
},
},
computed: {
@ -33,14 +33,14 @@ export default createComponent({
return [
{
type: 'hour',
range: [this.minHour, this.maxHour]
range: [this.minHour, this.maxHour],
},
{
type: 'minute',
range: [this.minMinute, this.maxMinute]
}
range: [this.minMinute, this.maxMinute],
},
];
}
},
},
watch: {
@ -57,7 +57,7 @@ export default createComponent({
this.innerValue = val;
this.updateColumnValue(val);
}
}
},
},
methods: {
@ -100,6 +100,6 @@ export default createComponent({
this.$nextTick(() => {
this.getPicker().setValues(values);
});
}
}
},
},
});

View File

@ -57,7 +57,7 @@ export default {
title4: '选择时间',
year: '年',
month: '月',
optionFilter: '选项过滤器'
optionFilter: '选项过滤器',
},
'en-US': {
title1: 'Choose DateTime',
@ -66,8 +66,8 @@ export default {
title4: 'Choose Time',
year: ' Year',
month: ' Month',
optionFilter: 'Option Filter'
}
optionFilter: 'Option Filter',
},
},
data() {
@ -99,7 +99,7 @@ export default {
}
return values;
}
}
},
},
};
</script>

View File

@ -7,7 +7,7 @@ const [createComponent, bem] = createNamespace('datetime-picker');
export default createComponent({
props: {
...TimePicker.props,
...DatePicker.props
...DatePicker.props,
},
render() {
@ -18,9 +18,9 @@ export default createComponent({
class={bem()}
{...{
props: this.$props,
on: this.$listeners
on: this.$listeners,
}}
/>
);
}
},
});

View File

@ -9,18 +9,18 @@ export const sharedProps = {
filter: Function,
showToolbar: {
type: Boolean,
default: true
default: true,
},
formatter: {
type: Function,
default: (type, value) => value
}
default: (type, value) => value,
},
};
export const TimePickerMixin = {
data() {
return {
innerValue: this.formatValue(this.value)
innerValue: this.formatValue(this.value),
};
},
@ -38,16 +38,16 @@ export const TimePickerMixin = {
return {
type,
values
values,
};
});
},
columns() {
return this.originColumns.map(column => ({
values: column.values.map(value => this.formatter(column.type, value))
values: column.values.map(value => this.formatter(column.type, value)),
}));
}
},
},
watch: {
@ -55,7 +55,7 @@ export const TimePickerMixin = {
innerValue(val) {
this.$emit('input', val);
}
},
},
mounted() {
@ -78,7 +78,7 @@ export const TimePickerMixin = {
onCancel() {
this.$emit('cancel');
}
},
},
render() {
@ -97,5 +97,5 @@ export const TimePickerMixin = {
{...{ props }}
/>
);
}
},
};

View File

@ -16,8 +16,8 @@ test('filter prop', () => {
filter,
minDate: new Date(2020, 0, 1),
maxDate: new Date(2025, 10, 1),
value: new Date(2020, 10, 1, 0, 0)
}
value: new Date(2020, 10, 1, 0, 0),
},
});
expect(wrapper).toMatchSnapshot();
@ -30,8 +30,8 @@ test('formatter prop', async () => {
formatter,
minDate: new Date(2010, 0, 1),
maxDate: new Date(2025, 10, 1),
value: new Date(2020, 10, 1, 0, 0)
}
value: new Date(2020, 10, 1, 0, 0),
},
});
expect(wrapper).toMatchSnapshot();
@ -45,7 +45,7 @@ test('formatter prop', async () => {
'05 month',
'05 day',
'00 hour',
'00 minute'
'00 minute',
]);
});
@ -56,8 +56,8 @@ test('confirm event', () => {
propsData: {
value: date,
minDate: new Date(2020, 0, 1),
maxDate: new Date(2025, 10, 1)
}
maxDate: new Date(2025, 10, 1),
},
});
wrapper.find('.van-picker__confirm').trigger('click');
@ -80,8 +80,8 @@ test('max-date prop', () => {
const wrapper = mount(DatePicker, {
propsData: {
value: new Date(2020, 10, 30, 30, 30),
maxDate
}
maxDate,
},
});
wrapper.find('.van-picker__confirm').trigger('click');
@ -93,8 +93,8 @@ test('min-date prop', () => {
const wrapper = mount(DatePicker, {
propsData: {
value: new Date(2020, 0, 0, 0, 0),
minDate
}
minDate,
},
});
wrapper.find('.van-picker__confirm').trigger('click');
@ -104,8 +104,8 @@ test('min-date prop', () => {
test('dynamic set value', () => {
const wrapper = mount(DatePicker, {
propsData: {
value: new Date(2019, 1, 1)
}
value: new Date(2019, 1, 1),
},
});
wrapper.setProps({ value: new Date(2019, 1, 1) });
@ -132,8 +132,8 @@ test('use min-date with filter', async () => {
}
return values;
}
}
},
},
});
await later();

View File

@ -8,8 +8,8 @@ test('confirm & cancel event', () => {
const wrapper = mount(DatetimePicker, {
listeners: {
confirm: onConfirm,
cancel: onCancel
}
cancel: onCancel,
},
});
wrapper.find('.van-picker__confirm').trigger('click');
@ -24,8 +24,8 @@ test('time type', () => {
propsData: {
type: 'time',
minHour: 22,
minMinute: 58
}
minMinute: 58,
},
});
expect(wrapper).toMatchSnapshot();

View File

@ -14,8 +14,8 @@ test('format initial value', () => {
const wrapper = mount(TimePicker, {
propsData: {
minHour: 22,
minMinute: 58
}
minMinute: 58,
},
});
expect(wrapper).toMatchSnapshot();
@ -26,8 +26,8 @@ test('max-hour & max-minute', () => {
propsData: {
value: '23:59',
maxHour: 2,
maxMinute: 2
}
maxMinute: 2,
},
});
expect(wrapper).toMatchSnapshot();
@ -37,8 +37,8 @@ test('filter prop', () => {
const wrapper = mount(TimePicker, {
propsData: {
filter,
value: '12:00'
}
value: '12:00',
},
});
expect(wrapper).toMatchSnapshot();
@ -49,8 +49,8 @@ test('formatter prop', async () => {
propsData: {
filter,
formatter,
value: '12:00'
}
value: '12:00',
},
});
expect(wrapper).toMatchSnapshot();
@ -65,8 +65,8 @@ test('formatter prop', async () => {
test('confirm event', () => {
const wrapper = mount(TimePicker, {
propsData: {
value: '12:00'
}
value: '12:00',
},
});
triggerDrag(wrapper.find('.van-picker-column'), 0, -100);
@ -97,8 +97,8 @@ test('change min-minute and emit correct value', async () => {
const wrapper = mount(TimePicker, {
propsData: {
value: '12:00',
minMinute: 0
}
minMinute: 0,
},
});
await later();
@ -112,7 +112,7 @@ test('set max-hour & max-minute smaller than current then emit correct value', a
const wrapper = mount(TimePicker, {
propsData: {
value: '23:59',
}
},
});
await later();
wrapper.setProps({

View File

@ -23,28 +23,28 @@ export default createComponent({
showCancelButton: Boolean,
transition: {
type: String,
default: 'van-dialog-bounce'
default: 'van-dialog-bounce',
},
showConfirmButton: {
type: Boolean,
default: true
default: true,
},
overlay: {
type: Boolean,
default: true
default: true,
},
closeOnClickOverlay: {
type: Boolean,
default: false
}
default: false,
},
},
data() {
return {
loading: {
confirm: false,
cancel: false
}
cancel: false,
},
};
},
@ -90,7 +90,7 @@ export default createComponent({
onClosed() {
this.$emit('closed');
}
},
},
render() {
@ -166,5 +166,5 @@ export default createComponent({
</div>
</transition>
);
}
},
});

View File

@ -16,7 +16,7 @@
<demo-block :title="$t('componentCall')">
<van-button type="primary" @click="show = true">{{ $t('componentCall') }}</van-button>
<van-dialog v-model="show" :title="$t('title')" show-cancel-button :lazy-render="false">
<img :src="image">
<img :src="image" />
</van-dialog>
</demo-block>
</demo-section>
@ -31,22 +31,22 @@ export default {
confirm: '确认弹窗',
asyncClose: '异步关闭',
componentCall: '组件调用',
content: '代码是写出来给人看的,附带能在机器上运行'
content: '代码是写出来给人看的,附带能在机器上运行',
},
'en-US': {
alert1: 'Alert',
alert2: 'Alert without title',
confirm: 'Confirm dialog',
asyncClose: 'Async Close',
componentCall: 'Component Call'
}
componentCall: 'Component Call',
},
},
data() {
return {
show: false,
currentRate: 0,
image: 'https://img.yzcdn.cn/vant/apple-3.jpg'
image: 'https://img.yzcdn.cn/vant/apple-3.jpg',
};
},
@ -54,20 +54,20 @@ export default {
onClickAlert() {
this.$dialog.alert({
title: this.$t('title'),
message: this.$t('content')
message: this.$t('content'),
});
},
onClickAlert2() {
this.$dialog.alert({
message: this.$t('content')
message: this.$t('content'),
});
},
onClickConfirm() {
this.$dialog.confirm({
title: this.$t('title'),
message: this.$t('content')
message: this.$t('content'),
});
},
@ -83,10 +83,10 @@ export default {
this.$dialog.confirm({
title: this.$t('title'),
message: this.$t('content'),
beforeClose
beforeClose,
});
}
}
},
},
};
</script>

View File

@ -17,8 +17,8 @@ function initInstance() {
el: document.createElement('div'),
// avoid missing animation when first rendered
propsData: {
lazyRender: false
}
lazyRender: false,
},
});
instance.$on('input', value => {
@ -39,7 +39,7 @@ function Dialog(options) {
Object.assign(instance, Dialog.currentOptions, options, {
resolve,
reject
reject,
});
});
}
@ -68,14 +68,14 @@ Dialog.defaultOptions = {
closeOnClickOverlay: false,
callback: action => {
instance[action === 'confirm' ? 'resolve' : 'reject'](action);
}
},
};
Dialog.alert = Dialog;
Dialog.confirm = options => Dialog({
showCancelButton: true,
...options
...options,
});
Dialog.close = () => {

View File

@ -7,7 +7,7 @@ test('Dialog function call', async () => {
Dialog.close();
Dialog.alert({
message: '1',
showCancelButton: true
showCancelButton: true,
});
await later();
@ -38,8 +38,8 @@ test('before close', () => {
value: true,
showCancelButton: true,
closeOnClickOverlay: true,
beforeClose: (action, done) => done(false)
}
beforeClose: (action, done) => done(false),
},
});
const cancel = wrapper.find('.van-dialog__cancel');
@ -52,7 +52,7 @@ test('before close', () => {
if (action === 'cancel') {
done();
}
}
},
});
const overlay = document.querySelector('.van-overlay');
@ -81,8 +81,8 @@ test('button color', () => {
value: true,
showCancelButton: true,
cancelButtonColor: 'white',
confirmButtonColor: 'red'
}
confirmButtonColor: 'red',
},
});
expect(wrapper).toMatchSnapshot();
});
@ -93,8 +93,8 @@ test('button text', () => {
value: true,
showCancelButton: true,
cancelButtonText: 'Custom cancel',
confirmButtonText: 'Custom confirm'
}
confirmButtonText: 'Custom confirm',
},
});
expect(wrapper).toMatchSnapshot();
});
@ -106,11 +106,11 @@ test('dialog component', () => {
test('default slot', () => {
const wrapper = mount(DialogComponent, {
propsData: {
value: true
value: true,
},
scopedSlots: {
default: () => 'Custom Message'
}
default: () => 'Custom Message',
},
});
expect(wrapper).toMatchSnapshot();
});
@ -118,11 +118,11 @@ test('default slot', () => {
test('title slot', () => {
const wrapper = mount(DialogComponent, {
propsData: {
value: true
value: true,
},
scopedSlots: {
title: () => 'Custom Title'
}
title: () => 'Custom Title',
},
});
expect(wrapper).toMatchSnapshot();
});
@ -139,8 +139,8 @@ test('width prop', () => {
const wrapper = mount(DialogComponent, {
propsData: {
value: true,
width: 200
}
width: 200,
},
});
expect(wrapper.element.style.width).toEqual('200px');

View File

@ -47,22 +47,22 @@ export default {
dashed: '虚线',
withText: '展示文本',
contentPosition: '内容位置',
customStyle: '自定义样式'
customStyle: '自定义样式',
},
'en-US': {
text: 'Text',
dashed: 'Dashed',
withText: 'With Text',
contentPosition: 'Content Position',
customStyle: 'Custom Style'
}
customStyle: 'Custom Style',
},
},
data() {
return {
BLUE
BLUE,
};
}
},
};
</script>

View File

@ -27,7 +27,7 @@ function Divider(
class={bem({
dashed: props.dashed,
hairline: props.hairline,
[`content-${props.contentPosition}`]: slots.default
[`content-${props.contentPosition}`]: slots.default,
})}
{...inherit(ctx, true)}
>
@ -40,12 +40,12 @@ Divider.props = {
dashed: Boolean,
hairline: {
type: Boolean,
default: true
default: true,
},
contentPosition: {
type: String,
default: 'center'
}
default: 'center',
},
};
export default createComponent<DividerProps>(Divider);

View File

@ -18,15 +18,15 @@ export default createComponent({
titleClass: String,
options: {
type: Array,
default: () => []
}
default: () => [],
},
},
data() {
return {
transition: true,
showPopup: false,
showWrapper: false
showWrapper: false,
};
},
@ -38,13 +38,13 @@ export default createComponent({
const match = this.options.filter(option => option.value === this.value);
return match.length ? match[0].text : '';
}
},
},
watch: {
showPopup(val) {
this.bindScroll(val);
}
},
},
beforeCreate() {
@ -86,7 +86,7 @@ export default createComponent({
if (this.getContainer) {
event.stopPropagation();
}
}
},
},
render() {
@ -97,7 +97,7 @@ export default createComponent({
duration,
direction,
activeColor,
closeOnClickOverlay
closeOnClickOverlay,
} = this.parent;
const Options = this.options.map(option => {
@ -164,5 +164,5 @@ export default createComponent({
</div>
</div>
);
}
},
});

View File

@ -55,13 +55,13 @@ export default {
option1: [
{ text: '全部商品', value: 0 },
{ text: '新款商品', value: 1 },
{ text: '活动商品', value: 2 }
{ text: '活动商品', value: 2 },
],
option2: [
{ text: '默认排序', value: 'a' },
{ text: '好评排序', value: 'b' },
{ text: '销量排序', value: 'c' }
]
{ text: '销量排序', value: 'c' },
],
},
'en-US': {
disableMenu: 'Disable Menu',
@ -74,14 +74,14 @@ export default {
option1: [
{ text: 'Option1', value: 0 },
{ text: 'Option2', value: 1 },
{ text: 'Option3', value: 2 }
{ text: 'Option3', value: 2 },
],
option2: [
{ text: 'Option A', value: 'a' },
{ text: 'Option B', value: 'b' },
{ text: 'Option C', value: 'c' }
]
}
{ text: 'Option C', value: 'c' },
],
},
},
data() {
@ -89,7 +89,7 @@ export default {
switch1: true,
switch2: false,
value1: 0,
value2: 'a'
value2: 'a',
};
},
@ -100,13 +100,13 @@ export default {
option2() {
return this.$t('option2');
}
},
},
methods: {
onConfirm() {
this.$refs.item.toggle();
}
}
},
},
};
</script>

View File

@ -11,44 +11,44 @@ export default createComponent({
ParentMixin('vanDropdownMenu'),
ClickOutsideMixin({
event: 'click',
method: 'onClickOutside'
})
method: 'onClickOutside',
}),
],
props: {
activeColor: String,
overlay: {
type: Boolean,
default: true
default: true,
},
zIndex: {
type: Number,
default: 10
default: 10,
},
duration: {
type: Number,
default: 0.2
default: 0.2,
},
direction: {
type: String,
default: 'down'
default: 'down',
},
closeOnClickOverlay: {
type: Boolean,
default: true
}
default: true,
},
},
data() {
return {
offset: 0
offset: 0,
};
},
computed: {
scroller() {
return getScroller(this.$el);
}
},
},
methods: {
@ -77,7 +77,7 @@ export default createComponent({
this.children.forEach(item => {
item.toggle(false);
});
}
},
},
render() {
@ -96,9 +96,9 @@ export default createComponent({
class={[
bem('title', {
active: item.showPopup,
down: item.showPopup === (this.direction === 'down')
down: item.showPopup === (this.direction === 'down'),
}),
item.titleClass
item.titleClass,
]}
style={{ color: item.showPopup ? this.activeColor : '' }}
>
@ -113,5 +113,5 @@ export default createComponent({
{this.slots('default')}
</div>
);
}
},
});

View File

@ -16,10 +16,10 @@ function renderWrapper(options = {}) {
closeOnClickOutside: options.closeOnClickOutside,
options: [
{ text: 'A', value: 0, icon: options.icon },
{ text: 'B', value: 1, icon: options.icon }
]
{ text: 'B', value: 1, icon: options.icon },
],
};
}
},
});
}
@ -42,7 +42,7 @@ test('show dropdown item', async () => {
test('render option icon', async () => {
const wrapper = renderWrapper({
icon: 'success'
icon: 'success',
});
await later();
@ -55,7 +55,7 @@ test('render option icon', async () => {
test('close-on-click-outside', async () => {
const wrapper = renderWrapper({
closeOnClickOutside: true
closeOnClickOutside: true,
});
await later();
@ -69,7 +69,7 @@ test('close-on-click-outside', async () => {
test('disable close-on-click-outside', async () => {
const wrapper = renderWrapper({
closeOnClickOutside: false
closeOnClickOutside: false,
});
await later();
@ -86,7 +86,7 @@ test('direction up', async () => {
window.innerHeight = 1000;
const wrapper = renderWrapper({
direction: 'up'
direction: 'up',
});
await later();
@ -140,10 +140,10 @@ test('destroy one item', async () => {
render: true,
options: [
{ text: 'A', value: 0 },
{ text: 'B', value: 1 }
]
{ text: 'B', value: 1 },
],
};
}
},
});
await later();
@ -163,10 +163,10 @@ test('disable dropdown item', async () => {
value: 0,
options: [
{ text: 'A', value: 0 },
{ text: 'B', value: 1 }
]
{ text: 'B', value: 1 },
],
};
}
},
});
const title = wrapper.find('.van-dropdown-menu__title');
@ -189,13 +189,13 @@ test('change event', async () => {
value: 0,
options: [
{ text: 'A', value: 0 },
{ text: 'B', value: 1 }
]
{ text: 'B', value: 1 },
],
};
},
methods: {
onChange
}
onChange,
},
});
await later();
@ -232,7 +232,7 @@ test('toggle method', async done => {
expect(wrapper).toMatchSnapshot();
done();
}
},
});
});
@ -246,7 +246,7 @@ test('title slot', () => {
</template>
</van-dropdown-item>
</van-dropdown-menu>
`
`,
});
expect(wrapper).toMatchSnapshot();

View File

@ -221,7 +221,7 @@ export default {
numberPlaceholder: 'Number',
messagePlaceholder: 'Message',
alignPlaceHolder: 'Input Align Right',
}
},
},
data() {
@ -240,15 +240,15 @@ export default {
message2: '',
phone: '',
phone2: '12345',
formatValue: ''
formatValue: '',
};
},
methods: {
formatter(value) {
return value.replace(/\d/g, '');
}
}
},
},
};
</script>

View File

@ -33,20 +33,20 @@ export default createComponent({
showWordLimit: Boolean,
type: {
type: String,
default: 'text'
}
default: 'text',
},
},
data() {
return {
focused: false
focused: false,
};
},
watch: {
value() {
this.$nextTick(this.adjustSize);
}
},
},
mounted() {
@ -71,7 +71,7 @@ export default createComponent({
input: this.onInput,
keypress: this.onKeypress,
focus: this.onFocus,
blur: this.onBlur
blur: this.onBlur,
};
delete listeners.click;
@ -84,7 +84,7 @@ export default createComponent({
if (labelWidth) {
return { width: addUnit(labelWidth) };
}
}
},
},
methods: {
@ -230,22 +230,22 @@ export default createComponent({
ref: 'input',
class: bem('control', this.inputAlign),
domProps: {
value: this.value
value: this.value,
},
attrs: {
...this.$attrs,
disabled: this.disabled,
readonly: this.readonly,
placeholder: this.placeholder
placeholder: this.placeholder,
},
on: this.listeners,
// add model directive to skip IME composition
directives: [
{
name: 'model',
value: this.value
}
]
value: this.value,
},
],
};
if (type === 'textarea') {
@ -306,14 +306,14 @@ export default createComponent({
</div>
);
}
}
},
},
render() {
const { slots, labelAlign } = this;
const scopedSlots = {
icon: this.genLeftIcon
icon: this.genLeftIcon,
};
if (slots('label')) {
@ -336,7 +336,7 @@ export default createComponent({
class={bem({
error: this.error,
[`label-${labelAlign}`]: labelAlign,
'min-height': this.type === 'textarea' && !this.autosize
'min-height': this.type === 'textarea' && !this.autosize,
})}
scopedSlots={scopedSlots}
onClick={this.onClick}
@ -363,5 +363,5 @@ export default createComponent({
)}
</Cell>
);
}
},
});

View File

@ -22,8 +22,8 @@ test('click icon event', () => {
propsData: {
value: 'a',
leftIcon: 'contact',
rightIcon: 'search'
}
rightIcon: 'search',
},
});
wrapper.find('.van-field__left-icon').trigger('click');
@ -37,8 +37,8 @@ test('number type', () => {
const wrapper = mount(Field, {
propsData: {
value: '',
type: 'number'
}
type: 'number',
},
});
const input = wrapper.find('input');
@ -60,8 +60,8 @@ test('digit type', () => {
const wrapper = mount(Field, {
propsData: {
value: '',
type: 'digit'
}
type: 'digit',
},
});
const input = wrapper.find('input');
@ -83,8 +83,8 @@ test('render textarea', async () => {
const wrapper = mount(Field, {
propsData: {
type: 'textarea',
autosize: true
}
autosize: true,
},
});
await later();
@ -95,8 +95,8 @@ test('autosize textarea field', () => {
const wrapper = mount(Field, {
propsData: {
type: 'textarea',
autosize: {}
}
autosize: {},
},
});
const value = '1'.repeat(20);
@ -112,9 +112,9 @@ test('autosize object', async () => {
type: 'textarea',
autosize: {
maxHeight: 100,
minHeight: 50
}
}
minHeight: 50,
},
},
});
const textarea = wrapper.find('.van-field__control');
@ -147,12 +147,12 @@ test('focus method', () => {
test('maxlength', async () => {
const wrapper = mount(Field, {
attrs: {
maxlength: 3
maxlength: 3,
},
propsData: {
value: 1234,
type: 'number'
}
type: 'number',
},
});
const input = wrapper.find('input');
@ -170,8 +170,8 @@ test('clearable', () => {
const wrapper = mount(Field, {
propsData: {
value: 'test',
clearable: true
}
clearable: true,
},
});
expect(wrapper).toMatchSnapshot();
@ -192,8 +192,8 @@ test('render input slot', () => {
</field>
`,
components: {
Field
}
Field,
},
});
expect(wrapper).toMatchSnapshot();
@ -207,8 +207,8 @@ test('render label slot', () => {
</field>
`,
components: {
Field
}
Field,
},
});
expect(wrapper).toMatchSnapshot();
@ -217,8 +217,8 @@ test('render label slot', () => {
test('size prop', () => {
const wrapper = mount(Field, {
propsData: {
size: 'large'
}
size: 'large',
},
});
expect(wrapper).toMatchSnapshot();
});
@ -227,8 +227,8 @@ test('label-width prop with unit', () => {
const wrapper = mount(Field, {
propsData: {
label: 'Label',
labelWidth: '10rem'
}
labelWidth: '10rem',
},
});
expect(wrapper).toMatchSnapshot();
});
@ -237,8 +237,8 @@ test('label-width prop without unit', () => {
const wrapper = mount(Field, {
propsData: {
label: 'Label',
labelWidth: 100
}
labelWidth: 100,
},
});
expect(wrapper).toMatchSnapshot();
});
@ -247,8 +247,8 @@ test('label-class prop', () => {
const wrapper = mount(Field, {
propsData: {
label: 'Label',
labelClass: 'custom-label-class'
}
labelClass: 'custom-label-class',
},
});
expect(wrapper).toMatchSnapshot();
});
@ -257,8 +257,8 @@ test('arrow-direction prop', () => {
const wrapper = mount(Field, {
propsData: {
isLink: true,
arrowDirection: 'up'
}
arrowDirection: 'up',
},
});
expect(wrapper).toMatchSnapshot();
});
@ -267,8 +267,8 @@ test('formatter prop', () => {
const wrapper = mount(Field, {
propsData: {
value: 'abc123',
formatter: (value) => value.replace(/\d/g, '')
}
formatter: (value) => value.replace(/\d/g, ''),
},
});
const input = wrapper.find('input');

View File

@ -14,7 +14,7 @@ export default createComponent({
text: String,
color: String,
loading: Boolean,
disabled: Boolean
disabled: Boolean,
},
computed: {
@ -26,14 +26,14 @@ export default createComponent({
isLast() {
const next = this.parent && this.parent.children[this.index + 1];
return !next || next.$options.name !== this.$options.name;
}
},
},
methods: {
onClick(event) {
this.$emit('click', event);
route(this.$router, this);
}
},
},
render() {
@ -42,9 +42,9 @@ export default createComponent({
class={bem([
{
first: this.isFirst,
last: this.isLast
last: this.isLast,
},
this.type
this.type,
])}
square
size="large"
@ -57,5 +57,5 @@ export default createComponent({
{this.slots() || this.text}
</Button>
);
}
},
});

View File

@ -14,7 +14,7 @@ export default createComponent({
icon: String,
color: String,
info: [Number, String],
iconClass: null
iconClass: null,
},
methods: {
@ -39,7 +39,7 @@ export default createComponent({
color={this.color}
/>
);
}
},
},
render() {
@ -49,5 +49,5 @@ export default createComponent({
{this.slots() || this.text}
</div>
);
}
},
});

View File

@ -55,7 +55,7 @@ export default {
clickIcon: '点击图标',
clickButton: '点击按钮',
customIconColor: '自定义图标颜色',
customButtonColor: '自定义按钮颜色'
customButtonColor: '自定义按钮颜色',
},
'en-US': {
icon1: 'Icon1',
@ -68,8 +68,8 @@ export default {
clickIcon: 'Click Icon',
clickButton: 'Click Button',
customIconColor: 'Custom Icon Color',
customButtonColor: 'Custom Button Color'
}
customButtonColor: 'Custom Button Color',
},
},
methods: {
onClickIcon() {
@ -77,8 +77,8 @@ export default {
},
onClickButton() {
this.$toast(this.$t('clickButton'));
}
}
},
},
};
</script>

View File

@ -7,7 +7,7 @@ export default createComponent({
mixins: [ParentMixin('vanGoodsAction')],
props: {
safeAreaInsetBottom: Boolean
safeAreaInsetBottom: Boolean,
},
render() {
@ -16,5 +16,5 @@ export default createComponent({
{this.slots()}
</div>
);
}
},
});

View File

@ -18,7 +18,7 @@ test('Button render default slot', () => {
const wrapper = mount({
render(h) {
return h(Button, null, ['Default Content']);
}
},
});
expect(wrapper).toMatchSnapshot();
@ -28,7 +28,7 @@ test('Icon render default slot', () => {
const wrapper = mount({
render(h) {
return h(Icon, null, ['Default Content']);
}
},
});
expect(wrapper).toMatchSnapshot();
@ -40,10 +40,10 @@ test('Icon render icon slot', () => {
return h(Icon, {
scopedSlots: {
default: () => 'Text',
icon: () => 'Custom Icon'
}
icon: () => 'Custom Icon',
},
});
}
},
});
expect(wrapper).toMatchSnapshot();

View File

@ -15,7 +15,7 @@ export default createComponent({
dot: Boolean,
text: String,
icon: String,
info: [Number, String]
info: [Number, String],
},
computed: {
@ -24,7 +24,7 @@ export default createComponent({
const percent = `${100 / columnNum}%`;
const style = {
flexBasis: percent
flexBasis: percent,
};
if (square) {
@ -50,10 +50,10 @@ export default createComponent({
return {
right: gutterValue,
bottom: gutterValue,
height: 'auto'
height: 'auto',
};
}
}
},
},
methods: {
@ -96,9 +96,9 @@ export default createComponent({
return [
this.genIcon(),
this.slots('text') || (this.text && <span class={bem('text')}>{this.text}</span>)
this.slots('text') || (this.text && <span class={bem('text')}>{this.text}</span>),
];
}
},
},
render() {
@ -115,9 +115,9 @@ export default createComponent({
center,
square,
clickable,
surround: border && gutter
surround: border && gutter,
}),
{ [BORDER]: border }
{ [BORDER]: border },
]}
onClick={this.onClick}
>
@ -125,5 +125,5 @@ export default createComponent({
</div>
</div>
);
}
},
});

View File

@ -66,7 +66,7 @@ export default {
customContent: '自定义内容',
urlRoute: 'URL 跳转',
vueRoute: '路由跳转',
showInfo: '提示信息'
showInfo: '提示信息',
},
'en-US': {
text: 'Text',
@ -77,9 +77,9 @@ export default {
customContent: 'Custom Content',
urlRoute: 'URL',
vueRoute: 'Vue Router',
showInfo: 'Show Info'
}
}
showInfo: 'Show Info',
},
},
};
</script>

View File

@ -14,16 +14,16 @@ export default createComponent({
clickable: Boolean,
columnNum: {
type: Number,
default: 4
default: 4,
},
center: {
type: Boolean,
default: true
default: true,
},
border: {
type: Boolean,
default: true
}
default: true,
},
},
computed: {
@ -32,10 +32,10 @@ export default createComponent({
if (gutter) {
return {
paddingLeft: addUnit(gutter)
paddingLeft: addUnit(gutter),
};
}
}
},
},
render() {
@ -47,5 +47,5 @@ export default createComponent({
{this.slots()}
</div>
);
}
},
});

View File

@ -9,8 +9,8 @@ test('click grid item', () => {
</van-grid>
`,
methods: {
onClick
}
onClick,
},
});
const Item = wrapper.find('.van-grid-item__content');
@ -27,7 +27,7 @@ test('sqaure and set gutter', () => {
<van-grid-item />
<van-grid-item />
</van-grid>
`
`,
});
expect(wrapper).toMatchSnapshot();
@ -39,7 +39,7 @@ test('icon-size prop', () => {
<van-grid icon-size="10">
<van-grid-item icon="success" />
</van-grid>
`
`,
});
expect(wrapper).toMatchSnapshot();
@ -53,7 +53,7 @@ test('render icon-slot', () => {
<div slot="icon" />
</van-grid-item>
</van-grid>
`
`,
});
expect(wrapper).toMatchSnapshot();

View File

@ -120,7 +120,7 @@ export default {
filled: '实底风格',
demo: '用法示例',
color: '图标颜色',
size: '图标大小'
size: '图标大小',
},
'en-US': {
title: 'Icon List',
@ -131,8 +131,8 @@ export default {
filled: 'Filled',
demo: 'Demo',
color: 'Icon Color',
size: 'Icon Size'
}
size: 'Icon Size',
},
},
data() {
@ -142,7 +142,7 @@ export default {
return {
tab: 0,
demoIcon: 'chat-o',
demoImage: 'https://b.yzcdn.cn/vant/icon-demo-1126.png'
demoImage: 'https://b.yzcdn.cn/vant/icon-demo-1126.png',
};
},
@ -168,10 +168,10 @@ export default {
type: 'success',
duration: 1500,
className: 'demo-icon-notify',
message: `${this.$t('copied')}${tag}`
message: `${this.$t('copied')}${tag}`,
});
}
}
},
},
};
</script>

View File

@ -29,7 +29,7 @@ function isImage(name?: string): boolean {
// compatible with legacy usage, should be removed in next major version
const LEGACY_MAP: Record<string, string> = {
medel: 'medal',
'medel-o': 'medal-o'
'medel-o': 'medal-o',
};
function correctName(name?: string) {
@ -49,11 +49,11 @@ function Icon(
<props.tag
class={[
props.classPrefix,
imageIcon ? '' : `${props.classPrefix}-${name}`
imageIcon ? '' : `${props.classPrefix}-${name}`,
]}
style={{
color: props.color,
fontSize: addUnit(props.size)
fontSize: addUnit(props.size),
}}
{...inherit(ctx, true)}
>
@ -72,12 +72,12 @@ Icon.props = {
color: String,
tag: {
type: String,
default: 'i'
default: 'i',
},
classPrefix: {
type: String,
default: bem()
}
default: bem(),
},
};
export default createComponent<IconProps, IconEvents>(Icon);

View File

@ -4,8 +4,8 @@ import { mount } from '../../../test';
test('render icon with builtin icon name', () => {
const wrapper = mount(Icon, {
propsData: {
name: 'success'
}
name: 'success',
},
});
expect(wrapper).toMatchSnapshot();
});
@ -13,8 +13,8 @@ test('render icon with builtin icon name', () => {
test('render icon with url name', () => {
const wrapper = mount(Icon, {
propsData: {
name: 'https://img.yzcdn.com/icon.jpg'
}
name: 'https://img.yzcdn.com/icon.jpg',
},
});
expect(wrapper).toMatchSnapshot();
});
@ -22,8 +22,8 @@ test('render icon with url name', () => {
test('render icon with local image', () => {
const wrapper = mount(Icon, {
propsData: {
name: '/assets/icon.jpg'
}
name: '/assets/icon.jpg',
},
});
expect(wrapper).toMatchSnapshot();
});
@ -32,7 +32,7 @@ test('render icon default slot', () => {
const wrapper = mount({
render(h) {
return h(Icon, { props: { name: 'success' } }, ['Default slot']);
}
},
});
expect(wrapper).toMatchSnapshot();
});
@ -40,8 +40,8 @@ test('render icon default slot', () => {
test('tag prop', () => {
const wrapper = mount(Icon, {
propsData: {
tag: 'div'
}
tag: 'div',
},
});
expect(wrapper).toMatchSnapshot();
});
@ -49,8 +49,8 @@ test('tag prop', () => {
test('dot prop', () => {
const wrapper = mount(Icon, {
propsData: {
dot: true
}
dot: true,
},
});
expect(wrapper).toMatchSnapshot();
});
@ -58,8 +58,8 @@ test('dot prop', () => {
test('size without unit', () => {
const wrapper = mount(Icon, {
propsData: {
size: 20
}
size: 20,
},
});
expect(wrapper).toMatchSnapshot();
});

View File

@ -20,9 +20,9 @@ function getDistance(touches) {
export default createComponent({
mixins: [
PopupMixin({
skipToggleEvent: true
skipToggleEvent: true,
}),
TouchMixin
TouchMixin,
],
props: {
@ -32,40 +32,40 @@ export default createComponent({
showIndicators: Boolean,
images: {
type: Array,
default: () => []
default: () => [],
},
loop: {
type: Boolean,
default: true
default: true,
},
swipeDuration: {
type: Number,
default: 500
default: 500,
},
overlay: {
type: Boolean,
default: true
default: true,
},
showIndex: {
type: Boolean,
default: true
default: true,
},
startPosition: {
type: Number,
default: 0
default: 0,
},
minZoom: {
type: Number,
default: 1 / 3
default: 1 / 3,
},
maxZoom: {
type: Number,
default: 3
default: 3,
},
overlayClass: {
type: String,
default: bem('overlay')
}
default: bem('overlay'),
},
},
data() {
@ -76,7 +76,7 @@ export default createComponent({
active: 0,
moving: false,
zooming: false,
doubleClickTimer: null
doubleClickTimer: null,
};
},
@ -84,7 +84,7 @@ export default createComponent({
imageStyle() {
const { scale } = this;
const style = {
transitionDuration: this.zooming || this.moving ? '0s' : '.3s'
transitionDuration: this.zooming || this.moving ? '0s' : '.3s',
};
if (scale !== 1) {
@ -93,7 +93,7 @@ export default createComponent({
}
return style;
}
},
},
watch: {
@ -106,7 +106,7 @@ export default createComponent({
} else {
this.$emit('close', {
index: this.active,
url: this.images[this.active]
url: this.images[this.active],
});
}
},
@ -127,8 +127,8 @@ export default createComponent({
});
}
},
immediate: true
}
immediate: true,
},
},
methods: {
@ -288,7 +288,7 @@ export default createComponent({
genImages() {
const imageSlots = {
loading: () => <Loading type="spinner" />
loading: () => <Loading type="spinner" />,
};
return (
@ -320,7 +320,7 @@ export default createComponent({
))}
</Swipe>
);
}
},
},
render() {
@ -337,5 +337,5 @@ export default createComponent({
</div>
</transition>
);
}
},
});

View File

@ -41,7 +41,7 @@ const images = [
'https://img.yzcdn.cn/vant/apple-1.jpg',
'https://img.yzcdn.cn/vant/apple-2.jpg',
'https://img.yzcdn.cn/vant/apple-3.jpg',
'https://img.yzcdn.cn/vant/apple-4.jpg'
'https://img.yzcdn.cn/vant/apple-4.jpg',
];
export default {
@ -51,22 +51,22 @@ export default {
button2: '指定初始位置',
button3: '异步关闭',
componentCall: '组件调用',
index: index => `${index + 1}`
index: index => `${index + 1}`,
},
'en-US': {
button1: 'Show Images',
button2: 'Custom Start Position',
button3: 'Async Close',
componentCall: 'Component Call',
index: index => `Page: ${index}`
}
index: index => `Page: ${index}`,
},
},
data() {
return {
show: false,
images,
index: 0
index: 0,
};
},
@ -86,7 +86,7 @@ export default {
swipeDuration: 300,
asyncClose: !!timer,
closeOnPopstate: true,
startPosition: typeof position === 'number' ? position : 0
startPosition: typeof position === 'number' ? position : 0,
});
if (timer) {
@ -94,8 +94,8 @@ export default {
instance.close();
}, timer);
}
}
}
},
},
};
</script>

View File

@ -19,12 +19,12 @@ const defaultConfig = {
startPosition: 0,
swipeDuration: 500,
showIndicators: false,
closeOnPopstate: false
closeOnPopstate: false,
};
const initInstance = () => {
instance = new (Vue.extend(VueImagePreview))({
el: document.createElement('div')
el: document.createElement('div'),
});
document.body.appendChild(instance.$el);

View File

@ -15,12 +15,12 @@ function triggerZoom(el, x, y) {
const images = [
'https://img.yzcdn.cn/1.png',
'https://img.yzcdn.cn/2.png',
'https://img.yzcdn.cn/3.png'
'https://img.yzcdn.cn/3.png',
];
test('render image', async () => {
const wrapper = mount(ImagePreviewVue, {
propsData: { images, value: true }
propsData: { images, value: true },
});
expect(wrapper).toMatchSnapshot();
@ -43,13 +43,13 @@ test('async close prop', async () => {
propsData: {
images,
value: true,
asyncClose: true
asyncClose: true,
},
listeners: {
input(value) {
wrapper.setProps({ value });
}
}
},
},
});
const swipe = wrapper.find('.van-swipe__track');
@ -99,7 +99,7 @@ test('onClose option', () => {
const instance = ImagePreview({
images,
startPostion: 1,
onClose
onClose,
});
instance.close();
@ -115,7 +115,7 @@ test('onChange option', async done => {
onChange(index) {
expect(index).toEqual(2);
done();
}
},
});
const swipe = instance.$el.querySelector('.van-swipe__track');
@ -132,7 +132,7 @@ test('zoom', async () => {
Element.prototype.getBoundingClientRect = jest.fn(() => ({ width: 100 }));
const wrapper = mount(ImagePreviewVue, {
propsData: { images, value: true }
propsData: { images, value: true },
});
const image = wrapper.find('img');
@ -146,8 +146,8 @@ test('set show-index prop to false', () => {
const wrapper = mount(ImagePreviewVue, {
propsData: {
value: true,
showIndex: false
}
showIndex: false,
},
});
expect(wrapper).toMatchSnapshot();
@ -159,7 +159,7 @@ test('index slot', () => {
<van-image-preview :value="true">
<template #index>Custom Index</template>
</van-image-preview>
`
`,
});
expect(wrapper).toMatchSnapshot();
@ -171,7 +171,7 @@ test('cover slot', () => {
<van-image-preview :value="true">
<template #cover>Custom Cover Content</template>
</van-image-preview>
`
`,
});
expect(wrapper).toMatchSnapshot();
@ -182,8 +182,8 @@ test('closeOnPopstate', () => {
propsData: {
images,
value: true,
closeOnPopstate: true
}
closeOnPopstate: true,
},
});
trigger(window, 'popstate');
@ -191,7 +191,7 @@ test('closeOnPopstate', () => {
wrapper.setProps({
value: true,
closeOnPopstate: false
closeOnPopstate: false,
});
trigger(window, 'popstate');
@ -202,12 +202,12 @@ test('lazy-load prop', () => {
const wrapper = mount(ImagePreviewVue, {
propsData: {
images,
lazyLoad: true
}
lazyLoad: true,
},
});
wrapper.setProps({
value: true
value: true,
});
expect(wrapper).toMatchSnapshot();

View File

@ -70,7 +70,7 @@ export default {
error: '加载失败提示',
defaultTip: '默认提示',
customTip: '自定义提示',
loadFail: '加载失败'
loadFail: '加载失败',
},
'en-US': {
fitMode: 'Fit Mode',
@ -79,16 +79,16 @@ export default {
error: 'Error',
defaultTip: 'Default Tip',
customTip: 'Custom Tip',
loadFail: 'Load failed'
}
loadFail: 'Load failed',
},
},
data() {
return {
image: 'https://img.yzcdn.cn/vant/cat.jpeg',
fits: ['contain', 'cover', 'fill', 'none', 'scale-down']
fits: ['contain', 'cover', 'fill', 'none', 'scale-down'],
};
}
},
};
</script>

View File

@ -15,26 +15,26 @@ export default createComponent({
lazyLoad: Boolean,
showError: {
type: Boolean,
default: true
default: true,
},
showLoading: {
type: Boolean,
default: true
default: true,
},
errorIcon: {
type: String,
default: 'warning-o'
default: 'warning-o',
},
loadingIcon: {
type: String,
default: 'photo-o'
}
default: 'photo-o',
},
},
data() {
return {
loading: true,
error: false
error: false,
};
},
@ -42,7 +42,7 @@ export default createComponent({
src() {
this.loading = true;
this.error = false;
}
},
},
computed: {
@ -63,7 +63,7 @@ export default createComponent({
}
return style;
}
},
},
created() {
@ -138,11 +138,11 @@ export default createComponent({
const imgData = {
class: bem('img'),
attrs: {
alt: this.alt
alt: this.alt,
},
style: {
objectFit: this.fit
}
objectFit: this.fit,
},
};
if (this.error) {
@ -161,7 +161,7 @@ export default createComponent({
{...imgData}
/>
);
}
},
},
render() {
@ -175,5 +175,5 @@ export default createComponent({
{this.genPlaceholder()}
</div>
);
}
},
});

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