You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
36 lines
1.2 KiB
36 lines
1.2 KiB
'use strict';
|
|
const fs = require('fs');
|
|
const moment = require('moment');
|
|
/**
|
|
* 查询员工沟通统计数据
|
|
* @param {*} ctx ctx ctx.query:{keywordTarget-关键字项、keyword-关键字内容、timeRange-沟通时间、limit-页宽, page-页码}
|
|
*/
|
|
async function get(ctx) {
|
|
try {
|
|
const { models } = ctx.fs.dc;
|
|
const { keywordTarget, keyword, timeRange, limit, page } = ctx.query;
|
|
const where = {};
|
|
if (keywordTarget && keyword) {
|
|
where[keywordTarget] = { $iLike: `%${keyword}%` };
|
|
}
|
|
if(timeRange){
|
|
where.communicateDate= { $between: timeRange.split(',') };
|
|
}
|
|
let employeeCommunicate = await models.EmployeeCommunicate.findAndCountAll({
|
|
where: where,
|
|
offset: Number(page) * Number(limit),
|
|
limit: Number(limit),
|
|
order: [['id', 'ASC']]
|
|
});
|
|
ctx.status = 200
|
|
ctx.body = employeeCommunicate;
|
|
} catch (error) {
|
|
ctx.fs.logger.error(`path:${ctx.path},error:${error}`)
|
|
ctx.status = 400;
|
|
ctx.body = { name: 'FindError', message: '查询员工沟通统计数据失败' }
|
|
}
|
|
}
|
|
|
|
module.exports = {
|
|
get
|
|
}
|