185 lines
4.6 KiB
PHP
185 lines
4.6 KiB
PHP
<?php
|
|
/*************************************************************************************/
|
|
/* This file is part of the Thelia package. */
|
|
/* */
|
|
/* Copyright (c) OpenStudio */
|
|
/* email : dev@thelia.net */
|
|
/* web : http://www.thelia.net */
|
|
/* */
|
|
/* For the full copyright and license information, please view the LICENSE.txt */
|
|
/* file that was distributed with this source code. */
|
|
/*************************************************************************************/
|
|
|
|
namespace Thelia\Coupon;
|
|
|
|
use Symfony\Component\DependencyInjection\Container;
|
|
use Symfony\Component\DependencyInjection\ContainerInterface;
|
|
use Symfony\Component\Translation\TranslatorInterface;
|
|
use Thelia\Condition\ConditionEvaluator;
|
|
use Thelia\Core\HttpFoundation\Request;
|
|
use Thelia\Core\Template\ParserInterface;
|
|
use Thelia\Model\Country;
|
|
use Thelia\Model\Coupon;
|
|
|
|
/**
|
|
* Allow to assist in getting relevant data on the current application state
|
|
*
|
|
* @package Coupon
|
|
* @author Guillaume MOREL <gmorel@openstudio.fr>
|
|
*
|
|
*/
|
|
interface FacadeInterface
|
|
{
|
|
|
|
/**
|
|
* Constructor
|
|
*
|
|
* @param ContainerInterface $container Service container
|
|
*/
|
|
public function __construct(ContainerInterface $container);
|
|
|
|
/**
|
|
* Return a Cart a CouponManager can process
|
|
*
|
|
* @return \Thelia\Model\Cart
|
|
*/
|
|
public function getCart();
|
|
|
|
/**
|
|
* Return an Address a CouponManager can process
|
|
*
|
|
* @return \Thelia\Model\Address
|
|
*/
|
|
public function getDeliveryAddress();
|
|
|
|
/**
|
|
* @return Country the delivery country
|
|
*/
|
|
public function getDeliveryCountry();
|
|
|
|
/**
|
|
* Return an Customer a CouponManager can process
|
|
*
|
|
* @return \Thelia\Model\Customer
|
|
*/
|
|
public function getCustomer();
|
|
|
|
/**
|
|
* Return Checkout total price
|
|
*
|
|
* @return float
|
|
*/
|
|
public function getCheckoutTotalPrice();
|
|
|
|
/**
|
|
* Return Products total price
|
|
* CartTotalPrice = Checkout total - discount - postage
|
|
* @param bool $withItemsInPromo true (default) if item in promotion should be included in the total, false otherwise.
|
|
*
|
|
* @return float
|
|
*/
|
|
public function getCartTotalPrice($withItemsInPromo = true);
|
|
|
|
/**
|
|
* Return Product total tax price
|
|
* @param bool $withItemsInPromo true (default) if item in promotion should be included in the total, false otherwise.
|
|
*
|
|
* @return float
|
|
*/
|
|
public function getCartTotalTaxPrice($withItemsInPromo = true);
|
|
|
|
/**
|
|
* Return the Checkout currency EUR|USD
|
|
*
|
|
* @return string
|
|
*/
|
|
public function getCheckoutCurrency();
|
|
|
|
/**
|
|
* Return Checkout total postage (only) price
|
|
*
|
|
* @return float
|
|
*/
|
|
public function getCheckoutPostagePrice();
|
|
|
|
/**
|
|
* Return the number of Products in the Cart
|
|
*
|
|
* @return int
|
|
*/
|
|
public function getNbArticlesInCart();
|
|
|
|
/**
|
|
* Return all Coupon given during the Checkout
|
|
*
|
|
* @return array Array of CouponInterface
|
|
*/
|
|
public function getCurrentCoupons();
|
|
|
|
/**
|
|
* Find one Coupon in the database from its code
|
|
*
|
|
* @param string $code Coupon code
|
|
*
|
|
* @return Coupon
|
|
*/
|
|
public function findOneCouponByCode($code);
|
|
|
|
/**
|
|
* Return platform Container
|
|
*
|
|
* @return Container
|
|
*/
|
|
public function getContainer();
|
|
|
|
/**
|
|
* Return platform TranslatorInterface
|
|
*
|
|
* @return TranslatorInterface
|
|
*/
|
|
public function getTranslator();
|
|
/**
|
|
* Return platform ParserInterface
|
|
*
|
|
* @return ParserInterface
|
|
*/
|
|
public function getParser();
|
|
|
|
/**
|
|
* Return the main currency
|
|
* THe one used to set prices in BackOffice
|
|
*
|
|
* @return string
|
|
*/
|
|
public function getMainCurrency();
|
|
|
|
/**
|
|
* Return request
|
|
*
|
|
* @return Request
|
|
*/
|
|
public function getRequest();
|
|
|
|
/**
|
|
* Return Condition Evaluator
|
|
*
|
|
* @return ConditionEvaluator
|
|
*/
|
|
public function getConditionEvaluator();
|
|
|
|
/**
|
|
* Return all available currencies
|
|
*
|
|
* @return array of Currency
|
|
*/
|
|
public function getAvailableCurrencies();
|
|
|
|
/**
|
|
* Return the event dispatcher,
|
|
*
|
|
* @return \Symfony\Component\EventDispatcher\EventDispatcher
|
|
*/
|
|
public function getDispatcher();
|
|
|
|
}
|