123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120 |
- <?php
- namespace Modules\Audience\Http\Controllers;
- use Catch\Base\CatchController;
- use Illuminate\Foundation\Validation\ValidatesRequests;
- use Illuminate\Http\Request;
- use Illuminate\Support\Facades\DB;
- use Modules\Audience\Models\GzhUgMapModel;
- use Modules\Audience\Models\UserGroupModel;
- class UserGroupController extends CatchController
- {
- use ValidatesRequests;
- /**
- * 用户分群列表
- * @param Request $request
- */
- public function list(Request $request) {
- $name = $request->input('name');
- return DB::table('user_groups')
- ->when($name, function ($query, $name){
- return $query->where('name', 'like', '%'.$name.'%');
- })->where([
- 'uid' => $this->getLoginUserId(),
- 'is_enabled' => 1
- ])->orderBy('id', 'desc')
- ->paginate($request->input('limit', 20));
- }
- /**
- * 详情
- * @param Request $request
- * @throws \Illuminate\Validation\ValidationException
- */
- public function detail(Request $request) {
- $this->validate($request, ['id' => 'required']);
- $uid = $this->getLoginUserId();
- $obj = DB::table('user_groups')
- ->where([
- 'uid' => $uid, 'is_enabled' => 1,
- 'id' => $request->input('id')
- ])->first();
- if($obj) {
- // ToDo:完善
- $obj->user_num = '-1';
- $obj->tags_arr = \json_decode($obj->tags, true);
- $obj->gzh_names = DB::table('gzh_ug_maps as a')
- ->join('wechat_authorization_infos as b', function($query) use ($uid) {
- $query->on('a.gzh_id', '=', 'b.id')
- ->where([
- 'b.is_enabled' => 1,
- 'b.user_id' => $uid
- ]);
- })->where([
- 'a.ug_id' => $request->input('id')
- ])->select('b.nick_name')->get()->pluck('nick_name')->toArray();
- }
- return $obj;
- }
- /**
- * 添加用户分群
- * @param Request $request
- * @return string
- * @throws \Illuminate\Validation\ValidationException
- */
- public function add(Request $request){
- $this->validate($request, [
- 'name' => 'required|string|max:64',
- 'gzh_ids' => 'required|array',
- 'tags' => 'required|array',
- 'remark' => 'nullable|string|max:140'
- ]);
- $model = UserGroupModel::create([
- 'name' => $request->input('name'), 'uid' => $this->getLoginUserId(),
- 'tags' => \json_encode($request->input('tags', []), JSON_UNESCAPED_UNICODE),
- 'remark' => $request->input('remark', '')
- ]);
- foreach ($request->input('gzh_ids') as $gzh_id) {
- GzhUgMapModel::create([
- 'ug_id' => $model->id, 'gzh_id' => $gzh_id
- ]);
- }
- return 'ok';
- }
- /**
- * 批量删除
- * @param Request $request
- * @return string
- * @throws \Illuminate\Validation\ValidationException
- */
- public function delete(Request $request) {
- $this->validate($request, ['ids' => 'required|array']);
- foreach ($request->input('ids') as $id) {
- $model = UserGroupModel::where([
- 'uid' => $this->getLoginUserId(), 'id' => $id,
- 'is_enabled' => 1,
- ])->first();
- if($model) {
- $model->is_enabled = 0;
- $model->save();
- GzhUgMapModel::where([
- 'ug_id' => $model->id,
- 'is_enabled' => 1
- ])->update([
- 'is_enabled' => 0
- ]);
- }
- }
- return 'ok';
- }
- }
|