PageRenderTime 34ms CodeModel.GetById 9ms RepoModel.GetById 0ms app.codeStats 0ms

/includes/modules/payment/cod.php

https://bitbucket.org/flth/xtcm
PHP | 206 lines | 143 code | 44 blank | 19 comment | 69 complexity | 3bef5073648280966ad7b39589fef6ac MD5 | raw file
Possible License(s): AGPL-1.0
  1. <?php
  2. /* -----------------------------------------------------------------------------------------
  3. $Id: cod.php 1003 2005-07-10 18:58:52Z mz $
  4. XT-Commerce - community made shopping
  5. http://www.xt-commerce.com
  6. Copyright (c) 2003 XT-Commerce
  7. -----------------------------------------------------------------------------------------
  8. based on:
  9. (c) 2000-2001 The Exchange Project (earlier name of osCommerce)
  10. (c) 2002-2003 osCommerce(cod.php,v 1.28 2003/02/14); www.oscommerce.com
  11. (c) 2003 nextcommerce (cod.php,v 1.7 2003/08/24); www.nextcommerce.org
  12. Released under the GNU General Public License
  13. ---------------------------------------------------------------------------------------*/
  14. class cod {
  15. var $code, $title, $description, $enabled;
  16. function cod() {
  17. global $order,$xtPrice;
  18. $this->code = 'cod';
  19. $this->title = MODULE_PAYMENT_COD_TEXT_TITLE;
  20. $this->description = MODULE_PAYMENT_COD_TEXT_DESCRIPTION;
  21. $this->sort_order = MODULE_PAYMENT_COD_SORT_ORDER;
  22. $this->enabled = ((MODULE_PAYMENT_COD_STATUS == 'True') ? true : false);
  23. $this->info = MODULE_PAYMENT_COD_TEXT_INFO;
  24. $this->cost;
  25. if ((int) MODULE_PAYMENT_COD_ORDER_STATUS_ID > 0) {
  26. $this->order_status = MODULE_PAYMENT_COD_ORDER_STATUS_ID;
  27. }
  28. if (is_object($order))
  29. $this->update_status();
  30. }
  31. function update_status() {
  32. global $order;
  33. if ($_SESSION['shipping']['id'] == 'selfpickup_selfpickup') {
  34. $this->enabled = false;
  35. }
  36. if (($this->enabled == true) && ((int) MODULE_PAYMENT_COD_ZONE > 0)) {
  37. $check_flag = false;
  38. $check_query = xtc_db_query("select zone_id from ".TABLE_ZONES_TO_GEO_ZONES." where geo_zone_id = '".MODULE_PAYMENT_COD_ZONE."' and zone_country_id = '".$order->delivery['country']['id']."' order by zone_id");
  39. while ($check = xtc_db_fetch_array($check_query)) {
  40. if ($check['zone_id'] < 1) {
  41. $check_flag = true;
  42. break;
  43. }
  44. elseif ($check['zone_id'] == $order->delivery['zone_id']) {
  45. $check_flag = true;
  46. break;
  47. }
  48. }
  49. if ($check_flag == false) {
  50. $this->enabled = false;
  51. }
  52. }
  53. }
  54. function javascript_validation() {
  55. return false;
  56. }
  57. function selection() {
  58. global $xtPrice,$order;
  59. if (MODULE_ORDER_TOTAL_COD_FEE_STATUS == 'true') {
  60. $cod_country = false;
  61. //process installed shipping modules
  62. // BOF - Hetfield - 2009-08-18 - replaced deprecated function split with preg_split to be ready for PHP >= 5.3
  63. if ($_SESSION['shipping']['id'] == 'flat_flat') $cod_zones = preg_split("/[:,]/", MODULE_ORDER_TOTAL_COD_FEE_FLAT);
  64. if ($_SESSION['shipping']['id'] == 'item_item') $cod_zones = preg_split("/[:,]/", MODULE_ORDER_TOTAL_COD_FEE_ITEM);
  65. if ($_SESSION['shipping']['id'] == 'table_table') $cod_zones = preg_split("/[:,]/", MODULE_ORDER_TOTAL_COD_FEE_TABLE);
  66. if ($_SESSION['shipping']['id'] == 'zones_zones') $cod_zones = preg_split("/[:,]/", MODULE_ORDER_TOTAL_COD_FEE_ZONES);
  67. if ($_SESSION['shipping']['id'] == 'ap_ap') $cod_zones = preg_split("/[:,]/", MODULE_ORDER_TOTAL_COD_FEE_AP);
  68. if ($_SESSION['shipping']['id'] == 'dp_dp') $cod_zones = preg_split("/[:,]/", MODULE_ORDER_TOTAL_COD_FEE_DP);
  69. if ($_SESSION['shipping']['id'] == 'chp_ECO') $cod_zones = preg_split("/[:,]/", MODULE_ORDER_TOTAL_COD_FEE_CHP);
  70. if ($_SESSION['shipping']['id'] == 'chp_PRI') $cod_zones = preg_split("/[:,]/", MODULE_ORDER_TOTAL_COD_FEE_CHP);
  71. if ($_SESSION['shipping']['id'] == 'chp_URG') $cod_zones = preg_split("/[:,]/", MODULE_ORDER_TOTAL_COD_FEE_CHP);
  72. if ($_SESSION['shipping']['id'] == 'chronopost_chronopost') $cod_zones = preg_split("/[:,]/", MODULE_ORDER_TOTAL_COD_FEE_CHRONOPOST);
  73. if ($_SESSION['shipping']['id'] == 'dhl_ECX') $cod_zones = preg_split("/[:,]/", MODULE_ORDER_TOTAL_COD_FEE_DHL);
  74. if ($_SESSION['shipping']['id'] == 'dhl_DOX') $cod_zones = preg_split("/[:,]/", MODULE_ORDER_TOTAL_COD_FEE_DHL);
  75. if ($_SESSION['shipping']['id'] == 'dhl_SDX') $cod_zones = preg_split("/[:,]/", MODULE_ORDER_TOTAL_COD_FEE_DHL);
  76. if ($_SESSION['shipping']['id'] == 'dhl_MDX') $cod_zones = preg_split("/[:,]/", MODULE_ORDER_TOTAL_COD_FEE_DHL);
  77. if ($_SESSION['shipping']['id'] == 'dhl_WPX') $cod_zones = preg_split("/[:,]/", MODULE_ORDER_TOTAL_COD_FEE_DHL);
  78. if ($_SESSION['shipping']['id'] == 'ups_ups') $cod_zones = preg_split("/[:,]/", MODULE_ORDER_TOTAL_COD_FEE_UPS);
  79. if ($_SESSION['shipping']['id'] == 'upse_upse') $cod_zones = preg_split("/[:,]/", MODULE_ORDER_TOTAL_COD_FEE_UPSE);
  80. if ($_SESSION['shipping']['id'] == 'free_free') $cod_zones = preg_split("/[:,]/", MODULE_ORDER_TOTAL_COD_FEE_FREE);
  81. if ($_SESSION['shipping']['id'] == 'freeamount_freeamount') $cod_zones = preg_split("/[:,]/", MODULE_ORDER_TOTAL_FREEAMOUNT_FREE);
  82. // EOF - Hetfield - 2009-08-18 - replaced deprecated function split with preg_split to be ready for PHP >= 5.3
  83. for ($i = 0; $i < count($cod_zones); $i++) {
  84. if ($cod_zones[$i] == $order->delivery['country']['iso_code_2']) {
  85. $cod_cost = $cod_zones[$i + 1];
  86. $cod_country = true;
  87. break;
  88. } elseif ($cod_zones[$i] == '00') {
  89. $cod_cost = $cod_zones[$i + 1];
  90. $cod_country = true;
  91. break;
  92. } else {
  93. }
  94. $i++;
  95. }
  96. } else {
  97. //COD selected, but no shipping module which offers COD
  98. }
  99. if ($cod_country) {
  100. $cod_tax = xtc_get_tax_rate(MODULE_ORDER_TOTAL_COD_FEE_TAX_CLASS, $order->delivery['country']['id'], $order->delivery['zone_id']);
  101. $cod_tax_description = xtc_get_tax_description(MODULE_ORDER_TOTAL_COD_FEE_TAX_CLASS, $order->delivery['country']['id'], $order->delivery['zone_id']);
  102. if ($_SESSION['customers_status']['customers_status_show_price_tax'] == 1) {
  103. $cod_cost_value= xtc_add_tax($cod_cost, $cod_tax);
  104. $cod_cost= $xtPrice->xtcFormat($cod_cost_value,true);
  105. }
  106. if ($_SESSION['customers_status']['customers_status_show_price_tax'] == 0 && $_SESSION['customers_status']['customers_status_add_tax_ot'] == 1) {
  107. $cod_cost_value=$cod_cost;
  108. $cod_cost= $xtPrice->xtcFormat($cod_cost,true);
  109. }
  110. if (!$cod_cost_value) {
  111. $cod_cost_value=$cod_cost;
  112. $cod_cost= $xtPrice->xtcFormat($cod_cost,true);
  113. }
  114. $this->cost = '+ '.$cod_cost;
  115. }
  116. return array ('id' => $this->code, 'module' => $this->title, 'description' => $this->info,'module_cost'=>$this->cost);
  117. }
  118. function pre_confirmation_check() {
  119. return false;
  120. }
  121. function confirmation() {
  122. return false;
  123. }
  124. function process_button() {
  125. return false;
  126. }
  127. function before_process() {
  128. return false;
  129. }
  130. function after_process() {
  131. global $insert_id;
  132. if ($this->order_status)
  133. xtc_db_query("UPDATE ".TABLE_ORDERS." SET orders_status='".$this->order_status."' WHERE orders_id='".$insert_id."'");
  134. }
  135. function get_error() {
  136. return false;
  137. }
  138. function check() {
  139. if (!isset ($this->_check)) {
  140. $check_query = xtc_db_query("select configuration_value from ".TABLE_CONFIGURATION." where configuration_key = 'MODULE_PAYMENT_COD_STATUS'");
  141. $this->_check = xtc_db_num_rows($check_query);
  142. }
  143. return $this->_check;
  144. }
  145. function install() {
  146. xtc_db_query("insert into ".TABLE_CONFIGURATION." ( configuration_key, configuration_value, configuration_group_id, sort_order, set_function, date_added) values ('MODULE_PAYMENT_COD_STATUS', 'True', '6', '1', 'xtc_cfg_select_option(array(\'True\', \'False\'), ', now())");
  147. xtc_db_query("insert into ".TABLE_CONFIGURATION." ( configuration_key, configuration_value, configuration_group_id, sort_order, date_added) values ('MODULE_PAYMENT_COD_ALLOWED', '', '6', '0', now())");
  148. xtc_db_query("insert into ".TABLE_CONFIGURATION." ( configuration_key, configuration_value, configuration_group_id, sort_order, use_function, set_function, date_added) values ('MODULE_PAYMENT_COD_ZONE', '0', '6', '2', 'xtc_get_zone_class_title', 'xtc_cfg_pull_down_zone_classes(', now())");
  149. xtc_db_query("insert into ".TABLE_CONFIGURATION." ( configuration_key, configuration_value, configuration_group_id, sort_order, date_added) values ('MODULE_PAYMENT_COD_SORT_ORDER', '0', '6', '0', now())");
  150. xtc_db_query("insert into ".TABLE_CONFIGURATION." ( configuration_key, configuration_value, configuration_group_id, sort_order, set_function, use_function, date_added) values ('MODULE_PAYMENT_COD_ORDER_STATUS_ID', '0','6', '0', 'xtc_cfg_pull_down_order_statuses(', 'xtc_get_order_status_name', now())");
  151. }
  152. function remove() {
  153. xtc_db_query("delete from ".TABLE_CONFIGURATION." where configuration_key in ('".implode("', '", $this->keys())."')");
  154. }
  155. function keys() {
  156. return array ('MODULE_PAYMENT_COD_STATUS', 'MODULE_PAYMENT_COD_ALLOWED', 'MODULE_PAYMENT_COD_ZONE', 'MODULE_PAYMENT_COD_ORDER_STATUS_ID', 'MODULE_PAYMENT_COD_SORT_ORDER');
  157. }
  158. }
  159. ?>