徐总多门店
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
jiuhaoshenghuo/app/services/user/label/UserLabelCateServices.php

185 lines
5.5 KiB

3 months ago
<?php
// +----------------------------------------------------------------------
// | CRMEB [ CRMEB赋能开发者,助力企业发展 ]
// +----------------------------------------------------------------------
// | Copyright (c) 2016~2020 https://www.crmeb.com All rights reserved.
// +----------------------------------------------------------------------
// | Licensed CRMEB并不是自由软件,未经许可不能去掉CRMEB相关版权
// +----------------------------------------------------------------------
// | Author: CRMEB Team <admin@crmeb.com>
// +----------------------------------------------------------------------
namespace app\services\user\label;
use app\dao\other\CategoryDao;
use app\services\BaseServices;
use crmeb\services\CacheService;
use crmeb\services\FormBuilder;
use crmeb\traits\ServicesTrait;
use think\exception\ValidateException;
/**
* 用户标签分类
* Class UserLabelCateServices
* @package app\services\user\label
* @mixin CategoryDao
*/
class UserLabelCateServices extends BaseServices
{
/**
* 在分类库中0
*/
const GROUP = 0;
use ServicesTrait;
/**
* 标签分类缓存
* @var string
*/
protected $cacheName = 'label_list_all';
/**
* UserLabelCateServices constructor.
* @param CategoryDao $dao
*/
public function __construct(CategoryDao $dao)
{
$this->dao = $dao;
}
/**
* 获取标签分类
* @param array $where
* @return array
* @throws \think\db\exception\DataNotFoundException
* @throws \think\db\exception\DbException
* @throws \think\db\exception\ModelNotFoundException
*/
public function getLabelList(array $where)
{
[$page, $limit] = $this->getPageValue();
$list = $this->dao->getCateList($where, $page, $limit);
$count = $this->dao->count($where);
return compact('list', 'count');
}
/**
* 获取tree数据
* @param array $where
* @param array|string[] $field
* @param array $with
* @return array
*/
public function getLabelTree(array $where, array $field = ['*'], array $with = [])
{
return $this->dao->getCateList($where, 0, 0, $field, $with);
}
/**
* 删除分类缓存
* @param int $type
* @param int $relation_id
* @return bool
* @throws \Psr\SimpleCache\InvalidArgumentException
*/
public function deleteCateCache(int $type = 0, int $relation_id = 0)
{
$key = $this->cacheName . '_' . $type . '_' . $relation_id;
return CacheService::delete($key);
}
/**
* 获取标签全部分类
* @param int $type
* @param int $relation_id
* @return bool|mixed|null
*/
public function getLabelCateAll(int $type = 0, int $relation_id = 0)
{
$key = $this->cacheName . '_' . $type . '_' . $relation_id;
return CacheService::get($key, function () use ($type, $relation_id) {
return $this->dao->getCateList(['type' => $type, 'owner_id' => 0, 'relation_id' => $relation_id, 'group' => 0]);
});
}
/**
* 标签分类表单
* @param array $cataData
* @return mixed
*/
public function labelCateForm(array $cataData = [])
{
$f[] = FormBuilder::input('name', '分类名称', $cataData['name'] ?? '')->maxlength(20)->required();
$f[] = FormBuilder::number('sort', '排序', (int)($cataData['sort'] ?? 0))->min(0);
return $f;
}
/**
* 创建表单
* @return array
* @throws \FormBuilder\Exception\FormBuilderException
*/
public function createForm()
{
return create_form('添加标签分类', $this->labelCateForm(), $this->url('/user/user_label_cate'), 'POST');
}
/**
* 修改分类标签表单
* @param int $id
* @return array
* @throws \FormBuilder\Exception\FormBuilderException
* @throws \think\db\exception\DataNotFoundException
* @throws \think\db\exception\DbException
* @throws \think\db\exception\ModelNotFoundException
*/
public function updateForm(int $id)
{
$labelCate = $this->dao->get($id);
if (!$labelCate) {
throw new ValidateException('分类标签没有查到');
}
return create_form('编辑标签分类', $this->labelCateForm($labelCate->toArray()), $this->url('user/user_label_cate/' . $id), 'PUT');
}
/**
* 用户标签列表
* @param int $uid
* @param int $type
* @param int $relation_id
* @return array
* @throws \think\db\exception\DataNotFoundException
* @throws \think\db\exception\DbException
* @throws \think\db\exception\ModelNotFoundException
*/
public function getUserLabel(int $uid = 0, int $type = 0, int $relation_id = 0)
{
$list = $this->dao->getAll(['group' => 0, 'type' => $type, 'relation_id' => $relation_id], ['label']);
$labelIds = [];
if ($uid) {
/** @var UserLabelRelationServices $services */
$services = app()->make(UserLabelRelationServices::class);
$labelIds = $services->getUserLabels($uid, $type, $relation_id);
}
foreach ($list as $key => &$item) {
if (is_array($item['label'])) {
if (!$item['label']) {
unset($list[$key]);
continue;
}
foreach ($item['label'] as &$value) {
if (in_array($value['id'], $labelIds)) {
$value['disabled'] = true;
} else {
$value['disabled'] = false;
}
}
}
}
return array_merge($list);
}
}