123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129 |
- <?php
- // +----------------------------------------------------------------------
- // | CRMEB [ CRMEB赋能开发者,助力企业发展 ]
- // +----------------------------------------------------------------------
- // | Copyright (c) 2016~2022 https://www.crmeb.com All rights reserved.
- // +----------------------------------------------------------------------
- // | Licensed CRMEB并不是自由软件,未经许可不能去掉CRMEB相关版权
- // +----------------------------------------------------------------------
- // | Author: CRMEB Team <admin@crmeb.com>
- // +----------------------------------------------------------------------
- namespace app\common\repositories\community;
- use app\common\dao\community\CommunityTopicDao;
- use app\common\repositories\BaseRepository;
- use FormBuilder\Factory\Elm;
- use think\exception\ValidateException;
- use think\facade\Route;
- class CommunityTopicRepository extends BaseRepository
- {
- /**
- * @var CommunityTopicDao
- */
- protected $dao;
- /**
- * CommunityTopicRepository constructor.
- * @param CommunityTopicDao $dao
- */
- public function __construct(CommunityTopicDao $dao)
- {
- $this->dao = $dao;
- }
- public function form(?int $id)
- {
- $formData = [];
- if (!$id) {
- $form = Elm::createForm(Route::buildUrl('systemCommunityTopicCreate')->build());
- } else {
- $formData = $this->dao->get($id)->toArray();
- $form = Elm::createForm(Route::buildUrl('systemCommunityTopicUpdate', ['id' => $id])->build());
- }
- $form->setRule([
- Elm::select('category_id', '社区分类')->options(function () {
- return app()->make(CommunityCategoryRepository::class)->options();
- })->requiredNum(),
- Elm::frameImage('pic', '图标', '/' . config('admin.admin_prefix') . '/setting/uploadPicture?field=pic&type=1')
- ->modal(['modal' => false])
- ->width('896px')
- ->height('480px'),
- Elm::input('topic_name', '社区话题')->required(),
- Elm::switches('status', '是否显示', 1)->activeValue(1)->inactiveValue(0)->inactiveText('关')->activeText('开'),
- Elm::switches('is_hot', '是否推荐', 1)->activeValue(1)->inactiveValue(0)->inactiveText('关')->activeText('开'),
- Elm::number('sort', '排序')->precision(0)->max(99999),
- ]);
- return $form->setTitle(is_null($id) ? '添加话题' : '编辑话题')->formData($formData);
- }
- public function delete(int $id)
- {
- $make = app()->make(CommunityRepository::class);
- if ( $make->getWhereCount(CommunityRepository::IS_SHOW_WHERE) ) throw new ValidateException('该话题下存在数据');
- $this->dao->delete($id);
- }
- public function getList(array $where, int $page, int $limit)
- {
- $where['is_del'] = 0;
- $query = $this->dao->getSearch($where)->with(['category'])
- ->order('sort DESC,create_time DESC');
- $count = $query->count();
- $list = $query->page($page, $limit)->select();
- return compact('count','list');
- }
- /**
- * TODO 获取推荐的话题
- * @return array
- * @author Qinii
- * @day 10/27/21
- */
- public function getHotList()
- {
- $list = $this->dao->getSearch([
- 'is_hot' => 1,
- 'status' => 1,
- 'is_del' => 0
- ])
- ->setOption('field',[])->field('category_id,topic_name,topic_id,pic,count_view,count_use')
- ->order('create_time DESC')->select();
- return compact('list');
- }
- /**
- * TODO
- * @param int|null $id
- * @author Qinii
- * @day 11/3/21
- */
- public function sumCountUse(?int $id)
- {
- if (!$id) {
- $id = $this->dao->getSearch(['status' => 1,'is_del' =>0])->column('topic_id');
- } else {
- $id = [$id];
- }
- foreach ($id as $item) {
- $count = app()->make(CommunityRepository::class)
- ->getSearch(CommunityRepository::IS_SHOW_WHERE)->where('topic_id',$item)->count();
- $this->dao->update($item, ['count_use' => $count]);
- }
- }
- public function options()
- {
- $data = $this->dao->getSearch(['status' => 1,'is_del' =>0])->order('sort DESC,create_time DESC')
- ->field('topic_id as value,topic_name as label')->select();
- if ($data) $res = $data->toArray();
- return $res;
- }
- }
|