Примерочная
This commit is contained in:
@@ -19,14 +19,23 @@ class ControllerAccountWishList extends Controller {
|
||||
$this->load->model('tool/image');
|
||||
|
||||
if (isset($this->request->get['remove'])) {
|
||||
// Remove Wishlist
|
||||
$this->model_account_wishlist->deleteWishlist($this->request->get['remove']);
|
||||
$this->deleteWishlist((int)$this->request->get['remove']);
|
||||
|
||||
$this->session->data['success'] = $this->language->get('text_remove');
|
||||
|
||||
$this->response->redirect($this->url->link('account/wishlist'));
|
||||
}
|
||||
|
||||
if (isset($this->request->get['clear'])) {
|
||||
foreach ($this->getWishlistProductIds() as $product_id) {
|
||||
$this->deleteWishlist($product_id);
|
||||
}
|
||||
|
||||
$this->session->data['success'] = $this->language->get('text_clear');
|
||||
|
||||
$this->response->redirect($this->url->link('account/wishlist'));
|
||||
}
|
||||
|
||||
$this->document->setTitle($this->language->get('heading_title'));
|
||||
$this->document->setRobots('noindex,follow');
|
||||
|
||||
@@ -57,18 +66,32 @@ class ControllerAccountWishList extends Controller {
|
||||
|
||||
$data['products'] = array();
|
||||
|
||||
$results = $this->session->data['wishlist'] ? $this->session->data['wishlist'] : [];
|
||||
$results = $this->getWishlistProductIds();
|
||||
|
||||
foreach ($results as $result) {
|
||||
$product_info = $this->model_catalog_product->getProduct($result);
|
||||
foreach ($results as $product_id) {
|
||||
$product_info = $this->model_catalog_product->getProduct($product_id);
|
||||
|
||||
if ($product_info) {
|
||||
if ($product_info['image']) {
|
||||
$image = $this->model_tool_image->resize($product_info['image'], $this->config->get('theme_' . $this->config->get('config_theme') . '_image_wishlist_width'), $this->config->get('theme_' . $this->config->get('config_theme') . '_image_wishlist_height'));
|
||||
} else {
|
||||
$image = false;
|
||||
$image = $this->model_tool_image->resize('placeholder.png', $this->config->get('theme_' . $this->config->get('config_theme') . '_image_wishlist_width'), $this->config->get('theme_' . $this->config->get('config_theme') . '_image_wishlist_height'));
|
||||
}
|
||||
|
||||
$product_images = $this->model_catalog_product->getProductImages($product_info['product_id']);
|
||||
|
||||
if ($product_images) {
|
||||
$additional_image = $this->model_tool_image->resize($product_images[0]['image'], $this->config->get('theme_' . $this->config->get('config_theme') . '_image_wishlist_width'), $this->config->get('theme_' . $this->config->get('config_theme') . '_image_wishlist_height'));
|
||||
} else {
|
||||
$additional_image = false;
|
||||
}
|
||||
|
||||
$rent_prices = array_filter(array($product_info['price'], $product_info['price_2']), function($price) {
|
||||
return (float)$price > 0;
|
||||
});
|
||||
|
||||
$min_rent_price = $rent_prices ? min($rent_prices) : 0;
|
||||
|
||||
if ($product_info['quantity'] <= 0) {
|
||||
$stock = $product_info['stock_status'];
|
||||
} elseif ($this->config->get('config_stock_display')) {
|
||||
@@ -92,20 +115,27 @@ class ControllerAccountWishList extends Controller {
|
||||
$data['products'][] = array(
|
||||
'product_id' => $product_info['product_id'],
|
||||
'thumb' => $image,
|
||||
'additional_thumb' => $additional_image,
|
||||
'name' => $product_info['name'],
|
||||
'model' => $product_info['model'],
|
||||
'stock' => $stock,
|
||||
'price' => $price,
|
||||
'price_n' => $product_info['price'],
|
||||
'price_2_n' => $product_info['price_2'],
|
||||
'price_3' => $this->currency->format($this->tax->calculate($product_info['price_3'], $product_info['tax_class_id'], $this->config->get('config_tax')), $this->session->data['currency']),
|
||||
'min_price' => $this->currency->format($this->tax->calculate($min_rent_price, $product_info['tax_class_id'], $this->config->get('config_tax')), $this->session->data['currency']),
|
||||
'special' => $special,
|
||||
'href' => $this->url->link('product/product', 'product_id=' . $product_info['product_id']),
|
||||
'remove' => $this->url->link('account/wishlist', 'remove=' . $product_info['product_id'])
|
||||
);
|
||||
} else {
|
||||
$this->model_account_wishlist->deleteWishlist($result);
|
||||
$this->deleteWishlist($product_id);
|
||||
}
|
||||
}
|
||||
|
||||
$data['continue'] = $this->url->link('account/account', '', true);
|
||||
$data['fitting_room_count'] = count($data['products']);
|
||||
$data['clear'] = $this->url->link('account/wishlist', 'clear=1');
|
||||
$data['continue'] = $this->url->link('common/home');
|
||||
|
||||
$data['column_left'] = $this->load->controller('common/column_left');
|
||||
$data['column_right'] = $this->load->controller('common/column_right');
|
||||
@@ -133,22 +163,57 @@ class ControllerAccountWishList extends Controller {
|
||||
$product_info = $this->model_catalog_product->getProduct($product_id);
|
||||
|
||||
if ($product_info) {
|
||||
if (!isset($this->session->data['wishlist'])) {
|
||||
$this->session->data['wishlist'] = array();
|
||||
}
|
||||
if ($this->customer->isLogged()) {
|
||||
$this->load->model('account/wishlist');
|
||||
|
||||
$this->session->data['wishlist'][] = $this->request->post['product_id'];
|
||||
$this->model_account_wishlist->addWishlist($product_id);
|
||||
|
||||
$this->session->data['wishlist'] = array_unique($this->session->data['wishlist']);
|
||||
$total = $this->model_account_wishlist->getTotalWishlist();
|
||||
} else {
|
||||
if (!isset($this->session->data['wishlist']) || !is_array($this->session->data['wishlist'])) {
|
||||
$this->session->data['wishlist'] = array();
|
||||
}
|
||||
|
||||
$json['success'] = sprintf($this->language->get('text_success'), $this->url->link('product/product', 'product_id=' . (int)$this->request->post['product_id']), $product_info['name'], $this->url->link('account/wishlist'));
|
||||
$this->session->data['wishlist'][] = $product_id;
|
||||
$this->session->data['wishlist'] = array_unique($this->session->data['wishlist']);
|
||||
|
||||
$json['total'] = sprintf($this->language->get('text_wishlist'), (isset($this->session->data['wishlist']) ? count($this->session->data['wishlist']) : 0));
|
||||
}
|
||||
$total = count($this->session->data['wishlist']);
|
||||
}
|
||||
|
||||
$json['success'] = sprintf($this->language->get('text_success'), $this->url->link('product/product', 'product_id=' . (int)$product_id), $product_info['name'], $this->url->link('account/wishlist'));
|
||||
$json['total'] = sprintf($this->language->get('text_wishlist'), $total);
|
||||
}
|
||||
|
||||
$this->response->addHeader('Content-Type: application/json');
|
||||
$this->response->setOutput(json_encode($json));
|
||||
}
|
||||
|
||||
private function getWishlistProductIds() {
|
||||
if ($this->customer->isLogged()) {
|
||||
$product_ids = array();
|
||||
|
||||
foreach ($this->model_account_wishlist->getWishlist() as $result) {
|
||||
$product_ids[] = (int)$result['product_id'];
|
||||
}
|
||||
|
||||
return $product_ids;
|
||||
}
|
||||
|
||||
if (isset($this->session->data['wishlist']) && is_array($this->session->data['wishlist'])) {
|
||||
return array_map('intval', $this->session->data['wishlist']);
|
||||
}
|
||||
|
||||
return array();
|
||||
}
|
||||
|
||||
private function deleteWishlist($product_id) {
|
||||
if ($this->customer->isLogged()) {
|
||||
$this->model_account_wishlist->deleteWishlist($product_id);
|
||||
} elseif (isset($this->session->data['wishlist']) && is_array($this->session->data['wishlist'])) {
|
||||
$this->session->data['wishlist'] = array_values(array_diff($this->session->data['wishlist'], array($product_id)));
|
||||
}
|
||||
}
|
||||
|
||||
public function old_add() {
|
||||
$this->load->language('account/wishlist');
|
||||
|
||||
|
||||
Reference in New Issue
Block a user