UserPartakeController.php 3.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107
  1. <?php
  2. namespace app\api\controller\user;
  3. use app\models\system\SystemGroupData;
  4. use app\models\user\Out;
  5. use app\models\user\User;
  6. use app\models\user\UserPartake;
  7. use app\Request;
  8. use crmeb\services\GroupDataService;
  9. use crmeb\services\SystemConfigService;
  10. use crmeb\services\UtilService;
  11. use think\facade\Db;
  12. class UserPartakeController
  13. {
  14. /**
  15. * 出局奖励列表
  16. * @return void
  17. */
  18. public function out_list(Request $request)
  19. {
  20. [$page, $limit] = UtilService::getMore([['page', 1], ['limit', 10]], $request, true);
  21. $list = Out::where('status', 1)->where($page, $limit)->order('id DESC')->select()->toArray();
  22. return app('json')->success($list);
  23. }
  24. /**
  25. * 出局奖励列表
  26. * @return void
  27. */
  28. public function out_detail($id, Request $request)
  29. {
  30. $list = Out::where('status', 1)->where('id', $id)->order('id DESC')->find();
  31. $list = $list ? $list->toArray() : [];
  32. return app('json')->success($list);
  33. }
  34. /**
  35. * 参加
  36. * @return void
  37. */
  38. public function participate_in(Request $request)
  39. {
  40. $data = UtilService::postMore([
  41. 'out_id'
  42. ]);
  43. Db::startTrans();
  44. $user = User::where('uid', $request->uid())->find();
  45. if ($user['level'] < 2) return app('json')->fail('等级为团队合伙人才能参与');
  46. $out = Out::where('id', $data['out_id'])->find();
  47. if (empty($out)) return app('json')->fail('参与项目不存在');
  48. if ($out['status'] == 0) return app('json')->fail('参与项目已关闭');
  49. $partake = UserPartake::where('uid', $request->uid())->where('status', 0)->find();
  50. if ($partake) return app('json')->fail('当前已有参与中项目,无法参加');
  51. $res = UserPartake::create([
  52. 'uid' => $request->uid(),
  53. 'out_id' => $data['out_id'],
  54. ]);
  55. if ($res) {
  56. Db::commit();
  57. return app('json')->success('参与成功');
  58. } else {
  59. Db::rollback();
  60. return app('json')->fail('参与失败');
  61. }
  62. }
  63. /**
  64. * 参与记录
  65. * @param Request $request
  66. * @return mixed
  67. * @throws \think\db\exception\DataNotFoundException
  68. * @throws \think\db\exception\DbException
  69. * @throws \think\db\exception\ModelNotFoundException
  70. */
  71. public function partake(Request $request)
  72. {
  73. $where = UtilService::getMore([
  74. ['page', 1],
  75. ['limit', 20],
  76. ]);
  77. $data = UserPartake::alias('a')
  78. ->field('a.*,c.name')
  79. ->order('a.id DESC')
  80. ->leftJoin('out c', 'c.id = a.out_id')
  81. ->where('uid', $request->uid())
  82. ->page($where['page'], $where['limit'])
  83. ->select();
  84. $data = count($data) ? $data->toArray() : [];
  85. foreach ($data as &$item) {
  86. if ($item['money'] == 0) {
  87. $item['money'] = User::where('uid', $item['uid'])->find()['pay_price'];
  88. }
  89. }
  90. return app('json')->success($data);
  91. }
  92. }