fixed transaction recurring duplicate issue
This commit is contained in:
parent
b91951547d
commit
5026356289
|
|
@ -322,7 +322,7 @@ class Transaction extends Model
|
|||
$suffix = $src->isRecurringTransaction() ? '-recurring' : '';
|
||||
}
|
||||
|
||||
$this->number = $this->getNextTransactionNumber($suffix);
|
||||
$this->number = $this->getNextTransactionNumber($this->type, $suffix);
|
||||
$this->document_id = null;
|
||||
$this->split_id = null;
|
||||
unset($this->reconciled);
|
||||
|
|
|
|||
|
|
@ -15,16 +15,16 @@ class TransactionNumber implements TransactionNumberInterface
|
|||
$digit = (int) setting('transaction' . $suffix . '.number_digit');
|
||||
|
||||
$get_number = fn($prefix, $next, $digit) => $prefix . str_pad($next, $digit, '0', STR_PAD_LEFT);
|
||||
$number_exists = fn($number) => Transaction::where('number', $number)->exists();
|
||||
$number_exists = fn($type, $number) => $this->numberExists($type, $number);
|
||||
|
||||
$transaction_number = $get_number($prefix, $next, $digit);
|
||||
|
||||
if ($number_exists($transaction_number)) {
|
||||
if ($number_exists($type, $transaction_number)) {
|
||||
do {
|
||||
$next++;
|
||||
|
||||
$transaction_number = $get_number($prefix, $next, $digit);
|
||||
} while ($number_exists($transaction_number));
|
||||
} while ($number_exists($type, $transaction_number));
|
||||
|
||||
setting(['transaction' . $suffix . '.number_next' => $next]);
|
||||
setting()->save();
|
||||
|
|
@ -34,6 +34,23 @@ class TransactionNumber implements TransactionNumberInterface
|
|||
|
||||
}
|
||||
|
||||
public function numberExists($type, $number)
|
||||
{
|
||||
$number_exists = new Transaction;
|
||||
|
||||
if (Str::endsWith($type, '-recurring')) {
|
||||
$number_exists = $number_exists->isRecurring();
|
||||
}
|
||||
|
||||
if (Str::endsWith($type, '-split')) {
|
||||
$number_exists = $number_exists->isSplitTransaction();
|
||||
}
|
||||
|
||||
$number_exists = $number_exists->where('number', $number);
|
||||
|
||||
return $number_exists->exists();
|
||||
}
|
||||
|
||||
public function increaseNextNumber($type, $suffix = '', ?Contact $contact): void
|
||||
{
|
||||
$next = setting('transaction' . $suffix . '.number_next', 1) + 1;
|
||||
|
|
|
|||
Loading…
Reference in New Issue