table.spec.js 29 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890891892893894895896897898899900901902903904905906907908909910911912913914915916917918919920921922923924925926927928929930931932933934935936937938939940941942943944945946947948949950951952953954955956957958959960961962963964965966967968969970971972973974975976977978979980981982983984985
  1. import { createVue, triggerEvent, destroyVM } from '../util';
  2. const DELAY = 10;
  3. const testDataArr = [];
  4. const toArray = function(obj) {
  5. return [].slice.call(obj);
  6. };
  7. const getTestData = function() {
  8. return [
  9. { name: 'Toy Story', release: '1995-11-22', director: 'John Lasseter', runtime: 80 },
  10. { name: 'A Bug\'s Life', release: '1998-11-25', director: 'John Lasseter', runtime: 95 },
  11. { name: 'Toy Story 2', release: '1999-11-24', director: 'John Lasseter', runtime: 92 },
  12. { name: 'Monsters, Inc.', release: '2001-11-2', director: 'Peter Docter', runtime: 92 },
  13. { name: 'Finding Nemo', release: '2003-5-30', director: 'Andrew Stanton', runtime: 100 }
  14. ];
  15. };
  16. getTestData().forEach(cur => {
  17. Object.keys(cur).forEach(prop => {
  18. testDataArr.push(cur[prop].toString());
  19. });
  20. });
  21. describe('Table', () => {
  22. describe('rendering data is correct', () => {
  23. const vm = createVue({
  24. template: `
  25. <el-table :data="testData">
  26. <el-table-column prop="name" label="片名" />
  27. <el-table-column prop="release" label="发行日期" />
  28. <el-table-column prop="director" label="导演" />
  29. <el-table-column prop="runtime" label="时长(分)" />
  30. </el-table>
  31. `,
  32. created() {
  33. this.testData = getTestData();
  34. }
  35. });
  36. it('head', done => {
  37. setTimeout(_ => {
  38. const ths = toArray(vm.$el.querySelectorAll('thead th'));
  39. expect(ths.map(node => node.textContent).filter(o => o))
  40. .to.eql(['片名', '发行日期', '导演', '时长(分)']);
  41. done();
  42. }, DELAY);
  43. });
  44. it('row length', () => {
  45. expect(vm.$el.querySelectorAll('.el-table__body-wrapper tbody tr')).to.length(getTestData().length);
  46. });
  47. it('row data', () => {
  48. const cells = toArray(vm.$el.querySelectorAll('td .cell'))
  49. .map(node => node.textContent);
  50. expect(cells).to.eql(testDataArr);
  51. destroyVM(vm);
  52. });
  53. });
  54. describe('attributes', () => {
  55. const createTable = function(props, opts) {
  56. return createVue(Object.assign({
  57. template: `
  58. <el-table :data="testData" ${props}>
  59. <el-table-column prop="name" label="片名" />
  60. <el-table-column prop="release" label="发行日期" />
  61. <el-table-column prop="director" label="导演" />
  62. <el-table-column prop="runtime" label="时长(分)" />
  63. </el-table>
  64. `,
  65. created() {
  66. this.testData = getTestData();
  67. }
  68. }, opts));
  69. };
  70. it('height', done => {
  71. const vm = createTable('height="134"');
  72. setTimeout(_ => {
  73. expect(vm.$el.style.height).to.equal('134px');
  74. destroyVM(vm);
  75. done();
  76. }, DELAY);
  77. });
  78. it('stripe', done => {
  79. const vm = createTable('stripe');
  80. setTimeout(_ => {
  81. expect(vm.$el.classList.contains('el-table--striped')).to.true;
  82. destroyVM(vm);
  83. done();
  84. }, DELAY);
  85. });
  86. it('border', done => {
  87. const vm = createTable('border');
  88. setTimeout(_ => {
  89. expect(vm.$el.classList.contains('el-table--border')).to.true;
  90. destroyVM(vm);
  91. done();
  92. }, DELAY);
  93. });
  94. it('fit', done => {
  95. const vm = createTable(':fit="false"');
  96. setTimeout(_ => {
  97. expect(vm.$el.classList.contains('el-table--fit')).to.false;
  98. destroyVM(vm);
  99. done();
  100. }, DELAY);
  101. });
  102. it('tableRowClassName', done => {
  103. const vm = createTable(':row-class-name="tableRowClassName"', {
  104. methods: {
  105. tableRowClassName(row, index) {
  106. if (index === 1) {
  107. return 'info-row';
  108. } else if (index === 3) {
  109. return 'positive-row';
  110. }
  111. return '';
  112. }
  113. }
  114. });
  115. setTimeout(_ => {
  116. expect(vm.$el.querySelectorAll('.info-row')).to.length(1);
  117. expect(vm.$el.querySelectorAll('.positive-row')).to.length(1);
  118. destroyVM(vm);
  119. done();
  120. }, DELAY);
  121. });
  122. });
  123. describe('filter', () => {
  124. let vm;
  125. beforeEach(done => {
  126. vm = createVue({
  127. template: `
  128. <el-table ref="table" :data="testData">
  129. <el-table-column prop="name" label="片名" />
  130. <el-table-column prop="release" label="发行日期" />
  131. <el-table-column
  132. prop="director"
  133. :filters="[
  134. { text: 'John Lasseter', value: 'John Lasseter' },
  135. { text: 'Peter Docter', value: 'Peter Docter' },
  136. { text: 'Andrew Stanton', value: 'Andrew Stanton' }
  137. ]"
  138. :filter-method="filterMethod"
  139. label="导演" />
  140. <el-table-column prop="runtime" label="时长(分)" />
  141. </el-table>
  142. `,
  143. created() {
  144. this.testData = getTestData();
  145. },
  146. methods: {
  147. filterMethod(value, row) {
  148. return value === row.director;
  149. }
  150. }
  151. }, true);
  152. setTimeout(done, DELAY);
  153. });
  154. afterEach(() => destroyVM(vm));
  155. it('render', () => {
  156. expect(vm.$el.querySelector('.el-table__column-filter-trigger')).to.exist;
  157. });
  158. it('click dropdown', done => {
  159. const btn = vm.$el.querySelector('.el-table__column-filter-trigger');
  160. triggerEvent(btn, 'click', true, false);
  161. setTimeout(_ => {
  162. const filter = document.body.querySelector('.el-table-filter');
  163. expect(filter).to.exist;
  164. document.body.removeChild(filter);
  165. done();
  166. }, 100);
  167. });
  168. it('click filter', done => {
  169. const btn = vm.$el.querySelector('.el-table__column-filter-trigger');
  170. triggerEvent(btn, 'click', true, false);
  171. setTimeout(_ => {
  172. const filter = document.body.querySelector('.el-table-filter');
  173. // John Lasseter
  174. triggerEvent(filter.querySelector('.el-checkbox'), 'click', true, false);
  175. // confrim button
  176. setTimeout(_ => {
  177. triggerEvent(filter.querySelector('.el-table-filter__bottom button'), 'click', true, false);
  178. setTimeout(_ => {
  179. expect(vm.$el.querySelectorAll('.el-table__body-wrapper tbody tr')).to.length(3);
  180. document.body.removeChild(filter);
  181. done();
  182. }, DELAY);
  183. }, 100);
  184. }, 100);
  185. });
  186. it('click reset', done => {
  187. const btn = vm.$el.querySelector('.el-table__column-filter-trigger');
  188. triggerEvent(btn, 'click', true, false);
  189. setTimeout(_ => {
  190. const filter = document.body.querySelector('.el-table-filter');
  191. // John Lasseter
  192. triggerEvent(filter.querySelector('.el-checkbox'), 'click', true, false);
  193. setTimeout(_ => {
  194. // reset button
  195. triggerEvent(filter.querySelectorAll('.el-table-filter__bottom button')[1], 'click', true, false);
  196. setTimeout(_ => {
  197. expect(filter.querySelector('.el-table-filter__bottom button').classList.contains('is-disabled')).to.true;
  198. document.body.removeChild(filter);
  199. destroyVM(vm);
  200. done();
  201. }, DELAY);
  202. }, 100);
  203. }, 100);
  204. });
  205. });
  206. describe('events', () => {
  207. const createTable = function(prop = '', opts) {
  208. return createVue({
  209. template: `
  210. <el-table :data="testData" @${prop}="handleEvent">
  211. <el-table-column type="selection" />
  212. <el-table-column prop="name" />
  213. <el-table-column prop="release" />
  214. <el-table-column prop="director" />
  215. <el-table-column prop="runtime"/>
  216. </el-table>
  217. `,
  218. methods: {
  219. handleEvent(...args) {
  220. this.result = args;
  221. }
  222. },
  223. created() {
  224. this.testData = getTestData();
  225. },
  226. data() {
  227. return { result: '', testData: this.testData };
  228. }
  229. }, true);
  230. };
  231. it('select', done => {
  232. const vm = createTable('select');
  233. setTimeout(_ => {
  234. vm.$el.querySelectorAll('.el-checkbox')[1].click();
  235. expect(vm.result).to.length(2);
  236. expect(vm.result[1]).to.have.property('name').to.equal(getTestData()[0].name);
  237. destroyVM(vm);
  238. done();
  239. }, DELAY);
  240. });
  241. it('select-all', done => {
  242. const vm = createTable('select-all');
  243. setTimeout(_ => {
  244. vm.$el.querySelector('.el-checkbox').click();
  245. setTimeout(_ => {
  246. expect(vm.result).to.length(1);
  247. expect(vm.result[0]).to.length(getTestData().length);
  248. destroyVM(vm);
  249. done();
  250. }, DELAY);
  251. }, DELAY);
  252. });
  253. it('selection-change', done => {
  254. const vm = createTable('selection-change');
  255. setTimeout(_ => {
  256. vm.$el.querySelectorAll('.el-checkbox')[1].click();
  257. expect(vm.result).to.length(1);
  258. destroyVM(vm);
  259. done();
  260. }, DELAY);
  261. });
  262. it('cell-mouse-enter', done => {
  263. const vm = createTable('cell-mouse-enter');
  264. setTimeout(_ => {
  265. const cell = vm.$el.querySelectorAll('.el-table__body .cell')[2]; // first row
  266. triggerEvent(cell.parentNode, 'mouseenter');
  267. expect(vm.result).to.length(4); // row, column, cell, event
  268. expect(vm.result[0]).to.have.property('name').to.equal(getTestData()[0].name);
  269. destroyVM(vm);
  270. done();
  271. }, DELAY);
  272. });
  273. it('cell-mouse-leave', done => {
  274. const vm = createTable('cell-mouse-leave');
  275. setTimeout(_ => {
  276. const cell = vm.$el.querySelectorAll('.el-table__body .cell')[7]; // second row
  277. const cell2 = vm.$el.querySelectorAll('.el-table__body .cell')[2]; // first row
  278. triggerEvent(cell2.parentNode, 'mouseenter');
  279. triggerEvent(cell.parentNode, 'mouseleave');
  280. expect(vm.result).to.length(4); // row, column, cell, event
  281. expect(vm.result[0]).to.have.property('name').to.equal(getTestData()[0].name);
  282. destroyVM(vm);
  283. done();
  284. }, DELAY);
  285. });
  286. it('cell-click', done => {
  287. const vm = createTable('cell-click');
  288. setTimeout(_ => {
  289. const cell = vm.$el.querySelectorAll('.el-table__body .cell')[2]; // first row
  290. cell.parentNode.click();
  291. expect(vm.result).to.length(4); // row, column, cell, event
  292. expect(vm.result[0]).to.have.property('name').to.equal(getTestData()[0].name);
  293. destroyVM(vm);
  294. done();
  295. }, DELAY);
  296. });
  297. it('row-click', done => {
  298. const vm = createTable('row-click');
  299. setTimeout(_ => {
  300. const cell = vm.$el.querySelectorAll('.el-table__body .cell')[2]; // first row
  301. triggerEvent(cell.parentNode.parentNode, 'click');
  302. expect(vm.result).to.length(2); // row, event
  303. expect(vm.result[0]).to.have.property('name').to.equal(getTestData()[0].name);
  304. destroyVM(vm);
  305. done();
  306. }, DELAY);
  307. });
  308. it('current-change', done => {
  309. const vm = createTable('current-change');
  310. setTimeout(_ => {
  311. const cell = vm.$el.querySelectorAll('.el-table__body .cell')[2]; // first row
  312. triggerEvent(cell.parentNode.parentNode, 'click');
  313. expect(vm.result).to.length(2); // currentRow, oldCurrentRow
  314. expect(vm.result[0]).to.have.property('name').to.equal(getTestData()[0].name);
  315. expect(vm.result[1]).to.equal(null);
  316. // clear data => current-change should fire again.
  317. const oldRow = vm.result[0];
  318. vm.testData = [];
  319. setTimeout(() => {
  320. expect(vm.result).to.length(2); // currentRow, oldCurrentRow
  321. expect(vm.result[0]).to.equal(null);
  322. expect(vm.result[1]).to.equal(oldRow);
  323. destroyVM(vm);
  324. done();
  325. }, DELAY);
  326. }, DELAY);
  327. });
  328. });
  329. describe('column attributes', () => {
  330. const createTable = function(props1, props2, props3, props4, opts, tableProps) {
  331. return createVue(Object.assign({
  332. template: `
  333. <el-table :data="testData" ${tableProps || ''}>
  334. <el-table-column prop="name" ${props1 || ''} />
  335. <el-table-column prop="release" ${props2 || ''} />
  336. <el-table-column prop="director" ${props3 || ''} />
  337. <el-table-column prop="runtime" ${props4 || ''} />
  338. </el-table>
  339. `,
  340. created() {
  341. this.testData = getTestData();
  342. }
  343. }, opts));
  344. };
  345. it('label', done => {
  346. const vm = createTable('label="啊哈哈哈"', 'label="啊啦啦啦"');
  347. setTimeout(_ => {
  348. const ths = toArray(vm.$el.querySelectorAll('thead th'))
  349. .map(node => node.textContent).filter(o => o);
  350. expect(ths).to.eql(['啊哈哈哈', '啊啦啦啦']);
  351. destroyVM(vm);
  352. done();
  353. }, DELAY);
  354. });
  355. it('width', done => {
  356. const vm = createTable('width="123px"', ':width="102"', 'width="39"');
  357. setTimeout(_ => {
  358. const ths = toArray(vm.$el.querySelectorAll('.el-table__header-wrapper col'))
  359. .map(node => node.width).filter(o => o);
  360. expect(ths).to.include('123').include('102').include('39');
  361. destroyVM(vm);
  362. done();
  363. }, DELAY);
  364. });
  365. it('fixed', done => {
  366. const vm = createTable(
  367. 'fixed label="test1"',
  368. 'fixed="right" label="test2"',
  369. 'fixed="left" label="test3"');
  370. setTimeout(_ => {
  371. expect(toArray(vm.$el.querySelectorAll('.el-table__fixed th:not(.is-hidden)'))
  372. .map(node => node.textContent))
  373. .to.eql(['test1', 'test3']);
  374. expect(toArray(vm.$el.querySelectorAll('.el-table__fixed-right th:not(.is-hidden)'))
  375. .map(node => node.textContent))
  376. .to.eql(['test2']);
  377. expect(vm.$el.querySelector('.el-table__body-wrapper').style.height).to.equal('');
  378. destroyVM(vm);
  379. done();
  380. }, DELAY);
  381. });
  382. it('resizable', done => {
  383. const vm = createTable(
  384. 'resizable',
  385. ':resizable="false"',
  386. '',
  387. '',
  388. {},
  389. 'border');
  390. setTimeout(_ => {
  391. const firstCol = vm.$el.querySelector('thead th');
  392. triggerEvent(firstCol, 'mousemove');
  393. triggerEvent(firstCol, 'mousedown');
  394. destroyVM(vm);
  395. done();
  396. }, DELAY);
  397. });
  398. it('formatter', done => {
  399. const vm = createTable(
  400. ':formatter="renderCell"', '', '', '', {
  401. methods: {
  402. renderCell(row, column) {
  403. return `[${row.name}]`;
  404. }
  405. }
  406. });
  407. setTimeout(_ => {
  408. const cells = toArray(vm.$el.querySelectorAll('.el-table__body-wrapper tbody tr td:first-child'));
  409. expect(cells.map(n => n.textContent)).to.eql(getTestData().map(o => `[${o.name}]`));
  410. destroyVM(vm);
  411. done();
  412. }, DELAY);
  413. });
  414. it('show-overflow-tooltip', done => {
  415. const vm = createTable('show-overflow-tooltip');
  416. setTimeout(_ => {
  417. expect(vm.$el.querySelectorAll('.el-tooltip')).to.length(5);
  418. destroyVM(vm);
  419. done();
  420. }, DELAY);
  421. });
  422. it('show-tooltip-when-overflow', done => { // old version prop name
  423. const vm = createTable('show-tooltip-when-overflow');
  424. setTimeout(_ => {
  425. expect(vm.$el.querySelectorAll('.el-tooltip')).to.length(5);
  426. destroyVM(vm);
  427. done();
  428. }, DELAY);
  429. });
  430. it('inline-template', done => {
  431. const vm = createVue({
  432. template: `
  433. <el-table :data="testData">
  434. <el-table-column prop="name" inline-template>
  435. <span>[{{ row.name }}]</span>
  436. </el-table-column>
  437. <el-table-column prop="release"/>
  438. <el-table-column prop="director"/>
  439. <el-table-column prop="runtime"/>
  440. </el-table>
  441. `,
  442. created() {
  443. this.testData = getTestData();
  444. }
  445. });
  446. setTimeout(_ => {
  447. const cells = toArray(vm.$el.querySelectorAll('.el-table__body-wrapper tbody tr td:first-child'));
  448. expect(cells.map(n => n.textContent)).to.eql(getTestData().map(o => `[${o.name}]`));
  449. destroyVM(vm);
  450. done();
  451. }, DELAY);
  452. });
  453. it('render-header', done => {
  454. const vm = createVue({
  455. template: `
  456. <el-table :data="testData">
  457. <el-table-column prop="name" :render-header="renderHeader" label="name">
  458. </el-table-column>
  459. <el-table-column prop="release"/>
  460. <el-table-column prop="director"/>
  461. <el-table-column prop="runtime"/>
  462. </el-table>
  463. `,
  464. methods: {
  465. renderHeader(h, { column, $index }) {
  466. return '' + $index + ':' + column.label;
  467. }
  468. },
  469. created() {
  470. this.testData = getTestData();
  471. }
  472. });
  473. setTimeout(_ => {
  474. const headerCell = vm.$el.querySelector('.el-table__header-wrapper thead tr th:first-child .cell');
  475. expect(headerCell.textContent).to.equal('0:name');
  476. destroyVM(vm);
  477. done();
  478. }, DELAY);
  479. });
  480. it('align', done => {
  481. const vm = createTable('align="left"', 'align="right"', 'align="center"');
  482. setTimeout(_ => {
  483. var len = getTestData().length + 1;
  484. expect(vm.$el.querySelectorAll('.is-left')).to.length(len);
  485. expect(vm.$el.querySelectorAll('.is-right')).to.length(len);
  486. expect(vm.$el.querySelectorAll('.is-center')).to.length(len);
  487. destroyVM(vm);
  488. done();
  489. }, DELAY);
  490. });
  491. it('class-name', done => {
  492. const vm = createTable('class-name="column-1"', 'class-name="column-2 column-class-a"', 'class-name="column-class-a"');
  493. setTimeout(_ => {
  494. var len = getTestData().length + 1;
  495. expect(vm.$el.querySelectorAll('.column-1')).to.length(len);
  496. expect(vm.$el.querySelectorAll('.column-2')).to.length(len);
  497. expect(vm.$el.querySelectorAll('.column-class-a')).to.length(len * 2);
  498. destroyVM(vm);
  499. done();
  500. }, DELAY);
  501. });
  502. it('selectable', done => {
  503. const vm = createVue({
  504. template: `
  505. <el-table :data="testData" @selection-change="change">
  506. <el-table-column type="selection" :selectable="filterSelect" />
  507. <el-table-column prop="name" label="name" />
  508. <el-table-column prop="release" label="release" />
  509. <el-table-column prop="director" label="director" />
  510. <el-table-column prop="runtime" label="runtime" />
  511. </el-table>
  512. `,
  513. created() {
  514. this.testData = getTestData();
  515. },
  516. data() {
  517. return { selected: [] };
  518. },
  519. methods: {
  520. change(rows) {
  521. this.selected = rows;
  522. },
  523. filterSelect(row, index) {
  524. return index > 2;
  525. }
  526. }
  527. }, true);
  528. setTimeout(_ => {
  529. vm.$el.querySelector('.el-checkbox').click();
  530. setTimeout(_ => {
  531. expect(vm.selected).to.length(2);
  532. destroyVM(vm);
  533. done();
  534. }, DELAY);
  535. }, DELAY);
  536. });
  537. it('emit selection-change after row has been removed', done => {
  538. const vm = createVue({
  539. template: `
  540. <el-table :data="testData" @selection-change="change">
  541. <el-table-column type="selection" />
  542. <el-table-column prop="name" label="name" />
  543. <el-table-column prop="release" label="release" />
  544. <el-table-column prop="director" label="director" />
  545. <el-table-column prop="runtime" label="runtime" />
  546. </el-table>
  547. `,
  548. created() {
  549. this.testData = getTestData();
  550. },
  551. data() {
  552. return { selected: [], testData: null };
  553. },
  554. methods: {
  555. change(rows) {
  556. this.selected = rows;
  557. },
  558. filterSelect(row, index) {
  559. return index > 2;
  560. }
  561. }
  562. }, true);
  563. setTimeout(_ => {
  564. vm.$el.querySelector('.el-checkbox').click();
  565. setTimeout(_ => {
  566. expect(vm.selected).to.length(5);
  567. vm.testData.splice(0, 1);
  568. setTimeout(_ => {
  569. expect(vm.selected).to.length(4);
  570. destroyVM(vm);
  571. done();
  572. });
  573. }, DELAY);
  574. }, DELAY);
  575. });
  576. it('reserve-selection', done => {
  577. const getData = function(page = 0) {
  578. let id = 0;
  579. const rows = [];
  580. const row = () => {
  581. return {
  582. id: ++id + page * 10,
  583. date: new Date().getTime()
  584. };
  585. };
  586. let count = 10;
  587. while (--count) {
  588. rows.push(row());
  589. }
  590. return rows;
  591. };
  592. const vm = createVue({
  593. template: `
  594. <el-table ref="table" :row-key="rowKey" :data="testData" @selection-change="change">
  595. <el-table-column type="selection" reserve-selection />
  596. <el-table-column prop="id" label="id" />
  597. <el-table-column prop="date" label="date" />
  598. </el-table>
  599. `,
  600. created() {
  601. this.testData = getData();
  602. },
  603. data() {
  604. return { selected: [], testData: [] };
  605. },
  606. methods: {
  607. rowKey(row) {
  608. return row.id;
  609. },
  610. change(rows) {
  611. this.selected = rows;
  612. }
  613. }
  614. }, true);
  615. setTimeout(_ => {
  616. // click first
  617. vm.$el.querySelectorAll('.el-checkbox')[1].click();
  618. setTimeout(_ => {
  619. expect(vm.$el.querySelectorAll('.el-checkbox__inner.is-checked')).to.length(1);
  620. // go to second page
  621. vm.testData = getData(1);
  622. setTimeout(_ => {
  623. // expect no checked
  624. expect(vm.$el.querySelectorAll('.el-checkbox__inner.is-checked')).to.length(0);
  625. // click first checkbox
  626. vm.$el.querySelectorAll('.el-checkbox')[1].click();
  627. vm.$el.querySelectorAll('.el-checkbox')[2].click();
  628. setTimeout(_ => {
  629. // back first page
  630. vm.testData = getData();
  631. setTimeout(_ => {
  632. expect(vm.$el.querySelectorAll('.el-checkbox__inner.is-checked')).to.length(1);
  633. // clear
  634. vm.$refs.table.clearSelection();
  635. setTimeout(_ => {
  636. expect(vm.$el.querySelectorAll('.el-checkbox__inner.is-checked')).to.length(0);
  637. destroyVM(vm);
  638. done();
  639. }, DELAY);
  640. }, DELAY);
  641. }, DELAY);
  642. }, DELAY);
  643. }, DELAY);
  644. }, DELAY);
  645. });
  646. describe('type', () => {
  647. const createTable = function(type) {
  648. return createVue({
  649. template: `
  650. <el-table :data="testData" @selection-change="change">
  651. <el-table-column type="${type}" />
  652. <el-table-column prop="name" label="name" />
  653. <el-table-column prop="release" label="release" />
  654. <el-table-column prop="director" label="director" />
  655. <el-table-column prop="runtime" label="runtime" />
  656. </el-table>
  657. `,
  658. created() {
  659. this.testData = getTestData();
  660. },
  661. data() {
  662. return { selected: [] };
  663. },
  664. methods: {
  665. change(rows) {
  666. this.selected = rows;
  667. }
  668. }
  669. }, true);
  670. };
  671. describe('= selection', () => {
  672. const vm = createTable('selection');
  673. it('render', done => {
  674. setTimeout(_ => {
  675. expect(vm.$el.querySelectorAll('.el-checkbox')).to.length(getTestData().length + 1);
  676. done();
  677. }, DELAY);
  678. });
  679. it('select all', done => {
  680. vm.$el.querySelector('.el-checkbox').click();
  681. setTimeout(_ => {
  682. expect(vm.selected).to.length(getTestData().length);
  683. done();
  684. }, DELAY);
  685. });
  686. it('cancel all', done => {
  687. vm.$el.querySelector('.el-checkbox').click();
  688. setTimeout(_ => {
  689. expect(vm.selected).to.length(0);
  690. destroyVM(vm);
  691. done();
  692. }, DELAY);
  693. });
  694. it('select one', done => {
  695. const vm2 = createTable('selection');
  696. setTimeout(_ => {
  697. vm2.$el.querySelectorAll('.el-checkbox')[1].click();
  698. setTimeout(_ => {
  699. expect(vm2.selected).to.length(1);
  700. expect(vm2.selected[0].name).to.equal(getTestData()[0].name);
  701. destroyVM(vm2);
  702. done();
  703. }, DELAY);
  704. }, DELAY);
  705. });
  706. });
  707. describe('= index', () => {
  708. const vm = createTable('index');
  709. it('render', done => {
  710. setTimeout(_ => {
  711. expect(toArray(vm.$el.querySelectorAll('.el-table__body-wrapper tbody tr td:first-child'))
  712. .map(node => node.textContent)).to.eql(['1', '2', '3', '4', '5']);
  713. destroyVM(vm);
  714. done();
  715. }, DELAY);
  716. });
  717. });
  718. });
  719. describe('sortable', () => {
  720. it('render', done => {
  721. const vm = createTable('', '', '', 'sortable');
  722. setTimeout(_ => {
  723. expect(vm.$el.querySelectorAll('.caret-wrapper')).to.length(1);
  724. destroyVM(vm);
  725. done();
  726. }, DELAY);
  727. });
  728. it('sortable method', done => {
  729. const vm = createTable(
  730. 'sortable :sort-method="sortMethod"', '', '', '', {
  731. methods: {
  732. sortMethod(a, b) {
  733. return a.runtime < b.runtime;
  734. }
  735. }
  736. });
  737. setTimeout(_ => {
  738. const elm = vm.$el.querySelector('.caret-wrapper');
  739. elm.click();
  740. setTimeout(_ => {
  741. const lastCells = vm.$el.querySelectorAll('.el-table__body-wrapper tbody tr td:last-child');
  742. expect(toArray(lastCells).map(node => node.textContent)).to.eql(['100', '95', '92', '92', '80']);
  743. destroyVM(vm);
  744. done();
  745. }, DELAY);
  746. }, DELAY);
  747. });
  748. it('sort-change', done => {
  749. let result;
  750. const vm = createTable('sortable="custom"', '', '', '', {
  751. methods: {
  752. sortChange(...args) {
  753. result = args;
  754. }
  755. }
  756. }, '@sort-change="sortChange"');
  757. setTimeout(_ => {
  758. const elm = vm.$el.querySelector('.caret-wrapper');
  759. elm.click();
  760. setTimeout(_ => {
  761. expect(result).to.exist;
  762. destroyVM(vm);
  763. done();
  764. }, DELAY);
  765. }, DELAY);
  766. });
  767. });
  768. describe('click sortable column', () => {
  769. const vm = createTable('', '', '', 'sortable');
  770. it('ascending', done => {
  771. const elm = vm.$el.querySelector('.caret-wrapper');
  772. elm.click();
  773. setTimeout(_ => {
  774. const lastCells = vm.$el.querySelectorAll('.el-table__body-wrapper tbody tr td:last-child');
  775. expect(toArray(lastCells).map(node => node.textContent))
  776. .to.eql(['80', '92', '92', '95', '100']);
  777. done();
  778. }, DELAY);
  779. });
  780. it('descending', done => {
  781. const elm = vm.$el.querySelector('.caret-wrapper');
  782. elm.click();
  783. setTimeout(_ => {
  784. const lastCells = vm.$el.querySelectorAll('.el-table__body-wrapper tbody tr td:last-child');
  785. expect(toArray(lastCells).map(node => node.textContent))
  786. .to.eql(['100', '95', '92', '92', '80']);
  787. destroyVM(vm);
  788. done();
  789. }, DELAY);
  790. });
  791. });
  792. });
  793. it('hover', done => {
  794. const vm = createVue({
  795. template: `
  796. <el-table :data="testData">
  797. <el-table-column prop="name" label="片名" />
  798. <el-table-column prop="release" label="发行日期" />
  799. <el-table-column prop="director" label="导演" />
  800. <el-table-column prop="runtime" label="时长(分)" />
  801. </el-table>
  802. `,
  803. created() {
  804. this.testData = getTestData();
  805. }
  806. }, true);
  807. setTimeout(_ => {
  808. const tr = vm.$el.querySelector('.el-table__body-wrapper tbody tr');
  809. triggerEvent(tr, 'mouseenter', true, false);
  810. setTimeout(_ => {
  811. expect(tr.classList.contains('hover-row')).to.true;
  812. triggerEvent(tr, 'mouseleave', true, false);
  813. setTimeout(_ => {
  814. expect(tr.classList.contains('hover-row')).to.false;
  815. destroyVM(vm);
  816. done();
  817. }, DELAY);
  818. }, DELAY);
  819. }, DELAY);
  820. });
  821. it('highlight-current-row', done => {
  822. const vm = createVue({
  823. template: `
  824. <el-table :data="testData" highlight-current-row>
  825. <el-table-column prop="name" label="片名" />
  826. <el-table-column prop="release" label="发行日期" />
  827. <el-table-column prop="director" label="导演" />
  828. <el-table-column prop="runtime" label="时长(分)" />
  829. </el-table>
  830. `,
  831. created() {
  832. this.testData = getTestData();
  833. }
  834. }, true);
  835. setTimeout(_ => {
  836. const tr = vm.$el.querySelector('.el-table__body-wrapper tbody tr');
  837. triggerEvent(tr, 'click', true, false);
  838. setTimeout(_ => {
  839. expect(tr.classList.contains('current-row')).to.be.true;
  840. const rows = vm.$el.querySelectorAll('.el-table__body-wrapper tbody tr');
  841. triggerEvent(rows[2], 'click', true, false);
  842. setTimeout(_ => {
  843. expect(tr.classList.contains('current-row')).to.be.false;
  844. expect(rows[2].classList.contains('current-row')).to.be.true;
  845. destroyVM(vm);
  846. done();
  847. }, DELAY);
  848. }, DELAY);
  849. }, DELAY);
  850. });
  851. });