Guest Posted January 16, 2006 Posted January 16, 2006 I have installed a shipping module contribution which I have customised to do what I want it to do. It doesnt work and I'm quite sure that my modifying of it is not the cause. Everything works until I try going to the checkout. The shipping option just doesnt show up on the page. Does anyone know what it is (ie what code on what page) that makes it show up or not? Your help is much appreciated and I can post code here if necessary. :D
vasttech Posted January 16, 2006 Posted January 16, 2006 Have you enabled the module through the admin area? osCommerce Knowledge Base osCommerce Documentation Contributions
Guest Posted January 17, 2006 Posted January 17, 2006 Have you enabled the module through the admin area? Yes and filled in all the correct settings too. I filled in the settings in this format for the countries: AL, AD, AM, AT etc. And in this format for rates: .10:6.32,.20:7.27,.30:8.22,.40:9.17,.50:10.12,.60:11.07,.70:12.02,.80:12.97,.90: 13.92,1.00:14.82,1.10:15.72,1.20:16.62,1.30:17.52,1.40:18.42,1.50:19.32,1.60:20.2 2,1.70:21.12,1.80:22.02,1.90:22.92,2.00:22.92 that's ok isn't it? I think the problem is most likly to be some kind of conflict between this module and one of the other contributions i have installed. I'm sure it could be sorted though. Any other ideas?
Guest Posted January 21, 2006 Posted January 21, 2006 what shipping module is this? or you could post its code. You could also check if the module is enabled place a check in its constructor. If everything is ok then you move to check the checkout_shipping.php
Guest Posted January 23, 2006 Posted January 23, 2006 what shipping module is this? or you could post its code. You could also check if the module is enabled place a check in its constructor. If everything is ok then you move to check the checkout_shipping.php It's called the UK postal rates contribution. It's basically a modified version of the standard zones module and it enables you to have as many zones with different rates as you want. <?php /* $Id: zones.php,v 1.11 2002/07/01 18:01:50 project3000 Exp $ osCommerce, Open Source E-Commerce Solutions http://www.oscommerce.com Copyright © 2002 osCommerce Released under the GNU General Public License USAGE By default, the module comes with support for 1 zone. This can be easily changed by editing the line below in the zones constructor that defines $this->num_zones. Next, you will want to activate the module by going to the Admin screen, clicking on Modules, then clicking on Shipping. A list of all shipping modules should appear. Click on the green dot next to the one labeled zones.php. A list of settings will appear to the right. Click on the Edit button. PLEASE NOTE THAT YOU WILL LOSE YOUR CURRENT SHIPPING RATES AND OTHER SETTINGS IF YOU TURN OFF THIS SHIPPING METHOD. Make sure you keep a backup of your shipping settings somewhere at all times. If you want an additional handling charge applied to orders that use this method, set the Handling Fee field. Next, you will need to define which countries are in each zone. Determining this might take some time and effort. You should group a set of countries that has similar shipping charges for the same weight. For instance, when shipping from the US, the countries of Japan, Australia, New Zealand, and Singapore have similar shipping rates. As an example, one of my customers is using this set of zones: 1: USA 2: Canada 3: Austria, Belgium, Great Britain, France, Germany, Greenland, Iceland, Ireland, Italy, Norway, Holland/Netherlands, Denmark, Poland, Spain, Sweden, Switzerland, Finland, Portugal, Israel, Greece 4: Japan, Australia, New Zealand, Singapore 5: Taiwan, China, Hong Kong When you enter these country lists, enter them into the Zone X Countries fields, where "X" is the number of the zone. They should be entered as two character ISO country codes in all capital letters. They should be separated by commas with no spaces or other punctuation. For example: 1: US 2: CA 3: AT,BE,GB,FR,DE,GL,IS,IE,IT,NO,NL,DK,PL,ES,SE,CH,FI,PT,IL,GR 4: JP,AU,NZ,SG 5: TW,CN,HK Now you need to set up the shipping rate tables for each zone. Again, some time and effort will go into setting the appropriate rates. You will define a set of weight ranges and the shipping price for each range. For instance, you might want an order than weighs more than 0 and less than or equal to 3 to cost 5.50 to ship to a certain zone. This would be defined by this: 3:5.5 You should combine a bunch of these rates together in a comma delimited list and enter them into the "Zone X Shipping Table" fields where "X" is the zone number. For example, this might be used for Zone 1: 1:3.5,2:3.95,3:5.2,4:6.45,5:7.7,6:10.4,7:11.85, 8:13.3,9:14.75,10:16.2,11:17.65, 12:19.1,13:20.55,14:22,15:23.45 The above example includes weights over 0 and up to 15. Note that units are not specified in this explanation since they should be specific to your locale. CAVEATS At this time, it does not deal with weights that are above the highest amount defined. This will probably be the next area to be improved with the module. For now, you could have one last very high range with a very high shipping rate to discourage orders of that magnitude. For instance: 999:1000 If you want to be able to ship to any country in the world, you will need to enter every country code into the Country fields. For most shops, you will not want to enter every country. This is often because of too much fraud from certain places. If a country is not listed, then the module will add a $0.00 shipping charge and will indicate that shipping is not available to that destination. PLEASE NOTE THAT THE ORDER CAN STILL BE COMPLETED AND PROCESSED! It appears that the osC shipping system automatically rounds the shipping weight up to the nearest whole unit. This makes it more difficult to design precise shipping tables. If you want to, you can hack the shipping.php file to get rid of the rounding. Lastly, there is a limit of 255 characters on each of the Zone Shipping Tables and Zone Countries. */ class zones { var $code, $title, $description, $enabled, $num_zones; // class constructor function zones() { $this->code = 'zones'; $this->title = MODULE_SHIPPING_ZONES_TEXT_TITLE; $this->description = MODULE_SHIPPING_ZONES_TEXT_DESCRIPTION; $this->icon = DIR_WS_ICONS . 'postage-royal-mail.jpg'; $this->enabled = MODULE_SHIPPING_ZONES_STATUS; // CUSTOMIZE THIS SETTING FOR THE NUMBER OF ZONES NEEDED $this->num_zones = 5; } // class methods function selection() { $selection_string = '<table border="0" cellspacing="0" cellpadding="0" width="100%">' . "\n" . ' <tr>' . "\n" . ' <td class="main">' . (($this->icon) ? tep_image($this->icon, $this->title) : '') . ' ' . MODULE_SHIPPING_ZONES_TEXT_TITLE . '</td>' . "\n" . ' <td align="right" class="main">' . tep_draw_checkbox_field('shipping_quote_zones', '1', true) . '</td>' . "\n" . ' </tr>' . "\n" . '</table>' . "\n"; return $selection_string; } function quote() { global $shipping_quote_zones, $shipping_quote_all, $address_values, $shipping_weight, $shipping_quoted, $shipping_zones_cost, $shipping_zones_method; if ( ($GLOBALS['shipping_quote_all'] == '1') || ($GLOBALS['shipping_quote_zones'] == '1') ) { $shipping_quoted = 'zones'; $destination = tep_get_countries($address_values['country_id'], '1'); $dest_country = $destination['countries_iso_code_2']; $dest_zone = 0; for ($i = 1; $i <= $this->num_zones; $i ++) { $countries_table = constant('MODULE_SHIPPING_ZONES_COUNTRIES_' . $i); $country_zones = split("[,]", $countries_table); if ( in_array($dest_country, $country_zones ) ) { $dest_zone = $i; break; } } if ($dest_zone == 0) { $shipping_zones_cost = 0; $shipping_zones_method = MODULE_SHIPPING_ZONES_INVALID_ZONE; return; } $shipping = -1; $zones_cost = constant('MODULE_SHIPPING_ZONES_COST_' . $i); $zones_table = split("[:,]" , $zones_cost); for ($i = 0; $i < count($zones_table); $i+=2) { if ($shipping_weight <= $zones_table[$i]) { $shipping = $zones_table[$i+1]; $shipping_zones_method = MODULE_SHIPPING_ZONES_TEXT_WAY . ' ' . $dest_country . " : " . $shipping_weight . ' ' . MODULE_SHIPPING_ZONES_TEXT_UNITS; break; } } if ( $shipping == -1) { $shipping_zones_cost = 0; $shipping_zones_method = MODULE_SHIPPING_ZONES_UNDEFINED_RATE; } else { $shipping_zones_cost = ($shipping + MODULE_SHIPPING_ZONES_HANDLING + SHIPPING_HANDLING); } } } function cheapest() { global $shipping_count, $shipping_quote_zones, $shipping_quote_all, $shipping_cheapest, $shipping_cheapest_cost, $shipping_zones_cost; if ( ($shipping_quote_all == '1') || ($shipping_quote_zones) ) { if ($shipping_count == 0) { $shipping_cheapest = 'zones'; $shipping_cheapest_cost = $shipping_zones_cost; } else { if ($shipping_zones_cost < $shipping_cheapest_cost) { $shipping_cheapest = 'zones'; $shipping_cheapest_cost = $shipping_zones_cost; } } $shipping_count++; } } function display() { global $HTTP_GET_VARS, $currencies, $shipping_cheapest, $shipping_zones_method, $shipping_zones_cost, $shipping_selected; if (!$shipping_selected) $shipping_selected = $shipping_cheapest; if ( ($GLOBALS['shipping_quote_all'] == '1') || ($GLOBALS['shipping_quote_zones'] == '1') ) { $display_string = '<table border="0" width="100%" cellspacing="0" cellpadding="0">' . "\n" . ' <tr>' . "\n" . ' <td class="main">' . (($this->icon) ? tep_image($this->icon, $this->title) : '') . ' ' . MODULE_SHIPPING_ZONES_TEXT_TITLE . ' <small><i>(' . $shipping_zones_method . ')</i></small></td>' . "\n" . ' <td align="right" class="main">' . $currencies->format($shipping_zones_cost); if (tep_count_shipping_modules() > 1) { $display_string .= tep_draw_radio_field('shipping_selected', 'zones') . tep_draw_hidden_field('shipping_zones_cost', $shipping_zones_cost) . tep_draw_hidden_field('shipping_zones_method', $shipping_zones_method) . '</td>' . "\n"; } else { $display_string .= tep_draw_hidden_field('shipping_selected', 'zones') . tep_draw_hidden_field('shipping_zones_cost', $shipping_zones_cost) . tep_draw_hidden_field('shipping_zones_method', $shipping_zones_method) . '</td>' . "\n"; } $display_string .= ' </tr>' . "\n" . '</table>' . "\n"; } return $display_string; } function confirm() { global $HTTP_POST_VARS, $shipping_cost, $shipping_method, $shipping_selected; if ($shipping_selected == 'zones') { $shipping_cost = $HTTP_POST_VARS['shipping_zones_cost']; $shipping_method = $HTTP_POST_VARS['shipping_zones_method']; } } function check() { if (!isset($this->check)) { $check_query = tep_db_query("select configuration_value from " . TABLE_CONFIGURATION . " where configuration_key = 'MODULE_SHIPPING_ZONES_STATUS'"); $this->check = tep_db_num_rows($check_query); } return $this->check; } function install() { tep_db_query("insert into " . TABLE_CONFIGURATION . " (configuration_title, configuration_key, configuration_value, configuration_description, configuration_group_id, sort_order, date_added) VALUES ('Enable Zones Method', 'MODULE_SHIPPING_ZONES_STATUS', '1', 'Do you want to offer zone rate shipping?', '6', '0', now())"); tep_db_query("insert into " . TABLE_CONFIGURATION . " (configuration_title, configuration_key, configuration_value, configuration_description, configuration_group_id, sort_order, date_added) values ('Handling Fee', 'MODULE_SHIPPING_ZONES_HANDLING', '0', 'Handling Fee for this shipping method', '6', '0', now())"); for ($i = 1; $i <= $this->num_zones; $i++) { $default_countries = ''; if ($i == 1) { $default_countries = 'US,CA'; } tep_db_query("insert into " . TABLE_CONFIGURATION . " (configuration_title, configuration_key, configuration_value, configuration_description, configuration_group_id, sort_order, date_added) values ('Zone " . $i ." Countries', 'MODULE_SHIPPING_ZONES_COUNTRIES_" . $i ."', '" . $default_countries . "', 'Comma separated list of two character ISO country codes that are part of Zone " . $i . ".', '6', '0', now())"); tep_db_query("insert into " . TABLE_CONFIGURATION . " (configuration_title, configuration_key, configuration_value, configuration_description, configuration_group_id, sort_order, date_added) values ('Zone " . $i ." Shipping Table', 'MODULE_SHIPPING_ZONES_COST_" . $i ."', '3:8.50,7:10.50,99:20.00', 'Shipping rates to Zone " . $i . " destinations based on a group of maximum order weights. Example: 3:8.50,7:10.50,... Weights less than or equal to 3 would cost 8.50 for Zone " . $i . " destinations.', '6', '0', now())"); } } function remove() { tep_db_query("delete from " . TABLE_CONFIGURATION . " where configuration_key = 'MODULE_SHIPPING_ZONES_STATUS'"); tep_db_query("delete from " . TABLE_CONFIGURATION . " where configuration_key = 'MODULE_SHIPPING_ZONES_HANDLING'"); for ($i = 1; $i <= $this->num_zones; $i ++) { tep_db_query("delete from " . TABLE_CONFIGURATION . " where configuration_key = 'MODULE_SHIPPING_ZONES_COUNTRIES_" . $i ."'"); tep_db_query("delete from " . TABLE_CONFIGURATION . " where configuration_key = 'MODULE_SHIPPING_ZONES_COST_" . $i ."'"); } } function keys() { $keys = array('MODULE_SHIPPING_ZONES_STATUS', 'MODULE_SHIPPING_ZONES_HANDLING'); for ($i = 1; $i <= $this->num_zones; $i ++) { $keys[count($keys)] = 'MODULE_SHIPPING_ZONES_COUNTRIES_' . $i; $keys[count($keys)] = 'MODULE_SHIPPING_ZONES_COST_' . $i; } return $keys; } } ?>
Recommended Posts
Archived
This topic is now archived and is closed to further replies.