feat: Optimize connect component props with redux store.

This commit is contained in:
Ahmed Bouhuolia
2020-05-10 02:14:42 +02:00
parent e590a21740
commit a0653674ff
58 changed files with 660 additions and 460 deletions

View File

@@ -1,23 +1,32 @@
import React, {useState, useCallback, useEffect, useMemo} from 'react';
import React, { useState, useCallback, useEffect } from 'react';
import { useQuery } from 'react-query';
import {compose} from 'utils';
import JournalConnect from 'connectors/Journal.connect';
import JournalHeader from 'containers/FinancialStatements/Journal/JournalHeader';
import useAsync from 'hooks/async';
import {useIntl} from 'react-intl';
import moment from 'moment';
import JournalTable from './JournalTable';
import DashboardConnect from 'connectors/Dashboard.connector';
import JournalHeader from './JournalHeader';
import JournalActionsBar from './JournalActionsBar';
import DashboardPageContent from 'components/Dashboard/DashboardPageContent';
import DashboardInsider from 'components/Dashboard/DashboardInsider';
import SettingsConnect from 'connectors/Settings.connect';
import withDashboard from 'containers/Dashboard/withDashboard';
import withJournal from './withJournal';
import withJournalActions from './withJournalActions';
function Journal({
fetchJournalSheet,
getJournalSheet,
getJournalSheetIndex,
changePageTitle,
// #withJournalActions
requestFetchJournalSheet,
// #withDashboard
changePageTitle,
// #withJournal
journalSheetLoading,
// #withPreferences
organizationSettings,
}) {
const [filter, setFilter] = useState({
@@ -30,21 +39,8 @@ function Journal({
changePageTitle('Journal Sheet');
}, []);
const fetchHook = useAsync((query = filter) => {
return Promise.all([
fetchJournalSheet(query),
]);
}, false);
// Retrieve journal sheet index by the given filter query.
const journalSheetIndex = useMemo(() =>
getJournalSheetIndex(filter),
[getJournalSheetIndex, filter]);
// Retrieve journal sheet by the given sheet index.
const journalSheet = useMemo(() =>
getJournalSheet(journalSheetIndex),
[getJournalSheet, journalSheetIndex]);
const fetchHook = useQuery(['journal', filter],
(key, query) => { requestFetchJournalSheet(query); });
// Handle financial statement filter change.
const handleFilterSubmit = useCallback((filter) => {
@@ -54,7 +50,6 @@ function Journal({
to_date: moment(filter.to_date).format('YYYY-MM-DD'),
};
setFilter(_filter);
fetchHook.execute(_filter);
}, [fetchHook]);
const handlePrintClick = useCallback(() => {
@@ -66,7 +61,7 @@ function Journal({
}, []);
const handleFetchData = useCallback(({ sortBy, pageIndex, pageSize }) => {
fetchHook.execute();
fetchHook.refetch();
}, [fetchHook]);
return (
@@ -85,12 +80,9 @@ function Journal({
<div class="financial-statement__table">
<JournalTable
companyName={organizationSettings.name}
data={[
...(journalSheet && journalSheet.tableRows)
? journalSheet.tableRows : []
]}
journalQuery={filter}
loading={journalSheetLoading}
onFetchData={handleFetchData} />
onFetchData={handleFetchData} />
</div>
</div>
</DashboardPageContent>
@@ -99,7 +91,10 @@ function Journal({
}
export default compose(
JournalConnect,
DashboardConnect,
withDashboard,
withJournalActions,
withJournal(({ journalSheetLoading }) => ({
journalSheetLoading,
})),
SettingsConnect,
)(Journal);

View File

@@ -28,9 +28,9 @@ export default function JournalHeader({
from_date: Yup.date().required(),
to_date: Yup.date().min(Yup.ref('from_date')).required(),
}),
onSubmit: (values, actions) => {
onSubmit: (values, { setSubmitting }) => {
onSubmitFilter(values);
actions.setSubmitting(false);
setSubmitting(false);
},
});

View File

@@ -1,18 +1,25 @@
import React, {useState, useEffect, useCallback, useMemo} from 'react';
import React, { useCallback, useMemo } from 'react';
import {connect} from 'react-redux';
import moment from 'moment';
import FinancialSheet from 'components/FinancialSheet';
import DataTable from 'components/DataTable';
import {compose, defaultExpanderReducer} from 'utils';
import moment from 'moment';
import JournalConnect from 'connectors/Journal.connect';
import {
getFinancialSheet,
} from 'store/financialStatement/financialStatements.selectors';
import {connect} from 'react-redux';
import Money from 'components/Money';
import {
getFinancialSheetIndexByQuery,
} from 'store/financialStatement/financialStatements.selectors';
import withJournal from './withJournal';
function JournalSheetTable({
// #withJournal
journalSheetTableRows,
// #ownProps
onFetchData,
data,
loading,
companyName,
}) {
@@ -73,7 +80,7 @@ function JournalSheetTable({
}, [onFetchData]);
// Default expanded rows of general journal table.
const expandedRows = useMemo(() => defaultExpanderReducer(data, 1), [data]);
const expandedRows = useMemo(() => defaultExpanderReducer([], 1), []);
return (
<FinancialSheet
@@ -82,11 +89,11 @@ function JournalSheetTable({
date={new Date()}
name="journal"
loading={loading}>
<DataTable
className="bigcapital-datatable--financial-report"
columns={columns}
data={data}
data={journalSheetTableRows}
onFetchData={handleFetchData}
noResults={"This report does not contain any data."}
expanded={expandedRows}
@@ -95,6 +102,19 @@ function JournalSheetTable({
);
}
const mapStateToProps = (state, props) => {
const { journalQuery } = props;
return {
journalIndex: getFinancialSheetIndexByQuery(state.financialStatements.journal.sheets, journalQuery)
};
}
const withJournalTable = connect(mapStateToProps);
export default compose(
JournalConnect,
withJournalTable,
withJournal(({ journalSheetTableRows }) => ({
journalSheetTableRows
})),
)(JournalSheetTable);

View File

@@ -0,0 +1,21 @@
import {connect} from 'react-redux';
import {
getFinancialSheetIndexByQuery,
getFinancialSheet,
getFinancialSheetTableRows,
} from 'store/financialStatement/financialStatements.selectors';
export default (mapState) => {
const mapStateToProps = (state, props) => {
const { journalIndex } = props;
const mapped = {
journalSheet: getFinancialSheet(state.financialStatements.journal.sheets, journalIndex),
journalSheetTableRows: getFinancialSheetTableRows(state.financialStatements.journal.sheets, journalIndex),
journalSheetLoading: state.financialStatements.journal.loading,
};
return mapState ? mapState(mapped, state, props) : mapped;
};
return connect(mapStateToProps);
};

View File

@@ -0,0 +1,10 @@
import {connect} from 'react-redux';
import {
fetchJournalSheet
} from 'store/financialStatement/financialStatements.actions';
export const mapDispatchToProps = (dispatch) => ({
requestFetchJournalSheet: (query) => dispatch(fetchJournalSheet({ query })),
});
export default connect(null, mapDispatchToProps);