mirror of
https://github.com/youzan/vant.git
synced 2025-10-17 08:37:23 +00:00
183 lines
4.1 KiB
JavaScript
183 lines
4.1 KiB
JavaScript
import Collapse from '..';
|
|
import CollapseItem from '../../collapse-item';
|
|
import { later, mount } from '../../../test';
|
|
|
|
const component = {
|
|
template: `
|
|
<van-collapse v-model="active" :accordion="accordion" :border="border">
|
|
<van-collapse-item title="a" name="first">content</van-collapse-item>
|
|
<van-collapse-item title="b">content</van-collapse-item>
|
|
<van-collapse-item title="c">content</van-collapse-item>
|
|
</van-collapse>
|
|
`,
|
|
props: {
|
|
accordion: Boolean,
|
|
border: {
|
|
type: Boolean,
|
|
default: true,
|
|
},
|
|
},
|
|
data() {
|
|
return {
|
|
active: this.accordion ? '' : [],
|
|
};
|
|
},
|
|
};
|
|
|
|
test('basic mode', async () => {
|
|
const wrapper = mount(component);
|
|
|
|
const titles = wrapper.findAll('.van-collapse-item__title');
|
|
titles.at(0).trigger('click');
|
|
expect(wrapper.vm.active).toEqual(['first']);
|
|
|
|
await later();
|
|
titles.at(1).trigger('click');
|
|
expect(wrapper.vm.active).toEqual(['first', 1]);
|
|
|
|
await later();
|
|
titles.at(0).trigger('click');
|
|
expect(wrapper.vm.active).toEqual([1]);
|
|
|
|
wrapper.destroy();
|
|
});
|
|
|
|
test('accordion', async () => {
|
|
const wrapper = mount(component, {
|
|
propsData: {
|
|
accordion: true,
|
|
},
|
|
});
|
|
|
|
const titles = wrapper.findAll('.van-collapse-item__title');
|
|
titles.at(0).trigger('click');
|
|
expect(wrapper.vm.active).toEqual('first');
|
|
|
|
titles.at(1).trigger('click');
|
|
expect(wrapper.vm.active).toEqual(1);
|
|
|
|
await later();
|
|
titles.at(0).trigger('click');
|
|
expect(wrapper.vm.active).toEqual('first');
|
|
|
|
titles.at(0).trigger('click');
|
|
expect(wrapper.vm.active).toEqual('');
|
|
});
|
|
|
|
test('render collapse-item slot', () => {
|
|
const wrapper = mount({
|
|
template: `
|
|
<van-collapse v-model="active">
|
|
<van-collapse-item>
|
|
<template v-slot:title>this is title</template>
|
|
<template v-slot:value>this is value</template>
|
|
<template v-slot:icon>this is icon</template>
|
|
<template v-slot:right-icon>this is right icon</template>
|
|
</van-collapse-item>
|
|
</van-collapse>
|
|
`,
|
|
data() {
|
|
return {
|
|
active: [],
|
|
};
|
|
},
|
|
});
|
|
|
|
expect(wrapper.html()).toMatchSnapshot();
|
|
});
|
|
|
|
test('disable border', () => {
|
|
const wrapper = mount(component, {
|
|
propsData: {
|
|
border: false,
|
|
},
|
|
});
|
|
|
|
expect(wrapper.html()).toMatchSnapshot();
|
|
});
|
|
|
|
test('lazy render collapse content', async () => {
|
|
const wrapper = mount({
|
|
template: `
|
|
<collapse v-model="active">
|
|
<collapse-item title="a" name="first" style="padding: 0;">content</collapse-item>
|
|
<collapse-item title="b" style="padding: 0;">{{ content }}</collapse-item>
|
|
</collapse>
|
|
`,
|
|
components: {
|
|
Collapse,
|
|
CollapseItem,
|
|
},
|
|
data() {
|
|
return {
|
|
content: '',
|
|
active: [],
|
|
};
|
|
},
|
|
});
|
|
|
|
const titles = wrapper.findAll('.van-collapse-item__title');
|
|
|
|
titles.at(1).trigger('click');
|
|
wrapper.vm.content = 'content';
|
|
expect(wrapper.html()).toMatchSnapshot();
|
|
});
|
|
|
|
test('toggle method', (done) => {
|
|
mount({
|
|
template: `
|
|
<van-collapse v-model="active" >
|
|
<van-collapse-item name="a" ref="a" />
|
|
<van-collapse-item name="b" ref="b" />
|
|
</van-collapse>
|
|
`,
|
|
data() {
|
|
return { active: [] };
|
|
},
|
|
mounted() {
|
|
this.$refs.a.toggle();
|
|
expect(this.active).toEqual(['a']);
|
|
|
|
this.$refs.b.toggle();
|
|
expect(this.active).toEqual(['a', 'b']);
|
|
|
|
this.$refs.b.toggle(false);
|
|
expect(this.active).toEqual(['a']);
|
|
|
|
this.$refs.a.toggle();
|
|
expect(this.active).toEqual([]);
|
|
|
|
done();
|
|
},
|
|
});
|
|
});
|
|
|
|
test('toggle method in accordion mode', (done) => {
|
|
mount({
|
|
template: `
|
|
<van-collapse v-model="active" accordion>
|
|
<van-collapse-item name="a" ref="a" />
|
|
<van-collapse-item name="b" ref="b" />
|
|
</van-collapse>
|
|
`,
|
|
data() {
|
|
return { active: '' };
|
|
},
|
|
mounted() {
|
|
this.$refs.a.toggle();
|
|
expect(this.active).toEqual('a');
|
|
|
|
this.$refs.b.toggle();
|
|
expect(this.active).toEqual('b');
|
|
|
|
this.$refs.b.toggle(false);
|
|
expect(this.active).toEqual('');
|
|
|
|
this.$refs.a.toggle();
|
|
expect(this.active).toEqual('a');
|
|
|
|
done();
|
|
},
|
|
});
|
|
});
|