|
|
@ -1,11 +1,9 @@
|
|
|
|
<?php
|
|
|
|
<?php
|
|
|
|
namespace Engelsystem;
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
use Exception;
|
|
|
|
namespace Engelsystem;
|
|
|
|
|
|
|
|
|
|
|
|
class ShiftCalendarRenderer
|
|
|
|
class ShiftCalendarRenderer
|
|
|
|
{
|
|
|
|
{
|
|
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
/**
|
|
|
|
* 15m * 60s/m = 900s
|
|
|
|
* 15m * 60s/m = 900s
|
|
|
|
*/
|
|
|
|
*/
|
|
|
@ -51,9 +49,9 @@ class ShiftCalendarRenderer
|
|
|
|
/**
|
|
|
|
/**
|
|
|
|
* ShiftCalendarRenderer constructor.
|
|
|
|
* ShiftCalendarRenderer constructor.
|
|
|
|
*
|
|
|
|
*
|
|
|
|
* @param array[] $shifts
|
|
|
|
* @param array[] $shifts
|
|
|
|
* @param array[] $needed_angeltypes
|
|
|
|
* @param array[] $needed_angeltypes
|
|
|
|
* @param array[] $shift_entries
|
|
|
|
* @param array[] $shift_entries
|
|
|
|
* @param ShiftsFilter $shiftsFilter
|
|
|
|
* @param ShiftsFilter $shiftsFilter
|
|
|
|
*/
|
|
|
|
*/
|
|
|
|
public function __construct($shifts, $needed_angeltypes, $shift_entries, ShiftsFilter $shiftsFilter)
|
|
|
|
public function __construct($shifts, $needed_angeltypes, $shift_entries, ShiftsFilter $shiftsFilter)
|
|
|
@ -69,9 +67,7 @@ class ShiftCalendarRenderer
|
|
|
|
/**
|
|
|
|
/**
|
|
|
|
* Assigns the shifts to different lanes per room if they collide
|
|
|
|
* Assigns the shifts to different lanes per room if they collide
|
|
|
|
*
|
|
|
|
*
|
|
|
|
* @param array[] $shifts
|
|
|
|
* @param array[] $shifts The shifts to assign
|
|
|
|
* The shifts to assign
|
|
|
|
|
|
|
|
*
|
|
|
|
|
|
|
|
* @return array Returns an array that assigns a room_id to an array of ShiftCalendarLane containing the shifts
|
|
|
|
* @return array Returns an array that assigns a room_id to an array of ShiftCalendarLane containing the shifts
|
|
|
|
*/
|
|
|
|
*/
|
|
|
|
private function assignShiftsToLanes($shifts)
|
|
|
|
private function assignShiftsToLanes($shifts)
|
|
|
@ -82,10 +78,10 @@ class ShiftCalendarRenderer
|
|
|
|
foreach ($shifts as $shift) {
|
|
|
|
foreach ($shifts as $shift) {
|
|
|
|
$room_id = $shift['RID'];
|
|
|
|
$room_id = $shift['RID'];
|
|
|
|
$header = Room_name_render([
|
|
|
|
$header = Room_name_render([
|
|
|
|
'RID' => $room_id,
|
|
|
|
'RID' => $room_id,
|
|
|
|
'Name' => $shift['room_name']
|
|
|
|
'Name' => $shift['room_name']
|
|
|
|
]);
|
|
|
|
]);
|
|
|
|
if (! isset($lanes[$room_id])) {
|
|
|
|
if (!isset($lanes[$room_id])) {
|
|
|
|
// initialize room with one lane
|
|
|
|
// initialize room with one lane
|
|
|
|
$lanes[$room_id] = [
|
|
|
|
$lanes[$room_id] = [
|
|
|
|
new ShiftCalendarLane($header, $this->getFirstBlockStartTime(), $this->getBlocksPerSlot())
|
|
|
|
new ShiftCalendarLane($header, $this->getFirstBlockStartTime(), $this->getBlocksPerSlot())
|
|
|
@ -95,7 +91,7 @@ class ShiftCalendarRenderer
|
|
|
|
$shift_added = false;
|
|
|
|
$shift_added = false;
|
|
|
|
foreach ($lanes[$room_id] as $lane) {
|
|
|
|
foreach ($lanes[$room_id] as $lane) {
|
|
|
|
/** @var ShiftCalendarLane $lane */
|
|
|
|
/** @var ShiftCalendarLane $lane */
|
|
|
|
if($lane->shiftFits($shift)) {
|
|
|
|
if ($lane->shiftFits($shift)) {
|
|
|
|
$lane->addShift($shift);
|
|
|
|
$lane->addShift($shift);
|
|
|
|
$shift_added = true;
|
|
|
|
$shift_added = true;
|
|
|
|
break;
|
|
|
|
break;
|
|
|
@ -113,7 +109,6 @@ class ShiftCalendarRenderer
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
/**
|
|
|
|
*
|
|
|
|
|
|
|
|
* @return int
|
|
|
|
* @return int
|
|
|
|
*/
|
|
|
|
*/
|
|
|
|
public function getFirstBlockStartTime()
|
|
|
|
public function getFirstBlockStartTime()
|
|
|
@ -122,7 +117,6 @@ class ShiftCalendarRenderer
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
/**
|
|
|
|
*
|
|
|
|
|
|
|
|
* @return int
|
|
|
|
* @return int
|
|
|
|
*/
|
|
|
|
*/
|
|
|
|
public function getLastBlockEndTime()
|
|
|
|
public function getLastBlockEndTime()
|
|
|
@ -131,7 +125,6 @@ class ShiftCalendarRenderer
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
/**
|
|
|
|
*
|
|
|
|
|
|
|
|
* @return float
|
|
|
|
* @return float
|
|
|
|
*/
|
|
|
|
*/
|
|
|
|
public function getBlocksPerSlot()
|
|
|
|
public function getBlocksPerSlot()
|
|
|
@ -153,9 +146,9 @@ class ShiftCalendarRenderer
|
|
|
|
return '';
|
|
|
|
return '';
|
|
|
|
}
|
|
|
|
}
|
|
|
|
return div('shift-calendar', [
|
|
|
|
return div('shift-calendar', [
|
|
|
|
$this->renderTimeLane(),
|
|
|
|
$this->renderTimeLane(),
|
|
|
|
$this->renderShiftLanes()
|
|
|
|
$this->renderShiftLanes()
|
|
|
|
]) . $this->renderLegend();
|
|
|
|
]) . $this->renderLegend();
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
/**
|
|
|
@ -178,8 +171,7 @@ class ShiftCalendarRenderer
|
|
|
|
/**
|
|
|
|
/**
|
|
|
|
* Renders a single lane
|
|
|
|
* Renders a single lane
|
|
|
|
*
|
|
|
|
*
|
|
|
|
* @param ShiftCalendarLane $lane
|
|
|
|
* @param ShiftCalendarLane $lane The lane to render
|
|
|
|
* The lane to render
|
|
|
|
|
|
|
|
* @return string
|
|
|
|
* @return string
|
|
|
|
*/
|
|
|
|
*/
|
|
|
|
private function renderLane(ShiftCalendarLane $lane)
|
|
|
|
private function renderLane(ShiftCalendarLane $lane)
|
|
|
@ -196,7 +188,12 @@ class ShiftCalendarRenderer
|
|
|
|
$rendered_until += ShiftCalendarRenderer::SECONDS_PER_ROW;
|
|
|
|
$rendered_until += ShiftCalendarRenderer::SECONDS_PER_ROW;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
list ($shift_height, $shift_html) = $shift_renderer->render($shift, $this->needed_angeltypes[$shift['SID']], $this->shift_entries[$shift['SID']], $user);
|
|
|
|
list ($shift_height, $shift_html) = $shift_renderer->render(
|
|
|
|
|
|
|
|
$shift,
|
|
|
|
|
|
|
|
$this->needed_angeltypes[$shift['SID']],
|
|
|
|
|
|
|
|
$this->shift_entries[$shift['SID']],
|
|
|
|
|
|
|
|
$user
|
|
|
|
|
|
|
|
);
|
|
|
|
$html .= $shift_html;
|
|
|
|
$html .= $shift_html;
|
|
|
|
$rendered_until += $shift_height * ShiftCalendarRenderer::SECONDS_PER_ROW;
|
|
|
|
$rendered_until += $shift_height * ShiftCalendarRenderer::SECONDS_PER_ROW;
|
|
|
|
}
|
|
|
|
}
|
|
|
@ -215,23 +212,21 @@ class ShiftCalendarRenderer
|
|
|
|
/**
|
|
|
|
/**
|
|
|
|
* Renders a tick/block for given time
|
|
|
|
* Renders a tick/block for given time
|
|
|
|
*
|
|
|
|
*
|
|
|
|
* @param int $time
|
|
|
|
* @param int $time unix timestamp
|
|
|
|
* unix timestamp
|
|
|
|
* @param boolean $label Should time labels be generated?
|
|
|
|
* @param boolean $label
|
|
|
|
|
|
|
|
* Should time labels be generated?
|
|
|
|
|
|
|
|
* @return string rendered tick html
|
|
|
|
* @return string rendered tick html
|
|
|
|
*/
|
|
|
|
*/
|
|
|
|
private function renderTick($time, $label = false)
|
|
|
|
private function renderTick($time, $label = false)
|
|
|
|
{
|
|
|
|
{
|
|
|
|
if ($time % (24 * 60 * 60) == 23 * 60 * 60) {
|
|
|
|
if ($time % (24 * 60 * 60) == 23 * 60 * 60) {
|
|
|
|
if (! $label) {
|
|
|
|
if (!$label) {
|
|
|
|
return div('tick day');
|
|
|
|
return div('tick day');
|
|
|
|
}
|
|
|
|
}
|
|
|
|
return div('tick day', [
|
|
|
|
return div('tick day', [
|
|
|
|
date('m-d<b\r />H:i', $time)
|
|
|
|
date('m-d<b\r />H:i', $time)
|
|
|
|
]);
|
|
|
|
]);
|
|
|
|
} elseif ($time % (60 * 60) == 0) {
|
|
|
|
} elseif ($time % (60 * 60) == 0) {
|
|
|
|
if (! $label) {
|
|
|
|
if (!$label) {
|
|
|
|
return div('tick hour');
|
|
|
|
return div('tick hour');
|
|
|
|
}
|
|
|
|
}
|
|
|
|
return div('tick hour', [
|
|
|
|
return div('tick hour', [
|
|
|
@ -253,7 +248,7 @@ class ShiftCalendarRenderer
|
|
|
|
_('Time')
|
|
|
|
_('Time')
|
|
|
|
])
|
|
|
|
])
|
|
|
|
];
|
|
|
|
];
|
|
|
|
for ($block = 0; $block < $this->getBlocksPerSlot(); $block ++) {
|
|
|
|
for ($block = 0; $block < $this->getBlocksPerSlot(); $block++) {
|
|
|
|
$thistime = $this->getFirstBlockStartTime() + ($block * ShiftCalendarRenderer::SECONDS_PER_ROW);
|
|
|
|
$thistime = $this->getFirstBlockStartTime() + ($block * ShiftCalendarRenderer::SECONDS_PER_ROW);
|
|
|
|
$time_slot[] = $this->renderTick($thistime, true);
|
|
|
|
$time_slot[] = $this->renderTick($thistime, true);
|
|
|
|
}
|
|
|
|
}
|
|
|
@ -261,7 +256,6 @@ class ShiftCalendarRenderer
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
/**
|
|
|
|
*
|
|
|
|
|
|
|
|
* @param array[] $shifts
|
|
|
|
* @param array[] $shifts
|
|
|
|
* @return int
|
|
|
|
* @return int
|
|
|
|
*/
|
|
|
|
*/
|
|
|
@ -277,7 +271,6 @@ class ShiftCalendarRenderer
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
/**
|
|
|
|
*
|
|
|
|
|
|
|
|
* @param array[] $shifts
|
|
|
|
* @param array[] $shifts
|
|
|
|
* @return int
|
|
|
|
* @return int
|
|
|
|
*/
|
|
|
|
*/
|
|
|
@ -293,7 +286,6 @@ class ShiftCalendarRenderer
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
/**
|
|
|
|
*
|
|
|
|
|
|
|
|
* @return int
|
|
|
|
* @return int
|
|
|
|
*/
|
|
|
|
*/
|
|
|
|
private function calcBlocksPerSlot()
|
|
|
|
private function calcBlocksPerSlot()
|
|
|
|