У меня есть модель Order, которая имеет отношение многие-ко-многим к модели Product:
class Order extends Model
{
//...
public function products(): BelongsToMany
{
return $this->belongsToMany(Product::class, 'tbl_order_products', null, 'product_id')
->as('orderProduct')
->withPivot('cost_per_unit', 'amount')
->using(OrderProduct::class)
->orderByPivot('position');
}
}
В моем сводном классе OrderProduct я вычисляю промежуточную сумму для каждого заказанного продукта:
class OrderProduct extends Pivot
{
//...
protected function subtotal(): Attribute
{
return Attribute::get(function (mixed $value, array $attributes) {
return number_format($attributes['cost_per_unit'] * $attributes['amount'], 2);
});
}
}
Я хочу включить этот атрибут промежуточного итога в содержимое JSON только на определенных страницах, поэтому я не могу добавить его с помощью protected $appends = ['subtotal'];.
Как добавить атрибут промежуточного итога в сводную таблицу OrderProduct во время выполнения с помощью ->append(), если я получить экземпляры Order таким образом?
Order::select(
'id',
'number',
)
->whereNull('invoice_id')
->whereHas('products', function ($query) {
$query->where('code', '!=', 'P');
})
->orderBy('number', 'asc')
->with('products:code,name')
->get();
Мне бы хотелось, чтобы содержимое JSON для заказа выглядело так:
{
"id": 1077,
"number": "Order number",
"products": [
{
"code": "Product code",
"name": "Product name",
"order_product": {
"order_id": 1077,
"product_id": 46,
"cost_per_unit": "55.00",
"amount": 1,
"subtotal": "55.00"
Подробнее здесь: https://stackoverflow.com/questions/797 ... at-runtime
Как добавить вычисленное значение в сводный класс во время выполнения? ⇐ Php
Кемеровские программисты php общаются здесь
1761510390
Anonymous
У меня есть модель Order, которая имеет отношение многие-ко-многим к модели Product:
class Order extends Model
{
//...
public function products(): BelongsToMany
{
return $this->belongsToMany(Product::class, 'tbl_order_products', null, 'product_id')
->as('orderProduct')
->withPivot('cost_per_unit', 'amount')
->using(OrderProduct::class)
->orderByPivot('position');
}
}
В моем сводном классе OrderProduct я вычисляю промежуточную сумму для каждого заказанного продукта:
class OrderProduct extends Pivot
{
//...
protected function subtotal(): Attribute
{
return Attribute::get(function (mixed $value, array $attributes) {
return number_format($attributes['cost_per_unit'] * $attributes['amount'], 2);
});
}
}
Я хочу включить этот атрибут промежуточного итога в содержимое JSON только на определенных страницах, поэтому я не могу добавить его с помощью protected $appends = ['subtotal'];.
Как добавить атрибут промежуточного итога в сводную таблицу OrderProduct во время выполнения с помощью ->append(), если я получить экземпляры Order таким образом?
Order::select(
'id',
'number',
)
->whereNull('invoice_id')
->whereHas('products', function ($query) {
$query->where('code', '!=', 'P');
})
->orderBy('number', 'asc')
->with('products:code,name')
->get();
Мне бы хотелось, чтобы содержимое JSON для заказа выглядело так:
{
"id": 1077,
"number": "Order number",
"products": [
{
"code": "Product code",
"name": "Product name",
"order_product": {
"order_id": 1077,
"product_id": 46,
"cost_per_unit": "55.00",
"amount": 1,
"subtotal": "55.00"
Подробнее здесь: [url]https://stackoverflow.com/questions/79799503/how-can-i-append-a-calculated-value-to-a-pivot-class-at-runtime[/url]
Ответить
1 сообщение
• Страница 1 из 1
Перейти
- Кемерово-IT
- ↳ Javascript
- ↳ C#
- ↳ JAVA
- ↳ Elasticsearch aggregation
- ↳ Python
- ↳ Php
- ↳ Android
- ↳ Html
- ↳ Jquery
- ↳ C++
- ↳ IOS
- ↳ CSS
- ↳ Excel
- ↳ Linux
- ↳ Apache
- ↳ MySql
- Детский мир
- Для души
- ↳ Музыкальные инструменты даром
- ↳ Печатная продукция даром
- Внешняя красота и здоровье
- ↳ Одежда и обувь для взрослых даром
- ↳ Товары для здоровья
- ↳ Физкультура и спорт
- Техника - даром!
- ↳ Автомобилистам
- ↳ Компьютерная техника
- ↳ Плиты: газовые и электрические
- ↳ Холодильники
- ↳ Стиральные машины
- ↳ Телевизоры
- ↳ Телефоны, смартфоны, плашеты
- ↳ Швейные машинки
- ↳ Прочая электроника и техника
- ↳ Фототехника
- Ремонт и интерьер
- ↳ Стройматериалы, инструмент
- ↳ Мебель и предметы интерьера даром
- ↳ Cантехника
- Другие темы
- ↳ Разное даром
- ↳ Давай меняться!
- ↳ Отдам\возьму за копеечку
- ↳ Работа и подработка в Кемерове
- ↳ Давай с тобой поговорим...
Мобильная версия