From f7fe30fdae38c6bdd41f4e8ef1c47afd8191ec72 Mon Sep 17 00:00:00 2001 From: Giga Chubinidze Date: Fri, 13 Jan 2023 14:49:58 +0400 Subject: [PATCH] no results state updates --- app/assets/javascripts/experiments/table.js | 28 +++++++++++---------- 1 file changed, 15 insertions(+), 13 deletions(-) diff --git a/app/assets/javascripts/experiments/table.js b/app/assets/javascripts/experiments/table.js index 6e9b42905..8c2426cc1 100644 --- a/app/assets/javascripts/experiments/table.js +++ b/app/assets/javascripts/experiments/table.js @@ -459,20 +459,11 @@ var ExperimnetTable = { this.filterDropdown.on('filter:apply', () => { $.each(this.filters, (_i, filter) => { this.activeFilters[filter.name] = filter.apply($experimentFilter); - - // Prompt empty state when theres no filtered results - let values = Object.values(this.activeFilters); - let anyFilter = values.every(value => /^\s+$/.test(value) || value === null || value === undefined || value?.length === 0); - setTimeout(() => { - var tableRowLength = document.getElementsByClassName('table-row').length; - var emptyState = document.getElementById('tasksNoResultsContainer'); - if (tableRowLength === 0 && !anyFilter) { - emptyState.style.display = 'block'; - } else { - emptyState.style.display = 'none'; - } - }, 250) }); + + // filters are active if they have any non-empty value + let filtersEmpty = Object.values(this.activeFilters).every(value => /^\s+$/.test(value) || value === null || value === undefined || value && value.length === 0); + this.filtersActive = !filtersEmpty; filterDropdown.toggleFilterMark( this.filterDropdown, @@ -507,6 +498,8 @@ var ExperimnetTable = { $(this.table).find('.table-row').remove(); this.appendRows(result.data); this.initDueDatePicker(result.data); + this.handleNoResults(); + InfiniteScroll.init(this.table, { url: dataUrl, eventTarget: window, @@ -536,6 +529,15 @@ var ExperimnetTable = { if (this.provisioningMyModulesCount > 0) this.pollProvisioningStatuses(provisioningStatusUrls); }, + handleNoResults: function() { + let tableRowLength = document.getElementsByClassName('table-row').length; + let noResultsContainer = document.getElementById('tasksNoResultsContainer'); + if (this.filtersActive && tableRowLength === 0) { + noResultsContainer.style.display = 'block'; + } else { + noResultsContainer.style.display = 'none'; + } + }, pollProvisioningStatuses: function(provisioningStatusUrls) { let remainingUrls = [];