fix: poprawny koszt transportu na /koszyk-podsumowanie
Na podstronie /koszyk-podsumowanie transport z flaga delivery_free=1 byl pokazywany zawsze za 0,00 zl, niezaleznie od wartosci koszyka. Teraz kontroler wylicza transport_cost_effective i free_delivery_applies uwzgledniajac prog settings.free_delivery, a szablon uzywa tych kluczy. - Nowa chroniona metoda ShopBasketController::calculateTransportCostForSummary - Dodane 6 testow jednostkowych (ShopBasketControllerSummaryViewTest) - Suita: 834 testy / 2318 assertions OK Co-Authored-By: Claude Opus 4.7 (1M context) <noreply@anthropic.com>
This commit is contained in:
@@ -280,20 +280,71 @@ class ShopBasketController
|
||||
$client = \Shared\Helpers\Helpers::get_session( 'client' );
|
||||
$orderSubmitToken = $this->createOrderSubmitToken();
|
||||
|
||||
$basket = \Shared\Helpers\Helpers::get_session( 'basket' );
|
||||
$coupon = \Shared\Helpers\Helpers::get_session( 'coupon' );
|
||||
$transport = ( new \Domain\Transport\TransportRepository( $GLOBALS['mdb'] ) )->findActiveByIdCached( \Shared\Helpers\Helpers::get_session( 'basket-transport-method-id' ) );
|
||||
|
||||
$productsSummary = (float)\Domain\Basket\BasketCalculator::summaryPrice( $basket, $coupon );
|
||||
$freeDeliveryThreshold = isset( $settings['free_delivery'] ) ? (float)$settings['free_delivery'] : 0.0;
|
||||
$transportCalc = $this->calculateTransportCostForSummary( $transport, $productsSummary, $freeDeliveryThreshold );
|
||||
|
||||
return \Shared\Tpl\Tpl::view( 'shop-basket/summary-view', [
|
||||
'lang_id' => $lang_id,
|
||||
'client' => \Shared\Helpers\Helpers::get_session( 'client' ),
|
||||
'basket' => \Shared\Helpers\Helpers::get_session( 'basket' ),
|
||||
'transport' => ( new \Domain\Transport\TransportRepository( $GLOBALS['mdb'] ) )->findActiveByIdCached( \Shared\Helpers\Helpers::get_session( 'basket-transport-method-id' ) ),
|
||||
'basket' => $basket,
|
||||
'transport' => $transport,
|
||||
'transport_cost_effective' => $transportCalc['transport_cost_effective'],
|
||||
'free_delivery_applies' => $transportCalc['free_delivery_applies'],
|
||||
'payment_method' => $this->paymentMethodRepository->paymentMethodCached( (int)\Shared\Helpers\Helpers::get_session( 'basket-payment-method-id' ) ),
|
||||
'addresses' => ( new \Domain\Client\ClientRepository( $GLOBALS['mdb'] ) )->clientAddresses( (int)$client['id'] ),
|
||||
'settings' => $settings,
|
||||
'coupon' => \Shared\Helpers\Helpers::get_session( 'coupon' ),
|
||||
'coupon' => $coupon,
|
||||
'basket_message' => \Shared\Helpers\Helpers::get_session( 'basket_message' ),
|
||||
'order_submit_token' => $orderSubmitToken
|
||||
] );
|
||||
}
|
||||
|
||||
/**
|
||||
* Wylicza efektywny koszt transportu dla widoku /koszyk-podsumowanie.
|
||||
* Koszt spada do 0, gdy transport ma flage delivery_free=1 ORAZ wartosc koszyka
|
||||
* (po kuponie) osiaga prog darmowej dostawy $freeDeliveryThreshold.
|
||||
*
|
||||
* @param array|null $transport Aktywny transport (lub null gdy nie wybrany)
|
||||
* @param float $productsSummary Wartosc koszyka po kuponie
|
||||
* @param float $freeDeliveryThreshold Prog darmowej dostawy z settings.free_delivery
|
||||
* @return array{transport_cost_effective: float, free_delivery_applies: bool}
|
||||
*/
|
||||
protected function calculateTransportCostForSummary( $transport, $productsSummary, $freeDeliveryThreshold )
|
||||
{
|
||||
if ( !is_array( $transport ) )
|
||||
{
|
||||
return [
|
||||
'transport_cost_effective' => 0.0,
|
||||
'free_delivery_applies' => false,
|
||||
];
|
||||
}
|
||||
|
||||
$deliveryFree = isset( $transport['delivery_free'] ) ? (int)$transport['delivery_free'] : 0;
|
||||
$cost = isset( $transport['cost'] ) ? (float)$transport['cost'] : 0.0;
|
||||
|
||||
$applies = false;
|
||||
if ( $deliveryFree === 1 && $freeDeliveryThreshold > 0 )
|
||||
{
|
||||
$summaryNormalized = \Shared\Helpers\Helpers::normalize_decimal( $productsSummary );
|
||||
$thresholdNormalized = \Shared\Helpers\Helpers::normalize_decimal( $freeDeliveryThreshold );
|
||||
|
||||
if ( $summaryNormalized >= $thresholdNormalized )
|
||||
{
|
||||
$applies = true;
|
||||
}
|
||||
}
|
||||
|
||||
return [
|
||||
'transport_cost_effective' => $applies ? 0.0 : $cost,
|
||||
'free_delivery_applies' => $applies,
|
||||
];
|
||||
}
|
||||
|
||||
public function basketSave()
|
||||
{
|
||||
$orderSubmitToken = (string)\Shared\Helpers\Helpers::get( 'order_submit_token', true );
|
||||
|
||||
Reference in New Issue
Block a user