123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778 |
- <?php
- namespace app\data\service;
- use app\data\model\DataNewsItem;
- use app\data\model\DataNewsMark;
- use app\data\model\DataNewsXCollect;
- use think\admin\Service;
- /**
- * 文章数据服务
- * Class NewsService
- * @package app\data\service
- */
- class NewsService extends Service
- {
- /**
- * 同步文章数据统计
- * @param string $code 文章编号
- * @param array $total 查询统计
- */
- public static function syncNewsTotal(string $code, array $total = []): void
- {
- $query = DataNewsXCollect::mk()->field('type,count(1) count');
- foreach ($query->where(['code' => $code, 'status' => 2])->group('type')->cursor() as $item) {
- $total[$item['type']] = $item['count'];
- }
- DataNewsItem::mk()->where(['code' => $code])->update([
- 'num_like' => $total[1] ?? 0, 'num_collect' => $total[2] ?? 0, 'num_comment' => $total[4] ?? 0,
- ]);
- }
- /**
- * 根据code绑定列表数据
- * @param array $list 数据列表
- * @return array
- */
- public static function buildListByUidAndCode(array &$list = []): array
- {
- if (count($list) > 0) {
- /*! 绑定文章内容 */
- $colls = 'id,code,name,cover,mark,status,deleted,create_at,num_like,num_read,num_comment,num_collect';
- $items = DataNewsItem::mk()->whereIn('code', array_unique(array_column($list, 'code')))->column($colls, 'code');
- $marks = DataNewsMark::mk()->where(['status' => 1])->column('name');
- foreach ($items as &$vo) $vo['mark'] = str2arr($vo['mark'] ?: '', ',', $marks);
- foreach ($list as &$vo) $vo['record'] = $items[$vo['code']] ?? [];
- /*! 绑定用户数据 */
- $colls = 'id,phone,nickname,username,headimg,status';
- UserAdminService::buildByUid($list, 'uuid', 'user', $colls);
- }
- return $list;
- }
- /**
- * 获取列表状态
- * @param array $list 数据列表
- * @param integer $uuid 用户UID
- * @return array
- */
- public static function buildData(array &$list, int $uuid = 0): array
- {
- if (count($list) > 0) {
- [$code2, $code1] = [[], []];
- $marks = DataNewsMark::mk()->where(['status' => 1])->column('name');
- if ($uuid > 0) {
- $map = [['uuid', '=', $uuid], ['code', 'in', array_unique(array_column($list, 'code'))]];
- $code1 = DataNewsXCollect::mk()->where($map)->where(['type' => 1])->column('code');
- $code2 = DataNewsXCollect::mk()->where($map)->where(['type' => 2])->column('code');
- }
- foreach ($list as &$vo) {
- $vo['mark'] = str2arr($vo['mark'] ?: '', ',', $marks);
- $vo['my_like_state'] = in_array($vo['code'], $code2) ? 1 : 0;
- $vo['my_coll_state'] = in_array($vo['code'], $code1) ? 1 : 0;
- }
- }
- return $list;
- }
- }
|