BroadcastAssistantRepository.php 5.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117
  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\store\broadcast;
  12. use app\common\dao\store\broadcast\BroadcastAssistantDao;
  13. use app\common\repositories\BaseRepository;
  14. use crmeb\services\MiniProgramService;
  15. use FormBuilder\Exception\FormBuilderException;
  16. use think\facade\Route;
  17. use FormBuilder\Factory\Elm;
  18. use FormBuilder\Form;
  19. class BroadcastAssistantRepository extends BaseRepository
  20. {
  21. /**
  22. * @var BroadcastAssistantDao
  23. */
  24. protected $dao;
  25. public function __construct(BroadcastAssistantDao $dao)
  26. {
  27. $this->dao = $dao;
  28. }
  29. /**
  30. * 创建或编辑小助手账号的表单
  31. *
  32. * 本函数用于生成一个表单,根据$id$的存在与否决定是创建新的小助手账号还是编辑已有的账号。
  33. * 如果$id$存在,则表单将用于编辑已有账号,否则用于创建新账号。
  34. *
  35. * @param int|null $id 小助手账号的ID,如果为null,则表示创建新账号。
  36. * @return \EasyWeChat\OfficialAccount\Forms\Form 创建或编辑小助手账号的表单。
  37. * @throws FormBuilderException 如果指定的账号ID不存在,则抛出异常。
  38. */
  39. public function form(?int $id)
  40. {
  41. $formData = [];
  42. // 根据$id$的存在与否决定是创建还是编辑表单
  43. if ($id) {
  44. // 编辑模式:构建表单URL并获取指定ID的账号数据
  45. $form = Elm::createForm(Route::buildUrl('merchantBroadcastAssistantUpdate', ['id' => $id])->build());
  46. $data = $this->dao->get($id);
  47. // 检查数据是否存在,如果不存在则抛出异常
  48. if (!$data) throw new FormBuilderException('数据不存在');
  49. // 将账号数据转换为数组并存储为表单数据
  50. $formData = $data->toArray();
  51. } else {
  52. // 创建模式:构建表单URL
  53. $form = Elm::createForm(Route::buildUrl('merchantBroadcastAssistantCreate')->build());
  54. }
  55. // 定义表单的验证规则
  56. $rules = [
  57. Elm::input('username', '微信号:')->placeholder('请输入微信号')->required(),
  58. Elm::input('nickname', '微信昵称:')->placeholder('请输入微信昵称')->required(),
  59. Elm::input('mark', '备注:')->placeholder('请输入备注'),
  60. ];
  61. // 设置表单的验证规则
  62. $form->setRule($rules);
  63. // 根据$id$的存在与否设置表单标题,并设置表单的初始数据
  64. return $form->setTitle(is_null($id) ? '添加小助手账号' : '编辑小助手账号')->formData($formData);
  65. }
  66. /**
  67. * 根据条件获取列表数据
  68. *
  69. * 本函数用于根据给定的条件查询数据库,并返回满足条件的数据列表以及总条数。
  70. * 这对于分页查询非常有用,可以一次性获取当前页的数据以及数据的总页数。
  71. *
  72. * @param string $where 查询条件,用于限定查询的数据范围。
  73. * @param int $page 当前页码,用于指定要返回的页的数据。
  74. * @param int $limit 每页的数据条数,用于控制每页显示的数据数量。
  75. * @return array 返回包含 'count' 和 'list' 两个元素的数组,'count' 表示满足条件的总数据条数,'list' 表示当前页的数据列表。
  76. */
  77. public function getList($where, int $page, int $limit)
  78. {
  79. // 根据条件获取查询对象
  80. $query = $this->dao->getSearch($where);
  81. // 计算满足条件的数据总条数
  82. $count = $query->count('*');
  83. // 获取当前页的数据列表
  84. $list = $query->page($page, $limit)->select();
  85. // 返回包含数据总条数和当前页数据列表的数组
  86. return compact('count','list');
  87. }
  88. /**
  89. * 根据商家ID获取搜索相关的助手昵称和ID
  90. *
  91. * 本函数旨在为特定商家ID检索并返回搜索助手的昵称和ID列表。这有助于商家在搜索功能中识别和选择合适的助手。
  92. *
  93. * @param int $merId 商家ID,用于限定搜索范围,指定要获取助手信息的商家。
  94. * @return array 返回一个数组,其中包含助手的昵称和ID,格式为['nickname' => '助手昵称', 'assistant_id' => '助手ID']。
  95. */
  96. public function options(int $merId)
  97. {
  98. // 通过商家ID查询搜索助手的信息,并仅返回昵称和ID列
  99. return $this->dao->getSearch(['mer_id' => $merId])->column('nickname','assistant_id');
  100. }
  101. }