WorkOrderCommodities.php 4.1 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192
  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. ];
  44. static public $enums = [
  45. 'tag' => [
  46. '创建' => 0,
  47. '完成' => 1,
  48. '标记' => 2, // 工单重新创建,未完成原始数据进行历史标记,完成原始数据不进行处理
  49. ],
  50. ];
  51. function __construct(array $attributes = [])
  52. {
  53. foreach (self::$enums as &$enum) {
  54. $enum = $enum + array_flip($enum);
  55. }
  56. parent::__construct($attributes);
  57. }
  58. public function getTagAttribute($value)
  59. {
  60. if (is_numeric($value)) return self::$enums['tag'][$value];
  61. if (!$value) return '';
  62. return self::$enums['tag'][$value];
  63. }
  64. public function setTagAttribute($value)
  65. {
  66. if (!$value) return;
  67. if (is_numeric($value)) {
  68. $this->attributes['tag'] = $value;
  69. } else {
  70. $this->attributes['tag'] = self::$enums['tag'][$value];
  71. }
  72. }
  73. public function workOrder(): BelongsTo
  74. {
  75. return $this->belongsTo(WorkOrder::class);
  76. }
  77. public function commodity(): BelongsTo
  78. {
  79. return $this->belongsTo(Commodity::class);
  80. }
  81. }