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: Versandkostenfrei nach Zonen

    moscbabe

    • Frisch an Board
    • Beiträge: 86
    Versandkostenfrei nach Zonen
    am: 28. Dezember 2010, 16:08:26
    Hallo Ihr Lieben,

    ich würde gerne verschiedene Werte definieren, ab wann eine Bestellung versankostenfrei ist:

    Austria ab 50 Euro
    Rest ab 50 Euro

    Habe folgenden Link gefunden, leider klappt es nicht so richtig: Versandkostenfrei nach Zonen

    Kann es sein, dass dies bei modified eCommerce Shopsoftware nicht funktioniert?

    ... hab das dann noch abgeändert:

    Code: PHP  [Auswählen]
    <?php
    /* -----------------------------------------------------------------------------------------
       $Id: ot_shipping.php 1002 2005-07-10 16:11:37Z mz $  

       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(ot_shipping.php,v 1.15 2003/02/07); www.oscommerce.com
       (c) 2003      nextcommerce (ot_shipping.php,v 1.13 2003/08/24); www.nextcommerce.org

       Released under the GNU General Public License
       ---------------------------------------------------------------------------------------*/


      class ot_shipping {
        var $title, $output;

        function ot_shipping() {
            global $xtPrice;
          $this->code = 'ot_shipping';
          $this->title = MODULE_ORDER_TOTAL_SHIPPING_TITLE;
          $this->description = MODULE_ORDER_TOTAL_SHIPPING_DESCRIPTION;
          $this->enabled = ((MODULE_ORDER_TOTAL_SHIPPING_STATUS == 'true') ? true : false);
          $this->sort_order = MODULE_ORDER_TOTAL_SHIPPING_SORT_ORDER;

          $this->output = array();
        }

        function process() {
          global $order, $xtPrice;

          if (MODULE_ORDER_TOTAL_SHIPPING_FREE_SHIPPING == 'true') {
            switch (MODULE_ORDER_TOTAL_SHIPPING_DESTINATION) {
                            case 'individual':
                             if ($order->delivery['country_id'] == STORE_COUNTRY) { // Versandkosten frei im eigenen Land ab ...
                             $pass = true;
                             $free_shipping = 50; //Betrag ab Versandkosten frei
                             break;
                            } elseif($order->delivery['country_id'] != STORE_COUNTRY) { //Versandkosten frei ins Ausland ab ...
                             $pass = true;
                             $free_shipping = 100; //Betrag ab Versandkosten frei
                             break;
                            } else {
                             $pass = false;
                             break;
                            }
                            case 'national':
                             if ($order->delivery['country_id'] == STORE_COUNTRY) $pass = true; break;
              case 'international':
                if ($order->delivery['country_id'] != STORE_COUNTRY) $pass = true; break;
              case 'both':
                $pass = true; break;
              default:
                $pass = false; break;
            }

                    if ( ($pass == true) && ( ($order->info['total'] - $order->info['shipping_cost'])>= $xtPrice->xtcFormat((isset($free_shipping)?$free_shipping:MODULE_ORDER_TOTAL_SHIPPING_FREE_SHIPPING_OVER),false,0,true)) ) {
              $order->info['shipping_method'] = $this->title;
              $order->info['total'] -= $order->info['shipping_cost'];
              $order->info['shipping_cost'] = 0;
            }
          }

          $module = substr($_SESSION['shipping']['id'], 0, strpos($_SESSION['shipping']['id'], '_'));

          if (xtc_not_null($order->info['shipping_method'])) {
            if ($_SESSION['customers_status']['customers_status_show_price_tax'] == 1) {
            // price with tax

              $shipping_tax = xtc_get_tax_rate($GLOBALS[$module]->tax_class, $order->delivery['country']['id'], $order->delivery['zone_id']);
              $shipping_tax_description = xtc_get_tax_description($GLOBALS[$module]->tax_class, $order->delivery['country']['id'], $order->delivery['zone_id']);
              $tax = $xtPrice->xtcFormat(xtc_add_tax($order->info['shipping_cost'], $shipping_tax),false,0,false)-$order->info['shipping_cost'];
              $tax = $xtPrice->xtcFormat($tax,false,0,true);
              $order->info['shipping_cost'] = xtc_add_tax($order->info['shipping_cost'], $shipping_tax);
              $order->info['tax'] += $tax;
              $order->info['tax_groups'][TAX_ADD_TAX . "$shipping_tax_description"] += $tax;
              $order->info['total'] += $tax;

            } else {

            if ($_SESSION['customers_status']['customers_status_show_price_tax'] == 0 && $_SESSION['customers_status']['customers_status_add_tax_ot'] == 1) {

              $shipping_tax = xtc_get_tax_rate($GLOBALS[$module]->tax_class, $order->delivery['country']['id'], $order->delivery['zone_id']);
              $shipping_tax_description = xtc_get_tax_description($GLOBALS[$module]->tax_class, $order->delivery['country']['id'], $order->delivery['zone_id']);
              $tax = $xtPrice->xtcFormat(xtc_add_tax($order->info['shipping_cost'], $shipping_tax),false,0,false)-$order->info['shipping_cost'];
                     $tax = $xtPrice->xtcFormat($tax,false,0,true);

              $order->info['tax'] = $order->info['tax'] += $tax;
              $order->info['tax_groups'][TAX_NO_TAX . "$shipping_tax_description"] = $order->info['tax_groups'][TAX_NO_TAX . "$shipping_tax_description"] += $tax;
            }
            }
            $this->output[] = array('title' => $order->info['shipping_method'] . ':',
                                    'text' => $xtPrice->xtcFormat($order->info['shipping_cost'], true,0,true),
                                    'value' => $xtPrice->xtcFormat($order->info['shipping_cost'], false,0,true));
          }
        }

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

          return $this->_check;
        }

        function keys() {
          return array('MODULE_ORDER_TOTAL_SHIPPING_STATUS', 'MODULE_ORDER_TOTAL_SHIPPING_SORT_ORDER', 'MODULE_ORDER_TOTAL_SHIPPING_FREE_SHIPPING', 'MODULE_ORDER_TOTAL_SHIPPING_FREE_SHIPPING_OVER', 'MODULE_ORDER_TOTAL_SHIPPING_DESTINATION', 'MODULE_ORDER_TOTAL_SHIPPING_TAX_CLASS');
        }

        function install() {
          xtc_db_query("insert into " . TABLE_CONFIGURATION . " (configuration_key, configuration_value, configuration_group_id, sort_order, set_function, date_added) values ('MODULE_ORDER_TOTAL_SHIPPING_STATUS', 'true','6', '1','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_ORDER_TOTAL_SHIPPING_SORT_ORDER', '3','6', '2', now())");
          xtc_db_query("insert into " . TABLE_CONFIGURATION . " (configuration_key, configuration_value, configuration_group_id, sort_order, set_function, date_added) values ('MODULE_ORDER_TOTAL_SHIPPING_FREE_SHIPPING', 'false','6', '3', 'xtc_cfg_select_option(array(\'true\', \'false\'), ', now())");
          xtc_db_query("insert into " . TABLE_CONFIGURATION . " (configuration_key, configuration_value, configuration_group_id, sort_order, use_function, date_added) values ('MODULE_ORDER_TOTAL_SHIPPING_FREE_SHIPPING_OVER', '50', '6', '4', 'currencies->format', now())");
              xtc_db_query("insert into " . TABLE_CONFIGURATION . " (configuration_key, configuration_value, configuration_group_id, sort_order, set_function, date_added) values ('MODULE_ORDER_TOTAL_SHIPPING_DESTINATION', 'national','6', '5', 'xtc_cfg_select_option(array(\'individual\', \'national\', \'international\', \'both\'), ', 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_ORDER_TOTAL_SHIPPING_TAX_CLASS', '0','6', '7', 'xtc_get_tax_class_title', 'xtc_cfg_pull_down_tax_classes(', now())");
        }

        function remove() {
          xtc_db_query("delete from " . TABLE_CONFIGURATION . " where configuration_key in ('" . implode("', '", $this->keys()) . "')");
        }
      }
    ?>
     
    Leider will das einfach nicht klappen.
    Kann mir irgendjemand bitte weiterhelfen?

    Danke für Eure Ratschläge!
    Liebe Grüße,
     moscbabe



    Linkback: https://www.modified-shop.org/forum/index.php?topic=10298.0

    franky_n

    • Experte
    • Beiträge: 4.950
    Versandkostenfrei nach Zonen
    Antwort #1 am: 28. Dezember 2010, 16:17:36
    Hallo moscbabe,

    keine Doppelposts bitte!

    -> Mindestbestellwert und versandkostenfreie Lieferung

    :close:

    Viele Grüße

    Franky

    2 Antworten
    2669 Aufrufe
    28. Februar 2014, 11:38:34 von diefl
    1 Antworten
    2135 Aufrufe
    25. Februar 2014, 14:32:10 von womd
    2 Antworten
    2221 Aufrufe
    28. Juli 2012, 07:51:40 von andi80
    1 Antworten
    2853 Aufrufe
    02. Februar 2011, 19:35:53 von Tomcraft
               
    anything