release/3.0.1.2504.01-合并业务线
This commit is contained in:
parent
573f2cf62d
commit
1cbb7ce943
|
|
@ -32,3 +32,11 @@ export const getPushRecordList = (params) => {
|
|||
export const getPushRecordDetail = (params) => {
|
||||
return postFetch("/api/bs/hrmsalary/push/record/detail", params);
|
||||
};
|
||||
// 推送记录-推送
|
||||
export const pushRecords = (params) => {
|
||||
return postFetch("/api/bs/hrmsalary/push/record/push", params);
|
||||
};
|
||||
// 推送记录-撤回
|
||||
export const withdrawRecords = (params) => {
|
||||
return postFetch("/api/bs/hrmsalary/push/record/withdraw", params);
|
||||
};
|
||||
|
|
|
|||
|
|
@ -0,0 +1,134 @@
|
|||
/*
|
||||
* 数据推送记录
|
||||
* 创建
|
||||
* @Author: 黎永顺
|
||||
* @Date: 2025/4/15
|
||||
* @Wechat:
|
||||
* @Email: 971387674@qq.com
|
||||
* @description:
|
||||
*/
|
||||
import React, { Component } from "react";
|
||||
import { WeaDialog, WeaFormItem, WeaLocaleProvider, WeaTable, WeaTools } from "ecCom";
|
||||
import { WeaForm, WeaSwitch } from "comsMobx";
|
||||
import { Button } from "antd";
|
||||
import moment from "moment";
|
||||
import FormInfo from "../../../../components/FormInfo";
|
||||
import { RQconditions } from "../../conditions";
|
||||
import { MonthRangePicker } from "../../../reportView/components/statisticalMicroSettingsSlide";
|
||||
import { getSalaryAcctList } from "../../../../apis/calculate";
|
||||
|
||||
const form = new WeaForm();
|
||||
const getKey = WeaTools.getKey;
|
||||
const getLabel = WeaLocaleProvider.getLabel;
|
||||
|
||||
class CreatePushRecordDialog extends Component {
|
||||
constructor(props) {
|
||||
super(props);
|
||||
this.state = {
|
||||
dataSource: [], columns: [], loading: false, pageInfo: { current: 1, pageSize: 10, total: 0 },
|
||||
conditions: []
|
||||
};
|
||||
}
|
||||
|
||||
componentWillReceiveProps(nextProps, nextContext) {
|
||||
if (nextProps.visible !== this.props.visible && nextProps.visible) {
|
||||
this.setState({
|
||||
conditions: _.map(RQconditions, item => ({
|
||||
...item,
|
||||
items: _.map(item.items, o => {
|
||||
o = { ...o, label: getLabel(o.lanId, o.label) };
|
||||
if (getKey(o) === "startMonthStr") {
|
||||
return {
|
||||
...o, value: moment(new Date()).subtract(1, "year").startOf("year").format("YYYY-MM")
|
||||
};
|
||||
} else if (getKey(o) === "endMonthStr") {
|
||||
return {
|
||||
...o, value: moment(new Date()).endOf("year").format("YYYY-MM")
|
||||
};
|
||||
}
|
||||
return o;
|
||||
})
|
||||
}))
|
||||
}, () => {
|
||||
form.initFormFields(this.state.conditions);
|
||||
this.getSalaryAcctList();
|
||||
});
|
||||
} else {
|
||||
form.resetForm();
|
||||
}
|
||||
}
|
||||
|
||||
getSalaryAcctList = () => {
|
||||
const { pageInfo } = this.state, payload = { ...pageInfo, ...form.getFormParams() };
|
||||
this.setState({ loading: true });
|
||||
getSalaryAcctList(payload).then(({ status, data }) => {
|
||||
this.setState({ loading: false });
|
||||
if (status) {
|
||||
const { columns, list: dataSource, pageNum: current, pageSize, total } = data;
|
||||
this.setState({
|
||||
dataSource, pageInfo: { current, pageSize, total },
|
||||
columns: _.filter(columns, it => (it.dataIndex !== "backCalcStatus" && it.dataIndex !== "acctTimes" && it.dataIndex !== "operate"))
|
||||
});
|
||||
}
|
||||
}).catch(() => this.setState({ loading: false }));
|
||||
};
|
||||
save = (record) => {
|
||||
console.log(record);
|
||||
};
|
||||
|
||||
render() {
|
||||
const { loading, conditions, dataSource, columns, pageInfo } = this.state;
|
||||
const pagination = {
|
||||
...pageInfo,
|
||||
showTotal: total => `${getLabel(18609, "共")} ${total} ${getLabel(18256, "条")}`,
|
||||
showQuickJumper: true,
|
||||
showSizeChanger: true,
|
||||
pageSizeOptions: ["10", "20", "50", "100"],
|
||||
onShowSizeChange: (current, pageSize) => {
|
||||
this.setState({ pageInfo: { ...pageInfo, current, pageSize } }, () => this.getSalaryAcctList());
|
||||
},
|
||||
onChange: current => {
|
||||
this.setState({ pageInfo: { ...pageInfo, current } }, () => this.getSalaryAcctList());
|
||||
}
|
||||
};
|
||||
const itemRender = {
|
||||
name: (field, textAreaProps, form, formParams) => {
|
||||
return (<WeaSwitch fieldConfig={{ ...field, ...textAreaProps }} form={form} formParams={formParams}
|
||||
onChange={_.debounce(() => this.getSalaryAcctList(), 500)}/>);
|
||||
},
|
||||
startMonthStr: () => null,
|
||||
endMonthStr: () => null
|
||||
};
|
||||
const childrenComponents = {
|
||||
startMonthStr: () => {
|
||||
const { startMonthStr, endMonthStr } = form.getFormParams();
|
||||
const coms = [], { fieldMap } = form;
|
||||
const dateRange = [startMonthStr, endMonthStr];
|
||||
coms.push(
|
||||
<WeaFormItem label={<span>{fieldMap["startMonthStr"].label}</span>} labelCol={{ span: 6 }}
|
||||
wrapperCol={{ span: 14 }}>
|
||||
<MonthRangePicker dateRange={dateRange} viewAttr={2} onChange={v => {
|
||||
const [v1, v2] = v;
|
||||
form.updateFields({ startMonthStr: v1, endMonthStr: v2 });
|
||||
this.getSalaryAcctList();
|
||||
}}/>
|
||||
</WeaFormItem>
|
||||
);
|
||||
return [{ com: coms, col: 2 }];
|
||||
}
|
||||
};
|
||||
console.log(this.refs.recordRef);
|
||||
return (<WeaDialog {...this.props} style={{ width: 1000 }} initLoadCss className="record-dialog"
|
||||
title={getLabel(111, "创建推送记录")} ref="recordRef" buttons={[
|
||||
<Button onClick={this.props.onCancel}>{getLabel(111, "取消")}</Button>
|
||||
]}>
|
||||
<FormInfo className="record-form" center={false} itemRender={itemRender} colCount={2}
|
||||
form={form} formFields={conditions} childrenComponents={childrenComponents}/>
|
||||
<WeaTable className="wea-browser-table-cursor" rowKey="id" scroll={{ y: "calc(100vh - 152px)" }}
|
||||
dataSource={dataSource} loading={loading} pagination={pagination} columns={columns}
|
||||
onRowClick={this.save}/>
|
||||
</WeaDialog>);
|
||||
}
|
||||
}
|
||||
|
||||
export default CreatePushRecordDialog;
|
||||
|
|
@ -27,7 +27,7 @@ class Index extends Component {
|
|||
}
|
||||
|
||||
componentWillUnmount() {
|
||||
this.setState({ selectedRowKeys: [] });
|
||||
this.setState({ selectedRowKeys: [] }, () => this.props.onChange("rowKey", []));
|
||||
}
|
||||
|
||||
componentWillReceiveProps(nextProps, nextContext) {
|
||||
|
|
@ -49,9 +49,9 @@ class Index extends Component {
|
|||
columns: [...columns, {
|
||||
title: getLabel(111, "操作"), dataIndex: "opts", width: 140, render: (__, record) => (<React.Fragment>
|
||||
<a href="javascript: void(0);" style={{ marginRight: 10 }}
|
||||
onClick={() => _.debounce(this.props.onChange("push", record), 300)}>{getLabel(111, "推送")}</a>
|
||||
onClick={_.debounce(() => this.props.onChange("push", record), 300)}>{getLabel(111, "推送")}</a>
|
||||
<a href="javascript: void(0);" style={{ marginRight: 10 }}
|
||||
onClick={() => this.props.onChange("withdraw", record)}>{getLabel(111, "撤回")}</a>
|
||||
onClick={_.debounce(() => this.props.onChange("withdraw", record), 300)}>{getLabel(111, "撤回")}</a>
|
||||
<a href="javascript: void(0);"
|
||||
onClick={() => this.props.onChange("view", record)}>{getLabel(111, "查看详情")}</a>
|
||||
</React.Fragment>)
|
||||
|
|
@ -78,9 +78,9 @@ class Index extends Component {
|
|||
};
|
||||
const rowSelection = {
|
||||
selectedRowKeys,
|
||||
onChange: v => this.setState({ selectedRowKeys: v })
|
||||
onChange: v => this.setState({ selectedRowKeys: v }, () => this.props.onChange("rowKey", v))
|
||||
};
|
||||
return (<WeaTable loading={loading} dataSource={dataSource} columns={columns} pagination={pagination}
|
||||
return (<WeaTable rowKey="id" loading={loading} dataSource={dataSource} columns={columns} pagination={pagination}
|
||||
rowSelection={rowSelection} scroll={{ y: `calc(100vh - 182px)` }}/>);
|
||||
}
|
||||
}
|
||||
|
|
|
|||
|
|
@ -145,3 +145,43 @@ export const PDConditions = [
|
|||
defaultshow: true
|
||||
}
|
||||
];// 推送详细配置表单
|
||||
|
||||
|
||||
export const RQconditions = [
|
||||
{
|
||||
items: [
|
||||
{
|
||||
conditionType: "MONTHPICKER",
|
||||
domkey: ["startMonthStr"],
|
||||
fieldcol: 14,
|
||||
label: "薪资所属月",
|
||||
lanId: 111,
|
||||
labelcol: 6,
|
||||
value: "",
|
||||
viewAttr: 2
|
||||
},
|
||||
{
|
||||
conditionType: "MONTHPICKER",
|
||||
domkey: ["endMonthStr"],
|
||||
fieldcol: 14,
|
||||
label: "薪资所属月",
|
||||
lanId: 111,
|
||||
labelcol: 6,
|
||||
value: "",
|
||||
viewAttr: 2
|
||||
},
|
||||
{
|
||||
conditionType: "INPUT",
|
||||
domkey: ["name"],
|
||||
fieldcol: 14,
|
||||
label: "薪资账套",
|
||||
lanId: 111,
|
||||
labelcol: 6,
|
||||
value: "",
|
||||
viewAttr: 2
|
||||
}
|
||||
],
|
||||
title: "",
|
||||
defaultshow: true
|
||||
}
|
||||
];// 推送记录查询表单
|
||||
|
|
|
|||
|
|
@ -18,6 +18,7 @@ import PushDetailDialog from "./components/pushRecord/pushDetailDialog";
|
|||
import { Button, message, Modal } from "antd";
|
||||
import cs from "classnames";
|
||||
import "./index.less";
|
||||
import CreatePushRecordDialog from "./components/pushRecord/createPushRecordDialog";
|
||||
|
||||
const getLabel = WeaLocaleProvider.getLabel;
|
||||
|
||||
|
|
@ -27,7 +28,8 @@ class Index extends Component {
|
|||
constructor(props) {
|
||||
super(props);
|
||||
this.state = {
|
||||
selectedKey: "pushRecord", isQuery: false, query: { name: "" },
|
||||
selectedKey: "pushRecord", isQuery: false, query: { name: "" }, selectedRowKeys: [],
|
||||
loading: { push: false, withdraw: false }, visible: false,
|
||||
DPDialog: { visible: false, title: "", detail: {} }, //数据推送弹框
|
||||
pushDetailDialog: { visible: false, recordId: "" } //数据推送记录查看推送详情弹框
|
||||
};
|
||||
|
|
@ -60,23 +62,71 @@ class Index extends Component {
|
|||
case "view":
|
||||
this.setState({ pushDetailDialog: { visible: true, recordId: detail.id } });
|
||||
break;
|
||||
case "rowKey":
|
||||
this.setState({ selectedRowKeys: detail });
|
||||
break;
|
||||
case "addRecord":
|
||||
this.setState({ visible: true });
|
||||
break;
|
||||
case "push":
|
||||
console.log(detail)
|
||||
case "batchpush":
|
||||
if (type === "batchpush" && _.isEmpty(this.state.selectedRowKeys)) {
|
||||
message.warning(getLabel(111, "请选择数据"));
|
||||
return;
|
||||
}
|
||||
this.pushRecords(type === "push" ? [detail.id] : this.state.selectedRowKeys);
|
||||
break;
|
||||
case "withdraw":
|
||||
case "batchwithdraw":
|
||||
if (type === "batchwithdraw" && _.isEmpty(this.state.selectedRowKeys)) {
|
||||
message.warning(getLabel(111, "请选择数据"));
|
||||
return;
|
||||
}
|
||||
this.withdrawRecords(type === "withdraw" ? [detail.id] : this.state.selectedRowKeys);
|
||||
break;
|
||||
default:
|
||||
break;
|
||||
}
|
||||
};
|
||||
pushRecords = (ids) => {
|
||||
this.setState({ loading: { ...this.state.loading, push: true } });
|
||||
API.pushRecords({ ids }).then(({ status, errormsg }) => {
|
||||
this.setState({ loading: { ...this.state.loading, push: false } });
|
||||
if (status) {
|
||||
this.handleAdvanceSearch();
|
||||
message.success(getLabel(111, "推送成功!"));
|
||||
} else {
|
||||
message.error(errormsg);
|
||||
}
|
||||
});
|
||||
};
|
||||
withdrawRecords = (ids) => {
|
||||
this.setState({ loading: { ...this.state.loading, withdraw: true } });
|
||||
API.withdrawRecords({ ids }).then(({ status, errormsg }) => {
|
||||
this.setState({ loading: { ...this.state.loading, withdraw: false } });
|
||||
if (status) {
|
||||
this.handleAdvanceSearch();
|
||||
message.success(getLabel(111, "撤回成功!"));
|
||||
} else {
|
||||
message.error(errormsg);
|
||||
}
|
||||
});
|
||||
};
|
||||
|
||||
render() {
|
||||
const { selectedKey, DPDialog, isQuery, query, pushDetailDialog } = this.state;
|
||||
const { selectedKey, DPDialog, isQuery, query, pushDetailDialog, loading, visible } = this.state;
|
||||
const { taxAgentStore: { PageAndOptAuth } } = this.props;
|
||||
const showOperateBtn = PageAndOptAuth.opts.includes("admin");
|
||||
const tabs = [
|
||||
{
|
||||
title: getLabel(111, "推送记录"), key: "pushRecord", showDropIcon: false, dropMenuDatas: [],
|
||||
buttons: showOperateBtn ? [
|
||||
<Button type="primary" onClick={() => this.handleOperate("batchpush")}>{getLabel(111, "批量推送")}</Button>,
|
||||
<Button type="primary" onClick={() => this.handleOperate("addRecord")}
|
||||
loading={loading.add}>{getLabel(111, "创建")}</Button>,
|
||||
<Button type="primary" onClick={() => this.handleOperate("batchpush")}
|
||||
loading={loading.push}>{getLabel(111, "批量推送")}</Button>,
|
||||
<Button type="ghost" loading={loading.withdraw}
|
||||
onClick={() => this.handleOperate("batchwithdraw")}>{getLabel(111, "批量撤回")}</Button>,
|
||||
<WeaInputSearch style={{ top: -3 }} value={query.name} onSearch={this.handleAdvanceSearch}
|
||||
onChange={v => this.setState({ query: { ...query, name: v } })}/>
|
||||
] : [<WeaInputSearch style={{ top: -3 }} value={query.name} onSearch={this.handleAdvanceSearch}
|
||||
|
|
@ -115,6 +165,7 @@ class Index extends Component {
|
|||
<PushDetailDialog {...pushDetailDialog} onClose={() => this.setState({
|
||||
pushDetailDialog: { ...pushDetailDialog, visible: false }
|
||||
})}/>
|
||||
<CreatePushRecordDialog visible={visible} onCancel={() => this.setState({ visible: false })}/>
|
||||
</WeaReqTop>
|
||||
);
|
||||
}
|
||||
|
|
|
|||
|
|
@ -167,3 +167,28 @@
|
|||
}
|
||||
}
|
||||
}
|
||||
|
||||
.record-dialog {
|
||||
.wea-dialog-body {
|
||||
background: #f6f6f6;
|
||||
padding: 8px 16px;
|
||||
|
||||
.record-form {
|
||||
background: #FFF;
|
||||
margin-bottom: 8px;
|
||||
|
||||
.wea-search-group, .wea-content {
|
||||
padding: 0;
|
||||
}
|
||||
|
||||
.rangePickerBox {
|
||||
display: flex;
|
||||
align-items: center;
|
||||
}
|
||||
}
|
||||
|
||||
.wea-new-table {
|
||||
background: #FFF;
|
||||
}
|
||||
}
|
||||
}
|
||||
|
|
|
|||
Loading…
Reference in New Issue