UserPartakeController.php 2.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899
  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. $list = Out::where('status', 1)->order('id DESC')->select()->toArray();
  21. return app('json')->success($list);
  22. }
  23. /**
  24. * 参加
  25. * @return void
  26. */
  27. public function participate_in(Request $request)
  28. {
  29. $data = UtilService::postMore([
  30. 'out_id'
  31. ]);
  32. Db::startTrans();
  33. $user = User::where('uid', $request->uid())->find();
  34. if ($user['level'] < 2) return app('json')->fail('等级为团队合伙人才能参与');
  35. $out = Out::where('id', $data['out_id'])->find();
  36. if (empty($out)) return app('json')->fail('参与项目不存在');
  37. if ($out['status'] == 0) return app('json')->fail('参与项目已关闭');
  38. $partake = UserPartake::where('uid', $request->uid())->where('status', 0)->find();
  39. if ($partake) return app('json')->fail('当前已有参与中项目,无法参加');
  40. $res = UserPartake::create([
  41. 'uid' => $request->uid(),
  42. 'out_id' => $data['out_id'],
  43. ]);
  44. if ($res) {
  45. Db::commit();
  46. return app('json')->success('参与成功');
  47. }else{
  48. Db::rollback();
  49. return app('json')->fail('参与失败');
  50. }
  51. }
  52. /**
  53. * 参与记录
  54. * @param Request $request
  55. * @return mixed
  56. * @throws \think\db\exception\DataNotFoundException
  57. * @throws \think\db\exception\DbException
  58. * @throws \think\db\exception\ModelNotFoundException
  59. */
  60. public function partake(Request $request)
  61. {
  62. $where = UtilService::getMore([
  63. ['page', 1],
  64. ['limit', 20],
  65. ]);
  66. $data = UserPartake::alias('a')
  67. ->field('a.*,c.name')
  68. ->order('a.id DESC')
  69. ->leftJoin('out c', 'c.id = a.out_id')
  70. ->where('uid', $request->uid())
  71. ->page($where['page'], $where['limit'])
  72. ->select();
  73. $data = count($data) ? $data->toArray() : [];
  74. foreach ($data as &$item)
  75. {
  76. if ($item['money'] == 0){
  77. $item['money'] = User::where('uid', $item['uid'])->find()['pay_price'];
  78. }
  79. }
  80. return app('json')->success($data);
  81. }
  82. }