niucloud-admin/niucloud/app/service/admin/member/MemberLevelService.php
全栈小学生 011cbe96f9 update
2024-06-25 10:09:57 +08:00

132 lines
4.3 KiB
PHP
Raw Blame History

This file contains ambiguous Unicode characters

This file contains Unicode characters that might be confused with other characters. If you think that this is intentional, you can safely ignore this warning. Use the Escape button to reveal them.

<?php
// +----------------------------------------------------------------------
// | Niucloud-admin 企业快速开发的多应用管理平台
// +----------------------------------------------------------------------
// | 官方网址https://www.niucloud.com
// +----------------------------------------------------------------------
// | niucloud团队 版权所有 开源版本可自由商用
// +----------------------------------------------------------------------
// | Author: Niucloud Team
// +----------------------------------------------------------------------
namespace app\service\admin\member;
use app\model\member\MemberLevel;
use app\service\core\member\CoreMemberLevelService;
use app\service\core\member\CoreMemberService;
use core\base\BaseAdminService;
use core\exception\CommonException;
use think\db\exception\DataNotFoundException;
use think\db\exception\DbException;
use think\db\exception\ModelNotFoundException;
use think\Response;
/**
* 会员等级
* Class MemberLabelService
* @package app\service\admin\member
*/
class MemberLevelService extends BaseAdminService
{
public function __construct()
{
parent::__construct();
$this->model = new MemberLevel();
}
/**
* 获取会员等级分页列表
* @param array $where
* @param string $order
* @return array
*/
public function getPage(array $where = [], string $order = 'growth asc')
{
$field = 'level_id,level_name,growth,remark,create_time,update_time,level_benefits,level_gifts';
$search_model = $this->model->where([ [ 'level_id', '>', 0 ] ])->withSearch([ 'level_name' ], $where)->field($field)->append([ "member_num" ])->order($order);
return $this->pageQuery($search_model, function ($item) {
if (!empty($item['level_benefits'])) $item['level_benefits'] = CoreMemberService::getBenefitsContent($item['level_benefits']);
if (!empty($item['level_gifts'])) $item['level_gifts'] = CoreMemberService::getGiftContent($item['level_gifts']);
});
}
/**
* 获取会员等级列表
* @param array $where
* @param string $field
* @return array
*/
public function getList(array $where = [], $field = 'level_id,level_name,growth,remark,create_time,update_time,level_benefits,level_gifts')
{
$order = 'growth asc';
return $this->model->where([['level_id', '>', 0]])->withSearch([ "level_name" ], $where)->field($field)->order($order)->select()->toArray();
}
/**
* 获取会员等级信息
* @param int $level_id
* @return array
*/
public function getInfo(int $level_id)
{
$field = 'level_id,level_name,growth,remark,create_time,update_time,level_benefits,level_gifts';
return $this->model->field($field)->where([ [ 'level_id', '=', $level_id ]])->findOrEmpty()->toArray();
}
/**
* 获取等级
* @return array
* @throws DataNotFoundException
* @throws DbException
* @throws ModelNotFoundException
*/
public function getAll()
{
return ( new CoreMemberLevelService() )->getAll();
}
/**
* 添加会员等级
* @param array $data
* @return mixed
*/
public function add(array $data)
{
$count = $this->model->where([ ['level_id', '>', 0 ] ])->count();
if ($count >= 10) throw new CommonException('MEMBER_LEVEL_MAX');
$res = $this->model->create($data);
( new CoreMemberLevelService() )->clearCache();
return $res->level_id;
}
/**
* 会员等级编辑
* @param int $level_id
* @param array $data
* @return true
*/
public function edit(int $level_id, array $data)
{
$data[ 'update_time' ] = time();
$this->model->update($data, [ [ 'level_id', '=', $level_id ] ]);
( new CoreMemberLevelService() )->clearCache();
return true;
}
/**
* 删除会员等级
* @param int $level_id
* @return bool
*/
public function del(int $level_id)
{
$level = $this->model->where([ [ 'level_id', '=', $level_id ] ])->append(['member_num'])->findOrEmpty();
if ($level['member_num'] > 0) throw new CommonException('LEVEL_NOT_ALLOWED_DELETE');
$level->delete();
( new CoreMemberLevelService() )->clearCache();
return true;
}
}