Version Notes
Did we add new features?
Yes
Did you fix a bunch of Bugs?
Yes
Well then, what in funkytown did you do?
Added a fix for Magento bug #28112 which prevent Shipping Tablerates to work correctly.
You can enable /disable the fix on the configuration screen.
Download this release
Release Info
Developer | Gareth Price |
Extension | Clearandfizzy_Reducedcheckout |
Version | 1.4.0 |
Comparing to | |
See all releases |
Code changes from version 1.3.2 to 1.4.0
- app/code/community/Clearandfizzy/Reducedcheckout/Helper/Data.php +4 -3
- app/code/community/Clearandfizzy/Reducedcheckout/Model/Resource/Carrier/TablerateFix.php +92 -0
- app/code/community/Clearandfizzy/Reducedcheckout/etc/config.xml +13 -0
- app/code/community/Clearandfizzy/Reducedcheckout/etc/system.xml +12 -0
- package.xml +10 -8
app/code/community/Clearandfizzy/Reducedcheckout/Helper/Data.php
CHANGED
@@ -12,12 +12,15 @@ class Clearandfizzy_Reducedcheckout_Helper_Data extends Mage_Core_Helper_Abstrac
|
|
12 |
return $value;
|
13 |
} // end
|
14 |
|
15 |
-
|
16 |
public function isGuestCheckoutOnly() {
|
17 |
$value = Mage::getStoreConfig('clearandfizzy_reducedcheckout_settings/reducedcheckout/guestcheckoutonly');
|
18 |
return $value;
|
19 |
} // end
|
20 |
|
|
|
|
|
|
|
|
|
21 |
|
22 |
public function getCustomerGroupsEnabled() {
|
23 |
$value = Mage::getStoreConfig('clearandfizzy_reducedcheckout_settings/reducedcheckout_customergroups/customergroups_enabled');
|
@@ -48,8 +51,6 @@ class Clearandfizzy_Reducedcheckout_Helper_Data extends Mage_Core_Helper_Abstrac
|
|
48 |
return $value;
|
49 |
} // end
|
50 |
|
51 |
-
|
52 |
-
|
53 |
/**
|
54 |
* Returns the current logged in customers group.
|
55 |
* If the customer is not logged in return false
|
12 |
return $value;
|
13 |
} // end
|
14 |
|
|
|
15 |
public function isGuestCheckoutOnly() {
|
16 |
$value = Mage::getStoreConfig('clearandfizzy_reducedcheckout_settings/reducedcheckout/guestcheckoutonly');
|
17 |
return $value;
|
18 |
} // end
|
19 |
|
20 |
+
public function isFix28112Enabled() {
|
21 |
+
$value = Mage::getStoreConfig('clearandfizzy_reducedcheckout_settings/reducedcheckout/enable28112fix');
|
22 |
+
return $value;
|
23 |
+
} // end
|
24 |
|
25 |
public function getCustomerGroupsEnabled() {
|
26 |
$value = Mage::getStoreConfig('clearandfizzy_reducedcheckout_settings/reducedcheckout_customergroups/customergroups_enabled');
|
51 |
return $value;
|
52 |
} // end
|
53 |
|
|
|
|
|
54 |
/**
|
55 |
* Returns the current logged in customers group.
|
56 |
* If the customer is not logged in return false
|
app/code/community/Clearandfizzy/Reducedcheckout/Model/Resource/Carrier/TablerateFix.php
ADDED
@@ -0,0 +1,92 @@
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
1 |
+
<?php
|
2 |
+
|
3 |
+
class Clearandfizzy_ReducedCheckout_Model_Resource_Carrier_TablerateFix extends Mage_Shipping_Model_Resource_Carrier_Tablerate
|
4 |
+
{
|
5 |
+
|
6 |
+
/**
|
7 |
+
* (non-PHPdoc)
|
8 |
+
* @see Mage_Shipping_Model_Resource_Carrier_Tablerate::getRate()
|
9 |
+
*/
|
10 |
+
public function getRate(Mage_Shipping_Model_Rate_Request $request) {
|
11 |
+
if ( Mage::helper('clearandfizzy_reducedcheckout')->isFix28112Enabled() ) {
|
12 |
+
return $this->__getRate($request);
|
13 |
+
} // end
|
14 |
+
|
15 |
+
// otherwise return the magento code
|
16 |
+
return parent::getRate($request);
|
17 |
+
|
18 |
+
} // end fun
|
19 |
+
|
20 |
+
/**
|
21 |
+
* This is a bug fix for
|
22 |
+
* (non-PHPdoc)
|
23 |
+
* @see Mage_Shipping_Model_Resource_Carrier_Tablerate::getRate()
|
24 |
+
*/
|
25 |
+
private function __getRate(Mage_Shipping_Model_Rate_Request $request) {
|
26 |
+
$adapter = $this->_getReadAdapter();
|
27 |
+
|
28 |
+
$bind = array(
|
29 |
+
':website_id' => (int) $request->getWebsiteId(),
|
30 |
+
':country_id' => $request->getDestCountryId(),
|
31 |
+
':region_id' => (int) $request->getDestRegionId(),
|
32 |
+
':postcode' => $request->getDestPostcode()
|
33 |
+
);
|
34 |
+
|
35 |
+
// condition_value DESC fix
|
36 |
+
$select = $adapter->select()
|
37 |
+
->from($this->getMainTable())
|
38 |
+
->where('website_id = :website_id')
|
39 |
+
->order(array('dest_country_id DESC', 'dest_region_id DESC', 'dest_zip DESC', 'condition_value DESC'))
|
40 |
+
->limit(1);
|
41 |
+
|
42 |
+
// Render destination condition
|
43 |
+
$orWhere = '(' . implode(') OR (', array(
|
44 |
+
"dest_country_id = :country_id AND dest_region_id = :region_id AND dest_zip = :postcode",
|
45 |
+
"dest_country_id = :country_id AND dest_region_id = :region_id AND dest_zip = ''",
|
46 |
+
|
47 |
+
// Handle asterix in dest_zip field
|
48 |
+
"dest_country_id = :country_id AND dest_region_id = :region_id AND dest_zip = '*'",
|
49 |
+
"dest_country_id = :country_id AND dest_region_id = 0 AND dest_zip = '*'",
|
50 |
+
"dest_country_id = '0' AND dest_region_id = :region_id AND dest_zip = '*'",
|
51 |
+
"dest_country_id = '0' AND dest_region_id = 0 AND dest_zip = '*'",
|
52 |
+
|
53 |
+
"dest_country_id = :country_id AND dest_region_id = 0 AND dest_zip = ''",
|
54 |
+
"dest_country_id = :country_id AND dest_region_id = 0 AND dest_zip = :postcode",
|
55 |
+
"dest_country_id = :country_id AND dest_region_id = 0 AND dest_zip = '*'",
|
56 |
+
)) . ')';
|
57 |
+
$select->where($orWhere);
|
58 |
+
|
59 |
+
// Render condition by condition name
|
60 |
+
if (is_array($request->getConditionName())) {
|
61 |
+
$orWhere = array();
|
62 |
+
$i = 0;
|
63 |
+
foreach ($request->getConditionName() as $conditionName) {
|
64 |
+
$bindNameKey = sprintf(':condition_name_%d', $i);
|
65 |
+
$bindValueKey = sprintf(':condition_value_%d', $i);
|
66 |
+
$orWhere[] = "(condition_name = {$bindNameKey} AND condition_value <= {$bindValueKey})";
|
67 |
+
$bind[$bindNameKey] = $conditionName;
|
68 |
+
$bind[$bindValueKey] = $request->getData($conditionName);
|
69 |
+
$i++;
|
70 |
+
}
|
71 |
+
|
72 |
+
if ($orWhere) {
|
73 |
+
$select->where(implode(' OR ', $orWhere));
|
74 |
+
}
|
75 |
+
} else {
|
76 |
+
$bind[':condition_name'] = $request->getConditionName();
|
77 |
+
$bind[':condition_value'] = $request->getData($request->getConditionName());
|
78 |
+
|
79 |
+
$select->where('condition_name = :condition_name');
|
80 |
+
$select->where('condition_value <= :condition_value');
|
81 |
+
}
|
82 |
+
|
83 |
+
$result = $adapter->fetchRow($select, $bind);
|
84 |
+
// Normalize destination zip code
|
85 |
+
if ($result && $result['dest_zip'] == '*') {
|
86 |
+
$result['dest_zip'] = '';
|
87 |
+
}
|
88 |
+
return $result;
|
89 |
+
|
90 |
+
} // end
|
91 |
+
|
92 |
+
} // end
|
app/code/community/Clearandfizzy/Reducedcheckout/etc/config.xml
CHANGED
@@ -20,6 +20,19 @@
|
|
20 |
<clearandfizzy_reducedcheckout>
|
21 |
<class>Clearandfizzy_Reducedcheckout_Model</class>
|
22 |
</clearandfizzy_reducedcheckout>
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
23 |
</models>
|
24 |
|
25 |
<helpers>
|
20 |
<clearandfizzy_reducedcheckout>
|
21 |
<class>Clearandfizzy_Reducedcheckout_Model</class>
|
22 |
</clearandfizzy_reducedcheckout>
|
23 |
+
|
24 |
+
<shipping_resource>
|
25 |
+
<rewrite>
|
26 |
+
|
27 |
+
|
28 |
+
<carrier_tablerate>Clearandfizzy_ReducedCheckout_Model_Resource_Carrier_TablerateFix</carrier_tablerate>
|
29 |
+
|
30 |
+
|
31 |
+
|
32 |
+
</rewrite>
|
33 |
+
</shipping_resource>
|
34 |
+
|
35 |
+
|
36 |
</models>
|
37 |
|
38 |
<helpers>
|
app/code/community/Clearandfizzy/Reducedcheckout/etc/system.xml
CHANGED
@@ -54,6 +54,7 @@
|
|
54 |
<li>Allows forced Guest Registration.</li>
|
55 |
<li>Allows forced Payment method.</li>
|
56 |
<li>Allows forced Shipping method.</li>
|
|
|
57 |
<li>Allows you to setup rules based on Customer groups.</li>
|
58 |
<li><a target="_blank" href="http://www.magentocommerce.com/magento-connect/clearandfizzy-reduced-one-step-checkout-6893.html">http://www.magentocommerce.com/magento-connect/clearandfizzy-reduced-one-step-checkout-6893.html</a>
|
59 |
</ol> ]]></comment>
|
@@ -80,6 +81,17 @@
|
|
80 |
<show_in_website>1</show_in_website>
|
81 |
<show_in_store>1</show_in_store>
|
82 |
</isenabled>
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
83 |
|
84 |
<guestcheckoutonly>
|
85 |
<label>Force guest checkout only</label>
|
54 |
<li>Allows forced Guest Registration.</li>
|
55 |
<li>Allows forced Payment method.</li>
|
56 |
<li>Allows forced Shipping method.</li>
|
57 |
+
<li>Fix for Magento Shipping Tablerates in 1.7.0.2 <a target="_blank" href="http://www.magentocommerce.com/bug-tracking/issue?issue=14069">http://www.magentocommerce.com/bug-tracking/issue?issue=14069</a></li>
|
58 |
<li>Allows you to setup rules based on Customer groups.</li>
|
59 |
<li><a target="_blank" href="http://www.magentocommerce.com/magento-connect/clearandfizzy-reduced-one-step-checkout-6893.html">http://www.magentocommerce.com/magento-connect/clearandfizzy-reduced-one-step-checkout-6893.html</a>
|
60 |
</ol> ]]></comment>
|
81 |
<show_in_website>1</show_in_website>
|
82 |
<show_in_store>1</show_in_store>
|
83 |
</isenabled>
|
84 |
+
|
85 |
+
<enable28112fix>
|
86 |
+
<label>Enable Shipping Tablerates Bug #28112 fix</label>
|
87 |
+
<frontend_type>select</frontend_type>
|
88 |
+
<source_model>adminhtml/system_config_source_yesno</source_model>
|
89 |
+
<comment>Enable fix for Magento bug #28112 Shipping tablerates</comment>
|
90 |
+
<sort_order>1</sort_order>
|
91 |
+
<show_in_default>1</show_in_default>
|
92 |
+
<show_in_website>1</show_in_website>
|
93 |
+
<show_in_store>1</show_in_store>
|
94 |
+
</enable28112fix>
|
95 |
|
96 |
<guestcheckoutonly>
|
97 |
<label>Force guest checkout only</label>
|
package.xml
CHANGED
@@ -1,15 +1,17 @@
|
|
1 |
<?xml version="1.0"?>
|
2 |
<package>
|
3 |
<name>Clearandfizzy_Reducedcheckout</name>
|
4 |
-
<version>1.
|
5 |
<stability>stable</stability>
|
6 |
-
<license uri="http://
|
7 |
<channel>community</channel>
|
8 |
<extends/>
|
9 |
<summary>The standard Magento checkout process but allows you to force payment and shipping methods. </summary>
|
10 |
<description>Extending the standard Magento checkout process this extension allows you reduce the number of steps a customer takes to a minimum, by allowing you to force one type of payment and shipping method within the admin screen and therefore remove these steps from the checkout process. 
|
11 |

|
12 |
-
Integration with 3rd-party payment and shipping extensions should be easy as this extension makes no modifications to the base templates
|
|
|
|
|
13 |
<notes>Did we add new features?<br />
|
14 |
Yes<br />
|
15 |
<br />
|
@@ -17,12 +19,12 @@ Did you fix a bunch of Bugs?<br />
|
|
17 |
Yes<br />
|
18 |
<br />
|
19 |
Well then, what in funkytown did you do?<br />
|
20 |
-
Added
|
21 |
-
|
22 |
<authors><author><name>Gareth Price</name><user>clearandfizzy</user><email>gareth@clearandfizzy.com</email></author></authors>
|
23 |
-
<date>2013-
|
24 |
-
<time>
|
25 |
-
<contents><target name="magecommunity"><dir name="Clearandfizzy"><dir name="Reducedcheckout"><dir name="Helper"><file name="Data.php" hash="
|
26 |
<compatible/>
|
27 |
<dependencies><required><php><min>5.2.0</min><max>6.0.0</max></php></required></dependencies>
|
28 |
</package>
|
1 |
<?xml version="1.0"?>
|
2 |
<package>
|
3 |
<name>Clearandfizzy_Reducedcheckout</name>
|
4 |
+
<version>1.4.0</version>
|
5 |
<stability>stable</stability>
|
6 |
+
<license uri="http://creativecommons.org/licenses/by-nd/3.0/">CC BY-ND 3.0</license>
|
7 |
<channel>community</channel>
|
8 |
<extends/>
|
9 |
<summary>The standard Magento checkout process but allows you to force payment and shipping methods. </summary>
|
10 |
<description>Extending the standard Magento checkout process this extension allows you reduce the number of steps a customer takes to a minimum, by allowing you to force one type of payment and shipping method within the admin screen and therefore remove these steps from the checkout process. 
|
11 |

|
12 |
+
Integration with 3rd-party payment and shipping extensions should be easy as this extension makes no modifications to the base templates.
|
13 |
+

|
14 |
+
Contains a fix for Magento bug #28112 with regards to Shipping Tablerates.</description>
|
15 |
<notes>Did we add new features?<br />
|
16 |
Yes<br />
|
17 |
<br />
|
19 |
Yes<br />
|
20 |
<br />
|
21 |
Well then, what in funkytown did you do?<br />
|
22 |
+
Added a fix for Magento bug #28112 which prevent Shipping Tablerates to work correctly.<br /> 
|
23 |
+
You can enable /disable the fix on the configuration screen.<br /></notes>
|
24 |
<authors><author><name>Gareth Price</name><user>clearandfizzy</user><email>gareth@clearandfizzy.com</email></author></authors>
|
25 |
+
<date>2013-09-08</date>
|
26 |
+
<time>22:45:59</time>
|
27 |
+
<contents><target name="magecommunity"><dir name="Clearandfizzy"><dir name="Reducedcheckout"><dir name="Helper"><file name="Data.php" hash="23f488e4f752563e3343c6ea02004ac3"/></dir><dir name="Model"><file name="Observer.php" hash="8f4498205db5d37752b3f795816517b4"/><dir name="Resource"><dir name="Carrier"><file name="TablerateFix.php" hash="0a8685c145d95ae76b838d2af2b88638"/></dir></dir><dir name="System"><dir name="Config"><dir name="Source"><dir name="Payment"><file name="EnabledMethods.php" hash="f6b69e6fc6697870c53c6c86dbd68e98"/></dir><dir name="Shipping"><file name="EnabledMethods.php" hash="5cf16d02a105f9699e4258bb5bc57364"/></dir></dir></dir></dir></dir><dir name="controllers"><file name="OnepageController.php" hash="8d8d7ee733035d27a202cbd277041267"/></dir><dir name="etc"><file name="adminhtml.xml" hash="0bb1372118e88ad09fbd1b1d5113dea7"/><file name="config.xml" hash="a3071a3f2a7c9988ee42b4c72a8f1eb0"/><file name="system.xml" hash="7b3d424939a66fd0a31de7e33f54229b"/></dir></dir></dir></target><target name="mageetc"><dir name="modules"><file name="Clearandfizzy_ReducedCheckout.xml" hash="9cb58e8121e0c0e294f10a3595b2be7d"/></dir></target><target name="magedesign"><dir><dir name="frontend"><dir name="base"><dir name="default"><dir name="layout"><dir name="clearandfizzy"><dir name="reducedcheckout"><file name="reducedcheckout.xml" hash="282aeb07fe3b9510bcbd92498907968f"/></dir></dir></dir><dir name="template"><dir name="clearandfizzy"><dir name="reducedcheckout"><file name="onepage.phtml" hash="21921ab772ef02af217c49200619f2d5"/></dir></dir></dir></dir></dir></dir></dir></target></contents>
|
28 |
<compatible/>
|
29 |
<dependencies><required><php><min>5.2.0</min><max>6.0.0</max></php></required></dependencies>
|
30 |
</package>
|