From bb14f7e38d5dcff0d1761f46ad61492680a2873c Mon Sep 17 00:00:00 2001 From: zhouxin Date: Wed, 28 Dec 2022 11:00:33 +0800 Subject: [PATCH] =?UTF-8?q?(*)=E5=B2=97=E4=BD=8D=E8=AF=84=E7=BA=A7?= =?UTF-8?q?=EF=BC=9A1.=20=E5=88=97=E8=A1=A8=E6=9F=A5=E8=AF=A2=E8=AF=84?= =?UTF-8?q?=E7=BA=A7=E6=97=B6=E9=97=B4=E5=80=92=E5=BA=8F=EF=BC=9B2.=20?= =?UTF-8?q?=E5=AF=BC=E5=85=A5=E6=A8=A1=E6=9D=BF=E5=A2=9E=E5=8A=A0=E5=A7=93?= =?UTF-8?q?=E5=90=8D=203.=20=E5=91=98=E5=B7=A5=E4=BF=A1=E6=81=AF=E3=80=90?= =?UTF-8?q?=E6=8A=80=E6=9C=AF=E8=81=8C=E7=BA=A7=E7=AD=89=E7=BA=A7=E3=80=91?= =?UTF-8?q?=E6=9B=BF=E6=8D=A2=E7=9C=9F=E5=AE=9E=E6=95=B0=E6=8D=AE?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- api/app/lib/controllers/member/index.js | 41 ++++++++++++++----- .../components/importPositionRating.jsx | 13 +++--- .../containers/employeeInformation.jsx | 2 +- .../containers/positionRating.jsx | 2 +- 4 files changed, 39 insertions(+), 19 deletions(-) diff --git a/api/app/lib/controllers/member/index.js b/api/app/lib/controllers/member/index.js index ae97fd8..92c310f 100644 --- a/api/app/lib/controllers/member/index.js +++ b/api/app/lib/controllers/member/index.js @@ -707,7 +707,9 @@ async function getPositionRating(ctx) { const { models } = ctx.fs.dc; const { limit, page } = ctx.query; - const findObj = {}; + const findObj = { + order: [["ratingTime", "desc"]] + }; if (Number(limit) > 0 && Number(page) >= 0) { findObj.limit = Number(limit); findObj.offset = Number(page) * Number(limit); @@ -786,25 +788,23 @@ async function postPositionRating(ctx) { //处理新增的 if (data) { + const dataToUpdate = []; if (data.length) { - const dataToSave = []; - const dataToUpdate = []; data.map((item) => { const { pepUserId, technicalGrade } = item; dataToUpdate.push({ pepUserId, technicalGrade }); }) await models.PositionRating.bulkCreate(data, { transaction }); - for (let item in dataToUpdate) { - await models.Member.update({ technicalGrade: dataToUpdate[item].technicalGrade }, - { where: { pepUserId: dataToUpdate[item].pepUserId }, transaction }); - } } else { await models.PositionRating.create(data, { transaction }); - await models.Member.update({ technicalGrade: data.technicalGrade }, - { where: { pepUserId: data.pepUserId }, transaction }); + dataToUpdate.push({ pepUserId: data.pepUserId, technicalGtechnicalGrade: data.technicalGraderade }); + } + + for (let item in dataToUpdate) { + await models.Member.update({ technicalGrade: dataToUpdate[item].technicalGrade }, + { where: { pepUserId: dataToUpdate[item].pepUserId }, transaction }); } - //更新member表字段 } await transaction.commit(); @@ -824,11 +824,30 @@ async function delPositionRating(ctx) { const oldData = await models.PositionRating.findOne({ where: { id: id } }); if (oldData) { - //todo 更新memeber技术等级字段 + const positionRating = await models.PositionRating.findAll({ + where: { + pepUserId: oldData.pepUserId, + id: { $not: oldData.id } + }, + attributes: ["technicalGrade"], + order: [["ratingTime", "desc"]] + }); + //更新员工信息中的技术等级 + const technicalGrade = positionRating.length ? positionRating[0].technicalGrade : undefined; + await models.Member.update({ technicalGrade: technicalGrade }, + { + where: { pepUserId: oldData.pepUserId, del: false }, + transaction + }); + await models.PositionRating.destroy({ where: { id: id }, transaction }); + + } + transaction.commit(); ctx.status = 204; } catch (error) { + transaction.rollback(); ctx.fs.logger.error(`path: ${ctx.path}, error: ${error}`); ctx.status = 400; ctx.body = { diff --git a/web/client/src/sections/humanAffairs/components/importPositionRating.jsx b/web/client/src/sections/humanAffairs/components/importPositionRating.jsx index 3adcc5d..7db7f33 100644 --- a/web/client/src/sections/humanAffairs/components/importPositionRating.jsx +++ b/web/client/src/sections/humanAffairs/components/importPositionRating.jsx @@ -32,11 +32,12 @@ const ImportPositionRatingModal = props => { } const download = () => { - const head = [Object.keys(IMPORT_FIELD).map(key => IMPORT_FIELD[key].label)]; + const head = Object.keys(IMPORT_FIELD).map(key => IMPORT_FIELD[key].label); + head.unshift("姓名"); let workbook = { SheetNames: [SHEETNAME], Sheets: {} }; - workbook.Sheets[SHEETNAME] = XLSX.utils.aoa_to_sheet(head);//json转excel + workbook.Sheets[SHEETNAME] = XLSX.utils.aoa_to_sheet([head]);//json转excel workbook.Sheets[SHEETNAME]['!cols'] = [ - { wch: 13 }, { wch: 12 }, { wch: 18 }, { wch: 30 }, { wch: 11 }, + { wch: 13 }, { wch: 13 }, { wch: 12 }, { wch: 18 }, { wch: 30 }, { wch: 11 }, { wch: 30 }, { wch: 13 }]; let wopts = { bookType: 'xlsx', type: 'buffer' };// 生成excel的配置项 XLSX.writeFile(workbook, `${SHEETNAME}导入模板.xlsx`, wopts); @@ -152,9 +153,9 @@ const ImportPositionRatingModal = props => { if (!member) { errmsg = `第${i + 2}行【${IMPORT_FIELD[item].label}】${obj.userCode}未匹配到数据,请检查该员工是否添加`; break; - } else if (postData.find(m => m.userCode == obj.userCode)) { - errmsg = `第${i + 2}行【${IMPORT_FIELD[item].label}】${obj.userCode}已存在,请检查`; - break; + // } else if (postData.find(m => m.userCode == obj.userCode)) { + // errmsg = `第${i + 2}行【${IMPORT_FIELD[item].label}】${obj.userCode}已存在,请检查`; + // break; } else { obj.pepUserId = member.pepUserId; } diff --git a/web/client/src/sections/humanAffairs/containers/employeeInformation.jsx b/web/client/src/sections/humanAffairs/containers/employeeInformation.jsx index 1fcdeff..f3253ac 100644 --- a/web/client/src/sections/humanAffairs/containers/employeeInformation.jsx +++ b/web/client/src/sections/humanAffairs/containers/employeeInformation.jsx @@ -263,7 +263,7 @@ const employeeInformation = (props) => { width: 150, dataIndex: "technicalGrade", key: "technicalGrade", - render: (_, r, index) => -, + // render: (_, r, index) => -, }, { title: '证件号', width: 180, diff --git a/web/client/src/sections/humanAffairs/containers/positionRating.jsx b/web/client/src/sections/humanAffairs/containers/positionRating.jsx index c24c828..41b40b2 100644 --- a/web/client/src/sections/humanAffairs/containers/positionRating.jsx +++ b/web/client/src/sections/humanAffairs/containers/positionRating.jsx @@ -93,7 +93,7 @@ const PositionRating = (props) => { }, { title: (
- 现在职岗位 + 岗位
), width: 120,