From 40a5e3d70ed8ba4bfa8253fefc08ec9926ab2832 Mon Sep 17 00:00:00 2001 From: Chelsea Shaw <82459713+hashishaw@users.noreply.github.com> Date: Fri, 10 Dec 2021 16:14:57 -0600 Subject: [PATCH] UI/fix client count partial (#13396) * Initial fix * Add fallback zero values * Add changelog * Fix client count current test --- changelog/13396.txt | 3 +++ ui/app/components/clients/history.js | 6 +++--- .../templates/components/clients/history.hbs | 8 +++---- .../components/clients-current-test.js | 21 ++++++++++++------- 4 files changed, 23 insertions(+), 15 deletions(-) create mode 100644 changelog/13396.txt diff --git a/changelog/13396.txt b/changelog/13396.txt new file mode 100644 index 000000000000..6600abedf19e --- /dev/null +++ b/changelog/13396.txt @@ -0,0 +1,3 @@ +```release-note:bug +ui: Fix client count current month data not showing unless monthly history data exists +``` diff --git a/ui/app/components/clients/history.js b/ui/app/components/clients/history.js index 0d543913b22a..b1ce2536dd26 100644 --- a/ui/app/components/clients/history.js +++ b/ui/app/components/clients/history.js @@ -10,11 +10,11 @@ export default class HistoryComponent extends Component { @tracked barChartSelection = false; - // Determine if we have client count data based on the current tab, - // since model is slightly different for current month vs history api + // Determine if we have client count data based on the current tab get hasClientData() { if (this.args.tab === 'current') { - return this.args.model.activity && this.args.model.activity.clients; + // Show the current numbers as long as config is on + return this.args.model.config?.enabled !== 'Off'; } return this.args.model.activity && this.args.model.activity.total; } diff --git a/ui/app/templates/components/clients/history.hbs b/ui/app/templates/components/clients/history.hbs index dfbfda7d4ce3..35cc4973e57d 100644 --- a/ui/app/templates/components/clients/history.hbs +++ b/ui/app/templates/components/clients/history.hbs @@ -1,4 +1,4 @@ -{{#if (eq @model.config.queriesAvailable false)}} +{{#if (and (eq @tab 'history') (eq @model.config.queriesAvailable false))}} {{#if (eq @model.config.enabled 'On')}} @@ -114,7 +114,7 @@ @@ -123,7 +123,7 @@ diff --git a/ui/tests/integration/components/clients-current-test.js b/ui/tests/integration/components/clients-current-test.js index ace20b389745..efd9790f24fe 100644 --- a/ui/tests/integration/components/clients-current-test.js +++ b/ui/tests/integration/components/clients-current-test.js @@ -20,23 +20,28 @@ module('Integration | Component | client count current', function(hooks) { await render(hbs``); assert.dom('[data-test-component="empty-state"]').exists('Empty state exists'); - assert.dom('[data-test-empty-state-title]').hasText('Data tracking is disabled'); + assert.dom('[data-test-empty-state-title]').hasText('Tracking is disabled'); }); - test('it shows empty state when enabled and no data available', async function(assert) { + test('it shows zeroes when enabled and no data', async function(assert) { Object.assign(this.model.config, { enabled: 'On', queriesAvailable: false }); + Object.assign(this.model.activity, { + clients: 0, + distinct_entities: 0, + non_entity_tokens: 0, + }); await render(hbs``); - - assert.dom('[data-test-component="empty-state"]').exists('Empty state exists'); - assert.dom('[data-test-empty-state-title]').hasText('No monthly history'); + assert.dom('[data-test-component="empty-state"]').doesNotExist('Empty state does not exist'); + assert.dom('[data-test-client-count-stats]').exists('Client count data exists'); }); - test('it shows empty state when data available but not returned', async function(assert) { + test('it shows zeroed data when enabled but no counts', async function(assert) { Object.assign(this.model.config, { queriesAvailable: true, enabled: 'On' }); await render(hbs``); assert.dom('[data-test-pricing-metrics-form]').doesNotExist('Date range component should not exists'); - assert.dom('[data-test-component="empty-state"]').exists('Empty state exists'); - assert.dom('[data-test-empty-state-title]').hasText('No data received'); + assert.dom('[data-test-component="empty-state"]').doesNotExist('Empty state does not exist'); + assert.dom('[data-test-client-count-stats]').exists('Client count data exists'); + assert.dom('[data-test-stat-text-container]').includesText('0'); }); test('it shows data when available from query', async function(assert) {