EmailScheduled.php 2.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596
  1. <?php
  2. namespace App\Models;
  3. use Illuminate\Database\Eloquent\Factories\HasFactory;
  4. use Illuminate\Database\Eloquent\Model;
  5. class EmailScheduled extends Model
  6. {
  7. use HasFactory;
  8. protected $table = 'email_scheduled';
  9. protected $fillable = [
  10. 'template_id',
  11. 'subject',
  12. 'content',
  13. 'scheduled_at',
  14. 'status',
  15. 'created_by',
  16. 'delivery_report'
  17. ];
  18. protected $casts = [
  19. 'scheduled_at' => 'datetime',
  20. 'delivery_report' => 'array',
  21. 'created_at' => 'datetime',
  22. 'updated_at' => 'datetime',
  23. ];
  24. public function template()
  25. {
  26. return $this->belongsTo(EmailTemplate::class, 'template_id');
  27. }
  28. public function creator()
  29. {
  30. return $this->belongsTo(User::class, 'created_by');
  31. }
  32. public function recipients()
  33. {
  34. return $this->belongsToMany(User::class, 'email_scheduled_recipients', 'email_scheduled_id', 'user_id')
  35. ->withPivot(['email_address', 'status', 'error_message', 'sent_at'])
  36. ->withTimestamps();
  37. }
  38. public function recipientDetails()
  39. {
  40. return $this->hasMany(EmailScheduledRecipient::class, 'email_scheduled_id');
  41. }
  42. public function scopeScheduled($query)
  43. {
  44. return $query->where('status', 'scheduled');
  45. }
  46. public function scopeSent($query)
  47. {
  48. return $query->where('status', 'sent');
  49. }
  50. public function scopeFailed($query)
  51. {
  52. return $query->where('status', 'failed');
  53. }
  54. public function getIsScheduledAttribute()
  55. {
  56. return $this->status === 'scheduled';
  57. }
  58. public function getIsSentAttribute()
  59. {
  60. return $this->status === 'sent';
  61. }
  62. public function getCanBeCancelledAttribute()
  63. {
  64. return $this->status === 'scheduled' && $this->scheduled_at->isFuture();
  65. }
  66. public function getTotalRecipientsAttribute()
  67. {
  68. return $this->recipients()->count();
  69. }
  70. public function getSuccessfulSendsAttribute()
  71. {
  72. return $this->recipientDetails()->where('status', 'sent')->count();
  73. }
  74. public function getFailedSendsAttribute()
  75. {
  76. return $this->recipientDetails()->where('status', 'failed')->count();
  77. }
  78. }