Перейти до вмісту
Пошук в
  • Детальніше...
Шукати результати, які ...
Шукати результати в ...

kuripka2222

Користувачі
  
  • Публікації

    136
  • З нами

  • Відвідування

Усі публікації користувача kuripka2222

  1. Скиньте содержимое файла product.twig по пути catalog/view/theme/fanes/template/product/
  2. Модуль рабочий. Он не работает в одном случае, если вы лезли в код сайта, в таком случае установите сами, не через модификатор и все будет гуд Посмотрите на офф сайте модули для вашей версии, там достаточно много похожих бесплатных и платных модулей
  3. https://www.opencart.com/index.php?route=marketplace/extension/info&extension_id=32928&filter_search=price -&filter_license=0&page=2
  4. Как вариант, задай в стилях в конце @media(max-width:768px;) { img { max-height: 100%; max-width: 100%; object-fit: contain; } }
  5. Там и копаю, но выдает ошибку Notice: Undefined index: mpn in ... on line 16 На странице оформления заказа все выводится (Скриншот 1), потому что я в /system/library/cart/cart.php добавляю строку (Скриншот 2). После добавлении записи в catalog\model\checkout\order.php (Скриншот 3), что как раз и должно записывать данные в таблицу, на странице оформления на шаге подтверждения выдает ошибку (Скриншот 4) и данные в таблицу после оформления не записываются. Что я тут не так нахимичил?)
  6. Здравствуйте, использую поле с нужной мне информацией, мне нужно чтобы для каждого заказа это поле сохранялось индивидуально, как цена, количество товара и тд в таблице "oc_order_product". Поле собственно использую mpn товара, значения в корзине и на странице оформления заказа выводится, но после оформления заказа значения в базу данных не записывается. Помогите плз разобраться, что я делаю не так или чего у меня не хватает ? На сколько я понимаю за все сохраненный данные с корзины отвечает файл: system/library/cart/cart.php Я mpn вывожу в массиве $product_data[] = array(): <?php namespace Cart; class Cart { private $data = array(); public function __construct($registry) { $this->config = $registry->get('config'); $this->customer = $registry->get('customer'); $this->session = $registry->get('session'); $this->db = $registry->get('db'); $this->tax = $registry->get('tax'); $this->weight = $registry->get('weight'); // Remove all the expired carts with no customer ID $this->db->query("DELETE FROM " . DB_PREFIX . "cart WHERE (api_id > '0' OR customer_id = '0') AND date_added < DATE_SUB(NOW(), INTERVAL 10 DAY)"); if ($this->customer->getId()) { // We want to change the session ID on all the old items in the customers cart $this->db->query("UPDATE " . DB_PREFIX . "cart SET session_id = '" . $this->db->escape($this->session->getId()) . "' WHERE api_id = '0' AND customer_id = '" . (int)$this->customer->getId() . "'"); // Once the customer is logged in we want to update the customers cart $cart_query = $this->db->query("SELECT * FROM " . DB_PREFIX . "cart WHERE api_id = '0' AND customer_id = '0' AND session_id = '" . $this->db->escape($this->session->getId()) . "'"); foreach ($cart_query->rows as $cart) { $this->db->query("DELETE FROM " . DB_PREFIX . "cart WHERE cart_id = '" . (int)$cart['cart_id'] . "'"); // The advantage of using $this->add is that it will check if the products already exist and increaser the quantity if necessary. $this->add($cart['product_id'], $cart['quantity'], json_decode($cart['option']), $cart['recurring_id']); } } } public function getProducts() { $product_data = array(); $cart_query = $this->db->query("SELECT * FROM " . DB_PREFIX . "cart WHERE api_id = '" . (isset($this->session->data['api_id']) ? (int)$this->session->data['api_id'] : 0) . "' AND customer_id = '" . (int)$this->customer->getId() . "' AND session_id = '" . $this->db->escape($this->session->getId()) . "'"); foreach ($cart_query->rows as $cart) { $stock = true; $product_query = $this->db->query("SELECT * FROM " . DB_PREFIX . "product_to_store p2s LEFT JOIN " . DB_PREFIX . "product p ON (p2s.product_id = p.product_id) LEFT JOIN " . DB_PREFIX . "product_description pd ON (p.product_id = pd.product_id) WHERE p2s.store_id = '" . (int)$this->config->get('config_store_id') . "' AND p2s.product_id = '" . (int)$cart['product_id'] . "' AND pd.language_id = '" . (int)$this->config->get('config_language_id') . "' AND p.date_available <= NOW() AND p.status = '1'"); if ($product_query->num_rows && ($cart['quantity'] > 0)) { $option_price = 0; $option_points = 0; $option_weight = 0; $option_data = array(); foreach (json_decode($cart['option']) as $product_option_id => $value) { $option_query = $this->db->query("SELECT po.product_option_id, po.option_id, od.name, o.type FROM " . DB_PREFIX . "product_option po LEFT JOIN `" . DB_PREFIX . "option` o ON (po.option_id = o.option_id) LEFT JOIN " . DB_PREFIX . "option_description od ON (o.option_id = od.option_id) WHERE po.product_option_id = '" . (int)$product_option_id . "' AND po.product_id = '" . (int)$cart['product_id'] . "' AND od.language_id = '" . (int)$this->config->get('config_language_id') . "'"); if ($option_query->num_rows) { if ($option_query->row['type'] == 'select' || $option_query->row['type'] == 'radio') { $option_value_query = $this->db->query("SELECT pov.option_value_id, ovd.name, pov.quantity, pov.subtract, pov.price, pov.price_prefix, pov.points, pov.points_prefix, pov.weight, pov.weight_prefix FROM " . DB_PREFIX . "product_option_value pov LEFT JOIN " . DB_PREFIX . "option_value ov ON (pov.option_value_id = ov.option_value_id) LEFT JOIN " . DB_PREFIX . "option_value_description ovd ON (ov.option_value_id = ovd.option_value_id) WHERE pov.product_option_value_id = '" . (int)$value . "' AND pov.product_option_id = '" . (int)$product_option_id . "' AND ovd.language_id = '" . (int)$this->config->get('config_language_id') . "'"); if ($option_value_query->num_rows) { if ($option_value_query->row['price_prefix'] == '+') { $option_price += $option_value_query->row['price']; } elseif ($option_value_query->row['price_prefix'] == '-') { $option_price -= $option_value_query->row['price']; } if ($option_value_query->row['points_prefix'] == '+') { $option_points += $option_value_query->row['points']; } elseif ($option_value_query->row['points_prefix'] == '-') { $option_points -= $option_value_query->row['points']; } if ($option_value_query->row['weight_prefix'] == '+') { $option_weight += $option_value_query->row['weight']; } elseif ($option_value_query->row['weight_prefix'] == '-') { $option_weight -= $option_value_query->row['weight']; } if ($option_value_query->row['subtract'] && (!$option_value_query->row['quantity'] || ($option_value_query->row['quantity'] < $cart['quantity']))) { $stock = false; } $option_data[] = array( 'product_option_id' => $product_option_id, 'product_option_value_id' => $value, 'option_id' => $option_query->row['option_id'], 'option_value_id' => $option_value_query->row['option_value_id'], 'name' => $option_query->row['name'], 'value' => $option_value_query->row['name'], 'type' => $option_query->row['type'], 'quantity' => $option_value_query->row['quantity'], 'subtract' => $option_value_query->row['subtract'], 'price' => $option_value_query->row['price'], 'price_prefix' => $option_value_query->row['price_prefix'], 'points' => $option_value_query->row['points'], 'points_prefix' => $option_value_query->row['points_prefix'], 'weight' => $option_value_query->row['weight'], 'weight_prefix' => $option_value_query->row['weight_prefix'] ); } } elseif ($option_query->row['type'] == 'checkbox' && is_array($value)) { foreach ($value as $product_option_value_id) { $option_value_query = $this->db->query("SELECT pov.option_value_id, pov.quantity, pov.subtract, pov.price, pov.price_prefix, pov.points, pov.points_prefix, pov.weight, pov.weight_prefix, ovd.name FROM " . DB_PREFIX . "product_option_value pov LEFT JOIN " . DB_PREFIX . "option_value_description ovd ON (pov.option_value_id = ovd.option_value_id) WHERE pov.product_option_value_id = '" . (int)$product_option_value_id . "' AND pov.product_option_id = '" . (int)$product_option_id . "' AND ovd.language_id = '" . (int)$this->config->get('config_language_id') . "'"); if ($option_value_query->num_rows) { if ($option_value_query->row['price_prefix'] == '+') { $option_price += $option_value_query->row['price']; } elseif ($option_value_query->row['price_prefix'] == '-') { $option_price -= $option_value_query->row['price']; } if ($option_value_query->row['points_prefix'] == '+') { $option_points += $option_value_query->row['points']; } elseif ($option_value_query->row['points_prefix'] == '-') { $option_points -= $option_value_query->row['points']; } if ($option_value_query->row['weight_prefix'] == '+') { $option_weight += $option_value_query->row['weight']; } elseif ($option_value_query->row['weight_prefix'] == '-') { $option_weight -= $option_value_query->row['weight']; } if ($option_value_query->row['subtract'] && (!$option_value_query->row['quantity'] || ($option_value_query->row['quantity'] < $cart['quantity']))) { $stock = false; } $option_data[] = array( 'product_option_id' => $product_option_id, 'product_option_value_id' => $product_option_value_id, 'option_id' => $option_query->row['option_id'], 'option_value_id' => $option_value_query->row['option_value_id'], 'name' => $option_query->row['name'], 'value' => $option_value_query->row['name'], 'type' => $option_query->row['type'], 'quantity' => $option_value_query->row['quantity'], 'subtract' => $option_value_query->row['subtract'], 'price' => $option_value_query->row['price'], 'price_prefix' => $option_value_query->row['price_prefix'], 'points' => $option_value_query->row['points'], 'points_prefix' => $option_value_query->row['points_prefix'], 'weight' => $option_value_query->row['weight'], 'weight_prefix' => $option_value_query->row['weight_prefix'] ); } } } elseif ($option_query->row['type'] == 'text' || $option_query->row['type'] == 'textarea' || $option_query->row['type'] == 'file' || $option_query->row['type'] == 'date' || $option_query->row['type'] == 'datetime' || $option_query->row['type'] == 'time') { $option_data[] = array( 'product_option_id' => $product_option_id, 'product_option_value_id' => '', 'option_id' => $option_query->row['option_id'], 'option_value_id' => '', 'name' => $option_query->row['name'], 'value' => $value, 'type' => $option_query->row['type'], 'quantity' => '', 'subtract' => '', 'price' => '', 'price_prefix' => '', 'points' => '', 'points_prefix' => '', 'weight' => '', 'weight_prefix' => '' ); } } } $price = $product_query->row['price']; // Product Discounts $discount_quantity = 0; foreach ($cart_query->rows as $cart_2) { if ($cart_2['product_id'] == $cart['product_id']) { $discount_quantity += $cart_2['quantity']; } } $product_discount_query = $this->db->query("SELECT price FROM " . DB_PREFIX . "product_discount WHERE product_id = '" . (int)$cart['product_id'] . "' AND customer_group_id = '" . (int)$this->config->get('config_customer_group_id') . "' AND quantity <= '" . (int)$discount_quantity . "' AND ((date_start = '0000-00-00' OR date_start < NOW()) AND (date_end = '0000-00-00' OR date_end > NOW())) ORDER BY quantity DESC, priority ASC, price ASC LIMIT 1"); if ($product_discount_query->num_rows) { $price = $product_discount_query->row['price']; } // Product Specials $product_special_query = $this->db->query("SELECT price FROM " . DB_PREFIX . "product_special WHERE product_id = '" . (int)$cart['product_id'] . "' AND customer_group_id = '" . (int)$this->config->get('config_customer_group_id') . "' AND ((date_start = '0000-00-00' OR date_start < NOW()) AND (date_end = '0000-00-00' OR date_end > NOW())) ORDER BY priority ASC, price ASC LIMIT 1"); if ($product_special_query->num_rows) { $price = $product_special_query->row['price']; } // Reward Points $product_reward_query = $this->db->query("SELECT points FROM " . DB_PREFIX . "product_reward WHERE product_id = '" . (int)$cart['product_id'] . "' AND customer_group_id = '" . (int)$this->config->get('config_customer_group_id') . "'"); if ($product_reward_query->num_rows) { $reward = $product_reward_query->row['points']; } else { $reward = 0; } // Downloads $download_data = array(); $download_query = $this->db->query("SELECT * FROM " . DB_PREFIX . "product_to_download p2d LEFT JOIN " . DB_PREFIX . "download d ON (p2d.download_id = d.download_id) LEFT JOIN " . DB_PREFIX . "download_description dd ON (d.download_id = dd.download_id) WHERE p2d.product_id = '" . (int)$cart['product_id'] . "' AND dd.language_id = '" . (int)$this->config->get('config_language_id') . "'"); foreach ($download_query->rows as $download) { $download_data[] = array( 'download_id' => $download['download_id'], 'name' => $download['name'], 'filename' => $download['filename'], 'mask' => $download['mask'] ); } // Stock if (!$product_query->row['quantity'] || ($product_query->row['quantity'] < $cart['quantity'])) { $stock = false; } $recurring_query = $this->db->query("SELECT * FROM " . DB_PREFIX . "recurring r LEFT JOIN " . DB_PREFIX . "product_recurring pr ON (r.recurring_id = pr.recurring_id) LEFT JOIN " . DB_PREFIX . "recurring_description rd ON (r.recurring_id = rd.recurring_id) WHERE r.recurring_id = '" . (int)$cart['recurring_id'] . "' AND pr.product_id = '" . (int)$cart['product_id'] . "' AND rd.language_id = " . (int)$this->config->get('config_language_id') . " AND r.status = 1 AND pr.customer_group_id = '" . (int)$this->config->get('config_customer_group_id') . "'"); if ($recurring_query->num_rows) { $recurring = array( 'recurring_id' => $cart['recurring_id'], 'name' => $recurring_query->row['name'], 'frequency' => $recurring_query->row['frequency'], 'price' => $recurring_query->row['price'], 'cycle' => $recurring_query->row['cycle'], 'duration' => $recurring_query->row['duration'], 'trial' => $recurring_query->row['trial_status'], 'trial_frequency' => $recurring_query->row['trial_frequency'], 'trial_price' => $recurring_query->row['trial_price'], 'trial_cycle' => $recurring_query->row['trial_cycle'], 'trial_duration' => $recurring_query->row['trial_duration'] ); } else { $recurring = false; } $product_data[] = array( 'cart_id' => $cart['cart_id'], 'product_id' => $product_query->row['product_id'], 'name' => $product_query->row['name'], 'model' => $product_query->row['model'], 'mpn' => $product_query->row['mpn'], 'shipping' => $product_query->row['shipping'], 'image' => $product_query->row['image'], 'option' => $option_data, 'download' => $download_data, 'quantity' => $cart['quantity'], 'minimum' => $product_query->row['minimum'], 'subtract' => $product_query->row['subtract'], 'stock' => $stock, 'price' => ($price + $option_price), 'total' => ($price + $option_price) * $cart['quantity'], 'reward' => $reward * $cart['quantity'], 'points' => ($product_query->row['points'] ? ($product_query->row['points'] + $option_points) * $cart['quantity'] : 0), 'tax_class_id' => $product_query->row['tax_class_id'], 'weight' => ($product_query->row['weight'] + $option_weight) * $cart['quantity'], 'weight_class_id' => $product_query->row['weight_class_id'], 'length' => $product_query->row['length'], 'width' => $product_query->row['width'], 'height' => $product_query->row['height'], 'length_class_id' => $product_query->row['length_class_id'], 'recurring' => $recurring ); } else { $this->remove($cart['cart_id']); } } return $product_data; } public function add($product_id, $quantity = 1, $option = array(), $recurring_id = 0) { $query = $this->db->query("SELECT COUNT(*) AS total FROM " . DB_PREFIX . "cart WHERE api_id = '" . (isset($this->session->data['api_id']) ? (int)$this->session->data['api_id'] : 0) . "' AND customer_id = '" . (int)$this->customer->getId() . "' AND session_id = '" . $this->db->escape($this->session->getId()) . "' AND product_id = '" . (int)$product_id . "' AND recurring_id = '" . (int)$recurring_id . "' AND `option` = '" . $this->db->escape(json_encode($option)) . "'"); if (!$query->row['total']) { $this->db->query("INSERT INTO " . DB_PREFIX . "cart SET api_id = '" . (isset($this->session->data['api_id']) ? (int)$this->session->data['api_id'] : 0) . "', customer_id = '" . (int)$this->customer->getId() . "', session_id = '" . $this->db->escape($this->session->getId()) . "', product_id = '" . (int)$product_id . "', recurring_id = '" . (int)$recurring_id . "', `option` = '" . $this->db->escape(json_encode($option)) . "', quantity = '" . (int)$quantity . "', date_added = NOW()"); } else { $this->db->query("UPDATE " . DB_PREFIX . "cart SET quantity = (quantity + " . (int)$quantity . ") WHERE api_id = '" . (isset($this->session->data['api_id']) ? (int)$this->session->data['api_id'] : 0) . "' AND customer_id = '" . (int)$this->customer->getId() . "' AND session_id = '" . $this->db->escape($this->session->getId()) . "' AND product_id = '" . (int)$product_id . "' AND recurring_id = '" . (int)$recurring_id . "' AND `option` = '" . $this->db->escape(json_encode($option)) . "'"); } } public function update($cart_id, $quantity) { $this->db->query("UPDATE " . DB_PREFIX . "cart SET quantity = '" . (int)$quantity . "' WHERE cart_id = '" . (int)$cart_id . "' AND api_id = '" . (isset($this->session->data['api_id']) ? (int)$this->session->data['api_id'] : 0) . "' AND customer_id = '" . (int)$this->customer->getId() . "' AND session_id = '" . $this->db->escape($this->session->getId()) . "'"); } public function remove($cart_id) { $this->db->query("DELETE FROM " . DB_PREFIX . "cart WHERE cart_id = '" . (int)$cart_id . "' AND api_id = '" . (isset($this->session->data['api_id']) ? (int)$this->session->data['api_id'] : 0) . "' AND customer_id = '" . (int)$this->customer->getId() . "' AND session_id = '" . $this->db->escape($this->session->getId()) . "'"); } public function clear() { $this->db->query("DELETE FROM " . DB_PREFIX . "cart WHERE api_id = '" . (isset($this->session->data['api_id']) ? (int)$this->session->data['api_id'] : 0) . "' AND customer_id = '" . (int)$this->customer->getId() . "' AND session_id = '" . $this->db->escape($this->session->getId()) . "'"); } public function getRecurringProducts() { $product_data = array(); foreach ($this->getProducts() as $value) { if ($value['recurring']) { $product_data[] = $value; } } return $product_data; } public function getWeight() { $weight = 0; foreach ($this->getProducts() as $product) { if ($product['shipping']) { $weight += $this->weight->convert($product['weight'], $product['weight_class_id'], $this->config->get('config_weight_class_id')); } } return $weight; } public function getSubTotal() { $total = 0; foreach ($this->getProducts() as $product) { $total += $product['total']; } return $total; } public function getTaxes() { $tax_data = array(); foreach ($this->getProducts() as $product) { if ($product['tax_class_id']) { $tax_rates = $this->tax->getRates($product['price'], $product['tax_class_id']); foreach ($tax_rates as $tax_rate) { if (!isset($tax_data[$tax_rate['tax_rate_id']])) { $tax_data[$tax_rate['tax_rate_id']] = ($tax_rate['amount'] * $product['quantity']); } else { $tax_data[$tax_rate['tax_rate_id']] += ($tax_rate['amount'] * $product['quantity']); } } } } return $tax_data; } public function getTotal() { $total = 0; foreach ($this->getProducts() as $product) { $total += $this->tax->calculate($product['price'], $product['tax_class_id'], $this->config->get('config_tax')) * $product['quantity']; } return $total; } public function countProducts() { $product_total = 0; $products = $this->getProducts(); foreach ($products as $product) { $product_total += $product['quantity']; } return $product_total; } public function hasProducts() { return count($this->getProducts()); } public function hasRecurringProducts() { return count($this->getRecurringProducts()); } public function hasStock() { foreach ($this->getProducts() as $product) { if (!$product['stock']) { return false; } } return true; } public function hasShipping() { foreach ($this->getProducts() as $product) { if ($product['shipping']) { return true; } } return false; } public function hasDownload() { foreach ($this->getProducts() as $product) { if ($product['download']) { return true; } } return false; } }
  7. В целом как написать код) $zakup_price = $this->db->query("SELECT zakup_price FROM " . DB_PREFIX . "product WHERE product_id = '" . $product['product_id'] . "'"); if ($zakup_price->row['zakup_price']) { $zakup_pribil = $this->currency->format(($product['total'] - ($zakup_prices * $product['quantity'])) , $order_info['currency_code'], $order_info['currency_value']); } else { $zakup_pribil = ''; } $data['products'][] = array( 'order_product_id' => $product['order_product_id'], 'product_id' => $product['product_id'], 'name' => $product['name'], 'model' => $product['model'], 'zakup_pribil' => $zakup_pribil, 'option' => $option_data, 'quantity' => $product['quantity'], 'price' => $this->currency->format($product['price'] + ($this->config->get('config_tax') ? $product['tax'] : 0), $order_info['currency_code'], $order_info['currency_value']), 'total' => $this->currency->format($product['total'] + ($this->config->get('config_tax') ? ($product['tax'] * $product['quantity']) : 0), $order_info['currency_code'], $order_info['currency_value']), 'href' => $this->url->link('catalog/product/edit', 'user_token=' . $this->session->data['user_token'] . '&product_id=' . $product['product_id'], true) ); Мне по идее надо каждый $zakup_pribil сложить за все товары и вывести уже общее число. Но я уже более часа не могу это никак сделать. Буду благодарен, если подскажете как записать)
  8. Здравствуйте, у меня есть стоимость закупки и при вычитании с цены продажи рассчитывается прибыль на товар, мне нужно вывести прибыль за весь заказ, то есть сложить прибыль за продажу каждого товара и вывести в общее. По какой логике я могу это сделать? На скриншоте понятнее )
  9. Если с помощью стороннего сервиса, не подскажете какого лучше?
  10. Всем привет, может кто знает где можно взять список товаров с фотографиями в csv формате, для выгрузки на демонстрационный сайт?
  11. Так зачем мне услуги, когда я самостоятельно хочу разобраться. Так как я развиваюсь в программировании и изучаю на данный момент php, но иногда глухо на столько, что спрашиваю совета либо помощи небольшой)) Все равно если никто не подскажет, то буду возиться сам и найду решение
  12. Спасибо, я изначально не правильно делал. Вообщем у меня задача сделать бонусную систему для клиента. Сейчас у меня есть уже все данные, которые мне нужны, но мне еще надо сделать калькулятор, чтобы рассчитывало какую сумму еще надо потратить клиенту, чтобы перейти в следующую группу и клиентов. Помогите плз, уже часа 2 пытаюсь через round(); вытащить число На скриншоте указано, что надо сделать, думаю понятно)) В контроллере и модели я вывожу: 1. Общую стоимость за все заказы // Контроллер $data['config_total_orders'] = array(); if ($this->customer->isLogged()) { $data['total_orders'] = $this->model_catalog_customers_sale->getTotalsForCustomer($customer_info['customer_id']); } else { $data['total_orders'] = ''; } // Модель public function getTotalsForCustomer($customerid){ $sql = $this->db->query("SELECT COUNT(*) as total_number, SUM(total) as total_value FROM " . DB_PREFIX . "order WHERE customer_id = $customerid AND order_status_id > 0 LIMIT 1"); // As we are only expecting one row of results we can use $sql->row rather than $sql->rows return $sql->row; // the output of which will result in an array('total_number', 'total_value') } <!-- В виде --> {{ total_orders.total_value|round(2) }} 2. Все группы клиентов // Контроллер $customer_groups = $this->model_catalog_customers_sale->getCustomerGroupss(); foreach ($customer_groups as $customer_group) { $data['customer_groups'][] = array( 'reach_value' => $customer_group['reach_value'], 'reach_group' => $reach_group, 'names' => (($customer_group['customer_group_id'] == $this->config->get('config_customer_group_id')) ? $this->language->get('text_default') : null), 'name' => $customer_group['name'], 'ids' => $customer_group['customer_group_id'], ); } // Модель public function getCustomerGroupss($data = array()) { $sql = "SELECT * FROM " . DB_PREFIX . "customer_group cg LEFT JOIN " . DB_PREFIX . "customer_group_description cgd ON (cg.customer_group_id = cgd.customer_group_id) WHERE cgd.language_id = '" . (int)$this->config->get('config_language_id') . "'"; $sort_data = array( 'cgd.name', 'cg.sort_order' ); if (isset($data['sort']) && in_array($data['sort'], $sort_data)) { $sql .= " ORDER BY " . $data['sort']; } else { $sql .= " ORDER BY cgd.name"; } if (isset($data['order']) && ($data['order'] == 'DESC')) { $sql .= " DESC"; } else { $sql .= " ASC"; } if (isset($data['start']) || isset($data['limit'])) { if ($data['start'] < 0) { $data['start'] = 0; } if ($data['limit'] < 1) { $data['limit'] = 20; } $sql .= " LIMIT " . (int)$data['start'] . "," . (int)$data['limit']; } $query = $this->db->query($sql); return $query->rows; } {% for customer_group in customer_groups %} {% if customer_group.ids in [5] %} <!-- Не знаю как записать по другому, чтобы не выводить группу клиентов с id = 5 :) , пробовал через "if not", не получилось вывести все кроме группы с id = 5 --> {% else %} <p style="float:left;width: 25%;"> Имя: {{ customer_group.name }} <br> Цена: {{ customer_group.reach_value|round(2) }}<br> ID группы: {{ customer_group.ids }} </p> {% endif %} По идее мне просто надо записать правильно в контроллере функцию калькулятора, чтобы было {{ customer_group.reach_value|round(2) }} - {{ total_orders.total_value|round(2) }} = число.
  13. Спасибо) Я после пытаюсь выводить в контроллере $data['customer_groups'] = $this->model_account_customer_group->getCustomerGroupsIds(); В виде {{ customer_groups }} Но почему на сайте ничего не появляется?
  14. Здравствуйте, нужно вывести ID всех групп клиентов, но не знаю как построить запрос в БД правильно, помогите плз public function getCustomerGroupsId() { $query = $this->db->query("SELECT * FROM " . DB_PREFIX . "customer_group ORDER BY cg.sort_order ASC " . DB_PREFIX . "customer_group.customer_group_id ASC"); return $query->rows; }
  15. Копия дефолтного шаблона. То есть скопировал все файлы шаблона и нужные контроллеры переименовал. Система: Opencart 3 PHP Version 7.3.20 Loader version 10.4.1
  16. В логах ошибка [Wed Jan 13 16:13:59 2021] [error] [client 188.243.183.203:10899] PHP Fatal error: Uncaught Twig\\Error\\LoaderError: Template "default/template/common/simple_header.twig" is not defined in "/template/checkout/simplecheckout.twig" at line 4. in /***/public_html/storage/vendor/twig/twig/src/Loader/ArrayLoader.php:70\nStack trace:\n#0 /public_html/storage/vendor/twig/twig/src/Environment.php(299): Twig\\Loader\\ArrayLoader->getCacheKey('default/templat...')\n#1 /***/qadget.ru/public_html/storage/vendor/twig/twig/src/Environment.php(381): Twig\\Environment->getTemplateClass('default/templat...')\n#2 /***/public_html/storage/vendor/twig/twig/src/Template.php(333): Twig\\Environment->loadTemplate('default/templat...', NULL)\n#3 /***/public_html/storage/cache/template/d7/d73b40df9719e9e58f71e77c74abce921974ac8c4fcc0c863edef033ed456a72.php(43): Twig\\Template->loadTemplate('default/templat...', 'eltczones/templ...', 4)\n#4 /home/k/kuripka/qadget.ru/public_html/storage/vendor/twig/twig/src/Template.php(40 in /***/public_html/storage/vendor/twig/twig/src/Loader/ArrayLoader.php on line 70, referer /***/
  17. Здравствуйте, после установки страница корзины и оформления заказа недоступна. Шаблон стандартный. Куда в первую очередь копать?
  18. Здравствуйте, вывожу в функции shipping в файле order.php так: Но при распечатывании списка доставки, поле не выводится. Помогите if ($order_info['shipping_address_format']) { $format = $order_info['shipping_address_format']; } else { $format = '{custom_field_26}'; // кастомное поле с id = 26 } $find = array( '{custom_field_26}', // кастомное поле с id = 26 ); $replace = array( 'custom_field_26' => $order_info['shipping_custom_field']['26'] // кастомное поле с id = 26 );
  19. В телеграмме по нику esculapra нет результатов (
  20. Здравствуйте, как можно загрузить содержимое {{ menu }} (файл menu.twig) только после клика на кнопку?
  21. Такого модуля в интернете не нашел. Модуль дополнительные позиции в макете меня не интересует, так как я вывожу настройки через шаблон, которые отображаются только на главной странице. То есть часть неизменного дизайна сайта будет
  22. Здравствуйте, подскажите или помогите, как можно вывести баннеры из настроек шаблона В админ части, в контроллере я вывожу настройки выбора баннеров таким способом: if (isset($this->request->post['theme_theme_banner_id'])) { $data['theme_theme_banner_id'] = $this->request->post['theme_theme_banner_id']; } elseif (!empty($setting_info)) { $data['theme_theme_banner_id'] = $setting_info['theme_theme_banner_id']; } else { $data['theme_theme_banner_id'] = ''; } if (isset($this->request->post['theme_theme_two_banner_id'])) { $data['theme_theme_two_banner_id'] = $this->request->post['theme_theme_two_banner_id']; } elseif (!empty($setting_info)) { $data['theme_theme_two_banner_id'] = $setting_info['theme_theme_two_banner_id']; } else { $data['theme_theme_two_banner_id'] = ''; } if (isset($this->request->post['theme_theme_logo_sidebar'])) { $data['theme_theme_logo_sidebar'] = $this->request->post['theme_theme_logo_sidebar']; } elseif (!empty($setting_info)) { $data['theme_theme_logo_sidebar'] = $setting_info['theme_theme_logo_sidebar']; } else { $data['theme_theme_logo_sidebar'] = ''; } $this->load->model('design/banner'); $data['theme_theme_banners'] = $this->model_design_banner->getBanners(); В контроллере стандартного модуля, баннеры выводятся так: $this->load->model('design/banner'); $this->load->model('tool/image'); $data['banners'] = array(); $results = $this->model_design_banner->getBanner($setting['banner_id']); foreach ($results as $result) { if (is_file(DIR_IMAGE . $result['image'])) { $data['banners'][] = array( 'title' => $result['title'], 'link' => $result['link'], 'image' => $this->model_tool_image->resize($result['image'], $setting['width'], $setting['height']) ); } } Как я могу вывести баннеры в home, чтобы настройки брались с настроек шаблона?
  23. Здравствуйте, подскажите пожалуйста, вывожу в модуле выпадающим списком баннеры в twig <div class="form-group"> <label class="col-sm-2 control-label" for="input-banner">{{ entry_banner }}</label> <div class="col-sm-10"> <select name="banner_id" id="input-banner" class="form-control"> {% for banner in banners %} {% if banner.banner_id == banner_id %} <option value="{{ banner.banner_id }}" selected="selected">{{ banner.name }}</option> {% else %} <option value="{{ banner.banner_id }}">{{ banner.name }}</option> {% endif %} {% endfor %} </select> </div> </div> в контроллере if (isset($this->request->post['banner_id'])) { $data['banner_id'] = $this->request->post['banner_id']; } elseif (!empty($module_info)) { $data['banner_id'] = $module_info['banner_id']; } else { $data['banner_id'] = ''; } $this->load->model('design/banner'); $data['banners'] = $this->model_design_banner->getBanners(); но при выборе баннера и сохранению модуля, выбранный баннер не сохраняется в настройках, подскажите что я не так делаю?
  24. {% for attribute_group in attribute_groups %} {% for attribute in attribute_group.attribute %} {% if attribute.attribute_id in [1, 2, 3, 4] %} <!-- тут id атрибутов --> <td>{{ attribute.name }}</td><!-- тут название атрибута--> <td>{{ attribute.text }}</td><!-- тут текст/описание атрибута --> {% endif %} {% endfor %} {% endfor %}
  25. Здравствуйте, форумчане. В связи с полным редизайном мобильной версии сайта, переделкой почти всего, что только можно, требуется автоматический переход с основного шаблона на мобильный. Я нашел в интернете вариант с использованием Mobile_Detect.php, но почему то сайта падает на мобильных устройствах в файле system/startup.php добавить require_once(DIR_SYSTEM . 'library/Mobile_Detect.php'); $detect = new Mobile_Detect(); define('isMobile', $detect->isMobile(), false);//Это используем define('isTablet', $detect->isTablet(), false); //Это используем а в индексном файле добавить //Mobile if(isMobile && !isTablet && $_COOKIE['ver'] !== 'full'){ $this->config->set('config_template', 'default_mobile'); }elseif(isMobile && !isTablet && $_COOKIE['ver'] == 'full'){ $this->config->set('config_template', 'default'); } Может такая конструкция не работает на 3 версии опенкарта?

×
×
  • Створити...

Important Information

На нашому сайті використовуються файли cookie і відбувається обробка деяких персональних даних користувачів, щоб поліпшити користувальницький інтерфейс. Щоб дізнатися для чого і які персональні дані ми обробляємо перейдіть за посиланням . Якщо Ви натиснете «Я даю згоду», це означає, що Ви розумієте і приймаєте всі умови, зазначені в цьому Повідомленні про конфіденційність.