SergeyKuzmenko
@SergeyKuzmenko

Как из двух коллекций сделать одну с дополнительным параметром?

Всем здравствуйте! Нужна Ваша помощь.
Суть вопроса: как из двух коллекций получить одну, а именно нужно при совпадении поля (id) добавлять у выходную коллекцию поле "is_follow" => true/false
Пример кода:
$tags = Tag::all();
$user_tags = auth()->user()->tags()->get();


$tags = Tag::all() - Все теги
$user_tags = auth()->user()->tags()->get() - Теги на которые подписан текущий пользователь

dd($tags->toArray());
array:50 [
  0 => array:6 [
    "id" => 1
    "icon" => "https://picsum.photos/seed/id/100/100"
    "title" => "Id"
    "slug" => "id"
    "created_at" => "2021-08-06T14:22:15.000000Z"
    "updated_at" => "2021-08-06T14:22:15.000000Z"
  ]
  1 => array:6 [
    "id" => 3
    "icon" => "https://picsum.photos/seed/qui/100/100"
    "title" => "Qui"
    "slug" => "qui"
    "created_at" => "2021-08-06T14:22:15.000000Z"
    "updated_at" => "2021-08-06T14:22:15.000000Z"
  ]
...
]


dd($user_tags->toArray());
array:2 [
  0 => array:7 [
    "id" => 1
    "icon" => "https://picsum.photos/seed/nesciunt/100/100"
    "title" => "Nesciunt"
    "slug" => "nesciunt"
    "created_at" => "2021-08-06T14:22:15.000000Z"
    "updated_at" => "2021-08-06T14:22:15.000000Z"
    "pivot" => array:2 []
  ]
  1 => array:7 [
    "id" => 3
    "icon" => "https://picsum.photos/seed/nulla/100/100"
    "title" => "Nulla"
    "slug" => "nulla"
    "created_at" => "2021-08-06T14:22:15.000000Z"
    "updated_at" => "2021-08-06T14:22:15.000000Z"
    "pivot" => array:2 []
  ]


Как мне получить коллекцию вида:
array:50 [
  0 => array:7 [
    "id" => 1
    "icon" => "https://picsum.photos/seed/id/100/100"
    "is_follow" => true
    "title" => "Id"
    "slug" => "id"
    "created_at" => "2021-08-06T14:22:15.000000Z"
    "updated_at" => "2021-08-06T14:22:15.000000Z"
  ]
  1 => array:7 [
    "id" => 2
    "icon" => "https://picsum.photos/seed/qui/100/100"
    "is_follow" => false
    "title" => "Qui"
    "slug" => "qui"
    "created_at" => "2021-08-06T14:22:15.000000Z"
    "updated_at" => "2021-08-06T14:22:15.000000Z"
  ]
  2 => array:7 [
    "id" => 3
    "icon" => "https://picsum.photos/seed/qui/100/100"
    "is_follow" => true
    "title" => "Qui"
    "slug" => "qui"
    "created_at" => "2021-08-06T14:22:15.000000Z"
    "updated_at" => "2021-08-06T14:22:15.000000Z"
  ]
...
]

Подскажите, в какую сторону смотреть и какие методы использовать...?
  • Вопрос задан
  • 172 просмотра
Решения вопроса 2
alexey-m-ukolov
@alexey-m-ukolov Куратор тега Laravel
$user_tags = auth()->user()->tags()->pluck('id');
$tags = Tag::all()->each(function (Tag $tag) use ($user_tags): Tag {
  $tag->setAttribute('is_follow', $user_tags->contains($tag->id))
});
Ответ написан
@jazzus
$tags = Tag::withExists(['user as is_follow' => function ($query) {
    $query->where('user_id', Auth::id());
}])->get();
Ответ написан
Комментировать
Пригласить эксперта
Ваш ответ на вопрос

Войдите, чтобы написать ответ

Похожие вопросы