MemberCard.php 2.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119
  1. <?php
  2. // +----------------------------------------------------------------------
  3. // | CRMEB [ CRMEB赋能开发者,助力企业发展 ]
  4. // +----------------------------------------------------------------------
  5. // | Copyright (c) 2016~2020 https://www.crmeb.com All rights reserved.
  6. // +----------------------------------------------------------------------
  7. // | Licensed CRMEB并不是自由软件,未经许可不能去掉CRMEB相关版权
  8. // +----------------------------------------------------------------------
  9. // | Author: CRMEB Team <admin@crmeb.com>
  10. // +----------------------------------------------------------------------
  11. namespace app\model\user\member;
  12. use crmeb\basic\BaseModel;
  13. use crmeb\traits\ModelTrait;
  14. use think\Model;
  15. /**
  16. * Class MemberCard
  17. * @package app\model\user\member
  18. */
  19. class MemberCard extends BaseModel
  20. {
  21. use ModelTrait;
  22. /**
  23. * 数据表主键
  24. * @var string
  25. */
  26. protected $pk = 'id';
  27. /**
  28. * 模型名称
  29. * @var string
  30. */
  31. protected $name = 'member_card';
  32. protected $insert = ['add_time', 'update_time'];
  33. protected $hidden = ['update_time'];
  34. protected $updateTime = false;
  35. /**
  36. * 卡号搜索器
  37. * @param Model $query
  38. * @param $value
  39. */
  40. public function searchCardNumberAttr($query, $value)
  41. {
  42. if ($value) {
  43. $query->whereLike('card_number', '%' . $value . '%');
  44. }
  45. }
  46. /**
  47. * 用户uid搜索器
  48. * @param Model $query
  49. * @param $value
  50. */
  51. public function searchUseUidAttr($query, $value)
  52. {
  53. if (is_array($value)) {
  54. $query->whereIn('use_uid', $value);
  55. } else {
  56. $query->where('use_uid', $value);
  57. }
  58. }
  59. /**
  60. * 手机号搜索器
  61. * @param Model $query
  62. * @param $value
  63. */
  64. public function searchPhoneAttr($query, $value)
  65. {
  66. if ($value) {
  67. $query->whereIn('use_uid', function ($query) use ($value) {
  68. $query->name('user')->whereLike('phone', $value . '%')->field('uid')->select();
  69. });
  70. }
  71. }
  72. /**
  73. * 批次id搜索器
  74. * @param Model $query
  75. * @param $value
  76. */
  77. public function searchBatchCardIdAttr($query, $value)
  78. {
  79. $query->where('card_batch_id', $value);
  80. }
  81. /**
  82. * 用户use_time搜索器
  83. * @param Model $query
  84. * @param $value
  85. */
  86. public function searchUseTimeAttr($query, $value)
  87. {
  88. if ($value > 0) {
  89. $query->where('use_time', '>', 0);
  90. }
  91. if ($value == 0) {
  92. $query->where('use_time', 0);
  93. }
  94. }
  95. public function searchIsStatusAttr($query, $value)
  96. {
  97. if ($value) {
  98. $query->where('status', $value);
  99. }
  100. }
  101. }