import React, { Component } from 'react'; import { createMuiTheme, FormControlLabel, MuiThemeProvider, Paper, TableCell, Tooltip, Typography, withStyles, Input, ThemeProvider, TextareaAutosize } from '@material-ui/core' import MUIDataTable from 'mui-datatables'; import Images from '../../assets/Images'; import api from '../../api'; import NumberFormat from 'react-number-format'; import Constant from '../../library/Constant'; import { titleCase } from '../../library/Utils'; import { Autocomplete } from '@material-ui/lab'; import { PropagateLoader } from 'react-spinners'; import ReactTooltip from 'react-tooltip'; import { DatePicker } from '@material-ui/pickers'; import { format } from 'date-fns'; import { BorderStyle } from '@material-ui/icons'; import { includes } from 'ramda'; import Snackbar from '@material-ui/core/Snackbar'; import MuiAlert from '@material-ui/lab/Alert'; import { makeStyles } from '@material-ui/core/styles'; import UploadFile from "../../library/Upload"; import { ExcelRenderer } from 'react-excel-renderer'; import { fixNumber, roundMath } from "../../library/Utils"; function Alert(props) { return ; } const useStyles = makeStyles((theme) => ({ root: { width: '100%', '& > * + *': { marginTop: theme.spacing(2), }, }, })); const LightTooltip = withStyles((theme) => ({ tooltip: { backgroundColor: theme.palette.common.white, color: 'rgba(0, 0, 0, 0.87)', boxShadow: theme.shadows[1], fontSize: 11, }, }))(Tooltip); var ct = require("../../library/CustomTable"); const getMuiTheme = () => createMuiTheme(ct.customTable3()); const options = ct.customOptionsFixedColumn(); const style = { position: "sticky", left: 0, background: "white", zIndex: 101, }; const style2 = { position: "sticky", background: "white", zIndex: 100, top: 0 }; const theme = createMuiTheme({ overrides: { // Style sheet name ⚛️ MuiInputBase: { input: { color: '#5198ea', marginTop: -10, textAlign: 'center' } } }, }); const theme2 = createMuiTheme({ overrides: { // Style sheet name ⚛️ MuiInputBase: { input: { color: '#5198ea', textAlign: 'center' } } }, }); const theme3 = createMuiTheme({ overrides: { // Style sheet name ⚛️ MuiInputBase: { input: { color: '#black', textAlign: 'center' } } }, }); export default class ListOfCreditFacilities extends Component { constructor(props) { super(props) this.state = { dataTable: [], bankNameList: [], typeOfCreditList: [], loading: false, dataTableRatio: [], currentDate: format(new Date(), 'yyyy-MM-dd'), totalOutStand: 0, diff: 0, perBS: 0, snekbar: false, snekbarMsg: '', visibleLOCFMR: true, saveDraft: true, saveComp: true, get_for: 'view', updateBy: [], notes: "", viewOnly: true, dataDelete: [], saveTambahan: true, defaultCurrencyUpload: this.props.defaultCurrency, visibleAlertSave: false, } this.fileHandler = this.fileHandler.bind(this); } componentDidMount() { this.getPerBS() this.getBankData() this.getTypeOfCredit() this.getSubmission() this.getLatestUpdate() this.handleViewOnly() } handleGetFor(type) { this.setState({ get_for: type }, () => { this.getPerBS() this.getBankData() this.getTypeOfCredit() this.getSubmission() this.getLatestUpdate() }) } handleViewOnly() { let checkApprover = false let checkLastStatus = false let checkStatus = false let checkPrevRev = false if (this.props.isApprover) { checkApprover = true } else { checkApprover = false } if (this.props.lastStatus == 'SUBMIT' || this.props.lastStatus == 'REVISION') { checkLastStatus = true } else { checkLastStatus = false } if (this.props.prevRevision) { checkPrevRev = true } else { checkPrevRev = false } if (this.props.status === 'revision' || this.props.status === 'not-yet' || this.props.status === 'draft' || this.props.status === 'submitted') { checkStatus = true } else { checkStatus = false } this.setState({ viewOnly: !checkApprover && checkLastStatus && checkStatus && checkPrevRev }) // this.setState({viewOnly: true}) } getItemHierarki() { let payload = { "report_id": this.props.report_id, "revision": Number(this.props.revision), "periode": this.props.periode, "company_id": this.props.company.company_id, "monthly_report_id": this.props.monthlyReportId, "months": this.props.month.month_id, "currency_id": this.props.defaultCurrency.id, "get_for": this.state.get_for } api.create().getHierarkiMontlyReportLOCF(payload).then(response => { console.log(payload); console.log(response); let dataTable = [] if (response.data) { let res = response.data.data // const handlePushChild = (item) => { // let indexIDzz = dataTable.findIndex((val) => val[1] === item.id) // if (indexIDzz === -1) { // dataTable.push([ // item.type_report_id, // item.id, // item.parent, // item.formula, // item.level, // item.description, // item.locf.borrower_comp_name === null ? "0.0" : item.locf.borrower_comp_name === "" ? "0.0" : item.locf.borrower_comp_name, // item.locf.bank_name === null ? "0.0" : item.locf.bank_name === "" ? "0.0" : item.locf.bank_name, // item.locf.type_of_credit === null ? "0.0" : item.locf.type_of_credit === "" ? "0.0" : item.locf.type_of_credit, // item.locf.remarks === null ? "0.0" : item.locf.remarks === "" ? "0.0" : item.locf.remarks, // item.locf.loan_maturity_date === null ? "0.0" : item.locf.loan_maturity_date === "" ? "0.0" : item.locf.loan_maturity_date, // item.locf.interest === null ? "0.0" : item.locf.interest === "" ? "0.0" : item.locf.interest, // item.locf.currency === null ? "0.0" : item.locf.currency === "" ? "0.0" : item.locf.currency, // item.locf.loan_plafond_amount_ori === null ? "0.0" : item.locf.loan_plafond_amount_ori === "" ? "0.0" : item.locf.loan_plafond_amount_ori, // item.locf.loan_plafond_amount_idr === null ? "0.0" : item.locf.loan_plafond_amount_idr === "" ? "0.0" : item.locf.loan_plafond_amount_idr, // item.locf.out_loan_ki_amount_ori === null ? "0.0" : item.locf.out_loan_ki_amount_ori === "" ? "0.0" : item.locf.out_loan_ki_amount_ori, // item.locf.out_loan_ki_amount_idr === null ? "0.0" : item.locf.out_loan_ki_amount_idr === "" ? "0.0" : item.locf.out_loan_ki_amount_idr, // item.locf.out_loan_kmk_amount_ori === null ? "0.0" : item.locf.out_loan_kmk_amount_ori === "" ? "0.0" : item.locf.out_loan_kmk_amount_ori, // item.locf.out_loan_kmk_amount_idr === null ? "0.0" : item.locf.out_loan_kmk_amount_idr === "" ? "0.0" : item.locf.out_loan_kmk_amount_idr, // // item.locf.mtd_vs_previous_month === null ? "0.0" : item.locf.mtd_vs_previous_month === "" ? "0.0" : item.locf.mtd_vs_previous_month, // item.locf.out_loan_other_type === null ? "0.0" : item.locf.out_loan_other_type === "" ? "0.0" : item.locf.out_loan_other_type, // item.locf.out_loan_other_amount_ori === null ? "0.0" : item.locf.out_loan_other_amount_ori === "" ? "0.0" : item.locf.out_loan_other_amount_ori, // item.locf.out_loan_other_amount_idr === null ? "0.0" : item.locf.out_loan_other_amount_idr === "" ? "0.0" : item.locf.out_loan_other_amount_idr, // item.locf.total_out_loan_ori === null ? "0.0" : item.locf.total_out_loan_ori === "" ? "0.0" : item.locf.total_out_loan_ori, // item.locf.total_out_loan_idr === null ? "0.0" : item.locf.total_out_loan_idr === "" ? "0.0" : item.locf.total_out_loan_idr, // item.locf.remaining_plafond_ori === null ? "0.0" : item.locf.remaining_plafond_ori === "" ? "0.0" : item.locf.remaining_plafond_ori, // item.locf.remaining_plafond_idr === null ? "0.0" : item.locf.remaining_plafond_idr === "" ? "0.0" : item.locf.remaining_plafond_idr, // item.locf.current_ratio_financial === null ? "0.0" : item.locf.current_ratio_financial === "" ? "0.0" : item.locf.current_ratio_financial, // item.locf.current_ratio_current === null ? "0.0" : item.locf.current_ratio_current === "" ? "0.0" : item.locf.current_ratio_current, // item.locf.der_financial === null ? "0.0" : item.locf.der_financial === "" ? "0.0" : item.locf.der_financial, // item.locf.der_current === null ? "0.0" : item.locf.der_current === "" ? "0.0" : item.locf.der_current, // item.locf.debt_to_ebitda_financial === null ? "0.0" : item.locf.debt_to_ebitda_financial === "" ? "0.0" : item.locf.debt_to_ebitda_financial, // item.locf.debt_to_ebitda_current === null ? "0.0" : item.locf.debt_to_ebitda_current === "" ? "0.0" : item.locf.debt_to_ebitda_current, // item.locf.ebitda_to_interest_financial === null ? "0.0" : item.locf.ebitda_to_interest_financial === "" ? "0.0" : item.locf.ebitda_to_interest_financial, // item.locf.ebitda_to_interest_current === null ? "0.0" : item.locf.ebitda_to_interest_current === "" ? "0.0" : item.locf.ebitda_to_interest_current, // item.locf.other_ratio1_ratio_name === null ? "0.0" : item.locf.other_ratio1_ratio_name === "" ? "0.0" : item.locf.other_ratio1_ratio_name, // item.locf.other_ratio1_financial === null ? "0.0" : item.locf.other_ratio1_financial === "" ? "0.0" : item.locf.other_ratio1_financial, // item.locf.other_ratio1_current === null ? "0.0" : item.locf.other_ratio1_current === "" ? "0.0" : item.locf.other_ratio1_current, // item.locf.other_ratio2_ratio_name === null ? "0.0" : item.locf.other_ratio2_ratio_name === "" ? "0.0" : item.locf.other_ratio2_ratio_name, // item.locf.other_ratio2_financial === null ? "0.0" : item.locf.other_ratio2_financial === "" ? "0.0" : item.locf.other_ratio2_financial, // item.locf.other_ratio2_current === null ? "0.0" : item.locf.other_ratio2_current === "" ? "0.0" : item.locf.other_ratio2_current, // item.locf.other_ratio3_ratio_name === null ? "0.0" : item.locf.other_ratio3_ratio_name === "" ? "0.0" : item.locf.other_ratio3_ratio_name, // item.locf.other_ratio3_financial === null ? "0.0" : item.locf.other_ratio3_financial === "" ? "0.0" : item.locf.other_ratio3_financial, // item.locf.other_ratio3_current === null ? "0.0" : item.locf.other_ratio3_current === "" ? "0.0" : item.locf.other_ratio3_current, // item.locf.other_ratio4_ratio_name === null ? "0.0" : item.locf.other_ratio4_ratio_name === "" ? "0.0" : item.locf.other_ratio4_ratio_name, // item.locf.other_ratio4_financial === null ? "0.0" : item.locf.other_ratio4_financial === "" ? "0.0" : item.locf.other_ratio4_financial, // item.locf.other_ratio4_current === null ? "0.0" : item.locf.other_ratio4_current === "" ? "0.0" : item.locf.other_ratio4_current, // item.notes, // // item.locf.per_bs === null ? "0.0" : item.locf.per_bs === "" ? "0.0" : item.locf.per_bs, // // item.locf.diff === null ? "0.0" : item.locf.diff === "" ? "0.0" : item.locf.diff, // ]) // } // if (item.children !== null) { // if (item.children.length > 0) { // item.children.map((items, indexs) => { // handlePushChild(items) // }) // } // } // } res.map((item, index) => { let tgl = String(item.locf.loan_maturity_date).split('-') if (index == res.length - 1) { dataTable.push([ item.type_report_id, item.id, item.parent, item.formula, item.level, // item.description, item.locf.borrower_comp_name === null || item.locf.borrower_comp_name === "" ? this.props.company.company_name : item.locf.borrower_comp_name, item.locf.bank_name === null ? null : item.locf.bank_name === "" ? null : { value: item.locf.bank_name }, item.locf.type_of_credit === null ? null : item.locf.type_of_credit === "" ? null : { value: item.locf.type_of_credit }, item.locf.remarks === null || item.locf.remarks === "" ? "" : item.locf.remarks, item.locf.loan_maturity_date == null || item.locf.loan_maturity_date == "" ? null : (item.locf.loan_maturity_date !== "null" ? String(tgl[2]).length > 2 ? tgl[2] + '-' + tgl[1] + '-' + tgl[0] : String(item.locf.loan_maturity_date) : null), item.locf.interest === null || item.locf.interest === "" ? "0.00" : item.locf.interest, item.locf.currency === null || item.locf.currency === "" ? "" : item.locf.currency, item.locf.loan_plafond_amount_ori, item.locf.loan_plafond_amount_idr === null ? "0.0" : item.locf.loan_plafond_amount_idr === "" ? "0.0" : item.locf.loan_plafond_amount_idr, item.locf.out_loan_ki_amount_ori, item.locf.out_loan_ki_amount_idr === null ? "0.0" : item.locf.out_loan_ki_amount_idr === "" ? "0.0" : item.locf.out_loan_ki_amount_idr, item.locf.out_loan_kmk_amount_ori, item.locf.out_loan_kmk_amount_idr === null ? "0.0" : item.locf.out_loan_kmk_amount_idr === "" ? "0.0" : item.locf.out_loan_kmk_amount_idr, // item.locf.mtd_vs_previous_month === null ? "0.0" : item.locf.mtd_vs_previous_month === "" ? "0.0" : item.locf.mtd_vs_previous_month, item.locf.out_loan_other_type, item.locf.out_loan_other_amount_ori, item.locf.out_loan_other_amount_idr === null ? "0.0" : item.locf.out_loan_other_amount_idr === "" ? "0.0" : item.locf.out_loan_other_amount_idr, item.locf.total_out_loan_ori === null ? "0.0" : item.locf.total_out_loan_ori === "" ? "0.0" : item.locf.total_out_loan_ori, item.locf.total_out_loan_idr === null ? "0.0" : item.locf.total_out_loan_idr === "" ? "0.0" : item.locf.total_out_loan_idr, item.locf.remaining_plafond_ori === null ? "0.0" : item.locf.remaining_plafond_ori === "" ? "0.0" : item.locf.remaining_plafond_ori, item.locf.remaining_plafond_idr === null ? "0.0" : item.locf.remaining_plafond_idr === "" ? "0.0" : item.locf.remaining_plafond_idr, item.locf.current_ratio_financial, item.locf.current_ratio_current === null ? "0.0" : item.locf.current_ratio_current === "" ? "0.0" : item.locf.current_ratio_current, item.locf.der_financial, item.locf.der_current === null ? "0.0" : item.locf.der_current === "" ? "0.0" : item.locf.der_current, item.locf.debt_to_ebitda_financial, item.locf.debt_to_ebitda_current === null ? "0.0" : item.locf.debt_to_ebitda_current === "" ? "0.0" : item.locf.debt_to_ebitda_current, item.locf.ebitda_to_interest_financial, item.locf.ebitda_to_interest_current === null ? "0.0" : item.locf.ebitda_to_interest_current === "" ? "0.0" : item.locf.ebitda_to_interest_current, item.locf.other_ratio1_ratio_name, item.locf.other_ratio1_financial, item.locf.other_ratio1_current === null ? "0.0" : item.locf.other_ratio1_current === "" ? "0.0" : item.locf.other_ratio1_current, item.locf.other_ratio2_ratio_name, item.locf.other_ratio2_financial, item.locf.other_ratio2_current === null ? "0.0" : item.locf.other_ratio2_current === "" ? "0.0" : item.locf.other_ratio2_current, item.locf.other_ratio3_ratio_name, item.locf.other_ratio3_financial, item.locf.other_ratio3_current === null ? "0.0" : item.locf.other_ratio3_current === "" ? "0.0" : item.locf.other_ratio3_current, item.locf.other_ratio4_ratio_name, item.locf.other_ratio4_financial, item.locf.other_ratio4_current === null ? "0.0" : item.locf.other_ratio4_current === "" ? "0.0" : item.locf.other_ratio4_current, item.locf.notes, // item.per_bs === null ? "0.0" : item.locf.per_bs === "" ? "0.0" : item.locf.per_bs, // item.diff === null ? "0.0" : item.locf.diff === "" ? "0.0" : item.locf.diff, index ], [9, "", "", "", "", "", { value: "Grand Total" }, null, "", "", "", "0", "", "0", "", "0", "", "0", "", "", "0", "0", "0", "0", "0", "", "0", "", "0", "", "0", "", "0", "", "", "", "", "", "", "", "", "", "", "", "", "notes", 999999], ) } else { dataTable.push([ item.type_report_id, item.id, item.parent, item.formula, item.level, // item.description, item.locf.borrower_comp_name === null || item.locf.borrower_comp_name === "" ? this.props.company.company_name : item.locf.borrower_comp_name, item.locf.bank_name === null ? null : item.locf.bank_name === "" ? null : { value: item.locf.bank_name }, item.locf.type_of_credit === null ? null : item.locf.type_of_credit === "" ? null : { value: item.locf.type_of_credit }, item.locf.remarks === null || item.locf.remarks === "" ? "" : item.locf.remarks, item.locf.loan_maturity_date == null || item.locf.loan_maturity_date == "" ? null : (item.locf.loan_maturity_date !== "null" ? String(tgl[2]).length > 2 ? tgl[2] + '-' + tgl[1] + '-' + tgl[0] : String(item.locf.loan_maturity_date) : null), item.locf.interest === null || item.locf.interest === "" ? "0.00" : item.locf.interest, item.locf.currency === null || item.locf.currency === "" ? "" : item.locf.currency, item.locf.loan_plafond_amount_ori, item.locf.loan_plafond_amount_idr === null ? "0.0" : item.locf.loan_plafond_amount_idr === "" ? "0.0" : item.locf.loan_plafond_amount_idr, item.locf.out_loan_ki_amount_ori, item.locf.out_loan_ki_amount_idr === null ? "0.0" : item.locf.out_loan_ki_amount_idr === "" ? "0.0" : item.locf.out_loan_ki_amount_idr, item.locf.out_loan_kmk_amount_ori, item.locf.out_loan_kmk_amount_idr === null ? "0.0" : item.locf.out_loan_kmk_amount_idr === "" ? "0.0" : item.locf.out_loan_kmk_amount_idr, // item.locf.mtd_vs_previous_month === null ? "0.0" : item.locf.mtd_vs_previous_month === "" ? "0.0" : item.locf.mtd_vs_previous_month, item.locf.out_loan_other_type, item.locf.out_loan_other_amount_ori, item.locf.out_loan_other_amount_idr === null ? "0.0" : item.locf.out_loan_other_amount_idr === "" ? "0.0" : item.locf.out_loan_other_amount_idr, item.locf.total_out_loan_ori === null ? "0.0" : item.locf.total_out_loan_ori === "" ? "0.0" : item.locf.total_out_loan_ori, item.locf.total_out_loan_idr === null ? "0.0" : item.locf.total_out_loan_idr === "" ? "0.0" : item.locf.total_out_loan_idr, item.locf.remaining_plafond_ori === null ? "0.0" : item.locf.remaining_plafond_ori === "" ? "0.0" : item.locf.remaining_plafond_ori, item.locf.remaining_plafond_idr === null ? "0.0" : item.locf.remaining_plafond_idr === "" ? "0.0" : item.locf.remaining_plafond_idr, item.locf.current_ratio_financial, item.locf.current_ratio_current === null ? "0.0" : item.locf.current_ratio_current === "" ? "0.0" : item.locf.current_ratio_current, item.locf.der_financial, item.locf.der_current === null ? "0.0" : item.locf.der_current === "" ? "0.0" : item.locf.der_current, item.locf.debt_to_ebitda_financial, item.locf.debt_to_ebitda_current === null ? "0.0" : item.locf.debt_to_ebitda_current === "" ? "0.0" : item.locf.debt_to_ebitda_current, item.locf.ebitda_to_interest_financial, item.locf.ebitda_to_interest_current === null ? "0.0" : item.locf.ebitda_to_interest_current === "" ? "0.0" : item.locf.ebitda_to_interest_current, item.locf.other_ratio1_ratio_name, item.locf.other_ratio1_financial, item.locf.other_ratio1_current === null ? "0.0" : item.locf.other_ratio1_current === "" ? "0.0" : item.locf.other_ratio1_current, item.locf.other_ratio2_ratio_name, item.locf.other_ratio2_financial, item.locf.other_ratio2_current === null ? "0.0" : item.locf.other_ratio2_current === "" ? "0.0" : item.locf.other_ratio2_current, item.locf.other_ratio3_ratio_name, item.locf.other_ratio3_financial, item.locf.other_ratio3_current === null ? "0.0" : item.locf.other_ratio3_current === "" ? "0.0" : item.locf.other_ratio3_current, item.locf.other_ratio4_ratio_name, item.locf.other_ratio4_financial, item.locf.other_ratio4_current === null ? "0.0" : item.locf.other_ratio4_current === "" ? "0.0" : item.locf.other_ratio4_current, item.locf.notes, index // item.per_bs === null ? "0.0" : item.locf.per_bs === "" ? "0.0" : item.locf.per_bs, // item.diff === null ? "0.0" : item.locf.diff === "" ? "0.0" : item.locf.diff, ]) } // if (item.children !== null) { // if (item.children.length > 0) { // item.children.map((items, indexs) => { // handlePushChild(items) // }) // } // } }) // console.log(dataTable); if (dataTable.length == 0 && this.state.get_for == 'edit') { dataTable.push( [3, "", "", "", "", this.props.company.company_name, null, null, "", null, "0.00", "", "", "0", "", "0", "", "0", "", "", "0", "0", "0", "0", "0", "", "0", "", "0", "", "0", "", "0", "", "", "", "", "", "", "", "", "", "", "", "", "", 0], [9, "", "", "", "", "", { value: "Grand Total" }, null, "", "", "", "0", "", "0", "", "0", "", "0", "", "", "0", "0", "0", "0", "0", "", "0", "", "0", "", "0", "", "0", "", "", "", "", "", "", "", "", "", "", "", "", "notes", 999999], ) } console.log(dataTable) this.setState({ dataTable, loading: false, visibleLOCFMR: true }, () => { this.handleCalculate() }) } }) } getLatestUpdate() { let payload = { "report_id": this.props.report_id, "revision": Number(this.props.revision), "periode": this.props.periode, "company_id": this.props.company.company_id, "monthly_report_id": this.props.monthlyReportId, "months": this.props.month.month_id } // console.log(payload) api.create().getLastestUpdateMR(payload).then(response => { console.log(JSON.stringify(response)) if (response.data) { if (response.data.status === "success") { this.setState({ updateBy: response.data.data.detail === null ? [] : response.data.data.detail, notes: response.data.data.notes_update === null ? "" : response.data.data.notes_update }) } else { this.setState({ alert: true, messageAlert: response.data.message, typeAlert: 'warning', loading: false }, () => { if (response.data.message.includes("Someone Logged In") || response.data.message.includes("Token Expired")) { setTimeout(() => { localStorage.removeItem(Constant.TOKEN) window.location.reload(); }, 1000); } }) } } else { // console.log('brrrrrrrr') this.setState({ alert: true, messageAlert: response.problem, tipeAlert: 'error', loading: false }) } }) } fileHandler = (event) => { let fileObj = event ExcelRenderer(fileObj, (err, resp) => { // console.log(resp) if (err) { console.log(err); } else { let isi = resp.rows.slice(3) console.log(isi); let payload = [] let reg = /^[-+]?(?:[0-9]+,)*[0-9]+(?:\.[0-9]+)?$/; isi.map((i, index) => { if (i.length > 0) { let tgl = String(i[5]).split('-') console.log(i[5]) console.log(tgl) payload.push({ "item_report_id": i[1], "borrower_comp_name": this.props.company.company_name, "bank_name": i[2], "type_of_credit": i[3], "remarks": i[4], "loan_maturity_date": i[5] !== undefined ? tgl[2] + '-' + tgl[1] + '-' + tgl[0] : null, "interest": i[6], "currency": i[7], "loan_plafond_amount_ori": i[8] !== undefined ? Number(i[8]) : i[8], "loan_plafond_amount_idr": i[9] !== undefined ? Number(i[9]) : i[9], "out_loan_ki_amount_ori": i[10] !== undefined ? Number(i[10]) : i[10], "out_loan_ki_amount_idr": i[11] !== undefined ? Number(i[11]) : i[11], "out_loan_kmk_amount_ori": i[12] !== undefined ? Number(i[12]) : i[12], "out_loan_kmk_amount_idr": i[13] !== undefined ? Number(i[13]) : i[13], "out_loan_other_type": i[14], "out_loan_other_amount_ori": i[15] !== undefined ? Number(i[15]) : i[15], "out_loan_other_amount_idr": i[16] !== undefined ? Number(i[16]) : i[16], // "total_out_loan_ori": i[18], // "total_out_loan_idr": i[19], // "remaining_plafond_ori": i[20], // "remaining_plafond_idr": i[21], "current_ratio_financial": i[17], "der_financial": i[18], "debt_to_ebitda_financial": i[19], "ebitda_to_interest_financial": i[20], "other_ratio1_ratio_name": i[21], "other_ratio1_financial": i[22], "other_ratio1_current": i[23], "other_ratio2_ratio_name": i[24], "other_ratio2_financial": i[25], "other_ratio2_current": i[26], "other_ratio3_ratio_name": i[27], "other_ratio3_financial": i[28], "other_ratio3_current": i[29], "other_ratio4_ratio_name": i[30], "other_ratio4_financial": i[31], "other_ratio4_current": i[32], "notes": i[33], }) } }) let body = { "monthly_report_id": this.props.monthlyReportId, "company_id": this.props.company.company_id, "periode": this.props.periode, "report_id": this.props.report_id, "status": 'submitted', "months": this.props.month.month_id, "locf": payload, "per_bs": this.state.perBS, "diff": this.state.diff, "total_loan": this.state.perBS } console.log(body) this.setState({ payload: body, judul: resp.rows[1][0], judulColumn: resp.rows[0][0] }) } }); } deleteReport() { let payload = { "item_report_id": this.state.dataDelete, "periode": this.props.periode, "months": this.props.month.month_id } if (this.state.dataDelete.length > 0) { api.create().deleteAllItemReportLOCF(payload).then((response) => { console.log(response) }) } } checkUpload() { let payload = { ...this.state.payload, currency_id: this.state.defaultCurrencyUpload?.id } let dataDelete = [] api.create().getIdDeleteFromExcelLOCF(payload).then((response) => { console.log(response) // if (response.data) { // // // // // // console.log(response.data) // let idDelete = response.data.data.item_report_id // if (idDelete.length > 0) { // idDelete.map((item, index) => { // dataDelete.push(item) // }) // this.setState({ dataDelete }) // } // } }) api.create().checkUploadMonthlyReportLOCF(payload).then(response => { // console.log(JSON.stringify(this.state.payload)); console.log(response) if (response.data) { if (response.data.status === 'success') { this.setState({ visibleUpload: false, loading: true, visibleLOCFMR: false, totalOutStand: 0, diff: 0 }) let dataTable = [] response.data.data.map((item, index) => { if (index == response.data.data.length - 1) { dataTable.push([ 3, item.item_report_id, item.parent, item.formula, item.level, item.borrower_comp_name === null ? this.props.company.company_name : item.borrower_comp_name === "" ? this.props.company.company_name : item.borrower_comp_name, item.bank_name === null ? null : item.bank_name === "" ? null : { value: item.bank_name }, item.type_of_credit === null ? null : item.type_of_credit === "" ? null : { value: item.type_of_credit }, item.remarks === null ? "" : item.remarks === "" ? "" : item.remarks, item.loan_maturity_date === null || item.loan_maturity_date === "" ? null : item.loan_maturity_date, item.interest === null || item.interest === "" ? "0.00" : item.interest, item.currency === null || item.currency === "" ? "" : item.currency, item.loan_plafond_amount_ori == null ? "" : item.loan_plafond_amount_ori, item.loan_plafond_amount_idr === null ? "0.0" : item.loan_plafond_amount_idr === "" ? "0.0" : item.loan_plafond_amount_idr, item.type_of_credit == "Investment Loan" ? item.out_loan_ki_amount_ori : "0.0", item.type_of_credit == "Investment Loan" ? (item.out_loan_ki_amount_idr === null ? "0.0" : item.out_loan_ki_amount_idr === "" ? "0.0" : item.out_loan_ki_amount_idr) : "0.0", item.type_of_credit == "Revolving Loan (KMK)" ? item.out_loan_kmk_amount_ori : "0.0", item.type_of_credit == "Revolving Loan (KMK)" ? (item.out_loan_kmk_amount_idr === null ? "0.0" : item.out_loan_kmk_amount_idr === "" ? "0.0" : item.out_loan_kmk_amount_idr) : "0.0", item.type_of_credit == "Others" ? item.out_loan_other_type : "", item.type_of_credit == "Others" ? item.out_loan_other_amount_ori : "0.0", item.type_of_credit == "Others" ? (item.out_loan_other_amount_idr === null ? "0.0" : item.out_loan_other_amount_idr === "" ? "0.0" : item.out_loan_other_amount_idr) : "0.0", item.total_out_loan_ori === null ? "0.0" : item.total_out_loan_ori === "" ? "0.0" : item.total_out_loan_ori === 0 ? "0.0" : item.total_out_loan_ori, item.total_out_loan_idr === null ? "0.0" : item.total_out_loan_idr === "" ? "0.0" : item.total_out_loan_idr, item.remaining_plafond_ori === null ? "0.0" : item.remaining_plafond_ori === "" ? "0.0" : item.remaining_plafond_ori, item.remaining_plafond_idr === null ? "0.0" : item.remaining_plafond_idr === "" ? "0.0" : item.remaining_plafond_idr, item.current_ratio_financial == null ? "" : item.current_ratio_financial, item.current_ratio_current === null ? "0.0" : item.current_ratio_current === "" ? "0.0" : item.current_ratio_current, item.der_financial == null ? "" : item.der_financial, item.der_current === null ? "0.0" : item.der_current === "" ? "0.0" : item.der_current, item.debt_to_ebitda_financial == null ? "" : item.debt_to_ebitda_financial, item.debt_to_ebitda_current === null ? "0.0" : item.debt_to_ebitda_current === "" ? "0.0" : item.debt_to_ebitda_current, item.ebitda_to_interest_financial == null ? "" : item.ebitda_to_interest_financial, item.ebitda_to_interest_current === null ? "0.0" : item.ebitda_to_interest_current === "" ? "0.0" : item.ebitda_to_interest_current, item.other_ratio1_ratio_name == null ? "" : item.other_ratio1_ratio_name, item.other_ratio1_financial === null ? "0.0" : item.other_ratio1_financial === "" ? "0.0" : item.other_ratio1_financial, item.other_ratio1_current === null ? "0.0" : item.other_ratio1_current === "" ? "0.0" : item.other_ratio1_current, item.other_ratio2_ratio_name == null ? "" : item.other_ratio2_ratio_name, item.other_ratio2_financial === null ? "0.0" : item.other_ratio2_financial === "" ? "0.0" : item.other_ratio2_financial, item.other_ratio2_current === null ? "0.0" : item.other_ratio2_current === "" ? "0.0" : item.other_ratio2_current, item.other_ratio3_ratio_name == null ? "" : item.other_ratio3_ratio_name, item.other_ratio3_financial === null ? "0.0" : item.other_ratio3_financial === "" ? "0.0" : item.other_ratio3_financial, item.other_ratio3_current === null ? "0.0" : item.other_ratio3_current === "" ? "0.0" : item.other_ratio3_current, item.other_ratio4_ratio_name == null ? "" : item.other_ratio4_ratio_name, item.other_ratio4_financial === null ? "0.0" : item.other_ratio4_financial === "" ? "0.0" : item.other_ratio4_financial, item.other_ratio4_current === null ? "0.0" : item.other_ratio4_current === "" ? "0.0" : item.other_ratio4_current, item.notes, ], [9, "", "", "", "", "", { value: "Grand Total" }, null, "", "", "", "0", "", "0", "", "0", "", "0", "", "", "0", "0", "0", "0", "0", "", "0", "", "0", "", "0", "", "0", "", "", "", "", "", "", "", "", "", "", "", "", "notes", 999999], ) } else { dataTable.push([ 3, item.item_report_id, item.parent, item.formula, item.level, item.borrower_comp_name === null ? this.props.company.company_name : item.borrower_comp_name === "" ? this.props.company.company_name : item.borrower_comp_name, item.bank_name === null ? null : item.bank_name === "" ? null : { value: item.bank_name }, item.type_of_credit === null ? null : item.type_of_credit === "" ? null : { value: item.type_of_credit }, item.remarks === null ? "" : item.remarks === "" ? "" : item.remarks, item.loan_maturity_date === null || item.loan_maturity_date === "" ? null : item.loan_maturity_date, item.interest === null || item.interest === "" ? "0.00" : item.interest, item.currency === null || item.currency === "" ? "" : item.currency, item.loan_plafond_amount_ori == null ? "" : item.loan_plafond_amount_ori, item.loan_plafond_amount_idr === null ? "0.0" : item.loan_plafond_amount_idr === "" ? "0.0" : item.loan_plafond_amount_idr, item.type_of_credit == "Investment Loan" ? item.out_loan_ki_amount_ori : "0.0", item.type_of_credit == "Investment Loan" ? (item.out_loan_ki_amount_idr === null ? "0.0" : item.out_loan_ki_amount_idr === "" ? "0.0" : item.out_loan_ki_amount_idr) : "0.0", item.type_of_credit == "Revolving Loan (KMK)" ? item.out_loan_kmk_amount_ori : "0.0", item.type_of_credit == "Revolving Loan (KMK)" ? (item.out_loan_kmk_amount_idr === null ? "0.0" : item.out_loan_kmk_amount_idr === "" ? "0.0" : item.out_loan_kmk_amount_idr) : "0.0", item.type_of_credit == "Others" ? item.out_loan_other_type : "", item.type_of_credit == "Others" ? item.out_loan_other_amount_ori : "0.0", item.type_of_credit == "Others" ? (item.out_loan_other_amount_idr === null ? "0.0" : item.out_loan_other_amount_idr === "" ? "0.0" : item.out_loan_other_amount_idr) : "0.0", item.total_out_loan_ori === null ? "0.0" : item.total_out_loan_ori === "" ? "0.0" : item.total_out_loan_ori, item.total_out_loan_idr === null ? "0.0" : item.total_out_loan_idr === "" ? "0.0" : item.total_out_loan_idr, item.remaining_plafond_ori === null ? "0.0" : item.remaining_plafond_ori === "" ? "0.0" : item.remaining_plafond_ori, item.remaining_plafond_idr === null ? "0.0" : item.remaining_plafond_idr === "" ? "0.0" : item.remaining_plafond_idr, item.current_ratio_financial == null ? "" : item.current_ratio_financial, item.current_ratio_current === null ? "0.0" : item.current_ratio_current === "" ? "0.0" : item.current_ratio_current, item.der_financial == null ? "" : item.der_financial, item.der_current === null ? "0.0" : item.der_current === "" ? "0.0" : item.der_current, item.debt_to_ebitda_financial == null ? "" : item.debt_to_ebitda_financial, item.debt_to_ebitda_current === null ? "0.0" : item.debt_to_ebitda_current === "" ? "0.0" : item.debt_to_ebitda_current, item.ebitda_to_interest_financial == null ? "" : item.ebitda_to_interest_financial, item.ebitda_to_interest_current === null ? "0.0" : item.ebitda_to_interest_current === "" ? "0.0" : item.ebitda_to_interest_current, item.other_ratio1_ratio_name == null ? "" : item.other_ratio1_ratio_name, item.other_ratio1_financial === null ? "0.0" : item.other_ratio1_financial === "" ? "0.0" : item.other_ratio1_financial, item.other_ratio1_current === null ? "0.0" : item.other_ratio1_current === "" ? "0.0" : item.other_ratio1_current, item.other_ratio2_ratio_name == null ? "" : item.other_ratio2_ratio_name, item.other_ratio2_financial === null ? "0.0" : item.other_ratio2_financial === "" ? "0.0" : item.other_ratio2_financial, item.other_ratio2_current === null ? "0.0" : item.other_ratio2_current === "" ? "0.0" : item.other_ratio2_current, item.other_ratio3_ratio_name == null ? "" : item.other_ratio3_ratio_name, item.other_ratio3_financial === null ? "0.0" : item.other_ratio3_financial === "" ? "0.0" : item.other_ratio3_financial, item.other_ratio3_current === null ? "0.0" : item.other_ratio3_current === "" ? "0.0" : item.other_ratio3_current, item.other_ratio4_ratio_name == null ? "" : item.other_ratio4_ratio_name, item.other_ratio4_financial === null ? "0.0" : item.other_ratio4_financial === "" ? "0.0" : item.other_ratio4_financial, item.other_ratio4_current === null ? "0.0" : item.other_ratio4_current === "" ? "0.0" : item.other_ratio4_current, item.notes, ]) } // if (item.children !== null) { // if (item.children.length > 0) { // item.children.map((items, indexs) => { // handlePushChild(items) // }) // } // } }) console.log(dataTable); if (dataTable.length == 0) { dataTable.push( [3, "", "", "", "", this.props.company.company_name, null, null, "", null, "0.00", "", "", "0", "", "0", "", "0", "", "", "0", "0", "0", "0", "0", "", "0", "", "0", "", "0", "", "0", "", "", "", "", "", "", "", "", "", "", "", "", "", 0], [9, "", "", "", "", "", { value: "Grand Total" }, null, "", "", "", "0", "", "0", "", "0", "", "0", "", "", "0", "0", "0", "0", "0", "", "0", "", "0", "", "0", "", "0", "", "", "", "", "", "", "", "", "", "", "", "", "notes", 999999], ) } this.setState({ dataTable, dataLoaded: true, loading: false, buttonError: false, dataDelete: [] }, () => { this.handleCalculate() this.state.dataTable.map(item => { if (item[23].length > 0) { // console.log('masuk') this.setState({ buttonError: true, errorPreview: true }) } }) // console.log(this.state.buttonError) }) // console.log(dataTable); } } }) } uploadLOCF(type) { let data = [] let error = false this.deleteReport() this.state.dataTable.map(i => { if (i[0] == 3) { if (i[6] == null || i[7] == null || i[8] == "" || i[9] == "" || i[10] == "" || i[11] == "") { error = true } if (i[7].value == 'Others' && i[18] == '') { error = true } let tgl = String(i[9]).split('-') let checkUndifined = tgl.findIndex((val) => val == undefined) if (this.props.defaultCurrency.id == 2) { data.push({ "item_report_id": i[1], "borrower_comp_name": i[5], "bank_name": i[6] == null ? [6] : i[6].value, "type_of_credit": i[7] == null ? i[7] : i[7].value, "remarks": i[8], // "loan_maturity_date": i[9], "loan_maturity_date": i[9] == undefined || i[9] == "null" || i[9] == null ? "" : (String(tgl[2]).length <= 2 ? tgl[2] + '-' + tgl[1] + '-' + tgl[0] : String(i[9])), // "loan_maturity_date": i[9] !== undefined || i[9] !== "null" || i[9] !== null? (String(tgl[2]).length <= 2? tgl[2] + '-' + tgl[1] + '-' + tgl[0] : String(i[9])) : "", "interest": i[10] == "" ? "0.00" : i[10], "currency": i[11], "loan_plafond_amount_ori": Number(i[12]) == "" ? "0.0" : Number(i[12]), "loan_plafond_amount_idr": Number(i[13]) == "" ? "0.0" : Number(i[13]), "out_loan_ki_amount_ori": Number(i[14]) == "" ? "0.0" : Number(i[14]), "out_loan_ki_amount_idr": Number(i[15]) == "" ? "0.0" : Number(i[15]), "out_loan_kmk_amount_ori": Number(i[16]) == "" ? "0.0" : Number(i[16]), "out_loan_kmk_amount_idr": Number(i[17]) == "" ? "0.0" : Number(i[17]), // "mtd_vs_previous_month": i[18], "out_loan_other_type": i[18], "out_loan_other_amount_ori": Number(i[19]) == "" ? "0.0" : Number(i[19]), "out_loan_other_amount_idr": Number(i[20]) == "" ? "0.0" : Number(i[20]), "total_out_loan_ori": Number(i[21]) == "" ? "0.0" : Number(i[21]), "total_out_loan_idr": Number(i[22]) == "" ? "0.0" : Number(i[22]), "remaining_plafond_ori": Number(i[23]) == "" ? "0.0" : Number(i[23]), "remaining_plafond_idr": Number(i[24]) == "" ? "0.0" : Number(i[24]), "current_ratio_financial": Number(i[25]) == "" ? "0.00" : Number(i[25]), "current_ratio_current": Number(i[26]) == "" ? "0.00" : Number(i[26]), "der_financial": Number(i[27]) == "" ? "0.00" : Number(i[27]), "der_current": Number(i[28]) == "" ? "0.00" : Number(i[28]), "debt_to_ebitda_financial": Number(i[29]) == "" ? "0.00" : Number(i[29]), "debt_to_ebitda_current": Number(i[30]) == "" ? "0.00" : Number(i[30]), "ebitda_to_interest_financial": Number(i[31]) == "" ? "0.00" : Number(i[31]), "ebitda_to_interest_current": Number(i[32]) == "" ? "0.00" : Number(i[32]), "other_ratio1_ratio_name": i[33], "other_ratio1_financial": Number(i[34]) == "" ? "0.00" : Number(i[34]), "other_ratio1_current": Number(i[35]) == "" ? "0.00" : Number(i[35]), "other_ratio2_ratio_name": i[36], "other_ratio2_financial": Number(i[37]) == "" ? "0.00" : Number(i[37]), "other_ratio2_current": Number(i[38]) == "" ? "0.00" : Number(i[38]), "other_ratio3_ratio_name": i[39], "other_ratio3_financial": Number(i[40]) == "" ? "0.00" : Number(i[40]), "other_ratio3_current": Number(i[41]) == "" ? "0.00" : Number(i[41]), "other_ratio4_ratio_name": i[42], "other_ratio4_financial": Number(i[43]) == "" ? "0.00" : Number(i[43]), "other_ratio4_current": Number(i[44]) == "" ? "0.00" : Number(i[44]), "notes": i[45], }) } else { data.push({ "item_report_id": i[1], "borrower_comp_name": i[5], "bank_name": i[6] == null ? [6] : i[6].value, "type_of_credit": i[7] == null ? i[7] : i[7].value, "remarks": i[8], // "loan_maturity_date": i[9], "loan_maturity_date": i[9] == undefined || i[9] == "null" || i[9] == null ? "" : (String(tgl[2]).length <= 2 ? tgl[2] + '-' + tgl[1] + '-' + tgl[0] : String(i[9])), // "loan_maturity_date": i[9] !== undefined || i[9] !== "null" || i[9] !== null? (String(tgl[2]).length <= 2? tgl[2] + '-' + tgl[1] + '-' + tgl[0] : String(i[9])) : "", "interest": i[10] == "" ? "0.00" : i[10], "currency": i[11], "loan_plafond_amount_ori": fixNumber(Number(i[12]), 1) == "" ? "0.0" : fixNumber(Number(i[12]), 1), "loan_plafond_amount_idr": fixNumber(Number(i[13]), 1) == "" ? "0.0" : fixNumber(Number(i[13]), 1), "out_loan_ki_amount_ori": fixNumber(Number(i[14]), 1) == "" ? "0.0" : fixNumber(Number(i[14]), 1), "out_loan_ki_amount_idr": fixNumber(Number(i[15]), 1) == "" ? "0.0" : fixNumber(Number(i[15]), 1), "out_loan_kmk_amount_ori": fixNumber(Number(i[16]), 1) == "" ? "0.0" : fixNumber(Number(i[16]), 1), "out_loan_kmk_amount_idr": fixNumber(Number(i[17]), 1) == "" ? "0.0" : fixNumber(Number(i[17]), 1), // "mtd_vs_previous_month": i[18], "out_loan_other_type": i[18], "out_loan_other_amount_ori": fixNumber(Number(i[19]), 1) == "" ? "0.0" : fixNumber(Number(i[19]), 1), "out_loan_other_amount_idr": fixNumber(Number(i[20]), 1) == "" ? "0.0" : fixNumber(Number(i[20]), 1), "total_out_loan_ori": fixNumber(Number(i[21]), 1) == "" ? "0.0" : fixNumber(Number(i[21]), 1), "total_out_loan_idr": fixNumber(Number(i[22]), 1) == "" ? "0.0" : fixNumber(Number(i[22]), 1), "remaining_plafond_ori": fixNumber(Number(i[23]), 1) == "" ? "0.0" : fixNumber(Number(i[23]), 1), "remaining_plafond_idr": fixNumber(Number(i[24]), 1) == "" ? "0.0" : fixNumber(Number(i[24]), 1), "current_ratio_financial": fixNumber(Number(i[25]), 2) == "" ? "0.00" : fixNumber(Number(i[25]), 2), "current_ratio_current": fixNumber(Number(i[26]), 2) == "" ? "0.00" : fixNumber(Number(i[26]), 2), "der_financial": fixNumber(Number(i[27]), 2) == "" ? "0.00" : fixNumber(Number(i[27]), 2), "der_current": fixNumber(Number(i[28]), 2) == "" ? "0.00" : fixNumber(Number(i[28]), 2), "debt_to_ebitda_financial": fixNumber(Number(i[29]), 2) == "" ? "0.00" : fixNumber(Number(i[29]), 2), "debt_to_ebitda_current": fixNumber(Number(i[30]), 2) == "" ? "0.00" : fixNumber(Number(i[30]), 2), "ebitda_to_interest_financial": fixNumber(Number(i[31]), 2) == "" ? "0.00" : fixNumber(Number(i[31]), 2), "ebitda_to_interest_current": fixNumber(Number(i[32]), 2) == "" ? "0.00" : fixNumber(Number(i[32]), 2), "other_ratio1_ratio_name": i[33], "other_ratio1_financial": fixNumber(Number(i[34]), 2) == "" ? "0.00" : fixNumber(Number(i[34]), 2), "other_ratio1_current": fixNumber(Number(i[35]), 2) == "" ? "0.00" : fixNumber(Number(i[35]), 2), "other_ratio2_ratio_name": i[36], "other_ratio2_financial": fixNumber(Number(i[37]), 2) == "" ? "0.00" : fixNumber(Number(i[37]), 2), "other_ratio2_current": fixNumber(Number(i[38]), 2) == "" ? "0.00" : fixNumber(Number(i[38]), 2), "other_ratio3_ratio_name": i[39], "other_ratio3_financial": fixNumber(Number(i[40]), 2) == "" ? "0.00" : fixNumber(Number(i[40]), 2), "other_ratio3_current": fixNumber(Number(i[41]), 2) == "" ? "0.00" : fixNumber(Number(i[41]), 2), "other_ratio4_ratio_name": i[42], "other_ratio4_financial": fixNumber(Number(i[43]), 2) == "" ? "0.00" : fixNumber(Number(i[43]), 2), "other_ratio4_current": fixNumber(Number(i[44]), 2) == "" ? "0.00" : fixNumber(Number(i[44]), 2), "notes": i[45], }) } } }) let body = { "monthly_report_id": this.props.monthlyReportId, "company_id": this.props.company.company_id, "periode": this.props.periode, "report_id": this.props.report_id, "status": type, "months": this.props.month.month_id, "currency_id": this.props.defaultCurrency.id, "locf": data, "per_bs": this.state.perBS, "diff": this.state.diff, "total_loan": this.state.perBS } console.log(JSON.stringify(body)); if (error && type == 'submitted') { this.setState({ handleDoubleClick: 0, saveDraft: false, saveComp: true, loading: false, snekbar: true, snekbarMsg: 'Data Incomplete', handleDoubleClick: 0 }) } else { api.create('UPLOAD').uploadMonthlyReportLOCF(body).then(response => { console.log(response); if (response.data) { if (response.ok) { if (response.data.status === "success") { this.props.saveToMonthlyReport('LOCF') // this.props.onClickClose() // this.props.getReport() } else { this.setState({ visibleAlertSave: true, alert: true, messageAlert: response.data.message, tipeAlert: 'warning', loading: false }, () => { if (response.data.message.includes("Someone Logged In") || response.data.message.includes("Token Expired")) { setTimeout(() => { localStorage.removeItem(Constant.TOKEN) window.location.reload(); }, 1000); } }) // alert(response.data.status) } } else { this.setState({ alert: true, messageAlert: response.data.message, tipeAlert: 'error', loading: false, handleDoubleClick: 0 }) } } else { this.setState({ alert: true, messageAlert: response.problem, tipeAlert: 'error', loading: false, handleDoubleClick: 0 }) } this.setState({ handleDoubleClick: 0 }) }) } } getBankData() { let body = { group: 'BANK', company_id: this.props.company.company_id, type: 'BANK_NAME' } this.setState({ dataLoaded: false }) api.create().getAllSettingByType(body).then(response => { console.log(response) if (response.data) { if (response.ok) { if (response.data.status === 'success') { let data = response.data.data // // // console.log(data) let inputBank = [] data.map((item) => { inputBank.push({ value: `${item.value}` }) }) let defaultProps = { options: inputBank, getOptionLabel: (option) => titleCase(option.value), }; // // // console.log(defaultProps) this.setState({ bankNameList: defaultProps }) } else { this.setState({ alert: true, messageAlert: response.data.message, tipeAlert: 'warning' }, () => { if (response.data.message.includes("Someone Logged In") || response.data.message.includes("Token Expired")) { setTimeout(() => { localStorage.removeItem(Constant.TOKEN) window.location.reload(); }, 1000); } }) } } else { this.setState({ alert: true, messageAlert: response.data.message, tipeAlert: 'error' }) } } else { this.setState({ alert: true, messageAlert: response.problem, tipeAlert: 'error' }) } }) } getTypeOfCredit() { let body = { group: 'BANK', company_id: this.props.company.company_id, type: 'TYPE_OF_CREDIT' } api.create().getAllSettingByType(body).then(response => { console.log(response) if (response.data) { if (response.ok) { if (response.data.status === 'success') { let data = response.data.data // // // console.log(data) let inputTypeOfCredit = [] data.map((item) => { inputTypeOfCredit.push({ value: item.value }) }) let defaultProps = { options: inputTypeOfCredit, getOptionLabel: (option) => titleCase(option.value), }; // // // console.log(defaultProps) this.setState({ typeOfCreditList: defaultProps }) } else { this.setState({ alert: true, messageAlert: response.data.message, tipeAlert: 'warning' }, () => { if (response.data.message.includes("Someone Logged In") || response.data.message.includes("Token Expired")) { setTimeout(() => { localStorage.removeItem(Constant.TOKEN) window.location.reload(); }, 1000); } }) } } else { this.setState({ alert: true, messageAlert: response.data.message, tipeAlert: 'error' }) } } else { this.setState({ alert: true, messageAlert: response.problem, tipeAlert: 'error' }) } }) } downloadTemplate = async () => { let res = await fetch( `${process.env.REACT_APP_URL_MAIN_BE}/public/transaction/locf/monthly_report/download_template?report_id=${this.props.report_id}&&company_id=${this.props.company.company_id}&&year=${this.props.periode}&&months=${this.props.month.month_id}&¤cy_id=${this.props.defaultCurrency.id}` ) res = await res.blob() // console.log(this.props.report_id) // console.log(this.props.company.company_id) // console.log(this.props.periode) // console.log(this.props.month.month_id) if (res.size > 0) { let url = window.URL.createObjectURL(res); let a = document.createElement('a'); a.href = url; a.download = 'Template Monthly Report List of Credit Facilities.xlsx'; a.click(); } } async downloadAllData() { let url = `${process.env.REACT_APP_URL_MAIN_BE}/public/transaction/locf/monthly_report/export_monthly_report?monthly_report_id=&&report_id=${this.props.report_id}&&company_id=${this.props.company.company_id}&&year=${this.props.periode}&&revision=${this.props.revision}&&months=${this.props.month.month_id}` let urls = `${process.env.REACT_APP_URL_MAIN_BE}/public/transaction/locf/monthly_report/export_monthly_report?monthly_report_id=${this.props.monthlyReportId}&&report_id=${this.props.report_id}&&company_id=${this.props.company.company_id}&&year=${this.props.periode}&&revision=${this.props.revision}&&months=${this.props.month.month_id}` // console.log(url); // console.log(urls); let res = await fetch( this.props.monthlyReportId == null ? url : urls ) res = await res.blob() this.setState({ loading: false }) if (res.size > 0) { let url = window.URL.createObjectURL(res); let a = document.createElement('a'); a.href = url; a.download = 'Monthly Report List of Credit Facilities.xlsx'; a.click(); } } getSubmission() { this.setState({ loading: true }) let payload = { "company_id": this.props.company.company_id, "periode": this.props.periode, "is_approver": true } api.create().getSubmission(payload).then(response => { // console.log(response) if (response.data) { if (response.data.status === "success") { this.setState({ submissionID: response.data.data.submission_id, lastRevision: response.data.data.last_revision, }, () => { this.getDataRatio() }) } else { this.setState({ submissionID: null, loading: false }) } } }) } getPerBS() { let payload = { "report_id": this.props.report_id, "revision": Number(this.props.revision), "periode": this.props.periode, "company_id": this.props.company.company_id, "monthly_report_id": this.props.monthlyReportId, "months": this.props.month.month_id, "currency_id": this.props.defaultCurrency.id, } api.create().getPerBSiMontlyReportLOCF(payload).then((response) => { console.log(response) // if (this.state.get_for == 'view') { // this.setState({perBS: "0.0"}) // } else { if (response.data.status == "success") { this.setState({ perBS: this.props.defaultCurrency.id == 1 ? (response.data.data.per_bs == null || response.data.data.per_bs == '' ? fixNumber(Number(0), 1) : fixNumber(Number(response.data.data.per_bs), 1)) : (response.data.data.per_bs == null || response.data.data.per_bs == '' ? Number(0) : Number(response.data.data.per_bs)), totalOutStand: response.data.data.total_loan, diff: response.data.data.diff }) } // } }) } getDataRatio() { let payload = { "report": 'ratio', "monthlyReportId": this.props.monthlyReportId, "periode": this.props.periode, "companyId": this.props.company.company_id, "months": this.props.month.month_id, "currency_id": this.props.defaultCurrency.id, } api.create().getRatioLOCF(payload).then(response => { console.log(payload); console.log(response); let dataTable = [] if (response.data) { if (response.data.status === 'success') { let res = response.data.data const handlePushChild = (item) => { let indexIDzz = dataTable.findIndex((val) => val[1] === item.id) if (indexIDzz === -1) { dataTable.push([ item.type_report_id, item.id, item.parent, item.formula, item.level, item.description, item.uom, item.ratio.total_actual_before === null ? "0.0" : item.ratio.total_actual_before === "" ? "0.0" : item.ratio.total_actual_before, // Number(item.ratio.monthly_january).toFixed(2), Number(item.ratio.monthly_january), Number(item.ratio.monthly_february), Number(item.ratio.monthly_march), Number(item.ratio.monthly_april), Number(item.ratio.monthly_may), Number(item.ratio.monthly_june), Number(item.ratio.monthly_july), Number(item.ratio.monthly_august), Number(item.ratio.monthly_september), Number(item.ratio.monthly_october), Number(item.ratio.monthly_november), Number(item.ratio.monthly_december), Number(item.ratio.total_next_year), Number(item.ratio.total_more_year), item.order, item.condition_it_should_be, item.condition_if_wrong ]) } if (item.children !== null) { if (item.children.length > 0) { item.children.map((items, indexs) => { handlePushChild(items) }) } } } res.map((item, index) => { dataTable.push([ item.type_report_id, item.id, item.parent, item.formula, item.level, item.description, item.oum, item.ratio.total_actual_before === null ? "0.0" : item.ratio.total_actual_before === "" ? "0.0" : item.ratio.total_actual_before, Number(item.ratio.monthly_january), Number(item.ratio.monthly_february), Number(item.ratio.monthly_march), Number(item.ratio.monthly_april), Number(item.ratio.monthly_may), Number(item.ratio.monthly_june), Number(item.ratio.monthly_july), Number(item.ratio.monthly_august), Number(item.ratio.monthly_september), Number(item.ratio.monthly_october), Number(item.ratio.monthly_november), Number(item.ratio.monthly_december), Number(item.ratio.total_next_year), Number(item.ratio.total_more_year), item.order, item.condition_it_should_be, item.condition_if_wrong ]) if (item.children !== null) { if (item.children.length > 0) { item.children.map((items, indexs) => { handlePushChild(items) }) } } }) console.log(dataTable) this.setState({ dataTableRatio: dataTable }, () => { this.getItemHierarki() }) } else { this.setState({ alert: true, messageAlert: response.data.message, tipeAlert: 'warning' }, () => { if (response.data.message.includes("Someone Logged In") || response.data.message.includes("Token Expired")) { setTimeout(() => { localStorage.removeItem(Constant.TOKEN) window.location.reload(); }, 1000); } }) } } else { this.setState({ alert: true, messageAlert: response.problem, tipeAlert: 'error', loading: false }) } }) } backToMonthlyReport(type) { // this.setState({ loading: true }) let data = [] let error = false this.deleteReport() this.state.dataTable.map(i => { if (i[0] == 3) { if (i[6] == null || i[7] == null || i[8] == "" || i[9] == "" || i[10] == "" || i[11] == "") { error = true } if (i[7].value == 'Others' && i[18] == '') { error = true } let tgl = String(i[9]).split('-') let checkUndifined = tgl.findIndex((val) => val == undefined) if (this.props.defaultCurrency.id == 2) { data.push({ "item_report_id": i[1], "borrower_comp_name": i[5], "bank_name": i[6] == null ? [6] : i[6].value, "type_of_credit": i[7] == null ? i[7] : i[7].value, "remarks": i[8], "loan_maturity_date": i[9] == undefined || i[9] == "null" || i[9] == null ? "" : (String(tgl[2]).length <= 2 ? tgl[2] + '-' + tgl[1] + '-' + tgl[0] : String(i[9])), // "loan_maturity_date": i[9], "interest": i[10] == "" ? "0.00" : i[10], "currency": i[11], "loan_plafond_amount_ori": Number(i[12]) == "" ? "0.0" : Number(i[12]), "loan_plafond_amount_idr": Number(i[13]) == "" ? "0.0" : Number(i[13]), "out_loan_ki_amount_ori": Number(i[14]) == "" ? "0.0" : Number(i[14]), "out_loan_ki_amount_idr": Number(i[15]) == "" ? "0.0" : Number(i[15]), "out_loan_kmk_amount_ori": Number(i[16]) == "" ? "0.0" : Number(i[16]), "out_loan_kmk_amount_idr": Number(i[17]) == "" ? "0.0" : Number(i[17]), // "mtd_vs_previous_month": i[18], "out_loan_other_type": i[18], "out_loan_other_amount_ori": Number(i[19]) == "" ? "0.0" : Number(i[19]), "out_loan_other_amount_idr": Number(i[20]) == "" ? "0.0" : Number(i[20]), "total_out_loan_ori": Number(i[21]) == "" ? "0.0" : Number(i[21]), "total_out_loan_idr": Number(i[22]) == "" ? "0.0" : Number(i[22]), "remaining_plafond_ori": Number(i[23]) == "" ? "0.0" : Number(i[23]), "remaining_plafond_idr": Number(i[24]) == "" ? "0.0" : Number(i[24]), "current_ratio_financial": Number(i[25]) == "" ? "0.00" : Number(i[25]), "current_ratio_current": Number(i[26]) == "" ? "0.00" : Number(i[26]), "der_financial": Number(i[27]) == "" ? "0.00" : Number(i[27]), "der_current": Number(i[28]) == "" ? "0.00" : Number(i[28]), "debt_to_ebitda_financial": Number(i[29]) == "" ? "0.00" : Number(i[29]), "debt_to_ebitda_current": Number(i[30]) == "" ? "0.00" : Number(i[30]), "ebitda_to_interest_financial": Number(i[31]) == "" ? "0.00" : Number(i[31]), "ebitda_to_interest_current": Number(i[32]) == "" ? "0.00" : Number(i[32]), "other_ratio1_ratio_name": i[33], "other_ratio1_financial": Number(i[34]) == "" ? "0.00" : Number(i[34]), "other_ratio1_current": Number(i[35]) == "" ? "0.00" : Number(i[35]), "other_ratio2_ratio_name": i[36], "other_ratio2_financial": Number(i[37]) == "" ? "0.00" : Number(i[37]), "other_ratio2_current": Number(i[38]) == "" ? "0.00" : Number(i[38]), "other_ratio3_ratio_name": i[39], "other_ratio3_financial": Number(i[40]) == "" ? "0.00" : Number(i[40]), "other_ratio3_current": Number(i[41]) == "" ? "0.00" : Number(i[41]), "other_ratio4_ratio_name": i[42], "other_ratio4_financial": Number(i[43]) == "" ? "0.00" : Number(i[43]), "other_ratio4_current": Number(i[44]) == "" ? "0.00" : Number(i[44]), "notes": i[45], }) } else { data.push({ "item_report_id": i[1], "borrower_comp_name": i[5], "bank_name": i[6] == null ? [6] : i[6].value, "type_of_credit": i[7] == null ? i[7] : i[7].value, "remarks": i[8], "loan_maturity_date": i[9] == undefined || i[9] == "null" || i[9] == null ? "" : (String(tgl[2]).length <= 2 ? tgl[2] + '-' + tgl[1] + '-' + tgl[0] : String(i[9])), // "loan_maturity_date": i[9], "interest": i[10] == "" ? "0.00" : i[10], "currency": i[11], "loan_plafond_amount_ori": fixNumber(Number(i[12]), 1) == "" ? "0.0" : fixNumber(Number(i[12]), 1), "loan_plafond_amount_idr": fixNumber(Number(i[13]), 1) == "" ? "0.0" : fixNumber(Number(i[13]), 1), "out_loan_ki_amount_ori": fixNumber(Number(i[14]), 1) == "" ? "0.0" : fixNumber(Number(i[14]), 1), "out_loan_ki_amount_idr": fixNumber(Number(i[15]), 1) == "" ? "0.0" : fixNumber(Number(i[15]), 1), "out_loan_kmk_amount_ori": fixNumber(Number(i[16]), 1) == "" ? "0.0" : fixNumber(Number(i[16]), 1), "out_loan_kmk_amount_idr": fixNumber(Number(i[17]), 1) == "" ? "0.0" : fixNumber(Number(i[17]), 1), // "mtd_vs_previous_month": i[18], "out_loan_other_type": i[18], "out_loan_other_amount_ori": fixNumber(Number(i[19]), 1) == "" ? "0.0" : fixNumber(Number(i[19]), 1), "out_loan_other_amount_idr": fixNumber(Number(i[20]), 1) == "" ? "0.0" : fixNumber(Number(i[20]), 1), "total_out_loan_ori": fixNumber(Number(i[21]), 1) == "" ? "0.0" : fixNumber(Number(i[21]), 1), "total_out_loan_idr": fixNumber(Number(i[22]), 1) == "" ? "0.0" : fixNumber(Number(i[22]), 1), "remaining_plafond_ori": fixNumber(Number(i[23]), 1) == "" ? "0.0" : fixNumber(Number(i[23]), 1), "remaining_plafond_idr": fixNumber(Number(i[24]), 1) == "" ? "0.0" : fixNumber(Number(i[24]), 1), "current_ratio_financial": fixNumber(Number(i[25]), 2) == "" ? "0.00" : fixNumber(Number(i[25]), 2), "current_ratio_current": fixNumber(Number(i[26]), 2) == "" ? "0.00" : fixNumber(Number(i[26]), 2), "der_financial": fixNumber(Number(i[27]), 2) == "" ? "0.00" : fixNumber(Number(i[27]), 2), "der_current": fixNumber(Number(i[28]), 2) == "" ? "0.00" : fixNumber(Number(i[28]), 2), "debt_to_ebitda_financial": fixNumber(Number(i[29]), 2) == "" ? "0.00" : fixNumber(Number(i[29]), 2), "debt_to_ebitda_current": fixNumber(Number(i[30]), 2) == "" ? "0.00" : fixNumber(Number(i[30]), 2), "ebitda_to_interest_financial": fixNumber(Number(i[31]), 2) == "" ? "0.00" : fixNumber(Number(i[31]), 2), "ebitda_to_interest_current": fixNumber(Number(i[32]), 2) == "" ? "0.00" : fixNumber(Number(i[32]), 2), "other_ratio1_ratio_name": i[33], "other_ratio1_financial": fixNumber(Number(i[34]), 2) == "" ? "0.00" : fixNumber(Number(i[34]), 2), "other_ratio1_current": fixNumber(Number(i[35]), 2) == "" ? "0.00" : fixNumber(Number(i[35]), 2), "other_ratio2_ratio_name": i[36], "other_ratio2_financial": fixNumber(Number(i[37]), 2) == "" ? "0.00" : fixNumber(Number(i[37]), 2), "other_ratio2_current": fixNumber(Number(i[38]), 2) == "" ? "0.00" : fixNumber(Number(i[38]), 2), "other_ratio3_ratio_name": i[39], "other_ratio3_financial": fixNumber(Number(i[40]), 2) == "" ? "0.00" : fixNumber(Number(i[40]), 2), "other_ratio3_current": fixNumber(Number(i[41]), 2) == "" ? "0.00" : fixNumber(Number(i[41]), 2), "other_ratio4_ratio_name": i[42], "other_ratio4_financial": fixNumber(Number(i[43]), 2) == "" ? "0.00" : fixNumber(Number(i[43]), 2), "other_ratio4_current": fixNumber(Number(i[44]), 2) == "" ? "0.00" : fixNumber(Number(i[44]), 2), "notes": i[45], }) } } }) let payload = { "monthly_report_id": this.props.monthlyReportId, "company_id": this.props.company.company_id, "periode": this.props.periode, "report_id": this.props.report_id, "status": type, "months": this.props.month.month_id, "currency_id": this.props.defaultCurrency.id, "locf": data, "per_bs": this.state.perBS, "diff": this.state.diff, "total_loan": this.state.perBS } console.log(JSON.stringify(payload)) if (error && type == 'submitted') { this.setState({ handleDoubleClick: 0, saveDraft: false, saveComp: true, loading: false, snekbar: true, snekbarMsg: 'Data Incomplete', handleDoubleClick: 0 }) } else { api.create('UPLOAD').createMonthlyReportLOCF(payload).then(response => { console.log(response); if (response.data) { if (response.data.status === "success") { this.props.saveToMonthlyReport('LOCF') } else { this.setState({ alert: true, messageAlert: response.data.message, tipeAlert: 'warning', loading: false }, () => { document.body.style.overflow = 'unset'; if (response.data.message.includes("Someone Logged In") || response.data.message.includes("Token Expired")) { setTimeout(() => { localStorage.removeItem(Constant.TOKEN) window.location.reload(); }, 1000); } this.props.saveToMonthlyReport() }) } // else { // this.setState({ loading: false }, () => { // this.props.saveToMonthlyReport() // }) // } } else { this.setState({ loading: false }, () => { // this.getSubmission() document.body.style.overflow = 'unset'; }) } this.setState({ handleDoubleClick: 0 }) }) } } handleCalculate = () => { let dataTable2 = this.state.dataTable this.setState({ loading: true }, () => { let bankPrev = "" let idPrev = 0 let newData = [] let dataCoba = [] let bankNameEmpty = false let totalLoan = 0 console.log(dataTable2); dataTable2.map((item, index) => { if (item[0] !== 8) { if (item[6] == null) { bankNameEmpty = true } else { let groupName = String(item[6].value).split("-") let indexAS = dataCoba.findIndex((val) => item[6].value.includes(val.groupName)) if (indexAS == -1) { dataCoba.push({ groupName: groupName[groupName.length - 1], data: [item] }) } else { let indexDD = dataCoba[indexAS].data.length - 1 == -1 ? 0 : dataCoba[indexAS].data.length - 1 if (String(dataCoba[indexAS].data[indexDD]).includes('Total')) { let dataAwal = [] let dataAkhir = [] dataAwal = dataCoba[indexAS].data.splice(0, dataCoba[indexAS].data.length - 2) dataAkhir = dataCoba[indexAS].data.splice(dataCoba[indexAS].data.length - 1, 1) dataAwal.push(item) dataCoba[indexAS].data = dataAwal.concat(dataAkhir) } else { dataCoba[indexAS].data.push(item) } } } } }) console.log(dataCoba); let dataGabung = [] if (!bankNameEmpty) { dataCoba.map((item, index) => { item.data.map((items, index) => { dataGabung.push(items) }) }) console.log(dataGabung); dataGabung.map((items, index) => { console.log(items); if (items[0] == 3) { console.log(Number(totalLoan)); this.props.defaultCurrency.id == 1 ? totalLoan += items[22] : totalLoan += items[21] } if (bankPrev != "") { if (items[6].value !== bankPrev) { bankPrev = items[6].value if (items[6].value == 'Grand Total') { // if (dataTable2.length > 2) { // newData.push(items) // } else { if (String(dataGabung[index - 1][6].value).includes('Total ')) { newData.push(items) } else { // if (String(dataGabung[index][6].value).includes('Total ')) { // newData.push(items) // } else { // items[46] = index + 1 let nameTotal = String(dataGabung[index - 1][6].value).split("-") newData.push([ 8, "", "", "", "", "", { value: 'Total ' + nameTotal[nameTotal.length - 1] }, null, "", null, "0.00", "", "", "0", "", "0", "", "0", "", "", "0", "0", "0", "0", "0", "", "0", "", "0", "", "0", "", "0", "", "", "", "", "", "", "", "", "", "", "", "", "", index], items, ) // } } // } } else { if (String(dataGabung[index - 1][6].value).includes('Total ')) { newData.push(items) } else { if (String(dataGabung[index][6].value).includes('Total ')) { newData.push(items) } else { items[46] = index + 1 let nameTotal = String(dataGabung[index - 1][6].value).split("-") newData.push([ 8, "", "", "", "", "", { value: 'Total ' + nameTotal[nameTotal.length - 1] }, null, "", null, "0.00", "", "", "0", "", "0", "", "0", "", "", "0", "0", "0", "0", "0", "", "0", "", "0", "", "0", "", "0", "", "", "", "", "", "", "", "", "", "", "", "", "", index], items, ) } } } } else { newData.push(items) } } else { bankPrev = items[6].value idPrev = items[0] newData.push(items) } }) } else { if (this.state.get_for == 'edit') { this.setState({ snekbar: true, snekbarMsg: 'Bank Names Cannot be Empty' }) } } setTimeout(() => { // console.log(dataCoba) // console.log(dataGabung) console.log(newData) // console.log(dataTampungBank) console.log(totalLoan); console.log(this.state.perBS) console.log(this.state.diff) console.log(bankNameEmpty) // dataTable: newData, totalOutStand: newData[newData.length-1][22] if (bankNameEmpty) { if (this.state.get_for == 'view') { this.setState({ loading: false, dataTable: this.state.dataTable, diff: this.state.diff == null ? "0.0" : this.props.defaultCurrency.id == 1 ? fixNumber(Number(0 - this.state.perBS), 1) : Number(0 - this.state.perBS), perBS: this.state.totalOutStand == null ? "0.0" : this.state.totalOutStand, saveDraft: false, saveComp: true }) } else { this.setState({ loading: false, dataTable: this.state.dataTable, diff: this.props.defaultCurrency.id == 1 ? fixNumber(Number(0 - this.state.perBS), 1) : Number(0 - this.state.perBS), saveDraft: false, saveComp: true }) } } else { if (this.state.get_for == 'view') { if (this.props.defaultCurrency.id == 1) { this.setState({ loading: false, dataTable: newData, diff: this.state.diff == null ? "0.0" : fixNumber(Number(fixNumber(Number(totalLoan), 1) - this.state.perBS), 1), perBS: this.state.totalOutStand == null ? "0.0" : this.state.totalOutStand }) } else { this.setState({ loading: false, dataTable: newData, diff: this.state.diff == null ? "0.0" : Number(Number(totalLoan) - this.state.perBS), perBS: this.state.totalOutStand == null ? "0.0" : this.state.totalOutStand }) } } else { if (this.props.defaultCurrency.id == 1) { this.setState({ loading: false, dataTable: newData, diff: fixNumber(Number(fixNumber(Number(totalLoan), 1) - this.state.perBS), 1), saveDraft: false, saveComp: Number(fixNumber(Number(totalLoan), 1) - this.state.perBS) == 0 || Number(fixNumber(Number(totalLoan), 1) - this.state.perBS) == "-0.0" ? false : true }) } else { this.setState({ loading: false, dataTable: newData, diff: Number(Number(totalLoan) - this.state.perBS), saveDraft: false, saveComp: Number(Number(totalLoan) - this.state.perBS) == 0 || Number(Number(totalLoan) - this.state.perBS) == "-0.0" ? false : true }) } } } }, 100); }) } render() { let dataTable2 = this.state.dataTable let loading = this.state.loading let dataTampungBank = [] let indexNyasar = false let totalLoan = 0 // const formatSeparator = (num) => { // return String(num).replace(/(? { // console.log(typeReport) if (typeReport == 3) { if (dataTable2.length == 2) { if (typeButton == 'add') { return true } else { return false } } else { return true } } else { return false } } const handleChange = (value, tableMeta, column, typeChange, typeDrop) => { let val = '' if (typeChange == 'date') { dataTable2[tableMeta.rowIndex][column] = format(value, 'yyyy-MM-dd') this.setState({ loading: true }, () => { this.setState({ loading: false }) }) } else { if (column != 8 && column != 11 && column != 18 && column != 25 && column != 27 && column != 29 && column != 31 && column != 33 && column != 36 && column != 39 && column != 42 && column != 45) { val = String(value).split(",").join("") val = this.props.defaultCurrency.id == 1 ? fixNumber(Number(val), 2) : Number(val) } else { val = String(value).split(",").join("") } if (value.value !== undefined) { if (value.value == 'Investment Loan') { dataTable2[tableMeta.rowIndex][16] = 0 dataTable2[tableMeta.rowIndex][17] = 0 dataTable2[tableMeta.rowIndex][18] = "" dataTable2[tableMeta.rowIndex][19] = 0 dataTable2[tableMeta.rowIndex][20] = 0 } else if (value.value == 'Revolving Loan (KMK)') { dataTable2[tableMeta.rowIndex][14] = 0 dataTable2[tableMeta.rowIndex][15] = 0 dataTable2[tableMeta.rowIndex][18] = "" dataTable2[tableMeta.rowIndex][19] = 0 dataTable2[tableMeta.rowIndex][20] = 0 } else if (value.value == 'others') { dataTable2[tableMeta.rowIndex][14] = 0 dataTable2[tableMeta.rowIndex][15] = 0 dataTable2[tableMeta.rowIndex][16] = 0 dataTable2[tableMeta.rowIndex][17] = 0 } dataTable2[tableMeta.rowIndex][column] = value } else { dataTable2[tableMeta.rowIndex][column] = val } } console.log(dataTable2[tableMeta.rowIndex][column]); console.log(value) console.log(String(value).split(",").join("")) } const handleValueDropDown = (value, type, tableMeta) => { let data = type == 'bankName' ? this.state.bankNameList.options : this.state.typeOfCreditList.options let index = 0 if (type == 'bankName' && dataTable2[tableMeta.rowIndex][tableMeta.columnIndex] != null && dataTable2[tableMeta.rowIndex][tableMeta.columnIndex] != "") { indexNyasar = true } if (value == null) { index = -1 } else { index = data.findIndex((val) => String(val.value) == String(value.value)) } if (index == -1) { dataTable2[tableMeta.rowIndex][tableMeta.columnIndex] = null return null } else { dataTable2[tableMeta.rowIndex][tableMeta.columnIndex] = value return value } } const handleTableRatio = (value, tableMeta, column, reportName) => { let dataTableRatio = this.state.dataTableRatio let indexId = dataTableRatio.findIndex((val) => String(val[5]).toLocaleLowerCase() == String(reportName).toLocaleLowerCase()) let valuez = 0 if (indexId != -1) { valuez = dataTableRatio[indexId][Number(this.props.month.month_id) + 7] // console.log(valuez) if (String(valuez).includes('infinity')) { valuez = 0 } } dataTable2[tableMeta.rowIndex][column] = valuez return valuez } const handleFormulaHardcode = (value, tableMeta, column) => { // console.log("------------coba------------------"); // console.log(tableMeta); // console.log(tableMeta.rowData[0]); let valuez = 0 if (tableMeta.rowData[0] == 8) { dataTable2.map((item, index) => { if (item[6].value.includes(String(tableMeta.rowData[6].value).substr(6, tableMeta.rowData[6].length)) && item[0] != 8) { valuez += Number(item[column]) } }) } else if (tableMeta.rowData[0] == 9) { dataTable2.map((item, index) => { if (item[0] == 8) { valuez += Number(item[column]) } }) if (column == 22) { totalLoan = valuez } } else { if (column == 21) { valuez = Number(tableMeta.rowData[14]) + Number(tableMeta.rowData[16]) + Number(tableMeta.rowData[19]) } else if (column == 22) { valuez = Number(tableMeta.rowData[15]) + Number(tableMeta.rowData[17]) + Number(tableMeta.rowData[20]) } else if (column == 23) { valuez = Number(tableMeta.rowData[12]) - Number(tableMeta.rowData[21]) } else if (column == 24) { valuez = Number(tableMeta.rowData[13]) - Number(tableMeta.rowData[22]) } } dataTable2[tableMeta.rowIndex][column] = valuez return valuez } const handleTambah = (data, rowIndex) => { // // console.log(dataTable2) let newData = [] let indexxx = 0 dataTable2.map((item, index) => { indexxx = index if (item[6] == "Grand Total") { item[46] = 999999 } else { item[46] = indexxx } newData.push(item) if (index == rowIndex) { indexxx = index + 1 newData.push([ 3, "", "", "", "", this.props.company.company_name, item[6], null, "", null, "0.00", "", "", "0", "", "0", "", "0", "", "", "0", "0", "0", "0", "0", "", "0", "", "0", "", "0", "", "0", "", "", "", "", "", "", "", "", "", "", "", "", "", indexxx], ) } }) dataTable2 = newData.sort((a, b) => a[46] - b[46]) this.setState({ dataTable: dataTable2 }, () => { setTimeout(() => { this.setState({ loading: false }) console.log(dataTable2) }, 500) }) } const handleDelete = (index) => { let dataDelete = this.state.dataDelete let berapaInput = 0 dataTable2.map((items, indexs) => { if (items[0] == 3) { berapaInput += 1 } }) dataDelete.push(dataTable2[index][1]) let prevData = dataTable2[index - 1] == undefined ? null : dataTable2[index - 1][6] let currentData = dataTable2[index][6] let nextData = dataTable2[index + 1] == undefined ? null : dataTable2[index + 1][6] if (nextData == null) { dataTable2.splice(index, 1) } else if (nextData.value.includes('Total')) { if (prevData !== null && currentData == null) { dataTable2.splice(index, 1) } else if (prevData !== null && prevData.value == currentData.value) { dataTable2.splice(index, 1) } else if (dataTable2.length > 3) { if (prevData == null) { if (nextData.value.includes('Grand')) { dataTable2.splice(index, 1) } else { dataTable2.splice(index, 2) } } else { dataTable2.splice(index, 2) } } else if (dataTable2.length == 3) { if (prevData == null) { if (nextData.value.includes('Grand')) { dataTable2.splice(index, 1) } else { dataTable2.splice(index, 3) dataTable2.push( [3, "", "", "", "", this.props.company.company_name, null, null, "", null, "0.00", "", "", "0", "", "0", "", "0", "", "", "0", "0", "0", "0", "0", "", "0", "", "0", "", "0", "", "0", "", "", "", "", "", "", "", "", "", "", "", "", "", 0], [9, "", "", "", "", "", { value: "Grand Total" }, null, "", "", "", "0", "", "0", "", "0", "", "0", "", "", "0", "0", "0", "0", "0", "", "0", "", "0", "", "0", "", "0", "", "", "", "", "", "", "", "", "", "", "", "", "notes", 999999], ) } } else { dataTable2.splice(index, 1) } } } else { dataTable2.splice(index, 1) } this.setState({ dataTable: dataTable2, dataDelete }, () => { setTimeout(() => { console.log(this.state.dataDelete) this.setState({ loading: false }) }, 100) }) } let columns = [ { name: "", options: { display: false } }, { name: "", options: { display: false } }, { name: "", options: { display: false } }, { name: "", options: { display: false } }, { name: "", options: { filter: false, display: this.state.get_for == 'view' ? false : true, customHeadRender: (columnMeta) => ( {columnMeta.name} ), setCellProps: () => ({ style2 }), customBodyRender: (val, tableMeta) => { return ( // handleAction(tableMeta.rowData[2]) &&
{/* {tableMeta.rowData[6] === "Active" ? */} {handleAction(tableMeta.rowData[0], tableMeta, 'add') && } {handleAction(tableMeta.rowData[0], tableMeta, 'delete') && }
); } } }, { name: "Borrower (Company) Name", options: { customHeadRender: (columnMeta) => ( {columnMeta.name} ), setCellProps: () => ({ style2 }), customBodyRender: (val, tableMeta, updateValue) => { return (
{tableMeta.rowData[0] === 4 ? null : val }
) } } }, { name: "Bank Name", options: { customHeadRender: (columnMeta) => ( {columnMeta.name} ), setCellProps: () => ({ style2 }), customBodyRender: (val, tableMeta, updateValue) => { return (
{tableMeta.rowData[0] === 8 || tableMeta.rowData[0] === 9 || tableMeta.rowData[0] === 4 ? {val.value} : handleChange(newInputValue, tableMeta, tableMeta.columnIndex)} debug disableClearable disabled={this.state.get_for == 'view'} // disabled={!handleAction(tableMeta.rowData[2], tableMeta.rowData[0])} value={handleValueDropDown(val, 'bankName', tableMeta)} style={{ padding: 0, margin: 0 }} renderInput={(params) =>