CouponUseLog.php 2.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106
  1. <?php
  2. /**
  3. * Created by PhpStorm.
  4. * User: 17812
  5. * Date: 2020/8/28
  6. * Time: 11:45
  7. */
  8. namespace app\common\models\coupon;
  9. use app\common\models\BaseModel;
  10. use app\common\models\Coupon;
  11. use app\common\models\Member;
  12. class CouponUseLog extends BaseModel
  13. {
  14. /**
  15. * @var string
  16. */
  17. protected $table = "yz_coupon_use_log";
  18. /**
  19. * @var array
  20. */
  21. protected $guarded = [''];
  22. const TYPE_SHOPPING = 1;
  23. const TYPE_TRANSFER = 2;
  24. const TYPE_WRITE_OFF = 3;
  25. const TYPE_SHARE = 4;
  26. const TYPE_CART_SHARE = 5;
  27. const TYPE_BACKEND_DEL = 6;
  28. /**
  29. * @var array
  30. */
  31. protected $appends = ['type_name'];
  32. /**
  33. * @var array
  34. */
  35. public static $TypeComment = [
  36. self::TYPE_SHOPPING => '购物使用',
  37. self::TYPE_TRANSFER => '会员转赠',
  38. self::TYPE_WRITE_OFF => '核销',
  39. self::TYPE_SHARE => '分享',
  40. self::TYPE_CART_SHARE => '购物车分享',
  41. self::TYPE_CART_SHARE => '购物车分享',
  42. self::TYPE_BACKEND_DEL => '后台作废',
  43. ];
  44. public function getTypeNameAttribute()
  45. {
  46. return self::$TypeComment[$this->attributes['type']] ?: '异常';
  47. }
  48. public static function getRecords($search){
  49. $merModel=self::uniacid()->with(['belongsToMember','hasOneCoupon']);
  50. if (!empty($search['member_id'])) {
  51. $merModel->whereHas('belongsToMember', function ($query) use ($search) {
  52. return $query->where('member_id', $search['member_id']);
  53. });
  54. }
  55. if (!empty($search['member'])) {
  56. $merModel->whereHas('belongsToMember', function ($query) use ($search) {
  57. return $query->searchLike($search['member']);
  58. });
  59. }
  60. if (!empty($search['coupon_name'])) {
  61. $merModel->whereHas('hasOneCoupon', function ($query) use ($search) {
  62. return $query->where('name', 'like', '%'.$search['coupon_name'].'%');
  63. });
  64. }
  65. if (!empty($search['use_type'])) {
  66. $merModel->where('type',$search['use_type']);
  67. }
  68. if ($search['is_time']) {
  69. if ($search['time']) {
  70. $range = [strtotime($search['time']['start']), strtotime($search['time']['end'])];
  71. $merModel->whereBetween('created_at', $range);
  72. }
  73. }
  74. $merModel->orderBy('created_at', 'desc');
  75. return $merModel;
  76. }
  77. public function belongsToMember()
  78. {
  79. return $this->belongsTo(Member::class, 'member_id', 'uid');
  80. }
  81. public function hasOneCoupon()
  82. {
  83. return $this->hasOne(Coupon::class, 'id', 'coupon_id');
  84. }
  85. }