| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081 | 'use strict';/** * * * @author Mai * @date 2018/8/14 * @version */module.exports = app => {    class ChangeCompany extends app.BaseService {        /**         * 构造函数         *         * @param {Object} ctx - egg全局变量         * @return {void}         */        constructor(ctx) {            super(ctx);            this.tableName = 'change_company';        }        /**         * 队列修改和添加公司信息         * @param {Object} data - 公司信息集合         * @return {Object} - 返回新增的公司列表,和替换下拉选择公司列表         */        async setCompanyList(data) {            const tenderId = parseInt(data.tid);            const updateIdArray = data.uci;            const updateArray = data.uc;            const addArray = data.ac;            const addCompany = [];            const selectCompany = [];            // 初始化事务            this.transaction = await this.db.beginTransaction();            try {                // 更新公司信息                if (updateIdArray.length !== 0) {                    for (const index in updateIdArray) {                        if (updateArray[index].trim() === '') {                            await this.transaction.delete(this.tableName, { id: updateIdArray[index] });                        } else {                            const updateData = {                                id: updateIdArray[index],                                name: updateArray[index],                            };                            await this.transaction.update(this.tableName, updateData);                            selectCompany.push(updateData);                        }                    }                }                if (addArray.length !== 0) {                    for (const name of addArray) {                        const addData = {                            tid: tenderId,                            name,                        };                        const operate = await this.transaction.insert(this.tableName, addData);                        if (operate.affectedRows !== 1) {                            throw '提交数据失败';                        } else {                            selectCompany.push({ id: operate.insertId, name });                            addCompany.push({ id: operate.insertId, name });                        }                    }                }                this.transaction.commit();            } catch (error) {                console.log(error);                // 回滚                await this.transaction.rollback();            }            return [addCompany, selectCompany];        }    }    return ChangeCompany;};
 |