close #2975 Fixed: Recurring Invoice Custom Interval

This commit is contained in:
Cüneyt Şentürk 2023-08-28 15:40:55 +03:00
parent a83d446141
commit 8387830ecd
9 changed files with 73 additions and 8 deletions

View File

@ -22,10 +22,14 @@ class Schedule extends Component
->first();
$started_date = '<span class="font-medium">' . company_date($recurring->started_at) . '</span>';
$frequency = Str::lower(trans('recurring.' . str_replace('ly', 's', $recurring->frequency)));
$frequency = Str::lower(trans('recurring.' . str_replace(['daily', 'ly'], ['days', 's'], $recurring->frequency)));
$invertal = $recurring->interval;
$this->description = trans('transactions.slider.schedule', ['frequency' => $frequency, 'interval' => $invertal, 'date' => $started_date]);
$this->description = trans('transactions.slider.schedule', [
'frequency' => $frequency,
'interval' => $invertal,
'date' => $started_date
]);
return view('components.documents.show.schedule', compact('recurring'));
}

View File

@ -12,6 +12,8 @@ class Recurring extends Component
public $frequency;
public $frequencies = [];
public $interval = '';
public $customFrequency = '';
public $customFrequencies = [];
@ -35,6 +37,8 @@ class Recurring extends Component
$frequency = '',
$frequencies = [],
$interval = '',
$customFrequency = '',
$customFrequencies = [],
@ -49,10 +53,13 @@ class Recurring extends Component
$sendEmail = false
) {
$this->type = $this->getType($type);
$this->frequency = $this->getFrequency($frequency);
$this->interval = $this->getInterval($interval);
$this->frequency = $this->getFrequency($frequency, $interval);
$this->frequencies = $this->getFrequencies($frequencies);
$this->customFrequency = $this->getCustomFrequency($customFrequency);
$this->customFrequency = $this->getCustomFrequency($frequency, $customFrequency, $interval);
$this->customFrequencies = $this->getCustomFrequencies($customFrequencies);
$this->limit = $this->getLimit($limit);
@ -85,8 +92,12 @@ class Recurring extends Component
return 'invoice';
}
protected function getFrequency($frequency)
protected function getFrequency($frequency, $interval = 0)
{
if ($interval > 1) {
return 'custom';
}
if (! empty($frequency)) {
return $frequency;
}
@ -109,8 +120,21 @@ class Recurring extends Component
];
}
protected function getCustomFrequency($customFrequency)
protected function getInterval($interval)
{
if (! empty($interval)) {
return $interval;
}
return '';
}
protected function getCustomFrequency($frequency, $customFrequency, $interval = 0)
{
if ($interval > 1) {
return $frequency;
}
if (! empty($customFrequency)) {
return $customFrequency;
}

View File

@ -198,6 +198,11 @@ export default {
default: 'monthly',
description: "Default reccuring type"
},
intervalValue: {
type: String,
default: '',
description: 'Default interval value'
},
invertalError: {
type: String,
default: null,
@ -310,6 +315,7 @@ export default {
mounted() {
this.frequency = this.frequencyValue;
this.interval = this.intervalValue;
this.customFrequency = this.customFrequencyValue;
this.started_at = this.startedValue;

View File

@ -32,6 +32,7 @@ return [
'send_email_auto' => 'Send email automatically',
'frequency_type' => 'Repeat this :type',
'custom_frequency_desc' => 'Repeat every :interval :frequency',
'limit_date' => 'Create first :type on',
'limit_middle' => 'and end',

View File

@ -59,6 +59,7 @@
<x-slot name="body">
<x-form.group.recurring
type="transaction"
:interval="$recurring_transaction ? $recurring_transaction->recurring->interval : null"
:frequency="$recurring_transaction ? $recurring_transaction->recurring->frequency : null"
:custom-frequency="$recurring_transaction ? $recurring_transaction->recurring->custom_frequency : null"
:limit="$recurring_transaction ? $recurring_transaction->recurring->limit_by : null"

View File

@ -123,7 +123,20 @@
<x-table.td class="w-2/12" hidden-mobile>
<x-slot name="first">
@if ($item->recurring->interval > 1)
<x-tooltip
id="tooltip-frequency-{{ $item->recurring->id }}"
placement="top"
message="{{ trans('recurring.custom_frequency_desc', [
'interval' => $item->recurring->interval,
'frequency' => str()->lower(trans('recurring.' . str_replace(['daily', 'ly'], ['days', 's'], $item->recurring->frequency)))
]) }}"
>
{{ trans('recurring.custom') }}
</x-tooltip>
@else
{{ trans('recurring.' . $item->recurring->frequency) }}
@endif
</x-slot>
<x-slot name="second">
@if ($item->recurring->limit_by == 'count')

View File

@ -10,6 +10,7 @@
<x-form.group.recurring
:type="$type"
@started="onChangeRecurringDate()"
:interval="$document ? $document->recurring->interval : null"
:frequency="$document ? $document->recurring->frequency : null"
:custom-frequency="$document ? $document->recurring->custom_frequency : null"
:limit="$document ? $document->recurring->limit_by : null"

View File

@ -81,7 +81,20 @@
<x-table.td class="w-2/12" hidden-mobile>
<x-slot name="first">
@if ($item->recurring->interval > 1)
<x-tooltip
id="tooltip-frequency-{{ $item->recurring->id }}"
placement="top"
message="{{ trans('recurring.custom_frequency_desc', [
'interval' => $item->recurring->interval,
'frequency' => str()->lower(trans('recurring.' . str_replace(['daily', 'ly'], ['days', 's'], $item->recurring->frequency)))
]) }}"
>
{{ trans('recurring.custom') }}
</x-tooltip>
@else
{{ trans('recurring.' . $item->recurring->frequency) }}
@endif
</x-slot>
<x-slot name="second">
@if ($item->recurring->limit_by == 'count')

View File

@ -21,6 +21,8 @@
:custom-frequencies="{{ json_encode($customFrequencies) }}"
custom-frequency-value="{{ $customFrequency }}"
:custom-frequency-error="form.errors.get('recurring_custom_frequency')"
interval-value="{{ $interval }}"
@if ($attributes->has('@interval'))
@interval="form.recurring_interval = $event;{{ $attributes['@interval'] }}"
@else