AccountItem.php 4.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103
  1. <?php
  2. namespace app\user\controller;
  3. use app\user\model\CompanyItem;use think\App;
  4. use think\facade\Validate;
  5. class AccountItem extends Base{
  6. protected $noLogin=[];
  7. public function __construct(App $app) {
  8. parent::__construct($app);
  9. $this->model=new \app\user\model\AccountItem();
  10. }
  11. /**
  12. * @param int $account_id 账户id
  13. * @param int $itemid 部门id
  14. * @param int $position 1:部门 2:主管部门
  15. * @return \think\response\Json
  16. */
  17. public function setItem(){
  18. $param=$this->request->param(["account_id"=>"","itemid"=>"",'position'=>'1'],"post","trim");
  19. $valid = Validate::rule([
  20. "account_id|账户id"=>"require|number|gt:0",
  21. "itemid|部门id"=>"require|number|gt:0",
  22. ]);
  23. if($valid->check($param)==false) return error($valid->getError());
  24. $info = $this->model->where(["account_id"=>$param['account_id']])->findOrEmpty();
  25. $this->model->startTrans();
  26. try{
  27. if($param['position']==2){
  28. $position=$this->model->where([['itemid','=',$param['itemid']],['position','=',2],['account_id','<>',$param['account_id']],])
  29. ->findOrEmpty();
  30. if($position->isEmpty()==false){
  31. $position->position=1;
  32. $position->save();
  33. }
  34. }
  35. $info->account_id = $param['account_id'];
  36. $info->itemid = $param['itemid'];
  37. $info->position = $param['position'];
  38. $result= $info->save();
  39. if($result==false) return error("部门设置失败");
  40. $this->model->commit();
  41. }catch(\Exception $e){
  42. $this->model->rollback();
  43. return error($e->getMessage());
  44. }
  45. return success("部门设置成功");
  46. }
  47. /**
  48. * @param int $account_id 账户id
  49. * @return \think\Response|\think\response\Json|void
  50. */
  51. public function resetItem(){
  52. $param=$this->request->param(['account_id'=>''],'post','trim');
  53. $valid = Validate::rule([
  54. 'account_id|账户id'=>'require|number|gt:0',
  55. ]);
  56. if($valid->check($param)==false) return error($valid->getError());
  57. $info = $this->model->where(['account_id'=>$param['account_id']])->findOrEmpty();
  58. if($info->position==2)return error('请先解除用户部门主管');
  59. $result= $info->delete();
  60. return $result ? success('部门解除成功'): error('部门解除失败');
  61. }
  62. /**
  63. * @return \think\Response|\think\response\Json
  64. * @throws \think\db\exception\DataNotFoundException
  65. * @throws \think\db\exception\DbException
  66. * @throws \think\db\exception\ModelNotFoundException
  67. */
  68. public function list(){
  69. $param = $this->request->param(['pid' => '', 'name' => '', 'account_id' => '', 'companyNo' => ''], 'post', 'trim');
  70. $condition = [["is_del","=",0]];
  71. if($param['pid']!=='')$condition[]=['pid','=',$param['pid']];
  72. if($param['name']!=='')$condition[]=['name','like','%'.$param['name'].'%'];
  73. if($param['account_id']!=='')$condition[]=['account_id','=',$param['account_id']];
  74. if($param['companyNo']!=='')$condition[]=['companyNo','like','%'.$param['companyNo'].'%'];
  75. $depart = new CompanyItem();
  76. $list = $depart->with(["companyInfo"])->where($condition)->order('id asc')->select();
  77. $userwhere=[['is_del','=',0]];
  78. if(!$list->isEmpty()){
  79. $userwhere[]=['itemid', 'in', array_unique(array_column($list->toArray(),"pid"))];
  80. }else{
  81. $userwhere[]=['itemid', '=', $param['pid']??0];
  82. }
  83. $item= $this->model->with(['accountInfo'=>['userInfo']])->where($userwhere)->select();
  84. return success("获取成功",['depart' => $list, 'item' => $item]);
  85. }
  86. /**
  87. * @return \think\Response|\think\response\Json|void
  88. */
  89. public function getItem(){
  90. $param = $this->request->param(['account_id' => ''], 'post', 'trim');
  91. $valid = Validate::rule([
  92. 'account_id|账户id' => 'require|number|gt:0',
  93. ]);
  94. if($valid->check($param)==false) return error($valid->getError());
  95. $info = $this->model->with(['ItemName'])->where(['account_id'=>$param['account_id']])->findOrEmpty();
  96. if($info->isEmpty())return error('未找到部门信息');
  97. return success('获取成功',$info);
  98. }
  99. }