- 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:
parent
72f253f62b
commit
b8032801a2
@ -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>
|
||||||
|
@ -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,
|
||||||
|
@ -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}
|
||||||
/>
|
/>
|
||||||
|
@ -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
|
||||||
|
Loading…
Reference in New Issue
Block a user