Jelajahi Sumber

添加积分;付款成功后添加积分

lrf 2 tahun lalu
induk
melakukan
118bd0d195

+ 39 - 0
app/controller/user/config/.point.js

@@ -0,0 +1,39 @@
+module.exports = {
+  create: {
+    requestBody: ['customer', 'point', 'time', 'status', 'source'],
+  },
+  destroy: {
+    params: ['!id'],
+    service: 'delete',
+  },
+  update: {
+    params: ['!id'],
+    requestBody: ['customer', 'point', 'time', 'status', 'source'],
+  },
+  show: {
+    parameters: {
+      params: ['!id'],
+    },
+    service: 'fetch',
+  },
+  index: {
+    parameters: {
+      query: {
+        'meta.createdAt@start': 'meta.createdAt@start',
+        'meta.createdAt@end': 'meta.createdAt@end',
+        customer: 'customer',
+        status: 'status',
+      },
+      // options: {
+      //   "meta.state": 0 // 默认条件
+      // },
+    },
+    service: 'query',
+    options: {
+      query: ['skip', 'limit'],
+      sort: ['meta.createdAt'],
+      desc: true,
+      count: true,
+    },
+  },
+};

+ 13 - 0
app/controller/user/point.js

@@ -0,0 +1,13 @@
+'use strict';
+const meta = require('./config/.point.js');
+const Controller = require('egg').Controller;
+const { CrudController } = require('naf-framework-mongoose-free/lib/controller');
+
+// 
+class PointController extends Controller {
+  constructor(ctx) {
+    super(ctx);
+    this.service = this.ctx.service.user.point;
+  }
+}
+module.exports = CrudController(PointController, meta);

+ 24 - 0
app/model/user/point.js

@@ -0,0 +1,24 @@
+'use strict';
+const Schema = require('mongoose').Schema;
+const metaPlugin = require('naf-framework-mongoose-free/lib/model/meta-plugin');
+
+// 积分表明细
+const point = {
+  customer: { type: String, required: false, zh: '顾客', ref: 'User.User' }, //
+  point: { type: Number, required: false, zh: '积分' }, // 整数
+  time: { type: String, required: false, zh: '时间' }, //
+  status: { type: String, required: false, default: '0', zh: '状态' }, // 字典:point_status
+  source: { type: String, required: false, zh: '来源' }, // 字典:point_source
+};
+const schema = new Schema(point, { toJSON: { getters: true, virtuals: true } });
+schema.index({ id: 1 });
+schema.index({ 'meta.createdAt': 1 });
+schema.index({ customer: 1 });
+schema.index({ status: 1 });
+
+schema.plugin(metaPlugin);
+
+module.exports = app => {
+  const { mongoose } = app;
+  return mongoose.model('Point', schema, 'point');
+};

+ 22 - 1
app/service/trade/pay.js

@@ -4,7 +4,7 @@ const { BusinessError, ErrorCode } = require('naf-core').Error;
 const _ = require('lodash');
 const assert = require('assert');
 const Transaction = require('mongoose-transactions');
-
+const moment = require('moment');
 //
 class PayService extends CrudService {
   constructor(ctx) {
@@ -14,6 +14,8 @@ class PayService extends CrudService {
     this.orderModel = this.ctx.model.Trade.Order;
     this.dictDataModel = this.ctx.model.Dev.DictData;
     this.payOrderReturnUrl = this.app.config.payReturn.order;
+    this.userModel = this.ctx.model.User.User;
+    this.pointModel = this.ctx.model.User.Point;
     this.wxDomain = _.get(this.app, 'config.httpPrefix.wechat');
     this.tran = new Transaction();
   }
@@ -108,6 +110,25 @@ class PayService extends CrudService {
     payData.result = result;
     // 修改状态
     await this.orderModel.updateOne(query, { pay: payData, status: '1' });
+
+    // 10块钱给1积分,不到10块不给
+    const pay_money = _.get(orderData, 'pay.pay_money');
+    if (!_.isNumber(pay_money) || pay_money < 10) return;
+    const point = _.floor(pay_money / 10);
+    // 添加积分
+    const user = await this.userModel.findOne({ openid });
+    if (!user) {
+      console.error('未找到用户信息----添加积分');
+      return;
+    }
+    const customer = _.get(user, '_id');
+    const pointData = {
+      customer,
+      point,
+      time: moment().format('YYYY-MM-D HH:mm:ss'),
+      source: '0',
+    };
+    await this.pointModel.create(pointData);
   }
 
   /**

+ 15 - 0
app/service/user/point.js

@@ -0,0 +1,15 @@
+'use strict';
+const { CrudService } = require('naf-framework-mongoose-free/lib/service');
+const { BusinessError, ErrorCode } = require('naf-core').Error;
+const _ = require('lodash');
+const assert = require('assert');
+
+// 
+class PointService extends CrudService {
+  constructor(ctx) {
+    super(ctx, 'point');
+    this.model = this.ctx.model.User.Point;
+  }
+}
+
+module.exports = PointService;

+ 1 - 0
app/z_router/user/index.js

@@ -5,4 +5,5 @@ module.exports = app => {
   require('./admin')(app); // 管理员
   require('./user')(app); // 用户
   require('./address')(app); // 收货地址
+  require('./point')(app); // 积分
 };

+ 19 - 0
app/z_router/user/point.js

@@ -0,0 +1,19 @@
+'use strict';
+// 路由配置
+const path = require('path');
+const regPath = path.resolve('app', 'public', 'routerRegister');
+const routerRegister = require(regPath);
+const rkey = 'point';
+const ckey = 'user.point';
+const keyZh = '积分';
+const routes = [
+  { 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);
+};