Attendize/app/Http/Controllers/EventTicketsController.php

297 lines
9.5 KiB
PHP

<?php
namespace App\Http\Controllers;
use App\Models\Event;
use App\Models\Ticket;
use Carbon\Carbon;
use Illuminate\Http\Request;
use Log;
/*
Attendize.com - Event Management & Ticketing
*/
class EventTicketsController extends MyBaseController
{
/**
* @param Request $request
* @param $event_id
* @return mixed
*/
public function showTickets(Request $request, $event_id)
{
$allowed_sorts = [
'created_at' => trans("Controllers.sort.created_at"),
'title' => trans("Controllers.sort.title"),
'quantity_sold' => trans("Controllers.sort.quantity_sold"),
'sales_volume' => trans("Controllers.sort.sales_volume"),
'sort_order' => trans("Controllers.sort.sort_order"),
];
// Getting get parameters.
$q = $request->get('q', '');
$sort_by = $request->get('sort_by');
if (isset($allowed_sorts[$sort_by]) === false) {
$sort_by = 'sort_order';
}
// Find event or return 404 error.
$event = Event::with('venue')->scope()->findOrFail($event_id);
// Get tickets for event.
$tickets = empty($q) === false
? $event->tickets()->where('title', 'like', '%' . $q . '%')->orderBy($sort_by, 'asc')->paginate()
: $event->tickets()->orderBy($sort_by, 'asc')->paginate();
// Return view.
return view('ManageEvent.Tickets', compact('event', 'tickets', 'sort_by', 'q', 'allowed_sorts'));
}
/**
* Show the edit ticket modal
*
* @param $event_id
* @param $ticket_id
* @return mixed
*/
public function showEditTicket($event_id, $ticket_id)
{
$data = [
'event' => Event::scope()->find($event_id),
'ticket' => Ticket::scope()->find($ticket_id),
];
return view('ManageEvent.Modals.EditTicket', $data);
}
/**
* Show the create ticket modal
*
* @param $event_id
* @return \Illuminate\Contracts\View\View
*/
public function showCreateTicket($event_id)
{
return view('ManageEvent.Modals.CreateTicket', [
'event' => Event::scope()->find($event_id),
]);
}
/**
* Creates a ticket
*
* @param $event_id
* @return \Illuminate\Http\JsonResponse
*/
public function postCreateTicket(Request $request, $event_id)
{
$ticket = Ticket::createNew();
if (!$ticket->validate($request->all())) {
return response()->json([
'status' => 'error',
'messages' => $ticket->errors(),
]);
}
$ticket->event_id = $event_id;
$ticket->title = strip_tags($request->get('title'));
$ticket->quantity_available = !$request->get('quantity_available') ? null : $request->get('quantity_available');
$ticket->ticket_date = $request->get('ticket_date');
$ticket->start_sale_date = $request->get('start_sale_date');
$ticket->end_sale_date = $request->get('end_sale_date');
$ticket->price = $request->get('price');
$ticket->min_per_person = $request->get('min_per_person');
$ticket->max_per_person = $request->get('max_per_person');
$ticket->description = strip_tags($request->get('description'));
$ticket->is_hidden = $request->get('is_hidden') ? 1 : 0;
$ticket->account_id = auth()->user()->account_id;
$ticket->section_id = $request->get('section_id');
$ticket->save();
// Attach the access codes to the ticket if it's hidden and the code ids have come from the front
if ($ticket->is_hidden) {
$ticketAccessCodes = $request->get('ticket_access_codes', []);
if (empty($ticketAccessCodes) === false) {
// Sync the access codes on the ticket
$ticket->event_access_codes()->attach($ticketAccessCodes);
}
}
session()->flash('message', 'Successfully Created Ticket');
return response()->json([
'status' => 'success',
'id' => $ticket->id,
'message' => trans("Controllers.refreshing"),
'redirectUrl' => route('showEventTickets', [
'event_id' => $event_id,
]),
]);
}
/**
* Pause ticket / take it off sale
*
* @param Request $request
* @return mixed
*/
public function postPauseTicket(Request $request)
{
$ticket_id = $request->get('ticket_id');
$ticket = Ticket::scope()->find($ticket_id);
$ticket->is_paused = ($ticket->is_paused == 1) ? 0 : 1;
if ($ticket->save()) {
return response()->json([
'status' => 'success',
'message' => trans("Controllers.ticket_successfully_updated"),
'id' => $ticket->id,
]);
}
Log::error('Ticket Failed to pause/resume', [
'ticket' => $ticket,
]);
return response()->json([
'status' => 'error',
'id' => $ticket->id,
'message' => trans("Controllers.whoops"),
]);
}
/**
* Deleted a ticket
*
* @param Request $request
* @return \Illuminate\Http\JsonResponse
*/
public function postDeleteTicket(Request $request)
{
$ticket_id = $request->get('ticket_id');
$ticket = Ticket::scope()->find($ticket_id);
/*
* Don't allow deletion of tickets which have been sold already.
*/
if ($ticket->quantity_sold > 0) {
return response()->json([
'status' => 'error',
'message' => trans("Controllers.cant_delete_ticket_when_sold"),
'id' => $ticket->id,
]);
}
if ($ticket->delete()) {
return response()->json([
'status' => 'success',
'message' => trans("Controllers.ticket_successfully_deleted"),
'id' => $ticket->id,
]);
}
Log::error('Ticket Failed to delete', [
'ticket' => $ticket,
]);
return response()->json([
'status' => 'error',
'id' => $ticket->id,
'message' => trans("Controllers.whoops"),
]);
}
/**
* Edit a ticket
*
* @param Request $request
* @param $event_id
* @param $ticket_id
* @return \Illuminate\Http\JsonResponse
*/
public function postEditTicket(Request $request, $event_id, $ticket_id)
{
$ticket = Ticket::scope()->findOrFail($ticket_id);
/*
* Add validation message
*/
$validation_messages['quantity_available.min'] = trans("Controllers.quantity_min_error");
$ticket->messages = $validation_messages + $ticket->messages;
if (!$ticket->validate($request->all())) {
return response()->json([
'status' => 'error',
'messages' => $ticket->errors(),
]);
}
// Check if the ticket visibility changed on update
$ticketPreviouslyHidden = (bool)$ticket->is_hidden;
$ticket->title = $request->get('title');
$ticket->quantity_available = !$request->get('quantity_available') ? null : $request->get('quantity_available');
$ticket->price = $request->get('price');
$ticket->ticket_date = $request->get('ticket_date');
// dd($request);
$ticket->start_sale_date = $request->get('start_sale_date');
$ticket->end_sale_date = $request->get('end_sale_date');
$ticket->description = $request->get('description');
$ticket->min_per_person = $request->get('min_per_person');
$ticket->max_per_person = $request->get('max_per_person');
$ticket->is_hidden = $request->get('is_hidden') ? 1 : 0;
$ticket->section_id = $request->get('section_id');
$ticket->save();
// Attach the access codes to the ticket if it's hidden and the code ids have come from the front
if ($ticket->is_hidden) {
$ticketAccessCodes = $request->get('ticket_access_codes', []);
if (empty($ticketAccessCodes) === false) {
// Sync the access codes on the ticket
$ticket->event_access_codes()->detach();
$ticket->event_access_codes()->attach($ticketAccessCodes);
}
} else if ($ticketPreviouslyHidden) {
// Delete access codes on ticket if the visibility changed to visible
$ticket->event_access_codes()->detach();
}
return response()->json([
'status' => 'success',
'id' => $ticket->id,
'message' => trans("Controllers.refreshing"),
'redirectUrl' => route('showEventTickets', [
'event_id' => $event_id,
]),
]);
}
/**
* Updates the sort order of tickets
*
* @param Request $request
* @return \Illuminate\Http\JsonResponse
*/
public function postUpdateTicketsOrder(Request $request)
{
$ticket_ids = $request->get('ticket_ids');
$sort = 1;
foreach ($ticket_ids as $ticket_id) {
$ticket = Ticket::scope()->find($ticket_id);
$ticket->sort_order = $sort;
$ticket->save();
$sort++;
}
return response()->json([
'status' => 'success',
'message' => trans("Controllers.ticket_order_successfully_updated"),
]);
}
}