Laravel Api - как ставить нравится и не нравится - PullRequest
0 голосов
/ 19 мая 2019

Я пытаюсь создать запрос API для «нравится» и «не нравится» в моем проекте Laravel:

Route :: post ('like', 'Api \ ApiController @ like');

Функция в ApiController выглядит следующим образом:

$post = \App\Post::find($request->id);

$social = SocialPost::where([['user_id', '=', ($request->user_id)],['post_id', '=', ($request->id)]])->first();

$unsocial = SocialPost::where([['user_id', '=', ($request->user_id)],['post_id', '=', ($request->id)],['like', '=', 0]])->first();

if ($social) {
    if ($unsocial) {
        $social->update(['like' => 1]);
        return json_encode(array('status' => true,'msg'=>'like')); 
    }
    else {
        $social->update(['like' => 0]);
        return json_encode(array('status' => true,'msg'=>'dislike')); 
    }
}
else {
    $join = new \App\SocialPost;
    $join->user_id = $request->user_id;
    $join->post_id = $post->id;
    $join->like = 1;
    $join->view = 0;
    $join->creator = 1;
    $join->save();
    return json_encode(array('status' => true,'msg'=>'New table')); 
}

Проблема в том, что первый оператор If работает, а второй - нет.Если строка уже существует, он всегда ставит «1» для «лайк» также, если возвращаемое сообщение «неприязнь».

1 Ответ

0 голосов
/ 19 мая 2019

Вот пример, который должен работать с вами.

<?php

// Get the post from the database
$post = \App\Post::find($request->id);

// Find the SocialPost record if it exists,
// if it doesn't create a new one with no likes
$socialPost = SocialPost::firstOrCreate(
    ['user_id' => $request->user_id, 'post_id' => $post->id],
    ['user_id' => $request->user_id, 'post_id' => $post->id, 'likes' => 0, 'view' => 0, 'creator' => 1],
);

// Declare an empty variable that will determine if
// the post is being "liked" or "disliked"
$postAction = '';

// Determine if the post has likes or not
if ($socialPost->likes > 0)
{
    // The post has at least 1 like
    $postAction = 'dislike';

    // Decrement the likes by 1
    $socialPost->decrement('likes', 1);
}
else
{
    // The post has 0 likes
    $postAction = 'like';

    // Increment the likes by 1
    $socialPost->increment('likes', 1);
}

// Determine if this was a new SocialPost record
if ($socialPost->wasRecentlyCreated)
{
    // Override the post action as "New table"
    $postAction = 'New table';
}

// Return the goods
return json_encode(['status' => true, 'msg' => $postAction]);
Объяснение

Вы можете определить, существует ли запись SocialPost, или создать новую - все в одной строке, используя firstOrCreate, на который есть ссылка вдокументация здесь .Первый параметр массива принимает то, что вы ищете, а второй параметр массива принимает то, что должно быть создано, если первый параметр ничего не дал

// Find the SocialPost record if it exists,
// if it doesn't create a new one with no likes
$socialPost = SocialPost::firstOrCreate(
    ['user_id' => $request->user_id, 'post_id' => $post->id],
    ['user_id' => $request->user_id, 'post_id' => $post->id, 'likes' => 0, 'view' => 0, 'creator' => 1],
);

Тогда вы можете очистить добавление или вычитание лайков с помощьюиспользуя increment или decrement, указанные в документации здесь .

// Determine if the post has likes or not
if ($socialPost->likes > 0)
{
    // Decrement the likes by 1
    $socialPost->decrement('likes', 1);
}
else
{
    // Increment the likes by 1
    $socialPost->increment('likes', 1);
}
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...