MemberModel.php 2.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101
  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. * Class MemberModel
  17. * @package App\Models
  18. */
  19. class MemberModel extends BaseModel
  20. {
  21. // 设置数据表
  22. protected $table = 'member';
  23. protected $guarded = ['id']; // 除了 id 之外,其余字段都允许批量更新
  24. /**
  25. * 仓库
  26. * @return \Illuminate\Database\Eloquent\Relations\BelongsTo
  27. */
  28. public function stock()
  29. {
  30. return $this->belongsTo(StockModel::class, 'stock_id', 'stock_id')
  31. ->where(['mark' => 1])
  32. ->select(['stock_id', 'stock_name', 'status']);
  33. }
  34. /**
  35. * 线路
  36. * @return \Illuminate\Database\Eloquent\Relations\BelongsTo
  37. */
  38. public function line()
  39. {
  40. return $this->belongsTo(LineModel::class, 'line_id', 'line_id')
  41. ->where(['mark' => 1])
  42. ->select(['line_id', 'line_name', 'status']);
  43. }
  44. /**
  45. * 推荐人
  46. */
  47. public function parent()
  48. {
  49. return $this->hasOne(MemberModel::class, 'id', 'parent_id')
  50. ->where(['status' => 1, 'mark' => 1])
  51. ->select(['id', 'nickname', 'username', 'mobile', 'status']);
  52. }
  53. /**
  54. * 订单
  55. * @return \Illuminate\Database\Eloquent\Relations\HasMany
  56. */
  57. public function order1()
  58. {
  59. return $this->hasMany(OrderModel::class, 'user_id', 'id')
  60. ->where(['mark' => 1])->where('status', '>=', 1);
  61. }
  62. /**
  63. * 待捡货订单
  64. * @return \Illuminate\Database\Eloquent\Relations\hasMany
  65. */
  66. public function order2()
  67. {
  68. return $this->hasMany(OrderModel::class, 'user_id', 'id')
  69. ->where(['mark' => 1])->where('status', 2);
  70. }
  71. /**
  72. * 获取会员信息
  73. * @param int $id 会员ID
  74. * @return array|string
  75. * @author laravel开发员
  76. * @since 2020/11/11
  77. */
  78. public function getInfo($id)
  79. {
  80. $info = parent::getInfo($id); // TODO: Change the autogenerated stub
  81. if ($info) {
  82. // 头像
  83. if ($info['avatar']) {
  84. $info['avatar'] = get_image_url($info['avatar']);
  85. }
  86. }
  87. return $info;
  88. }
  89. }