332 lines
		
	
	
		
			15 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
			
		
		
	
	
			332 lines
		
	
	
		
			15 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
| <?php
 | |
| /* ----------------------------------------------------------------------
 | |
| 
 | |
|    MyOOS [Shopsystem]
 | |
|    https://www.oos-shop.de
 | |
| 
 | |
|    Copyright (c) 2003 - 2019 by the MyOOS Development Team.
 | |
|    ----------------------------------------------------------------------
 | |
|    Based on:
 | |
| 
 | |
|    File: tax_rates.php,v 1.27 2002/06/07 01:17:46 hpdl 
 | |
|    ----------------------------------------------------------------------
 | |
|    osCommerce, Open Source E-Commerce Solutions
 | |
|    http://www.oscommerce.com
 | |
| 
 | |
|    Copyright (c) 2003 osCommerce
 | |
|    ----------------------------------------------------------------------
 | |
|    Released under the GNU General Public License
 | |
|    ---------------------------------------------------------------------- */
 | |
| 
 | |
| define('OOS_VALID_MOD', 'yes');
 | |
| require 'includes/main.php';
 | |
| 
 | |
|  /**
 | |
|   * Output a form pull down menu with tax classes
 | |
|   *
 | |
|   * @param $parameters
 | |
|   * @param $selected
 | |
|   * @return string
 | |
|   */
 | |
|   function oosTaxClassesPullDown($parameters, $selected = '') {
 | |
| 
 | |
|     $select_string = '<select ' . $parameters . '>';
 | |
| 
 | |
|     // Get database information
 | |
|     $dbconn =& oosDBGetConn();
 | |
|     $oostable =& oosDBGetTables();
 | |
| 
 | |
|     $tax_classtable = $oostable['tax_class'];
 | |
|     $classes_sql = "SELECT tax_class_id, tax_class_title
 | |
|                     FROM $tax_classtable
 | |
|                     ORDER BY tax_class_title";
 | |
|     $result = $dbconn->Execute($classes_sql);
 | |
|     while ($classes = $result->fields) {
 | |
|       $select_string .= '<option value="' . $classes['tax_class_id'] . '"';
 | |
|       if ($selected == $classes['tax_class_id']) $select_string .= ' selected="selected"';
 | |
|       $select_string .= '>' . $classes['tax_class_title'] . '</option>';
 | |
| 
 | |
|       // Move that ADOdb pointer!
 | |
|       $result->MoveNext();
 | |
|     }
 | |
| 
 | |
|     $select_string .= '</select>';
 | |
| 
 | |
|     return $select_string;
 | |
|   }
 | |
| 
 | |
| 
 | |
|  /**
 | |
|   * Output a form pull down menu with geo zones
 | |
|   *
 | |
|   * @param $parameters
 | |
|   * @param $selected
 | |
|   * @return string
 | |
|   */ 
 | |
|   function oosGeoZonesPullDown($parameters, $selected = '') {
 | |
| 
 | |
|     $select_string = '<select ' . $parameters . '>';
 | |
| 
 | |
|     // Get database information
 | |
|     $dbconn =& oosDBGetConn();
 | |
|     $oostable =& oosDBGetTables();
 | |
| 
 | |
|     $geo_zonestable = $oostable['geo_zones'];
 | |
|     $zones_sql = "SELECT geo_zone_id, geo_zone_name
 | |
|                   FROM $geo_zonestable
 | |
|                   ORDER BY geo_zone_name";
 | |
|     $result = $dbconn->Execute($zones_sql);
 | |
|     while ($zones = $result->fields) {
 | |
|       $select_string .= '<option value="' . $zones['geo_zone_id'] . '"';
 | |
|       if ($selected == $zones['geo_zone_id']) $select_string .= ' selected="selected"';
 | |
|       $select_string .= '>' . $zones['geo_zone_name'] . '</option>';
 | |
| 
 | |
|       // Move that ADOdb pointer!
 | |
|       $result->MoveNext();
 | |
|     }
 | |
| 
 | |
|     $select_string .= '</select>';
 | |
| 
 | |
|     return $select_string;
 | |
|   }
 | |
| 
 | |
| $nPage = (!isset($_GET['page']) || !is_numeric($_GET['page'])) ? 1 : intval($_GET['page']); 
 | |
| $action = (isset($_GET['action']) ? $_GET['action'] : '');
 | |
| 
 | |
| if (!empty($action)) {
 | |
|     switch ($action) {
 | |
|       case 'insert':
 | |
|         $tax_zone_id = oos_db_prepare_input($_POST['tax_zone_id']);
 | |
|         $tax_class_id = oos_db_prepare_input($_POST['tax_class_id']);
 | |
|         $tax_rate = oos_db_prepare_input($_POST['tax_rate']);
 | |
|         $tax_description = oos_db_prepare_input($_POST['tax_description']);
 | |
|         $tax_priority = oos_db_prepare_input($_POST['tax_priority']);	  
 | |
|  
 | |
|         $tax_ratestable = $oostable['tax_rates'];
 | |
|         $dbconn->Execute("INSERT INTO $tax_ratestable (tax_zone_id, tax_class_id, tax_rate, tax_description, tax_priority, date_added) VALUES ('" . oos_db_input($tax_zone_id) . "', '" . oos_db_input($tax_class_id) . "', '" . oos_db_input($tax_rate) . "', '" . oos_db_input($tax_description) . "', '" . oos_db_input($tax_priority) . "', now())");
 | |
| 
 | |
|         oos_redirect_admin(oos_href_link_admin($aContents['tax_rates']));
 | |
|         break;
 | |
| 
 | |
|       case 'save':
 | |
|         $tax_rates_id = oos_db_prepare_input($_GET['tID']);
 | |
| 
 | |
|         $tax_zone_id = oos_db_prepare_input($_POST['tax_zone_id']);
 | |
|         $tax_class_id = oos_db_prepare_input($_POST['tax_class_id']);
 | |
|         $tax_rate = oos_db_prepare_input($_POST['tax_rate']);
 | |
|         $tax_description = oos_db_prepare_input($_POST['tax_description']);
 | |
|         $tax_priority = oos_db_prepare_input($_POST['tax_priority']);	 
 | |
| 
 | |
|         $tax_ratestable = $oostable['tax_rates'];
 | |
|         $dbconn->Execute("UPDATE $tax_ratestable SET tax_rates_id = '" . oos_db_input($tax_rates_id) . "', tax_zone_id = '" . oos_db_input($tax_zone_id) . "', tax_class_id = '" . oos_db_input($tax_class_id) . "', tax_rate = '" . oos_db_input($tax_rate) . "', tax_description = '" . oos_db_input($tax_description) . "', tax_priority = '" . oos_db_input($tax_priority) . "', last_modified = now() WHERE tax_rates_id = '" . oos_db_input($tax_rates_id) . "'");
 | |
|         oos_redirect_admin(oos_href_link_admin($aContents['tax_rates'], 'page=' . $nPage . '&tID=' . $tax_rates_id));
 | |
|         break;
 | |
| 
 | |
|       case 'deleteconfirm':
 | |
|         $tax_rates_id = oos_db_prepare_input($_GET['tID']);
 | |
| 
 | |
|         $tax_ratestable = $oostable['tax_rates'];
 | |
|         $dbconn->Execute("DELETE FROM $tax_ratestable WHERE tax_rates_id = '" . oos_db_input($tax_rates_id) . "'");
 | |
|         oos_redirect_admin(oos_href_link_admin($aContents['tax_rates'], 'page=' . $nPage));
 | |
|         break;
 | |
|     }
 | |
|   }
 | |
|   require 'includes/header.php'; 
 | |
| ?>
 | |
| <div class="wrapper">
 | |
| 	<!-- Header //-->
 | |
| 	<header class="topnavbar-wrapper">
 | |
| 		<!-- Top Navbar //-->
 | |
| 		<?php require 'includes/menue.php'; ?>
 | |
| 	</header>
 | |
| 	<!-- END Header //-->
 | |
| 	<aside class="aside">
 | |
| 		<!-- Sidebar //-->
 | |
| 		<div class="aside-inner">
 | |
| 			<?php require 'includes/blocks.php'; ?>
 | |
| 		</div>
 | |
| 		<!-- END Sidebar (left) //-->
 | |
| 	</aside>
 | |
| 	
 | |
| 	<!-- Main section //-->
 | |
| 	<section>
 | |
| 		<!-- Page content //-->
 | |
| 		<div class="content-wrapper">
 | |
| 						
 | |
| 			<!-- Breadcrumbs //-->
 | |
| 			<div class="content-heading">
 | |
| 				<div class="col-lg-12">
 | |
| 					<h2><?php echo HEADING_TITLE; ?></h2>
 | |
| 					<ol class="breadcrumb">
 | |
| 						<li class="breadcrumb-item">
 | |
| 							<?php echo '<a href="' . oos_href_link_admin($aContents['default']) . '">' . HEADER_TITLE_TOP . '</a>'; ?>
 | |
| 						</li>
 | |
| 						<li class="breadcrumb-item">
 | |
| 							<?php echo '<a href="' . oos_href_link_admin($aContents['countries'], 'selected_box=taxes') . '">' . BOX_HEADING_LOCATION_AND_TAXES . '</a>'; ?>
 | |
| 						</li>
 | |
| 						<li class="breadcrumb-item active">
 | |
| 							<strong><?php echo HEADING_TITLE; ?></strong>
 | |
| 						</li>
 | |
| 					</ol>
 | |
| 				</div>
 | |
| 			</div>
 | |
| 			<!-- END Breadcrumbs //-->
 | |
| 			
 | |
| 			<div class="wrapper wrapper-content">
 | |
| 				<div class="row">
 | |
| 					<div class="col-lg-12">					
 | |
| <!-- body_text //-->
 | |
| 	<div class="table-responsive">
 | |
| 		<table class="table w-100">
 | |
|           <tr>
 | |
|             <td valign="top">
 | |
| 			
 | |
| 				<table class="table table-striped table-hover w-100">
 | |
| 					<thead class="thead-dark">
 | |
| 						<tr>
 | |
| 							<th><?php echo TABLE_HEADING_TAX_RATE_PRIORITY; ?></th>
 | |
| 							<th><?php echo TABLE_HEADING_TAX_CLASS_TITLE; ?></th>
 | |
| 							<th><?php echo TABLE_HEADING_ZONE; ?></th>
 | |
| 							<th><?php echo TABLE_HEADING_TAX_RATE; ?></th>
 | |
| 							<th class="text-right"><?php echo TABLE_HEADING_ACTION; ?> </th>
 | |
| 						</tr>	
 | |
| 					</thead>	
 | |
| <?php
 | |
|   $tax_classtable = $oostable['tax_class'];
 | |
|   $tax_ratestable = $oostable['tax_rates'];
 | |
|   $geo_zonestable = $oostable['geo_zones'];
 | |
|   $rates_result_raw = "SELECT r.tax_rates_id, z.geo_zone_id, z.geo_zone_name, tc.tax_class_title, tc.tax_class_id,
 | |
|                               r.tax_priority, r.tax_rate, r.tax_description, r.date_added, r.last_modified
 | |
|                       FROM $tax_classtable tc,
 | |
|                            $tax_ratestable r LEFT JOIN
 | |
|                            $geo_zonestable z
 | |
|                        ON r.tax_zone_id = z.geo_zone_id
 | |
|                       WHERE r.tax_class_id = tc.tax_class_id";
 | |
|   $rates_split = new splitPageResults($nPage, MAX_DISPLAY_SEARCH_RESULTS, $rates_result_raw, $rates_result_numrows);
 | |
|   $rates_result = $dbconn->Execute($rates_result_raw);
 | |
|   while ($rates = $rates_result->fields) {
 | |
|     if ((!isset($_GET['tID']) || (isset($_GET['tID']) && ($_GET['tID'] == $rates['tax_rates_id']))) && !isset($trInfo) && (substr($action, 0, 3) != 'new')) {
 | |
|       $trInfo = new objectInfo($rates);
 | |
|     }
 | |
| 
 | |
|     if (isset($trInfo) && is_object($trInfo) && ($rates['tax_rates_id'] == $trInfo->tax_rates_id) ) {
 | |
|       echo '              <tr onclick="document.location.href=\'' . oos_href_link_admin($aContents['tax_rates'], 'page=' . $nPage . '&tID=' . $trInfo->tax_rates_id . '&action=edit') . '\'">' . "\n";
 | |
|     } else {
 | |
|       echo '              <tr onclick="document.location.href=\'' . oos_href_link_admin($aContents['tax_rates'], 'page=' . $nPage . '&tID=' . $rates['tax_rates_id']) . '\'">' . "\n";
 | |
|     }
 | |
| ?>
 | |
|                 <td><?php echo $rates['tax_priority']; ?></td>
 | |
|                 <td><?php echo $rates['tax_class_title']; ?></td>
 | |
|                 <td><?php echo $rates['geo_zone_name']; ?></td>
 | |
|                 <td><?php echo oos_display_tax_value($rates['tax_rate']); ?>%</td>
 | |
|                 <td class="text-right"><?php if (isset($trInfo) && is_object($trInfo) && ($rates['tax_rates_id'] == $trInfo->tax_rates_id) ) { echo '<button class="btn btn-info" type="button"><i class="fa fa-check"></i></button>'; } else { echo '<a href="' . oos_href_link_admin($aContents['tax_rates'], 'page=' . $nPage . '&tID=' . $rates['tax_rates_id']) . '"><button class="btn btn-default" type="button"><i class="fa fa-eye-slash"></i></button></a>'; } ?> </td>
 | |
|               </tr>
 | |
| <?php
 | |
|     // Move that ADOdb pointer!
 | |
|     $rates_result->MoveNext();
 | |
|   }
 | |
| ?>
 | |
|               <tr>
 | |
|                 <td colspan="5"><table border="0" width="100%" cellspacing="0" cellpadding="2">
 | |
|                   <tr>
 | |
|                     <td class="smallText" valign="top"><?php echo $rates_split->display_count($rates_result_numrows, MAX_DISPLAY_SEARCH_RESULTS, $nPage, TEXT_DISPLAY_NUMBER_OF_TAX_RATES); ?></td>
 | |
|                     <td class="smallText" align="right"><?php echo $rates_split->display_links($rates_result_numrows, MAX_DISPLAY_SEARCH_RESULTS, MAX_DISPLAY_PAGE_LINKS, $nPage); ?></td>
 | |
|                   </tr>
 | |
| <?php
 | |
|   if (empty($action)) {
 | |
| ?>
 | |
|                   <tr>
 | |
|                     <td colspan="5" align="right"><?php echo '<a href="' . oos_href_link_admin($aContents['tax_rates'], 'page=' . $nPage . '&action=new') . '">' . oos_button(IMAGE_NEW_TAX_RATE) . '</a>'; ?></td>
 | |
|                   </tr>
 | |
| <?php
 | |
|   }
 | |
| ?>
 | |
|                 </table></td>
 | |
|               </tr>
 | |
|             </table></td>
 | |
| <?php
 | |
|   $heading = array();
 | |
|   $contents = array();
 | |
| 
 | |
|   switch ($action) {
 | |
|     case 'new':
 | |
|       $heading[] = array('text' => '<b>' . TEXT_INFO_HEADING_NEW_TAX_RATE . '</b>');
 | |
| 
 | |
|       $contents = array('form' => oos_draw_form('id', 'rates', $aContents['tax_rates'], 'page=' . $nPage . '&action=insert', 'post',  FALSE));
 | |
|       $contents[] = array('text' => TEXT_INFO_INSERT_INTRO);
 | |
|       $contents[] = array('text' => '<br />' . TEXT_INFO_CLASS_TITLE . '<br />' . oosTaxClassesPullDown('name="tax_class_id" style="font-size:10px"'));
 | |
|       $contents[] = array('text' => '<br />' . TEXT_INFO_ZONE_NAME . '<br />' . oosGeoZonesPullDown('name="tax_zone_id" style="font-size:10px"'));
 | |
|       $contents[] = array('text' => '<br />' . TEXT_INFO_TAX_RATE . '<br />' . oos_draw_input_field('tax_rate'));
 | |
|       $contents[] = array('text' => '<br />' . TEXT_INFO_RATE_DESCRIPTION . '<br />' . oos_draw_input_field('tax_description'));
 | |
|       $contents[] = array('text' => '<br />' . TEXT_INFO_TAX_RATE_PRIORITY . '<br />' . oos_draw_input_field('tax_priority', $trInfo->tax_priority));	  
 | |
|       $contents[] = array('align' => 'center', 'text' => '<br />' . oos_submit_button(BUTTON_INSERT) . ' <a class="btn btn-sm btn-primary mb-20" href="' . oos_href_link_admin($aContents['tax_rates'], 'page=' . $nPage) . '" role="button"><strong>' . BUTTON_CANCEL . '</strong></a>');
 | |
|       break;
 | |
| 
 | |
|     case 'edit':
 | |
|       $heading[] = array('text' => '<b>' . TEXT_INFO_HEADING_EDIT_TAX_RATE . '</b>');
 | |
| 
 | |
|       $contents = array('form' => oos_draw_form('id', 'rates', $aContents['tax_rates'], 'page=' . $nPage . '&tID=' . $trInfo->tax_rates_id  . '&action=save', 'post', FALSE));
 | |
|       $contents[] = array('text' => TEXT_INFO_EDIT_INTRO);
 | |
|       $contents[] = array('text' => '<br />' . TEXT_INFO_CLASS_TITLE . '<br />' . oosTaxClassesPullDown('name="tax_class_id" style="font-size:10px"', $trInfo->tax_class_id));
 | |
|       $contents[] = array('text' => '<br />' . TEXT_INFO_ZONE_NAME . '<br />' . oosGeoZonesPullDown('name="tax_zone_id" style="font-size:10px"', $trInfo->geo_zone_id));
 | |
|       $contents[] = array('text' => '<br />' . TEXT_INFO_TAX_RATE . '<br />' . oos_draw_input_field('tax_rate', $trInfo->tax_rate));
 | |
|       $contents[] = array('text' => '<br />' . TEXT_INFO_RATE_DESCRIPTION . '<br />' . oos_draw_input_field('tax_description', $trInfo->tax_description));
 | |
|       $contents[] = array('text' => '<br />' . TEXT_INFO_TAX_RATE_PRIORITY . '<br />' . oos_draw_input_field('tax_priority', $trInfo->tax_priority));
 | |
|       $contents[] = array('align' => 'center', 'text' => '<br />' . oos_submit_button(IMAGE_UPDATE) . ' <a class="btn btn-sm btn-primary mb-20" href="' . oos_href_link_admin($aContents['tax_rates'], 'page=' . $nPage . '&tID=' . $trInfo->tax_rates_id) . '" role="button"><strong>' . BUTTON_CANCEL . '</strong></a>');
 | |
|       break;
 | |
| 
 | |
|     case 'delete':
 | |
|       $heading[] = array('text' => '<b>' . TEXT_INFO_HEADING_DELETE_TAX_RATE . '</b>');
 | |
| 
 | |
|       $contents = array('form' => oos_draw_form('id', 'rates', $aContents['tax_rates'], 'page=' . $nPage . '&tID=' . $trInfo->tax_rates_id  . '&action=deleteconfirm', 'post', FALSE));
 | |
|       $contents[] = array('text' => TEXT_INFO_DELETE_INTRO);
 | |
|       $contents[] = array('text' => '<br /><b>' . $trInfo->tax_class_title . ' ' . number_format($trInfo->tax_rate, TAX_DECIMAL_PLACES) . '%</b>');
 | |
|       $contents[] = array('align' => 'center', 'text' => '<br />' . oos_submit_button(BUTTON_DELETE) . ' <a class="btn btn-sm btn-primary mb-20" href="' . oos_href_link_admin($aContents['tax_rates'], 'page=' . $nPage . '&tID=' . $trInfo->tax_rates_id) . '" role="button"><strong>' . BUTTON_CANCEL . '</strong></a>');
 | |
|       break;
 | |
| 
 | |
|     default:
 | |
|       if (isset($trInfo) && is_object($trInfo)) {
 | |
|         $heading[] = array('text' => '<b>' . $trInfo->tax_class_title . '</b>');
 | |
|         $contents[] = array('align' => 'center', 'text' => '<a href="' . oos_href_link_admin($aContents['tax_rates'], 'page=' . $nPage . '&tID=' . $trInfo->tax_rates_id . '&action=edit') . '">' . oos_button(BUTTON_EDIT) . '</a> <a href="' . oos_href_link_admin($aContents['tax_rates'], 'page=' . $nPage . '&tID=' . $trInfo->tax_rates_id . '&action=delete') . '">' . oos_button(BUTTON_DELETE) . '</a>');
 | |
|         $contents[] = array('text' => '<br />' . TEXT_INFO_DATE_ADDED . ' ' . oos_date_short($trInfo->date_added));
 | |
|         $contents[] = array('text' => '' . TEXT_INFO_LAST_MODIFIED . ' ' . oos_date_short($trInfo->last_modified));
 | |
|         $contents[] = array('text' => '<br />' . TEXT_INFO_RATE_DESCRIPTION . '<br />' . $trInfo->tax_description);
 | |
|       }
 | |
|       break;
 | |
|   }
 | |
| 
 | |
|     if ( (oos_is_not_null($heading)) && (oos_is_not_null($contents)) ) {
 | |
| ?>
 | |
| 	<td class="w-25">
 | |
| 		<table class="table table-striped">
 | |
| <?php
 | |
| 		$box = new box;
 | |
| 		echo $box->infoBox($heading, $contents);  
 | |
| ?>
 | |
| 		</table> 
 | |
| 	</td> 
 | |
| <?php
 | |
|   }
 | |
| ?>
 | |
|           </tr>
 | |
|         </table>
 | |
| 	</div>
 | |
| <!-- body_text_eof //-->
 | |
| 
 | |
| 				</div>
 | |
| 			</div>
 | |
|         </div>
 | |
| 
 | |
| 		</div>
 | |
| 	</section>
 | |
| 	<!-- Page footer //-->
 | |
| 	<footer>
 | |
| 		<span>© 2019 - <a href="https://www.oos-shop.de" target="_blank" rel="noopener">MyOOS [Shopsystem]</a></span>
 | |
| 	</footer>
 | |
| </div>
 | |
| 
 | |
| 
 | |
| <?php 
 | |
| 	require 'includes/bottom.php';
 | |
| 	require 'includes/nice_exit.php';
 | |
| ?>
 |