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; } }