mirror of
https://github.com/invoiceninja/invoiceninja.git
synced 2024-11-12 22:22:32 +01:00
Prevent converting a qoute from incrementing the counter
This commit is contained in:
parent
e6a05509b1
commit
51d9b2b427
@ -652,30 +652,34 @@ class Account extends Eloquent
|
|||||||
public function getNextInvoiceNumber($invoice)
|
public function getNextInvoiceNumber($invoice)
|
||||||
{
|
{
|
||||||
if ($this->hasNumberPattern($invoice->invoice_type_id)) {
|
if ($this->hasNumberPattern($invoice->invoice_type_id)) {
|
||||||
return $this->getNumberPattern($invoice);
|
$number = $this->getNumberPattern($invoice);
|
||||||
|
} else {
|
||||||
|
$counter = $this->getCounter($invoice->invoice_type_id);
|
||||||
|
$prefix = $this->getNumberPrefix($invoice->invoice_type_id);
|
||||||
|
$counterOffset = 0;
|
||||||
|
|
||||||
|
// confirm the invoice number isn't already taken
|
||||||
|
do {
|
||||||
|
$number = $prefix . str_pad($counter, $this->invoice_number_padding, '0', STR_PAD_LEFT);
|
||||||
|
$check = Invoice::scope(false, $this->id)->whereInvoiceNumber($number)->withTrashed()->first();
|
||||||
|
$counter++;
|
||||||
|
$counterOffset++;
|
||||||
|
} while ($check);
|
||||||
|
|
||||||
|
// update the invoice counter to be caught up
|
||||||
|
if ($counterOffset > 1) {
|
||||||
|
if ($invoice->isType(INVOICE_TYPE_QUOTE) && !$this->share_counter) {
|
||||||
|
$this->quote_number_counter += $counterOffset - 1;
|
||||||
|
} else {
|
||||||
|
$this->invoice_number_counter += $counterOffset - 1;
|
||||||
|
}
|
||||||
|
|
||||||
|
$this->save();
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
$counter = $this->getCounter($invoice->invoice_type_id);
|
if ($invoice->recurring_invoice_id) {
|
||||||
$prefix = $this->getNumberPrefix($invoice->invoice_type_id);
|
$number = $this->recurring_invoice_number_prefix . $number;
|
||||||
$counterOffset = 0;
|
|
||||||
|
|
||||||
// confirm the invoice number isn't already taken
|
|
||||||
do {
|
|
||||||
$number = $prefix . str_pad($counter, $this->invoice_number_padding, '0', STR_PAD_LEFT);
|
|
||||||
$check = Invoice::scope(false, $this->id)->whereInvoiceNumber($number)->withTrashed()->first();
|
|
||||||
$counter++;
|
|
||||||
$counterOffset++;
|
|
||||||
} while ($check);
|
|
||||||
|
|
||||||
// update the invoice counter to be caught up
|
|
||||||
if ($counterOffset > 1) {
|
|
||||||
if ($invoice->isType(INVOICE_TYPE_QUOTE) && !$this->share_counter) {
|
|
||||||
$this->quote_number_counter += $counterOffset - 1;
|
|
||||||
} else {
|
|
||||||
$this->invoice_number_counter += $counterOffset - 1;
|
|
||||||
}
|
|
||||||
|
|
||||||
$this->save();
|
|
||||||
}
|
}
|
||||||
|
|
||||||
return $number;
|
return $number;
|
||||||
@ -683,17 +687,15 @@ class Account extends Eloquent
|
|||||||
|
|
||||||
public function incrementCounter($invoice)
|
public function incrementCounter($invoice)
|
||||||
{
|
{
|
||||||
|
// if they didn't use the counter don't increment it
|
||||||
|
if ($invoice->invoice_number != $this->getNextInvoiceNumber($invoice)) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
if ($invoice->isType(INVOICE_TYPE_QUOTE) && !$this->share_counter) {
|
if ($invoice->isType(INVOICE_TYPE_QUOTE) && !$this->share_counter) {
|
||||||
$this->quote_number_counter += 1;
|
$this->quote_number_counter += 1;
|
||||||
} else {
|
} else {
|
||||||
$default = $this->invoice_number_counter;
|
$this->invoice_number_counter += 1;
|
||||||
$actual = Utils::parseInt($invoice->invoice_number);
|
|
||||||
|
|
||||||
if ( ! $this->hasFeature(FEATURE_INVOICE_SETTINGS) && $default != $actual) {
|
|
||||||
$this->invoice_number_counter = $actual + 1;
|
|
||||||
} else {
|
|
||||||
$this->invoice_number_counter += 1;
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
$this->save();
|
$this->save();
|
||||||
|
@ -741,7 +741,7 @@ class InvoiceRepository extends BaseRepository
|
|||||||
$invoice = Invoice::createNew($recurInvoice);
|
$invoice = Invoice::createNew($recurInvoice);
|
||||||
$invoice->client_id = $recurInvoice->client_id;
|
$invoice->client_id = $recurInvoice->client_id;
|
||||||
$invoice->recurring_invoice_id = $recurInvoice->id;
|
$invoice->recurring_invoice_id = $recurInvoice->id;
|
||||||
$invoice->invoice_number = $recurInvoice->account->recurring_invoice_number_prefix . $recurInvoice->account->getNextInvoiceNumber($recurInvoice);
|
$invoice->invoice_number = $recurInvoice->account->getNextInvoiceNumber($invoice);
|
||||||
$invoice->amount = $recurInvoice->amount;
|
$invoice->amount = $recurInvoice->amount;
|
||||||
$invoice->balance = $recurInvoice->amount;
|
$invoice->balance = $recurInvoice->amount;
|
||||||
$invoice->invoice_date = date_create()->format('Y-m-d');
|
$invoice->invoice_date = date_create()->format('Y-m-d');
|
||||||
|
Loading…
Reference in New Issue
Block a user