salary-management-front/pc4mobx/hrmSalary/pages/ledgerPage/components/ledgerBaseSetting.js

382 lines
13 KiB
JavaScript
Raw Normal View History

2022-12-09 14:16:11 +08:00
/*
* Author: 黎永顺
* name: 薪资账套基本设置
* Description:
* Date: 2022/12/9
*/
import React, { Component } from "react";
import { WeaCheckbox, WeaFormItem, WeaHelpfulTip, WeaInput, WeaSelect, WeaTextarea } from "ecCom";
import { Col, Row } from "antd";
import { inject, observer } from "mobx-react";
import { baseSettingFormItem } from "../config";
2022-12-12 10:24:07 +08:00
import { getLedgerBasicForm } from "../../../apis/ledger";
import {
generateBasicInfo,
getAddMonthYearMonth,
getCurrentYearMonth,
getMonthDays,
getSubtractMonthYearMonth,
prefixAddZero
} from "../../../util/date";
2023-01-18 09:22:14 +08:00
import { commonEnumList } from "../../../apis/ruleconfig";
import moment from "moment";
2022-12-09 14:16:11 +08:00
import "./index.less";
@inject("taxAgentStore")
@observer
class LedgerBaseSetting extends Component {
constructor(props) {
super(props);
this.state = {
2023-02-14 15:38:04 +08:00
baseForm: [],
2022-12-09 14:16:11 +08:00
settingBaseInfo: {
2022-12-12 10:24:07 +08:00
name: "",
taxAgentId: "",
taxableItems: "1",
salaryCycleType: "3",
salaryCycleFromDay: "1",
taxCycleType: "3",
attendCycleType: "3",
attendCycleFromDay: "1",
socialSecurityCycleType: "3",
description: "",
canEdit: false
2022-12-09 14:16:11 +08:00
}
};
}
2023-02-14 15:38:04 +08:00
componentWillMount() {
2022-12-09 14:16:11 +08:00
this.getTaxAgentSelectListAsAdmin();
2023-02-14 15:38:04 +08:00
}
componentDidMount() {
// this.getTaxAgentSelectListAsAdmin();
// this.commonEenumList();
2022-12-12 10:24:07 +08:00
if (this.props.visible && this.props.editId) {
this.getLedgerBasicForm(this.props.editId);
}
}
componentWillReceiveProps(nextProps, nextContext) {
if (nextProps.visible !== this.props.visible && nextProps.editId) {
this.getLedgerBasicForm(nextProps.editId);
}
if (nextProps.visible !== this.props.visible && !nextProps.editId) {
this.handleResetBaseInfo();
}
2022-12-09 14:16:11 +08:00
}
2022-12-12 10:24:07 +08:00
handleResetBaseInfo = () => {
this.setState({
settingBaseInfo: {
name: "",
taxAgentId: "",
taxableItems: "1",
salaryCycleType: "3",
salaryCycleFromDay: "1",
taxCycleType: "3",
attendCycleType: "3",
attendCycleFromDay: "1",
socialSecurityCycleType: "3",
description: "",
2022-12-12 11:38:43 +08:00
canEdit: "true"
2022-12-12 10:24:07 +08:00
}
});
};
getLedgerBasicForm = (id) => {
getLedgerBasicForm({ id }).then(({ status, data }) => {
if (status) {
const { basicForm } = data;
const { settingBaseInfo } = this.state;
let tmpV = {};
_.map(Object.keys(settingBaseInfo), key => {
2022-12-16 11:05:07 +08:00
tmpV[key] = !_.isNil(basicForm[key]) ? basicForm[key].toString() : "";
2022-12-12 10:24:07 +08:00
});
this.setState({
settingBaseInfo: {
...settingBaseInfo,
...tmpV
}
}, () => {
this.props.onSaveParams(this.state.settingBaseInfo);
});
}
});
};
2022-12-09 14:16:11 +08:00
getTaxAgentSelectListAsAdmin = () => {
const { taxAgentStore } = this.props;
const { getTaxAgentSelectListAsAdmin } = taxAgentStore;
getTaxAgentSelectListAsAdmin().then(({ status, data }) => {
if (status) {
this.setState({
2023-02-14 15:38:04 +08:00
baseForm: _.map(baseSettingFormItem, it => {
2022-12-09 14:16:11 +08:00
if (it.key === "taxAgentId") {
return {
...it,
options: _.map(data, it => ({ key: it.id, showname: it.content }))
};
}
return { ...it };
})
2023-02-14 15:38:04 +08:00
}, () => this.commonEenumList());
2022-12-09 14:16:11 +08:00
}
});
};
2023-02-14 15:38:04 +08:00
commonEenumList = () => {
2023-01-18 09:22:14 +08:00
const payload = {
enumClass: "com.engine.salary.enums.salarysob.IncomeCategoryEnum"
};
commonEnumList(payload).then(({ status, data }) => {
if (status) {
const { baseForm } = this.state;
this.setState({
baseForm: _.map(baseForm, it => {
if (it.key === "taxableItems") {
return {
...it,
options: _.map(data, it => ({ key: it.value.toString(), showname: it.defaultLabel }))
};
}
return { ...it };
})
});
}
});
2023-02-14 15:38:04 +08:00
};
2022-12-09 14:16:11 +08:00
handleChangeField = (key, value) => {
const { onSaveParams } = this.props;
const { settingBaseInfo } = this.state;
this.setState({
settingBaseInfo: {
...settingBaseInfo,
[key]: value
}
}, () => {
onSaveParams(this.state.settingBaseInfo);
});
};
render() {
2023-02-15 18:47:37 +08:00
const { editId, taxAgentStore: { taxAgentOption } } = this.props;
2022-12-09 14:16:11 +08:00
const { baseForm, settingBaseInfo } = this.state;
2022-12-12 11:38:43 +08:00
const { canEdit, taxAgentId } = settingBaseInfo;
let taxAgentIdDisabled = false, taxableItemsDisabled = false;
2022-12-09 14:16:11 +08:00
return (
<div className="baseSettingWrapper">
<Row gutter={20}>
<Col span={18} className="baseSettingLeft">
{
_.map(baseForm, item => {
const { key, label, type, options = [], children = [] } = item;
2023-01-28 10:10:00 +08:00
taxAgentIdDisabled = key === "taxAgentId" && editId && taxAgentId;
2022-12-12 11:38:43 +08:00
taxableItemsDisabled = key === "taxableItems" && editId;
2022-12-09 14:16:11 +08:00
return <WeaFormItem
key={key} label={label}
labelCol={{ span: 6 }} wrapperCol={{ span: 12 }}
>
{
type === "INPUT" ?
2022-12-12 11:38:43 +08:00
<WeaInput value={settingBaseInfo[key]} viewAttr={3} disabled={canEdit !== "true"}
2022-12-09 14:16:11 +08:00
onChange={(v) => this.handleChangeField(key, v)}/> :
type === "TEXTAREA" ?
2022-12-12 11:38:43 +08:00
<WeaTextarea value={settingBaseInfo[key]} disabled={canEdit !== "true"}
onChange={(v) => this.handleChangeField(key, v)}/> :
2022-12-09 14:16:11 +08:00
type === "CHECKBOX" ?
<React.Fragment>
<WeaCheckbox value={true} viewAttr={1}
content="【起薪日期≤薪资周期止】且【最后发薪日期≥薪资周期起】"/>
2022-12-09 14:16:11 +08:00
<WeaHelpfulTip width={200} title="提示:最后发薪日期为空,默认为无穷大" placement="topLeft"/>
</React.Fragment> :
type === "SELECT" ?
2023-02-15 18:47:37 +08:00
<WeaSelect value={settingBaseInfo[key]}
options={((canEdit !== "true" || taxAgentIdDisabled || taxableItemsDisabled) && key === "taxAgentId") ? taxAgentOption : options}
viewAttr={3}
2022-12-12 11:38:43 +08:00
disabled={canEdit !== "true" || taxAgentIdDisabled || taxableItemsDisabled}
2022-12-09 14:16:11 +08:00
onChange={(v) => this.handleChangeField(key, v)}/> :
2022-12-12 10:24:07 +08:00
type === "CUSTOM" ?
<CustomSelect list={children} baseInfo={settingBaseInfo} inputStr={key}
onChange={(key, v) => this.handleChangeField(key, v)}/> : null
2022-12-09 14:16:11 +08:00
}
</WeaFormItem>;
})
}
</Col>
2022-12-09 15:26:21 +08:00
<Col span={6}><MonthCycleDesc {...settingBaseInfo}/></Col>
2022-12-09 14:16:11 +08:00
</Row>
</div>
);
}
}
export default LedgerBaseSetting;
const CustomSelect = (props) => {
2022-12-12 10:24:07 +08:00
const { list, baseInfo, onChange, inputStr } = props;
const { canEdit } = baseInfo;
const selectInfo = buildEditBasicInfo(baseInfo);
2023-01-05 15:03:03 +08:00
return <Row gutter={10} key={inputStr}>
2022-12-09 14:16:11 +08:00
{
_.map(list, item => {
const { key, options = [] } = item;
return <Col span={6}>
<WeaSelect value={baseInfo[key]} options={options} viewAttr={3}
2022-12-12 11:38:43 +08:00
disabled={canEdit !== "true"}
2022-12-09 14:16:11 +08:00
onChange={(v) => onChange(key, v)}/>
</Col>;
})
}
2022-12-12 10:24:07 +08:00
<Col span={12}
className="desc">{inputStr === "salaryCycleStrObj" ? selectInfo.salaryCycleInfo.salaryPeriodTip : selectInfo.attendCycleInfo.attendancePeriodTip}</Col>
2022-12-09 14:16:11 +08:00
</Row>;
};
const MonthCycleDesc = (props) => {
const { taxCycleType, socialSecurityCycleType } = props;
const selectInfo = buildEditBasicInfo({ ...props });
2022-12-09 14:16:11 +08:00
return <div className="baseSettingRight">
<div className="title">月份周期说明</div>
<div className="descContent">
2022-12-09 15:26:21 +08:00
<div>
薪资所属月是<span className="notice">{moment().format("YYYY-MM")}</span><span
className="notice">{moment().format("MM")}</span>
</div>
2022-12-09 14:16:11 +08:00
<div>根据您当前的选择相应的周期为</div>
<div className="descTitle">薪资周期</div>
2022-12-12 10:24:07 +08:00
<div>
<span className="notice">{selectInfo.salaryCycleInfo.salaryPeriodStart}</span>
<span className="notice">{selectInfo.salaryCycleInfo.salaryPeriodEnd}</span>
2022-12-12 10:24:07 +08:00
</div>
2022-12-09 14:16:11 +08:00
<div className="descTitle">税款所属期</div>
2022-12-09 15:26:21 +08:00
<div className="notice">{getMonth(taxCycleType)}</div>
2022-12-09 14:16:11 +08:00
<div className="descTitle">考勤取值周期</div>
2022-12-12 10:24:07 +08:00
<div>
<span className="notice">{selectInfo.attendCycleInfo.attendancePeriodStart}</span>
<span className="notice">{selectInfo.attendCycleInfo.attendancePeriodEnd}</span>
2022-12-12 10:24:07 +08:00
</div>
2022-12-09 14:16:11 +08:00
<div className="descTitle">福利台账月份</div>
2022-12-09 15:26:21 +08:00
<div>引用<span className="notice">{getMonth(socialSecurityCycleType)}</span></div>
2022-12-09 14:16:11 +08:00
</div>
</div>;
};
const buildEditBasicInfo = (editBasicInfo) => {
const { attendCycleType, salaryCycleType } = editBasicInfo;
const now = new Date();
let nowYear = now.getFullYear();
let nowMonth = now.getMonth() + 1;
let tmpV = {};
// 薪资联动
switch (salaryCycleType) {
case "1" :
tmpV["salaryCycleInfo"] = buildSalaryInfo(editBasicInfo, -2, nowYear, nowMonth);
break;
case "2" :
tmpV["salaryCycleInfo"] = buildSalaryInfo(editBasicInfo, -1, nowYear, nowMonth);
break;
case "3" :
tmpV["salaryCycleInfo"] = buildSalaryInfo(editBasicInfo, 0, nowYear, nowMonth);
break;
case "4" :
tmpV["salaryCycleInfo"] = buildSalaryInfo(editBasicInfo, 1, nowYear, nowMonth);
break;
}
// 考勤联动
switch (attendCycleType) {
case "1" :
tmpV["attendCycleInfo"] = buildAttendanceInfo(editBasicInfo, -2, nowYear, nowMonth);
break;
case "2" :
tmpV["attendCycleInfo"] = buildAttendanceInfo(editBasicInfo, -1, nowYear, nowMonth);
break;
case "3" :
tmpV["attendCycleInfo"] = buildAttendanceInfo(editBasicInfo, 0, nowYear, nowMonth);
break;
case "4" :
tmpV["attendCycleInfo"] = buildAttendanceInfo(editBasicInfo, 1, nowYear, nowMonth);
break;
}
return tmpV;
};
/*
* Author: 黎永顺
* Description:构建薪资周期联动信息
* Params:
* Date: 2023/4/17
*/
const buildSalaryInfo = (editBasicInfo, monthCal, nowYear, nowMonth) => {
const { salaryCycleFromDay } = editBasicInfo;
let salaryCycleFromDayNum = Number(salaryCycleFromDay), customInfo = {};
const basicInfo = generateBasicInfo(monthCal, nowYear, nowMonth);
const { nowMonthStr, nextMonthStr, year, month } = basicInfo;
customInfo.salaryYear = year;
customInfo.salaryMonth = month;
2022-12-09 15:26:21 +08:00
if (salaryCycleFromDayNum === 1) {
customInfo.salaryPeriodTip = "至" + nowMonthStr + "最后一天";
customInfo.salaryPeriodStart = customInfo.salaryYear + "-"
+ prefixAddZero(customInfo.salaryMonth, 2) + "-01";
customInfo.salaryPeriodEnd = customInfo.salaryYear + "-"
+ prefixAddZero(customInfo.salaryMonth, 2) + "-"
+ prefixAddZero(getMonthDays(customInfo.salaryYear, customInfo.salaryMonth), 2);
} else {
customInfo.salaryPeriodTip = "至" + nextMonthStr + (salaryCycleFromDayNum - 1) + "号";
customInfo.salaryPeriodStart = customInfo.salaryYear + "-"
+ prefixAddZero(customInfo.salaryMonth, 2) + "-" + prefixAddZero(salaryCycleFromDayNum, 2);
let year = customInfo.salaryYear;
let month = customInfo.salaryMonth;
if (month === "12") {
year = Number(year) + 1;
month = 1;
} else {
month = Number(month) + 1;
}
customInfo.salaryPeriodEnd = year + "-"
+ prefixAddZero(month, 2) + "-"
+ prefixAddZero(salaryCycleFromDayNum - 1, 2);
}
return customInfo;
2022-12-12 10:24:07 +08:00
};
const buildAttendanceInfo = (editBasicInfo, monthCal, nowYear, nowMonth) => {
const { attendCycleFromDay } = editBasicInfo;
let attendCycleFromDayNum = Number(attendCycleFromDay), customInfo = {};
2022-12-12 10:24:07 +08:00
const basicInfo = generateBasicInfo(monthCal, nowYear, nowMonth);
const { nowMonthStr, nextMonthStr } = basicInfo;
let year = basicInfo.year;
let month = basicInfo.month;
if (attendCycleFromDayNum === 1) {
customInfo.attendancePeriodTip = "至" + nowMonthStr + "最后一天";
customInfo.attendancePeriodStart = year + "-"
+ prefixAddZero(month, 2) + "-01";
customInfo.attendancePeriodEnd = year + "-"
+ prefixAddZero(month, 2) + "-"
+ prefixAddZero(getMonthDays(year, month), 2);
} else {
customInfo.attendancePeriodTip = "至" + nextMonthStr + (attendCycleFromDayNum - 1) + "号";
customInfo.attendancePeriodStart = year + "-"
+ prefixAddZero(month, 2) + "-" + prefixAddZero(attendCycleFromDayNum, 2);
if (month === "12") {
year = (Number(year) + 1).toString();
month = "1";
} else {
month = (Number(month) + 1).toString();
}
customInfo.attendancePeriodEnd = year + "-"
+ prefixAddZero(month, 2) + "-"
+ prefixAddZero(attendCycleFromDayNum - 1, 2);
}
return customInfo;
};
2022-12-09 15:26:21 +08:00
const getMonth = (salaryCycleType) => {
switch (salaryCycleType) {
case "1": // 上上月
return getSubtractMonthYearMonth(2);
case "2": // 上月
return getSubtractMonthYearMonth(1);
case "3": // 本月
return getCurrentYearMonth();
case "4": // 下月
return getAddMonthYearMonth(1);
}
};