|
23 | 23 | const settingsNode = event.target.closest(SELECTOR_SETTINGS_COLUMNS); |
24 | 24 | const template = settingsNode.querySelector(SELECTOR_TEMPLATE).innerHTML; |
25 | 25 | const node = settingsNode.querySelector(SELECTOR_COLUMNS_CONTAINER); |
26 | | - const emptyPlaceholder = node.querySelector('.ibexa-table__empty-table-cell'); |
| 26 | + const table = settingsNode.querySelector('.ibexa-table'); |
| 27 | + const tableHead = table.querySelector('.ibexa-table thead'); |
| 28 | + const emptyPlaceholder = table.querySelector('.ibexa-table__empty-table-cell'); |
27 | 29 |
|
28 | 30 | if (emptyPlaceholder) { |
29 | 31 | emptyPlaceholder.closest('.ibexa-table__row').remove(); |
| 32 | + |
| 33 | + tableHead.hidden = false; |
30 | 34 | } |
31 | 35 |
|
32 | 36 | node.insertAdjacentHTML('beforeend', template.replace(NUMBER_PLACEHOLDER, getNextIndex(node))); |
|
37 | 41 | }; |
38 | 42 | const removeItems = (event) => { |
39 | 43 | const settingsNode = event.target.closest(SELECTOR_SETTINGS_COLUMNS); |
| 44 | + const checkedRows = findCheckedColumns(settingsNode); |
| 45 | + const allRows = settingsNode.querySelectorAll(':not(.ibexa-table__template--empty-row) .ibexa-table__row'); |
| 46 | + const tableHead = settingsNode.querySelector('.ibexa-table thead'); |
| 47 | + const tableBody = settingsNode.querySelector('.ibexa-table__body'); |
| 48 | + const emptyPlaceholder = settingsNode.querySelector('.ibexa-table__template--empty-row')?.content.cloneNode(true); |
| 49 | + const removedAllRows = checkedRows.length === allRows.length; |
40 | 50 |
|
41 | | - findCheckedColumns(settingsNode).forEach((checkbox) => { |
42 | | - checkbox.checked = false; |
43 | | - checkbox.dispatchEvent(new Event('change')); |
44 | | - checkbox.closest(SELECTOR_COLUMN).remove(); |
45 | | - }); |
| 51 | + if (removedAllRows) { |
| 52 | + tableBody.appendChild(emptyPlaceholder); |
| 53 | + } |
| 54 | + |
| 55 | + setTimeout(() => { |
| 56 | + if (removedAllRows) { |
| 57 | + tableHead.hidden = true; |
| 58 | + } |
| 59 | + |
| 60 | + checkedRows.forEach((checkbox) => { |
| 61 | + checkbox.checked = false; |
| 62 | + checkbox.dispatchEvent(new Event('change')); |
| 63 | + checkbox.closest(SELECTOR_COLUMN).remove(); |
| 64 | + }); |
| 65 | + }, 1); |
46 | 66 |
|
47 | 67 | initColumns(settingsNode); |
48 | 68 | }; |
|
0 commit comments