Fixes for quote reminder dates

This commit is contained in:
David Bomba 2024-06-24 10:22:16 +10:00
parent ffaf5259e6
commit 6ceef3695d
3 changed files with 109 additions and 79 deletions

View File

@ -434,7 +434,7 @@ class Quote extends BaseModel
/**
* @return bool
*/
public function isRemindable(): bool
public function canRemind(): bool
{
if (in_array($this->status_id, [self::STATUS_DRAFT, self::STATUS_APPROVED, self::STATUS_CONVERTED]) || $this->is_deleted)
return false;

View File

@ -29,7 +29,7 @@ class UpdateReminder extends AbstractService
$this->settings = $this->quote->client->getMergedSettings();
}
if (! $this->quote->isRemindable()) {
if (!$this->quote->canRemind()) {
$this->quote->next_send_date = null;
$this->quote->saveQuietly();
@ -45,8 +45,8 @@ class UpdateReminder extends AbstractService
$date_collection = collect();
if (is_null($this->quote->reminder1_sent) &&
$this->settings->schedule_reminder1 == 'after_quote_date') {
$reminder_date = Carbon::parse($this->quote->date)->startOfDay()->addDays($this->settings->num_days_reminder1);
$this->settings->quote_schedule_reminder1 == 'after_quote_date') {
$reminder_date = Carbon::parse($this->quote->date)->startOfDay()->addDays($this->settings->quote_num_days_reminder1);
if ($reminder_date->gt(now())) {
$date_collection->push($reminder_date);
@ -55,9 +55,9 @@ class UpdateReminder extends AbstractService
if (is_null($this->quote->reminder1_sent) &&
($this->quote->partial_due_date || $this->quote->due_date) &&
$this->settings->schedule_reminder1 == 'before_valid_until_date') {
$this->settings->quote_schedule_reminder1 == 'before_valid_until_date') {
$partial_or_due_date = ($this->quote->partial > 0 && isset($this->quote->partial_due_date)) ? $this->quote->partial_due_date : $this->quote->due_date;
$reminder_date = Carbon::parse($partial_or_due_date)->startOfDay()->subDays($this->settings->num_days_reminder1);
$reminder_date = Carbon::parse($partial_or_due_date)->startOfDay()->subDays($this->settings->quote_num_days_reminder1);
// nlog("1. {$reminder_date->format('Y-m-d')}");
if ($reminder_date->gt(now())) {
@ -67,10 +67,10 @@ class UpdateReminder extends AbstractService
if (is_null($this->quote->reminder1_sent) &&
($this->quote->partial_due_date || $this->quote->due_date) &&
$this->settings->schedule_reminder1 == 'after_valid_until_date') {
$this->settings->quote_schedule_reminder1 == 'after_valid_until_date') {
$partial_or_due_date = ($this->quote->partial > 0 && isset($this->quote->partial_due_date)) ? $this->quote->partial_due_date : $this->quote->due_date;
$reminder_date = Carbon::parse($partial_or_due_date)->startOfDay()->addDays($this->settings->num_days_reminder1);
$reminder_date = Carbon::parse($partial_or_due_date)->startOfDay()->addDays($this->settings->quote_num_days_reminder1);
// nlog("2. {$reminder_date->format('Y-m-d')}");
if ($reminder_date->gt(now())) {
@ -78,89 +78,89 @@ class UpdateReminder extends AbstractService
}
}
if (is_null($this->quote->reminder2_sent) &&
$this->settings->schedule_reminder2 == 'after_valid_until_date') {
$reminder_date = Carbon::parse($this->quote->date)->startOfDay()->addDays($this->settings->num_days_reminder2);
// if (is_null($this->quote->reminder2_sent) &&
// $this->settings->schedule_reminder2 == 'after_valid_until_date') {
// $reminder_date = Carbon::parse($this->quote->date)->startOfDay()->addDays($this->settings->num_days_reminder2);
if ($reminder_date->gt(now())) {
$date_collection->push($reminder_date);
}
}
// if ($reminder_date->gt(now())) {
// $date_collection->push($reminder_date);
// }
// }
if (is_null($this->quote->reminder2_sent) &&
($this->quote->partial_due_date || $this->quote->due_date) &&
$this->settings->schedule_reminder2 == 'before_valid_until_date') {
// if (is_null($this->quote->reminder2_sent) &&
// ($this->quote->partial_due_date || $this->quote->due_date) &&
// $this->settings->schedule_reminder2 == 'before_valid_until_date') {
$partial_or_due_date = ($this->quote->partial > 0 && isset($this->quote->partial_due_date)) ? $this->quote->partial_due_date : $this->quote->due_date;
$reminder_date = Carbon::parse($partial_or_due_date)->startOfDay()->subDays($this->settings->num_days_reminder2);
// nlog("3. {$reminder_date->format('Y-m-d')}");
// $partial_or_due_date = ($this->quote->partial > 0 && isset($this->quote->partial_due_date)) ? $this->quote->partial_due_date : $this->quote->due_date;
// $reminder_date = Carbon::parse($partial_or_due_date)->startOfDay()->subDays($this->settings->num_days_reminder2);
// // nlog("3. {$reminder_date->format('Y-m-d')}");
if ($reminder_date->gt(now())) {
$date_collection->push($reminder_date);
}
}
// if ($reminder_date->gt(now())) {
// $date_collection->push($reminder_date);
// }
// }
if (is_null($this->quote->reminder2_sent) &&
($this->quote->partial_due_date || $this->quote->due_date) &&
$this->settings->schedule_reminder2 == 'after_valid_until_date') {
// if (is_null($this->quote->reminder2_sent) &&
// ($this->quote->partial_due_date || $this->quote->due_date) &&
// $this->settings->schedule_reminder2 == 'after_valid_until_date') {
$partial_or_due_date = ($this->quote->partial > 0 && isset($this->quote->partial_due_date)) ? $this->quote->partial_due_date : $this->quote->due_date;
$reminder_date = Carbon::parse($partial_or_due_date)->startOfDay()->addDays($this->settings->num_days_reminder2);
// nlog("4. {$reminder_date->format('Y-m-d')}");
// $partial_or_due_date = ($this->quote->partial > 0 && isset($this->quote->partial_due_date)) ? $this->quote->partial_due_date : $this->quote->due_date;
// $reminder_date = Carbon::parse($partial_or_due_date)->startOfDay()->addDays($this->settings->num_days_reminder2);
// // nlog("4. {$reminder_date->format('Y-m-d')}");
if ($reminder_date->gt(now())) {
$date_collection->push($reminder_date);
}
}
// if ($reminder_date->gt(now())) {
// $date_collection->push($reminder_date);
// }
// }
if (is_null($this->quote->reminder3_sent) &&
$this->settings->schedule_reminder3 == 'after_valid_until_date') {
$reminder_date = Carbon::parse($this->quote->date)->startOfDay()->addDays($this->settings->num_days_reminder3);
// if (is_null($this->quote->reminder3_sent) &&
// $this->settings->schedule_reminder3 == 'after_valid_until_date') {
// $reminder_date = Carbon::parse($this->quote->date)->startOfDay()->addDays($this->settings->num_days_reminder3);
if ($reminder_date->gt(now())) {
$date_collection->push($reminder_date);
}
}
// if ($reminder_date->gt(now())) {
// $date_collection->push($reminder_date);
// }
// }
if (is_null($this->quote->reminder3_sent) &&
($this->quote->partial_due_date || $this->quote->due_date) &&
$this->settings->schedule_reminder3 == 'before_valid_until_date') {
// if (is_null($this->quote->reminder3_sent) &&
// ($this->quote->partial_due_date || $this->quote->due_date) &&
// $this->settings->schedule_reminder3 == 'before_valid_until_date') {
$partial_or_due_date = ($this->quote->partial > 0 && isset($this->quote->partial_due_date)) ? $this->quote->partial_due_date : $this->quote->due_date;
$reminder_date = Carbon::parse($partial_or_due_date)->startOfDay()->subDays($this->settings->num_days_reminder3);
// nlog("5. {$reminder_date->format('Y-m-d')}");
// $partial_or_due_date = ($this->quote->partial > 0 && isset($this->quote->partial_due_date)) ? $this->quote->partial_due_date : $this->quote->due_date;
// $reminder_date = Carbon::parse($partial_or_due_date)->startOfDay()->subDays($this->settings->num_days_reminder3);
// // nlog("5. {$reminder_date->format('Y-m-d')}");
if ($reminder_date->gt(now())) {
$date_collection->push($reminder_date);
}
}
// if ($reminder_date->gt(now())) {
// $date_collection->push($reminder_date);
// }
// }
if (is_null($this->quote->reminder3_sent) &&
($this->quote->partial_due_date || $this->quote->due_date) &&
$this->settings->schedule_reminder3 == 'after_valid_until_date') {
// if (is_null($this->quote->reminder3_sent) &&
// ($this->quote->partial_due_date || $this->quote->due_date) &&
// $this->settings->schedule_reminder3 == 'after_valid_until_date') {
$partial_or_due_date = ($this->quote->partial > 0 && isset($this->quote->partial_due_date)) ? $this->quote->partial_due_date : $this->quote->due_date;
$reminder_date = Carbon::parse($partial_or_due_date)->startOfDay()->addDays($this->settings->num_days_reminder3);
// nlog("6. {$reminder_date->format('Y-m-d')}");
// $partial_or_due_date = ($this->quote->partial > 0 && isset($this->quote->partial_due_date)) ? $this->quote->partial_due_date : $this->quote->due_date;
// $reminder_date = Carbon::parse($partial_or_due_date)->startOfDay()->addDays($this->settings->num_days_reminder3);
// // nlog("6. {$reminder_date->format('Y-m-d')}");
if ($reminder_date->gt(now())) {
$date_collection->push($reminder_date);
}
}
// if ($reminder_date->gt(now())) {
// $date_collection->push($reminder_date);
// }
// }
if ($this->quote->last_sent_date &&
$this->settings->enable_reminder_endless &&
($this->quote->reminder1_sent || $this->settings->schedule_reminder1 == "" || !$this->settings->enable_reminder1) &&
($this->quote->reminder2_sent || $this->settings->schedule_reminder2 == "" || !$this->settings->enable_reminder2) &&
($this->quote->reminder3_sent || $this->settings->schedule_reminder3 == "" || !$this->settings->enable_reminder3)) {
$reminder_date = $this->addTimeInterval($this->quote->last_sent_date, (int) $this->settings->endless_reminder_frequency_id);
// if ($this->quote->last_sent_date &&
// $this->settings->enable_reminder_endless &&
// ($this->quote->reminder1_sent || $this->settings->schedule_reminder1 == "" || !$this->settings->enable_reminder1) &&
// ($this->quote->reminder2_sent || $this->settings->schedule_reminder2 == "" || !$this->settings->enable_reminder2) &&
// ($this->quote->reminder3_sent || $this->settings->schedule_reminder3 == "" || !$this->settings->enable_reminder3)) {
// $reminder_date = $this->addTimeInterval($this->quote->last_sent_date, (int) $this->settings->endless_reminder_frequency_id);
if ($reminder_date) {
if ($reminder_date->gt(now())) {
$date_collection->push($reminder_date);
}
}
}
// if ($reminder_date) {
// if ($reminder_date->gt(now())) {
// $date_collection->push($reminder_date);
// }
// }
// }
if ($date_collection->count() >= 1 && $date_collection->sort()->first()->gte(now())) {
$this->quote->next_send_date = $date_collection->sort()->first()->addSeconds($offset);

View File

@ -160,12 +160,9 @@ class QuoteReminderTest extends TestCase
}
public function testReminderInThePast()
public function testNullReminder()
{
$translations = new \stdClass;
$translations->late_fee_added = "Fee added :date";
$settings = $this->company->settings;
$settings->enable_quote_reminder1 = false;
$settings->quote_schedule_reminder1 = '';
@ -183,6 +180,39 @@ class QuoteReminderTest extends TestCase
$this->quote = $this->quote->fresh();
$this->assertNull($this->quote->next_send_date);
}
public function testBeforeValidReminder()
{
$settings = $this->company->settings;
$settings->enable_quote_reminder1 = true;
$settings->quote_schedule_reminder1 = 'before_valid_until_date';
$settings->quote_num_days_reminder1 = 1;
$this->buildData(($settings));
$this->quote->date = now()->addMonth()->format('Y-m-d');
$this->quote->partial_due_date = null;
$this->quote->due_date = now()->addMonths(2)->format('Y-m-d');
$this->quote->last_sent_date = null;
$this->quote->next_send_date = null;
$this->quote->save();
$this->assertTrue($this->quote->canRemind());
$this->quote->service()->setReminder($settings)->save();
$this->quote = $this->quote->fresh();
$this->assertNotNull($this->quote->next_send_date);
nlog($this->quote->next_send_date);
$this->assertEquals(now()->addMonths(2)->subDay()->format('Y-m-d'), \Carbon\Carbon::parse($this->quote->next_send_date)->addSeconds($this->quote->client->timezone_offset())->format('Y-m-d'));
}
}