CompanySetController.php 18 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437
  1. <?php
  2. namespace App\Admin\Controllers\Company;
  3. use App\Admin\Extensions\Form\ValidateForm;
  4. use App\Admin\Extensions\Form\ValueForm;
  5. use App\Http\Controllers\Controller;
  6. use App\Models\Company;
  7. use App\Models\CompanyDownResume;
  8. use App\Models\CompanyImg;
  9. use App\Models\CompanyInterView;
  10. use App\Models\MembersChargeLog;
  11. use App\Models\MembersPoint;
  12. use App\Models\MembersSetmeal;
  13. use App\Models\Order;
  14. use App\Models\PersonalJobsApply;
  15. use App\Models\Setmeal;
  16. use App\Models\Subsite;
  17. use App\Repositories\MemberPointRepository;
  18. use Encore\Admin\Auth\Permission;
  19. use Encore\Admin\Facades\Admin;
  20. use Encore\Admin\Grid;
  21. use Encore\Admin\Layout\Content;
  22. use Encore\Admin\Widgets\Tab;
  23. use Illuminate\Http\Request;
  24. use Encore\Admin\Form;
  25. class CompanySetController extends Controller
  26. {
  27. //企业相关内容
  28. public function comBusiness(Content $content, Request $request, $id, $type = 'points')
  29. {
  30. if (!intval($id)) {
  31. admin_toastr('参数错误');
  32. return back();
  33. }
  34. $tab = new Tab();
  35. $types = [
  36. 'points'=>'积分管理',
  37. 'setmeal'=>'套餐管理',
  38. 'order'=>'充值/订单',
  39. 'increment'=>'增值服务',
  40. 'down_resume'=>'下载的简历',
  41. 'apply'=>'收到的简历',
  42. 'interview'=>'面试邀请',
  43. 'companyimg'=>'企业风采管理',
  44. ];
  45. /**
  46. * 直接在case里头判断的话,case 完了的代码会产生css影响
  47. */
  48. if (!Admin::user()->can('company_comBusiness_points')) {
  49. unset($types["points"]);
  50. }
  51. if (!Admin::user()->can('company_comBusiness_setmeal')) {
  52. unset($types["setmeal"]);
  53. }
  54. foreach ($types as $key => $val) {
  55. $form=null;
  56. $memberSetform=null;
  57. switch ($key) {
  58. case 'points':
  59. $grid = new Grid(new MembersPoint());
  60. $grid->model()->where('uid', $id)->where('utype', 1)->when(get_subsite_id()>0, function ($querys) {
  61. $querys->whereHas('companys', function ($query) {
  62. $query->where('subsite_id', get_subsite_id());
  63. });
  64. })->whereHas('companys')->orderBy('created_at', 'desc');
  65. $grid->column('companys.companyname', '企业名称');
  66. $grid->points('积分');
  67. $grid->column('companys.username', '用户名称');
  68. $grid->column('companys.created_at', '注册时间');
  69. $grid->disableActions();
  70. $grid->disableTools();
  71. $grid->setPaginatorBaseUrl($key);
  72. $grid->disableRowSelector();
  73. $form=$this->PointeditForm()->edit($id);
  74. $form->setAction(admin_base_path("firm/comBusiness/update/{$id}"));
  75. $form->setTitle("修改");
  76. break;
  77. case 'setmeal':
  78. $grid = new Grid(new MembersSetmeal);
  79. $grid->model()->where('uid', $id)->where('utype', 1)->whereHas('companys')->when(get_subsite_id()>0, function ($querys) {
  80. $querys->whereHas('companys', function ($query) {
  81. $query->where('subsite_id', get_subsite_id());
  82. });
  83. })->orderBy('id', 'desc');
  84. $grid->id('id');
  85. $grid->setmeal_name('套餐名称');
  86. $grid->column('companys.companyname', '公司名称');
  87. $grid->column('companys.username', '用户名称');
  88. $grid->starttime('开始时间')->display(function ($starttime) {
  89. return date('Y-m-d H:i:s', $starttime);
  90. });
  91. $grid->endtime('结束时间')->display(function ($endtime) {
  92. if ($endtime) {
  93. return $endtime;
  94. }
  95. return "永久";
  96. });
  97. $grid->disableActions();
  98. $grid->disableTools();
  99. $grid->setName($key);
  100. $grid->setPaginatorBaseUrl($key);
  101. $grid->disableRowSelector();
  102. $memberSetmealInfo=MembersSetmeal::where(['uid'=>$id])->first();
  103. //套餐修改的form表单
  104. $memberSetform=$this->eidtMemberSetForm()->edit($memberSetmealInfo->id);
  105. $memberSetform->setAction(admin_base_path("firm/companysetmeal/index/{$memberSetmealInfo->id}"));
  106. $memberSetform->setTitle("套餐更换");
  107. //修改套餐内容的Form 表单
  108. $form=$this->eidtForm()->edit($memberSetmealInfo->id);
  109. $form->setTitle("套餐修改");
  110. $form->setAction(admin_base_path("firm/companysetmeal/index/{$memberSetmealInfo->id}"));
  111. break;
  112. case "order":
  113. $utype = 1;
  114. $grid = new Grid(new Order);
  115. $grid ->model()->where('uid', $id)->where('utype', $utype)->when(get_subsite_id()>0, function ($querys) {
  116. $relations = 'companys';
  117. $querys->whereHas($relations, function ($query) {
  118. $query->where('subsite_id', get_subsite_id());
  119. });
  120. })->orderBy('created_at', 'desc')->orderBy("is_pay", 'asc');
  121. $grid->id('ID');
  122. $grid->is_pay('支付状态')->display(function ($is_pay) {
  123. if ($is_pay == 1) {
  124. return '待付款';
  125. } elseif ($is_pay == 2) {
  126. return "已付款";
  127. } else {
  128. return '已取消';
  129. }
  130. });
  131. $grid->amount('金额')->width(150);
  132. $grid->column('companys.companyname', '企业名称')->width(200);
  133. $grid->service_name('说明')->width(150);
  134. $grid->column('companys.username', '企业会员')->width(200);
  135. $grid->oid('订单号')->width(200);
  136. $grid->created_at('申请时间');
  137. $grid->payment_cn('支付方式')->width(150);
  138. $grid->disableActions();
  139. $grid->disableTools();
  140. $grid->setName($key);
  141. // $tab_content[$key] = $grid;
  142. $grid->setPaginatorBaseUrl($key);
  143. $grid->disableRowSelector();
  144. break;
  145. case 'increment':
  146. $grid = new Grid(new Order);
  147. $grid->model()->where('uid', $id)->where('uid', $id)->where('utype', 1)->when(get_subsite_id()>0, function ($querys) {
  148. $querys->whereHas('companys', function ($query) {
  149. $query->where('subsite_id', get_subsite_id());
  150. });
  151. });
  152. $grid->id('ID');
  153. $grid->service_name('服务内容');
  154. $grid->column('companys.companyname', '企业名称');
  155. $grid->column('companys.username', '申请会员');
  156. $grid->amount('金额');
  157. $grid->created_at('申请时间');
  158. $grid->disableActions();
  159. $grid->disableTools();
  160. $grid->setName($key);
  161. $grid->setPaginatorBaseUrl($key);
  162. $grid->disableRowSelector();
  163. // $tab_content[$key] = $grid;
  164. break;
  165. case 'down_resume':
  166. $grid = new Grid(new CompanyDownResume);
  167. $grid->model()->where('company_uid', $id)->whereHas('resumes');
  168. $grid->id('ID');
  169. $grid->column('resumes.fullname', '姓名');
  170. $grid->column('resumes.birthdate', '年龄')->display(function ($birthdate) {
  171. return date('Y')-$birthdate;
  172. });
  173. $grid->column('resumes.sex_cn', '性别');
  174. $grid->column('resumes.education_cn', '学历');
  175. $grid->column('resumes.experience_cn', '工作经验');
  176. $grid->column('resumes.wage_cn', '期望薪资');
  177. $grid->down_addtime('下载时间')->display(function ($down_addtime) {
  178. return date('Y-m-d H:i:s', $down_addtime);
  179. });
  180. $grid->disableActions();
  181. $grid->disableTools();
  182. $grid->setName($key);
  183. $grid->setPaginatorBaseUrl($key);
  184. $grid->disableRowSelector();
  185. // $tab_content[$key] = $grid;
  186. break;
  187. case "apply":
  188. $grid = new Grid(new PersonalJobsApply);
  189. $grid->model()->where('company_id', $id)->whereHas('resumes');
  190. $grid->id('ID');
  191. $grid->column('resumes.fullname', '姓名');
  192. $grid->column('resumes.birthdate', '年龄')->display(function ($birthdate) {
  193. return date('Y')-$birthdate;
  194. });
  195. $grid->column('resumes.sex_cn', '性别');
  196. $grid->column('resumes.education_cn', '学历');
  197. $grid->column('resumes.experience_cn', '工作经验');
  198. $grid->column('jobs_name', '应聘职位');
  199. $grid->column('created_at', '投递时间');
  200. $grid->disableActions();
  201. $grid->disableTools();
  202. $grid->setName($key);
  203. $grid->setPaginatorBaseUrl($key);
  204. $grid->disableRowSelector();
  205. //$grid->model()->eloquent()->withPath('aaa');
  206. // $tab_content[$key] = $grid;
  207. break;
  208. case "interview":
  209. $grid = new Grid(new CompanyInterView);
  210. $grid->model()->where('company_id', $id)->whereHas('resumes');
  211. $grid->id('ID');
  212. $grid->column('resumes.fullname', '姓名');
  213. $grid->column('resumes.birthdate', '年龄')->display(function ($birthdate) {
  214. return date('Y')-$birthdate;
  215. });
  216. $grid->column('resumes.sex_cn', '性别');
  217. $grid->column('resumes.education_cn', '学历');
  218. $grid->column('resumes.experience_cn', '工作经验');
  219. $grid->column('resumes.wage_cn', '期望薪资');
  220. $grid->column('interview_time', '面试时间')->display(function ($interview_time) {
  221. return date('Y-m-d H:i:s', $interview_time);
  222. });
  223. $grid->disableActions();
  224. $grid->disableTools();
  225. // $tab_content[$key] = $grid;
  226. $grid->setName($key);
  227. $grid->setPaginatorBaseUrl($key);
  228. $grid->disableRowSelector();
  229. break;
  230. case 'companyimg':
  231. $grid = new Grid(new CompanyImg);
  232. $grid->model()->where('company_id', $id)->when(get_subsite_id()>0, function ($query) {
  233. $query->where('subsite_id', get_subsite_id());
  234. })->whereHas('companys')->orderByRaw('field(audit,0,2,1,3)')->orderBy('created_at', 'desc');
  235. $grid->id('ID');
  236. $grid->image()->image();
  237. $grid->company_id('企业名称')->display(function ($company_id) {
  238. $companyname = Company::where('id', $company_id)->select(['companyname'])->first();
  239. return $companyname['companyname'];
  240. })->width(200);
  241. $grid->audit('审核状态')->display(function ($audit) {
  242. switch ($audit) {
  243. case 1:
  244. return '<span style="color:#009900">审核通过</span>';
  245. break;
  246. case 2:
  247. return '<span style="color:#FF6600">审核中</span>';
  248. break;
  249. case 3:
  250. return '<span style="color:#FF0000">审核未通过</span>';
  251. break;
  252. case 0:
  253. return '<span style="color:#FF6600">未审核</span>';
  254. break;
  255. }
  256. });
  257. $grid->subsite_id('所属分站')->display(function ($subsite_id) {
  258. if ($subsite_id == 0) {
  259. return "总站";
  260. } else {
  261. $subsite = Subsite::findOrFail($subsite_id);
  262. return $subsite->sitename;
  263. }
  264. });
  265. $grid->created_at('添加时间');
  266. $grid->disableActions();
  267. $grid->disableTools();
  268. $grid->setName($key);
  269. $grid->setPaginatorBaseUrl($key);
  270. $grid->disableRowSelector();
  271. break;
  272. }
  273. if (!empty($grid)){
  274. $tab->add($val, view('admin.company.content')->with(['contents'=>$grid,'form'=>$form,'memberSetform'=>$memberSetform] ), $type == $key);
  275. }
  276. }
  277. return $content
  278. ->header('企业信息')
  279. ->description('列表')
  280. ->body($tab->render());
  281. }
  282. public function update($id,MemberPointRepository $memberPointRepository){
  283. $data = $this->PointeditForm($id)->getValidateInput();
  284. if($data['points']){
  285. if ($data['regpoints'] == 1) {
  286. //增加积分
  287. $pointData['points'] = $data['points'];
  288. if (false == $memberPointRepository->reportDeal($id, 1, 1, $data['points'])) {
  289. admin_toastr('企业增加积分失败', 'error');
  290. }
  291. } else {
  292. //减少积分
  293. if (false == $memberPointRepository->reportDeal($id, 1, 2, $data['points'])) {
  294. admin_toastr('企业增加积分失败', 'error');
  295. }
  296. }
  297. }
  298. $amount = 0;
  299. if ($data['is_money']) {
  300. $amount = $data['amount'];
  301. $company=Company::find($id);
  302. $logData['log_uid'] = $id;
  303. $logData['log_utype'] = 1;
  304. $logData['log_username'] = $company->username;
  305. $logData['log_value'] = "操作人:".Admin::user()->username.",说明:修改会员:{$company->username},(+{$data['points']})积分,收到".$amount."元。";
  306. $logData['log_amount'] = $amount;
  307. $logData['log_ismoney'] = $data['is_money'];
  308. $logData['log_type'] = 2;
  309. $logData['log_mode'] = 1;
  310. if (!MembersChargeLog::create($logData)) {
  311. admin_toastr('企业增加记录失败', 'error');
  312. }
  313. }
  314. admin_toastr('积分修改成功', 'success');
  315. return back();
  316. }
  317. //积分表单
  318. public function PointeditForm(){
  319. Permission::check('company_comBusiness_points');
  320. $form = new ValidateForm(new Company);
  321. $form->radio('regpoints', '管理积分')->options([0=>'减少', 1=>'增加' ])->default('1');
  322. $form->number('points', '赠送数量')->min(0);
  323. $form->switch('is_money', '是否收费');
  324. $form->number('amount', '收费金额')->min(0);
  325. return $form;
  326. }
  327. //套餐内容表单
  328. public function eidtForm()
  329. {
  330. Permission::check('company_comBusiness_setmeal');
  331. $form= new Form(new MembersSetmeal);
  332. $form->display('id');
  333. $form->display('companys.companyname', '企业名称');
  334. $form->display('setmeal_name', '套餐名称');
  335. $form->display('setmealtime', '服务时间')->with(function () {
  336. return '起:'.date('Y-m-d H:i:s', $this->starttime).' ~ 止:'.($this->endtime ==0?"无限制":$this->endtime);
  337. });
  338. $form->datetime('endtime', '到期时间');
  339. //
  340. $form->text('dayes', '服务天数')->help("默认为空表示不做修改,0为不限制,如填写3则延长3天,-3则减少3天");
  341. $form->hidden('days', "服务天数");
  342. $form->number('jobs_meanwhile', '在招职位数')->min(0);
  343. $form->number('jobfair_num', '招聘会场次')->min(0);
  344. $form->number('refresh_jobs_free', '职位免费刷新数')->min(0);
  345. $form->number('download_resume', '下载简历数')->min(0);
  346. $form->number('download_resume_max', '下载简历数上限')->min(0);
  347. $form->number('companys.sms_num', '短信数')->min(0);
  348. $form->radio('show_apply_contact', '收到简历的联系方式')->options([0=>'需下载',1=>'免费查看']);
  349. $form->text('added', '其他说明');
  350. $form->hidden('uid');
  351. $form->hidden('utype');
  352. $form->hidden('companys.username');
  353. $form->hidden('starttime');
  354. $form->hidden('setmeal')->default(2);
  355. return $form;
  356. }
  357. //改变套餐的表单
  358. public function eidtMemberSetForm()
  359. {
  360. Permission::check('company_comBusiness_setmeal');
  361. $form= new Form(new MembersSetmeal);
  362. $setmeal = Setmeal::where('display', 1)->list()->pluck('setmeal_name', 'id')->toArray();
  363. empty(\request('setmeal_id')) ? request()->offsetSet('setmeal_id', key($setmeal)) : "" ;
  364. $form->radio('setmeal_id', '会员套餐')->options($setmeal)->default(key($setmeal))->rules(['required'], ['required'=>'请选择相应的会员套餐'])->setMustMark();
  365. $form->switch('is_money', '是否已收费');
  366. $form->text('amount', '收费金额');
  367. $form->hidden('setmeal')->default(1);
  368. return $form;
  369. }
  370. }