/** * Returns ALL reservations of a certain item with start_date between $from and $till * * @param - String $from DateTime * @param - String $till DateTime * @param - int $itemid The itemId * @return - Array ['reservations'][RESERVATION_ID]=all info + array with all corresponding subscriptions * ['min_start_at'] = the minimal start_at in all reservations (usefull to build table) * ['max_end_at'] = the maximal end_at in all reservations (usefull to build table) */ function get_item_reservations($from, $till, $itemid) { $itemid = Database::escape_string($itemid); $till = Database::escape_string($till); $from = Database::escape_string($from); $sql = "SELECT r.*,i.name as item_name FROM " . Rsys::getTable('reservation') . " r\n\t\t\t\t\t\t INNER JOIN " . Rsys::getTable('item') . " i ON r.item_id=i.id\n\t\t\t\t\t\t LEFT JOIN " . Rsys::getTable('item_rights') . " ir ON ir.item_id=i.id\n\t\t\t\t\t\t LEFT JOIN " . Database::get_main_table(TABLE_MAIN_CLASS) . " c ON ir.class_id=c.id AND ir.item_id = i.id\n\t\t\t\t\t\t LEFT JOIN " . Database::get_main_table(TABLE_MAIN_CLASS_USER) . " cu ON cu.class_id = c.id\n\t\t\t\t\t\t WHERE r.item_id='" . $itemid . "' AND (((cu.user_id='" . api_get_user_id() . "' AND ir.view_right=1) OR 1=" . (api_is_platform_admin() ? 1 : 0) . ") AND\n\t\t\t\t\t\t (r.start_at<='" . $from . "' AND r.end_at>='" . $from . "') OR (r.start_at>='" . $from . "' AND r.start_at<='" . $till . "')) ORDER BY start_at ASC"; $result = Database::query($sql); $max_start_at = -1; $min_end_at = -1; $ids = ''; $from_stamp = Rsys::mysql_datetime_to_timestamp($from); $till_stamp = Rsys::mysql_datetime_to_timestamp($till); if (Database::num_rows($result) == 0) { return false; } while ($array = Database::fetch_array($result)) { $ids .= $array['id'] . ','; $current_start_at = Rsys::mysql_datetime_to_timestamp($array['start_at']); $current_end_at = Rsys::mysql_datetime_to_timestamp($array['end_at']); if ($from_stamp > $current_start_at) { $array['start_at'] = $from; } $rarr['reservations'][$array['id']]['info'] = $array; /* if ($max_start_at == -1 || $current_start_at < $rarr['min_start_at']) $rarr['min_start_at'] = $current_start_at; if ($current_end_at > $rarr['max_end_at']) $rarr['max_end_at'] = $current_end_at;*/ } $ids = substr($ids, 0, -1); $sql = "SELECT * FROM " . Rsys::getTable('subscription') . " WHERE reservation_id IN (" . $ids . ") AND (start_at='0000-00-00 00:00:00' OR (start_at<='" . $from . "' AND end_at>='" . $from . "') OR (start_at>='" . $from . "' AND start_at<='" . $till . "')) ORDER BY start_at ASC"; $result = Database::query($sql); while ($array = Database::fetch_array($result, 'ASSOC')) { // echo $array['reservation_id'].': '.$array['start_at'].'-'.$array['end_at'].'<br />'; if ($rarr['reservations'][$array['reservation_id']]['info']['timepicker']) { $current_start_at = Rsys::mysql_datetime_to_timestamp($array['start_at']); $current_end_at = Rsys::mysql_datetime_to_timestamp($array['end_at']); if ($current_start_at < $from_stamp) { //&& $current_end_at>=$from_stamp) || ($current_start_at>=$from_stamp && $current_start_at<=$till_stamp))) $array['start_at'] = $from; } if ($current_end_at > $till_stamp) { $array['end_at'] = $till; } } $rarr['reservations'][$array['reservation_id']]['subscriptions'][] = $array; } return $rarr; }
if ($values['timepicker'] == 0) { $result = Rsys :: add_subscription($_GET['rid'], api_get_user_id(),$values['accepted']); switch ($result) { case 0 : Display :: display_normal_message(Rsys :: get_return_msg2(get_lang('ReservationAdded'), "javascript:history.go(-2)", get_lang('BookingView')),false); break; case 1 : Display :: display_normal_message(Rsys :: get_return_msg2(str_replace('#END#', "<b>".$GLOBALS['end_date']."</b>",str_replace('#START#', "<b>".$GLOBALS['start_date']."</b>",get_lang('ReservationAlready'))),"reservation.php?cat=".$item[1]."&item=".$item[0]."", get_lang('BookingView')),false); break; } } else { $result = Rsys :: add_subscription_timepicker($_GET['rid'], api_get_user_id(), $values['startpicker'], $values['endpicker'],$values['accepted'],$values['min'],$values['max']); switch ($result) { case 0 : Display :: display_normal_message(Rsys :: get_return_msg2(get_lang('ReservationAdded'), "reservation.php?cat=".$item[1]."&item=".$item[0]."&date=".date( 'Y-m-d',Rsys :: mysql_datetime_to_timestamp($values['startpicker']))."&changemonth=yes", get_lang('BookingView')),false); break; case 1 : Display :: display_normal_message(str_replace('#END#', "<b>".$GLOBALS['end_date']."</b>",str_replace('#START#', "<b>".$GLOBALS['start_date']."</b>",get_lang('ReservationOutOfDate'))),false); $form->display(); echo $buffer; break; case 2 : Display :: display_normal_message(get_lang('BookingPeriodTooSmall'),false); $form->display(); //echo $buffer; break; case 3 : Display :: display_normal_message(get_lang('BookingPeriodTooBig'),false); $form->display(); //echo $buffer;
function get_week_view($day, $month, $year, $itemid, $day_scale = 180, $cat) { // 1) Item is blackout? >> True of False ... wordt gebruikt in get_bar methode om kleur indien nodig om te zetten $GLOBALS['bblackout'] = Rsys::is_blackout($itemid); // 2) $day_scale controleren en aanpassen indien nodig // Day_scale mag niet groter zijn dan 3600 (anders wordt de tabel te klein) if ($day_scale > 3600) { $day_scale = 3600; } elseif ($day_scale < 1) { $day_scale = 1; } // 3) Een '0' voor de maand-integer zetten indien deze kleiner is dan 10, nodig voor datetime // bv voor 1 december 1985: '01-12-1985' ipv '1-12-1985' (S�ba's geboortedatum ^^) if ($month < 10) { $month = '0' . $month; } // 4) Bepaal de juiste start datum (maandag) van de omliggende week // (verander eventueel maand (en jaar) wanneer de maandag in de vorige maand/jaar ligt) $fromdate = $year . '-' . $month . '-' . ($day < 10 ? '0' . $day : $day) . ' 00:00:00'; $stamp = Rsys::mysql_datetime_to_timestamp($fromdate); $dayofweek = date('w', $stamp); if ($dayofweek == 0) { $stamp = $stamp - 1; $datum = Rsys::mysql_datetime_to_array(Rsys::timestamp_to_datetime($stamp)); $day = $datum['day']; $month = $datum['month']; $year = $datum['year']; } $fromdate = $year . '-' . $month . '-' . $day . ' 00:00:00'; $stamp = Rsys::mysql_datetime_to_timestamp($fromdate); $dayofweek = date('w', $stamp); if ($day - $dayofweek < 0) { $stamp = $stamp - 60 * 60 * 24 * ($dayofweek - 1); $fromdate = Rsys::timestamp_to_datetime($stamp); $tilldate = $stamp; } else { $day = $day - $dayofweek + 1; // M-FIX: sunday + 1 = monday $fromdate = $year . '-' . $month . '-' . ($day < 10 ? '0' . $day : $day) . ' 00:00:00'; $tilldate = Rsys::mysql_datetime_to_timestamp($fromdate); } //zeven Dagen opvullen en eind-datum bepalen (= startdatum + 7 dagen) for ($i = 1; $i <= 7; $i++) { $day_start_dates[$i] = $tilldate; $tilldate += 60 * 60 * 24; } // 5) Haal de reservaties periodes (+ reservaties) op tussen de start en einddatum $arr = Rsys::get_item_reservations($fromdate, Rsys::timestamp_to_datetime($tilldate), $itemid); // 6) Doorloop $arr met reservatie periodes en vul de $days array op met balkjes (bars) voor elke dag $weekday_pointer = $GLOBALS['weekday_pointer'] = 1; // Stel de weekdag pointer in op 1 (=maandag) $one_day = 60 * 60 * 24 - 1; // Het aantal seconden dat ��n dag in beslag neemt (23:59:59) $last_end = $day_start_dates[1]; // Stel de $last_end pointer in op het begin van maandag (00:00:00) if (count($arr['reservations']) > 0) { foreach ($arr['reservations'] as $res_id => $res) { // 6.1) Stel basis variabelen in $r = $res['info']; // Reservatie periode informatie (start en eind tijd etc.) $s = $res['subscriptions']; // Reservaties (inschrijvingen) op reservatie periode $start = Rsys::mysql_datetime_to_timestamp($r['start_at']); // Start tijd van reservatie periode blok $end = Rsys::mysql_datetime_to_timestamp($r['end_at']); // Eind tijd van reservatie periode blok $timepicker_min = $r['timepicker_min']; $timepicker_max = $r['timepicker_max']; $chunk_size = $end - $start; // Unscaled chunk_size (of "reservation-period-block") // een "chunk" is dus een balkje (bar) // 6.2) Als de weekdag van de huidige start-tijd (van de reservatieperiode) niet overeenkomt met de huidige weekdag-pointer (=$weekday_pointer) if (date('w', $start) != $weekday_pointer) { // a) Wijzig de $weekday_pointer naar de weekdag waarin de start-tijd (van de reservatieperiode) zich bevindt $weekday_pointer = $GLOBALS['weekday_pointer'] = date('w', $start); if ($weekday_pointer == 0) { $weekday_pointer = 7; } // b) Stel de $last_end in op het begin van de nieuwe dag $last_end = $day_start_dates[$weekday_pointer]; } // 6.3) Vul de ruimte tussen $last_end en de huidige start-tijd met een grijze balk if ($start - $last_end > 0) { $days[$weekday_pointer] .= $this->get_bar(($start - $last_end) / $day_scale, 'grey'); } // 6.4.A) Indien het NIET om een timepicker gaat... (= 1 reservatie-blok) if ($r['timepicker'] != 1) { // ..a1) bepaal kleur en link (of geen link) op basis van de inschrijvingsperiode en het aantal en het maximaal aantal inschrijvingen if ($r['subscribers'] < $r['max_users'] && Rsys::mysql_datetime_to_timestamp($r['start_at']) > time() && ($r['subscribe_from'] == '0000-00-00 00:00:00' || Rsys::mysql_datetime_to_timestamp($r['subscribe_from']) < time() && Rsys::mysql_datetime_to_timestamp($r['subscribe_until']) > time())) { // Subscription is allowed $color = "green"; $link = "subscribe.php?rid=" . $r['id']; } elseif ($r['subscribers'] < $r['max_users'] && (Rsys::mysql_datetime_to_timestamp($r['subscribe_from']) > time() || Rsys::mysql_datetime_to_timestamp($r['subscribe_until']) < time() || Rsys::mysql_datetime_to_timestamp($r['start_at']) < time())) { // Subscribe_from is not yet reached $color = "orange"; $link = null; } else { // Subscription is not allowed $color = "red"; $link = null; } // ..a2) stel titel in (dat je ziet als je over het balkje zweeft met je muis) $title = date('H:i (d/m/Y)', $start) . ' » ' . date('H:i (d/m/Y)', $end); // ..a3) controleer of het reservatie-periode-blok de huidige dag overschrijdt if ($end > $day_start_dates[$weekday_pointer] + $one_day) { // indien ja, cree�r dan balkjes voor elke volgende dag $trimmed_chunk_size = $chunk_size - ($end - ($day_start_dates[$weekday_pointer] + $one_day)); $days[$weekday_pointer] .= $this->get_bar($trimmed_chunk_size / $day_scale, $color, $link, $title, $itemid, $cat); $new_day = true; while ($new_day && $weekday_pointer < 7) { $weekday_pointer++; $GLOBALS['weekday_pointer']++; $start = $days[$weekday_pointer]; $chunk_size = $end - $start; if ($end > $day_start_dates[$weekday_pointer] + $one_day) { // If still larger than one day, trim chunk and continue $days[$weekday_pointer] .= $this->get_bar($one_day / $day_scale, $color, $link, $title, $itemid, $cat); } else { $trimmed_chunk_size = $end - $day_start_dates[$weekday_pointer]; $days[$weekday_pointer] .= $this->get_bar($trimmed_chunk_size / $day_scale, $color, $link, $title, $itemid, $cat); $new_day = false; } } } else { // indien niet, voeg dan gewoon het balkje toe aan de huidige dag $days[$weekday_pointer] .= $this->get_bar($chunk_size / $day_scale, $color, $link, $title, $itemid, $cat); } // 6.4.B) Indien het WEL om een timepicker gaat... (max_users telt hier niet) } else { $timepicker_min *= 60; $timepicker_max *= 60; $minute_interval = 30; $minute_interval *= 60; $color = "blue"; $pickedcolor = "red"; $tosmallchunkcolor = "yellow"; $start_pointer = $start; $link = "subscribe.php?rid=" . $r['id'] . '&timestart='; // + (start)tijd waarop geklikt werd = volwaardige link if (count($s) == 0) { if ($start > time()) { //controle of dat de time tussen $r['subscribe_from'] en $r['subscribe_until'] ligt if (Rsys::mysql_datetime_to_timestamp($r['subscribe_from']) <= time() && Rsys::mysql_datetime_to_timestamp($r['subscribe_until']) > time() || $r['subscribe_from'] == '0000-00-00 00:00:00' && $r['subscribe_until'] == '0000-00-00 00:00:00') { $days[$weekday_pointer] .= $this->get_bar(($end - $start) / $day_scale, $color, $link . $start_pointer, date('H:i', $start) . ' » ' . date('H:i', $end), $itemid, $cat); } else { $days[$weekday_pointer] .= $this->get_bar(($end - $start) / $day_scale, 'orange', null, date('H:i', $start) . ' » ' . date('H:i', $end)); } } else { if (time() < $end) { //eerst oranje daarna blauw of geel $days[$weekday_pointer] .= $this->get_bar((time() - $start) / $day_scale, 'orange', null, date('H:i', $start) . ' » ' . date('H:i', time())); //controle of het stuk nog kan gereserveerd worden -> stuk > timepicker_min if (Rsys::mysql_datetime_to_timestamp($r['subscribe_from']) <= time() && Rsys::mysql_datetime_to_timestamp($r['subscribe_until']) > time() || $r['subscribe_from'] == '0000-00-00 00:00:00' && $r['subscribe_until'] == '0000-00-00 00:00:00') { if ($end - time() >= $timepicker_min) { $days[$weekday_pointer] .= $this->get_bar(($end - time()) / $day_scale, $color, $link . $start_pointer, date('H:i', time()) . ' » ' . date('H:i', $end), $itemid, $cat); } else { $days[$weekday_pointer] .= $this->get_bar(($end - time()) / $day_scale, $tosmallchunkcolor, null, date('H:i', time()) . ' » ' . date('H:i', $end)); } } else { $days[$weekday_pointer] .= $this->get_bar(($end - time()) / $day_scale, 'orange', null, date('H:i', time()) . ' » ' . date('H:i', $end)); } } else { //volledig oranje blok $days[$weekday_pointer] .= $this->get_bar(($end - $start) / $day_scale, 'orange', null, date('H:i', $start) . ' » ' . date('H:i', $end)); } } } else { $i = 0; foreach ($s as $key => $sub) { $start = Rsys::mysql_datetime_to_timestamp($sub['start_at']); $einde = Rsys::mysql_datetime_to_timestamp($sub['end_at']); if (Rsys::mysql_datetime_to_timestamp($sub['start_at']) - $start_pointer <= 0) { //start onmiddelijk met een rood stuk $start_tijd = date('H:i', $start_pointer); $eind_tijd = date('H:i', $einde); $days[$weekday_pointer] .= $this->get_bar(($einde - $start_pointer) / $day_scale, $pickedcolor, null, $start_tijd . ' » ' . $eind_tijd); } else { //start met een blauw of oranje stuk //kijken of dat de start_tijd al buiten de huidige tijd ligt -> if ($start_pointer > time()) { $start_tijd = date('H:i', $start_pointer); $eind_tijd = date('H:i', $start); if (Rsys::mysql_datetime_to_timestamp($r['subscribe_from']) <= time() && Rsys::mysql_datetime_to_timestamp($r['subscribe_until']) > time() || $r['subscribe_from'] == '0000-00-00 00:00:00' && $r['subscribe_until'] == '0000-00-00 00:00:00') { //niet buiten tijd! //blauw stuk maken indien groter dan timepicker_min anders geel if ($start - $start_pointer >= $timepicker_min) { $days[$weekday_pointer] .= $this->get_bar(($start - $start_pointer) / $day_scale, $color, $link . $start_pointer, $start_tijd . ' » ' . $eind_tijd, $itemid, $cat); } else { $days[$weekday_pointer] .= $this->get_bar(($start - $start_pointer) / $day_scale, $tosmallchunkcolor, null, $start_tijd . ' » ' . $eind_tijd); } } else { $days[$weekday_pointer] .= $this->get_bar(($start - $start_pointer) / $day_scale, 'orange', null, $start_tijd . ' » ' . $eind_tijd); } } else { //controleren of dat tijd nu groter is dan de start van het gereserveerde stuk //Ja -> stuk voor de start oranje maken //Neen -> stuk voor de start oranje maken en wat er nog overblijft vr de $start blauw maken if (time() >= $start) { $days[$weekday_pointer] .= $this->get_bar(($start - $start_pointer) / $day_scale, 'orange', null, date('H:i', $start_pointer) . ' » ' . date('H:i', $start)); } else { //buiten tijd! -> stuk opdelen in een gedeelte buiten tijd en een gedeelte timepicker //oranje stuk $days[$weekday_pointer] .= $this->get_bar((time() - $start_pointer) / $day_scale, 'orange', null, date('H:i', $start_pointer) . ' » ' . date('H:i', time())); if (Rsys::mysql_datetime_to_timestamp($r['subscribe_from']) <= time() && Rsys::mysql_datetime_to_timestamp($r['subscribe_until']) > time() || $r['subscribe_from'] == '0000-00-00 00:00:00' && $r['subscribe_until'] == '0000-00-00 00:00:00') { //blauw stuk maken indien groter dan timepicker_min anders geel if ($start - time() >= $timepicker_min) { $days[$weekday_pointer] .= $this->get_bar(($start - time()) / $day_scale, $color, $link . time(), date('H:i', time()) . ' » ' . date('H:i', $start), $itemid, $cat); } else { $days[$weekday_pointer] .= $this->get_bar(($start - time()) / $day_scale, $tosmallchunkcolor, null, date('H:i', time()) . ' » ' . date('H:i', $start), $itemid, $cat); } } else { $days[$weekday_pointer] .= $this->get_bar(($start - time()) / $day_scale, 'orange', null, date('H:i', time()) . ' » ' . date('H:i', $start)); } } } $start_tijd = date('H:i', $start); $eind_tijd = date('H:i', $einde); $days[$weekday_pointer] .= $this->get_bar(($einde - $start) / $day_scale, $pickedcolor, null, $start_tijd . ' » ' . $eind_tijd); } //print_r($days); $start_pointer = $einde; // + 1; } //indien er nog een stuk blauw moet gemaakt worden op het einde vd reservering if ($start_pointer < $end) { //controleren of dat tijd nu groter is dan de start van het gereserveerde stuk //Ja -> stuk voor de start oranje maken //Neen -> stuk voor de start oranje maken en wat er nog overblijft vr de $start blauw maken if (time() >= $end) { $days[$weekday_pointer] .= $this->get_bar(($end - $start_pointer) / $day_scale, 'orange', null, date('H:i', $start_pointer) . ' » ' . date('H:i', $end)); } else { if (time() >= $start_pointer) { //buiten tijd! -> stuk opdelen in een gedeelte buiten tijd en een gedeelte timepicker //oranje stuk $days[$weekday_pointer] .= $this->get_bar((time() - $start_pointer) / $day_scale, 'orange', null, date('H:i', $start_pointer) . ' » ' . date('H:i', time())); if (Rsys::mysql_datetime_to_timestamp($r['subscribe_from']) <= time() && Rsys::mysql_datetime_to_timestamp($r['subscribe_until']) > time() || $r['subscribe_from'] == '0000-00-00 00:00:00' && $r['subscribe_until'] == '0000-00-00 00:00:00') { //blauw stuk maken indien groter dan timepicker_min anders geel if ($end - time() >= $timepicker_min) { //blauwe stuk $days[$weekday_pointer] .= $this->get_bar(($end - time()) / $day_scale, $color, $link . time(), date('H:i', time()) . ' » ' . date('H:i', $end), $itemid, $cat); } else { //geel stuk $days[$weekday_pointer] .= $this->get_bar(($end - time()) / $day_scale, $tosmallchunkcolor, null, date('H:i', time()) . ' » ' . date('H:i', $end)); } } else { $days[$weekday_pointer] .= $this->get_bar(($end - time()) / $day_scale, 'orange', null, date('H:i', time()) . ' » ' . date('H:i', $end)); } } else { if (Rsys::mysql_datetime_to_timestamp($r['subscribe_from']) <= time() && Rsys::mysql_datetime_to_timestamp($r['subscribe_until']) > time() || $r['subscribe_from'] == '0000-00-00 00:00:00' && $r['subscribe_until'] == '0000-00-00 00:00:00') { //blauw stuk maken indien groter dan timepicker_min anders geel if ($end - $start_pointer >= $timepicker_min) { //blauwe stuk $days[$weekday_pointer] .= $this->get_bar(($end - $start_pointer) / $day_scale, $color, $link . $start_pointer, date('H:i', $start_pointer) . ' » ' . date('H:i', $end), $itemid, $cat); } else { //gele stuk $days[$weekday_pointer] .= $this->get_bar(($end - $start_pointer) / $day_scale, $tosmallchunkcolor, null, date('H:i', $start_pointer) . ' » ' . date('H:i', $end)); } } else { $days[$weekday_pointer] .= $this->get_bar(($end - $start_pointer) / $day_scale, 'orange', null, date('H:i', $start_pointer) . ' » ' . date('H:i', $end)); } } } } } } // 6.5) Zet de $last_end pointer op de eindtijd van de huidige reservatie periode $last_end = $end; } // end if } // 7) loop through all days of the week and fill them with the contents of $days $firstcol = 120; // Width of first col (in pixels) $x = 0; $borderstyle = "border-bottom: 1px solid #003;"; echo '<table cellspacing="0" style="padding: 1px;width: ' . (round($one_day / $day_scale) + $firstcol + $x) . 'px;border: 1px solid #003;border-bottom: 0"><tr><td style="' . $borderstyle . 'width: ' . $firstcol . 'px;background-color: #069; "> </td><td style="' . $borderstyle . 'background-color: #069; color: #FFF; white-space: nowrap; font-family: Arial, sans-serif; font-size:10px;width: ' . (round($one_day / $day_scale) + $x) . 'px">'; $vast = 3600 * 2 / $day_scale; $lasttotal = 0; for ($i = 0; $i < 22; $i = $i + 2) { $w = $vast; $total += $w; $rounded_total = round($total); $w = $rounded_total - $lasttotal; echo '<div style="float:left; width: ' . $w . 'px">' . $i . '</div>'; $lasttotal = $rounded_total; } echo '<div style="float:left;">22</div><div style="float: right">0</float>'; echo '</td></tr>'; for ($i = 1; $i <= 7; $i++) { echo '<tr><td style="background-color: #069; color: #FFF; width:' . $firstcol . 'px; font-family: Verdana, Arial, sans-serif; font-weight: bold;font-size:10px;' . $borderstyle . ';cursor: help" title="' . date('d/m/Y', $day_start_dates[$i]) . '">' . $this->get_long_day($i == 7 ? 0 : $i) . '</td><td style="' . $borderstyle . ' background-color: #CCC; width:' . (round($one_day / $day_scale) + $x) . 'px; white-space: nowrap;">'; if (is_array($days) && array_key_exists($i, $days)) { echo $days[$i]; } else { echo ' '; } echo '</td></tr>' . "\n"; } echo '</table>'; $GLOBALS['weekstart'] = date('d/m/Y', $day_start_dates[1]); $GLOBALS['weekend'] = date('d/m/Y', $day_start_dates[7]); }
$form->addElement('checkbox', 'auto_accept', get_lang('AutoAccept')); $form->addElement('checkbox', 'timepicker', get_lang('TimePicker'), '', array('disabled' => 'disabled')); $form->addElement('textarea', 'notes', get_lang('Notes'), array('cols' => 40, 'rows' => 4)); $form->addElement('style_submit_button', 'submit', get_lang('EditNewBookingPeriod'), 'class="save"'); $form->addElement('hidden', 'id', $Reservation_id); $form->addElement('hidden', 'timepicker2'); $form->addElement('hidden', 'period', $reservation[0][7] == '0000-00-00 00:00:00' && $reservation[0][8] == '0000-00-00 00:00:00' ? 0 : 1); if ($categori[0] == $tijdelijke_cat) { $defaultvalues['item_id'] = $reservation[0][2]; } $defaultvalues['auto_accept'] = $reservation[0][3]; $defaultvalues['maxuser'] = $reservation[0][4]; $defaultvalues['start'] = $reservation[0][5]; $defaultvalues['end'] = $reservation[0][6]; $defaultvalues['forever'] = $reservation[0][7] == '0000-00-00 00:00:00' && $reservation[0][8] == '0000-00-00 00:00:00' ? 0 : 1; $my_start_date = Rsys::mysql_datetime_to_timestamp($reservation[0][5]); if ($defaultvalues['forever'] == 0) { //here we set the default dates $defaultvalues['subscribe_from'] = $my_start_date - 60 * 60; $defaultvalues['subscribe_until'] = $my_start_date - 60; } else { $defaultvalues['subscribe_from'] = $reservation[0][7]; $defaultvalues['subscribe_until'] = $reservation[0][8]; } $defaultvalues['notes'] = $reservation[0][10]; $defaultvalues['timepicker'] = $reservation[0][11]; $defaultvalues['timepicker2'] = $reservation[0][11]; $form->setDefaults($defaultvalues); if (count($reservation) > 0) { $form->Display(); } else {