Expand and simplify vacancy update notification

This commit is contained in:
Miguel Nogueira 2022-02-11 01:55:01 +00:00
parent 572d750711
commit 784c8f6595
2 changed files with 26 additions and 12 deletions

View File

@ -25,10 +25,11 @@ use App\Facades\JSON;
use App\Form; use App\Form;
use App\Http\Requests\VacancyEditRequest; use App\Http\Requests\VacancyEditRequest;
use App\Http\Requests\VacancyRequest; use App\Http\Requests\VacancyRequest;
use App\Notifications\VacancyClosed; use App\Notifications\VacancyStatusUpdated;
use App\User; use App\User;
use App\Vacancy; use App\Vacancy;
use Illuminate\Http\Request; use Illuminate\Http\Request;
use Illuminate\Support\Facades\Notification;
use Illuminate\Support\Str; use Illuminate\Support\Str;
class VacancyController extends Controller class VacancyController extends Controller
@ -102,11 +103,6 @@ class VacancyController extends Controller
$vacancy->close(); $vacancy->close();
$message = __('Position successfully closed!'); $message = __('Position successfully closed!');
foreach (User::all() as $user) { // Avoid the ghost account
if ($user->isStaffMember() && $user->id != 1) {
$user->notify(new VacancyClosed($vacancy));
}
}
break; break;
default: default:
@ -114,11 +110,17 @@ class VacancyController extends Controller
$type = 'error'; $type = 'error';
} }
} else { } else {
$message = __("The position you're trying to update doesn't exist!"); $message = __("The position you're trying to update doesn't exist!");
$type = 'error'; $type = 'error';
} }
if ($type !== 'error') {
Notification::send(User::role('reviewer')->get(), new VacancyStatusUpdated($vacancy, $status));
}
return redirect() return redirect()
->back() ->back()
->with($type, $message); ->with($type, $message);

View File

@ -30,20 +30,30 @@ use Illuminate\Notifications\Messages\MailMessage;
use Illuminate\Notifications\Notification; use Illuminate\Notifications\Notification;
use Illuminate\Queue\SerializesModels; use Illuminate\Queue\SerializesModels;
class VacancyClosed extends Notification implements ShouldQueue class VacancyStatusUpdated extends Notification implements ShouldQueue
{ {
use Queueable, SerializesModels, Cancellable; use Queueable, SerializesModels, Cancellable;
protected $vacancy; protected string $status;
protected Vacancy $vacancy;
/** /**
* Create a new notification instance. * Create a new notification instance.
* *
* @return void * @return void
*/ */
public function __construct(Vacancy $vacancy) public function __construct(Vacancy $vacancy, $status)
{ {
// there's no simpler solution to this for now, but an array works
$statusDict = [
'open' => 'opened',
'close' => 'closed'
];
$this->vacancy = $vacancy; $this->vacancy = $vacancy;
$this->status = $statusDict[$status];
} }
public function optOut($notifiable) public function optOut($notifiable)
@ -59,12 +69,14 @@ class VacancyClosed extends Notification implements ShouldQueue
*/ */
public function toMail($notifiable) public function toMail($notifiable)
{ {
return (new MailMessage) return (new MailMessage)
->greeting('Hi ' . $notifiable->name . ',') ->greeting('Hi ' . $notifiable->name . ',')
->from(config('notification.sender.address'), config('notification.sender.name')) ->from(config('notification.sender.address'), config('notification.sender.name'))
->subject(config('app.name').' - Vacancy Closed') ->subject(config('app.name').' - Vacancy ' . $this->status)
->line('The vacancy '.$this->vacancy->vacancyName.', with '.$this->vacancy->vacancyCount.' remaining slots, has just been closed.') ->line('The vacancy '.$this->vacancy->vacancyName.', with '.$this->vacancy->vacancyCount.' remaining slots, has just been ' . $this->status . '.')
->line('Please be aware that this position may be deleted/reopened any time.') ->line('Please be aware that this position may be change at any time.')
->line('You are receiving this email because you currently have staff/team member privileges. Depending on your access level, you may not be able to view the list of positions on the backoffice.')
->action('View positions', url(route('showPositions'))) ->action('View positions', url(route('showPositions')))
->salutation('The team at ' . config('app.name')); ->salutation('The team at ' . config('app.name'));
} }