// +---------------------------------------------------------------------- namespace app\model\user\label; use crmeb\basic\BaseModel; use think\Model; /** * 标签分类 * Class UserLabelCate * @package app\model\user\label */ class UserLabelCate extends BaseModel { /** * 表名 * @var string */ protected $name = 'user_label_cate'; /** * 主键 * @var string */ protected $pk = 'id'; /** * @param Model $query * @param $value */ public function searchNameAttr($query, $value) { $query->whereLike('name', '%' . $value . '%'); } /** * 一对多关联 * @return \think\model\relation\HasMany */ public function label() { return $this->hasMany(UserLabel::class, 'label_cate', 'id'); } /** * 商户搜索器 * @param Model $query * @param $value */ public function searchTypeAttr($query, $value) { if (is_array($value)) { if ($value) $query->whereIn('type', $value); } else { if ($value !== '') $query->where('type', $value); } } /** * 关联门店ID、供应商ID搜索器 * @param Model $query * @param $value */ public function searchRelationIdAttr($query, $value) { if (is_array($value)) { if ($value) $query->whereIn('relation_id', $value); } else { if ($value !== '') $query->where('relation_id', $value); } } /** * 供应商 * @param Model $query * @param $value */ public function searchSupplierIdAttr($query, $value) { if (is_array($value)) { if ($value) $query->whereIn('relation_id', $value)->where('type', 2); } else { if ($value !== '') $query->where('relation_id', $value)->where('type', 2); } } /** * 门店 * @param Model $query * @param $value */ public function searchStoreIdAttr($query, $value) { if (is_array($value)) { if ($value) $query->whereIn('relation_id', $value)->where('type', 1); } else { if ($value !== '') $query->where('relation_id', $value)->where('type', 1); } } }