UserAddress.php 2.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111
  1. <?php
  2. namespace App\Module\Ulogic\Models;
  3. use Dcat\Admin\Traits\HasDateTimeFormatter;
  4. use Illuminate\Database\Eloquent\SoftDeletes;
  5. use Illuminate\Database\Eloquent\Model;
  6. class UserAddress extends Model
  7. {
  8. use HasDateTimeFormatter;
  9. use SoftDeletes;
  10. protected $table = 'user_address';
  11. /**
  12. * @param $userId
  13. * @return \Illuminate\Database\Eloquent\Collection
  14. * 用户保存地址列表
  15. */
  16. public static function list($userId, $type)
  17. {
  18. $query = self::query();
  19. $query->where('user_id', $userId);
  20. if ($type != 0) {
  21. $query->where('type', $type);
  22. }
  23. return $query->orderBy('id', 'desc')->get();
  24. }
  25. /**
  26. * @param $userId
  27. * @param $addressId
  28. * @return null
  29. * 查询用户地址
  30. */
  31. public static function getUserAddress($userId, $addressId)
  32. {
  33. $query = self::query();
  34. $query->where('user_id', $userId);
  35. $query->where('id', $addressId);
  36. return $query->first();
  37. }
  38. /**
  39. * @param $userId
  40. * @param $addressType
  41. * @param $addressName
  42. * @param $address
  43. * @return bool
  44. * 添加地址
  45. */
  46. public static function add($userId, $addressType, $addressName, $address)
  47. {
  48. $model = new self();
  49. $model->user_id = $userId;
  50. $model->nickname = $addressName;
  51. $model->type = $addressType;
  52. $model->address = $address;
  53. return $model->save();
  54. }
  55. /**
  56. * @param $addressId
  57. * @return mixed
  58. * 删除地址
  59. */
  60. public static function userDelete($addressId)
  61. {
  62. $model = self::find($addressId);
  63. $model->status = 2;
  64. $model->deleted_at = date('Y-m-d H:i:s');
  65. return $model->save();
  66. }
  67. /**
  68. * @param $addressId
  69. * @return null
  70. * 根据id获取地址
  71. */
  72. public static function getAddressById($addressId)
  73. {
  74. $query = self::query();
  75. $query->where('id', $addressId);
  76. return $query->first();
  77. }
  78. /**
  79. * @param $addressId
  80. * @return null
  81. * 根据地址获取信息
  82. */
  83. public static function getDataByAddress($address)
  84. {
  85. $query = self::query();
  86. $query->where('address', $address);
  87. return $query->first();
  88. }
  89. /**
  90. * @param $addressId
  91. * @return null
  92. * 根据地址获取信息
  93. */
  94. public static function getDataByUserId($userId)
  95. {
  96. $query = self::query();
  97. $query->where('user_id', $userId);
  98. return $query->first();
  99. }
  100. }