123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163 |
- 'use strict';
- /**
- *
- *
- * @author Mai
- * @date
- * @version
- */
- const auditConst = require('../const/audit');
- const accountGroup = require('../const/account_group').group;
- module.exports = app => {
- class SubProjController extends app.BaseController {
- /**
- * 概算投资
- *
- * @param ctx
- * @returns {Promise<void>}
- */
- async index(ctx) {
- try {
- const renderData = {
- jsFiles: this.app.jsFiles.common.concat(this.app.jsFiles.subProject.list),
- auditConst,
- };
- renderData.budgetStd = await ctx.service.budgetStd.getDataByProjectId(ctx.session.sessionProject.id);
- renderData.projectList = await ctx.service.subProject.getSubProject(ctx.session.sessionProject.id, ctx.session.sessionUser.accountId, ctx.session.sessionUser.is_admin);
- renderData.tenderList = await ctx.service.tender.getList4Select('stage');
- const accountList = await ctx.service.projectAccount.getAllDataByCondition({
- where: { project_id: ctx.session.sessionProject.id, enable: 1 },
- columns: ['id', 'name', 'company', 'role', 'enable', 'is_admin', 'account_group', 'mobile'],
- });
- renderData.accountList = accountList;
- renderData.accountGroup = accountGroup.map((item, idx) => {
- const groupList = accountList.filter(item => item.account_group === idx);
- return { groupName: item, groupList };
- });
- renderData.permissionConst = ctx.service.subProjPermission.PermissionConst;
- renderData.categoryData = await this.ctx.service.category.getAllCategory(this.ctx.session.sessionProject.id);
- renderData.companys = await this.ctx.service.constructionUnit.getAllDataByCondition({ where: { pid: ctx.session.sessionProject.id } });
- await this.layout('sub_proj/index.ejs', renderData, 'sub_proj/modal.ejs');
- } catch (err) {
- ctx.log(err);
- }
- }
- async addFolder(ctx) {
- try {
- const data = JSON.parse(ctx.request.body.data);
- if (!data.name || data.name.length > 100) throw '文件夹名称有误';
- const result = await ctx.service.subProject.addFolder(data);
- ctx.body = { err: 0, msg: '', data: result };
- } catch (err) {
- ctx.log(err);
- ctx.ajaxErrorBody(err, '新建文件夹失败');
- }
- }
- async addProj(ctx) {
- try {
- const data = JSON.parse(ctx.request.body.data);
- if (!data.name || data.name.length > 100) throw '项目名称有误';
- const result = await ctx.service.subProject.addSubProject(data);
- ctx.body = { err: 0, msg: '', data: result };
- } catch (err) {
- ctx.log(err);
- ctx.ajaxErrorBody(err, '新建项目失败');
- }
- }
- async dragTo(ctx) {
- try {
- const data = JSON.parse(ctx.request.body.data);
- if (!data.drag_id || !data.drop_id) throw '提交数据错误';
- const result = await ctx.service.subProject.dragTo(data);
- ctx.body = { err: 0, msg: '', data: result };
- } catch (err) {
- ctx.log(err);
- ctx.ajaxErrorBody(err, '调整所属文件夹失败');
- }
- }
- async del(ctx) {
- try {
- const data = JSON.parse(ctx.request.body.data);
- if (!data.id) throw '参数有误';
- const result = await ctx.service.subProject.del(data.id);
- ctx.body = { err: 0, msg: '', data: result };
- } catch(err) {
- ctx.log(err);
- ctx.ajaxErrorBody(err, '删除项目失败');
- }
- }
- async save(ctx) {
- try {
- const data = JSON.parse(ctx.request.body.data);
- if (!data.id) throw '参数有误';
- let result = null;
- if (data.name !== undefined) {
- if (!data.name || data.name.length > 100) throw '项目名称有误';
- result = await ctx.service.subProject.save({ id: data.id, name: data.name });
- } else if (data.rela_tender !== undefined) {
- result = await ctx.service.subProject.setRelaTender({ id: data.id, rela_tender: data.rela_tender });
- } else if (data.std_id !== undefined) {
- result = await ctx.service.subProject.setBudgetStd({ id: data.id, std_id: data.std_id });
- } else if (data.management !== undefined) {
- result = await ctx.service.subProject.setManagement({ id: data.id, management: data.management });
- }
- ctx.body = { err: 0, msg: '', data: { update: [result] } };
- } catch(err) {
- ctx.log(err);
- ctx.ajaxErrorBody(err, '保存数据失败');
- }
- }
- async rela(ctx) {
- try {
- const id = ctx.query.id;
- const projectList = await ctx.service.subProject.getSubProject(this.ctx.session.sessionProject.id, this.ctx.session.sessionUser.accountId, true);
- const otherProj = projectList.filter(x => { return x.id !== id || !x.rela_tender || x.is_folder });
- const _ = ctx.helper._;
- const otherRela = _.map(_.map(otherProj, 'rela_tender').join(',').split(','), _.toInteger);
- const tenderList = await ctx.service.tender.getList4Select('stage');
- ctx.body = {
- err: 0,
- msg: '',
- data: tenderList.filter(x => { return otherRela.indexOf(x.id) === -1})
- .map(y => { return {id: y.id, name: y.name, lastStageOrder: y.lastStage.order, lastStageStatus: auditConst.stage.statusString[y.lastStage.status], category: y.category}}),
- };
- } catch (err) {
- ctx.log(err);
- ctx.postError(err, '获取数据失败');
- }
- }
- async member(ctx) {
- try {
- const data = JSON.parse(ctx.request.body.data);
- const member = await ctx.service.subProjPermission.getPermission(data.id);
- ctx.body = { err: 0, msg: '', data: member };
- } catch (err) {
- ctx.log(err);
- ctx.ajaxErrorBody(err, '查询项目成员失败');
- }
- }
- async memberSave(ctx) {
- try {
- const data = JSON.parse(ctx.request.body.data);
- if (!data.id) throw '参数有误';
- await ctx.service.subProjPermission.savePermission(data.id, data.member);
- ctx.body = { err: 0, msg: '', data: '' };
- } catch (err) {
- ctx.log(err);
- ctx.ajaxErrorBody(err, '保存数据失败');
- }
- }
- }
- return SubProjController;
- };
|