diff --git a/code/app/BookedProduct.php b/code/app/BookedProduct.php index 913e2320..2ac2e641 100644 --- a/code/app/BookedProduct.php +++ b/code/app/BookedProduct.php @@ -327,7 +327,7 @@ public function getValue($type) public function getFinalUnitPrice() { - if ($this->delivered) { + if ($this->delivered > 0) { return $this->final_price / $this->delivered; } else { diff --git a/code/app/Printers/Concerns/Shipping.php b/code/app/Printers/Concerns/Shipping.php index e7855768..3aab9656 100644 --- a/code/app/Printers/Concerns/Shipping.php +++ b/code/app/Printers/Concerns/Shipping.php @@ -94,6 +94,8 @@ public function formatShipping($order, $fields, $status, $shipping_place, $extra 'products' => [], 'totals' => [], 'notes' => !empty($booking->notes) ? [$booking->notes] : [], + + 'others' => $booking->user->morePendingBookings($order->aggregate), ]; foreach($booking->products_with_friends as $booked) { diff --git a/code/app/User.php b/code/app/User.php index 94bb432d..904f22dd 100644 --- a/code/app/User.php +++ b/code/app/User.php @@ -215,6 +215,33 @@ public function initialWelcome() } } + /* + Genera la notifica relativa ad altre prenotazioni (oltre a quella + dell'aggregato specificato) che devono essere ritirate dall'utente nel + corso della giornata. Viene aggiunta nel pannello delle consegne e nel + Dettaglio Consegne PDF + */ + public function morePendingBookings($aggregate) + { + $other_bookings = $this->bookings()->where('status', 'pending')->whereHas('order', function($query) use ($aggregate) { + $query->where('aggregate_id', '!=', $aggregate->id)->where('shipping', $aggregate->shipping); + })->get(); + + if ($other_bookings->isEmpty() == false) { + $notice = _i('Questa persona oggi deve ritirare anche altre prenotazioni:'); + $notice .= ''; + return $notice; + } + + return null; + } + /************************************************************ SluggableID */ public function getSlugID() diff --git a/code/resources/views/delivery/edit.blade.php b/code/resources/views/delivery/edit.blade.php index 5d14aaf2..bec97c1c 100644 --- a/code/resources/views/delivery/edit.blade.php +++ b/code/resources/views/delivery/edit.blade.php @@ -9,9 +9,7 @@ $master_summary = $aggregate->reduxData(); $currency_symbol = defaultCurrency()->symbol; -$other_bookings = $user->bookings()->where('status', 'pending')->whereHas('order', function($query) use ($aggregate) { - $query->where('aggregate_id', '!=', $aggregate->id)->where('shipping', $aggregate->shipping); -})->get(); +$other_bookings = $user->morePendingBookings($aggregate); /* In fase di consegna, aggrego sempre tutte le quantità @@ -47,16 +45,11 @@ - @if($other_bookings->count()) + @if($other_bookings)
- {{ _i('Questa persona oggi deve ritirare anche altre prenotazioni:') }} -
    - @foreach($other_bookings as $ob) -
  • {{ $ob->order->printableName() }}
  • - @endforeach -
+ {!! $other_bookings !!}
diff --git a/code/resources/views/documents/order_shipping_pdf.blade.php b/code/resources/views/documents/order_shipping_pdf.blade.php index e87510b7..ea6257c2 100644 --- a/code/resources/views/documents/order_shipping_pdf.blade.php +++ b/code/resources/views/documents/order_shipping_pdf.blade.php @@ -49,6 +49,14 @@ padding: 4px 0; width: 100%; } + + ul { + margin: 0; + } + + li { + margin: 0; + } @@ -139,6 +147,10 @@ ?> + @if($d->others) +
{!! $d->others !!}
+ @endif +
@foreach($d->products as $product)