From 24d75c4376382205ae6b8f731b1cd23d517772c9 Mon Sep 17 00:00:00 2001 From: Vladislav Abdulmyanov Date: Tue, 21 Mar 2023 18:21:13 +0200 Subject: [PATCH] client: add ignore domains for stats --- client/src/__locales/en.json | 1 + client/src/actions/stats.js | 2 +- client/src/api/Api.js | 10 ++--- .../components/Settings/StatsConfig/Form.js | 41 +++++++++++-------- .../components/Settings/StatsConfig/index.js | 15 +++++-- client/src/components/Settings/index.js | 4 ++ client/src/helpers/constants.js | 7 +++- client/src/reducers/stats.js | 4 +- 8 files changed, 53 insertions(+), 31 deletions(-) diff --git a/client/src/__locales/en.json b/client/src/__locales/en.json index 2afa38bdc35..72436717573 100644 --- a/client/src/__locales/en.json +++ b/client/src/__locales/en.json @@ -523,6 +523,7 @@ "statistics_retention_confirm": "Are you sure you want to change statistics retention? If you decrease the interval value, some data will be lost", "statistics_cleared": "Statistics successfully cleared", "statistics_enable": "Enable statistics", + "statistics_ignore_domains": "Ignore domains (separated by newline)", "interval_hours": "{{count}} hour", "interval_hours_plural": "{{count}} hours", "filters_configuration": "Filters configuration", diff --git a/client/src/actions/stats.js b/client/src/actions/stats.js index d3948efad08..0e5b416e06f 100644 --- a/client/src/actions/stats.js +++ b/client/src/actions/stats.js @@ -13,7 +13,7 @@ export const getStatsConfigSuccess = createAction('GET_STATS_CONFIG_SUCCESS'); export const getStatsConfig = () => async (dispatch) => { dispatch(getStatsConfigRequest()); try { - const data = await apiClient.getStatsInfo(); + const data = await apiClient.getStatsConfig(); dispatch(getStatsConfigSuccess(data)); } catch (error) { dispatch(addErrorToast({ error })); diff --git a/client/src/api/Api.js b/client/src/api/Api.js index d984bbb8b0f..92d3e558279 100644 --- a/client/src/api/Api.js +++ b/client/src/api/Api.js @@ -497,9 +497,9 @@ class Api { // Settings for statistics GET_STATS = { path: 'stats', method: 'GET' }; - STATS_INFO = { path: 'stats_info', method: 'GET' }; + GET_STATS_CONFIG = { path: 'stats/config', method: 'GET' }; - STATS_CONFIG = { path: 'stats_config', method: 'POST' }; + UPDATE_STATS_CONFIG = { path: 'stats/config/update', method: 'PUT' }; STATS_RESET = { path: 'stats_reset', method: 'POST' }; @@ -508,13 +508,13 @@ class Api { return this.makeRequest(path, method); } - getStatsInfo() { - const { path, method } = this.STATS_INFO; + getStatsConfig() { + const { path, method } = this.GET_STATS_CONFIG; return this.makeRequest(path, method); } setStatsConfig(data) { - const { path, method } = this.STATS_CONFIG; + const { path, method } = this.UPDATE_STATS_CONFIG; const config = { data, }; diff --git a/client/src/components/Settings/StatsConfig/Form.js b/client/src/components/Settings/StatsConfig/Form.js index cf8da0ac25a..637337c3b15 100644 --- a/client/src/components/Settings/StatsConfig/Form.js +++ b/client/src/components/Settings/StatsConfig/Form.js @@ -4,23 +4,31 @@ import { Field, reduxForm } from 'redux-form'; import { Trans, withTranslation } from 'react-i18next'; import flow from 'lodash/flow'; -import { renderRadioField, toNumber, CheckboxField } from '../../../helpers/form'; -import { FORM_NAME, STATS_INTERVALS_DAYS, DISABLED_STATS_INTERVAL } from '../../../helpers/constants'; +import { + renderRadioField, + toNumber, + CheckboxField, + renderTextareaField, +} from '../../../helpers/form'; +import { + FORM_NAME, + STATS_INTERVALS_DAYS, + DAY, +} from '../../../helpers/constants'; import '../FormButton.css'; -const getIntervalTitle = (interval, t) => { - switch (interval) { +const getIntervalTitle = (intervalMs, t) => { + switch (intervalMs / DAY) { case 1: return t('interval_24_hour'); default: - return t('interval_days', { count: interval }); + return t('interval_days', { count: intervalMs / DAY }); } }; const Form = (props) => { const { handleSubmit, - change, processing, submitting, invalid, @@ -38,13 +46,6 @@ const Form = (props) => { component={CheckboxField} placeholder={t('statistics_enable')} disabled={processing} - onChange={(event) => { - if (event.target.checked) { - change('interval', STATS_INTERVALS_DAYS[0]); - } else { - change('interval', DISABLED_STATS_INTERVAL); - } - }} />