AssetService.php 4.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118
  1. <?php
  2. namespace App\Service;
  3. use App\Model\Asset;
  4. use App\Model\InventoryOrder;
  5. use App\Model\InventoryOrderAsset;
  6. class AssetService extends Service
  7. {
  8. public function edit($data){
  9. list($status,$msg) = $this->AssetRule($data,false);
  10. if(!$status) return [$status,$msg];
  11. $model = new Asset();
  12. $model = $model->where('id',$data['id'])->first();
  13. $model->name = $data['name'];
  14. $model->singleCode = $data['singleCode'];
  15. $model->assetNo = $data['assetNo'] ?? '';
  16. $model->version = $data['version'] ?? '';
  17. $model->located = $data['located'] ?? '';
  18. $model->startUseDate = $data['startUseDate'] ?? '';
  19. $model->useDept = $data['useDept'] ?? '';
  20. $model->userName = $data['userName'] ?? '';
  21. $model->assetCode = $data['assetCode'] ?? '';
  22. $model->assetType = $data['assetType'] ?? '';
  23. $model->originalValue = $data['originalValue'] ?? '';
  24. $model->purchaseTime = $data['purchaseTime'] ?? '';
  25. $model->expectedLife = $data['expectedLife'] ?? '';
  26. $model->isKey = $data['isKey'] ?? '';
  27. $model->brand = $data['brand'] ?? '';
  28. $model->type = $data['type'] ?? '';
  29. $model->remark = $data['remark'] ?? '';
  30. $model->kind = $data['kind'] ?? '';
  31. $model->gs1 = $data['gs1'] ?? '';
  32. $model->nextCalibrationTime = $data['nextCalibrationTime'] ?? '';
  33. $model->save();
  34. return [true,''];
  35. }
  36. public function add($data){
  37. list($status,$msg) = $this->AssetRule($data);
  38. if(!$status) return [$status,$msg];
  39. $model = new Asset();
  40. $model->name = $data['name'];
  41. $model->singleCode = $data['singleCode'];
  42. $model->assetNo = $data['assetNo'] ?? '';
  43. $model->version = $data['version'] ?? '';
  44. $model->located = $data['located'] ?? '';
  45. $model->startUseDate = $data['startUseDate'] ?? '';
  46. $model->useDept = $data['useDept'] ?? '';
  47. $model->userName = $data['userName'] ?? '';
  48. $model->assetCode = $data['assetCode'] ?? '';
  49. $model->assetType = $data['assetType'] ?? '';
  50. $model->originalValue = $data['originalValue'] ?? '';
  51. $model->purchaseTime = $data['purchaseTime'] ?? '';
  52. $model->expectedLife = $data['expectedLife'] ?? '';
  53. $model->isKey = $data['isKey'] ?? '';
  54. $model->brand = $data['brand'] ?? '';
  55. $model->type = $data['type'] ?? '';
  56. $model->remark = $data['remark'] ?? '';
  57. $model->kind = $data['kind'] ?? '';
  58. $model->gs1 = $data['gs1'] ?? '';
  59. $model->nextCalibrationTime = $data['nextCalibrationTime'] ?? '';
  60. $model->save();
  61. return [true,''];
  62. }
  63. public function del($data){
  64. if($this->isEmpty($data,'id')) return [false,'请选择数据!'];
  65. $bool = InventoryOrderAsset::where('del_time',0)
  66. ->where('asset_id',$data['id'])
  67. ->exists();
  68. if($bool) return [false,'资产已录入盘点单,删除失败!'];
  69. Asset::where('id',$data['id'])->update([
  70. 'del_time' => time()
  71. ]);
  72. return [true,''];
  73. }
  74. public function assetList($data){
  75. $model = Asset::where('del_time',0)
  76. ->select('*')
  77. ->orderby('id', 'desc');
  78. if(! empty($data['name'])) $model->where('name', 'LIKE', '%'.$data['name'].'%');
  79. if(! empty($data['singleCode'])) $model->where('singleCode', 'LIKE', '%'.$data['singleCode'].'%');
  80. $list = $this->limit($model,'',$data);
  81. return [true,$list];
  82. }
  83. public function AssetRule($data, $is_check = true){
  84. if($this->isEmpty($data,'name')) return [false,'资产名称不能为空!'];
  85. if($this->isEmpty($data,'singleCode')) return [false,'资产唯一码不能为空!'];
  86. if($is_check){
  87. $bool = Asset::where('del_time',0)
  88. ->where('singleCode',$data['singleCode'])
  89. ->exists();
  90. }else{
  91. if($this->isEmpty($data,'id')) return [false,'数据ID不能为空!'];
  92. $bool = Asset::where('del_time',0)
  93. ->where('id','<>',$data['id'])
  94. ->where('singleCode',$data['singleCode'])
  95. ->exists();
  96. }
  97. if($bool) return [false,'资产唯一码不能重复'];
  98. return [true, ''];
  99. }
  100. }