为什么客户的运输选项与Zen Cart 1.5中的数据库或模块设置不匹配?

时间:2012-04-03 14:36:52

标签: php database shopping-cart zen-cart

客户在Zen Cart 1.5中有自定义送货模块。昨天我将模块改为区域感知(他们希望原始模块适用于美国,并且需要为非美国订单调整副本)。

现在我在该模块中只有一个送货选项,而不是配置的四个。区域意识似乎有效(我的测试订单显示美国费用,而不是国际费用,显示的选项)但只显示第一个选项。

这是模块的代码:

/*include functions/functions_categories.pnp for zen_product_in_category method
*/
class tfn
{
    var $code, $title, $description, $icon, $enabled, $types;

    // class constructor
    function tfn() {
        global $order, $db, $types, $fees;

        $this->code = 'tfn';
        $this->title = MODULE_SHIPPING_TFN_TEXT_TITLE;
        $this->description = MODULE_SHIPPING_TFN_TEXT_DESCRIPTION;
        $this->sort_order = MODULE_SHIPPING_TFN_SORT_ORDER;
        $this->icon = '';
        $this->tax_class = MODULE_SHIPPING_TFN_TAX_CLASS;
        $this->tax_basis = MODULE_SHIPPING_TFN_TAX_BASIS;

        // disable only when entire cart is free shipping
        if (zen_get_shipping_enabled($this->code)) {
            $this->enabled = ((MODULE_SHIPPING_TFN_STATUS == 'True') ? true : false);
        }

        if (($this->enabled == true) && ((int)MODULE_SHIPPING_TFN_ZONE > 0)) {
            $check_flag = false;
            $check = $db->Execute("select zone_id from " . TABLE_ZONES_TO_GEO_ZONES . " where geo_zone_id = '" . MODULE_SHIPPING_TFN_ZONE . "' and zone_country_id = '" . $order->delivery['country']['id'] . "' order by zone_id");
            while (!$check->EOF) {
                if ($check->fields['zone_id'] < 1) {
                    $check_flag = true;
                    break;
                } elseif ($check->fields['zone_id'] == $order->delivery['zone_id']) {
                    $check_flag = true;
                    break;
                }
                $check->MoveNext();
            }

            if ($check_flag == false) {
                $this->enabled = false;
            }
        }

        $types = array(
            'STD'  => 'Standard',
            'FXH'  => 'USPS Priority Mail',
            'FXES' => 'USPS Express Mail',
            'FXSO' => 'FedEx Overnight'
        );
        // 'FAM' => 'Foreign Airmail',
        // 'FXG' => 'USPS Priority Mail with Delivery Confirmation',
        // 'FX2D' => 'FedEx 2nd Day',

        $fees = array(
            'STD'  => '0.00',
            'FXH'  => '4.50',
            'FXES' => '17.50',
            'FXSO' => '28.00'
        );
        // 'FAM' => '15.00',
        // 'FXG' => '5.50',
        // 'FX2D' => '10.00',
    }

    // class methods
    function quote($method = '') {
        global $order, $types, $fees;

        $methods = array();

        $this->quotes = array(
            'id'     => $this->code,
            'module' => $this->title
        );

        if (($method == '') || (!isset($method))) {
            foreach ($fees as $type => $cost) {
                $methods[] = array(
                    'id'    => $type,
                    'title' => $types[$type],
                    'cost'  => $this->_calculateBaseCost() + $cost
                );
            }
        } else {
            $cost = $fees[$method];
            $methods[] = array(
                'id'    => $method,
                'title' => $types[$method],
                'cost'  => $this->_calculateBaseCost() + $cost
            );
        }

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

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

        return $this->quotes;
    }

    function _calculateBaseCost() {
        global $db, $shipping_cost;

        $total_count = $_SESSION['cart']->count_contents();
        $total_count = $total_count - $_SESSION['cart']->free_shipping_items();
        $foreign_charge = $this->_additionalForeignCharge();
        $shipping_cost = ($total_count * (MODULE_SHIPPING_TFN_BASE_COST + $foreign_charge));

        return $shipping_cost;
    }

    function _additionalForeignCharge() {
        global $db, $order;

        $foreign_charge = 0;

        $dest_country = $order->delivery['country']['iso_code_2'];

        if ($dest_country != 'US') {
            $foreign_charge = MODULE_SHIPPING_TFN_FOREIGN_COST;
        }

        return $foreign_charge;
    }

    function check() {
        global $db;
        if (!isset($this->_check)) {
            $check_query = $db->Execute("select configuration_value from " . TABLE_CONFIGURATION . " where configuration_key = 'MODULE_SHIPPING_TFN_STATUS'");
            $this->_check = $check_query->RecordCount();
        }

        return $this->_check;
    }

    function install() {
        global $db;
        $db->Execute("insert into " . TABLE_CONFIGURATION . " (configuration_title, configuration_key, configuration_value, configuration_description, configuration_group_id, sort_order, set_function, date_added) values ('Enable Item Shipping', 'MODULE_SHIPPING_TFN_STATUS', 'True', 'Do you want to offer per item rate shipping?', '6', '0', 'zen_cfg_select_option(array(\'True\', \'False\'), ', now())");
        $db->Execute("insert into " . TABLE_CONFIGURATION . " (configuration_title, configuration_key, configuration_value, configuration_description, configuration_group_id, sort_order, date_added) values ('Shipping Cost', 'MODULE_SHIPPING_TFN_BASE_COST', '2.50', 'The shipping cost will be multiplied by the number of items in an order that uses this shipping method.', '6', '0', now())");
        $db->Execute("insert into " . TABLE_CONFIGURATION . " (configuration_title, configuration_key, configuration_value, configuration_description, configuration_group_id, sort_order, date_added) values ('Additional Foreign Shipping Cost', 'MODULE_SHIPPING_TFN_FOREIGN_COST', '4.00', 'The additional foreign shipping cost will be multiplied by the number of items and added to the base cost.', '6', '0', now())");
        $db->Execute("insert into " . TABLE_CONFIGURATION . " (configuration_title, configuration_key, configuration_value, configuration_description, configuration_group_id, sort_order, use_function, set_function, date_added) values ('Tax Class', 'MODULE_SHIPPING_TFN_TAX_CLASS', '0', 'Use the following tax class on the shipping fee.', '6', '0', 'zen_get_tax_class_title', 'zen_cfg_pull_down_tax_classes(', now())");
        $db->Execute("insert into " . TABLE_CONFIGURATION . " (configuration_title, configuration_key, configuration_value, configuration_description, configuration_group_id, sort_order, set_function, date_added) values ('Tax Basis', 'MODULE_SHIPPING_TFN_TAX_BASIS', 'Shipping', 'On what basis is Shipping Tax calculated. Options are<br />Shipping - Based on customers Shipping Address<br />Billing Based on customers Billing address<br />Store - Based on Store address if Billing/Shipping Zone equals Store zone', '6', '0', 'zen_cfg_select_option(array(\'Shipping\', \'Billing\', \'Store\'), ', now())");
        $db->Execute("insert into " . TABLE_CONFIGURATION . " (configuration_title, configuration_key, configuration_value, configuration_description, configuration_group_id, sort_order, date_added) values ('Sort Order', 'MODULE_SHIPPING_TFN_SORT_ORDER', '0', 'Sort order of display.', '6', '0', now())");
        $db->Execute("insert into " . TABLE_CONFIGURATION . " (configuration_title, configuration_key, configuration_value, configuration_description, configuration_group_id, sort_order, date_added) values ('Sort Order', 'MODULE_SHIPPING_TFN_SHIPPING_TYPES', '0', 'Code and Name for each kind of shipping offered.', '6', '0', now())");
        $db->Execute("insert into " . TABLE_CONFIGURATION . " (configuration_title, configuration_key, configuration_value, configuration_description, configuration_group_id, sort_order, set_function, date_added) values ( 'Shipping Methods: <br />Standard, Foreign Airmail, FedEx Home Delivery, FedEx Ground, FedEx Express Saver, FedEx 2nd Day, FedEx Standard Overnight', 'MODULE_SHIPPING_TFN_TYPES', 'STD, FAM, FXHD, FXG, FXES, FX2D, FXSO', 'Select the TFN services to be offered.', '6', '13', 'zen_cfg_select_multioption(array(\'STD\',\'FAM\',\'FXHD\', \'FXG\', \'FXES\', \'FX2D\', \'FXSO\'), ', now() )");
        $db->Execute("insert into " . TABLE_CONFIGURATION . " (configuration_title, configuration_key, configuration_value, configuration_description, configuration_group_id, sort_order, use_function, set_function, date_added) values ('Shipping Zone', 'MODULE_SHIPPING_TFN_ZONE', '0', 'If a zone is selected, only enable this shipping method for that zone.', '6', '0', 'zen_get_zone_class_title', 'zen_cfg_pull_down_zone_classes(', now())");
    }

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

    function keys() {
        return array(
            'MODULE_SHIPPING_TFN_STATUS', 'MODULE_SHIPPING_TFN_BASE_COST',
            'MODULE_SHIPPING_TFN_FOREIGN_COST', 'MODULE_SHIPPING_TFN_TAX_CLASS',
            'MODULE_SHIPPING_TFN_TAX_BASIS', 'MODULE_SHIPPING_TFN_SORT_ORDER',
            'MODULE_SHIPPING_TFN_TYPES', 'MODULE_SHIPPING_TFN_ZONE'
        );
    }
}
?>

管理页面显示了八个送货选项,其中四个列在所选代码中。

以下是相关的数据库条目,包括国际模块:

mysql> select configuration_value, configuration_key from configuration where configuration_key LIKE 'MODULE_SHIPPING_%_TYPES';
+-----------------------+----------------------------------------+
| configuration_value   | configuration_key                      |
+-----------------------+----------------------------------------+
| 0                     | MODULE_SHIPPING_TFN_INT_SHIPPING_TYPES | 
| STD                   | MODULE_SHIPPING_TFN_INT_TYPES          | 
| 0                     | MODULE_SHIPPING_TFN_SHIPPING_TYPES     | 
| STD, FXHD, FXES, FXSO | MODULE_SHIPPING_TFN_TYPES              | 
+-----------------------+----------------------------------------+
4 rows in set (0.00 sec)

直接在数据库中更新_SHIPPING_TYPES设置(例如将其设置为1而不是0)似乎没有任何改变。我找不到任何似乎调用此设置的代码。

Zen Cart在哪里确定运输选项?如何让它显示我想要的?

1 个答案:

答案 0 :(得分:0)

由于运输选项的文件命名和文件结构错误,因此运输模块通常不会显示。你知道如何制作50个不同的文件只是为了在zen cart中添加1页吗?

请仔细按照此处的说明操作,确保您的命名约定和文件放置都正确无误。

http://www.zen-cart.com/wiki/index.php/Creating_Your_Own_Shipping_Module