CheckService.php 3.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117
  1. <?php
  2. namespace App\Service;
  3. use App\Model\SalesOrder;
  4. use Illuminate\Support\Facades\DB;
  5. class CheckService extends Service
  6. {
  7. //审批操作对应的数值
  8. const one = 1; //收货
  9. const two = 2; //发货
  10. const three = 3; //采购
  11. const four = 4; //销售订单
  12. const five = 5; //施工单
  13. //中文对照
  14. public $map = [
  15. self::one => '收货单',
  16. self::two => '发货单',
  17. self::three => '采购单',
  18. self::four => '销售订单',
  19. self::five => '施工单',
  20. ];
  21. const TYPE_ONE = 1;//通过
  22. const TYPE_TWO = 2;//不通过
  23. public static $opt_case = [
  24. self::four => 'confirmSalesOrder'
  25. ];
  26. public static $record = [
  27. ];
  28. public function confirmSalesOrder($data){
  29. $model = SalesOrder::where('id',$data['id'])->where('del_time',0)->first();
  30. if($data['type'] == self::TYPE_ONE){
  31. if($model->state == SalesOrder::State_one) return [false,'已锁定,操作失败!'];
  32. $model->state = SalesOrder::State_one;
  33. }else{
  34. if($model->state == SalesOrder::State_zero) return [false,'未锁定,操作失败!'];
  35. $model->state = SalesOrder::State_zero;
  36. }
  37. $model->save();
  38. return [true,$model];
  39. }
  40. public function checkAll($data,$user){
  41. if(empty($data['id']) || empty($data['opt_case']) || empty($data['type'])) return [false,'必传参数不能为空或者参数值错误!'];
  42. //具体方法
  43. $function = self::$opt_case[$data['opt_case']];
  44. try{
  45. DB::beginTransaction();
  46. //更新单据的状态 从待审变成已审核
  47. list($bool,$msg) = $this->$function($data);
  48. if(! $bool){
  49. DB::rollBack();
  50. return [false, $msg];
  51. }
  52. DB::commit();
  53. return [true, ''];
  54. }catch (\Throwable $exception){
  55. DB::rollBack();
  56. return [false, $exception->getMessage()];
  57. }
  58. }
  59. public function createRecordAndInventory($data = []){
  60. if(empty($data['order_number']) || empty($data['type']) || empty($data['opt_case']) || ! isset(self::$opt_case[$data['opt_case']])) return [false,300];
  61. //具体方法
  62. $function = self::$opt_case[$data['opt_case']];
  63. try{
  64. DB::beginTransaction();
  65. //更新单据的状态
  66. $bool = $this->$function($data);
  67. if($bool && $data['type'] == self::TYPE_ONE && isset(self::$record[$data['opt_case']])){
  68. //审批通过 创建流水
  69. $function_record = self::$record[$data['opt_case']];
  70. $boolean = $this->$function_record($data);
  71. if(! $boolean) { //创建流水失败 数据库回滚
  72. DB::rollBack();
  73. return [false, 300];
  74. }
  75. //更新库存
  76. $inventory = new InventoryService();
  77. $boole = $inventory->changeInventory($data);
  78. if(! $boole){
  79. DB::rollBack();
  80. return [false, 300];
  81. }
  82. }
  83. DB::commit();
  84. return [true, 200];
  85. }catch (\Throwable $exception){
  86. DB::rollBack();
  87. return [false, 201];
  88. }
  89. }
  90. }