MemberinterestsRepository.php 12 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250
  1. <?php
  2. // +----------------------------------------------------------------------
  3. // | CRMEB [ CRMEB赋能开发者,助力企业发展 ]
  4. // +----------------------------------------------------------------------
  5. // | Copyright (c) 2016~2024 https://www.crmeb.com All rights reserved.
  6. // +----------------------------------------------------------------------
  7. // | Licensed CRMEB并不是自由软件,未经许可不能去掉CRMEB相关版权
  8. // +----------------------------------------------------------------------
  9. // | Author: CRMEB Team <admin@crmeb.com>
  10. // +----------------------------------------------------------------------
  11. namespace app\common\repositories\user;
  12. use app\common\dao\user\MemberInterestsDao;
  13. use app\common\dao\user\UserBrokerageDao;
  14. use app\common\repositories\BaseRepository;
  15. use FormBuilder\Factory\Elm;
  16. use think\exception\ValidateException;
  17. use think\facade\Route;
  18. /**
  19. * @mixin UserBrokerageDao
  20. */
  21. class MemberinterestsRepository extends BaseRepository
  22. {
  23. const TYPE_FREE = 1;
  24. //付费会员
  25. const TYPE_SVIP = 2;
  26. const HAS_TYPE_PRICE = 1;
  27. const HAS_TYPE_SIGN = 2;
  28. const HAS_TYPE_PAY = 3;
  29. const HAS_TYPE_SERVICE = 4;
  30. const HAS_TYPE_MEMBER = 5;
  31. const HAS_TYPE_COUPON = 6;
  32. //签到收益
  33. const INTERESTS_TYPE = [
  34. 1 => ['label'=> '会员特价', 'msg' => ''],
  35. 2 => ['label'=> '签到返利' , 'msg' => '积分倍数' ],
  36. 3 => ['label'=> '消费返利' , 'msg' => '积分倍数' ],
  37. 4 => ['label'=> '专属客服' , 'msg' => '' ],
  38. 5 => ['label'=> '经验翻倍' , 'msg' => '经验翻倍' ],
  39. 6 => ['label'=> '会员优惠券', 'msg' => ''],
  40. ];
  41. public function __construct(MemberInterestsDao $dao)
  42. {
  43. $this->dao = $dao;
  44. }
  45. /**
  46. * 根据条件获取列表数据
  47. *
  48. * 本函数用于根据给定的条件数组和分页信息,从数据库中检索并返回列表数据。
  49. * 它首先构造一个查询,然后获取符合条件的数据总数,最后根据页码和每页的限制数量,
  50. * 获取对应页的数据列表。这个函数对于实现分页查询非常有用。
  51. *
  52. * @param array $where 查询条件数组,包含需要匹配的字段及其值。
  53. * @param int $page 当前页码,用于计算查询的起始位置。
  54. * @param int $limit 每页显示的数据条数,用于限制查询的结果数量。
  55. * @return array 返回一个包含 'count' 和 'list' 两个元素的数组,'count' 表示总数据量,'list' 表示当前页的数据列表。
  56. */
  57. public function getList(array $where, int $page, int $limit)
  58. {
  59. // 根据传入的条件数组构造查询
  60. $query = $this->dao->getSearch($where);
  61. // 计算符合条件的数据总数
  62. $count = $query->count();
  63. // 根据当前页码和每页限制的数量,从查询中获取数据列表
  64. $list = $query->page($page, $limit)->select();
  65. // 将数据总数和数据列表一起返回
  66. return compact('count', 'list');
  67. }
  68. /**
  69. * 获取VIP兴趣值
  70. *
  71. * 本函数用于查询并返回满足特定条件的VIP兴趣值。兴趣值由数据表中的'value'字段提供。
  72. * 如果查询结果不存在,则默认返回0。
  73. *
  74. * @param int $has_type 查询条件之一,用于筛选具有特定类型的记录。
  75. * @return float 返回查询到的最大兴趣值,如果不存在则为0。
  76. */
  77. public function getSvipInterestVal($has_type)
  78. {
  79. // 根据条件查询数据表中状态为1,类型为2,且has_type符合指定条件的记录的最大value值
  80. // 如果查询结果不存在,则默认返回0
  81. return max(((float)$this->dao->query(['status' => 1])->where('has_type', $has_type)->where('type', 2)->value('value')) ?: 0, 0);
  82. }
  83. /**
  84. * 创建或编辑会员权益表单
  85. *
  86. * @param int|null $id 权益ID,如果提供,则为编辑模式;否则为新增模式
  87. * @param string $type 权益类型,定义了权益的分类
  88. * @return \EasyWeChat\MiniProgram\Forms\Form 创建或编辑权益的表单对象
  89. *
  90. * 此方法根据$id的存在与否决定是创建新的会员权益还是编辑已有的权益。
  91. * 它使用了EasyWeChat的表单构建工具来简化表单的创建过程,并且动态地根据数据库中的数据来填充表单,
  92. * 以便用户可以方便地编辑或创建新的会员权益。
  93. */
  94. public function form(?int $id = null, $type = self::TYPE_FREE)
  95. {
  96. $formData = [];
  97. // 根据$id来决定是编辑模式还是新增模式
  98. if ($id) {
  99. // 在编辑模式下,尝试获取指定ID的权益数据
  100. $data = $this->dao->get($id);
  101. // 如果数据不存在,则抛出异常
  102. if (!$data) throw new ValidateException('数据不存在');
  103. // 构建表单的提交URL,用于更新权益信息
  104. $form = Elm::createForm(Route::buildUrl('systemUserMemberInterestsUpdate', ['id' => $id])->build());
  105. // 将获取到的权益数据转换为数组,并存储到formData中
  106. $formData = $data->toArray();
  107. } else {
  108. // 在新增模式下,构建表单的提交URL,用于创建新的权益信息
  109. $form = Elm::createForm(Route::buildUrl('systemUserMemberInterestsCreate')->build());
  110. }
  111. // 定义表单的验证规则和字段
  112. $rules = [
  113. // 创建名称输入字段,并设置必要的验证规则
  114. Elm::input('name', '权益名称:')->placeholder('请输入权益名称')->required(),
  115. // 创建简介输入字段,并设置必要的验证规则
  116. Elm::input('info', '权益简介:')->placeholder('请输入权益简介')->required(),
  117. // 创建图标选择字段,使用框架内置的图片上传组件,并设置初始值和相关样式
  118. Elm::frameImage('pic', '图标:', '/' . config('admin.admin_prefix') . '/setting/uploadPicture?field=pic&type=1')
  119. ->value($formData['pic'] ?? '')
  120. ->modal(['modal' => false])
  121. ->icon('el-icon-camera')
  122. ->width('1000px')
  123. ->height('600px'),
  124. // 创建会员级别选择字段,并动态地从数据库加载可选值
  125. Elm::select('brokerage_level', '会员级别:')->options(function () use($type){
  126. $options = app()->make(UserBrokerageRepository::class)->options(['type' => $type])->toArray();
  127. return $options;
  128. })->placeholder('请选择会员级别'),
  129. ];
  130. // 将定义的规则应用到表单中
  131. $form->setRule($rules);
  132. // 设置表单标题,并根据$id的存在与否决定标题文本
  133. return $form->setTitle(is_null($id) ? '添加权益' : '编辑权益')->formData($formData);
  134. }
  135. /**
  136. * 根据类型和级别获取兴趣点列表
  137. *
  138. * 本函数旨在根据提供的类型和级别参数,从数据库中检索兴趣点(或称兴趣列表)。
  139. * 具体来说,它将根据类型参数的不同,返回全部兴趣点或仅返回已启用的兴趣点。
  140. * 当类型为免费类型时,会忽略级别参数;否则,仅返回级别大于等于提供的级别参数的兴趣点。
  141. *
  142. * @param int $type 兴趣点的类型,用于筛选兴趣点列表。可能的值包括免费类型和其他类型。
  143. * @param int $level 兴趣点的级别,用于进一步筛选兴趣点列表。仅当类型不为免费类型时生效。
  144. * @return array 返回符合条件的兴趣点列表,每个兴趣点包含状态和其他相关信息。
  145. */
  146. public function getInterestsByLevel(int $type, $level = 0)
  147. {
  148. // 当类型为免费类型时
  149. if ($type == self::TYPE_FREE) {
  150. // 获取所有免费类型的兴趣点
  151. $list = $this->dao->getSearch(['type' => $type])->select();
  152. // 遍历列表,设置默认状态为0(未启用)
  153. foreach ($list as $item) {
  154. $item['status'] = 0;
  155. // 如果兴趣点的级别小于等于提供的级别,则将其状态设置为1(启用)
  156. if ($item['brokerage_level'] <= $level) {
  157. $item['status'] = 1;
  158. }
  159. }
  160. } else {
  161. // 当类型非免费类型时,获取已启用的兴趣点
  162. $list = $this->dao->getSearch(['type' => $type,'status' => 1])->select();
  163. }
  164. // 返回符合条件的兴趣点列表
  165. return $list;
  166. }
  167. /**
  168. * 创建SVIP会员权益表单
  169. * 该方法用于生成编辑会员权益的表单界面,通过传入会员权益ID,获取相应的数据,并构建相应的表单字段。
  170. * @param int $id 会员权益ID,用于查询特定的会员权益数据。
  171. * @return mixed 返回生成的表单对象,用于在前端展示编辑表单。
  172. * @throws ValidateException 如果查询的数据不存在,则抛出验证异常。
  173. */
  174. public function svipForm(int $id)
  175. {
  176. // 根据ID查询会员权益数据
  177. $data = $this->dao->get($id);
  178. // 如果数据不存在,则抛出异常
  179. if (!$data) throw new ValidateException('数据不存在');
  180. // 创建表单对象,并设置表单提交的URL
  181. $form = Elm::createForm(Route::buildUrl('systemUserSvipInterestsUpdate', ['id' => $id])->build());
  182. // 将查询到的数据转换为数组格式,方便后续表单数据的填充
  183. $formData = $data->toArray();
  184. // 定义表单规则,包括各个字段的生成及其配置
  185. $rules = [
  186. // 生成权益类型选择字段,为下拉列表形式,选项固定,且不可更改
  187. Elm::select('has_type', '权益名称:')->options(function(){
  188. foreach (self::INTERESTS_TYPE as $k => $v) {
  189. $res[] = ['value' => $k, 'label' => $v['label']];
  190. }
  191. return $res;
  192. })->disabled(true),
  193. // 生成展示名称输入字段,必填
  194. Elm::input('name', '展示名称:')->required(),
  195. // 生成权益简介输入字段,必填
  196. Elm::input('info', '权益简介:')->required(),
  197. // 生成未开通图标上传框架,使用iframe嵌入式上传,必填
  198. Elm::frameImage('pic', '未开通图标:', '/' . config('admin.admin_prefix') . '/setting/uploadPicture?field=pic&type=1')
  199. ->value($formData['pic'] ?? '')->required()
  200. ->modal(['modal' => false])
  201. ->icon('el-icon-camera')
  202. ->width('1000px')
  203. ->height('600px'),
  204. // 生成已开通图标上传框架,使用iframe嵌入式上传,必填
  205. Elm::frameImage('on_pic', '已开通图标:', '/' . config('admin.admin_prefix') . '/setting/uploadPicture?field=on_pic&type=1')
  206. ->value($formData['on_pic'] ?? '')->required()
  207. ->modal(['modal' => false])
  208. ->icon('el-icon-camera')
  209. ->width('1000px')
  210. ->height('600px'),
  211. // 生成跳转内部链接输入字段
  212. Elm::input('link', '跳转内部链接:'),
  213. ];
  214. // 根据权益类型,动态添加价值输入字段
  215. $msg = self::INTERESTS_TYPE[$formData['has_type']]['msg'];
  216. if ($msg) $rules[] = Elm::number('value',$msg,0);
  217. // 设置表单规则
  218. $form->setRule($rules);
  219. // 设置表单标题,并填充已有的表单数据
  220. return $form->setTitle('编辑会员权益')->formData($formData);
  221. }
  222. }