链街Dcat后台
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

210 lines
7.4 KiB

5 years ago
5 years ago
5 years ago
5 years ago
5 years ago
5 years ago
5 years ago
5 years ago
5 years ago
5 years ago
5 years ago
5 years ago
5 years ago
5 years ago
  1. <?php
  2. namespace App\Admin\Controllers;
  3. use App\Admin\Common\Auth;
  4. use App\Admin\Repositories\LanzuMmInfo;
  5. use App\Models\AdminUsers;
  6. use \App\Models\AdminRoles;
  7. use \App\Models\AdminRoleUsers;
  8. use App\Models\ImsCjdcMarket;
  9. use App\Models\ImsCjdcUser;
  10. use App\Models\LanzuMmWithdraw;
  11. use App\Models\LanzuMpInfo;
  12. use App\Models\LanzuMpInfo as mpInfo;
  13. use App\Models\MpBalance;
  14. use Dcat\Admin\Form;
  15. use Dcat\Admin\Grid;
  16. use Dcat\Admin\Show;
  17. use Dcat\Admin\Controllers\AdminController;
  18. use Illuminate\Support\Facades\Hash;
  19. use App\Models\LanzuMmInfo as mmInfo;
  20. use Dcat\Admin\Admin;
  21. class LanzuMmInfoController extends AdminController
  22. {
  23. /**
  24. * Make a grid builder.
  25. *
  26. * @return Grid
  27. */
  28. protected function grid()
  29. {
  30. return Grid::make(new LanzuMmInfo(), function (Grid $grid) {
  31. $grid->model()->orderBy('created_at','desc');
  32. $user = Admin::user();
  33. //根据登陆帐户获取服务商信息
  34. $mp_info = mpInfo::where('admin_user_id', $user->id)->first();
  35. if ($mp_info) {//如果没有获取到对应的服务商信息,说明该帐号没有绑定服务商
  36. $mk = ImsCjdcMarket::where('mp_id', $mp_info->id)->get()->pluck('id');
  37. $mk_ids = [-1];
  38. if (count($mk) > 0) {
  39. $mk_ids = $mk;
  40. }
  41. $grid->model()->whereIn('market_id', $mk_ids);
  42. }
  43. $grid->id->sortable();
  44. $grid->name;
  45. $grid->phone;
  46. $grid->column('market_id', '所属市场')->display(function ($id) {
  47. $market = ImsCjdcMarket::find($id);
  48. return $market->name;
  49. });
  50. $grid->column('可提现金额')->display(function () {
  51. return MpBalance::getBalance($this->admin_user_id, Type::BALANCE_USER_TYPE_MM);
  52. });
  53. $grid->id_frond->image('', 50, 50);
  54. $grid->id_back->image('', 50, 50);
  55. $grid->id_number;
  56. $grid->column('status', '状态')->display(function ($status) {
  57. if ($status == 1) {
  58. return '正常';
  59. } else {
  60. return '禁用';
  61. }
  62. });
  63. $grid->created_at->display(function ($time) {
  64. return date('Y-m-d H:i:s', $time);
  65. });
  66. $grid->filter(function (Grid\Filter $filter) {
  67. $filter->like('name')->placeholder('输入经理名称');
  68. $filter->equal('phone')->placeholder('输入电话');
  69. });
  70. });
  71. }
  72. /**
  73. * Make a show builder.
  74. *
  75. * @param mixed $id
  76. *
  77. * @return Show
  78. */
  79. protected function detail($id)
  80. {
  81. return Show::make($id, new LanzuMmInfo(), function (Show $show) {
  82. $show->name;
  83. $show->phone;
  84. $show->market_id()->as(function ($id) {
  85. $market = ImsCjdcMarket::find($id);
  86. return $market->name;
  87. });
  88. $show->id_frond->image();
  89. $show->id_back->image();
  90. $show->id_number;
  91. $show->status()->using([1 => '正常', 0 => '禁用']);
  92. $show->created_at()->as(function ($time) {
  93. if ($time) {
  94. return date('Y-m-d H:i', $time);
  95. } else {
  96. return '-';
  97. }
  98. });
  99. $show->updated_at()->as(function ($time) {
  100. if ($time) {
  101. return date('Y-m-d H:i', $time);
  102. } else {
  103. return '-';
  104. }
  105. });
  106. });
  107. }
  108. /**
  109. * Make a form builder.
  110. *
  111. * @return Form
  112. */
  113. protected function form()
  114. {
  115. return Form::make(new LanzuMmInfo(), function (Form $form) {
  116. $form->display('id');
  117. $form->text('user_id', '懒ID')->placeholder('对应懒族小程序个人中心的懒ID')->required();
  118. $form->text('name')->required();
  119. $form->text('phone')->required();
  120. $form->select('market_id', '所属市场')->options('/api/getMarket')->required();
  121. $form->image('id_frond')->uniqueName();
  122. $form->image('id_back')->uniqueName();
  123. $form->text('id_number');
  124. $form->radio('status', '状态')->options(['禁用', '启用'])->default(1);
  125. $form->saving(function (Form $form){
  126. //保存前,校验懒ID是否有效
  127. if ($form->user_id){
  128. $count = ImsCjdcUser::where('id', $form->user_id)->count();
  129. if (!$count) {
  130. return $form->error('该懒ID无效');
  131. }
  132. if ($form->isCreating()){
  133. //校验懒ID是否已被绑定
  134. $count = mmInfo::where('user_id',$form->user_id)->count();
  135. if ($count) {
  136. return $form->error('懒ID已被绑定');
  137. }
  138. }else{
  139. if ($form->user_id!=$form->model()->user_id){
  140. $count = mmInfo::where('user_id',$form->user_id)->count();
  141. if ($count) {
  142. return $form->error('懒ID已被绑定');
  143. }
  144. }
  145. }
  146. }
  147. });
  148. $form->saved(function (Form $form, $mmid) {
  149. $model = new mmInfo();
  150. if ($form->isCreating()) {
  151. $res = Auth::addAdminUser($form, $model, $mmid, 'lanzu_mm', Type::BALANCE_USER_TYPE_MM);
  152. if ($res == -1) {
  153. return $form->error('该手机号作为登陆帐号已存在!');
  154. } elseif ($res == -2) {
  155. return $form->error('添加失败!');
  156. }
  157. } else {
  158. //>>4.编辑时同步登陆帐号状态
  159. $adu = new AdminUsers();
  160. $id = $form->getKey();
  161. $mm = mmInfo::find($id);
  162. $ad = $adu->find($mm->admin_user_id);
  163. $ad->status = $form->status;
  164. $ad->save();
  165. }
  166. });
  167. $form->deleted(function (Form $form, $result) {
  168. $aduids = array_column($form->model()->toArray(), 'admin_user_id');
  169. $mids = array_column($form->model()->toArray(), 'id');
  170. //删除对应的登陆帐号
  171. AdminUsers::whereIn('id', $aduids)->delete();
  172. //删除提现记录
  173. LanzuMmWithdraw::whereIn('mm_id',$mids)->update(['deleted_at'=>time()]);
  174. });
  175. });
  176. }
  177. /**
  178. * 获取市场信息
  179. * @return \Illuminate\Http\JsonResponse
  180. */
  181. protected function getMarket()
  182. {
  183. $user = Admin::user();
  184. $mp = LanzuMpInfo::where('admin_user_id', $user->id)->first();
  185. $data = [];
  186. if ($mp) {
  187. $markets = ImsCjdcMarket::where('mp_id', $mp->id)->get();
  188. foreach ($markets as $market) {
  189. $item = [];
  190. $item['id'] = $market->id;
  191. $item['text'] = $market->name;
  192. $data[] = $item;
  193. }
  194. }
  195. return response()->json($data);
  196. }
  197. }