function __construct()
 {
     global $osC_Language, $osC_MessageStack;
     $this->_page_title = $osC_Language->get('heading_title');
     if (!isset($_GET['action'])) {
         $_GET['action'] = '';
     }
     if (!isset($_GET['page']) || isset($_GET['page']) && !is_numeric($_GET['page'])) {
         $_GET['page'] = 1;
     }
     if (!empty($_GET['action'])) {
         switch ($_GET['action']) {
             case 'save':
                 if (isset($_GET['osID']) && is_numeric($_GET['osID'])) {
                     $this->_page_contents = 'edit.php';
                 } else {
                     $this->_page_contents = 'new.php';
                 }
                 if (isset($_POST['subaction']) && $_POST['subaction'] == 'confirm') {
                     $data = array('name' => $_POST['name']);
                     if (osC_OrdersStatus_Admin::save(isset($_GET['osID']) ? $_GET['osID'] : null, $data, isset($_POST['default']) && $_POST['default'] == 'on' ? true : false)) {
                         $osC_MessageStack->add($this->_module, $osC_Language->get('ms_success_action_performed'), 'success');
                     } else {
                         $osC_MessageStack->add($this->_module, $osC_Language->get('ms_error_action_not_performed'), 'error');
                     }
                     osc_redirect_admin(osc_href_link_admin(FILENAME_DEFAULT, $this->_module . '&page' . $_GET['page']));
                 }
                 break;
             case 'delete':
                 $this->_page_contents = 'delete.php';
                 if (isset($_POST['subaction']) && $_POST['subaction'] == 'confirm') {
                     if (osC_OrdersStatus_Admin::delete($_GET['osID'])) {
                         $osC_MessageStack->add($this->_module, $osC_Language->get('ms_success_action_performed'), 'success');
                     } else {
                         $osC_MessageStack->add($this->_module, $osC_Language->get('ms_error_action_not_performed'), 'error');
                     }
                     osc_redirect_admin(osc_href_link_admin(FILENAME_DEFAULT, $this->_module . '&page=' . $_GET['page']));
                 }
                 break;
             case 'batchDelete':
                 if (isset($_POST['batch']) && is_array($_POST['batch']) && !empty($_POST['batch'])) {
                     $this->_page_contents = 'batch_delete.php';
                     if (isset($_POST['subaction']) && $_POST['subaction'] == 'confirm') {
                         $error = false;
                         foreach ($_POST['batch'] as $id) {
                             if (!osC_OrdersStatus_Admin::delete($id)) {
                                 $error = true;
                                 break;
                             }
                         }
                         if ($error === false) {
                             $osC_MessageStack->add($this->_module, $osC_Language->get('ms_success_action_performed'), 'success');
                         } else {
                             $osC_MessageStack->add($this->_module, $osC_Language->get('ms_error_action_not_performed'), 'error');
                         }
                         osc_redirect_admin(osc_href_link_admin(FILENAME_DEFAULT, $this->_module . '&page=' . $_GET['page']));
                     }
                 }
                 break;
         }
     }
 }
Beispiel #2
0
 function batchDeleteOrdersStatus()
 {
     global $toC_Json, $osC_Database, $osC_Language;
     $error = false;
     $feedback = array();
     $batch = explode(',', $_REQUEST['batch']);
     foreach ($batch as $id) {
         if ($id == DEFAULT_ORDERS_STATUS_ID) {
             $error = true;
             $feedback[] = $osC_Language->get('batch_delete_error_order_status_prohibited');
         } else {
             $Qorders = $osC_Database->query('select count(*) as total from :table_orders where orders_status = :orders_status');
             $Qorders->bindTable(':table_orders', TABLE_ORDERS);
             $Qorders->bindInt(':orders_status', $id);
             $Qorders->execute();
             if ($Qorders->valueInt('total') > 0) {
                 $error = true;
                 $feedback[] = $osC_Language->get('batch_delete_error_order_status_in_use');
                 break;
             }
             $Qhistory = $osC_Database->query('select count(*) as total from :table_orders_status_history where orders_status_id = :orders_status_id group by orders_id');
             $Qhistory->bindTable(':table_orders_status_history', TABLE_ORDERS_STATUS_HISTORY);
             $Qhistory->bindInt(':orders_status_id', $id);
             $Qhistory->execute();
             if ($Qhistory->valueInt('total') > 0) {
                 $error = true;
                 $feedback[] = $osC_Language->get('batch_delete_error_order_status_used');
                 break;
             }
         }
     }
     if ($error === false) {
         foreach ($batch as $id) {
             if (!osC_OrdersStatus_Admin::delete($id)) {
                 $error = true;
                 break;
             }
         }
         if ($error === false) {
             $response = array('success' => true, 'feedback' => $osC_Language->get('ms_success_action_performed'));
         } else {
             $response = array('success' => false, 'feedback' => $osC_Language->get('ms_error_action_not_performed'));
         }
     } else {
         $response = array('success' => false, 'feedback' => $osC_Language->get('ms_error_action_not_performed') . '<br />' . implode('<br />', $feedback));
     }
     echo $toC_Json->encode($response);
 }