1
0
mirror of https://gitee.com/koogua/course-tencent-cloud.git synced 2025-06-22 11:41:27 +08:00
koogua 2628f6b7d7 1.整理查询构建语句
2.整理前台编辑器页面
2022-08-15 17:22:33 +08:00

120 lines
3.0 KiB
PHP

<?php
/**
* @copyright Copyright (c) 2021 深圳市酷瓜软件有限公司
* @license https://opensource.org/licenses/GPL-2.0
* @link https://www.koogua.com
*/
namespace App\Services\Logic\Question;
use App\Builders\AnswerList as AnswerListBuilder;
use App\Library\Paginator\Query as PagerQuery;
use App\Models\Answer as AnswerModel;
use App\Repos\Answer as AnswerRepo;
use App\Repos\AnswerLike as AnswerLikeRepo;
use App\Services\Logic\QuestionTrait;
use App\Services\Logic\Service as LogicService;
class AnswerList extends LogicService
{
use QuestionTrait;
public function handle($id)
{
$question = $this->checkQuestion($id);
$pagerQuery = new PagerQuery();
$params = $pagerQuery->getParams();
$params['question_id'] = $question->id;
$params['published'] = AnswerModel::PUBLISH_APPROVED;
$params['deleted'] = 0;
$sort = $pagerQuery->getSort();
$page = $pagerQuery->getPage();
$limit = $pagerQuery->getLimit();
$sort = $sort ?: 'accepted';
$answerRepo = new AnswerRepo();
$pager = $answerRepo->paginate($params, $sort, $page, $limit);
return $this->handleAnswers($pager);
}
protected function handleAnswers($pager)
{
if ($pager->total_items == 0) {
return $pager;
}
$builder = new AnswerListBuilder();
$answers = $pager->items->toArray();
$users = $builder->getUsers($answers);
$meMappings = $this->getMeMappings($answers);
$items = [];
foreach ($answers as $answer) {
$owner = $users[$answer['owner_id']];
$me = $meMappings[$answer['id']];
$items[] = [
'id' => $answer['id'],
'content' => $answer['content'],
'anonymous' => $answer['anonymous'],
'accepted' => $answer['accepted'],
'like_count' => $answer['like_count'],
'comment_count' => $answer['comment_count'],
'create_time' => $answer['create_time'],
'update_time' => $answer['update_time'],
'owner' => $owner,
'me' => $me,
];
}
$pager->items = $items;
return $pager;
}
protected function getMeMappings($answers)
{
$user = $this->getCurrentUser(true);
$likeRepo = new AnswerLikeRepo();
$likedIds = [];
if ($user->id > 0) {
$likes = $likeRepo->findByUserId($user->id)
->filter(function ($like) {
if ($like->deleted == 0) {
return $like;
}
});
$likedIds = array_column($likes, 'answer_id');
}
$result = [];
foreach ($answers as $answer) {
$result[$answer['id']] = [
'liked' => in_array($answer['id'], $likedIds) ? 1 : 0,
'owned' => $answer['owner_id'] == $user->id ? 1 : 0,
];
}
return $result;
}
}