Fooman_SameOrderInvoiceNumber - Version 2.0.5

Version Notes

prevent duplicates is now mandatory

Download this release

Release Info

Developer Magento Core Team
Extension Fooman_SameOrderInvoiceNumber
Version 2.0.5
Comparing to
See all releases


Code changes from version 2.0.1 to 2.0.5

app/code/community/Fooman/SameOrderInvoiceNumber/Model/Observer.php CHANGED
@@ -20,95 +20,95 @@
20
* @copyright Copyright (c) 2010 Fooman Limited (http://www.fooman.co.nz)
21
* @license http://opensource.org/licenses/osl-3.0.php Open Software License (OSL 3.0)
22
*/
23
-
24
class Fooman_SameOrderInvoiceNumber_Model_Observer
25
{
26
- public function sales_order_invoice_save_before($observer)
27
{
28
29
$invoice = $observer->getInvoice();
30
- $order = $invoice->getOrder();
31
- $storeId = $order->getStore()->getStoreId();
32
- $prefix = Mage::getStoreConfig('sameorderinvoicenumber/settings/invoiceprefix',$storeId);
33
- if (Mage::getStoreConfig('sameorderinvoicenumber/settings/preventduplicates',$storeId)) {
34
- $newInvoiceNr = 0;
35
- $currentPostfix = 0;
36
- while (!$newInvoiceNr) {
37
- if ($currentPostfix) {
38
- $newInvoiceNr = $prefix.$order->getIncrementId().'-'.$currentPostfix;
39
- } else {
40
- $newInvoiceNr = $prefix.$order->getIncrementId();
41
- }
42
- $collection = Mage::getModel('sales/order_invoice')->getCollection()->addFieldToFilter('increment_id',$newInvoiceNr);
43
- if($collection->getAllIds()){
44
- //number already exists
45
- $newInvoiceNr = 0;
46
- $currentPostfix++;
47
- } else {
48
- $invoice->setIncrementId($newInvoiceNr);
49
}
50
- }
51
- } else {
52
- $invoice->setIncrementId($prefix.$order->getIncrementId());
53
}
54
}
55
56
- public function sales_order_shipment_save_before($observer)
57
{
58
$shipment = $observer->getShipment();
59
- $order = $shipment->getOrder();
60
- $storeId = $order->getStore()->getStoreId();
61
- $prefix = Mage::getStoreConfig('sameorderinvoicenumber/settings/shipmentprefix',$storeId);
62
- if (Mage::getStoreConfig('sameorderinvoicenumber/settings/preventduplicates',$storeId)) {
63
- $newShipmentNr = 0;
64
- $currentPostfix = 0;
65
- while (!$newShipmentNr) {
66
- if ($currentPostfix) {
67
- $newShipmentNr = $prefix.$order->getIncrementId().'-'.$currentPostfix;
68
- } else {
69
- $newShipmentNr = $prefix.$order->getIncrementId();
70
}
71
- $collection = Mage::getModel('sales/order_shipment')->getCollection()->addFieldToFilter('increment_id',$newShipmentNr);
72
- if($collection->getAllIds()){
73
- //number already exists
74
- $newShipmentNr = 0;
75
- $currentPostfix++;
76
- } else {
77
- $shipment->setIncrementId($newShipmentNr);
78
- }
79
- }
80
- } else {
81
- $shipment->setIncrementId($prefix.$order->getIncrementId());
82
}
83
}
84
85
- public function sales_order_creditmemo_save_before($observer)
86
{
87
$creditmemo = $observer->getCreditmemo();
88
- $order = $creditmemo->getOrder();
89
- $storeId = $order->getStore()->getStoreId();
90
- $prefix = Mage::getStoreConfig('sameorderinvoicenumber/settings/creditmemoprefix',$storeId);
91
- if (Mage::getStoreConfig('sameorderinvoicenumber/settings/preventduplicates',$storeId)) {
92
- $newCreditmemoNr = 0;
93
- $currentPostfix = 0;
94
- while (!$newCreditmemoNr) {
95
- if ($currentPostfix) {
96
- $newCreditmemoNr = $prefix.$order->getIncrementId().'-'.$currentPostfix;
97
- } else {
98
- $newCreditmemoNr = $prefix.$order->getIncrementId();
99
- }
100
- $collection = Mage::getModel('sales/order_creditmemo')->getCollection()->addFieldToFilter('increment_id',$newCreditmemoNr);
101
- if($collection->getAllIds()){
102
- //number already exists
103
- $newCreditmemoNr = 0;
104
- $currentPostfix++;
105
- } else {
106
- $creditmemo->setIncrementId($newCreditmemoNr);
107
}
108
- }
109
- } else {
110
- $creditmemo->setIncrementId($prefix.$order->getIncrementId());
111
}
112
}
113
114
- }
20
* @copyright Copyright (c) 2010 Fooman Limited (http://www.fooman.co.nz)
21
* @license http://opensource.org/licenses/osl-3.0.php Open Software License (OSL 3.0)
22
*/
23
class Fooman_SameOrderInvoiceNumber_Model_Observer
24
{
25
+
26
+ public function sales_order_invoice_save_before ($observer)
27
{
28
29
$invoice = $observer->getInvoice();
30
+ if (!$invoice->getId()) {
31
+ $order = $invoice->getOrder();
32
+ $storeId = $order->getStore()->getStoreId();
33
+ $prefix = Mage::getStoreConfig('sameorderinvoicenumber/settings/invoiceprefix',
34
+ $storeId);
35
+ $newInvoiceNr = 0;
36
+ $currentPostfix = 0;
37
+ while (!$newInvoiceNr) {
38
+ if ($currentPostfix) {
39
+ $newInvoiceNr = $prefix . $order->getIncrementId() . '-' . $currentPostfix;
40
+ } else {
41
+ $newInvoiceNr = $prefix . $order->getIncrementId();
42
+ }
43
+ $collection = Mage::getModel('sales/order_invoice')->getCollection()->addFieldToFilter('increment_id',
44
+ $newInvoiceNr);
45
+ if ($collection->getAllIds()) {
46
+ //number already exists
47
+ $newInvoiceNr = 0;
48
+ $currentPostfix++;
49
+ } else {
50
+ $invoice->setIncrementId($newInvoiceNr);
51
+ }
52
}
53
}
54
}
55
56
+ public function sales_order_shipment_save_before ($observer)
57
{
58
$shipment = $observer->getShipment();
59
+ if (!$shipment->getId()) {
60
+ $order = $shipment->getOrder();
61
+ $storeId = $order->getStore()->getStoreId();
62
+ $prefix = Mage::getStoreConfig('sameorderinvoicenumber/settings/shipmentprefix',
63
+ $storeId);
64
+ $newShipmentNr = 0;
65
+ $currentPostfix = 0;
66
+ while (!$newShipmentNr) {
67
+ if ($currentPostfix) {
68
+ $newShipmentNr = $prefix . $order->getIncrementId() . '-' . $currentPostfix;
69
+ } else {
70
+ $newShipmentNr = $prefix . $order->getIncrementId();
71
+ }
72
+ $collection = Mage::getModel('sales/order_shipment')->getCollection()->addFieldToFilter('increment_id',
73
+ $newShipmentNr);
74
+ if ($collection->getAllIds()) {
75
+ //number already exists
76
+ $newShipmentNr = 0;
77
+ $currentPostfix++;
78
+ } else {
79
+ $shipment->setIncrementId($newShipmentNr);
80
+ }
81
}
82
}
83
}
84
85
+ public function sales_order_creditmemo_save_before ($observer)
86
{
87
$creditmemo = $observer->getCreditmemo();
88
+ if (!$creditmemo->getId()) {
89
+ $order = $creditmemo->getOrder();
90
+ $storeId = $order->getStore()->getStoreId();
91
+ $prefix = Mage::getStoreConfig('sameorderinvoicenumber/settings/creditmemoprefix',
92
+ $storeId);
93
+ $newCreditmemoNr = 0;
94
+ $currentPostfix = 0;
95
+ while (!$newCreditmemoNr) {
96
+ if ($currentPostfix) {
97
+ $newCreditmemoNr = $prefix . $order->getIncrementId() . '-' . $currentPostfix;
98
+ } else {
99
+ $newCreditmemoNr = $prefix . $order->getIncrementId();
100
+ }
101
+ $collection = Mage::getModel('sales/order_creditmemo')->getCollection()->addFieldToFilter('increment_id',
102
+ $newCreditmemoNr);
103
+ if ($collection->getAllIds()) {
104
+ //number already exists
105
+ $newCreditmemoNr = 0;
106
+ $currentPostfix++;
107
+ } else {
108
+ $creditmemo->setIncrementId($newCreditmemoNr);
109
+ }
110
}
111
}
112
}
113
114
+ }
app/code/community/Fooman/SameOrderInvoiceNumber/Model/Observer.php~ DELETED
@@ -1,117 +0,0 @@
1
- <?php
2
-
3
- /**
4
- * Fooman Order = Invoice Number
5
- *
6
- * Magento
7
- *
8
- * NOTICE OF LICENSE
9
- *
10
- * This source file is subject to the Open Software License (OSL 3.0)
11
- * that is bundled with this package in the file LICENSE.txt.
12
- * It is also available through the world-wide-web at this URL:
13
- * http://opensource.org/licenses/osl-3.0.php
14
- * If you did not receive a copy of the license and are unable to
15
- * obtain it through the world-wide-web, please send an email
16
- * to license@magentocommerce.com so we can send you a copy immediately.
17
- *
18
- * @category Fooman
19
- * @package SameOrderInvoiceNumber
20
- * @copyright Copyright (c) 2010 Fooman Limited (http://www.fooman.co.nz)
21
- * @license http://opensource.org/licenses/osl-3.0.php Open Software License (OSL 3.0)
22
- */
23
-
24
- class Fooman_SameOrderInvoiceNumber_Model_Observer
25
- {
26
- public function sales_order_invoice_save_before($observer)
27
- {
28
-
29
- $invoice = $observer->getInvoice();
30
- $order = $invoice->getOrder();
31
- $storeId = $order->getStore()->getStoreId();
32
- $prefix = Mage::getStoreConfig('sameorderinvoicenumber/settings/invoiceprefix',$storeId);
33
- if (Mage::getStoreConfig('sameorderinvoicenumber/settings/preventduplicates',$storeId)) {
34
- $newInvoiceNr = 0;
35
- $currentPostfix = 0;
36
- while (!$newInvoiceNr) {
37
- if ($currentPostfix) {
38
- $newInvoiceNr = $prefix.$order->getIncrementId().'-'.$currentPostfix;
39
- } else {
40
- $newInvoiceNr = $prefix.$order->getIncrementId();
41
- }
42
- Mage::log('$newInvoiceNr'.$newInvoiceNr);
43
- $collection = Mage::getModel('sales/order_invoice')->getCollection()->addFieldToFilter('increment_id',$newInvoiceNr);
44
- if($collection->getAllIds()){
45
- Mage::log('exists');
46
- Mage::log($collection->getAllIds());
47
- //number already exists
48
- $newInvoiceNr = 0;
49
- $currentPostfix++;
50
- } else {
51
- $invoice->setIncrementId($newInvoiceNr);
52
- }
53
- }
54
- } else {
55
- $invoice->setIncrementId($prefix.$order->getIncrementId());
56
- }
57
- }
58
-
59
- public function sales_order_shipment_save_before($observer)
60
- {
61
- $shipment = $observer->getShipment();
62
- $order = $shipment->getOrder();
63
- $storeId = $order->getStore()->getStoreId();
64
- $prefix = Mage::getStoreConfig('sameorderinvoicenumber/settings/shipmentprefix',$storeId);
65
- if (Mage::getStoreConfig('sameorderinvoicenumber/settings/preventduplicates',$storeId)) {
66
- $newShipmentNr = 0;
67
- $currentPostfix = 0;
68
- while (!$newShipmentNr) {
69
- if ($currentPostfix) {
70
- $newShipmentNr = $prefix.$order->getIncrementId().'-'.$currentPostfix;
71
- } else {
72
- $newShipmentNr = $prefix.$order->getIncrementId();
73
- }
74
- $collection = Mage::getModel('sales/order_shipment')->getCollection()->addFieldToFilter('increment_id',$newShipmentNr);
75
- if($collection->getAllIds()){
76
- //number already exists
77
- $newShipmentNr = 0;
78
- $currentPostfix++;
79
- } else {
80
- $shipment->setIncrementId($newShipmentNr);
81
- }
82
- }
83
- } else {
84
- $shipment->setIncrementId($prefix.$order->getIncrementId());
85
- }
86
- }
87
-
88
- public function sales_order_creditmemo_save_before($observer)
89
- {
90
- $creditmemo = $observer->getCreditmemo();
91
- $order = $creditmemo->getOrder();
92
- $storeId = $order->getStore()->getStoreId();
93
- $prefix = Mage::getStoreConfig('sameorderinvoicenumber/settings/creditmemoprefix',$storeId);
94
- if (Mage::getStoreConfig('sameorderinvoicenumber/settings/preventduplicates',$storeId)) {
95
- $newCreditmemoNr = 0;
96
- $currentPostfix = 0;
97
- while (!$newCreditmemoNr) {
98
- if ($currentPostfix) {
99
- $newCreditmemoNr = $prefix.$order->getIncrementId().'-'.$currentPostfix;
100
- } else {
101
- $newCreditmemoNr = $prefix.$order->getIncrementId();
102
- }
103
- $collection = Mage::getModel('sales/order_creditmemo')->getCollection()->addFieldToFilter('increment_id',$newCreditmemoNr);
104
- if($collection->getAllIds()){
105
- //number already exists
106
- $newCreditmemoNr = 0;
107
- $currentPostfix++;
108
- } else {
109
- $creditmemo->setIncrementId($newCreditmemoNr);
110
- }
111
- }
112
- } else {
113
- $creditmemo->setIncrementId($prefix.$order->getIncrementId());
114
- }
115
- }
116
-
117
- }
app/code/community/Fooman/SameOrderInvoiceNumber/etc/config.xml CHANGED
@@ -23,7 +23,7 @@
23
<config>
24
<modules>
25
<Fooman_SameOrderInvoiceNumber>
26
- <version>2.0.1</version>
27
<depends>
28
<Mage_Sales />
29
</depends>
23
<config>
24
<modules>
25
<Fooman_SameOrderInvoiceNumber>
26
+ <version>2.0.4</version>
27
<depends>
28
<Mage_Sales />
29
</depends>
app/code/community/Fooman/SameOrderInvoiceNumber/etc/system.xml CHANGED
@@ -18,16 +18,6 @@
18
<show_in_website>1</show_in_website>
19
<show_in_store>1</show_in_store>
20
<fields>
21
- <preventduplicates translate="label">
22
- <label>Prevent Duplicates</label>
23
- <frontend_type>select</frontend_type>
24
- <source_model>adminhtml/system_config_source_yesno</source_model>
25
- <comment>For orders with multiple invoices, shipments or creditmemos the numbers will be appended by -1,-2,...</comment>
26
- <sort_order>10</sort_order>
27
- <show_in_default>1</show_in_default>
28
- <show_in_website>1</show_in_website>
29
- <show_in_store>1</show_in_store>
30
- </preventduplicates>
31
<invoiceprefix translate="label">
32
<label>Invoice Prefix</label>
33
<frontend_type>text</frontend_type>
@@ -57,4 +47,4 @@
57
</groups>
58
</sameorderinvoicenumber>
59
</sections>
60
- </config>
18
<show_in_website>1</show_in_website>
19
<show_in_store>1</show_in_store>
20
<fields>
21
<invoiceprefix translate="label">
22
<label>Invoice Prefix</label>
23
<frontend_type>text</frontend_type>
47
</groups>
48
</sameorderinvoicenumber>
49
</sections>
50
+ </config>
package.xml CHANGED
@@ -1,7 +1,7 @@
1
<?xml version="1.0"?>
2
<package>
3
<name>Fooman_SameOrderInvoiceNumber</name>
4
- <version>2.0.1</version>
5
<stability>stable</stability>
6
<license uri="http://www.opensource.org/licenses/osl-3.0.php">OSL v3.0</license>
7
<channel>community</channel>
@@ -10,11 +10,11 @@
10
<description>&lt;p&gt;Use the order number as invoice,shipment and creditmemo number.&lt;/p&gt;
11
12
&lt;p&gt;By default Magento keeps separate counts for order and invoice numbers. This extension ensures that when an invoice is created it uses the related order number as invoice number.&lt;/p&gt;</description>
13
- <notes>stable release</notes>
14
<authors><author><name>Kristof Ringleff</name><user>auto-converted</user><email>kristof@fooman.co.nz</email></author></authors>
15
- <date>2010-12-22</date>
16
- <time>08:22:53</time>
17
- <contents><target name="mage"><dir name="app"><dir name="etc"><dir name="modules"><file name="Fooman_SameOrderInvoiceNumber.xml" hash="9c647ab0671752cda14b95db99dd7805"/></dir></dir></dir></target><target name="magecommunity"><dir name="Fooman"><dir name="SameOrderInvoiceNumber"><dir name="etc"><file name="config.xml" hash="302c6b442e750afb09117e334e35edb8"/><file name="system.xml" hash="0ecb4c0fda0b6803022841c1db388493"/></dir><dir name="Helper"><file name="Data.php" hash="2902afb6f8362656b9e1212091d04550"/></dir><dir name="Model"><file name="Observer.php" hash="f6b16960b7b7e0df1ab2747592953b55"/><file name="Observer.php~" hash="bb22e58aad1c4f37223653cc50e1aeeb"/></dir><file name="LICENSE.txt" hash="59563e7be45096d0833dade102989042"/><file name="LICENSE_AFL.txt" hash="45a399f2095030865fb962263ccd7506"/></dir></dir></target></contents>
18
<compatible/>
19
<dependencies/>
20
</package>
1
<?xml version="1.0"?>
2
<package>
3
<name>Fooman_SameOrderInvoiceNumber</name>
4
+ <version>2.0.5</version>
5
<stability>stable</stability>
6
<license uri="http://www.opensource.org/licenses/osl-3.0.php">OSL v3.0</license>
7
<channel>community</channel>
10
<description>&lt;p&gt;Use the order number as invoice,shipment and creditmemo number.&lt;/p&gt;
11
12
&lt;p&gt;By default Magento keeps separate counts for order and invoice numbers. This extension ensures that when an invoice is created it uses the related order number as invoice number.&lt;/p&gt;</description>
13
+ <notes>prevent duplicates is now mandatory</notes>
14
<authors><author><name>Kristof Ringleff</name><user>auto-converted</user><email>kristof@fooman.co.nz</email></author></authors>
15
+ <date>2012-02-05</date>
16
+ <time>20:50:29</time>
17
+ <contents><target name="mage"><dir name="app"><dir name="etc"><dir name="modules"><file name="Fooman_SameOrderInvoiceNumber.xml" hash="9c647ab0671752cda14b95db99dd7805"/></dir></dir></dir></target><target name="magecommunity"><dir name="Fooman"><dir name="SameOrderInvoiceNumber"><dir name="etc"><file name="config.xml" hash="cccd6bc82bb56fe6ab70210fb2eda5c7"/><file name="system.xml" hash="902bc08c44d3473fa86fbbc8968a7f26"/></dir><dir name="Helper"><file name="Data.php" hash="2902afb6f8362656b9e1212091d04550"/></dir><dir name="Model"><file name="Observer.php" hash="9fe79ff9d71a0b91440afece4b5f5fe5"/></dir><file name="LICENSE.txt" hash="59563e7be45096d0833dade102989042"/><file name="LICENSE_AFL.txt" hash="45a399f2095030865fb962263ccd7506"/></dir></dir></target></contents>
18
<compatible/>
19
<dependencies/>
20
</package>