verification for seats left and already registered students added
This commit is contained in:
parent
e6a11127c8
commit
25d7ea4fe3
@ -123,7 +123,28 @@ class UserClassesController extends Controller
|
|||||||
$student_name = $request->input('student_name');
|
$student_name = $request->input('student_name');
|
||||||
$student_surname = $request->input('student_surname');
|
$student_surname = $request->input('student_surname');
|
||||||
$classes = Classes::find($request->get('classes_id'));
|
$classes = Classes::find($request->get('classes_id'));
|
||||||
|
$subject = Subject::find($classes->subject_id);
|
||||||
|
$room_capacity = Room::find($subject->room_id)->capacity;
|
||||||
|
$attendances = Attendance::where('classes_id', $classes->id)->get();
|
||||||
|
$student_ids = $attendances->pluck('student_id_number')->toArray();
|
||||||
|
$seat_numbers = $attendances->pluck('seat_number')->toArray();
|
||||||
|
|
||||||
|
if(in_array($student_id_number, $student_ids)) { // if student attendance record already exists
|
||||||
|
$student_seat_number = Attendance::where('student_id_number', $student_id_number)->first()->seat_number;
|
||||||
|
$warning = 'Ten numer indeksu został już wcześniej zapisany na te zajęcia.';
|
||||||
|
return view('map.summary_map', ['student_name' => $student_name, 'student_surname' => $student_surname, 'seat_number' => $student_seat_number, 'student_id_number' => $student_id_number, 'classes_id' => $classes->id, 'mode' => $classes->mode, 'warning' => $warning]);
|
||||||
|
} else {
|
||||||
|
if (count($seat_numbers) >= $room_capacity) { // if there are no more free seats in room, add student without assigning seat number (regardless of the classes mode)
|
||||||
|
Attendance::create([
|
||||||
|
'classes_id' => $classes->id,
|
||||||
|
'student_id_number' => $student_id_number,
|
||||||
|
'student_name' => $student_name,
|
||||||
|
'student_surname' => $student_surname,
|
||||||
|
'seat_number' => null
|
||||||
|
]);
|
||||||
|
$warning = "Zostałeś zapisany na listę obecności, ale bez przyznanego miejsca.";
|
||||||
|
return view('map.summary_map', ['student_name' => $student_name, 'student_surname' => $student_surname, 'seat_number' => null, 'student_id_number' => $student_id_number, 'classes_id' => $classes->id, 'mode' => $classes->mode, 'warning' => $warning]);
|
||||||
|
} else {
|
||||||
if ($classes->mode == 'quick') {
|
if ($classes->mode == 'quick') {
|
||||||
Attendance::create([
|
Attendance::create([
|
||||||
'classes_id' => $classes->id,
|
'classes_id' => $classes->id,
|
||||||
@ -132,12 +153,9 @@ class UserClassesController extends Controller
|
|||||||
'student_surname' => $student_surname,
|
'student_surname' => $student_surname,
|
||||||
'seat_number' => null
|
'seat_number' => null
|
||||||
]);
|
]);
|
||||||
return view('map.summary_map', ['student_name' => $student_name, 'student_surname' => $student_surname, 'seat_number' => null, 'student_id_number' => $student_id_number, 'classes_id' => $classes->id, 'mode' => $classes->mode]);
|
return view('map.summary_map', ['student_name' => $student_name, 'student_surname' => $student_surname, 'seat_number' => null, 'student_id_number' => $student_id_number, 'classes_id' => $classes->id, 'mode' => $classes->mode, 'warning' => null]);
|
||||||
|
|
||||||
} else {
|
} else {
|
||||||
$attendances = Attendance::where('classes_id', $classes->id)->get();
|
// prepare seat map
|
||||||
$seat_numbers = $attendances->pluck('seat_number')->toArray();
|
|
||||||
$subject = Subject::find($classes->subject_id);
|
|
||||||
$room_arrangement = Room::find($subject->room_id)->arrangement;
|
$room_arrangement = Room::find($subject->room_id)->arrangement;
|
||||||
if (!$room_arrangement) {
|
if (!$room_arrangement) {
|
||||||
$room_arrangement = Room::where('name', 'Inna sala')->first()->arrangement;
|
$room_arrangement = Room::where('name', 'Inna sala')->first()->arrangement;
|
||||||
@ -152,16 +170,18 @@ class UserClassesController extends Controller
|
|||||||
}
|
}
|
||||||
|
|
||||||
if ($classes->mode == 'test') {
|
if ($classes->mode == 'test') {
|
||||||
$room_capacity = Room::find($subject->room_id)->capacity;
|
|
||||||
$random_seat = rand(1, $room_capacity);
|
$random_seat = rand(1, $room_capacity);
|
||||||
while (in_array($random_seat, $seat_numbers)) {
|
while (in_array($random_seat, $seat_numbers)) {
|
||||||
$random_seat = rand(1, $room_capacity);
|
$random_seat = rand(1, $room_capacity);
|
||||||
}
|
}
|
||||||
return view('map.seat_map', ['student_name' => $student_name, 'student_surname' => $student_surname, 'seat_number' => $random_seat, 'student_id_number' => $student_id_number, 'classes_id' => $classes->id, 'seat_numbers' => $seat_numbers, 'room_arrangement' => $room_arrangement, 'multi_parts' => $multi_parts, 'parts_number' => $parts_number, 'mode' => 'test', 'random_seat' => $random_seat]);
|
return view('map.seat_map', ['student_name' => $student_name, 'student_surname' => $student_surname, 'seat_number' => $random_seat, 'student_id_number' => $student_id_number, 'classes_id' => $classes->id, 'seat_numbers' => $seat_numbers, 'room_arrangement' => $room_arrangement, 'multi_parts' => $multi_parts, 'parts_number' => $parts_number, 'mode' => 'test', 'random_seat' => $random_seat]);
|
||||||
}
|
} else {
|
||||||
return view('map.seat_map', ['student_name' => $student_name, 'student_surname' => $student_surname, 'student_id_number' => $student_id_number, 'classes_id' => $classes->id, 'seat_numbers' => $seat_numbers, 'room_arrangement' => $room_arrangement, 'multi_parts' => $multi_parts, 'parts_number' => $parts_number, 'mode' => null]);
|
return view('map.seat_map', ['student_name' => $student_name, 'student_surname' => $student_surname, 'student_id_number' => $student_id_number, 'classes_id' => $classes->id, 'seat_numbers' => $seat_numbers, 'room_arrangement' => $room_arrangement, 'multi_parts' => $multi_parts, 'parts_number' => $parts_number, 'mode' => null]);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
public function save_classes_data(Request $request)
|
public function save_classes_data(Request $request)
|
||||||
{
|
{
|
||||||
@ -177,7 +197,7 @@ class UserClassesController extends Controller
|
|||||||
'student_surname' => $student_surname,
|
'student_surname' => $student_surname,
|
||||||
'seat_number' => $seat_number
|
'seat_number' => $seat_number
|
||||||
]);
|
]);
|
||||||
return view('map.summary_map', ['student_name' => $student_name, 'student_surname' => $student_surname, 'seat_number' => $seat_number, 'student_id_number' => $student_id_number, 'classes_id' => $classes_id, 'mode' => null]);
|
return view('map.summary_map', ['student_name' => $student_name, 'student_surname' => $student_surname, 'seat_number' => $seat_number, 'student_id_number' => $student_id_number, 'classes_id' => $classes_id, 'mode' => null, 'warning' => null]);
|
||||||
}
|
}
|
||||||
|
|
||||||
public function preview_classes($classes_id, $orderBy='student_surname', $orderDirection='ASC')
|
public function preview_classes($classes_id, $orderBy='student_surname', $orderDirection='ASC')
|
||||||
|
@ -5,6 +5,7 @@ function assignPlaces() {
|
|||||||
const seat_number = $(this).attr('id').split('++')[0];
|
const seat_number = $(this).attr('id').split('++')[0];
|
||||||
const name = $(this).attr('id').split('++')[1];
|
const name = $(this).attr('id').split('++')[1];
|
||||||
const surname = $(this).attr('id').split('++')[2];
|
const surname = $(this).attr('id').split('++')[2];
|
||||||
|
if(seat_number) {
|
||||||
let map_seat = '';
|
let map_seat = '';
|
||||||
if(!multi_parts) {
|
if(!multi_parts) {
|
||||||
map_seat = $('#seat-map').find(`#${seat_number}`);
|
map_seat = $('#seat-map').find(`#${seat_number}`);
|
||||||
@ -17,7 +18,7 @@ function assignPlaces() {
|
|||||||
map_seat = $(`#seat-map-${index}`).find(`#${seat_number}`);
|
map_seat = $(`#seat-map-${index}`).find(`#${seat_number}`);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
console.log(map_seat);
|
if(map_seat.length) {
|
||||||
map_seat.html(`<b>${seat_number}</b> <br><span class="preview-name">${name} ${surname}</span>`);
|
map_seat.html(`<b>${seat_number}</b> <br><span class="preview-name">${name} ${surname}</span>`);
|
||||||
map_seat.on('mouseover', () => {
|
map_seat.on('mouseover', () => {
|
||||||
map_seat.css('backgroundColor', 'lightgrey');
|
map_seat.css('backgroundColor', 'lightgrey');
|
||||||
@ -33,6 +34,8 @@ function assignPlaces() {
|
|||||||
map_seat.css('backgroundColor', '#649a24');
|
map_seat.css('backgroundColor', '#649a24');
|
||||||
$(this).css('backgroundColor', 'unset');
|
$(this).css('backgroundColor', 'unset');
|
||||||
})
|
})
|
||||||
|
}
|
||||||
|
}
|
||||||
})
|
})
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -34,6 +34,27 @@
|
|||||||
<button type="submit" id="submit" class="checkout-button"> Dodaj studenta </button>
|
<button type="submit" id="submit" class="checkout-button"> Dodaj studenta </button>
|
||||||
</form>
|
</form>
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
|
<div class="modal fade" id="already-exist-modal" tabindex="-1" role="dialog" aria-labelledby="already-exist-modal" aria-hidden="true">
|
||||||
|
<div class="modal-dialog modal-dialog-centered" role="document">
|
||||||
|
<div class="modal-content">
|
||||||
|
<div class="modal-header">
|
||||||
|
<h5>Taki student już istnieje</h5>
|
||||||
|
<button type="button" class="close" data-dismiss="modal" aria-label="Close">
|
||||||
|
<span aria-hidden="true">×</span>
|
||||||
|
</button>
|
||||||
|
</div>
|
||||||
|
<div class="modal-body">
|
||||||
|
<p> Student <span class="student"></span> już istnieje </p>
|
||||||
|
</div>
|
||||||
|
<div class="modal-footer">
|
||||||
|
<button type="button" class="btn btn-primary" data-dismiss="modal" title="OK"> OK </button>
|
||||||
|
</div>
|
||||||
|
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
|
||||||
<script>
|
<script>
|
||||||
var classes_code_input = $('#classes_code_input').html();
|
var classes_code_input = $('#classes_code_input').html();
|
||||||
const client = new WebSocket('ws://127.0.0.1:8888', classes_code_input);
|
const client = new WebSocket('ws://127.0.0.1:8888', classes_code_input);
|
||||||
|
@ -10,9 +10,17 @@
|
|||||||
<div class="map-buttons">
|
<div class="map-buttons">
|
||||||
<a href="{{ route('user_classes') }}" class="checkout-button end-button"> Zakończ zapisy </a>
|
<a href="{{ route('user_classes') }}" class="checkout-button end-button"> Zakończ zapisy </a>
|
||||||
</div>
|
</div>
|
||||||
|
@if($warning)
|
||||||
|
<h1> {{ $warning }} </h1>
|
||||||
|
@else
|
||||||
<h1> Zostałeś poprawnie zapisany.</h1>
|
<h1> Zostałeś poprawnie zapisany.</h1>
|
||||||
|
@endif
|
||||||
|
<br><br>
|
||||||
<h2> {{ $student_name }} {{ $student_surname }} </h2>
|
<h2> {{ $student_name }} {{ $student_surname }} </h2>
|
||||||
|
<br><br>
|
||||||
|
|
||||||
<h3> {{ $student_id_number }} </h3>
|
<h3> {{ $student_id_number }} </h3>
|
||||||
|
<br><br>
|
||||||
@if(!$mode == "quick")
|
@if(!$mode == "quick")
|
||||||
<h3> miejsce: </h3>
|
<h3> miejsce: </h3>
|
||||||
<ul id="sel-seat"> {{ $seat_number }} </ul>
|
<ul id="sel-seat"> {{ $seat_number }} </ul>
|
||||||
|
Loading…
Reference in New Issue
Block a user