OrderModel.php 2.7 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192
  1. <?php
  2. // +----------------------------------------------------------------------
  3. // | LARAVEL8.0 框架 [ LARAVEL ][ RXThinkCMF ]
  4. // +----------------------------------------------------------------------
  5. // | 版权所有 2017~2021 LARAVEL研发中心
  6. // +----------------------------------------------------------------------
  7. // | 官方网站: http://www.laravel.cn
  8. // +----------------------------------------------------------------------
  9. // | Author: laravel开发员 <laravel.qq.com>
  10. // +----------------------------------------------------------------------
  11. namespace App\Models;
  12. /**
  13. * 订单管理-模型
  14. * @author laravel开发员
  15. * @since 2020/11/11
  16. * @package App\Models
  17. */
  18. class OrderModel extends BaseModel
  19. {
  20. // 设置数据表
  21. protected $table = 'orders';
  22. /**
  23. * 下单用户
  24. * @return \Illuminate\Database\Eloquent\Relations\HasOne
  25. */
  26. public function user()
  27. {
  28. return $this->hasOne(MemberModel::class, 'id', 'user_id')
  29. ->select(['id', 'mobile', 'nickname', 'realname', 'status']);
  30. }
  31. /**
  32. * 推荐收益用户
  33. * @return \Illuminate\Database\Eloquent\Relations\HasOne
  34. */
  35. public function recUser()
  36. {
  37. return $this->hasOne(MemberModel::class, 'id', 'rec_bonus_id')
  38. ->select(['id', 'mobile', 'nickname', 'realname', 'status']);
  39. }
  40. /**
  41. * 订单商品关联
  42. * 通过 order_no 字段关联订单商品表
  43. * @return \Illuminate\Database\Eloquent\Relations\HasMany
  44. */
  45. public function orderGoods()
  46. {
  47. return $this->hasMany(OrderGoodsModel::class, 'order_no', 'order_no')
  48. ->with(['category'])
  49. ->leftJoin('goods_skus as b','b.id','=','orders_goods.sku_id')
  50. ->where('orders_goods.mark', 1)->select(['orders_goods.*','b.sku_name']);
  51. }
  52. /**
  53. * 店铺
  54. * @return \Illuminate\Database\Eloquent\Relations\HasOne
  55. */
  56. public function store()
  57. {
  58. return $this->hasOne(StoreModel::class, 'id', 'store_id')
  59. ->select(['id', 'name', 'logo']);
  60. }
  61. /**
  62. * 经手人
  63. * @return \Illuminate\Database\Eloquent\Relations\HasOne
  64. */
  65. public function adminUser()
  66. {
  67. return $this->hasOne(UserModel::class, 'id', 'confirm_admin_id')
  68. ->select(['id', 'nickname', 'mobile', 'realname', 'status']);
  69. }
  70. /**
  71. * 已审核
  72. * @return \Illuminate\Database\Eloquent\Relations\HasOne
  73. */
  74. public function confirm()
  75. {
  76. return $this->hasOne(OrderModel::class, 'goods_id', 'goods_id')
  77. ->with(['user'])
  78. ->whereIn('status', [2, 3])
  79. ->where(['mark' => 1])
  80. ->select(['id', 'order_no', 'goods_id', 'confirm_at', 'status']);
  81. }
  82. }