Browse Source

(*)岗位评级:1. 列表查询评级时间倒序;2. 导入模板增加姓名

3. 员工信息【技术职级等级】替换真实数据
master
周沫沫历险记 2 years ago
parent
commit
bb14f7e38d
  1. 41
      api/app/lib/controllers/member/index.js
  2. 13
      web/client/src/sections/humanAffairs/components/importPositionRating.jsx
  3. 2
      web/client/src/sections/humanAffairs/containers/employeeInformation.jsx
  4. 2
      web/client/src/sections/humanAffairs/containers/positionRating.jsx

41
api/app/lib/controllers/member/index.js

@ -707,7 +707,9 @@ async function getPositionRating(ctx) {
const { models } = ctx.fs.dc; const { models } = ctx.fs.dc;
const { limit, page } = ctx.query; const { limit, page } = ctx.query;
const findObj = {}; const findObj = {
order: [["ratingTime", "desc"]]
};
if (Number(limit) > 0 && Number(page) >= 0) { if (Number(limit) > 0 && Number(page) >= 0) {
findObj.limit = Number(limit); findObj.limit = Number(limit);
findObj.offset = Number(page) * Number(limit); findObj.offset = Number(page) * Number(limit);
@ -786,25 +788,23 @@ async function postPositionRating(ctx) {
//处理新增的 //处理新增的
if (data) { if (data) {
const dataToUpdate = [];
if (data.length) { if (data.length) {
const dataToSave = [];
const dataToUpdate = [];
data.map((item) => { data.map((item) => {
const { pepUserId, technicalGrade } = item; const { pepUserId, technicalGrade } = item;
dataToUpdate.push({ pepUserId, technicalGrade }); dataToUpdate.push({ pepUserId, technicalGrade });
}) })
await models.PositionRating.bulkCreate(data, { transaction }); 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 { else {
await models.PositionRating.create(data, { transaction }); await models.PositionRating.create(data, { transaction });
await models.Member.update({ technicalGrade: data.technicalGrade }, dataToUpdate.push({ pepUserId: data.pepUserId, technicalGtechnicalGrade: data.technicalGraderade });
{ where: { pepUserId: data.pepUserId }, transaction }); }
for (let item in dataToUpdate) {
await models.Member.update({ technicalGrade: dataToUpdate[item].technicalGrade },
{ where: { pepUserId: dataToUpdate[item].pepUserId }, transaction });
} }
//更新member表字段
} }
await transaction.commit(); await transaction.commit();
@ -824,11 +824,30 @@ async function delPositionRating(ctx) {
const oldData = await models.PositionRating.findOne({ where: { id: id } }); const oldData = await models.PositionRating.findOne({ where: { id: id } });
if (oldData) { 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 }); await models.PositionRating.destroy({ where: { id: id }, transaction });
} }
transaction.commit();
ctx.status = 204; ctx.status = 204;
} catch (error) { } catch (error) {
transaction.rollback();
ctx.fs.logger.error(`path: ${ctx.path}, error: ${error}`); ctx.fs.logger.error(`path: ${ctx.path}, error: ${error}`);
ctx.status = 400; ctx.status = 400;
ctx.body = { ctx.body = {

13
web/client/src/sections/humanAffairs/components/importPositionRating.jsx

@ -32,11 +32,12 @@ const ImportPositionRatingModal = props => {
} }
const download = () => { 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: {} }; let workbook = { SheetNames: [SHEETNAME], Sheets: {} };
workbook.Sheets[SHEETNAME] = XLSX.utils.aoa_to_sheet(head);//jsonexcel workbook.Sheets[SHEETNAME] = XLSX.utils.aoa_to_sheet([head]);//jsonexcel
workbook.Sheets[SHEETNAME]['!cols'] = [ 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 }]; { wch: 30 }, { wch: 13 }];
let wopts = { bookType: 'xlsx', type: 'buffer' };// excel let wopts = { bookType: 'xlsx', type: 'buffer' };// excel
XLSX.writeFile(workbook, `${SHEETNAME}导入模板.xlsx`, wopts); XLSX.writeFile(workbook, `${SHEETNAME}导入模板.xlsx`, wopts);
@ -152,9 +153,9 @@ const ImportPositionRatingModal = props => {
if (!member) { if (!member) {
errmsg = `${i + 2}行【${IMPORT_FIELD[item].label}${obj.userCode}未匹配到数据,请检查该员工是否添加`; errmsg = `${i + 2}行【${IMPORT_FIELD[item].label}${obj.userCode}未匹配到数据,请检查该员工是否添加`;
break; break;
} else if (postData.find(m => m.userCode == obj.userCode)) { // } else if (postData.find(m => m.userCode == obj.userCode)) {
errmsg = `${i + 2}行【${IMPORT_FIELD[item].label}${obj.userCode}已存在,请检查`; // errmsg = `${i + 2}${IMPORT_FIELD[item].label}${obj.userCode},`;
break; // break;
} else { } else {
obj.pepUserId = member.pepUserId; obj.pepUserId = member.pepUserId;
} }

2
web/client/src/sections/humanAffairs/containers/employeeInformation.jsx

@ -263,7 +263,7 @@ const employeeInformation = (props) => {
width: 150, width: 150,
dataIndex: "technicalGrade", dataIndex: "technicalGrade",
key: "technicalGrade", key: "technicalGrade",
render: (_, r, index) => <span>-</span>, // render: (_, r, index) => <span>-</span>,
}, { }, {
title: '证件号', title: '证件号',
width: 180, width: 180,

2
web/client/src/sections/humanAffairs/containers/positionRating.jsx

@ -93,7 +93,7 @@ const PositionRating = (props) => {
}, { }, {
title: ( title: (
<div> <div>
<img src="/assets/images/hrImg/V.png" alt="" style={{ width: 14, height: 14 }} /> 现在职岗位 <img src="/assets/images/hrImg/V.png" alt="" style={{ width: 14, height: 14 }} /> 岗位
</div> </div>
), ),
width: 120, width: 120,

Loading…
Cancel
Save