Expand and simplify vacancy update notification
This commit is contained in:
parent
572d750711
commit
784c8f6595
@ -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);
|
||||||
|
@ -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'));
|
||||||
}
|
}
|
Loading…
x
Reference in New Issue
Block a user