Turntable.php 15 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447
  1. <?php
  2. namespace app\sys\controller;
  3. use think\facade\View;
  4. use think\facade\Request;
  5. use app\model\LotteryActivity;
  6. use app\model\LotteryActivityGoods;
  7. use app\model\LotteryLuckyUser;
  8. use think\facade\Db;
  9. use app\logics\OrgLogic;
  10. use app\model\LotteryUser;
  11. use app\logics\EmployeeLogic;
  12. use app\model\User;
  13. use app\model\Employee;
  14. class Turntable extends Base
  15. {
  16. //活动列表
  17. public function list()
  18. {
  19. if (!request()->isAjax()){
  20. $eid = LotteryActivity::where([['del','=',0],['root_id','=',request()->employee->root_id],['employee_id','>',0],['type','=',1]])->group('employee_id')->column('employee_id');
  21. $where = [
  22. ['id','in',$eid],
  23. ['grant_id', '>', 0],
  24. ['root_id', '=', request()->employee->root_id]
  25. ];
  26. // 运营人员列表
  27. $employee = Employee::where($where)->field(['id', 'opt_name as name'])->select()->toArray();
  28. View::assign('employee', $employee);
  29. return View::fetch();
  30. }
  31. $request = request();
  32. $data=$request->only(['page','limit','keyword','employee_id','date']);
  33. $this->sel_act_status();
  34. //条件
  35. $condition = [
  36. ['root_id','=',$request->employee->root_id],
  37. ['type','=',1]
  38. ];
  39. if(!empty($data['keyword'])){
  40. $condition[] = ['title', 'like', '%' . $data['keyword'] . '%'];
  41. }
  42. if (!empty($data['employee_id'])) {
  43. $condition[] = ['employee_id', '=', $data['employee_id']];
  44. }
  45. if (!empty($data['date'])) {
  46. $arr = explode(' - ',$data['date']);
  47. $condition[] = ['start_date','<=', $arr[0]];
  48. $condition[] = ['end_date', '>=', $arr[1]];
  49. }
  50. $list=LotteryActivity::with(['employee','good'=>function($query){$query->field('actid,good_name,good_img,stock');},
  51. 'lotteryluckyuser'=>function($query){
  52. $query->field('actid,status,uid');
  53. }])
  54. ->withCount(['lotteryuser'])
  55. ->where($condition)
  56. ->page($data['page'], $data['limit'])
  57. ->order(['addtime' => 'desc'])
  58. ->select()
  59. ->toArray();
  60. $count=LotteryActivity::where($condition)->count();
  61. foreach($list as $key=>$val){
  62. $gdnum=0;
  63. foreach($val['good'] as $n=>$m){
  64. $gdnum+=$m['stock'];
  65. }
  66. $list[$key]['good_num']=$gdnum;
  67. $list[$key]['share_num']=$val['share_num']?$val['share_num']:0;
  68. $list[$key]['lottery_num']=$val['lotteryuser_count']?$val['lotteryuser_count']:0;
  69. $list[$key]['yes_num']=count($val['lotteryluckyuser']);
  70. $list[$key]['yes_crm']=LotteryLuckyUser::where('actid',$val['id'])->group('uid')->count();
  71. $wiped_num=0;
  72. foreach($val['lotteryluckyuser'] as $k=>$v){
  73. if($v['status']==2){
  74. $wiped_num++;
  75. }
  76. }
  77. $list[$key]['wiped_num']=$wiped_num;
  78. }
  79. return json(['code' => 0, 'count'=>$count,'data' => $list, 'msg' => '获取成功']);
  80. }
  81. //查询到期的活动
  82. public function sel_act_status()
  83. {
  84. $time=date('Y-m-d',time());
  85. $ms=LotteryActivity::where('end_date','<',$time)->update(['status'=>2]);
  86. }
  87. //修改活动状态
  88. public function up_act_sta()
  89. {
  90. $request = request();
  91. $data=$request->only(['id']);
  92. $act_data=LotteryActivity::where([['id','=',$data['id']],['root_id','=',$request->employee->root_id]])->find();
  93. if($act_data['status']==2){
  94. $you=LotteryActivity::where([['status','=',1],['root_id','=',$request->employee->root_id],['type','=',$act_data['type']]])->count();
  95. if(!empty($you)){
  96. return json(['code' => 1, 'msg' => '已有活动在进行,暂时不能开启']);
  97. }else{
  98. if($act_data['end_date'] < date('Y-m-d',time())){
  99. return json(['code' => 1, 'msg' => '活动时间已经结束']);
  100. }
  101. $act_data->status=1;
  102. }
  103. }else{
  104. $act_data->status=2;
  105. }
  106. $ms=$act_data->save();
  107. if($ms){
  108. return json(['code' => 0, 'msg' => '修改成功']);
  109. }else{
  110. return json(['code' => 1, 'msg' => '修改失败']);
  111. }
  112. }
  113. //添加图片
  114. public function add_img()
  115. {
  116. $request = request();
  117. $data=$request->only(['good_img']);
  118. return json(['code' => 0, 'data' => $data['good_img'], 'msg' => '获取成功']);
  119. }
  120. //添加活动
  121. public function add_activity()
  122. {
  123. if (!request()->isAjax()) return View::fetch();
  124. $request = request();
  125. $data=$request->only(['title','start_date','end_date','lottery_num','share_count','good','prizeList','type','lottery_tel','lottery_address','shareimg']);
  126. if(empty($data['shareimg'])) return json(['code' => 1, 'msg' => '请选择分享封面图']);
  127. $good=json_decode(strip_tags($data['prizeList']),true);
  128. $add['root_id']=$request->employee->root_id;
  129. $add['type'] = $data['type'];
  130. $add['title'] = $data['title'];
  131. $add['start_date'] = $data['start_date'];
  132. $add['end_date'] = $data['end_date'];
  133. $add['lottery_num'] = $data['lottery_num'];
  134. $add['share_count'] = $data['share_count'];
  135. $add['employee_id'] = request()->employee->id;
  136. $add['lottery_tel'] = $data['lottery_tel'];
  137. $add['lottery_address'] = $data['lottery_address'];
  138. $add['shareimg'] = $data['shareimg'];
  139. $you=LotteryActivity::where([['root_id','=',$request->employee->root_id],['status','=','1'],['type','=',$data['type']]])->count();
  140. if(!empty($you)){
  141. $add['status'] = 2;
  142. }
  143. Db::startTrans();
  144. try {
  145. $ms=LotteryActivity::insertGetId($add);
  146. $xin=null;
  147. $allpr=0;
  148. foreach($good as $key=>$val){
  149. $xin[]=array(
  150. 'good_name'=>$val['name'],
  151. 'good_img' =>$val['url'],
  152. 'probability'=>$val['probability'],
  153. 'stock'=>$val['num'],
  154. 'actid'=>$ms,
  155. 'surplus'=>$val['num']
  156. );
  157. $allpr+=$val['probability'];
  158. }
  159. if($allpr>100){
  160. return json(['code' => 1, 'msg' => '所有奖品概率不能大于100']);
  161. }
  162. LotteryActivityGoods::insertAll($xin);
  163. Db::commit();
  164. }catch (\Exception $e) {
  165. Db::rollback();
  166. //var_dump($e->getMessage());
  167. return json(['code' => 1, 'msg' => '提交数据失败.']);
  168. }
  169. if($ms){
  170. return json(['code' => 0, 'msg' => '添加成功']);
  171. }else{
  172. return json(['code' => 1, 'msg' => '添加失败']);
  173. }
  174. }
  175. //编辑活动
  176. public function edit_activity()
  177. {
  178. $request = request();
  179. $data=$request->only(['title','start_date','end_date','lottery_num','share_count','good','id','prizeList','lottery_tel','lottery_address','shareimg']);
  180. $act_data=LotteryActivity::with(['good'])->where([['id','=',$data['id']],['root_id','=',$request->employee->root_id]])->find();
  181. if (!request()->isAjax()){
  182. View::assign('act_data',$act_data);
  183. return View::fetch();
  184. }else{
  185. $add['title'] = $data['title'];
  186. $add['start_date'] = $data['start_date'];
  187. $add['end_date'] = $data['end_date'];
  188. $add['lottery_num'] = $data['lottery_num'];
  189. $add['share_count'] = $data['share_count'];
  190. $add['lottery_tel'] = $data['lottery_tel'];
  191. $add['lottery_address'] = $data['lottery_address'];
  192. if(!empty($data['shareimg'])) $add['shareimg'] = $data['shareimg'];
  193. $ms=LotteryActivity::where([['id','=',$data['id']],['root_id','=',$request->employee->root_id]])->update($add);
  194. $good=json_decode(strip_tags($data['prizeList']),true);
  195. $gen = $in = null;
  196. $ali_oss_bindurl='http://' .config('app.ali_oss_bindurl').'/';
  197. $allpr=0;
  198. foreach($good as $key=>$val){
  199. if($val['id']){
  200. $gen[]=array(
  201. 'id' =>$val['id'],
  202. 'good_name'=>$val['name'],
  203. 'good_img' =>str_replace($ali_oss_bindurl,'',$val['url']),
  204. 'probability'=>$val['probability'],
  205. 'stock'=>$val['num'],
  206. 'surplus'=>$val['num']
  207. );
  208. }else{
  209. $in[]=array(
  210. 'good_name'=>$val['name'],
  211. 'good_img' =>$val['url'],
  212. 'probability'=>$val['probability'],
  213. 'stock'=>$val['num'],
  214. 'actid'=>$data['id'],
  215. 'surplus'=>$val['num']
  216. );
  217. }
  218. $allpr+=$val['probability'];
  219. }
  220. if($allpr>100){
  221. return json(['code' => 1, 'msg' => '所有奖品概率不能大于100']);
  222. }
  223. $ltg = new LotteryActivityGoods;
  224. if(!empty($gen)) $ltg->saveAll($gen);
  225. if(!empty($in)) $ltg->insertAll($in);
  226. return json(['code' => 0, 'msg' => '修改成功']);
  227. }
  228. }
  229. //中奖客户
  230. public function winning_customer()
  231. {
  232. $request = request();
  233. $data=$request->only(['id','page','limit','employee','org','keyword','type']);
  234. if (!request()->isAjax()){
  235. // 部门
  236. $org = OrgLogic::struc($request->employee->root_id);
  237. View::assign('org', $org);
  238. $orgids = orgSubIds(request()->employee->root_id);
  239. View::assign('orgids', json_encode($orgids));
  240. View::assign('id', $data['id']);
  241. return View::fetch();
  242. }
  243. $data['type']=!empty($data['type'])?$data['type']:1;
  244. $where[] = ['actid','=',$data['id']];
  245. if(!empty($data['employee'])){
  246. $where[] = ['empid','=',$data['employee']];
  247. }
  248. if(!empty($data['keyword'])){
  249. $uid=User::where([['phone','=',$data['keyword']],['root_id','=',$request->employee->root_id]])->value('id');
  250. $where[] = ['uid','=',$uid];
  251. }
  252. if(empty($data['employee']) && !empty($data['org'])){
  253. $employee = EmployeeLogic::employeelist($data['org'], [], 1, 1000);
  254. $aoid=null;
  255. foreach($employee as $key=>$val){
  256. $aoid.=$val['id'].',';
  257. }
  258. if(!empty($aoid)){
  259. $where[] = ['empid','in',(trim($aoid,','))];
  260. }
  261. }
  262. $actid=$data['id'];
  263. if($data['type']==1){
  264. $list=LotteryLuckyUser::with([
  265. 'user'=>function($query){
  266. $query->field('id,nickname,phone,headimgurl');
  267. },
  268. 'good'=>function($query){
  269. $query->field('id,good_name,good_img');
  270. },
  271. 'emp'=>function($query){
  272. $query->field('id,name');
  273. },
  274. 'lotteryuser'=>function($query) use ($actid){
  275. $query->where("actid =". $actid)->field('uid,share_img,id');
  276. //$query->field('uid,share_img,id');
  277. }
  278. ])
  279. ->where($where)
  280. ->page($data['page'], $data['limit'])
  281. ->order('lucky_time desc')
  282. ->select()
  283. ->toArray();
  284. $count=LotteryLuckyUser::where($where)->count();
  285. }
  286. if($data['type']==2){
  287. $where[]=['is_prize','=',0];
  288. $list=LotteryUser::with([
  289. 'user'=>function($query){
  290. $query->field('id,nickname,headimgurl,phone');
  291. },
  292. 'emp'=>function($query){
  293. $query->field('id,name');
  294. }
  295. ])
  296. ->where($where)
  297. ->page($data['page'], $data['limit'])
  298. ->order('addtime desc')
  299. ->select()
  300. ->toArray();
  301. $count=LotteryUser::where($where)->count();
  302. }
  303. return json(['code' => 0, 'count'=>$count,'data' => $list, 'msg' => '获取成功']);
  304. }
  305. //确认核销奖品
  306. public function wiped_lottery()
  307. {
  308. $request = request();
  309. $data=$request->only(['id','wiped_sn']);
  310. $ms=LotteryLuckyUser::where('id','=',$data['id'])->find();
  311. if($ms['wiped_sn']==$data['wiped_sn']){
  312. $ms->status=2;
  313. $ms->save();
  314. return json(['code' => 0, 'msg' => '核销成功']);
  315. }else{
  316. return json(['code' => 1, 'msg' => '核销码错误']);
  317. }
  318. }
  319. //奖品详情
  320. public function prize_list()
  321. {
  322. $request = request();
  323. $data=$request->only(['id','page'=>1,'limit'=>10]);
  324. if (!request()->isAjax()){
  325. View::assign('id', $data['id']);
  326. return View::fetch();
  327. }
  328. $list=LotteryActivityGoods::where('actid','=',$data['id'])->page($data['page'],$data['limit'])->select()->toArray();
  329. $count=LotteryActivityGoods::where('actid','=',$data['id'])->count();
  330. foreach($list as $key=>$val){
  331. $yes=LotteryLuckyUser::where([['good_id','=',$val['id']],['actid','=',$val['actid']]])->count();
  332. $list[$key]['yes']=$yes;
  333. $list[$key]['no']=$val['stock']-$yes;
  334. }
  335. return json(['code' => 0, 'count'=>$count,'data' => $list, 'msg' => '获取成功']);
  336. }
  337. //砸金蛋
  338. public function golden_eggs_list()
  339. {
  340. if (!request()->isAjax()){
  341. $eid = LotteryActivity::where([['del','=',0],['root_id','=',request()->employee->root_id],['employee_id','>',0],['type','=',2]])->group('employee_id')->column('employee_id');
  342. $where = [
  343. ['id','in',$eid],
  344. ['grant_id', '>', 0],
  345. ['root_id', '=', request()->employee->root_id]
  346. ];
  347. // 运营人员列表
  348. $employee = Employee::where($where)->field(['id', 'opt_name as name'])->select()->toArray();
  349. View::assign('employee', $employee);
  350. return View::fetch();
  351. }
  352. $request = request();
  353. $data=$request->only(['page','limit','keyword','employee_id','date']);
  354. $this->sel_act_status();
  355. //条件
  356. $condition = [
  357. ['root_id','=',$request->employee->root_id],
  358. ['type','=',2]
  359. ];
  360. if(!empty($data['keyword'])){
  361. $condition[] = ['title', 'like', '%' . $data['keyword'] . '%'];
  362. }
  363. if (!empty($data['employee_id'])) {
  364. $condition[] = ['employee_id', '=', $data['employee_id']];
  365. }
  366. if (!empty($data['date'])) {
  367. $arr = explode(' - ',$data['date']);
  368. $condition[] = ['start_date','<=', $arr[0]];
  369. $condition[] = ['end_date', '>=', $arr[1]];
  370. }
  371. $list=LotteryActivity::with(['employee','good'=>function($query){$query->field('actid,good_name,good_img,stock');},
  372. 'lotteryluckyuser'=>function($query){
  373. $query->field('actid,status,uid');
  374. }])
  375. ->withCount(['lotteryuser'])
  376. ->where($condition)
  377. //->page($data['page'], $data['limit'])
  378. ->order('addtime desc')
  379. ->select()
  380. ->toArray();
  381. $count=LotteryActivity::where($condition)->count();
  382. foreach($list as $key=>$val){
  383. $gdnum=0;
  384. foreach($val['good'] as $n=>$m){
  385. $gdnum+=$m['stock'];
  386. }
  387. $list[$key]['good_num']=$gdnum;
  388. $list[$key]['share_num']=$val['share_num']?$val['share_num']:0;
  389. $list[$key]['lottery_num']=$val['lotteryuser_count']?$val['lotteryuser_count']:0;
  390. $list[$key]['yes_num']=count($val['lotteryluckyuser']);
  391. $list[$key]['yes_crm']=LotteryLuckyUser::where('actid',$val['id'])->group('uid')->count();
  392. $wiped_num=0;
  393. foreach($val['lotteryluckyuser'] as $k=>$v){
  394. if($v['status']==2){
  395. $wiped_num++;
  396. }
  397. }
  398. $list[$key]['wiped_num']=$wiped_num;
  399. }
  400. return json(['code' => 0, 'count'=>$count,'data' => $list, 'msg' => '获取成功']);
  401. }
  402. //删除奖品
  403. public function delActgood($id)
  404. {
  405. $actids = LotteryActivity::where([['root_id','=',request()->employee->root_id],['del','=',0]])->column('id');
  406. $check = LotteryActivityGoods::where([['id','=',$id],['actid','in',$actids]])->find();
  407. if(!empty($check)){
  408. $cg = LotteryLuckyUser::where('good_id','=',$id)->count();
  409. if($cg > 0) return json(['code' => 1, 'msg' => '些奖品已经有人中奖,暂时无法删除']);
  410. $check->delete();
  411. }
  412. return json(['code' => 0, 'msg' => '删除成功']);
  413. }
  414. //砸金蛋-添加活动
  415. public function golden_eggs_add()
  416. {
  417. return View::fetch();
  418. }
  419. //砸金蛋-编辑活动
  420. public function golden_eggs_edit()
  421. {
  422. return View::fetch();
  423. }
  424. //砸金蛋-中奖客户
  425. public function golden_eggs_winning()
  426. {
  427. return View::fetch();
  428. }
  429. //砸金蛋-奖励详情
  430. public function golden_eggs_prize()
  431. {
  432. return View::fetch();
  433. }
  434. }
  435. ?>