169 похожих чатов

Такое можно в сервисы? Не, вроде ничего криминального, но

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

<?php

namespace App\Cart;

use App\Models\Book;

class Cart
{
private $oldCart;

public function __construct(
public $total = 0,
public $items = [],
)
{
$this->oldCart = session()->get('cart');

if ($this->oldCart instanceof Cart){
$this->total = $this->oldCart->total;
$this->items = $this->oldCart->items;
unset($this->oldCart); // Чтобы не копились вложенности
}
}

public function AddToCart(int $id)
{
$book = Book::findOrFail($id);

if (isset($this->items[$id])) {
$this->items[$id]['quantity']++;
} else {
$this->items[$id] = [
'id' => $id,
'name'=> $book->name,
'quantity' => 1,
'price' => $book->price,
'path' => $book->path,
];
}
$this->recountTotal();
}

public function updateItemQuantity($id, $quantity){
if (isset($this->items[$id])) {
$this->items[$id]['quantity'] = $quantity;
}
$this->recountTotal();
}

public function removeItem($id){
if (isset($this->items[$id])) {
unset($this->items[$id]);
}
$this->recountTotal();
}


public function recountTotal(): void
{
$this->total = 0;
foreach ($this->items as $item){
$this->total += $item['quantity']*$item['price'];
}
}

}

7 ответов

3 просмотра

Egor (@PAPRIKA_1994), мы обнаружили что Ваше сообщение больше чем наполовину состоит из кода. Рекомендуем сохранять примеры кода на внешних источниках, например, https://paste.laravel.io

разве это будет работать? ```

public function AddToCart(int $id) почему метод с большой буквы, почему нет типизации аргумента

PSYTRGLES
public function AddToCart(int $id) почему метод с ...

потому что метод позиционирует себя как клас

findOrFail - ну такое себе, у тебя сервис по хорошему должен сам обработать такую ситуацию, что нет книги, иначе тебе 404ую кинет лара.

$this->oldCart = session()->get('cart'); это вообще забей. используй БД для хранения корзины.

PSYTRGLES
public function AddToCart(int $id) почему метод с ...

у меня флешбеки. У нас phpcs в пайплане проверяет код, но он срабатывает только на измененные файлы. Правишь одну строчку в старом коде - все, линтер сходит с ума

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

Обсуждают сегодня

подскажите пожалуйста, как мне освободить результат записанный в переменную result? в чем проблема подскажите если МОЖЕТЕ?
Михаил Helper
28
есть тут кто-то , кто только начал изучать си? если проходите курс на степике или как-то сами изучаете, пишите, может, скооперируемся?..
Eule
25
Коллеги, здравствуйте! А можно узнать ваше мнение относительно Wolfram Mathematica vs Julia? Просто у меня стоит выбор между тем, чтобы продолжить преподавать Wolfram Mathemat...
Илья Гаража
10
Обновленный chat тестили уже господа? Готовимся на заводы ? Простой проект на ларавель собирает за 1 ответ..
Jacov Borisov
14
А если без шуток, на чем десктоп сейчас пишут кроссплатформенный (ну чтобы с минимальным допиливанием под каждую платформу) и чтобы хорошая производительность софта была. Толь...
🐈
9
кому не сложно распишите пожалуйста для какой цели тут вот эти скобки и в них пихается указатель?
Михаил Helper
15
я не магистр хаскеля, но разве не может лейзи тип конвертнуться в не-лейзи запросив вычисление содержимого прям при инициализации?
deadgnom32 λ madao
100
На одной бирже предложили обновить modx evo 1.0.1 Как думаете, стоит браться?
Artem
9
Такс, блин, таки кто-то знает, каким образом работают макросы stdin/stdout/stderr? Я влез в stdio.h, там определения нет, отладил через асмокод - вызывается функция со странны...
The Bird of Hermes
18
словил ушиб всей бабки Uncaught Error: Class "EvolutionCMS\Main\MainServiceProvider" not found in и ни composer update, ни composer dump-autoload не помогает что ещё сделать...
Oleg Nosov
7
Карта сайта