[-*Smarty*-] [-*****************************************************************************-] [-* Copyright (C) 2005-2006 Rod Roark and others *-] [-* Copyright (C) 2019 Jerry Padgett *-] [-* *-] [-* This program is free software; you can redistribute it and/or *-] [-* modify it under the terms of the GNU General Public License *-] [-* as published by the Free Software Foundation; either version 2 *-] [-* of the License, or (at your option) any later version. *-] [-*****************************************************************************-] [-config_load file="default.conf"-] [-*Load the Language Definitions*-] [-config_load file="lang.$USER_LANG"-] [-include file="$TPL_NAME/views/header.html"-] [-*Values used in setting timeslot and event heights*-] [-php-] /* if you change these be sure to change their matching values in * the CSS for the calendar, found in interface/themes/ajax_calendar.css */ $timeslotHeightVal=20; $timeslotHeightUnit="px"; $chevron_icon_left = $_SESSION['language_direction'] == 'ltr' ? 'fa-chevron-circle-left' : 'fa-chevron-circle-right'; $chevron_icon_right = $_SESSION['language_direction'] == 'ltr' ? 'fa-chevron-circle-right' : 'fa-chevron-circle-left'; [-/php-] [-php-] // this is my proposed setting in the globals config file so we don't // need to mess with altering the pn database AND the config file //pnModSetVar(__POSTCALENDAR__, 'pcFirstDayOfWeek', $GLOBALS['schedule_dow_start']); $openhour= $GLOBALS['schedule_start']; $closehour= $GLOBALS['schedule_end']; // build a day-of-week (DOW) list so we may properly build the calendars later in this code $DOWlist = array(); $tmpDOW = pnModGetVar(__POSTCALENDAR__, 'pcFirstDayOfWeek'); // bound check and auto-correction if ($tmpDOW <0 || $tmpDOW >6) { pnModSetVar(__POSTCALENDAR__, 'pcFirstDayOfWeek', '0'); $tmpDOW = 0; } while (count($DOWlist) < 7) { array_push($DOWlist, $tmpDOW); $tmpDOW++; if ($tmpDOW > 6) $tmpDOW = 0; } // A_CATEGORY is an ordered array of associative-array categories. // Keys of interest are: id, name, color, desc, event_duration. // // echo "\n"; // debugging // echo "\n"; // debugging $A_CATEGORY =& $this->_tpl_vars['A_CATEGORY']; $A_EVENTS =& $this->_tpl_vars['A_EVENTS']; $providers =& $this->_tpl_vars['providers']; $times =& $this->_tpl_vars['times']; $interval = $this->_tpl_vars['interval']; $viewtype = $this->_tpl_vars['VIEW_TYPE']; $PREV_WEEK_URL = $this->_tpl_vars['PREV_WEEK_URL']; $NEXT_WEEK_URL = $this->_tpl_vars['NEXT_WEEK_URL']; $PREV_DAY_URL = $this->_tpl_vars['PREV_DAY_URL']; $NEXT_DAY_URL = $this->_tpl_vars['NEXT_DAY_URL']; $PREV_MONTH_URL = $this->_tpl_vars['PREV_MONTH_URL']; $NEXT_MONTH_URL = $this->_tpl_vars['NEXT_MONTH_URL']; $Date = postcalendar_getDate(); if (!isset($y)) $y = substr($Date, 0, 4); if (!isset($m)) $m = substr($Date, 4, 2); if (!isset($d)) $d = substr($Date, 6, 2); // echo "\n"; //================================== //FACILITY FILTERING (CHEMED) $facilities = getUserFacilities($_SESSION['authUserID']); // from users_facility if ( $_SESSION['pc_facility'] ) { $provinfo = getProviderInfo('%', true, $_SESSION['pc_facility']); } else { $provinfo = getProviderInfo(); } //EOS FACILITY FILTERING (CHEMED) //================================== [-/php-]
[-php-] echo "\n"; echo "\n"; if ($Date <> date('Ymd')) { [-/php-] [-xlt t='Today'-] [-php-] } [-/php-]
[-php-] echo " \n"; $atmp = array_keys($A_EVENTS); echo text(date('d', strtotime($atmp[0]))) . " " . xlt(date('M', strtotime($atmp[0]))) . " " . text(date('Y', strtotime($atmp[0]))); echo " - "; echo text(date('d', strtotime($atmp[count($atmp)-1]))) . " " . xlt(date('M', strtotime($atmp[count($atmp)-1]))) . " " . text(date('Y', strtotime($atmp[count($atmp)-1]))); echo " \n"; [-/php-]
[-php-] echo " \n"; echo " \n"; echo " " . xlt('Day') . "\n"; echo " " . xlt('Week') . "\n"; echo " " . xlt('Month') . "\n"; [-/php-]
[-php-] /* used in debugging foreach ($A_EVENTS as $date => $events) { echo $date." = "; foreach ($events as $oneE) { echo text(print_r($oneE, true)); echo "

"; } echo "
"; } */ // This loops once for each provider to be displayed. // foreach ($providers as $provider) { $providerid = $provider['id']; // to specially handle the IN/OUT events I'm doing something new here // for each IN event it will have a duration lasting until the next // OUT event or until the end of the day $tmpTime = $times[0]; $calStartMin = ($tmpTime['hour'] * 60) + $tmpTime['minute']; $tmpTime = $times[count($times)-1]; $calEndMin = ($tmpTime['hour'] * 60) + $tmpTime['minute']; echo "
\n"; echo "\n"; echo " \n"; echo " \n"; echo " \n"; // output column (date) headers $colWidth = 100/7; // intentionally '7' and not '8' echo " \n"; echo " "; // blank TD for the header above the Times column $defaultDate = ""; // used when creating link for a 'new' event $in_cat_id = 0; // used when creating link for a 'new' event foreach ($A_EVENTS as $date => $events) { $dateFmt = date("Ymd", strtotime($date)); $gotoURL = pnModURL(__POSTCALENDAR__,'user','view', array('tplview'=>($template_view ?? null), 'viewtype'=>'day', 'Date'=> $dateFmt, 'pc_username'=>($pc_username ?? null), 'pc_category'=>($category ?? null), 'pc_topic'=>($topic ?? null))); if ($defaultDate == "") $defaultDate = $dateFmt; $currclass = ""; if ($Date == $dateFmt) { $currclass= "week_currday"; } echo ""; } echo " \n"; // output the TD with the times DIV echo ""; echo ""; // For each day... // output a TD with an inner containing DIV positioned 'relative' // within that DIV we place our event DIVs using 'absolute' positioning foreach ($A_EVENTS as $date => $events) { $eventdate = substr($date, 0, 4) . substr($date, 5, 2) . substr($date, 8, 2); // having a 'title' for the TD makes the date appear by the mouse pointer // this is nice when all you see are times on the left side and no head // row with the dates or day-of-week (DOW) $headDate=strtotime($date); $classForWeekend = is_weekend_day(date('w',$headDate)) ? 'weekend-day' : 'work-day'; echo "\n"; } // end date //================================================================================================================== echo " \n"; echo "
"; echo text($provider['fname']) . " " . text($provider['lname']); echo "
 "; echo ""; echo xlt(date("D", strtotime($date))) . " " . text(oeFormatShortDate($date, false)); echo "
\n"; //================================================================================================================== if ($GLOBALS['time_display_format'] == 1) { $timeformat = 12; } else { $timeformat = 0; } foreach ($times as $slottime) { $startampm = ($slottime['mer']) == "pm" ? 2 : 1; $starttimeh = $slottime['hour']; $disptimeh = ($starttimeh > $timeformat) ? ($starttimeh - $timeformat) : $starttimeh; $starttimem = $slottime['minute']; $slotendmins = $starttimeh * 60 + $starttimem + $interval; echo "\n"; } echo "
"; // echo ""; echo ""; //echo $slottime['hour'] * 60 + $slottime['minute']; echo text($disptimeh.":".$starttimem) . ""; echo "
"; echo "
"; // determine if events overlap and adjust their width and left position as needed // 26 Feb 2008 - This needs fine tuning or total replacement // - it doesn't work as well as I'd like - JRM $eventPositions = array(); foreach ($times as $slottime) { $starttimeh = $slottime['hour']; $starttimem = $slottime['minute']; $slotstartmins = $starttimeh * 60 + $starttimem; $slotendmins = $starttimeh * 60 + $starttimem + $interval; $events_in_timeslot = array(); foreach ($events as $e1) { // ignore IN and OUT events if (!empty($e1['catid']) && (($e1['catid'] == 2) || ($e1['catid'] == 3))) { continue; } // skip events without an ID (why they are in the loop, I have no idea) if (empty($e1['eid'])) { continue; } // skip events for other providers if ($providerid != $e1['aid']) { continue; } // specially handle all-day events if ($e1['alldayevent'] == 1) { $tmpTime = $times[0]; if (strlen($tmpTime['hour']) < 2) { $tmpTime['hour'] = "0".$tmpTime['hour']; } if (strlen($tmpTime['minute']) < 2) { $tmpTime['minute'] = "0".$tmpTime['minute']; } $e1['startTime'] = $tmpTime['hour'].":".$tmpTime['minute'].":00"; $e1['duration'] = ($calEndMin - $calStartMin) * 60; // measured in seconds } // create a numeric start and end for comparison $starth = substr($e1['startTime'], 0, 2); $startm = substr($e1['startTime'], 3, 2); $e1Start = ($starth * 60) + $startm; $e1End = $e1Start + $e1['duration']/60; // three ways to overlap: // start-in, end-in, span if ((($e1Start >= $slotstartmins) && ($e1Start < $slotendmins)) // start-in || (($e1End > $slotstartmins) && ($e1End <= $slotendmins)) // end-in || (($e1Start < $slotstartmins) && ($e1End > $slotendmins))) // span { array_push($events_in_timeslot, $e1['eid']); } } $leftpos = 0; $width = 100; if (!empty($events_in_timeslot)) { $width = 100 / count($events_in_timeslot); // loop over the events in this timeslot and adjust their width foreach ($events_in_timeslot as $eid) { $eventPositions[$eid] = new stdClass(); // set the width if not already set or if the current width is smaller // than was was previously set if (! isset($eventPositions[$eid]->width)) { $eventPositions[$eid]->width = $width; } else if ($eventPositions[$eid]->width > $width) { $eventPositions[$eid]->width = $width; } // set the left position if not already set or if the current left is // greater than what was previously set if (! isset($eventPositions[$eid]->leftpos)) { $eventPositions[$eid]->leftpos = $leftpos; } else if ($eventPositions[$eid]->leftpos < $leftpos) { $eventPositions[$eid]->leftpos = $leftpos; } // increment the leftpos by the width $leftpos += $width; } } } // end overlap detection // now loop over the events for the day and output their DIVs foreach ($events as $event) { // skip events for other providers // yeah, we've got that sort of overhead here... it ain't perfect // $event['aid']!=0 :With the holidays we included clinic events, they have provider id =0 // we dont want to exclude those events from being displayed if (!empty($event['aid']) && ($providerid != $event['aid'])) { continue; } // skip events without an ID (why they are in the loop, I have no idea) if (empty($event['eid'])) { continue; } // specially handle all-day events if ($event['alldayevent'] == 1) { $tmpTime = $times[0]; if (strlen($tmpTime['hour']) < 2) { $tmpTime['hour'] = "0".$tmpTime['hour']; } if (strlen($tmpTime['minute']) < 2) { $tmpTime['minute'] = "0".$tmpTime['minute']; } $event['startTime'] = $tmpTime['hour'].":".$tmpTime['minute'].":00"; $event['duration'] = ($calEndMin - $calStartMin) * 60; // measured in seconds } // figure the start time and minutes (from midnight) $starth = substr($event['startTime'], 0, 2); $startm = substr($event['startTime'], 3, 2); $eStartMin = $starth * 60 + $startm; $dispstarth = ($starth > 12) ? ($starth - $timeformat) : $starth; // determine the class for the event DIV based on the event category $evtClass = "event_appointment"; //fix bug 456 and 455 //check to see if the event is in the clinic hours range, if not it will not be displayed if ( (int)$starth < (int)$openhour || (int)$starth > (int)$closehour ) { continue; } switch ($event['catid']) { case 1: // NO-SHOW appt $evtClass = "event_noshow"; break; case 2: // IN office $evtClass = "event_in"; break; case 3: // OUT of office $evtClass = "event_out"; break; case 4: // VACATION $evtClass = "event_reserved"; break; case 6: // HOLIDAY $evtClass = "event_holiday"; break; case 8: // LUNCH $evtClass = "event_reserved"; break; case 11: // RESERVED $evtClass = "event_reserved"; break; case 99: // HOLIDAY $evtClass = "event_holiday"; break; default: // some appointment $evtClass = "event_appointment"; break; } // eventViewClass allows the event class to override the template (such as from a dispatched system event). $evtClass = $event['eventViewClass'] ?? $evtClass; // if this is an IN or OUT event then we have some extra special // processing to be done // the IN event creates a DIV until the OUT event // or, without an OUT DIV matching the IN event // then the IN event runs until the end of the day if ($event['catid'] == 2) { // locate a matching OUT for this specific IN $found = false; $outMins = 0; foreach ($events as $outevent) { // skip events for other providers if (!empty($outevent['aid']) && ($providerid != $outevent['aid'])) { continue; } // skip events with blank IDs if (empty($outevent['eid'])) { continue; } if ($outevent['eid'] == $event['eid']) { $found = true; continue; } if (($found == true) && ($outevent['catid'] == 3)) { // calculate the duration from this event to the outevent $outH = substr($outevent['startTime'], 0, 2); $outM = substr($outevent['startTime'], 3, 2); $outMins = ($outH * 60) + $outM; $event['duration'] = ($outMins - $eStartMin) * 60; // duration is in seconds $found = 2; break; } } if ($outMins == 0) { // no OUT was found so this event's duration goes // until the end of the day $event['duration'] = ($calEndMin - $eStartMin) * 60; // duration is in seconds } } // calculate the TOP value for the event DIV // diff between event start and schedule start $eMinDiff = $eStartMin - $calStartMin; // diff divided by the time interval of the schedule $eStartInterval = $eMinDiff / $interval; // times the interval height $eStartPos = $eStartInterval * $timeslotHeightVal; $evtTop = $eStartPos.$timeslotHeightUnit; // calculate the HEIGHT value for the event DIV // diff between end and start of event $eEndMin = $eStartMin + ($event['duration']/60); // prevent the overall height of the event from going beyond the bounds // of the time table if ($eEndMin > $calEndMin) { $eEndMin = $calEndMin + $interval; } $eMinDiff = $eEndMin - $eStartMin; // diff divided by the time interval of the schedule $eEndInterval = $eMinDiff / $interval; // times the interval height $eHeight = $eEndInterval * $timeslotHeightVal; $evtHeight = $eHeight.$timeslotHeightUnit; // determine the DIV width based on any overlapping events // see further above for the overlapping calculation code $divWidth = ""; $divLeft = ""; if (isset($eventPositions[$event['eid']])) { $divWidth = "width: ".$eventPositions[$event['eid']]->width."%"; $divLeft = "left: ".$eventPositions[$event['eid']]->leftpos."%"; } $eventid = $event['eid'] ?? null; $eventtype = sqlQuery("SELECT pc_cattype FROM openemr_postcalendar_categories as oc LEFT OUTER JOIN openemr_postcalendar_events as oe ON oe.pc_catid=oc.pc_catid WHERE oe.pc_eid='".$eventid."'"); $pccattype = ''; if($eventtype['pc_cattype']==1) $pccattype = 'true'; $patientid = $event['pid']; $commapos = strpos($event['patient_name'], ","); $lname = substr($event['patient_name'], 0, $commapos); $fname = substr($event['patient_name'], $commapos + 2); $patient_dob = oeFormatShortDate($event['patient_dob']); $patient_age = $event['patient_age']; $catid = $event['catid'] ?? ''; $comment = $event['hometext']; $catname = $event['catname']; $title = "Age $patient_age ($patient_dob)"; //Variables for therapy groups $groupid = $event['gid']; if($groupid) $patientid = ''; $groupname = $event['group_name']; $grouptype = $event['group_type']; $groupstatus = $event['group_status']; $groupcounselors = ''; foreach($event['group_counselors'] as $counselor){ $groupcounselors .= getUserNameById($counselor) . " \n "; } $content = ""; if ($comment && $GLOBALS['calendar_appt_style'] < 4) $title .= " " . $comment; // the divTitle is what appears when the user hovers the mouse over the DIV $divTitle = date("D, d M Y", strtotime($date)); $result = sqlStatement("SELECT name,id,color FROM facility WHERE id=(SELECT pc_facility FROM openemr_postcalendar_events WHERE pc_eid=?)", [$eventid]); $row = sqlFetchArray($result); $color=$event["catcolor"]; if($GLOBALS['event_color']==2) $color=$row['color']; $divTitle .= "\n" . $row['name']; if ($catid == 2 || $catid == 3 || $catid == 4 || $catid == 8 || $catid == 11) { if ($catid == 2) $catname = xl("IN"); else if ($catid == 3) $catname = xl("OUT"); else if ($catid == 4) $catname = xl("VACATION"); else if ($catid == 8) $catname = xl("LUNCH"); else if ($catid == 11) $catname = xl("RESERVED"); $atitle = $catname; if ($comment) $atitle .= " $comment"; //$divTitle .= "\n[".$atitle ."] ".$divTitle; $divTitle .= "\n[".$atitle ."]"; //$content .= ""; $content .= text($catname); if ($event['recurrtype'] > 0) $content .= " Repeating event"; if ($comment) $content .= " " . text($comment); //$content .= ""; } else { // some sort of patient appointment if($groupid){ $divTitle .= "\n" . xl('Counselors') . ": \n" . $groupcounselors . " \n"; $divTitle .= "\r\n[" . $catname . ' ' . $comment . "]" . $groupname; } else $divTitle .= "\r\n[" . $catname . ' ' . $comment . "]" .$fname . " " . $lname; $content .= ""; $content .= create_event_time_anchor($dispstarth . ':' . $startm); if ($event['recurrtype'] > 0) $content .= "Repeating event"; $content .= text($event['apptstatus']); if ($patientid) { // include patient name and link to their details $link_title = $fname . " " . $lname . " \n"; $link_title .= xl('Age') . ": " . $patient_age . "\n" . xl('DOB') . ": " . $patient_dob . $comment . "\n"; $link_title .= "(" . xl('Click to view') . ")"; $content .= ""; $content .= ""; if ($catid == 1) $content .= ""; $content .= text($lname); if ($GLOBALS['calendar_appt_style'] != 1) { $content .= "," . text($fname); if ($event['title'] && $GLOBALS['calendar_appt_style'] >= 3) { $content .= "(" . text($event['title']); if ($event['hometext'] && $GLOBALS['calendar_appt_style'] >= 4) $content .= ": " . text(trim($event['hometext'])) . ""; $content .= ")"; } } if ($catid == 1) $content .= ""; $content .= ""; $content .= ''; } elseif($groupid){ $divTitle .= "\n" . getTypeName($grouptype) . "\n"; $link_title = ''; $link_title .= $divTitle ."\n"; $link_title .= "(" . xl('Click to view') . ")"; $content .= ""; $content .= ""; if ($catid == 1) $content .= ""; $content .= text($groupname); if ($GLOBALS['calendar_appt_style'] != 1) { if ($event['title'] && $GLOBALS['calendar_appt_style'] >= 3) { $content .= "(" . text($event['title']); if ($event['hometext'] && $GLOBALS['calendar_appt_style'] >= 4) $content .= ": " . text(trim($event['hometext'])) . ""; $content .= ")"; } } if ($catid == 1) $content .= ""; $content .= ""; //Add class to wrapping div so EditEvent js function can differentiate between click on group and patient $evtClass .= ' groups '; } else { //Category Clinic closaed or holiday take the event title if ( $catid == 6 || $catid == 7){ $content .= xlt($event['title']); }else{ // no patient id, just output the category name $content .= text(xl_appt_category($catname)); } } $content .= ""; } $divTitle .= "\n(" . xl('double click to edit') . ")"; // output the DIV and content if($_SESSION['pc_facility'] == 0){ //This is to differentiate between the events of holiday(6) or vacation(4) in order to disable //the ability to double click and edit this events if ($event['catid']!="6" && $event['catid']!="4" ) { // output the DIV echo "
"; } else { // output the DIV echo "
"; } //output the content echo $content; echo "
\n"; } elseif($_SESSION['pc_facility'] == $row['id']){ echo "
"; // output the content echo $content; echo "
\n"; } else{ echo "
"; echo "" . text($row['name']) . ""; echo "
\n"; } } // end EVENT loop echo "
"; echo "
\n"; echo "
\n"; } // end provider [-/php-]