JsAlreadyController.php 4.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141
  1. <?php
  2. /**
  3. * Created by PhpStorm.
  4. * User: Administrator
  5. * Date: 2020-08-28
  6. * Time: 8:46
  7. */
  8. namespace app\back\controller;
  9. use app\back\model\JsCategoryModel;
  10. use app\back\model\JsModel;
  11. use cmf\controller\AdminBaseController;
  12. use think\Db;
  13. class JsAlreadyController extends AdminBaseController
  14. {
  15. public function index()
  16. {
  17. $where= [];
  18. $jsModel = new JsModel();
  19. $page = $this->request->param('page',1);
  20. $pw = [];
  21. $keyword = $this->request->param('keyword');
  22. $category_id = $this->request->param('category_id');
  23. if($category_id){
  24. $this->assign('category_id',$category_id);
  25. $pw['category_id'] = $category_id;
  26. $js_ids = Db::name('js_category_relevancy')->where('category_id',$category_id)->field('js_id')->select();
  27. $js_new_ids = [];
  28. foreach ($js_ids as $vo)
  29. {
  30. $js_new_ids[] = $vo['js_id'];
  31. }
  32. $where['id'] = $js_new_ids;
  33. }
  34. if($keyword){
  35. $this->assign('keyword',$keyword);
  36. $pw['keyword'] = $keyword;
  37. }
  38. // die;
  39. $where['js_status'] = [1,3];
  40. $list = $jsModel->with(['user','category','project'=>function($query){$query->where('status',1);}])->where($where)->where(function ($query) use ($keyword){
  41. if($keyword){
  42. $query->where('name|phone','like','%'.$keyword.'%');
  43. }
  44. })->order('id','desc')->paginate(30,false,array($page,url('index'),'query'=>$pw));
  45. // var_dump($jsModel->getLastSql());
  46. $JsCategoryModel = new JsCategoryModel();
  47. $js_category_list = $JsCategoryModel::select();
  48. $this->assign('list',$list);
  49. $this->assign('js_category_list',$js_category_list);
  50. $this->assign('page',$list->render());
  51. return $this->fetch();
  52. }
  53. public function show()
  54. {
  55. $ids = $this->request->param('ids/a');
  56. $is_show = $this->request->param('is_show');
  57. JsModel::where('id','in',$ids)->update(['is_show'=>$is_show]);
  58. $this->success('操作成功');
  59. }
  60. public function listOrder()
  61. {
  62. $JsModel= new JsModel();
  63. parent::listOrders($JsModel);
  64. $this->success("排序更新成功!");
  65. }
  66. public function delete()
  67. {
  68. $id = $this->request->param('id');
  69. JsModel::destroy($id);
  70. $this->success('删除成功');
  71. }
  72. public function xj()
  73. {
  74. $id = $this->request->param('id');
  75. $info = JsModel::get($id);
  76. $type = $this->request->param('type');
  77. if($type*1==1){
  78. $info->save(['js_status'=>3]);
  79. }else{
  80. $info->save(['js_status'=>1]);
  81. }
  82. $this->success('下架成功');
  83. }
  84. public function setCategory()
  85. {
  86. $js_id = $this->request->param('js_id');
  87. $car_ids = $this->request->param('car_ids/a');
  88. Db::name('js_category_relevancy')->where('js_id',$js_id)->delete();
  89. $ins = [];
  90. foreach ($car_ids as $k=>$v){
  91. $ins[$k]['category_id'] = $v;
  92. $ins[$k]['js_id'] = $js_id;
  93. }
  94. Db::name('js_category_relevancy')->insertAll($ins);
  95. return json(['code'=>1]);
  96. }
  97. public function edit()
  98. {
  99. $id = $this->request->param('id');
  100. $info = JsModel::get($id);
  101. $this->assign('info',$info);
  102. return $this->fetch();
  103. }
  104. public function editpost()
  105. {
  106. $data = $this->request->param();
  107. $JsModel = new JsModel();
  108. $info = JsModel::get($data['id'])->toArray();
  109. if(isset($data['v_jiedan_num']) && $data['v_jiedan_num'] != $info['v_jiedan_num']){
  110. $data['jiedan_num'] = $info['jiedan_num']+$data['v_jiedan_num']-$info['v_jiedan_num'];
  111. $admin_id = cmf_get_current_admin_id();
  112. $log_info = '变更前:'.$info['v_jiedan_num'].';变更后:'.$data['v_jiedan_num'];
  113. admin_log($admin_id,$log_info,$data['id'],'修改技师虚拟单');
  114. }
  115. $JsModel->allowField(true)->isUpdate(true)->save($data,['id'=>$data['id']]);
  116. $this->success('修改成功!');
  117. }
  118. public function cancel()
  119. {
  120. $id = $this->request->param('id');
  121. $js_id = $this->request->param('js_id');
  122. Db::name('js_project_relevancy')->where(['project_id'=>$id,'js_id'=>$js_id])->delete();
  123. $this->success('取消成功');
  124. }
  125. }