WechatUser.php 12 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389
  1. <?php
  2. namespace app\admin\controller\wechat;
  3. use app\admin\controller\AuthController;
  4. use crmeb\services\FormBuilder as Form;
  5. use app\admin\model\user\User;
  6. use app\admin\model\wechat\WechatUser as UserModel;
  7. use app\models\user\UserBill;
  8. use crmeb\services\JsonService;
  9. use crmeb\services\UtilService as Util;
  10. use crmeb\services\WechatService;
  11. use think\Collection;
  12. use think\facade\Route as Url;
  13. /**
  14. * 管理员操作记录表控制器
  15. * Class WechatUser
  16. * @package app\admin\controller\wechat
  17. */
  18. class WechatUser extends AuthController
  19. {
  20. /**
  21. * 显示操作记录
  22. */
  23. public function index(){
  24. $where = Util::getMore([
  25. ['nickname',''],
  26. ['data',''],
  27. ['tagid_list',''],
  28. ['groupid','-1'],
  29. ['sex',''],
  30. ['export',''],
  31. ['stair',''],
  32. ['second',''],
  33. ['order_stair',''],
  34. ['order_second',''],
  35. ['subscribe',''],
  36. ['now_money',''],
  37. ['is_promoter',''],
  38. ],$this->request);
  39. $tagidList = explode(',',$where['tagid_list']);
  40. foreach ($tagidList as $k=>$v){
  41. if(!$v){
  42. unset($tagidList[$k]);
  43. }
  44. }
  45. $tagidList = array_unique($tagidList);
  46. $where['tagid_list'] = implode(',',$tagidList);
  47. try{
  48. $groupList=UserModel::getUserGroup();
  49. $tagList=UserModel::getUserTag();
  50. }catch (\Exception $e){
  51. $groupList=[];
  52. $tagList=[];
  53. }
  54. $this->assign([
  55. 'where'=>$where,
  56. 'groupList'=>$groupList,
  57. 'tagList'=>$tagList
  58. ]);
  59. $limitTimeList = [
  60. 'today'=>implode(' - ',[date('Y/m/d'),date('Y/m/d',strtotime('+1 day'))]),
  61. 'week'=>implode(' - ',[
  62. date('Y/m/d', (time() - ((date('w') == 0 ? 7 : date('w')) - 1) * 24 * 3600)),
  63. date('Y-m-d', (time() + (7 - (date('w') == 0 ? 7 : date('w'))) * 24 * 3600))
  64. ]),
  65. 'month'=>implode(' - ',[date('Y/m').'/01',date('Y/m').'/'.date('t')]),
  66. 'quarter'=>implode(' - ',[
  67. date('Y').'/'.(ceil((date('n'))/3)*3-3+1).'/01',
  68. date('Y').'/'.(ceil((date('n'))/3)*3).'/'.date('t',mktime(0,0,0,(ceil((date('n'))/3)*3),1,date('Y')))
  69. ]),
  70. 'year'=>implode(' - ',[
  71. date('Y').'/01/01',date('Y/m/d',strtotime(date('Y').'/01/01 + 1year -1 day'))
  72. ])
  73. ];
  74. $uidAll = UserModel::getAll($where);
  75. $this->assign(compact('limitTimeList','uidAll'));
  76. $this->assign(UserModel::systemPage($where));
  77. return $this->fetch();
  78. }
  79. public function edit_user_tag($openid)
  80. {
  81. if(!$openid) return JsonService::fail('参数错误!');
  82. $list = Collection::make(UserModel::getUserTag())->each(function($item){
  83. return ['value'=>$item['id'],'label'=>$item['name']];
  84. });
  85. $tagList = UserModel::where('openid',$openid)->value('tagid_list');
  86. $tagList = explode(',',$tagList)?:[];
  87. $f = [Form::select('tag_id','用户标签',$tagList)->setOptions($list->toArray())->multiple(1)];
  88. $form = Form::make_post_form('标签名称',$f,Url::buildUrl('update_user_tag',compact('openid')));
  89. $this->assign(compact('form'));
  90. return $this->fetch('public/form-builder');
  91. }
  92. public function update_user_tag($openid)
  93. {
  94. if(!$openid) return JsonService::fail('参数错误!');
  95. $tagId = request()->post('tag_id/a',[]);
  96. if(!$tagId) return JsonService::fail('请选择用户标签!');
  97. $tagList = explode(',',UserModel::where('openid',$openid)->value('tagid_list'))?:[];
  98. UserModel::edit(['tagid_list'=>$tagId],$openid,'openid');
  99. if(!$tagId[0])unset($tagId[0]);
  100. UserModel::edit(['tagid_list'=>$tagId],$openid,'openid');
  101. try{
  102. foreach ($tagList as $tag){
  103. if($tag) WechatService::userTagService()->batchUntagUsers([$openid],$tag);
  104. }
  105. foreach ($tagId as $tag){
  106. WechatService::userTagService()->batchTagUsers([$openid],$tag);
  107. }
  108. }catch (\Exception $e){
  109. UserModel::rollbackTrans();
  110. return JsonService::fail($e->getMessage());
  111. }
  112. UserModel::commitTrans();
  113. return JsonService::successful('修改成功!');
  114. }
  115. public function edit_user_group($openid)
  116. {
  117. if(!$openid) return JsonService::fail('参数错误!');
  118. $list = Collection::make(UserModel::getUserGroup())->each(function($item){
  119. return ['value'=>$item['id'],'label'=>$item['name']];
  120. });
  121. $groupId = UserModel::where('openid',$openid)->value('groupid');
  122. $f = [Form::select('group_id','用户分组',(string)$groupId)->setOptions($list->toArray())];
  123. $form = Form::make_post_form('用户分组',$f,Url::buildUrl('update_user_group',compact('openid')));
  124. $this->assign(compact('form'));
  125. return $this->fetch('public/form-builder');
  126. }
  127. public function update_user_group($openid)
  128. {
  129. if(!$openid) return JsonService::fail('参数错误!');
  130. $groupId = request()->post('group_id');
  131. // if(!$groupId) return JsonService::fail('请选择用户分组!');
  132. UserModel::beginTrans();
  133. UserModel::edit(['groupid'=>$groupId],$openid,'openid');
  134. try{
  135. WechatService::userGroupService()->moveUser($openid,$groupId);
  136. }catch (\Exception $e){
  137. UserModel::rollbackTrans();
  138. return JsonService::fail($e->getMessage());
  139. }
  140. UserModel::commitTrans();
  141. return JsonService::successful('修改成功!');
  142. }
  143. /**
  144. * 用户标签列表
  145. */
  146. public function tag($refresh = 0)
  147. {
  148. $list=[];
  149. if($refresh == 1) {
  150. UserModel::clearUserTag();
  151. $this->redirect(Url::buildUrl('tag'));
  152. }
  153. try{
  154. $list = UserModel::getUserTag();
  155. }catch (\Exception $e){}
  156. $this->assign(compact('list'));
  157. return $this->fetch();
  158. }
  159. /**
  160. * 添加标签
  161. * @return mixed
  162. */
  163. public function create_tag()
  164. {
  165. $f = [Form::input('name','标签名称')];
  166. $form = Form::make_post_form('标签名称',$f,Url::buildUrl('save_tag'));
  167. $this->assign(compact('form'));
  168. return $this->fetch('public/form-builder');
  169. }
  170. /**
  171. * 添加
  172. */
  173. public function save_tag()
  174. {
  175. $tagName = request()->post('name');
  176. if(!$tagName) return JsonService::fail('请输入标签名称!');
  177. try{
  178. WechatService::userTagService()->create($tagName);
  179. }catch (\Exception $e){
  180. return JsonService::fail($e->getMessage());
  181. }
  182. UserModel::clearUserTag();
  183. return JsonService::successful('添加标签成功!');
  184. }
  185. /**
  186. * 修改标签
  187. * @param $id
  188. * @return mixed
  189. */
  190. public function edit_tag($id)
  191. {
  192. $f = [Form::input('name','标签名称')];
  193. $form = Form::make_post_form('标签名称',$f,Url::buildUrl('update_tag',['id'=>$id]));
  194. $this->assign(compact('form'));
  195. return $this->fetch('public/form-builder');
  196. }
  197. /**
  198. * 修改标签
  199. * @param $id
  200. */
  201. public function update_tag($id)
  202. {
  203. $tagName = request()->post('name');
  204. if(!$tagName) return JsonService::fail('请输入标签名称!');
  205. try{
  206. WechatService::userTagService()->update($id,$tagName);
  207. }catch (\Exception $e){
  208. return JsonService::fail($e->getMessage());
  209. }
  210. UserModel::clearUserTag();
  211. return JsonService::successful('修改标签成功!');
  212. }
  213. /**
  214. * 删除标签
  215. * @param $id
  216. * @return \think\response\Json
  217. */
  218. public function delete_tag($id)
  219. {
  220. try{
  221. WechatService::userTagService()->delete($id);
  222. }catch (\Exception $e){
  223. return JsonService::fail($e->getMessage());
  224. }
  225. UserModel::clearUserTag();
  226. return JsonService::successful('删除标签成功!');
  227. }
  228. /**
  229. * 用户分组列表
  230. */
  231. public function group($refresh = 0)
  232. {
  233. $list=[];
  234. try{
  235. if($refresh == 1) {
  236. UserModel::clearUserGroup();
  237. $this->redirect(Url::buildUrl('group'));
  238. }
  239. $list = UserModel::getUserGroup();
  240. }catch (\Exception $e){}
  241. $this->assign(compact('list'));
  242. return $this->fetch();
  243. }
  244. /**
  245. * 添加分组
  246. * @return mixed
  247. */
  248. public function create_group()
  249. {
  250. $f = [Form::input('name','分组名称')];
  251. $form = Form::make_post_form('标签名称',$f,Url::buildUrl('save_group'));
  252. $this->assign(compact('form'));
  253. return $this->fetch('public/form-builder');
  254. }
  255. /**
  256. * 添加
  257. */
  258. public function save_group()
  259. {
  260. $tagName = request()->post('name');
  261. if(!$tagName) return JsonService::fail('请输入分组名称!');
  262. try{
  263. WechatService::userGroupService()->create($tagName);
  264. }catch (\Exception $e){
  265. return JsonService::fail($e->getMessage());
  266. }
  267. UserModel::clearUserGroup();
  268. return JsonService::successful('添加分组成功!');
  269. }
  270. /**
  271. * 修改分组
  272. * @param $id
  273. * @return mixed
  274. */
  275. public function edit_group($id)
  276. {
  277. $f = [Form::input('name','分组名称')];
  278. $form = Form::make_post_form('标签名称',$f,Url::buildUrl('update_group',compact('id')));
  279. $this->assign(compact('form'));
  280. return $this->fetch('public/form-builder');
  281. }
  282. /**
  283. * 修改分组
  284. * @param $id
  285. */
  286. public function update_group($id)
  287. {
  288. $tagName = request()->post('name');
  289. if(!$tagName) return JsonService::fail('请输入分组名称!');
  290. try{
  291. WechatService::userGroupService()->update($id,$tagName);
  292. }catch (\Exception $e){
  293. return JsonService::fail($e->getMessage());
  294. }
  295. UserModel::clearUserGroup();
  296. return JsonService::successful('修改分组成功!');
  297. }
  298. /**
  299. * 删除分组
  300. * @param $id
  301. * @return \think\response\Json
  302. */
  303. public function delete_group($id)
  304. {
  305. try{
  306. WechatService::userTagService()->delete($id);
  307. }catch (\Exception $e){
  308. return JsonService::fail($e->getMessage());
  309. }
  310. UserModel::clearUserGroup();
  311. return JsonService::successful('删除分组成功!');
  312. }
  313. public function synchro_tag($openid){
  314. if(!$openid) return JsonService::fail('参数错误!');
  315. $data = array();
  316. if(UserModel::be($openid,'openid')){
  317. try{
  318. $tag = WechatService::userTagService()->userTags($openid)->toArray();
  319. }catch (\Exception $e) {
  320. return JsonService::fail($e->getMessage());
  321. }
  322. if($tag['tagid_list']) $data['tagid_list'] = implode(',',$tag['tagid_list']);
  323. else $data['tagid_list'] = '';
  324. $res = UserModel::edit($data,$openid,'openid');
  325. if($res) return JsonService::successful('同步成功');
  326. else return JsonService::fail('同步失败!');
  327. }else return JsonService::fail('参数错误!');
  328. }
  329. /**
  330. * 一级推荐人页面
  331. * @return mixed
  332. */
  333. public function stair($uid = ''){
  334. if($uid == '') return $this->failed('参数错误');
  335. $list = User::alias('u')
  336. ->where('u.spread_uid',$uid)
  337. ->field('u.avatar,u.nickname,u.now_money,u.add_time,u.uid')
  338. ->where('u.status',1)
  339. ->order('u.add_time DESC')
  340. ->select()
  341. ->toArray();
  342. foreach ($list as $key=>$value) $list[$key]['orderCount'] = StoreOrder::getOrderCount($value['uid']);
  343. $this->assign('list',$list);
  344. return $this->fetch();
  345. }
  346. /**
  347. * 个人资金详情页面
  348. * @return mixed
  349. */
  350. public function now_money($uid = ''){
  351. if($uid == '') return $this->failed('参数错误');
  352. $list = UserBill::where('uid',$uid)->where('category','now_money')
  353. ->field('mark,pm,number,add_time')
  354. ->where('status',1)->order('add_time DESC')->select()->toArray();
  355. foreach ($list as &$v){
  356. $v['add_time'] = date('Y-m-d H:i:s',$v['add_time']);
  357. }
  358. $this->assign('list',$list);
  359. return $this->fetch();
  360. }
  361. }