From 0e567e59fb52f758bb39c72aeb6dee13dd581c40 Mon Sep 17 00:00:00 2001 From: Jan Date: Wed, 31 Jan 2024 23:37:52 +0100 Subject: [PATCH] CM-502: add payment data upload --- .../payroll/PayrollPaymentDataUploadDialog.js | 188 ++++++++++++++++++ src/pages/payroll/PayrollBillSearcher.js | 17 +- src/pages/payroll/PayrollBillTabPanel.js | 10 +- src/pages/payroll/PayrollPage.js | 1 + src/pages/payroll/PayrollTab.js | 29 ++- src/translations/en.json | 4 +- 6 files changed, 218 insertions(+), 31 deletions(-) create mode 100644 src/components/payroll/PayrollPaymentDataUploadDialog.js diff --git a/src/components/payroll/PayrollPaymentDataUploadDialog.js b/src/components/payroll/PayrollPaymentDataUploadDialog.js new file mode 100644 index 0000000..1264deb --- /dev/null +++ b/src/components/payroll/PayrollPaymentDataUploadDialog.js @@ -0,0 +1,188 @@ +import React, { useState } from 'react'; +import { Input, Grid } from '@material-ui/core'; +import { injectIntl } from 'react-intl'; +import Button from '@material-ui/core/Button'; +import Dialog from '@material-ui/core/Dialog'; +import DialogActions from '@material-ui/core/DialogActions'; +import DialogContent from '@material-ui/core/DialogContent'; +import DialogTitle from '@material-ui/core/DialogTitle'; +import { + apiHeaders, + baseApiUrl, + formatMessage, +} from '@openimis/fe-core'; +import { withTheme, withStyles } from '@material-ui/core/styles'; +import { connect } from 'react-redux'; +import { bindActionCreators } from 'redux'; + +const styles = (theme) => ({ + item: theme.paper.item, +}); + +function PayrollPaymentDataUploadDialog({ + intl, + classes, + payrollUuid, +}) { + const [isOpen, setIsOpen] = useState(false); + const [forms, setForms] = useState({}); + + const handleOpen = () => { + setIsOpen(true); + }; + + const handleClose = () => { + setForms({}); + setIsOpen(false); + }; + + const handleFieldChange = (formName, fieldName, value) => { + setForms({ + ...forms, + [formName]: { + ...(forms[formName] ?? {}), + [fieldName]: value, + }, + }); + }; + + const onSubmit = async (values) => { + const fileFormat = values.file.type; + const formData = new FormData(); + + formData.append('file', values.file); + + let urlImport; + if (fileFormat.includes('/csv')) { + formData.append('payroll', payrollUuid); + urlImport = `${baseApiUrl}/payroll/import_payment_data/`; + } + + try { + const response = await fetch(urlImport, { + headers: apiHeaders, + body: formData, + method: 'POST', + credentials: 'same-origin', + }); + + await response.json(); + + if (response.status >= 400) { + handleClose(); + return; + } + handleClose(); + } catch (error) { + handleClose(); + } + }; + + return ( + <> + + +
+ + {formatMessage(intl, 'payroll', 'payroll.paymentData.upload.label')} + + +
+ + + + handleFieldChange('paymentData', 'file', event.target.files[0])} + required + id="import-button" + inputProps={{ + accept: '.csv, application/csv, text/csv', + }} + type="file" + /> + + + +
+
+ +
+
+ +
+
+ +
+
+
+
+
+ + ); +} + +const mapStateToProps = (state) => ({ + rights: !!state.core && !!state.core.user && !!state.core.user.i_user ? state.core.user.i_user.rights : [], + confirmed: state.core.confirmed, +}); + +const mapDispatchToProps = (dispatch) => bindActionCreators({ +}, dispatch); + +export default injectIntl( + withTheme( + withStyles(styles)( + connect(mapStateToProps, mapDispatchToProps)(PayrollPaymentDataUploadDialog), + ), + ), +); diff --git a/src/pages/payroll/PayrollBillSearcher.js b/src/pages/payroll/PayrollBillSearcher.js index 37451d3..b6deb1a 100644 --- a/src/pages/payroll/PayrollBillSearcher.js +++ b/src/pages/payroll/PayrollBillSearcher.js @@ -33,6 +33,7 @@ function PayrollBillSearcher({ bills, billsPageInfo, billsTotalCount, + payrollUuid, }) { const history = useHistory(); const modulesManager = useModulesManager(); @@ -44,20 +45,8 @@ function PayrollBillSearcher({ const onDoubleClick = (bill) => openBill(bill); - const [payrollUuid] = useState(''); - const fetch = (params) => { - const currentPath = window.location.pathname; - const pathSegments = currentPath.split('/'); - const payrollIndex = pathSegments.indexOf('payroll'); - if (payrollIndex !== -1 && payrollIndex < pathSegments.length - 1) { - const uuid = pathSegments[payrollIndex + 1]; - const index = params.findIndex((element) => element.startsWith('payrollUuid:')); - if (index !== -1) { - params[index] = `payrollUuid: "${uuid}"`; - } - fetchPayrollBills(modulesManager, params); - } + fetchPayrollBills(modulesManager, params); }; const headers = () => { @@ -119,6 +108,8 @@ function PayrollBillSearcher({ ['status', true], ]; + console.log(payrollUuid); + const defaultFilters = () => ({ isDeleted: { value: false, diff --git a/src/pages/payroll/PayrollBillTabPanel.js b/src/pages/payroll/PayrollBillTabPanel.js index b0b271e..469da84 100644 --- a/src/pages/payroll/PayrollBillTabPanel.js +++ b/src/pages/payroll/PayrollBillTabPanel.js @@ -20,14 +20,6 @@ function PayrollBillsTabLabel({ } function PayrollBillsTabPanel({ value, rights, payrollUuid }) { - let uuidPayroll = null; - const currentPath = window.location.pathname; - const pathSegments = currentPath.split('/'); - const payrollIndex = pathSegments.indexOf('payroll'); - if (payrollIndex !== -1 && payrollIndex < pathSegments.length - 1) { - const uuid = pathSegments[payrollIndex + 1]; - uuidPayroll = uuid; - } return ( { - rights.includes(RIGHT_BILL_SEARCH) && uuidPayroll && ( + rights.includes(RIGHT_BILL_SEARCH) && payrollUuid && ( ) } diff --git a/src/pages/payroll/PayrollPage.js b/src/pages/payroll/PayrollPage.js index 2fb8019..4219ea3 100644 --- a/src/pages/payroll/PayrollPage.js +++ b/src/pages/payroll/PayrollPage.js @@ -148,6 +148,7 @@ function PayrollPage({ rights={rights} actions={actions} setConfirmedAction={setConfirmedAction} + payrollUuid={payrollUuid} saveTooltip={formatMessage('tooltip.save')} /> diff --git a/src/pages/payroll/PayrollTab.js b/src/pages/payroll/PayrollTab.js index 1e06a59..2ad7b22 100644 --- a/src/pages/payroll/PayrollTab.js +++ b/src/pages/payroll/PayrollTab.js @@ -7,6 +7,7 @@ import { PAYROLL_TABS_LABEL_CONTRIBUTION_KEY, PAYROLL_TABS_PANEL_CONTRIBUTION_KEY, } from '../../constants'; +import PayrollPaymentDataUploadDialog from '../../components/payroll/PayrollPaymentDataUploadDialog'; const useStyles = makeStyles((theme) => ({ paper: theme.paper.paper, @@ -43,14 +44,26 @@ function PayrollTab({ rights, setConfirmedAction, payrollUuid }) { return ( - +
+
+ +
+
+ {payrollUuid + && ( + + )} +
+