4 * Presents page to view an event with links to edit, delete
5 * confirm, copy, add event
8 * id (*) - cal_id of requested event
9 * date - yyyymmdd format of requested event
10 * user - user to display
13 include_once $gfplugins.'webcalendar/www/includes/init.php';
14 include_once $gfplugins.'webcalendar/www/includes/site_extras.php';
16 // make sure this user is allowed to look at this calendar.
20 if ( $is_admin || $is_nonuser_admin || $is_assistant ) {
26 if ( empty ( $id ) || $id <= 0 || ! is_numeric ( $id ) ) {
27 $error = translate ( "Invalid entry id" ) . ".";
30 if ( empty ( $error ) ) {
31 // is this user a participant or the creator of the event?
32 $sql = "SELECT webcal_entry.cal_id FROM webcal_entry, " .
33 "webcal_entry_user WHERE webcal_entry.cal_id = " .
34 "webcal_entry_user.cal_id AND webcal_entry.cal_id = $id " .
35 "AND (webcal_entry.cal_create_by = '$login' " .
36 "OR webcal_entry_user.cal_login = '$login')";
37 $res = dbi_query ( $sql );
39 $row = dbi_fetch_row ( $res );
40 if ( $row && $row[0] > 0 ) {
44 dbi_free_result ( $res );
47 if ( ($login != "__public__") && ($public_access_others == "Y") ) {
53 // if not a participant in the event, must be allowed to look at
54 // other user's calendar.
55 if ( $login == "__public__" ) {
56 if ( $public_access_others == "Y" ) {
60 if ( $allow_view_other == "Y" ) {
64 // If $check_group is true now, it means this user can look at the
65 // event only if they are in the same group as some of the people in
67 // This gets kind of tricky. If there is a participant from a different
68 // group, do we still show it? For now, the answer is no.
69 // This could be configurable somehow, but how many lines of text would
70 // it need in the admin page to describe this scenario? Would confuse
72 // In summary, make sure at least one event participant is in one of
73 // this user's groups.
74 $my_users = get_my_users ();
75 if ( is_array ( $my_users ) ) {
76 $sql = "SELECT webcal_entry.cal_id FROM webcal_entry, " .
77 "webcal_entry_user WHERE webcal_entry.cal_id = " .
78 "webcal_entry_user.cal_id AND webcal_entry.cal_id = $id " .
79 "AND webcal_entry_user.cal_login IN ( ";
80 for ( $i = 0; $i < count ( $my_users ); $i++ ) {
84 $sql .= "'" . $my_users[$i]['cal_login'] . "'";
87 $res = dbi_query ( $sql );
89 $row = dbi_fetch_row ( $res );
90 if ( $row && $row[0] > 0 ) {
93 dbi_free_result ( $res );
96 // If we didn't indicate we need to check groups, then this user
97 // can't view this event.
98 if ( ! $check_group ) {
104 // If they still cannot view, make sure they are not looking at a nonuser
105 // calendar event where the nonuser is the _only_ participant.
106 if ( empty ( $error ) && ! $can_view && ! empty ( $nonuser_enabled ) &&
107 $nonuser_enabled == 'Y' ) {
108 $nonusers = get_nonuser_cals ();
109 $nonuser_lookup = array ();
110 for ( $i = 0; $i < count ( $nonusers ); $i++ ) {
111 $nonuser_lookup[$nonusers[$i]['cal_login']] = 1;
113 $sql = "SELECT cal_login FROM webcal_entry_user " .
114 "WHERE cal_id = $id AND cal_status in ('A','W')";
115 $res = dbi_query ( $sql );
116 $found_nonuser_cal = false;
117 $found_reg_user = false;
119 while ( $row = dbi_fetch_row ( $res ) ) {
120 if ( ! empty ( $nonuser_lookup[$row[0]] ) ) {
121 $found_nonuser_cal = true;
123 $found_reg_user = true;
126 dbi_free_result ( $res );
128 // Does this event contain only nonuser calendars as participants?
129 // If so, then grant access.
130 if ( $found_nonuser_cal && ! $found_reg_user ) {
135 if ( empty ( $error ) && ! $can_view ) {
136 $error = translate ( "You are not authorized" );
139 if ( ! empty ( $year ) ) {
142 if ( ! empty ( $month ) ) {
145 $pri[1] = translate("Low");
146 $pri[2] = translate("Medium");
147 $pri[3] = translate("High");
151 // Make sure this is not a continuation event.
152 // If it is, redirect the user to the original event.
154 if ( empty ( $error ) ) {
155 $res = dbi_query ( "SELECT cal_ext_for_id FROM webcal_entry " .
156 "WHERE cal_id = $id" );
158 if ( $row = dbi_fetch_row ( $res ) ) {
161 dbi_free_result ( $res );
163 // db error... ignore it, I guess.
167 $url = "view_entry.php?id=$ext_id";
169 $url .= "&date=$date";
172 $url .= "&user=$user";
174 if ( $cat_id != "" ) {
175 $url .= "&cat_id=$cat_id";
177 do_redirect ( $url );
182 if ( ! empty ( $error ) ) {
183 echo "<h2>" . translate ( "Error" ) .
186 echo "</body>\n</html>";
189 // Try to determine the event status.
192 if ( ! empty ( $user ) && $login != $user ) {
193 // If viewing another user's calendar, check the status of the
194 // event on their calendar (to see if it's deleted).
195 $sql = "SELECT cal_status FROM webcal_entry_user " .
196 "WHERE cal_login = '$user' AND cal_id = $id";
197 $res = dbi_query ( $sql );
199 if ( $row = dbi_fetch_row ( $res ) ) {
200 $event_status = $row[0];
202 dbi_free_result ( $res );
205 // We are viewing event on user's own calendar, so check the
206 // status on their own calendar.
207 $sql = "SELECT cal_id, cal_status FROM webcal_entry_user " .
208 "WHERE cal_login = '$login' AND cal_id = $id";
209 $res = dbi_query ( $sql );
211 $row = dbi_fetch_row ( $res );
212 $event_status = $row[1];
213 dbi_free_result ( $res );
217 // At this point, if we don't have the event status, then either
218 // this user is not viewing an event from his own calendar and not
219 // viewing an event from someone else's calendar.
220 // They probably got here from the search results page (or possibly
221 // by hand typing in the URL.)
222 // Check to make sure that it hasn't been deleted from everyone's
224 if ( empty ( $event_status ) ) {
225 $sql = "SELECT cal_status FROM webcal_entry_user " .
226 "WHERE cal_status <> 'D' ORDER BY cal_status";
227 $res = dbi_query ( $sql );
229 if ( $row = dbi_fetch_row ( $res ) ) {
230 $event_status = $row[0];
232 dbi_free_result ( $res );
236 // If we have no event status yet, it must have been deleted.
237 if ( ( empty ( $event_status ) && ! $is_admin ) || ! $can_view ) {
239 translate("Error") . "</h2>" .
240 translate("You are not authorized") . ".\n";
242 echo "</body>\n</html>";
247 // Load event info now.
248 $sql = "SELECT cal_create_by, cal_date, cal_time, cal_mod_date, " .
249 "cal_mod_time, cal_duration, cal_priority, cal_type, cal_access, " .
250 "cal_name, cal_description FROM webcal_entry WHERE cal_id = $id";
251 $res = dbi_query ( $sql );
253 echo translate("Invalid entry id") . ": $id";
257 $row = dbi_fetch_row ( $res );
259 $create_by = $row[0];
260 $orig_date = $row[1];
261 $event_time = $row[2];
263 $description = $row[10];
266 translate("Error") . "</h2>" .
267 translate("Invalid entry id") . ".\n";
269 echo "</body>\n</html>";
273 // Timezone Adjustments
274 if ( $event_time >= 0 && ! empty ( $TZ_OFFSET ) && $TZ_OFFSET != 0 ) {
275 // -1 = no time specified
276 $adjusted_time = $event_time + $TZ_OFFSET * 10000;
277 $year = substr($row[1],0,4);
278 $month = substr($row[1],4,2);
279 $day = substr($row[1],-2);
280 if ( $adjusted_time > 240000 ) {
281 $gmt = mktime ( 3, 0, 0, $month, $day, $year );
283 } else if ( $adjusted_time < 0 ) {
284 $gmt = mktime ( 3, 0, 0, $month, $day, $year );
289 $tz_date = ( ! empty ( $gmt ) ) ? date ( "Ymd", $gmt ) : $row[1];
291 // save date so the trailer links are for the same time period
292 $thisyear = (int) ( $tz_date / 10000 );
293 $thismonth = ( $tz_date / 100 ) % 100;
294 $thisday = $tz_date % 100;
295 $thistime = mktime ( 3, 0, 0, $thismonth, $thisday, $thisyear );
296 $thisdow = date ( "w", $thistime );
298 // $subject is used for mailto URLs
299 $subject = translate($application_name) . ": " . $name;
300 // Remove the '"' character since it causes some mailers to barf
301 $subject = str_replace ( "\"", "", $subject );
302 $subject = htmlspecialchars ( $subject );
304 $event_repeats = false;
305 // build info string for repeating events and end date
306 $sql = "SELECT cal_type, cal_end, cal_frequency, cal_days " .
307 "FROM webcal_entry_repeats WHERE cal_id = $id";
309 $res = dbi_query ($sql);
312 if ( $tmprow = dbi_fetch_row ( $res ) ) {
313 $event_repeats = true;
314 $cal_type = $tmprow[0];
315 $cal_end = $tmprow[1];
316 $cal_frequency = $tmprow[2];
317 $cal_days = $tmprow[3];
320 $rep_str .= " - ";
321 $rep_str .= date_to_str ( $cal_end );
323 $rep_str .= " (" . translate("every") . " ";
325 if ( $cal_frequency > 1 ) {
326 switch ( $cal_frequency ) {
327 case 2: $rep_str .= translate("2nd"); break;
328 case 3: $rep_str .= translate("3rd"); break;
329 case 4: $rep_str .= translate("4th"); break;
330 case 5: $rep_str .= translate("5th"); break;
331 case 12: if ( $cal_type == 'monthlyByDay' ||
332 $cal_type == 'monthlyByDayR' ) {
335 default: $rep_str .= $cal_frequency; break;
341 $rep_str .= translate("Day");
343 case "weekly": $rep_str .= translate("Week");
344 for ($i=0; $i<=7; $i++) {
345 if (substr($cal_days, $i, 1) == "y") {
346 $rep_str .= ", " . weekday_short_name($i);
351 case "monthlyByDayR":
352 if ( $cal_frequency == 12 ) {
353 $rep_str .= month_name ( $thismonth - 1 ) . " / ";
355 $rep_str .= translate("Month") . " / ";
357 $days_this_month = $thisyear % 4 == 0 ? $ldays_per_month[$thismonth] :
358 $days_per_month[$thismonth];
359 if ( $cal_type == 'monthlyByDay' ) {
360 $dow1 = date ( "w", mktime ( 3, 0, 0, $thismonth, 1, $thisyear ) );
361 $days_in_first_week = ( 7 - $dow1 );
362 $whichWeek = ceil ( $thisday / 7 );
364 $whichWeek = floor ( ( $days_this_month - $thisday ) / 7 );
368 switch ( $whichWeek ) {
370 if ( $cal_type == 'monthlyByDay' )
371 $rep_str .= translate ( "1st" );
374 $rep_str .= translate ( "2nd" ); break;
376 $rep_str .= translate ( "3rd" ); break;
378 $rep_str .= translate ( "4th" ); break;
380 $rep_str .= translate ( "5th" ); break;
382 if ( $cal_type == 'monthlyByDayR' )
383 $rep_str .= " " . translate ( "last" );
384 $rep_str .= ' ' . weekday_name ( $thisdow );
386 case "monthlyByDate":
387 $rep_str .= translate("Month") . "/" . translate("by date");
390 $rep_str .= translate("Year");
396 dbi_free_result ( $res );
398 /* calculate end time */
399 if ( $event_time >= 0 && $row[5] > 0 )
400 $end_str = "-" . display_time ( add_duration ( $row[2], $row[5] ) );
404 // get the email adress of the creator of the entry
405 user_load_variables ( $create_by, "createby_" );
406 $email_addr = empty ( $createby_email ) ? '' : $createby_email;
408 // If confidential and not this user's event, then
409 // They cannot seem name or description.
410 //if ( $row[8] == "R" && ! $is_my_event && ! $is_admin ) {
411 if ( $row[8] == "R" && ! $is_my_event ) {
413 $name = "[" . translate("Confidential") . "]";
414 $description = "[" . translate("Confidential") . "]";
419 if ( $event_repeats && ! empty ( $date ) )
422 $event_date = $row[1];
424 // TODO: don't let someone view another user's private entry
425 // by hand editing the URL.
428 if ( $categories_enabled == "Y" ) {
429 $cat_owner = ( ( ! empty ( $user ) && strlen ( $user ) ) && ( $is_assistant ||
430 $is_admin ) ) ? $user : $login;
431 $sql = "SELECT cat_name FROM webcal_categories, webcal_entry_user " .
432 "WHERE webcal_entry_user.cal_login = '$cat_owner' AND webcal_entry_user.cal_id = $id " .
433 "AND webcal_entry_user.cal_category = webcal_categories.cat_id";
434 $res2 = dbi_query ( $sql );
436 $row2 = dbi_fetch_row ( $res2 );
437 $category = $row2[0];
438 dbi_free_result ( $res2 );
442 <h2><?php echo htmlspecialchars ( $name ); ?></h2>
443 <table style="border-width:0px;">
444 <tr><td style="vertical-align:top; font-weight:bold;">
445 <?php etranslate("Description")?>:</td><td>
447 if ( ! empty ( $allow_html_description ) &&
448 $allow_html_description == 'Y' ) {
449 $str = str_replace ( '&', '&', $description );
450 $str = str_replace ( '&amp;', '&', $str );
451 // If there is no html found, then go ahead and replace
452 // the line breaks ("\n") with the html break.
453 if ( strstr ( $str, "<" ) && strstr ( $str, ">" ) ) {
454 // found some html...
457 echo nl2br ( activate_urls ( $str ) );
460 echo nl2br ( activate_urls ( htmlspecialchars ( $description ) ) );
464 <?php if ( $event_status != 'A' && ! empty ( $event_status ) ) { ?>
465 <tr><td style="vertical-align:top; font-weight:bold;">
466 <?php etranslate("Status")?>:</td><td>
468 if ( $event_status == 'W' )
469 etranslate("Waiting for approval");
470 if ( $event_status == 'D' )
471 etranslate("Deleted");
472 else if ( $event_status == 'R' )
473 etranslate("Rejected");
478 <tr><td style="vertical-align:top; font-weight:bold;">
479 <?php etranslate("Date")?>:</td><td>
481 if ( $event_repeats ) {
482 echo date_to_str ( $event_date );
484 echo date_to_str ( $row[1], "", true, false, ( $row[5] == ( 24 * 60 ) ? "" : $event_time ) );
488 <?php if ( $event_repeats ) { ?>
489 <tr><td style="vertical-align:top; font-weight:bold;">
490 <?php etranslate("Repeat Type")?>:</td><td>
491 <?php echo date_to_str ( $row[1], "", true, false, $event_time ) . $rep_str; ?>
494 <?php if ( $event_time >= 0 ) { ?>
495 <tr><td style="vertical-align:top; font-weight:bold;">
496 <?php etranslate("Time")?>:</td><td>
498 if ( $row[5] == ( 24 * 60 ) ) {
499 etranslate("All day event");
501 echo display_time ( $row[2] ) . $end_str;
506 <?php if ( $row[5] > 0 && $row[5] != ( 24 * 60 ) ) { ?>
507 <tr><td style="vertical-align:top; font-weight:bold;">
508 <?php etranslate("Duration")?>:</td><td>
509 <?php echo $row[5]; ?> <?php etranslate("minutes")?>
512 <?php if ( $disable_priority_field != "Y" ) { ?>
513 <tr><td style="vertical-align:top; font-weight:bold;">
514 <?php etranslate("Priority")?>:</td><td>
515 <?php echo $pri[$row[6]]; ?>
518 <?php if ( $disable_access_field != "Y" ) { ?>
519 <tr><td style="vertical-align:top; font-weight:bold;">
520 <?php etranslate("Access")?>:</td><td>
521 <?php echo ( $row[8] == "P" ) ? translate("Public") : translate("Confidential"); ?>
524 <?php if ( $categories_enabled == "Y" && ! empty ( $category ) ) { ?>
525 <tr><td style="vertical-align:top; font-weight:bold;">
526 <?php etranslate("Category")?>:</td><td>
527 <?php echo $category; ?>
531 // Display who originally created event
532 // useful if assistant or Admin
533 $proxy_fullname = '';
534 if ( !empty ( $DISPLAY_CREATED_BYPROXY ) && $DISPLAY_CREATED_BYPROXY == "Y" ) {
535 $res = dbi_query ( "SELECT wu.cal_firstname, wu.cal_lastname " .
536 "FROM webcal_user wu INNER JOIN webcal_entry_log wel ON wu.cal_login = wel.cal_login " .
537 "WHERE wel.cal_entry_id = $id " .
538 "AND wel.cal_type = 'C'" );
540 $row3 = dbi_fetch_row ( $res ) ;
541 $proxy_fullname = $row3[0] . " " . $row3[1];
542 $proxy_fullname = ($createby_fullname == $proxy_fullname ? "" :
543 " ( by " . $proxy_fullname . " )");
547 if ( $single_user == "N" ) {
548 echo "<tr><td style=\"vertical-align:top; font-weight:bold;\">\n" .
549 translate("Created by") . ":</td><td>\n";
551 echo "[" . translate("Confidential") . "]\n</td></tr>";
553 if ( strlen ( $email_addr ) ) {
554 echo "<a href=\"mailto:$email_addr?subject=$subject\">" .
555 ( $row[0] == "__public__" ? translate( "Public Access" ): $createby_fullname ) .
556 "</a>$proxy_fullname\n</td></tr>";
558 echo ( $row[0] == "__public__" ? translate( "Public Access" ) : $createby_fullname ) .
559 "$proxy_fullname\n</td></tr>";
564 <tr><td style="vertical-align:top; font-weight:bold;">
565 <?php etranslate("Updated")?>:</td><td>
567 echo date_to_str ( $row[3] );
569 echo display_time ( $row[4] );
573 // load any site-specific fields and display them
574 $extras = get_site_extra_fields ( $id );
575 for ( $i = 0; $i < count ( $site_extras ); $i++ ) {
576 $extra_name = $site_extras[$i][0];
577 $extra_type = $site_extras[$i][2];
578 $extra_arg1 = $site_extras[$i][3];
579 $extra_arg2 = $site_extras[$i][4];
580 if ( ! empty ( $extras[$extra_name]['cal_name'] ) ) {
581 echo "<tr><td style=\"vertical-align:top; font-weight:bold;\">\n" .
582 translate ( $site_extras[$i][1] ) .
584 if ( $extra_type == $EXTRA_URL ) {
585 if ( strlen ( $extras[$extra_name]['cal_data'] ) ) {
586 echo "<a href=\"" . $extras[$extra_name]['cal_data'] . "\">" .
587 $extras[$extra_name]['cal_data'] . "</a>\n";
589 } else if ( $extra_type == $EXTRA_EMAIL ) {
590 if ( strlen ( $extras[$extra_name]['cal_data'] ) ) {
591 echo "<a href=\"mailto:" . $extras[$extra_name]['cal_data'] .
592 "?subject=$subject\">" .
593 $extras[$extra_name]['cal_data'] . "</a>\n";
595 } else if ( $extra_type == $EXTRA_DATE ) {
596 if ( $extras[$extra_name]['cal_date'] > 0 ) {
597 echo date_to_str ( $extras[$extra_name]['cal_date'] );
599 } else if ( $extra_type == $EXTRA_TEXT ||
600 $extra_type == $EXTRA_MULTILINETEXT ) {
601 echo nl2br ( $extras[$extra_name]['cal_data'] );
602 } else if ( $extra_type == $EXTRA_USER ) {
603 echo $extras[$extra_name]['cal_data'];
604 } else if ( $extra_type == $EXTRA_REMINDER ) {
605 if ( $extras[$extra_name]['cal_remind'] <= 0 ) {
608 etranslate ( "Yes" );
609 if ( ( $extra_arg2 & $EXTRA_REMINDER_WITH_DATE ) > 0 ) {
610 echo " - ";
611 echo date_to_str ( $extras[$extra_name]['cal_date'] );
612 } else if ( ( $extra_arg2 & $EXTRA_REMINDER_WITH_OFFSET ) > 0 ) {
613 echo " - ";
614 $minutes = $extras[$extra_name]['cal_data'];
615 $d = (int) ( $minutes / ( 24 * 60 ) );
616 $minutes -= ( $d * 24 * 60 );
617 $h = (int) ( $minutes / 60 );
618 $minutes -= ( $h * 60 );
620 echo $d . " " . translate("days") . " ";
621 } else if ( $d == 1 ) {
622 echo $d . " " . translate("day") . " ";
625 echo $h . " " . translate("hours") . " ";
626 } else if ( $h == 1 ) {
627 echo $h . " " . translate("hour") . " ";
629 if ( $minutes > 1 ) {
630 echo $minutes . " " . translate("minutes");
631 } else if ( $minutes == 1 ) {
632 echo $minutes . " " . translate("minute");
634 echo " " . translate("before event" );
637 } else if ( $extra_type == $EXTRA_SELECTLIST ) {
638 echo $extras[$extra_name]['cal_data'];
640 echo "\n</td></tr>\n";
645 <?php // participants
646 // Only ask for participants if we are multi-user.
647 $allmails = array ();
648 $show_participants = ( $disable_participants_field != "Y" );
650 $show_participants = true;
652 if ( $public_access == "Y" && $login == "__public__" &&
653 ( $public_access_others != "Y" || $public_access_view_part == "N" ) ) {
654 $show_participants = false;
656 if ( $single_user == "N" && $show_participants ) { ?>
657 <tr><td style="vertical-align:top; font-weight:bold;">
658 <?php etranslate("Participants")?>:</td><td>
661 echo "[" . translate("Confidential") . "]";
663 $sql = "SELECT cal_login, cal_status FROM webcal_entry_user " .
664 "WHERE cal_id = $id";
666 $res = dbi_query ( $sql );
668 $num_app = $num_wait = $num_rej = 0;
670 while ( $row = dbi_fetch_row ( $res ) ) {
672 if ( $login == $row[0] && $row[1] == 'W' ) {
675 if ( $row[1] == 'A' ) {
676 $approved[$num_app++] = $pname;
677 } else if ( $row[1] == 'W' ) {
678 $waiting[$num_wait++] = $pname;
679 } else if ( $row[1] == 'R' ) {
680 $rejected[$num_rej++] = $pname;
683 dbi_free_result ( $res );
685 echo translate ("Database error") . ": " . dbi_error() . "<br />\n";
688 for ( $i = 0; $i < $num_app; $i++ ) {
689 user_load_variables ( $approved[$i], "temp" );
690 if ( strlen ( $tempemail ) ) {
691 echo "<a href=\"mailto:" . $tempemail . "?subject=$subject\">" .
692 $tempfullname . "</a><br />\n";
693 $allmails[] = $tempemail;
695 echo $tempfullname . "<br />\n";
698 // show external users here...
699 if ( ! empty ( $allow_external_users ) && $allow_external_users == "Y" ) {
700 $external_users = event_get_external_users ( $id, 1 );
701 $ext_users = explode ( "\n", $external_users );
702 if ( is_array ( $ext_users ) ) {
703 for ( $i = 0; $i < count( $ext_users ); $i++ ) {
704 if ( ! empty ( $ext_users[$i] ) ) {
705 echo $ext_users[$i] . " (" . translate("External User") .
711 for ( $i = 0; $i < $num_wait; $i++ ) {
712 user_load_variables ( $waiting[$i], "temp" );
713 if ( strlen ( $tempemail ) ) {
714 echo "<br /><a href=\"mailto:" . $tempemail . "?subject=$subject\">" .
715 $tempfullname . "</a> (?)\n";
716 $allmails[] = $tempemail;
718 echo "<br />" . $tempfullname . " (?)\n";
721 for ( $i = 0; $i < $num_rej; $i++ ) {
722 user_load_variables ( $rejected[$i], "temp" );
723 if ( strlen ( $tempemail ) ) {
724 echo "<br /><strike><a href=\"mailto:" . $tempemail .
725 "?subject=$subject\">" . $tempfullname .
726 "</a></strike> (" . translate("Rejected") . ")\n";
728 echo "<br /><strike>$tempfullname</strike> (" .
729 translate("Rejected") . ")\n";
735 } // end participants
743 if ( $event_repeats ) {
744 $rdate = "&date=$event_date";
747 // Show a printer-friendly link
748 if ( empty ( $friendly ) ) {
750 translate("Generate printer-friendly version") . "\" class=\"printer\" " .
751 "href=\"view_entry.php?id=$id&friendly=1$rdate\" " .
752 "target=\"cal_printer_friendly\">" .
753 translate("Printer Friendly") . "</a><br />\n";
756 if ( empty ( $event_status ) ) {
757 // this only happens when an admin views a deleted event that he is
758 // not a participant for. Set to $event_status to "D" just to get
759 // rid of all the edit/delete links below.
763 if ( $unapproved && $readonly == 'N' ) {
765 translate("Approve/Confirm entry") .
766 "\" href=\"approve_entry.php?id=$id\" " .
767 "onclick=\"return confirm('" .
768 translate("Approve this entry?") . "');\">" .
769 translate("Approve/Confirm entry") . "</a><br />\n";
771 translate("Reject entry") . "\" href=\"reject_entry.php?id=$id\" " .
772 "onclick=\"return confirm('" .
773 translate("Reject this entry?") . "');\">" .
774 translate("Reject entry") . "</a><br />\n";
777 if ( ! empty ( $user ) && $login != $user ) {
778 $u_url = "&user=$user";
783 $can_edit = ( $is_admin || $is_nonuser_admin && ($user == $create_by) ||
784 ( $is_assistant && ! $is_private && ($user == $create_by) ) ||
785 ( $readonly != "Y" && ( $login == $create_by || $single_user == "Y" ) ) );
786 if ( $public_access == "Y" && $login == "__public__" ) {
789 if ( $readonly == 'Y' ) {
793 // If approved, but event category not set (and user does not have permission
794 // to edit where they could also set the category), then allow them to
795 // set it through set_cat.php.
796 if ( empty ( $user ) && $categories_enabled == "Y" &&
797 $readonly != "Y" && $is_my_event && $login != "__public__" &&
798 $event_status != "D" && ! $can_edit ) {
800 translate("Set category") . "\" class=\"nav\" " .
801 "href=\"set_entry_cat.php?id=$id$rdate\">" .
802 translate("Set category") . "</a><br />\n";
805 if ( $can_edit && $event_status != "D" ) {
806 if ( $event_repeats ) {
808 translate("Edit repeating entry for all dates") .
809 "\" class=\"nav\" href=\"edit_entry.php?id=$id$u_url\">" .
810 translate("Edit repeating entry for all dates") . "</a><br />\n";
811 // Don't allow override of first event
812 if ( ! empty ( $date ) && $date != $orig_date ) {
814 translate("Edit entry for this date") . "\" class=\"nav\" " .
815 "href=\"edit_entry.php?id=$id$u_url$rdate&override=1\">" .
816 translate("Edit entry for this date") . "</a><br />\n";
819 translate("Delete repeating event for all dates") .
820 "\" class=\"nav\" href=\"del_entry.php?id=$id$u_url&override=1\" " .
821 "onclick=\"return confirm('" .
822 translate("Are you sure you want to delete this entry?") . "\\n\\n" .
823 translate("This will delete this entry for all users.") . "');\">" .
824 translate("Delete repeating event for all dates") . "</a><br />\n";
825 // Don't allow deletion of first event
826 if ( ! empty ( $date ) && $date != $orig_date ) {
828 translate("Delete entry only for this date") .
829 "\" class=\"nav\" href=\"del_entry.php?id=$id$u_url$rdate&override=1\" " .
830 "onclick=\"return confirm('" .
831 translate("Are you sure you want to delete this entry?") . "\\n\\n" .
832 translate("This will delete this entry for all users.") . "');\">" .
833 translate("Delete entry only for this date") . "</a><br />\n";
837 translate("Edit entry") . "\" class=\"nav\" " .
838 "href=\"edit_entry.php?id=$id$u_url\">" .
839 translate("Edit entry") . "</a><br />\n";
841 translate("Delete entry") . "\" class=\"nav\" " .
842 "href=\"del_entry.php?id=$id$u_url$rdate\" onclick=\"return confirm('" .
843 translate("Are you sure you want to delete this entry?") . "\\n\\n" .
844 translate("This will delete this entry for all users.") . "');\">" .
845 translate("Delete entry") . "</a><br />\n";
848 translate("Copy entry") . "\" class=\"nav\" " .
849 "href=\"edit_entry.php?id=$id$u_url&copy=1\">" .
850 translate("Copy entry") . "</a><br />\n";
851 } elseif ( $readonly != "Y" && $is_my_event && $login != "__public__" &&
852 $event_status != "D" ) {
854 translate("Delete entry") . "\" class=\"nav\" " .
855 "href=\"del_entry.php?id=$id$u_url$rdate\" onclick=\"return confirm('" .
856 translate("Are you sure you want to delete this entry?") . "\\n\\n" .
857 translate("This will delete the entry from your calendar.") . "');\">" .
858 translate("Delete entry") . "</a><br />\n";
860 translate("Copy entry") . "\" class=\"nav\" " .
861 "href=\"edit_entry.php?id=$id&copy=1\">" .
862 translate("Copy entry") . "</a><br />\n";
864 if ( $readonly != "Y" && ! $is_my_event && ! $is_private &&
865 $event_status != "D" && $login != "__public__" ) {
867 translate("Add to My Calendar") . "\" class=\"nav\" " .
868 "href=\"add_entry.php?id=$id&user=".$_GET['user']."\" onclick=\"return confirm('" .
869 translate("Do you want to add this entry to your calendar?") . "\\n\\n" .
870 translate("This will add the entry to your calendar.") . "');\">" .
871 translate("Add to My Calendar") . "</a><br />\n";
874 if ( count ( $allmails ) > 0 ) {
876 translate("Email all participants") . "\" class=\"nav\" " .
877 "href=\"mailto:" . implode ( ",", $allmails ) .
878 "?subject=" . rawurlencode($subject) . "\">" .
879 translate("Email all participants") . "</a><br />\n";
885 if ( empty ( $log ) ) {
887 translate("Show activity log") . "\" class=\"nav\" " .
888 "href=\"view_entry.php?id=$id&log=1\">" .
889 translate("Show activity log") . "</a><br />\n";
892 translate("Hide activity log") . "\" class=\"nav\" " .
893 "href=\"view_entry.php?id=$id\">" .
894 translate("Hide activity log") . "</a><br />\n";
900 echo "<h3>" . translate("Activity Log") . "</h3>\n";
901 echo "<table class=\"embactlog\">\n";
902 echo "<tr><th class=\"usr\">\n";
903 echo translate("User") . "</th><th class=\"cal\">\n";
904 echo translate("Calendar") . "</th><th class=\"date\">\n";
905 echo translate("Date") . "/" .
906 translate("Time") . "</th><th class=\"action\">\n";
907 echo translate("Action") . "\n</th></tr>\n";
909 $res = dbi_query ( "SELECT cal_login, cal_user_cal, cal_type, " .
910 "cal_date, cal_time " .
911 "FROM webcal_entry_log WHERE cal_entry_id = $id " .
912 "ORDER BY cal_log_id DESC" );
914 while ( $row = dbi_fetch_row ( $res ) ) {
916 echo $row[0] . "</td><td>\n";
917 echo $row[1] . "</td><td>\n" .
918 date_to_str ( $row[3] ) . " " .
919 display_time ( $row[4] ) . "</td><td>\n";
920 if ( $row[2] == $LOG_CREATE ) {
921 etranslate("Event created");
922 } else if ( $row[2] == $LOG_APPROVE ) {
923 etranslate("Event approved");
924 } else if ( $row[2] == $LOG_REJECT ) {
925 etranslate("Event rejected");
926 } else if ( $row[2] == $LOG_UPDATE ) {
927 etranslate("Event updated");
928 } else if ( $row[2] == $LOG_DELETE ) {
929 etranslate("Event deleted");
930 } else if ( $row[2] == $LOG_NOTIFICATION ) {
931 etranslate("Notification sent");
932 } else if ( $row[2] == $LOG_REMINDER ) {
933 etranslate("Reminder sent");
937 dbi_free_result ( $res );
943 echo "<br /><form method=\"post\" name=\"exportform\" " .
944 "action=\"export_handler.php\">\n";
945 echo "<label for=\"exformat\">" .
946 translate("Export this entry to") . ": </label>\n";
947 echo "<select name=\"format\" id=\"exformat\">\n";
948 echo " <option value=\"ical\">iCalendar</option>\n";
949 echo " <option value=\"vcal\">vCalendar</option>\n";
950 echo " <option value=\"pilot-csv\">Pilot-datebook CSV (" .
951 translate("Palm Pilot") . ")</option>\n";
952 echo " <option value=\"pilot-text\">Install-datebook (" .
953 translate("Palm Pilot") . ")</option>\n";
955 echo "<input type=\"hidden\" name=\"id\" value=\"$id\" />\n";
956 echo "<input type=\"submit\" value=\"" .
957 translate("Export") . "\" />\n";
963 print_trailer ( empty ($friendly) );