| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145 | <?phpnamespace app\common\model;use app\hander\HelpHander;use think\Db;use think\Exception;use think\Model;class AssetItems extends Model{    public $statusTxt = ['禁用','在库','使用','借用','维修','处置','待处置'];    public function updates(){        $data = request()->post();        $data['org_id'] = cur_org_id();        $result = validate('asset_items')->check($data,[],'');        if(true !== $result){            $this->error = validate('asset_items')->getError();            return false;        }        if($data['cate_id']){            $arr = $data['cate_id']?explode(',',$data['cate_id']):[];            $data['cate_id'] = end($arr);        }        $id = $data['id'];        unset($data['id']);        if($id > 0){            $data['update_time'] = date('Y-m-d H:i:s');            unset($data['nums']);            $ret = $this->allowField(true)->save($data,['id'=>$id]);            if(!$ret){                $this->error = '操作失败';                return false;            }        }else{            $data['create_time'] = date('Y-m-d H:i:s');            Db::startTrans();            try{                $max = Db::name('asset_items')                    ->where('org_id',$data['org_id'])                    ->where('create_time','>=',date('Y-m-d').' 00:00:00')                    ->order('id desc')                    ->value('sn');                $maxinit = $max?$max:date('Ymd').'0000';                $nums = $data['nums'];                $data['nums'] = 1;                for ($i=1;$i<=$nums;$i++){                    $data['sn'] = $maxinit + $i;                    $ret = Db::name('asset_items')->insert($data);                    if(!$ret){                        \exception('操作失败');                    }                }                Db::commit();            }catch (Exception $e){                Db::rollback();                $this->error = $e->getMessage();                return false;            }        }        return true;    }    public function info($id){        $info = $this->where('id',$id)->find();        if(!$info){            HelpHander::error('数据不存在');        }        return $info->toArray();    }    // type 0=全部在库和使用 1=在库 2=使用    // 去除掉正在审批中的物品    public function selectlists($page,$size,$title,$cateId,$companyId,$addId,$classId,$userId,$orgId,$type=0){        $map[] = ['org_id','=',$orgId];        $map[] = ['del','=',0];//        $map[] = ['is_check','=',0]; // 不取盘库中的物品//        $ids = $this->itemsuse($orgId);//        if($ids){//            $map[] = ['id','not in',$ids];//        }        if($cateId > 0){            $map[] = ['cate_id','=',$cateId];        }        if($title){            $map[] = ['sn|title','like','%'.$title.'%'];        }        if($companyId > 0){            $map[] = ['company_id','=',$companyId];        }        if($addId > 0){            $map[] = ['add_id','=',$addId];        }        if($classId > 0){            $map[] = ['class_id','=',$classId];        }        if($type == 1){            $map[] = ['enable','=',1];        } else if($type == 2){            $map[] = ['enable','=',2];//            $map[] = ['user_id','=',$userId];        }else{            $map[] = ['enable','in','1,2'];        }        $lists = $this            ->where($map)            ->page($page,$size)            ->order('id desc')            ->select();        $lists = $lists?$lists->toArray():[];        foreach ($lists as $k=>$v){            $lists[$k]['cate_name'] = Db::name('asset_cate')->where('id',$v['cate_id'])->value('title');            $lists[$k]['unit_name'] = Db::name('asset_unit')->where('id',$v['unit_id'])->value('title');            $lists[$k]['class_name'] = Db::name('asset_class')->where('id',$v['class_id'])->value('title');            $lists[$k]['add_name'] = Db::name('asset_add')->where('id',$v['add_id'])->value('title');            $lists[$k]['user_name'] = '';            $lists[$k]['dep_name'] = '';            if($v['user_id'] > 0){                $lists[$k]['user_name'] = Db::name('user')->where('id',$v['user_id'])->value('real_name');            }            if($v['dep_id'] > 0){                $lists[$k]['dep_name'] = Db::name('dep')->where('id',$v['dep_id'])->value('title');            }        }        $total = $this->where($map)->count();        $data = [            'total' => $total,            'list' => $lists        ];        return $data;    }}
 |