- client: Submit setFiltersConfig action on if the values are changed: Merge pull request #637 in DNS/adguard-home from fix/1749 to master

Close #1749

Squashed commit of the following:

commit aaf4ba86429670ea8b0001325562c4a173be5b4a
Author: ArtemBaskal <a.baskal@adguard.com>
Date:   Fri May 29 13:29:44 2020 +0300

    - client: Submit setFiltersConfig action on if the values are changed
This commit is contained in:
Artem Baskal 2020-05-29 16:08:01 +03:00
parent 72f253f62b
commit b8032801a2
4 changed files with 38 additions and 22 deletions

View File

@ -61,7 +61,6 @@ const Form = (props) => {
<label className="form__label"> <label className="form__label">
<Trans>filters_interval</Trans> <Trans>filters_interval</Trans>
</label> </label>
{getIntervalSelect(processing, t, handleChange, toNumber)} {getIntervalSelect(processing, t, handleChange, toNumber)}
</div> </div>
</div> </div>

View File

@ -1,33 +1,35 @@
import React, { Component } from 'react'; import React from 'react';
import PropTypes from 'prop-types'; import PropTypes from 'prop-types';
import { withTranslation } from 'react-i18next'; import { withTranslation } from 'react-i18next';
import debounce from 'lodash/debounce'; import debounce from 'lodash/debounce';
import { DEBOUNCE_TIMEOUT } from '../../../helpers/constants'; import { DEBOUNCE_TIMEOUT } from '../../../helpers/constants';
import Form from './Form'; import Form from './Form';
import { getObjDiff } from '../../../helpers/helpers';
class FiltersConfig extends Component { const FiltersConfig = (props) => {
handleFormChange = debounce((values) => { const { initialValues, processing } = props;
this.props.setFiltersConfig(values);
const handleFormChange = debounce((values) => {
const diff = getObjDiff(initialValues, values);
if (Object.values(diff).length > 0) {
props.setFiltersConfig(values);
}
}, DEBOUNCE_TIMEOUT); }, DEBOUNCE_TIMEOUT);
render() {
const { interval, enabled, processing } = this.props;
return ( return (
<Form <Form
initialValues={{ interval, enabled }} initialValues={initialValues}
onSubmit={this.handleFormChange} onSubmit={handleFormChange}
onChange={this.handleFormChange} onChange={handleFormChange}
processing={processing} processing={processing}
/> />
); );
} };
}
FiltersConfig.propTypes = { FiltersConfig.propTypes = {
interval: PropTypes.number.isRequired, initialValues: PropTypes.object.isRequired,
enabled: PropTypes.bool.isRequired,
processing: PropTypes.bool.isRequired, processing: PropTypes.bool.isRequired,
setFiltersConfig: PropTypes.func.isRequired, setFiltersConfig: PropTypes.func.isRequired,
t: PropTypes.func.isRequired, t: PropTypes.func.isRequired,

View File

@ -92,8 +92,10 @@ class Settings extends Component {
<Card bodyType="card-body box-body--settings"> <Card bodyType="card-body box-body--settings">
<div className="form"> <div className="form">
<FiltersConfig <FiltersConfig
interval={filtering.interval} initialValues={{
enabled={filtering.enabled} interval: filtering.interval,
enabled: filtering.enabled,
}}
processing={filtering.processingSetConfig} processing={filtering.processingSetConfig}
setFiltersConfig={setFiltersConfig} setFiltersConfig={setFiltersConfig}
/> />

View File

@ -482,6 +482,19 @@ export const getCurrentFilter = (url, filters) => {
}; };
}; };
/**
* @param {object} initialValues
* @param {object} values
* @returns {object} Returns different values of objects
*/
export const getObjDiff = (initialValues, values) => Object.entries(values)
.reduce((acc, [key, value]) => {
if (value !== initialValues[key]) {
acc[key] = value;
}
return acc;
}, {});
/** /**
* @param number Number to format * @param number Number to format
* @returns string Returns a string with a language-sensitive representation of this number * @returns string Returns a string with a language-sensitive representation of this number