2021-03-21 17:55:14 +01:00
|
|
|
import React, { useEffect } from 'react';
|
2021-03-20 03:20:48 +01:00
|
|
|
import { useDispatch, useSelector } from 'react-redux';
|
|
|
|
import { Map } from 'immutable';
|
|
|
|
|
2021-03-21 17:55:14 +01:00
|
|
|
import { getAllConfig } from '../../state/actions/Config';
|
2021-03-20 14:42:15 +01:00
|
|
|
import ConfigList from '../../components/ConfigList';
|
2021-03-20 15:07:10 +01:00
|
|
|
import ActionButtons from '../../components/ActionButtons';
|
2021-03-20 16:51:34 +01:00
|
|
|
import difference from '../../helpers/getObjectDiff';
|
2021-03-20 00:54:18 +01:00
|
|
|
|
|
|
|
const ConfigPage = () => {
|
2021-03-20 03:20:48 +01:00
|
|
|
const dispatch = useDispatch();
|
2021-03-21 17:55:14 +01:00
|
|
|
const isLoading = useSelector((state) => state.getIn(['config', 'isLoading']), Map());
|
2021-03-20 03:20:48 +01:00
|
|
|
const fileConfig = useSelector((state) => state.getIn(['config', 'fileConfig']), Map());
|
|
|
|
const databaseConfig = useSelector((state) => state.getIn(['config', 'databaseConfig']), Map());
|
|
|
|
|
|
|
|
useEffect(() => {
|
2021-03-21 17:55:14 +01:00
|
|
|
dispatch(getAllConfig());
|
2021-03-20 03:20:48 +01:00
|
|
|
}, []);
|
|
|
|
|
2021-03-20 16:51:34 +01:00
|
|
|
const diff = difference(fileConfig.toJS(), databaseConfig.toJS());
|
2021-03-20 03:20:48 +01:00
|
|
|
|
|
|
|
return (
|
2021-03-20 14:42:15 +01:00
|
|
|
<div>
|
2021-03-20 16:51:34 +01:00
|
|
|
<ActionButtons diff={diff} />
|
|
|
|
<ConfigList fileConfig={fileConfig} databaseConfig={databaseConfig} isLoading={isLoading} diff={diff} />
|
2021-03-20 14:42:15 +01:00
|
|
|
</div>
|
2021-03-20 03:20:48 +01:00
|
|
|
);
|
2021-03-20 00:54:18 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
export default ConfigPage;
|