123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460 |
- import { createVue, destroyVM } from '../util';
- describe('Tabs', () => {
- let vm;
- afterEach(() => {
- destroyVM(vm);
- });
- it('create', done => {
- vm = createVue({
- template: `
- <el-tabs ref="tabs">
- <el-tab-pane label="用户管理">A</el-tab-pane>
- <el-tab-pane label="配置管理">B</el-tab-pane>
- <el-tab-pane label="角色管理" ref="pane-click">C</el-tab-pane>
- <el-tab-pane label="定时任务补偿">D</el-tab-pane>
- </el-tabs>
- `
- }, true);
- let paneList = vm.$el.querySelector('.el-tabs__content').children;
- let spy = sinon.spy();
- vm.$refs.tabs.$on('tab-click', spy);
- setTimeout(_ => {
- const tabList = vm.$refs.tabs.$refs.nav.$refs.tabs;
- expect(tabList[0].classList.contains('is-active')).to.be.true;
- expect(paneList[0].style.display).to.not.ok;
- tabList[2].click();
- vm.$nextTick(_ => {
- expect(spy.withArgs(vm.$refs['pane-click']).calledOnce).to.true;
- expect(tabList[2].classList.contains('is-active')).to.be.true;
- expect(paneList[2].style.display).to.not.ok;
- done();
- });
- }, 100);
- });
- it('active-name', done => {
- vm = createVue({
- template: `
- <el-tabs ref="tabs" :active-name="activeName" @click="handleClick">
- <el-tab-pane name="tab-A" label="用户管理">A</el-tab-pane>
- <el-tab-pane name="tab-B" label="配置管理">B</el-tab-pane>
- <el-tab-pane name="tab-C" label="角色管理">C</el-tab-pane>
- <el-tab-pane name="tab-D" label="定时任务补偿">D</el-tab-pane>
- </el-tabs>
- `,
- data() {
- return {
- activeName: 'tab-B'
- };
- },
- methods: {
- handleClick(tab) {
- this.activeName = tab.name;
- }
- }
- }, true);
- setTimeout(_ => {
- const paneList = vm.$el.querySelector('.el-tabs__content').children;
- const tabList = vm.$refs.tabs.$refs.nav.$refs.tabs;
- expect(tabList[1].classList.contains('is-active')).to.be.true;
- expect(paneList[1].style.display).to.not.ok;
- tabList[3].click();
- vm.$nextTick(_ => {
- expect(tabList[3].classList.contains('is-active')).to.be.true;
- expect(paneList[3].style.display).to.not.ok;
- expect(vm.activeName === 'tab-D');
- done();
- });
- }, 100);
- });
- it('card', () => {
- vm = createVue({
- template: `
- <el-tabs type="card">
- <el-tab-pane label="用户管理">A</el-tab-pane>
- <el-tab-pane label="配置管理">B</el-tab-pane>
- <el-tab-pane label="角色管理">C</el-tab-pane>
- <el-tab-pane label="定时任务补偿">D</el-tab-pane>
- </el-tabs>
- `
- }, true);
- expect(vm.$el.classList.contains('el-tabs--card')).to.be.true;
- });
- it('border card', () => {
- vm = createVue({
- template: `
- <el-tabs type="border-card">
- <el-tab-pane label="用户管理">A</el-tab-pane>
- <el-tab-pane label="配置管理">B</el-tab-pane>
- <el-tab-pane label="角色管理">C</el-tab-pane>
- <el-tab-pane label="定时任务补偿">D</el-tab-pane>
- </el-tabs>
- `
- }, true);
- expect(vm.$el.classList.contains('el-tabs--border-card')).to.be.true;
- });
- it('dynamic', (done) => {
- vm = createVue({
- template: `
- <el-tabs type="card" ref="tabs">
- <el-tab-pane :label="tab.label" :name="tab.name" v-for="tab in tabs" :key="tab.name">Test Content</el-tab-pane>
- </el-tabs>
- `,
- data() {
- return {
- tabs: [{
- label: 'tab1',
- name: 'tab1'
- }, {
- label: 'tab2',
- name: 'tab2'
- }, {
- label: 'tab3',
- name: 'tab3'
- }, {
- label: 'tab4',
- name: 'tab4'
- }]
- };
- }
- }, true);
- setTimeout(() => {
- expect(vm.$el.querySelectorAll('.el-tab-pane').length).to.equal(4);
- vm.tabs.push({
- label: 'tab5',
- name: 'tab5'
- });
- setTimeout(() => {
- expect(vm.$el.querySelectorAll('.el-tab-pane').length).to.equal(5);
- done();
- });
- }, 100);
- });
- it('editable', done => {
- vm = createVue({
- template: `
- <el-tabs ref="tabs" v-model="editableTabsValue" type="card" editable @edit="handleTabsEdit">
- <el-tab-pane
- v-for="(item, index) in editableTabs"
- :key="item.name"
- :label="item.title"
- :name="item.name"
- >
- {{item.content}}
- </el-tab-pane>
- </el-tabs>
- `,
- data() {
- return {
- editableTabsValue: '2',
- editableTabs: [{
- title: 'Tab 1',
- name: '1',
- content: 'Tab 1 content'
- }, {
- title: 'Tab 2',
- name: '2',
- content: 'Tab 2 content'
- }, {
- title: 'Tab 3',
- name: '3',
- content: 'Tab 3 content'
- }],
- tabIndex: 3
- };
- },
- methods: {
- handleTabsEdit(targetName, action) {
- if (action === 'add') {
- let newTabName = ++this.tabIndex + '';
- this.editableTabs.push({
- title: 'New Tab',
- name: newTabName,
- content: 'New Tab content'
- });
- this.editableTabsValue = newTabName;
- }
- if (action === 'remove') {
- let tabs = this.editableTabs;
- let activeName = this.editableTabsValue;
- if (activeName === targetName) {
- tabs.forEach((tab, index) => {
- if (tab.name === targetName) {
- let nextTab = tabs[index + 1] || tabs[index - 1];
- if (nextTab) {
- activeName = nextTab.name;
- }
- }
- });
- }
- this.editableTabsValue = activeName;
- this.editableTabs = tabs.filter(tab => tab.name !== targetName);
- }
- }
- }
- }, true);
- setTimeout(_ => {
- const tabList = vm.$refs.tabs.$refs.nav.$refs.tabs;
- const paneList = vm.$el.querySelector('.el-tabs__content').children;
- tabList[1].querySelector('.el-icon-close').click();
- vm.$nextTick(_ => {
- expect(tabList.length).to.be.equal(2);
- expect(paneList.length).to.be.equal(2);
- expect(tabList[1].classList.contains('is-active')).to.be.true;
- vm.$refs.tabs.$el.querySelector('.el-tabs__new-tab').click();
- vm.$nextTick(_ => {
- expect(tabList.length).to.be.equal(3);
- expect(paneList.length).to.be.equal(3);
- expect(tabList[2].classList.contains('is-active')).to.be.true;
- done();
- });
- });
- }, 100);
- });
- it('addable & closable', done => {
- vm = createVue({
- template: `
- <el-tabs
- ref="tabs"
- v-model="editableTabsValue"
- type="card"
- addable
- closable
- @tab-add="addTab"
- @tab-remove="removeTab"
- >
- <el-tab-pane
- v-for="(item, index) in editableTabs"
- :label="item.title"
- :key="item.name"
- :name="item.name"
- >
- {{item.content}}
- </el-tab-pane>
- </el-tabs>
- `,
- data() {
- return {
- editableTabsValue: '2',
- editableTabs: [{
- title: 'Tab 1',
- name: '1',
- content: 'Tab 1 content'
- }, {
- title: 'Tab 2',
- name: '2',
- content: 'Tab 2 content'
- }],
- tabIndex: 2
- };
- },
- methods: {
- addTab(targetName) {
- let newTabName = ++this.tabIndex + '';
- this.editableTabs.push({
- title: 'New Tab',
- name: newTabName,
- content: 'New Tab content'
- });
- this.editableTabsValue = newTabName;
- },
- removeTab(targetName) {
- let tabs = this.editableTabs;
- let activeName = this.editableTabsValue;
- if (activeName === targetName) {
- tabs.forEach((tab, index) => {
- if (tab.name === targetName) {
- let nextTab = tabs[index + 1] || tabs[index - 1];
- if (nextTab) {
- activeName = nextTab.name;
- }
- }
- });
- }
- this.editableTabsValue = activeName;
- this.editableTabs = tabs.filter(tab => tab.name !== targetName);
- }
- }
- }, true);
- setTimeout(_ => {
- const tabList = vm.$refs.tabs.$refs.nav.$refs.tabs;
- const paneList = vm.$el.querySelector('.el-tabs__content').children;
- vm.$refs.tabs.$el.querySelector('.el-tabs__new-tab').click();
- vm.$nextTick(_ => {
- expect(tabList.length).to.be.equal(3);
- expect(paneList.length).to.be.equal(3);
- expect(tabList[2].classList.contains('is-active')).to.be.true;
- tabList[2].querySelector('.el-icon-close').click();
- vm.$nextTick(_ => {
- expect(tabList.length).to.be.equal(2);
- expect(paneList.length).to.be.equal(2);
- expect(tabList[1].classList.contains('is-active')).to.be.true;
- done();
- });
- });
- }, 100);
- });
- it('closable in tab-pane', (done) => {
- vm = createVue({
- template: `
- <el-tabs type="card" ref="tabs">
- <el-tab-pane label="用户管理" closable>A</el-tab-pane>
- <el-tab-pane label="配置管理">B</el-tab-pane>
- <el-tab-pane label="角色管理" closable>C</el-tab-pane>
- <el-tab-pane label="定时任务补偿">D</el-tab-pane>
- </el-tabs>
- `
- }, true);
- setTimeout(() => {
- expect(vm.$el.querySelectorAll('.el-icon-close').length).to.equal(2);
- done();
- }, 100);
- });
- it('disabled', done => {
- vm = createVue({
- template: `
- <el-tabs type="card" ref="tabs">
- <el-tab-pane label="用户管理">A</el-tab-pane>
- <el-tab-pane disabled label="配置管理" ref="disabled">B</el-tab-pane>
- <el-tab-pane label="角色管理">C</el-tab-pane>
- <el-tab-pane label="定时任务补偿">D</el-tab-pane>
- </el-tabs>
- `
- }, true);
- vm.$nextTick(_ => {
- const tabList = vm.$refs.tabs.$refs.nav.$refs.tabs;
- tabList[1].click();
- vm.$nextTick(_ => {
- expect(tabList[1].classList.contains('is-active')).to.not.true;
- done();
- });
- });
- });
- it('tab-position', done => {
- vm = createVue({
- template: `
- <el-tabs ref="tabs" tab-position="left">
- <el-tab-pane label="用户管理">A</el-tab-pane>
- <el-tab-pane label="配置管理">B</el-tab-pane>
- <el-tab-pane label="角色管理" ref="pane-click">C</el-tab-pane>
- <el-tab-pane label="定时任务补偿">D</el-tab-pane>
- </el-tabs>
- `
- }, true);
- let paneList = vm.$el.querySelector('.el-tabs__content').children;
- let spy = sinon.spy();
- vm.$refs.tabs.$on('tab-click', spy);
- setTimeout(_ => {
- const tabList = vm.$refs.tabs.$refs.nav.$refs.tabs;
- expect(tabList[0].classList.contains('is-active')).to.be.true;
- expect(paneList[0].style.display).to.not.ok;
- tabList[2].click();
- vm.$nextTick(_ => {
- expect(spy.withArgs(vm.$refs['pane-click']).calledOnce).to.true;
- expect(tabList[2].classList.contains('is-active')).to.be.true;
- expect(paneList[2].style.display).to.not.ok;
- done();
- });
- }, 100);
- });
- it('horizonal-scrollable', done => {
- vm = createVue({
- template: `
- <el-tabs ref="tabs" style="width: 200px;">
- <el-tab-pane label="用户管理">A</el-tab-pane>
- <el-tab-pane label="配置管理">B</el-tab-pane>
- <el-tab-pane label="用户管理">A</el-tab-pane>
- <el-tab-pane label="配置管理">B</el-tab-pane>
- <el-tab-pane label="用户管理">A</el-tab-pane>
- <el-tab-pane label="配置管理">B</el-tab-pane>
- <el-tab-pane label="定时任务补偿">D</el-tab-pane>
- </el-tabs>
- `
- }, true);
- setTimeout(_ => {
- const btnPrev = vm.$el.querySelector('.el-tabs__nav-prev');
- btnPrev.click();
- vm.$nextTick(_ => {
- const tabNav = vm.$el.querySelector('.el-tabs__nav-wrap');
- expect(tabNav.__vue__.navOffset).to.be.equal(0);
- const btnNext = vm.$el.querySelector('.el-tabs__nav-next');
- btnNext.click();
- vm.$nextTick(_ => {
- expect(tabNav.__vue__.navOffset).to.not.be.equal(0);
- btnPrev.click();
- vm.$nextTick(_ => {
- expect(tabNav.__vue__.navOffset).to.be.equal(0);
- done();
- });
- });
- });
- }, 100);
- });
- it('vertical-scrollable', done => {
- vm = createVue({
- template: `
- <el-tabs ref="tabs" tab-position="left" style="height: 200px;">
- <el-tab-pane label="用户管理">A</el-tab-pane>
- <el-tab-pane label="配置管理">B</el-tab-pane>
- <el-tab-pane label="用户管理">A</el-tab-pane>
- <el-tab-pane label="配置管理">B</el-tab-pane>
- <el-tab-pane label="用户管理">A</el-tab-pane>
- <el-tab-pane label="配置管理">B</el-tab-pane>
- <el-tab-pane label="定时任务补偿">D</el-tab-pane>
- </el-tabs>
- `
- }, true);
- setTimeout(_ => {
- const btnPrev = vm.$el.querySelector('.el-tabs__nav-prev');
- btnPrev.click();
- vm.$nextTick(_ => {
- const tabNav = vm.$el.querySelector('.el-tabs__nav-wrap');
- expect(tabNav.__vue__.navOffset).to.be.equal(0);
- const btnNext = vm.$el.querySelector('.el-tabs__nav-next');
- btnNext.click();
- vm.$nextTick(_ => {
- expect(tabNav.__vue__.navOffset).to.not.be.equal(0);
- btnPrev.click();
- vm.$nextTick(_ => {
- expect(tabNav.__vue__.navOffset).to.be.equal(0);
- done();
- });
- });
- });
- }, 100);
- });
- });
|