function __construct() { // Модель для работы заказом. $model = new Models_Order(); // Печать заказа в квитанцию. if (isset($_POST['printQittance'])) { $model->printQittance(); } if ($orderId = URL::get('getOrderPdf')) { $model->getPdfOrder($orderId); } // Запрос электронных товаров $fileToOrder = null; if (isset($_REQUEST['getFileToOrder'])) { $electroInfo = $model->getFileToOrder($_REQUEST['getFileToOrder']); $orderInfo = $model->getOrder(' id = ' . DB::quote($_REQUEST['getFileToOrder'])); $orderNumber = $orderInfo[$_REQUEST['getFileToOrder']]['number']; if ($electroInfo === false) { $infoMsg = "Для просмотра страницы необходимо зайти на сайт под пользователем сделавшим заказ №" . $orderNumber; } if (is_array($electroInfo) && empty($electroInfo)) { $infoMsg = "Заказ не содержит электронных товаров или ожидает оплаты!"; } if (is_array($electroInfo) && !empty($electroInfo)) { $infoMsg = "Скачать электронные товары для заказа №" . $orderNumber . ""; } $fileToOrder = array('infoMsg' => $infoMsg, 'electroInfo' => $electroInfo); } // пришел запрос на скачивание электронного товара if (isset($_REQUEST['link'])) { $model->getFileByMd5($_REQUEST['link']); } // Первый экран - Оформление заказа. $step = 1; // Если пришли данные с формы оформления заказа. if (isset($_POST['toOrder'])) { if (empty($_SESSION['cart'])) { MG::redirect('/cart'); } // Если параметры введены корректно, то создается новый заказ. if ($error = $model->isValidData($_POST)) { $msg = $error; } else { // Второй экран - оплата заказа $step = 2; $orderArray = $model->addOrder(); $orderId = $orderArray['id']; $orderNumber = $orderArray['orderNumber']; $summ = $model->summ + $model->delivery_cost; $pay = $model->payment; $paramArray = $model->getParamArray($pay, $orderId, $summ); } } // Обработка действия при переходе по ссылке подтверждения заказа. if ($id = URL::getQueryParametr('id')) { $info = $this->confirmOrder($id); $msg = $info['msg']; $userEmail = $info['userEmail']; // Третий экран - подтверждение заказа по ссылке из письма. $step = 3; } // Обработка действия при переходе по ссылке получения информации о статусе заказа. if (URL::getQueryParametr('hash')) { $hash = URL::getQueryParametr('hash'); // Информация о заказе по переданному id. $orderInfo = $model->getOrder('`' . PREFIX . 'order`.hash = "' . $hash . '"'); $id = key($orderInfo); if ($orderInfo) { if (USER::getUserInfoByEmail($orderInfo[$id]['user_email'])) { $msg = 'Посмотреть статус заказа Вы можете в <a href="' . SITE . '/personal">личном кабинете</a>.'; } else { $lang = MG::get('lang'); $orderNumber = $orderInfo[$id]['number']; $orderId = $id; $status = $model->getOrderStatus($orderInfo[$id]['status_id']); $orderInfo[$id]['string_status_id'] = $lang[$status]; $paymentArray = $model->getPaymentMethod($orderInfo[$id]['payment_id']); $orderInfo[$id]['paymentName'] = $paymentArray['name']; $msg = ''; } } else { $msg = 'Некорректная ссылка.<br> Заказ не найден<br>'; } // пятый экран - инфо о статусе заказа $step = 5; } // Запрос оплаты из ЛК. if (URL::getQueryParametr('pay')) { // Четвертый экран - Запрос оплаты из ЛК. $step = 4; $pay = URL::getQueryParametr('paymentId'); $orderId = URL::getQueryParametr('orderID'); $order = $model->getOrder(' id = ' . DB::quote($orderId, true)); $summ = URL::getQueryParametr('orderSumm'); $summ = $order[$orderId]['summ'] * 1 + $order[$orderId]['delivery_cost'] * 1; $paramArray = $model->getParamArray($pay, $orderId, $summ); } // Если пользователь авторизован, то заполняем форму личными даными. if (User::isAuth()) { $userInfo = User::getThis(); $_POST['email'] = $_POST['email'] ? $_POST['email'] : $userInfo->email; $_POST['phone'] = $_POST['phone'] ? $_POST['phone'] : $userInfo->phone; $_POST['fio'] = $_POST['fio'] ? $_POST['fio'] : $userInfo->name . ' ' . $userInfo->sname; $_POST['address'] = $_POST['address'] ? $_POST['address'] : $userInfo->address; if ($userInfo->inn) { $_POST['customer'] = 'yur'; } $_POST['yur_info']['adress'] = $userInfo->adress; $_POST['yur_info']['inn'] = $userInfo->inn; $_POST['yur_info']['kpp'] = $userInfo->kpp; $_POST['yur_info']['bank'] = $userInfo->bank; $_POST['yur_info']['bik'] = $userInfo->bik; $_POST['yur_info']['ks'] = $userInfo->ks; $_POST['yur_info']['rs'] = $userInfo->rs; } // Обработка ajax запроса из шаблона. if ('getPaymentByDeliveryId' == URL::getQueryParametr('action')) { $this->getPaymentByDeliveryId(); } // Обработка ajax запроса из шаблона. if ('getEssentialElements' == URL::getQueryParametr('action')) { $this->getEssentialElements(); } $this->includeIconsPack(); // Массив способов доставки. $deliveryArray = $this->getDelivery(); // Массив способов оплаты. $deliveryCount = count($deliveryArray); // если из доступных способов доставки - только один, то сразу находим для него способы оплаты if ($deliveryCount === 1) { $keyDev = array_keys($deliveryArray); $_POST['delivery'] = $deliveryArray[$keyDev[0]]['id']; } $paymentTable = $this->getPaymentByDeliveryId($_POST['delivery'], $_POST['customer'], true, $deliveryCount); // если доставка не предусмотрена, то выводим все доступные активные метода оплаты if ($deliveryCount === 0) { $paymentTable = ''; foreach ($this->getPayment() as $payment) { $delivArray = json_decode($payment['deliveryMethod'], true); if ($_POST['customer'] == "yur" && $payment['id'] != "7") { continue; } $paymentTable .= ' <li class="noneactive"> <label> <input type="radio" name="payment" rel value=' . $payment['id'] . '>' . $payment['name'] . '</label> <span class="icon-payment-' . $payment['id'] . '"></span> </li>'; } } $cart = new Models_Cart(); $summOrder = $cart->getTotalSumm(); $summOrder = MG::numberFormat($summOrder); if ($step != 5) { $orderInfo = $model->getOrder('`' . PREFIX . 'order`.id = "' . $orderId . '"'); } $userInfo = USER::getUserInfoByEmail($orderInfo[$orderId]['user_email']); $settings = MG::get('settings'); $orderNumber = $orderInfo[$orderId]['number'] != '' ? $orderInfo[$orderId]['number'] : $orderId; $linkToStatus = $orderInfo[$orderId]['hash'] ? $orderInfo[$orderId]['hash'] : ''; // Массив параметров для отображения в представлении. $this->data = array('active' => !empty($userEmail) ? $userEmail : '', 'msg' => !empty($msg) ? $msg : '', 'step' => !empty($step) ? $step : '', 'delivery' => !empty($deliveryArray) ? $deliveryArray : '', 'paymentArray' => !empty($paymentTable) ? $paymentTable : '', 'paramArray' => !empty($paramArray) ? $paramArray : '', 'id' => !empty($orderId) ? $orderId : '', 'orderNumber' => !empty($orderNumber) ? $orderNumber : $orderId, 'summ' => !empty($summ) ? $summ : '', 'pay' => !empty($pay) ? $pay : '', 'payMentView' => $this->getPaymentView($pay), 'currency' => $settings['currency'], 'userInfo' => $userInfo, 'orderInfo' => $orderInfo, 'fileToOrder' => $fileToOrder, 'meta_title' => 'Оформление заказа', 'meta_keywords' => !empty($model->currentCategory['meta_keywords']) ? $model->currentCategory['meta_keywords'] : "заказы,заявки,оформить,оформление заказа", 'meta_desc' => !empty($model->currentCategory['meta_desc']) ? $model->currentCategory['meta_desc'] : "Оформление заказа происходит в несколько этапов. 1 - ввод личных данных покупателя, 2 - оплата заказа.", 'summOrder' => !empty($summOrder) ? $summOrder . ' ' . MG::getSetting('currency') : '', 'captcha' => CAPTCHA_ORDER == '1' ? true : false, 'linkToStatus' => $linkToStatus); }
function __construct() { $lang = MG::get('lang'); $settings = MG::get('settings'); $this->lang = $lang; $status = 0; if (User::isAuth()) { $order = new Models_Order(); $status = 3; //обработка запроса на изменение данных пользователя if (URL::getQueryParametr('userData')) { $customer = URL::getQueryParametr('customer'); $userData = array('name' => URL::getQueryParametr('name'), 'sname' => URL::getQueryParametr('sname'), 'address' => URL::getQueryParametr('address'), 'phone' => URL::getQueryParametr('phone'), 'nameyur' => $customer == 'yur' ? URL::getQueryParametr('nameyur') : '', 'adress' => $customer == 'yur' ? URL::getQueryParametr('adress') : '', 'inn' => $customer == 'yur' ? URL::getQueryParametr('inn') : '', 'kpp' => $customer == 'yur' ? URL::getQueryParametr('kpp') : '', 'bank' => $customer == 'yur' ? URL::getQueryParametr('bank') : '', 'bik' => $customer == 'yur' ? URL::getQueryParametr('bik') : '', 'ks' => $customer == 'yur' ? URL::getQueryParametr('ks') : '', 'rs' => $customer == 'yur' ? URL::getQueryParametr('rs') : ''); if (USER::update(User::getThis()->id, $userData)) { $message = 'Данные успешно сохранены'; } else { $error = 'Не удалось сохранить данные ' . $this->_newUserData['sname']; } } // Обработка запроса на изменения пароля. if (URL::getQueryParametr('chengePass')) { if (USER::auth(User::getThis()->email, URL::getQueryParametr('pass'))) { $person = new Models_Personal(); $message = $person->changePass(URL::getQueryParametr('newPass'), User::getThis()->id); } else { $error = 'Неверный пароль'; } } // Обработка запроса на изменения способа оплаты. if (URL::getQueryParametr('changePaymentId')) { $order = new Models_Order(); $status = $order->updateOrder(array('payment_id' => $_POST['changePaymentId'], 'id' => $_POST['orderId'])); $result = array('status' => $status, 'comment' => 2, 'orderStatus' => 3); echo json_encode($result); MG::disableTemplate(); exit; } // Обработка AJAX запроса на закрытие заказа. if (URL::getQueryParametr('delOK')) { $comment = 'Отменено покупателем, по причине <br>"' . URL::getQueryParametr('comment') . '"'; // Пересчитываем остатки продуктов из заказа. $orderModel = new Models_Order(); $orderModel->refreshCountProducts(URL::getQueryParametr('delID'), 4); $res = DB::query(' UPDATE `' . PREFIX . 'order` SET close_date = now(), status_id = 4, comment = "%s" WHERE id = %d AND user_email = "%s"', $comment, URL::getQueryParametr('delID'), User::getThis()->email); if ($res) { $status = true; } if ($comment) { $comm = "<b>Комментарий: " . $comment . "</b>"; } $result = array('status' => $status, 'comment' => $comm, 'orderStatus' => $lang[$order->getOrderStatus(array('status_id' => 4))]); $orderModel->sendMailOfUpdateOrder(URL::getQueryParametr('delID')); echo json_encode($result); MG::disableTemplate(); exit; } // Отображение данных пользователя. $orderArray = $order->getOrder('user_email = "' . User::getThis()->email . '"', TRUE); if (is_array($orderArray)) { foreach ($orderArray as $orderId => $orderItems) { $orderArray[$orderId]['string_status_id'] = $order->getOrderStatus($orderItems); $paymentArray = $order->getPaymentMethod($orderItems['payment_id']); $orderArray[$orderId]['name'] = $paymentArray['name']; $orderArray[$orderId]['paided'] = $order->getPaidedStatus($orderItems); } } if (!User::getThis()->activity) { $status = 2; unset($_SESSION['user']); } if (User::getThis()->blocked) { $status = 1; unset($_SESSION['user']); } $paymentList = $order->getPaymentBlocksMethod(); } else { MG::redirect('/enter'); } $this->data = array('error' => !empty($error) ? $error : '', 'message' => !empty($message) ? $message : '', 'status' => !empty($status) ? $status : '', 'userInfo' => User::getThis(), 'orderInfo' => !empty($orderArray) ? $orderArray : '', 'currency' => $settings['currency'], 'paymentList' => $paymentList, 'meta_title' => 'Личный кабинет', 'meta_keywords' => !empty($model->currentCategory['meta_keywords']) ? $model->currentCategory['meta_keywords'] : "заказы,личные данные, личный кабинет", 'meta_desc' => !empty($model->currentCategory['meta_desc']) ? $model->currentCategory['meta_desc'] : "В личном кабинете нашего сайта вы сможете отслеживать состояние заказов и менять свои данные"); }
/** * Получает параметры заказа */ public function getOrderData() { $model = new Models_Order(); $orderData = $model->getOrder(" id = " . DB::quote($_POST['id'])); $orderData = $orderData[$_POST['id']]; if ($orderData['number'] == '') { $orderData['number'] = $orderData['id']; DB::query("UPDATE `" . PREFIX . "order` SET `number`= " . DB::quote($orderData['number']) . " WHERE `id`=" . DB::quote($orderData['id']) . ""); } $orderData['yur_info'] = unserialize(stripslashes($orderData['yur_info'])); $orderData['order_content'] = unserialize(stripslashes($orderData['order_content'])); // Запрос для проверки, существует ли система скидок $percent = false; $discountSyst = false; $res = DB::query('SELECT * FROM `' . PREFIX . 'plugins` WHERE `folderName` = "discount-system"'); $act = DB::fetchArray($res); $result = DB::query('SHOW TABLES LIKE "' . PREFIX . 'discount-system%"'); if (DB::numRows($result) == 2 && $act['active']) { $percent = 0; $discountSyst = true; } if (!empty($orderData['order_content'])) { $product = new Models_Product(); foreach ($orderData['order_content'] as &$item) { foreach ($item as &$v) { $v = rawurldecode($v); } } foreach ($orderData['order_content'] as &$items) { $res = $product->getProduct($items['id']); $items['image_url'] = $res['image_url']; $items['property'] = htmlspecialchars_decode(str_replace('&', '&', $items['property'])); $response['discount'] = $items['discount']; $percent = $items['discount']; $items['maxCount'] = $res['count']; $variants = DB::query("SELECT `id`, `count` FROM `" . PREFIX . "product_variant`\n WHERE `product_id`=" . DB::quote($items['id']) . " AND `code`=" . DB::quote($items['code'])); if ($variant = DB::fetchAssoc($variants)) { $items['variant'] = $variant['id']; $items['maxCount'] = $variant['count']; } } } //заменить на получение скидки $codes = array(); // Запрос для проверки , существуют ли промокоды. $result = DB::query('SHOW TABLES LIKE "' . PREFIX . 'promo-code"'); if (DB::numRows($result)) { $res = DB::query('SELECT * FROM `' . PREFIX . 'plugins` WHERE `folderName` = "promo-code"'); $act = DB::fetchArray($res); if ($act['active']) { $res = DB::query('SELECT code, percent FROM `' . PREFIX . 'promo-code` WHERE invisible = 1 AND now() >= `from_datetime` AND now() <= `to_datetime`'); while ($code = DB::fetchAssoc($res)) { $codes[] = $code['code']; if ($code['code'] == $orderData['order_content'][0]['coupon']) { $percent = $percent == 0 ? $code['percent'] : $percent; } } } } $response['order'] = $orderData; $response['order']['discountsSystem'] = $discountSyst; $response['order']['discontPercent'] = $percent; $response['order']['promoCodes'] = $codes; $response['order']['date_delivery'] = $orderData['date_delivery'] ? date('d.m.Y', strtotime($orderData['date_delivery'])) : ''; $deliveryArray = $model->getDeliveryMethod(); $response['deliveryArray'] = $deliveryArray; $paymentArray = array(); $i = 1; while ($payment = $model->getPaymentMethod($i)) { $paymentArray[$i] = $payment; $i++; } $response['paymentArray'] = $paymentArray; $this->data = $response; return true; }
$schemes[] = $color; } } } } $templates[] = array('foldername' => $foldername, 'colorScheme' => $schemes, 'colorSchemeActive' => $colorSchemeActive); } } } $licenceKey = MG::getOption('licenceKey', true); $mOrder = new Models_Order(); $deliveryArray = $mOrder->getDeliveryMethod(); //массив способов оплаты $paymentArray = array(); $i = 1; while ($payment = $mOrder->getPaymentMethod($i)) { $paymentArray[$i] = $payment; $i++; } $paymentArray = array_reverse($paymentArray); usort($paymentArray, array("Models_Order", "sort")); $res = DB::query("\r\n SELECT *\r\n FROM `" . PREFIX . "setting`\r\n WHERE `active` = 'Y'\r\n "); while ($option = DB::fetchAssoc($res)) { $options[$option['option']] = $option; } $allGroupsOptions = array('smtpHost', 'smtpLogin', 'smtpPass', 'smtpPort'); $groups = array('STNG_GROUP_1' => array('sitename', 'adminEmail', 'noReplyEmail', 'templateName', 'currencyShopIso', 'priceFormat', 'phoneMask', 'widgetCode'), 'STNG_GROUP_2' => array('horizontMenu', 'actionInCatalog', 'printRemInfo', 'printProdNullRem', 'printStrProp', 'printCompareButton', 'compareCategory', 'useCaptcha', 'autoRegister', 'printFilterResult', 'lockAuthorization', 'orderNumber', 'popupCart', 'catalogIndex', 'productInSubcat', 'copyrightMoguta', 'picturesCategory', 'requiredFields'), 'STNG_GROUP_3' => array('mainPageIsCatalog', 'countСatalogProduct', 'countNewProduct', 'countRecomProduct', 'countSaleProduct', 'randomProdBlock', 'buttonBuyName', 'buttonMoreName', 'buttonCompareName'), 'STNG_GROUP_4' => array('heightPreview', 'widthPreview', 'heightSmallPreview', 'widthSmallPreview', 'waterMark', 'waterMarkVariants'), 'STNG_GROUP_5' => array('smtp', 'smtpHost', 'smtpLogin', 'smtpPass', 'smtpPort'), 'STNG_GROUP_6' => array('shopName', 'shopPhone', 'shopAddress', 'shopLogo', 'backgroundSite'), 'STNG_GROUP_7' => array('cacheObject', 'cacheMode', 'cacheTime', 'cacheHost', 'cachePort', 'cacheCssJs')); foreach (MG::getSetting('currencyRate') as $key => $val) { $currencySettings[$key]['rate'] = $val; } foreach (MG::getSetting('currencyShort') as $key => $val) {