WorkOrderCommodities.php 4.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293
  1. <?php
  2. namespace App;
  3. use App\Traits\ModelTimeFormat;
  4. use Illuminate\Database\Eloquent\Model;
  5. use Illuminate\Database\Eloquent\Relations\BelongsTo;
  6. class WorkOrderCommodities extends Model
  7. {
  8. use ModelTimeFormat;
  9. protected $fillable = [
  10. 'work_order_id',
  11. 'work_order_detail_id', // 工单详情
  12. 'commodity_id', // 商品
  13. 'price', // 商品价值 单价
  14. 'sku', // 商品条码
  15. 'logistic_number', // 快递单号or
  16. 'reissue_logistic_number', // 补发单号 或 补发订单号
  17. 'out_order_number', // 出库订单
  18. 'store_in_number', // 入库单
  19. 'store_in_amount', // 入库数
  20. 'check_amount', // 承运商核实数量 (承运商核实商品数量)
  21. 'bao_shi_check_amount', // 宝时复核数量 (宝时核实商品数量)
  22. 'issue_type', // 异常类型 (对应工单异常类型)
  23. 'abnormal_type', // 问题类型 (商品问题类型)
  24. 'abnormal_amount', // 异常数量 (默认为订单数量) 错漏发 (客户实收数量)
  25. 'amount', // 订单数量 (原订单商品数量)
  26. 'check_result', // 核实结果 (核实 承运商)-----------------------------------
  27. 'process_result', // 处理结果 终审填充(破损:[赔偿,不赔偿] 错漏发:[少发,多发,’多发,客户退回‘,’少发,不补发‘,核实未错漏发])
  28. 'process_result_info', // 处理结果详情 -----------------------------------
  29. // 错漏发: string 为选项类型 与 process_result 相关
  30. // 1.【少发】宝时补发(商家不做单)
  31. // 宝时终审时填写 补发单号
  32. // 2.【多发,客户买下】商家做出库单(物流选自提,宝时不发货)
  33. // 需要待商家填写补发单号{填写出库单}
  34. // 3.【多发,客户退回】1.客户自行退回(提供退回单号)
  35. // {填写退回单号}
  36. // 2.宝时上门取件(提供寄件信息,地址,联系人,电话)
  37. // 4.【少发,不补发】商家做入库单,选择明细和数量
  38. // 待商家处理完结时 需填写 入库单单号,入库数量,宝时终审时需要填写“已完成入库”,
  39. // 5.【核实未错漏发】
  40. // -----------------------------------
  41. 'end_handle_result', // 错漏发时添加:
  42. 'tag', // 当前工单标记
  43. 'remark'
  44. ];
  45. static public $enums = [
  46. 'tag' => [
  47. '创建' => 0,
  48. '完成' => 1,
  49. '标记' => 2, // 工单重新创建,未完成原始数据进行历史标记,完成原始数据不进行处理
  50. ],
  51. ];
  52. function __construct(array $attributes = [])
  53. {
  54. foreach (self::$enums as &$enum) {
  55. $enum = $enum + array_flip($enum);
  56. }
  57. parent::__construct($attributes);
  58. }
  59. public function getTagAttribute($value)
  60. {
  61. if (is_numeric($value)) return self::$enums['tag'][$value];
  62. if (!$value) return '';
  63. return self::$enums['tag'][$value];
  64. }
  65. public function setTagAttribute($value)
  66. {
  67. if (!$value) return;
  68. if (is_numeric($value)) {
  69. $this->attributes['tag'] = $value;
  70. } else {
  71. $this->attributes['tag'] = self::$enums['tag'][$value];
  72. }
  73. }
  74. public function workOrder(): BelongsTo
  75. {
  76. return $this->belongsTo(WorkOrder::class);
  77. }
  78. public function commodity(): BelongsTo
  79. {
  80. return $this->belongsTo(Commodity::class);
  81. }
  82. }