Neuigkeiten
  • Die modified eCommerce Shopsoftware ist kostenlos, aber nicht umsonst.
    Spenden
  • Damit wir die modified eCommerce Shopsoftware auch zukünftig kostenlos anbieten können:
    Spenden
  • Thema: Versandmodul bei Versandkostenfrei deaktivieren

    Angeal

    • Fördermitglied
    • Beiträge: 411
    • Geschlecht:
    Versandmodul bei Versandkostenfrei deaktivieren
    am: 16. September 2016, 09:07:54
    Hallo Zusammen,
    wir nutzen für Bestellungen aus dem EU-Ausland das Versandmodul "zones".
    Nun versenden wir nach Österreich ab einem Bestellwert von 150 Euro versandkostenfrei.
    Wenn diese Grenze überschritten wird, möchte ich die Versandart "zones" im Checkout ausgeblendet haben.
    Ich weiß eh nicht warum dann noch jemand "zones" auswählen sollte, wenn er die Sendung eh frachtfrei nach Hause bekommt.

    Dazu habe ich folgenden Ansatz gewählt.

    /includes/modules/shipping/zones.php
    Code: PHP  [Auswählen]
    if ($_SESSION['cart']->show_total() > '150' and $dest_country == 'AT') {
        $this->enabled = false;
    }

    Ich scheine allerdings irgendwas zu übersehen, da ich andauernd einen Syntax Error am Ende der Datei (unexpected ; )

    Habe es schon an verschiedenen Stellen versucht, aber es will einfach nicht klappen.
    Wo liegt der Denkfehler?

    Linkback: https://www.modified-shop.org/forum/index.php?topic=35711.0
    Modulshop - Eine große Auswahl an neuen und hilfreichen Modulen für die modified eCommerce Shopsoftware

    BiDoubleU

    • Fördermitglied
    • Beiträge: 295
    • Geschlecht:
    Re: Versandmodul bei Versandkostenfrei deaktivieren
    Antwort #1 am: 16. September 2016, 10:18:13

    Angeal

    • Fördermitglied
    • Beiträge: 411
    • Geschlecht:
    Re: Versandmodul bei Versandkostenfrei deaktivieren
    Antwort #2 am: 16. September 2016, 17:55:58
    Hi,
    danke für die Antwort.
    Allerdings funktioniert die Anleitung für das Modul zones leider nicht.

    Bonsai

    • Viel Schreiber
    • Beiträge: 4.127
    • Geschlecht:
    Re: Versandmodul bei Versandkostenfrei deaktivieren
    Antwort #3 am: 16. September 2016, 18:17:21
    Wo das Semikolon herkommt ... keine Ahnung. Aber das:
    Code: PHP  [Auswählen]
    if ($_SESSION['cart']->show_total() > '150' and $dest_country == 'AT') {
        $this->enabled = false;
    }

    bedeutet vermutlich das:

    Code: PHP  [Auswählen]
    if ($_SESSION['cart']->show_total() > 0 and $dest_country == 'AT') {
        $this->enabled = false;
    }

    weil '150' ein Text ist. Habe das jetzt nicht getestet .... selbst wenn es funktionieren würde ist es extrem schlechter Programmierstil!

    Was mir noch auffällt .... and hat zwar die gleiche Funktionalität wie &&, aber && eine höhere Wertigkeit!

    Aber poste doch mal bitte die komplette Datei! Eventuell findet sich dann das ;

    Angeal

    • Fördermitglied
    • Beiträge: 411
    • Geschlecht:
    Re: Versandmodul bei Versandkostenfrei deaktivieren
    Antwort #4 am: 16. September 2016, 19:31:59
    Ist zwar nicht die feine Lösung, aber im Prinzip funktioniert es. Zumindest in einem anderen Modul. Wollte es daher der Einfachheit halber übernehmen. Aber Pustekuchen.

    Hier mal die komplette Zones Datei:

    Code: PHP  [Auswählen]
    <?php
    /* -----------------------------------------------------------------------------------------
       $Id: zones.php 899 2005-04-29 02:40:57Z hhgag $  

       XT-Commerce - community made shopping
       http://www.(( Wir dulden keine kommerziellen Werbelinks - Bitte <a href="index.php?topic=3013.0">Forenregeln</a> beachten! ))

       Copyright (c) 2003 XT-Commerce
       -----------------------------------------------------------------------------------------
       based on:
       (c) 2000-2001 The Exchange Project  (earlier name of osCommerce)
       (c) 2002-2003 osCommerce(zones.php,v 1.19 2003/02/05); www.oscommerce.com
       (c) 2003      nextcommerce (zones.php,v 1.7 2003/08/24); www.nextcommerce.org

       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.
     *
     *  Released under the GNU General Public License
     *
     */


      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->sort_order = MODULE_SHIPPING_ZONES_SORT_ORDER;
          $this->icon = '';
          $this->tax_class = MODULE_SHIPPING_ZONES_TAX_CLASS;
          $this->enabled = ((MODULE_SHIPPING_ZONES_STATUS == 'True') ? true : false);

    /**
     * CUSTOMIZE THIS SETTING FOR THE NUMBER OF ZONES NEEDED
     *
     * + CUSTOMIZE THE SETTING IN lang/LANGUAGE/modules/shipping/zones.php
     */


    //BOF - 29.07.2009 - Dokuman - up to 9 zones possible, no changes in langfile needed
          //$this->num_zones = 1;
          $this->num_zones = 9;
    //EOF - 29.07.2009 - Dokuman - up to 9 zones possible, no changes in langfile needed
        }

    /**
     * class methods
     */

        function quote($method = '') {
          global $order, $shipping_weight;

          $dest_country = $order->delivery['country']['iso_code_2'];
          $dest_zone = 0;
          $error = false;

          for ($i=1; $i<=$this->num_zones; $i++) {
            $countries_table = constant('MODULE_SHIPPING_ZONES_COUNTRIES_' . $i);
            $country_zones = explode(",", $countries_table); // Hetfield - 2009-08-18 - replaced deprecated function split with explode to be ready for PHP >= 5.3
            if (in_array($dest_country, $country_zones)) {
              $dest_zone = $i;
              break;
            }
          }

          if ($dest_zone == 0) {
            $error = true;
          } else {
            $shipping = -1;
            $zones_cost = constant('MODULE_SHIPPING_ZONES_COST_' . $dest_zone);

            $zones_table = preg_split("/[:,]/" , $zones_cost); // Hetfield - 2009-08-18 - replaced deprecated function split with preg_split to be ready for PHP >= 5.3
            $size = sizeof($zones_table);
            for ($i=0; $i<$size; $i+=2) {
              if ($shipping_weight <= $zones_table[$i]) {
                $shipping = $zones_table[$i+1];
                $shipping_method = MODULE_SHIPPING_ZONES_TEXT_WAY . ' ' . $dest_country . ' : ' . $shipping_weight . ' ' . MODULE_SHIPPING_ZONES_TEXT_UNITS;
                break;
              }
            }

            if ($shipping == -1) {
              $shipping_cost = 0;
              $shipping_method = MODULE_SHIPPING_ZONES_UNDEFINED_RATE;
            } else {
              $shipping_cost = ($shipping + constant('MODULE_SHIPPING_ZONES_HANDLING_' . $dest_zone));
            }
                   
          }

          $this->quotes = array('id' => $this->code,
                                'module' => MODULE_SHIPPING_ZONES_TEXT_TITLE,
                                'methods' => array(array('id' => $this->code,
                                                         'title' => $shipping_method,
                                                         'cost' => $shipping_cost)));

          if ($this->tax_class > 0) {
            $this->quotes['tax'] = xtc_get_tax_rate($this->tax_class, $order->delivery['country']['id'], $order->delivery['zone_id']);
          }

          if (xtc_not_null($this->icon)) $this->quotes['icon'] = xtc_image($this->icon, $this->title);

          if ($error == true) $this->quotes['error'] = MODULE_SHIPPING_ZONES_INVALID_ZONE;

          return $this->quotes;
        }

        function check() {
          if (!isset($this->_check)) {
            $check_query = xtc_db_query("select configuration_value from " . TABLE_CONFIGURATION . " where configuration_key = 'MODULE_SHIPPING_ZONES_STATUS'");
            $this->_check = xtc_db_num_rows($check_query);
          }
          return $this->_check;
        }

        function install() {
          xtc_db_query("insert into " . TABLE_CONFIGURATION . " (configuration_key, configuration_value, configuration_group_id, sort_order, set_function, date_added) VALUES ('MODULE_SHIPPING_ZONES_STATUS', 'True', '6', '0', 'xtc_cfg_select_option(array(\'True\', \'False\'), ', now())");
          xtc_db_query("insert into " . TABLE_CONFIGURATION . " (configuration_key, configuration_value, configuration_group_id, sort_order, date_added) values ('MODULE_SHIPPING_ZONES_ALLOWED', '', '6', '0', now())");
          xtc_db_query("insert into " . TABLE_CONFIGURATION . " (configuration_key, configuration_value, configuration_group_id, sort_order, use_function, set_function, date_added) values ('MODULE_SHIPPING_ZONES_TAX_CLASS', '0', '6', '0', 'xtc_get_tax_class_title', 'xtc_cfg_pull_down_tax_classes(', now())");
          xtc_db_query("insert into " . TABLE_CONFIGURATION . " (configuration_key, configuration_value, configuration_group_id, sort_order, date_added) values ('MODULE_SHIPPING_ZONES_SORT_ORDER', '0', '6', '0', now())");
          for ($i = 1; $i <= $this->num_zones; $i++) {
            $default_countries = '';
            if ($i == 1) {
              $default_countries = 'US,CA';
            }
            xtc_db_query("insert into " . TABLE_CONFIGURATION . " (configuration_key, configuration_value, configuration_group_id, sort_order, date_added) values ('MODULE_SHIPPING_ZONES_COUNTRIES_" . $i ."', '" . $default_countries . "', '6', '0', now())");
            xtc_db_query("insert into " . TABLE_CONFIGURATION . " (configuration_key, configuration_value, configuration_group_id, sort_order, date_added) values ('MODULE_SHIPPING_ZONES_COST_" . $i ."', '3:8.50,7:10.50,99:20.00', '6', '0', now())");
            xtc_db_query("insert into " . TABLE_CONFIGURATION . " (configuration_key, configuration_value, configuration_group_id, sort_order, date_added) values ('MODULE_SHIPPING_ZONES_HANDLING_" . $i."', '0', '6', '0', now())");
          }
        }

        function remove() {
          xtc_db_query("delete from " . TABLE_CONFIGURATION . " where configuration_key in ('" . implode("', '", $this->keys()) . "')");
        }

        function keys() {
          $keys = array('MODULE_SHIPPING_ZONES_STATUS','MODULE_SHIPPING_ZONES_ALLOWED', 'MODULE_SHIPPING_ZONES_TAX_CLASS', 'MODULE_SHIPPING_ZONES_SORT_ORDER');

          for ($i=1; $i<=$this->num_zones; $i++) {
            $keys[] = 'MODULE_SHIPPING_ZONES_COUNTRIES_' . $i;
            $keys[] = 'MODULE_SHIPPING_ZONES_COST_' . $i;
            $keys[] = 'MODULE_SHIPPING_ZONES_HANDLING_' . $i;
          }

          return $keys;
        }
      }
    ?>
     
    Managed Server
               
    anything