UserGroupController.php 3.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120
  1. <?php
  2. namespace Modules\Audience\Http\Controllers;
  3. use Catch\Base\CatchController;
  4. use Illuminate\Foundation\Validation\ValidatesRequests;
  5. use Illuminate\Http\Request;
  6. use Illuminate\Support\Facades\DB;
  7. use Modules\Audience\Models\GzhUgMapModel;
  8. use Modules\Audience\Models\UserGroupModel;
  9. class UserGroupController extends CatchController
  10. {
  11. use ValidatesRequests;
  12. /**
  13. * 用户分群列表
  14. * @param Request $request
  15. */
  16. public function list(Request $request) {
  17. $name = $request->input('name');
  18. return DB::table('user_groups')
  19. ->when($name, function ($query, $name){
  20. return $query->where('name', 'like', '%'.$name.'%');
  21. })->where([
  22. 'uid' => $this->getLoginUserId(),
  23. 'is_enabled' => 1
  24. ])->orderBy('id', 'desc')
  25. ->paginate($request->input('limit', 20));
  26. }
  27. /**
  28. * 详情
  29. * @param Request $request
  30. * @throws \Illuminate\Validation\ValidationException
  31. */
  32. public function detail(Request $request) {
  33. $this->validate($request, ['id' => 'required']);
  34. $uid = $this->getLoginUserId();
  35. $obj = DB::table('user_groups')
  36. ->where([
  37. 'uid' => $uid, 'is_enabled' => 1,
  38. 'id' => $request->input('id')
  39. ])->first();
  40. if($obj) {
  41. // ToDo:完善
  42. $obj->user_num = '-1';
  43. $obj->tags_arr = \json_decode($obj->tags, true);
  44. $obj->gzh_names = DB::table('gzh_ug_maps as a')
  45. ->join('wechat_authorization_infos as b', function($query) use ($uid) {
  46. $query->on('a.gzh_id', '=', 'b.id')
  47. ->where([
  48. 'b.is_enabled' => 1,
  49. 'b.user_id' => $uid
  50. ]);
  51. })->where([
  52. 'a.ug_id' => $request->input('id')
  53. ])->select('b.nick_name')->get()->pluck('nick_name')->toArray();
  54. }
  55. return $obj;
  56. }
  57. /**
  58. * 添加用户分群
  59. * @param Request $request
  60. * @return string
  61. * @throws \Illuminate\Validation\ValidationException
  62. */
  63. public function add(Request $request){
  64. $this->validate($request, [
  65. 'name' => 'required|string|max:64',
  66. 'gzh_ids' => 'required|array',
  67. 'tags' => 'required|array',
  68. 'remark' => 'nullable|string|max:140'
  69. ]);
  70. $model = UserGroupModel::create([
  71. 'name' => $request->input('name'), 'uid' => $this->getLoginUserId(),
  72. 'tags' => \json_encode($request->input('tags', []), JSON_UNESCAPED_UNICODE),
  73. 'remark' => $request->input('remark', '')
  74. ]);
  75. foreach ($request->input('gzh_ids') as $gzh_id) {
  76. GzhUgMapModel::create([
  77. 'ug_id' => $model->id, 'gzh_id' => $gzh_id
  78. ]);
  79. }
  80. return 'ok';
  81. }
  82. /**
  83. * 批量删除
  84. * @param Request $request
  85. * @return string
  86. * @throws \Illuminate\Validation\ValidationException
  87. */
  88. public function delete(Request $request) {
  89. $this->validate($request, ['ids' => 'required|array']);
  90. foreach ($request->input('ids') as $id) {
  91. $model = UserGroupModel::where([
  92. 'uid' => $this->getLoginUserId(), 'id' => $id,
  93. 'is_enabled' => 1,
  94. ])->first();
  95. if($model) {
  96. $model->is_enabled = 0;
  97. $model->save();
  98. GzhUgMapModel::where([
  99. 'ug_id' => $model->id,
  100. 'is_enabled' => 1
  101. ])->update([
  102. 'is_enabled' => 0
  103. ]);
  104. }
  105. }
  106. return 'ok';
  107. }
  108. }