From ac1b22020f31eba22ef4b89826c77a3506afc140 Mon Sep 17 00:00:00 2001 From: Joseph Date: Mon, 14 Oct 2024 23:02:43 +0000 Subject: [PATCH 1/2] Feature: Add prop to hide items index in footer --- src/components/DataTable.vue | 5 ++++- src/propsWithDefault.ts | 4 ++++ 2 files changed, 8 insertions(+), 1 deletion(-) diff --git a/src/components/DataTable.vue b/src/components/DataTable.vue index e51b2ab..561ed0f 100644 --- a/src/components/DataTable.vue +++ b/src/components/DataTable.vue @@ -255,7 +255,10 @@ :rows-items="rowsItemsComputed" /> -
+
{{ `${currentPageFirstIndex}–${currentPageLastIndex}` }} {{ rowsOfPageSeparatorMessage }} {{ totalItemsLength }}
diff --git a/src/propsWithDefault.ts b/src/propsWithDefault.ts index 947441d..5e52c75 100644 --- a/src/propsWithDefault.ts +++ b/src/propsWithDefault.ts @@ -63,6 +63,10 @@ export default { type: Boolean, default: false, }, + hideItemsIndex: { + type: Boolean, + default: false, + }, hideRowsPerPage: { type: Boolean, default: false, From 1f2ebfb3f590730cf87ea31c4172044f3b1392ba Mon Sep 17 00:00:00 2001 From: Joseph Date: Mon, 14 Oct 2024 23:03:09 +0000 Subject: [PATCH 2/2] fix failing tests --- test/DataTable.spec.js | 20 +++++++++++--------- 1 file changed, 11 insertions(+), 9 deletions(-) diff --git a/test/DataTable.spec.js b/test/DataTable.spec.js index 083fc24..85c190c 100644 --- a/test/DataTable.spec.js +++ b/test/DataTable.spec.js @@ -17,7 +17,7 @@ describe('Button Pagination', () => { rowsPerPage: 5, }, }); - expect(wrapper.find('.data-table').exists()).toBe(true); + expect(wrapper.find('.vue3-easy-data-table').exists()).toBe(true); }); /** @@ -76,7 +76,7 @@ describe('Button Pagination', () => { // Multiple selecting describe('Multiple selecting', () => { - it('Gather data of the the top two row items', async () => { + it('Gather data of the top two row items', async () => { const mockItems = mockClientItems(200); const wrapper = mount(DataTable, { props: { @@ -86,9 +86,9 @@ describe('Multiple selecting', () => { rowsPerPage: 5, }, }); - const singleCheckboxArr = wrapper.findAll('.single-select__checkbox'); - const firstSingleCheckbox = singleCheckboxArr.at(0); - const secondSingleCheckbox = singleCheckboxArr.at(1); + const singleCheckboxArr = wrapper.findAll('.easy-checkbox'); + const firstSingleCheckbox = singleCheckboxArr.at(1); + const secondSingleCheckbox = singleCheckboxArr.at(2); await firstSingleCheckbox.trigger('click'); await secondSingleCheckbox.trigger('click'); const updateItemsSelecedEvent = wrapper.emitted('update:itemsSelected'); @@ -106,18 +106,20 @@ describe('Multiple selecting', () => { rowsPerPage: 5, }, }); - const singleCheckboxArr = wrapper.findAll('.single-select__checkbox'); - const firstSingleCheckbox = singleCheckboxArr.at(0); + const singleCheckboxArr = wrapper.findAll('.easy-checkbox'); + const firstSingleCheckbox = singleCheckboxArr.at(1); await firstSingleCheckbox.trigger('click'); const nextPageButton = wrapper.find('.next-page__click-button'); await nextPageButton.trigger('click'); - const singleCheckboxArrInSecondPage = wrapper.findAll('.single-select__checkbox'); - const firstSingleCheckboxInSecondPage = singleCheckboxArrInSecondPage.at(0); + const singleCheckboxArrInSecondPage = wrapper.findAll('.easy-checkbox'); + const firstSingleCheckboxInSecondPage = singleCheckboxArrInSecondPage.at(1); await firstSingleCheckboxInSecondPage.trigger('click'); const updateItemsSelecedEvent = wrapper.emitted('update:itemsSelected'); + console.log(updateItemsSelecedEvent[1]); + expect(updateItemsSelecedEvent).toHaveLength(2); expect(updateItemsSelecedEvent[1]).toEqual([[mockItems[5], mockItems[0]]]); });