lrf 2 years ago
parent
commit
4a75a631e2

+ 7 - 0
app/controller/user/config/.cashBack.js

@@ -38,4 +38,11 @@ module.exports = {
       count: true,
     },
   },
+  computedTotal: {
+    parameters: {
+      query: {
+        customer: 'customer',
+      },
+    },
+  },
 };

+ 2 - 1
app/model/user/cashBack.js

@@ -7,9 +7,10 @@ const MoneyPlugin = require('naf-framework-mongoose-free/lib/model/type-money-pl
 // 返现记录表
 const cashBack = {
   inviter: { type: String, required: false, zh: '推荐人', ref: 'User.User' }, //
-  order_detail: { type: String, required: false, zh: '订单', ref: 'Trade.OrderDetail' }, //
   time: { type: String, required: false, zh: '返现时间' }, //
   status: { type: String, required: false, default: '0', zh: '状态' }, // 字典:cashBack_status
+  source: { type: String, required: false, zh: '来源' }, // 字典:cashBack_source
+  source_id: { type: String, required: false, zh: '来源id' }, //
 };
 const schema = new Schema(cashBack, { toJSON: { getters: true, virtuals: true } });
 schema.index({ id: 1 });

+ 15 - 1
app/service/user/cashBack.js

@@ -11,6 +11,17 @@ class CashBackService extends CrudService {
     this.model = this.ctx.model.User.CashBack;
     this.orderDetailModel = this.ctx.model.Trade.OrderDetail;
   }
+
+  async computedTotal({ customer }) {
+    assert(customer, '缺少用户信息');
+    const res = await this.model.find({ inviter: customer });
+    const total = res.reduce((p, n) => {
+      let point = n.point;
+      if (!(n.source === '0' || n.source === '1')) point = -point;
+      return this.ctx.plus(p, point);
+    }, 0);
+    return total;
+  }
   /**
    * 添加检查返现
    * @param {String} orderDetail_id 订单详情id
@@ -47,7 +58,10 @@ class CashBackService extends CrudService {
     }
     const { inviter, _id: order_detail } = orderDetail;
     if (!inviter) return;
-    const obj = { inviter: _.get(inviter, '_id'), order_detail, money: rmoney, time: moment().format('YYYY-MM-DD HH:mm:ss') };
+    const obj = { inviter: _.get(inviter, '_id'), source_id: order_detail, source: '0', money: rmoney, time: moment().format('YYYY-MM-DD HH:mm:ss') };
+    // 检查是否已经返利
+    const num = await this.model.count({ inviter, source_id: order_detail, source: '0' });
+    if (num > 0) return;
     tran.insert('CashBack', obj);
   }
 }

+ 20 - 0
app/z_router/user/cashBack.js

@@ -0,0 +1,20 @@
+'use strict';
+// 路由配置
+const path = require('path');
+const regPath = path.resolve('app', 'public', 'routerRegister');
+const routerRegister = require(regPath);
+const rkey = 'cashBack';
+const ckey = 'user.cashBack';
+const keyZh = '返现';
+const routes = [
+  { method: 'get', path: `${rkey}/computedTotal`, controller: `${ckey}.computedTotal`, name: `${ckey}computedTotal`, zh: `${keyZh}计算总分` },
+  { method: 'get', path: `${rkey}`, controller: `${ckey}.index`, name: `${ckey}Query`, zh: `${keyZh}列表查询` },
+  { method: 'get', path: `${rkey}/:id`, controller: `${ckey}.show`, name: `${ckey}Show`, zh: `${keyZh}查询` },
+  { method: 'post', path: `${rkey}`, controller: `${ckey}.create`, name: `${ckey}Create`, zh: `创建${keyZh}` },
+  { method: 'post', path: `${rkey}/:id`, controller: `${ckey}.update`, name: `${ckey}Update`, zh: `修改${keyZh}` },
+  { method: 'delete', path: `${rkey}/:id`, controller: `${ckey}.destroy`, name: `${ckey}Delete`, zh: `删除${keyZh}` },
+];
+
+module.exports = app => {
+  routerRegister(app, routes, keyZh, rkey, ckey);
+};