CheckService.php 9.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232
  1. <?php
  2. namespace App\Service;
  3. use App\Model\Construction;
  4. use App\Model\ConstructionOrderSub;
  5. use App\Model\InOutRecord;
  6. use App\Model\Inventory;
  7. use App\Model\InventoryInSub;
  8. use App\Model\InventoryOutSub;
  9. use App\Model\MaterialCharge;
  10. use App\Model\MaterialOrder;
  11. use App\Model\MaterialOrderInSub;
  12. use App\Model\MaterialReturn;
  13. use App\Model\RollFilmInventory;
  14. use App\Model\Setting;
  15. use App\Model\Transfer;
  16. use App\Model\TransferInSub;
  17. use App\Model\TransferOutSub;
  18. use App\Model\Warranty;
  19. use App\Service\Oa\OaService;
  20. use Illuminate\Support\Facades\DB;
  21. /**
  22. * 所有审批相关与流水
  23. * @package App\Models
  24. */
  25. class CheckService extends Service
  26. {
  27. //审批操作对应的数值
  28. const one = 1; //领料单申领区域审批
  29. const two = 2; //领料单发货区域审批
  30. const three = 3; //领料单收货区域审批
  31. const four = 4; //领料单入库区域审批
  32. const five = 5; //施工单审核
  33. const six = 6; //退料单审核
  34. const seven = 7; //调拨单详情审核
  35. const eight = 8; //调拨单入库审核
  36. const nine = 9; //调拨单出库审核
  37. const ten = 10; //盘点单详情审核
  38. const eleven = 11; //盘点单入库审核
  39. const twl = 12; //盘点单出库审核
  40. const thirteen = 13; //计费领料单审核
  41. //中文对照
  42. public $map = [
  43. self::one => '领料单申领区域审批',
  44. self::two => '领料单发货区域审批',
  45. self::three => '领料单收货区域审批',
  46. self::four => '领料单入库区域审批',
  47. self::five => '施工单审核',
  48. self::six => '退料单审核',
  49. self::seven => '调拨单详情审核',
  50. self::eight => '调拨单入库审核',
  51. self::nine => '调拨单出库审核',
  52. self::ten => '盘点单详情审核',
  53. self::eleven => '盘点单入库审核',
  54. self::twl => '盘点单出库审核',
  55. self::thirteen => '计费领料单审核',
  56. ];
  57. const TYPE_ONE = 1;//通过
  58. const TYPE_TWO = 2;//不通过
  59. //对应具体单子的具体操作数值(将待审批改为通过或者未审批)
  60. public static $opt_case = [
  61. self::one => 'check_material_order_apply', //领料单申领区域审批
  62. self::two => 'check_material_order_send', //领料单发货区域审批
  63. self::three => 'check_material_order_take', //领料单收货区域审批
  64. self::four => 'check_material_order_In', //领料单入库区域审批 审批通过后有入库流水
  65. self::five => 'check_construction', //施工单审核 审批通过后有出库流水
  66. self::six => 'check_material_return', //退料单审核 审批通过后有出库流水
  67. self::seven => 'check_transfer_sub', //调拨单详情审核
  68. self::eight => 'check_transfer_in_sub', //调拨单入库审核 审批通过后有入库流水
  69. self::nine => 'check_transfer_out_sub', //调拨单出库审核 审批通过后有出库流水
  70. self::ten => 'check_inventory_sub', //盘点单详情审核
  71. self::eleven => 'check_inventory_in_sub', //盘点单入库审核 审批通过后有入库流水
  72. self::twl => 'check_inventory_out_sub', //盘点单出库审核 审批通过后有出库流水
  73. self::thirteen => 'check_material_charge', //计费领料单审核
  74. ];
  75. //单子审批通过后产生流水
  76. public static $record = [
  77. self::four => 'record_material_order_In', //领料单入库区域审批 审批通过后有入库流水
  78. self::five => 'record_construction', //施工单审核 审批通过后有出库流水
  79. self::six => 'record_material_return', //退料单审核 审批通过后有出库流水
  80. self::eight => 'record_transfer_in_sub', //调拨单入库审核 审批通过后有入库流水
  81. self::nine => 'record_transfer_out_sub', //调拨单出库审核 审批通过后有出库流水
  82. self::eleven => 'record_inventory_in_sub', //盘点单入库审核 审批通过后有入库流水
  83. self::twl => 'record_inventory_out_sub', //盘点单出库审核 审批通过后有出库流水
  84. ];
  85. //将状态改为待审核
  86. public static $opt_case2 = [
  87. self::one => 'set_check_material_order_apply', //领料单申领区域审批
  88. self::two => 'set_check_material_order_send', //领料单发货区域审批
  89. self::three => 'set_check_material_order_take', //领料单收货区域审批
  90. self::four => 'set_check_material_order_In', //领料单入库区域审批 审批通过后有入库流水
  91. self::five => 'set_check_construction', //施工单审核 审批通过后有出库流水
  92. self::six => 'set_check_material_return', //退料单审核 审批通过后有出库流水
  93. self::seven => 'set_check_transfer_sub', //调拨单详情审核
  94. self::eight => 'set_check_transfer_in_sub', //调拨单入库审核 审批通过后有入库流水
  95. self::nine => 'set_check_transfer_out_sub', //调拨单出库审核 审批通过后有出库流水
  96. self::ten => 'set_check_inventory_sub', //盘点单详情审核
  97. self::eleven => 'set_check_inventory_in_sub', //盘点单入库审核 审批通过后有入库流水
  98. self::twl => 'set_check_inventory_out_sub', //盘点单出库审核 审批通过后有出库流水
  99. self::thirteen => 'set_check_material_charge', //计费领料单审核
  100. ];
  101. public static $opt_case3 = [
  102. self::five => 'create_warranty', //施工单审核 审批产生质保单
  103. ];
  104. //将状态改为待审核
  105. public function set_status_to_one($data){
  106. $modelOne = MaterialOrder::where('order_number',$data['order_number'])->where('del_time',0)->first();
  107. //待审
  108. if($modelOne->apply_status >= MaterialOrder::STATE_ONE) return [false,'已待审或审核通过,操作失败!'];
  109. $modelOne->apply_status = MaterialOrder::STATE_ONE;
  110. $modelOne->save();
  111. return [true,''];
  112. }
  113. /**
  114. * order_number 单据名称
  115. * opt_case 审核单据的区域 有已经定义的方法
  116. */
  117. public function checkAll($data,$user){
  118. if(empty($data['order_number']) || empty($data['opt_case']) || ! isset(self::$opt_case2[$data['opt_case']])) return [false,'必传参数不能为空或者参数值错误!'];
  119. //具体方法
  120. $function = self::$opt_case2[$data['opt_case']];
  121. $function2 = self::$opt_case3[$data['opt_case']] ?? '';
  122. try{
  123. DB::beginTransaction();
  124. //更新单据的状态 从待审变成已审核
  125. list($bool,$msg) = $this->$function($data);
  126. if(! $bool){
  127. DB::rollBack();
  128. return [false, $msg];
  129. }
  130. if($function2){
  131. $this->$function2($data,$user);
  132. }
  133. //创建审批流
  134. $args = [
  135. 'order_no' => $data['order_number'],
  136. 'menu_id' => $data['menu_id'] ?? 0,
  137. 'type' => $data['opt_case']
  138. ];
  139. $oa = new OaService();
  140. $bool = $oa->createOaOrder($args);
  141. DB::commit();
  142. return [true, ''];
  143. }catch (\Throwable $exception){
  144. DB::rollBack();
  145. return [false, $exception->getMessage()];
  146. }
  147. }
  148. //创建审批流 将状态改为待审核 结束
  149. //将待审核状态改为审批通过或者驳回
  150. public function check_status($data){
  151. return true;
  152. }
  153. //产生流水
  154. public function record_create($data){
  155. $result = [];
  156. //写入流水
  157. InOutRecord::insert($result);
  158. return true;
  159. }
  160. /**
  161. * 业务单据审核统一入库
  162. * order_number 订单编号
  163. * type 1 =》 通过 2 =》 驳回
  164. * opt_case 具体审核类型 已定义同名静态变量
  165. */
  166. public function createRecordAndInventory($data = []){
  167. if(empty($data['order_number']) || empty($data['type']) || empty($data['opt_case']) || ! isset(self::$opt_case[$data['opt_case']])) return [false,config('response.FAILED')];
  168. //具体方法
  169. $function = self::$opt_case[$data['opt_case']];
  170. try{
  171. DB::beginTransaction();
  172. //更新单据的状态
  173. $bool = $this->$function($data);
  174. if($bool && $data['type'] == self::TYPE_ONE && isset(self::$record[$data['opt_case']])){
  175. //审批通过 创建流水
  176. $function_record = self::$record[$data['opt_case']];
  177. $boolean = $this->$function_record($data);
  178. if(! $boolean) { //创建流水失败 数据库回滚
  179. DB::rollBack();
  180. return [false, config('response.FAILED')];
  181. }
  182. //更新库存
  183. $inventy = new InventoryService();
  184. $boole = $inventy->changeInventory($data);
  185. if(! $boole){
  186. DB::rollBack();
  187. return [false, config('response.FAILED')];
  188. }
  189. }
  190. DB::commit();
  191. return [true, config('response.SUCCESS')];
  192. }catch (\Throwable $exception){
  193. DB::rollBack();
  194. return [false, config('response.FAILED')];
  195. }
  196. }
  197. }