все еще ищете? Нашел этот:
http://www.magentocommerce.com/boards/viewthread/9797
Кажется, работает в текущих версиях, хотя я еще не проверял это. Если вы решили это, по крайней мере будущие искатели будут знать, где его найти!
/ *** EDIT **** /
Ну, чтобы «не считаться плохим ответом», вот как вы должны реализовать решение. Никакой кодекс не является моей работой, спасибо Uni-Man, Nexus Rex и ребятам из Magento Forum:)
Код хорошо документирован. Он создает полноценное расширение Magento в пространстве имен «Компания» с именем «Модуль».
Сначала внедрите помощника в app / code / local / Company / Module / helper / Data.php:
<?php
class Company_Module_Helper_Multiple extends Mage_Core_Helper_Url
{
/**
* Return url to add multiple items to the cart
* @return url
*/
public function getAddToCartUrl()
{
if ($currentCategory = Mage::registry('current_category')) {
$continueShoppingUrl = $currentCategory->getUrl();
} else {
$continueShoppingUrl = $this->_getUrl('*/*/*', array('_current'=>true));
}
$params = array(
Mage_Core_Controller_Front_Action::PARAM_NAME_URL_ENCODED => Mage::helper('core')->urlEncode($continueShoppingUrl)
);
if ($this->_getRequest()->getModuleName() == 'checkout'
&& $this->_getRequest()->getControllerName() == 'cart') {
$params['in_cart'] = 1;
}
return $this->_getUrl('checkout/cart/addmultiple', $params);
}
}
Далее вам нужно будет внести некоторые изменения в шаблон. Скопируйте файл app / design / base / default / templates / catalog / list.phtml в файл app / design / default / default / templates / catalog / list.phtml. Это гарантирует, что, когда расширение больше не требуется, вы / ваш клиент можете вернуться к обычному представлению списка без кодирования.
Измените новый файл list.phtml следующим образом:
После
<?php echo $this->getToolbarHtml(); ?>
добавить
<form action="<?php echo $this->helper( 'Module/multiple' )->getAddToCartUrl() ?>" method="post" id="product_addtocart_form">
<button class="form-button" onclick="productAddToCartForm.submit()"><span><?php echo $this->__('Add Items to Cart') ?></span></button>
(Это откроет форму; все последующие элементы добавят поля ввода для количества, поэтому вы можете положить все элементы в корзину, используя одну единственную кнопку. Это также и здесь.)
Прокручивая вниз, вы найдете область, где обычно генерируется кнопка «Добавить в корзину»:
<?php if($_product->isSaleable()): ?>
Заменить содержимое блока if на:
<fieldset class="add-to-cart-box">
<input type="hidden" name="products[]" value="<?php echo $_product->getId() ?>" />
<legend><?php echo $this->__('Add Items to Cart') ?></legend>
<span class="qty-box"><label for="qty<?php echo $_product->getId() ?>"><?php echo $this->__('Qty') ?>:</label>
<input name="qty<?php echo $_product->getId() ?>" type="text" class="input-text qty" id="qty<?php echo $_product->getId() ?>" maxlength="12" value="" /></span>
</fieldset>
Это поле ввода для количества.
Чтобы закрыть -tag, вставьте после
<?php echo $this->getToolbarHtml() ?>
внизу:
<button class="form-button" onclick="productAddToCartForm.submit()"><span><?php echo $this->__('Add Items to Cart') ?></span></button>
</form>
Что вы делаете здесь:
- сгенерировать вторую кнопку «Добавить в корзину», идентичную кнопке сверху
- закрыть форму
Когда товар добавляется в корзину, обычно Magento вызывает Checkout_CartController. Мы должны изменить это, чтобы добавить не один, а все товары в корзину в заслуженном количестве.
Поэтому добавьте файл app / code / local / Company / Module / controllers / Checkout / CartController.php и заполните это:
> require_once 'Mage/Checkout/controllers/CartController.php';
>
> class Company_Module_Checkout_CartController extends
> Mage_Checkout_CartController {
> public function addmultipleAction()
> {
> $productIds = $this->getRequest()->getParam('products');
> if (!is_array($productIds)) {
> $this->_goBack();
> return;
> }
>
> foreach( $productIds as $productId) {
> try {
> $qty = $this->getRequest()->getParam('qty' . $productId, 0);
> if ($qty <= 0) continue; // nothing to add
>
> $cart = $this->_getCart();
> $product = Mage::getModel('catalog/product')
> ->setStoreId(Mage::app()->getStore()->getId())
> ->load($productId)
> ->setConfiguredAttributes($this->getRequest()->getParam('super_attribute'))
> ->setGroupedProducts($this->getRequest()->getParam('super_group', array()));
> $eventArgs = array(
> 'product' => $product,
> 'qty' => $qty,
> 'additional_ids' => array(),
> 'request' => $this->getRequest(),
> 'response' => $this->getResponse(),
> );
>
> Mage::dispatchEvent('checkout_cart_before_add', $eventArgs);
>
> $cart->addProduct($product, $qty);
>
> Mage::dispatchEvent('checkout_cart_after_add', $eventArgs);
>
> $cart->save();
>
> Mage::dispatchEvent('checkout_cart_add_product', array('product'=>$product));
>
> $message = $this->__('%s was successfully added to your shopping cart.', $product->getName());
> Mage::getSingleton('checkout/session')->addSuccess($message);
> }
> catch (Mage_Core_Exception $e) {
> if (Mage::getSingleton('checkout/session')->getUseNotice(true)) {
> Mage::getSingleton('checkout/session')->addNotice($product->getName() . ': ' . $e->getMessage());
> }
> else {
> Mage::getSingleton('checkout/session')->addError($product->getName() . ': ' . $e->getMessage());
> }
> }
> catch (Exception $e) {
> Mage::getSingleton('checkout/session')->addException($e, $this->__('Can not add item to shopping cart'));
> }
> }
> $this->_goBack();
> } }
Мы заменяем существующий класс Mage Core своим собственным, что приводит к использованию нашего контроллера для этой цели.
Вам также нужно будет добавить файл config.xml модуля, как обычно, в app / code / local / Company / Module / etc / config.xml:
<?xml version="1.0"?>
<config>
<modules>
<Company_Module>
<version>0.1.0</version>
</Company_Module>
</modules>
<global>
<rewrite>
<company_module_checkout_cart>
<from><![CDATA[#^/checkout/cart/addmultiple/.*$#]]></from>
<to>/module/checkout_cart/addmultiple/</to>
</company_module_checkout_cart>
</rewrite>
<helpers>
<Module>
<class>Company_Module_Helper</class>
</Module>
</helpers>
</global>
<frontend>
<routers>
<company_module>
<use>standard</use>
<args>
<module>Company_Module</module>
<frontName>module</frontName>
</args>
</company_module>
</routers>
</frontend>
</config>
Что это делает:
- заменяет вызов контроллера корзины вызовом собственного контроллера multiadd
- регистрирует помощника
- применяет роутер к интерфейсу
Скажите, пожалуйста, нужна ли дополнительная документация по этому вопросу?