wzq 5 年之前
父節點
當前提交
59e0bdb87c

+ 46 - 0
app/Http/Controllers/V1/PostController.php

@@ -11,6 +11,7 @@ namespace App\Http\Controllers\V1;
 use App\Repositories\PostRepositories;
 use App\Traits\UserTrait;
 use App\Transformers\Post\CommentTransformer;
+use App\Transformers\Post\DetailTransformer;
 use App\Transformers\Post\ListTransformer;
 use App\Transformers\Post\ReplyTransformer;
 use App\Transformers\Post\SuggestTransformer;
@@ -119,6 +120,51 @@ class PostController extends Controller
         return jsonSuccess($data);
     }
 
+    /**
+     * 内容详情
+     */
+    public function detail(Request $request)
+    {
+        $validator = Validator::make($request->all(), [
+            'post_id' => 'required|integer',
+        ]);
+        if ($validator->fails()) {
+            return jsonError($validator->errors()->first());
+        }
+        $userInfo = $this->getUserInfo();
+        if(empty($userInfo)){
+            Log::info('获取用户信息失败');
+            return jsonError('获取用户信息失败');
+        }
+        $detail = $this->postRepositories->detail($request['post_id']);
+        if(!$detail){
+            return jsonError('获取内容信息失败');
+        }
+        $fractal = new Manager();
+        $res = new Item($detail, new DetailTransformer($userInfo['uid']));
+        return $array = $fractal->createData($res)->toArray();
+        $param = $request->all();
+        $list = $this->postRepositories->suggestPost($param);
+
+
+
+        $resource = new Collection($list, new SuggestTransformer($userInfo['uid']));
+        $resource->setPaginator(new IlluminatePaginatorAdapter($list));
+        $data = $fractal->createData($resource)->toArray();
+
+        if(!(isset($param['current_page']) && $param['current_page'] > 1)){
+            $newData = [];
+            foreach($data['data'] as $key => $val){
+                if($key == 1){
+                    $newData[] = ['show_type' => 1];
+                }
+                $newData[] = $val;
+            }
+            $data['data'] = $newData;
+        }
+        return jsonSuccess($data);
+    }
+
     /**
      * 评论列表
      */

+ 11 - 0
app/Repositories/PostRepositories.php

@@ -289,6 +289,17 @@ class PostRepositories
             ->paginate($perPage);
     }
 
+    /**
+     * 内容详情
+     */
+    public function detail($id)
+    {
+        return $this->post
+            ->join('post_data', 'post_data.post_id', '=', 'post.id')
+            ->select('post.*')
+            ->find($id);
+    }
+
     /**
      * 推荐内容列表
      */

+ 69 - 0
app/Transformers/Post/DetailTransformer.php

@@ -0,0 +1,69 @@
+<?php
+/**
+ * Created by PhpStorm.
+ * User: Administrator
+ * Date: 2019/6/17
+ * Time: 16:11
+ */
+namespace  App\Transformers\Post;
+
+use App\Models\Post;
+use App\Models\PostCollect;
+use App\Models\PostComment;
+use App\Models\PostDislike;
+use App\Models\PostLike;
+use App\Traits\UserTrait;
+use Carbon\Carbon;
+use League\Fractal\TransformerAbstract;
+
+class DetailTransformer extends TransformerAbstract
+{
+    use UserTrait;
+    public function __construct($uid)
+    {
+        $this->uid = $uid;
+    }
+    public function transform(Post $post)
+    {
+        $imgs = [];
+        foreach($post->imgs as $img){
+            $imgs[] = $img['img'];
+        }
+
+        $topic = [];
+        foreach($post->topic() as $key => $val){
+            $topic[] = [
+                'id' => $key,
+                'name' => $val
+            ];
+        }
+        $isFollow = 0;
+        $followStatus = $this->getFollowStatus($this->uid, $post['uid']);
+        if($followStatus){
+            $isFollow = $followStatus;
+        }
+        return [
+            'id' => $post['id'],
+            'type' => $post['type'],
+            'created_at' => Carbon::parse($post['created_at'])->diffForHumans(),
+            'uid' => $post['uid'],
+            'username' => $post['username'],
+            'avatar' => $post['avatar'],
+            'topic' => $topic,
+            'title' => $post['title'],
+            'content' => $post['content'],
+            'location' => $post['location'],
+            'img' => $post['img'],
+            'imgs' => $imgs,
+            'video' => $post['video'],
+            'pv' => $post->data->pv,
+            'praise_count' => $post->data->praise_count,
+            'comment_count' => $post->data->comment_count,
+            'will_collect_bean' => $post->data->will_collect_bean,
+            'is_like' => PostLike::where('post_id', $post['id'])->where('uid', $this->uid)->exists()?1:0,
+            'is_dislike' => PostDislike::where('post_id', $post['id'])->where('uid', $this->uid)->exists()?1:0,
+            'is_collect' => PostCollect::where('post_id', $post['id'])->where('uid', $this->uid)->exists()?1:0,
+            'is_follow' => $isFollow,
+        ];
+    }
+}

+ 1 - 0
routes/api.php

@@ -22,6 +22,7 @@ $api->version('v1', [
     $api->group(['middleware' => ['chxq_jwt_auth']], function ($api) {
         $api->post('post', 'PostController@create');
         $api->get('post', 'PostController@index');
+        $api->get('post/detail', 'PostController@detail');
         $api->get('post/suggest', 'PostController@suggestPost');
         $api->post('post/comment', 'PostController@comment');
         $api->get('post/comment', 'PostController@commentList');