X-Git-Url: http://git.pippins.net/embedvideo/.git/static/git-logo.png?a=blobdiff_plain;ds=inline;f=inc%2Fclass.eq.inc.php;h=ab486562700611841d1376e335e7597c99d1172d;hb=f4f7ff069f8d87117e673446e0fc4ce98f696de3;hp=7890ba1c6f2fd619f3c8fa10fa1bb73347abab1b;hpb=7a92fd777c036652da0b72138ca1cf32da9a9dd8;p=eq%2F.git
diff --git a/inc/class.eq.inc.php b/inc/class.eq.inc.php
index 7890ba1..ab48656 100644
--- a/inc/class.eq.inc.php
+++ b/inc/class.eq.inc.php
@@ -22,9 +22,10 @@ class eq
var $default_ht_num_months;
var $default_ppi_num_months;
var $default_ppi_num_years;
- var $default_int_num_months;
+ var $default_int_num_quarters;
var $default_int_num_years;
- var $default_att_num_months;
+ var $default_vis_num_years;
+ var $default_att_num_quarters;
var $current_year;
var $current_month;
var $upload_target_path;
@@ -43,6 +44,7 @@ class eq
'ppi_sched' => True,
'int_view' => True,
'int_update' => True,
+ 'int_sched' => True,
'vis_sched' => True,
'vis_view' => True,
'vis_update' => True,
@@ -51,7 +53,9 @@ class eq
'dir_view' => True,
'org_view' => True,
'schedule' => True,
- 'admin' => True
+ 'admin' => True,
+ 'email_appt' => True,
+ 'send_ical_appt' => True
);
function eq()
@@ -59,14 +63,16 @@ class eq
$this->default_ht_num_months = 3;
$this->default_ppi_num_months = 3;
$this->default_ppi_num_years = 0;
- $this->default_int_num_months = 3;
+ $this->default_int_num_quarters = 1;
$this->default_int_num_years = 0;
- $this->default_att_num_months = 3;
+ $this->default_att_num_quarters = 1;
+ $this->default_vis_num_years = 1;
$this->upload_target_path = "/home/users/eqpres/eq_data/";
$this->script_path = "/usr/share/phpgroupware/eq/";
$this->db = $GLOBALS['phpgw']->db;
$this->db2 = $this->db;
+ $this->db3 = $this->db;
$this->nextmatchs = CreateObject('phpgwapi.nextmatchs');
$this->t = $GLOBALS['phpgw']->template;
$this->account = $GLOBALS['phpgw_info']['user']['account_id'];
@@ -884,7 +890,7 @@ class eq
$this->t->set_var('schedule_ppi_link_title','Schedule Yearly PPIs');
$this->t->set_var('actionurl',$GLOBALS['phpgw']->link('/eq/index.php','menuaction=eq.eq.ppi_sched&action=save'));
- $this->t->set_var('title','Yearly PPIs Scheduler');
+ $this->t->set_var('title','Yearly PPI Scheduler');
$elder_width=500; $phone_width=25; $pri_width=10; $notes_width=128; $ppi_date_width=20;
$table_width=$elder_width + $phone_width + $pri_width + $notes_width + $ppi_date_width;
@@ -913,6 +919,9 @@ class eq
" elder='" . $elder . "'" .
" WHERE appointment=" . $appointment,__LINE__,__FILE__);
+ // Email the appointment
+ $this->email_appt($appointment);
+
}
// Save any changes made to the ppi notes table
@@ -935,20 +944,19 @@ class eq
Header('Location: ' . $take_me_to_url);
}
- // Get the Districts
- $sql = "SELECT * FROM eq_district where valid=1 ORDER BY district ASC";
+ // Get the EQ President
+ $sql = "SELECT * FROM eq_presidency where president=1 and valid=1";
$this->db->query($sql,__LINE__,__FILE__);
- $i=0;
- while ($this->db->next_record())
- {
- $districts[$i]['district'] = $this->db->f('district');
- $districts[$i]['name'] = $this->db->f('name');
- $districts[$i]['supervisor'] = $this->db->f('supervisor');
- $i++;
- }
- $districts[$i]['district'] = $i + 1;
- $districts[$i]['name'] = "Unassigned";
- $districts[$i]['supervisor'] = "Unassigned";
+ if($this->db->next_record()) {
+ $president_name = $this->db->f('name');
+ $president_id = $this->db->f('elder');
+ $presidency_id = $this->db->f('presidency');
+ $district_number = '*';
+ $district_name = $president_name;
+ } else {
+ print "
$total_companionships Total Comps Interview Quarterly Totals: ";
for($m=$num_months; $m >=0; $m--) {
- $month = $this->current_month - $m;
+ $month = $current_month - $m;
if(($month % 3) == 1) { $quarter_total = $total_ints[$m]; }
else { $quarter_total += $total_ints[$m]; }
$percent = ceil(($quarter_total / $total_companionships)*100);
@@ -2162,9 +2387,19 @@ class eq
$this->t->set_var('schedule_vis_link',$GLOBALS['phpgw']->link('/eq/index.php','menuaction=eq.eq.vis_sched'));
$this->t->set_var('schedule_vis_link_title','Schedule Yearly Visits');
+
+ $this->t->set_var('linkurl',$GLOBALS['phpgw']->link('/eq/index.php','menuaction=eq.eq.vis_view'));
+ $num_years = get_var('num_years',array('GET','POST'));
+ if($num_years == '') { $num_years = $this->default_vis_num_years; }
+ $this->t->set_var('num_years',$num_years);
+ if($num_years == 1) { $this->t->set_var('lang_num_years','Year of History'); }
+ else { $this->t->set_var('lang_num_years','Years of History'); }
+ $this->t->set_var('lang_filter','Filter');
+ $year = date('Y') - $num_years + 1;
+ $year_start = $year - 1 . "-12-31"; $year_end = $year + 1 . "-01-01";
- $sql = "SELECT * FROM eq_visit WHERE companionship=0 ORDER BY date DESC";
+ $sql = "SELECT * FROM eq_visit WHERE companionship=0 and date > '$year_start' ORDER BY date DESC";
$this->db->query($sql,__LINE__,__FILE__);
$total_records = $this->db->num_rows();
@@ -2345,6 +2580,10 @@ class eq
function att_view()
{
+ $monthnum['Jan']=1; $monthnum['Feb']=2; $monthnum['Mar']=3; $monthnum['Apr']=4;
+ $monthnum['May']=5; $monthnum['Jun']=6; $monthnum['Jul']=7; $monthnum['Aug']=8;
+ $monthnum['Sep']=9; $monthnum['Oct']=10; $monthnum['Nov']=11; $monthnum['Dec']=12;
+
$this->t->set_file(array('att_view_t' => 'att_view.tpl'));
$this->t->set_block('att_view_t','act_list','list');
@@ -2353,13 +2592,20 @@ class eq
$this->t->set_block('att_view_t','elder_list','list3');
$this->t->set_var('linkurl',$GLOBALS['phpgw']->link('/eq/index.php','menuaction=eq.eq.att_view'));
- $num_months = get_var('num_months',array('GET','POST'));
- if($num_months == '') { $num_months = $this->default_att_num_months; }
- $this->t->set_var('num_months',$num_months);
+ $num_quarters = get_var('num_quarters',array('GET','POST'));
+ if($num_quarters == '') { $num_quarters = $this->default_att_num_quarters; }
+ $this->t->set_var('num_quarters',$num_quarters);
$this->t->set_var('lang_filter','Filter');
- if($num_months == 1) { $this->t->set_var('lang_num_months','Month of History'); }
- else { $this->t->set_var('lang_num_months','Months of History'); }
-
+ if($num_quarters == 1) { $this->t->set_var('lang_num_quarters','Quarter of History'); }
+ else { $this->t->set_var('lang_num_quarters','Quarters of History'); }
+
+ $num_months = $num_quarters * 3;
+ $current_month = $this->current_month;
+ if($current_month >= 1 && $current_month <= 3) { $current_month=3; }
+ else if($current_month >= 4 && $current_month <= 6) { $current_month=6; }
+ else if($current_month >= 7 && $current_month <= 9) { $current_month=9; }
+ else if($current_month >= 10 && $current_month <= 12) { $current_month=12; }
+
$sql = "SELECT * FROM eq_elder where valid=1";
$this->db->query($sql,__LINE__,__FILE__);
$i=0;
@@ -2370,13 +2616,12 @@ class eq
$i++;
}
array_multisort($elder_name, $elder_id);
-
// Create a list of sunday dates for a window of 3 months back and current month
$i=0;
$last_time = 0;
$found_sunday = 0;
- $sunday_list[0]['date'] = date("Y-m-d", mktime(0, 0, 0, date("m")-$num_months, 1, date("y")));
+ $sunday_list[0]['date'] = date("Y-m-d", mktime(0, 0, 0, $current_month-$num_months, 1, date("y")));
$last_date = explode("-",$sunday_list[0]['date']);
$last_time = mktime(0, 0, 0, $last_date[1], $last_date[2], $last_date[0]);
$time_limit = mktime(0, 0, 0, date("m"), date("t"), date("y"));
@@ -2384,7 +2629,7 @@ class eq
{
$day = date("w",$last_time);
if(date("w",$last_time) == 0) {
- $sunday_list[$i]['date'] = date("Y-m-d", $last_time);
+ $sunday_list[$i]['date'] = date("Y-m-d", $last_time);
$last_date = explode("-",$sunday_list[$i]['date']);
$last_time = mktime(0, 0, 0, $last_date[1], $last_date[2], $last_date[0]);
$sunday_list[$i]['day'] = $last_date[2];
@@ -2438,6 +2683,7 @@ class eq
$this->t->set_var('year',$sunday_list[$i]['year']);
$this->t->fp('list2','header_list',True);
$total_width += $att_width;
+ $attendance[$monthnum[$sunday_list[$i]['month']]]=0;
}
for ($i=0; $i < count($elder_id); $i++) {
@@ -2456,8 +2702,8 @@ class eq
$cur_month = $sunday_list[$j]['month'];
if($attended[$i][$cur_month] != 1) {
$attended[$i][$cur_month]=1;
- $attendance[$cur_month]++;
- }
+ $attendance[$monthnum[$cur_month]]++;
+ }
$att_table .= ' ';
} else {
$att_table .= ' ';
@@ -2477,6 +2723,7 @@ class eq
$avenonattendance_str = "";
$num_months=0;
$ave_total_attended=0;
+ ksort($attendance);
foreach($attendance as $att => $value) {
$total_attended = $attendance[$att];
$ave_total_attended += $attendance[$att]; $num_months++;
@@ -2557,6 +2804,7 @@ class eq
{
$elder_name[$i] = $this->db->f('name');
$elder_id[$i] = $this->db->f('elder');
+ $elder_attending[$elder_id[$i]] = $this->db->f('attending');
$i++;
}
array_multisort($elder_name, $elder_id);
@@ -2634,6 +2882,8 @@ class eq
$value = $elder_id[$i] . "-" . $sunday_list[$j]['date'];
if($this->db->next_record()) {
$att_table .= ' ';
+ } else if($elder_attending[$elder_id[$i]] == 1) {
+ $att_table .= ' ';
} else {
$att_table .= ' ';
}
@@ -2755,7 +3005,7 @@ class eq
function schedule()
{
$this->t->set_file(array('sched_t' => 'schedule.tpl'));
- $this->t->set_block('sched_t','district_list','list');
+ $this->t->set_block('sched_t','presidency_list','list');
$action = get_var('action',array('GET','POST'));
@@ -2765,11 +3015,14 @@ class eq
$this->t->set_var('lang_save','Save Schedule');
$this->t->set_var('lang_reset','Cancel');
- $this->t->set_var('schedule_ppi_link',$GLOBALS['phpgw']->link('/eq/index.php','menuaction=eq.eq.ppi_sched'));
- $this->t->set_var('schedule_ppi_link_title','Schedule Yearly PPIs');
-
$this->t->set_var('schedule_vis_link',$GLOBALS['phpgw']->link('/eq/index.php','menuaction=eq.eq.vis_sched'));
$this->t->set_var('schedule_vis_link_title','Schedule Yearly Visits');
+
+ $this->t->set_var('schedule_int_link',$GLOBALS['phpgw']->link('/eq/index.php','menuaction=eq.eq.int_sched'));
+ $this->t->set_var('schedule_int_link_title','Schedule Hometeaching Interviews');
+
+ $this->t->set_var('schedule_ppi_link',$GLOBALS['phpgw']->link('/eq/index.php','menuaction=eq.eq.ppi_sched'));
+ $this->t->set_var('schedule_ppi_link_title','Schedule Yearly PPIs');
$date_width=150; $time_width=200; $elder_width=200; $family_width=200;
$table_width=$date_width + $time_width + $elder_width + $family_width;
@@ -2782,11 +3035,11 @@ class eq
if($action == 'save')
{
$new_data = get_var('sched',array('POST'));
- foreach ($new_data as $district_array)
+ foreach ($new_data as $presidency_array)
{
- foreach ($district_array as $entry)
+ foreach ($presidency_array as $entry)
{
- $district = $entry['district'];
+ $presidency = $entry['presidency'];
$appointment = $entry['appointment'];
$date = $entry['date'];
$hour = $entry['hour'];
@@ -2796,6 +3049,7 @@ class eq
$family = $entry['family'];
if($pm) { $hour = $hour + 12; }
$time = $hour.':'.$minute.':'.'00';
+ $uid = 0;
// Update an existing appointment
if($appointment != 0)
@@ -2807,15 +3061,16 @@ class eq
" ,time='" . $time . "'" .
" WHERE appointment=" . $appointment,__LINE__,__FILE__);
- //print "updating entry: appt=$appointment date: $date time: $time elder: $elder family: $family ";
+ // Email the appointment
+ $this->email_appt($appointment);
}
// Add a new appointment
else if(($appointment == 0) && ($date != "") && ($time != ""))
{
- $this->db->query("INSERT INTO eq_appointment (appointment,district,family,elder,date,time) "
- . "VALUES ('" . $appointment . "','" . $district . "','" . $family . "','"
- . $elder . "','" . $date . "','" . $time ."')",__LINE__,__FILE__);
+ $this->db->query("INSERT INTO eq_appointment (appointment,presidency,family,elder,date,time) "
+ . "VALUES ('" . $appointment . "','" . $presidency . "','" . $family . "','"
+ . $elder . "','" . $date . "','" . $time . "','" . $uid ."')",__LINE__,__FILE__);
//print "adding entry: appt=$appointment date: $date time: $time elder: $elder family: $family ";
}
@@ -2825,15 +3080,15 @@ class eq
$take_me_to_url = $GLOBALS['phpgw']->link('/eq/index.php','menuaction=eq.eq.schedule');
Header('Location: ' . $take_me_to_url);
}
-
- $sql = "SELECT * FROM eq_district where district != 0 ORDER BY district ASC";
+
+ $sql = "SELECT * FROM eq_presidency where valid=1";
$this->db->query($sql,__LINE__,__FILE__);
$i=0;
while ($this->db->next_record())
{
- $districts[$i]['district'] = $this->db->f('district');
- $districts[$i]['name'] = $this->db->f('name');
- $districts[$i]['supervisor'] = $this->db->f('supervisor');
+ $presidency_data[$i]['id'] = $this->db->f('presidency');
+ $presidency_data[$i]['name'] = $this->db->f('name');
+ $presidency_data[$i]['elder'] = $this->db->f('elder');
$i++;
}
@@ -2860,15 +3115,15 @@ class eq
}
array_multisort($family_name, $family_id);
- for ($i=0; $i < count($districts); $i++) {
- $district = $districts[$i]['district'];
- $this->t->set_var('district_number',$districts[$i]['district']);
- $this->t->set_var('district_name',$districts[$i]['name']);
- $supervisor = $districts[$i]['supervisor'];
+ for ($i=0; $i < count($presidency_data); $i++) {
+ $presidency = $presidency_data[$i]['id'];
+ $interviewer = $presidency_data[$i]['elder'];
+ $name = $presidency_data[$i]['name'];
+ $this->t->set_var('presidency_name',$name);
$table_data="";
// query the database for all the appointments
- $sql = "SELECT * FROM eq_appointment where district=$district and date>=CURDATE() ORDER BY date ASC, time ASC";
+ $sql = "SELECT * FROM eq_appointment where presidency=$presidency and date>=CURDATE() ORDER BY date ASC, time ASC";
$this->db->query($sql,__LINE__,__FILE__);
// Prefill any existing appointment slots
@@ -2895,33 +3150,33 @@ class eq
// Date selection
$table_data.= '';
- $table_data.= $this->jscal->input('sched['.$district.']['.$appointment.'][date]',$date,'','','','','',$this->cal_options);
+ $table_data.= $this->jscal->input('sched['.$presidency.']['.$appointment.'][date]',$date,'','','','','',$this->cal_options);
$table_data.= ' ';
// Hour & Minutes selection
$table_data.= "";
- $table_data.= '';
+ $table_data.= '';
foreach(range(1,12) as $num) {
if($hour == $num) { $selected[$num] = 'selected="selected"'; } else { $selected[$num] = ''; }
$table_data.= ''.$num.' ';
}
$table_data.= ' ';
$table_data.= ' : ';
- $table_data.= '';
+ $table_data.= '';
foreach(range(0,3) as $num) {
$num = $num * 15; if($num == 0) { $num = "00"; }
if($minute == $num) { $selected[$num] = 'selected="selected"'; } else { $selected[$num] = ''; }
$table_data.= ''.$num.' ';
}
$table_data.= ' ';
- $table_data.= '';
+ $table_data.= '';
if($pm == 0) { $table_data.= 'am '; $table_data.= 'pm '; }
else { $table_data.= 'am '; $table_data.= 'pm '; }
$table_data.= ' ';
$table_data.= " ";
// Elder drop down list (for PPIs)
- $table_data.= '';
+ $table_data.= '';
$table_data.= ' ';
for ($j=0; $j < count($elder_id); $j++) {
$id = $elder_id[$j];
@@ -2932,7 +3187,7 @@ class eq
$table_data.=' ';
// Family drop down list (for Visits)
- $table_data.= '';
+ $table_data.= '';
$table_data.= ' ';
for ($j=0; $j < count($elder_id); $j++) {
$id = $family_id[$j];
@@ -2942,8 +3197,8 @@ class eq
}
$table_data.=' ';
- $table_data.= ' ';
- $table_data.= ' ';
+ $table_data.= ' ';
+ $table_data.= ' ';
$tr_color = $this->nextmatchs->alternate_row_color($tr_color);
$this->t->set_var('tr_color',$tr_color);
@@ -2956,26 +3211,26 @@ class eq
// Date selection
$table_data.= '';
- $table_data.= $this->jscal->input('sched['.$district.']['.$appointment.'][date]','','','','','','',$this->cal_options);
+ $table_data.= $this->jscal->input('sched['.$presidency.']['.$appointment.'][date]','','','','','','',$this->cal_options);
$table_data.= ' ';
// Time selection
$table_data.= "";
- $table_data.= '';
+ $table_data.= '';
$table_data.= ' ';
foreach(range(1,12) as $num) {
$table_data.= ''.$num.' ';
}
$table_data.= ' ';
$table_data.= ' : ';
- $table_data.= '';
+ $table_data.= '';
$table_data.= ' ';
foreach(range(0,3) as $num) {
$num = $num * 15; if($num == 0) { $num = "00"; }
$table_data.= ''.$num.' ';
}
$table_data.= ' ';
- $table_data.= '';
+ $table_data.= '';
$table_data.= ' ';
$table_data.= 'am ';
$table_data.= 'pm ';
@@ -2983,7 +3238,7 @@ class eq
$table_data.= " ";
// Elder drop down list
- $table_data.= '';
+ $table_data.= '';
$table_data.= ' ';
for ($j=0; $j < count($elder_id); $j++) {
$id = $elder_id[$j];
@@ -2993,7 +3248,7 @@ class eq
$table_data.=' ';
// Family drop down list
- $table_data.= '';
+ $table_data.= '';
$table_data.= ' ';
for ($j=0; $j < count($elder_id); $j++) {
$id = $family_id[$j];
@@ -3002,13 +3257,13 @@ class eq
}
$table_data.=' ';
- $table_data.= ' ';
- $table_data.= ' ';
+ $table_data.= ' ';
+ $table_data.= ' ';
$this->t->set_var('table_data',$table_data);
$this->t->set_var('header_row',$header_row);
$this->t->set_var('table_width',$table_width);
- $this->t->fp('list','district_list',True);
+ $this->t->fp('list','presidency_list',True);
}
@@ -3140,7 +3395,175 @@ class eq
$this->save_sessiondata();
}
-
+
+ function email_appt($appointment)
+ {
+ //print "Emailing notification of appointment: $appointment ";
+
+ $sql = "SELECT * FROM eq_appointment where appointment='$appointment'";
+ $this->db->query($sql,__LINE__,__FILE__);
+
+ while ($this->db->next_record())
+ {
+ $appointment = $this->db->f('appointment');
+ $presidency = $this->db->f('presidency');
+ $interviewer = "";
+ $email = "";
+ $elder = $this->db->f('elder');
+ $elder_name = "";
+ $family = $this->db->f('family');
+ $family_name = "";
+ $appt_name = "";
+ $phone = "";
+ $location = "";
+ $uid = $this->db->f('uid');
+
+ // Extract the year, month, day, hours, minutes, seconds from the appointment time
+ $appt_date = $this->db->f('date');
+ $date_array = explode("-",$appt_date);
+ $year = $date_array[0]; $month = $date_array[1]; $day = $date_array[2];
+ $appt_time = $this->db->f('time');
+ $time_array = explode(":",$appt_time);
+ $hour = $time_array[0]; $minute = $time_array[1]; $seconds = $time_array[2];
+
+ // Format the appointment time into an iCal UTC equivalent
+ $dtstamp = gmdate("Ymd"."\T"."His"."\Z");
+ $dtstart = gmdate("Ymd"."\T"."His"."\Z", mktime($hour,$minute,$seconds,$month,$day,$year));
+
+ // Set the email address of the person making the appointment
+ $from = $GLOBALS['phpgw_info']['user']['fullname'] . "<" .
+ $GLOBALS['phpgw_info']['user']['preferences']['email']['address'] . ">";
+
+ $sql = "SELECT * FROM eq_presidency where presidency='$presidency'";
+ $this->db2->query($sql,__LINE__,__FILE__);
+ if($this->db2->next_record()) {
+ $email = $this->db2->f('email');
+ $interviewer = $this->db2->f('name');
+ }
+
+ if($elder > 0) {
+ $sql = "SELECT * FROM eq_elder where elder='$elder'";
+ $this->db2->query($sql,__LINE__,__FILE__);
+ if($this->db2->next_record()) {
+ $elder_name = $this->db2->f('name');
+ $phone = $this->db2->f('phone');
+ $appt_name = $elder_name . " Interview";
+ $location = "$interviewer"."'s home";
+ $duration = 1800; // 30 minutes
+ }
+ }
+
+ if($family > 0) {
+ $sql = "SELECT * FROM eq_family where family='$family'";
+ $this->db2->query($sql,__LINE__,__FILE__);
+ if($this->db2->next_record()) {
+ $family_name = $this->db2->f('name');
+ $phone = $this->db2->f('phone');
+ $elder_id = $this->db2->f('elder_id');
+ $appt_name = $family_name . " Family Visit";
+ $sql = "SELECT * FROM eq_elder where elder='$elder_id'";
+ $this->db3->query($sql,__LINE__,__FILE__);
+ if($this->db3->next_record()) {
+ $phone = $this->db3->f('phone');
+ }
+ $sql = "SELECT * FROM eq_parent where family='$family'";
+ $this->db3->query($sql,__LINE__,__FILE__);
+ if($this->db3->next_record()) {
+ $location=$this->db3->f('address');
+ }
+ $duration = 2700; // 45 minutes
+ }
+ }
+
+ $dtend = gmdate("Ymd"."\T"."His"."\Z", mktime($hour,$minute,$seconds+$duration,$month,$day,$year));
+ $description = "$appt_name : $phone";
+
+ if(($uid == 0) && ($appt_name != "")) {
+ // Create a new calendar item for this appointment, since this must be the first time we
+ // are sending it out.
+ print "Sent new appointment to " . $interviewer . " at " . $email . " for " . $appt_name . " ";
+ $uid = rand() . rand(); // Generate a random identifier for this appointment
+ $subject = "Created: $appt_name";
+
+ $this->db->query("UPDATE eq_appointment set" .
+ " uid=" . $uid .
+ " WHERE appointment=" . $appointment,__LINE__,__FILE__);
+
+ $action = "PUBLISH";
+ $this->send_ical_appt($action, $email, $from, $subject, $dtstamp, $dtstart,
+ $dtend, $location, $appt_name, $description, $uid);
+
+ } else if(($uid != 0) && ($appt_name == "")) {
+ // Remove the calendar item for this appointment since it has already been sent
+ // and there is no name we have changed it to.
+ print "Sent deleted appointment to " . $interviewer . " at " . $email . " for " . $appt_date . " " . $appt_time . " ";
+ $subject = "Canceled: $appt_date $appt_time";
+
+ $this->db->query("UPDATE eq_appointment set" .
+ " uid=0" .
+ " WHERE appointment=" . $appointment,__LINE__,__FILE__);
+
+ $action = "CANCEL";
+ $this->send_ical_appt($action, $email, $from, $subject, $dtstamp, $dtstart,
+ $dtend, $location, $appt_name, $description, $uid);
+
+ } else if($uid != 0) {
+ // Update the existing appointment since we have changed it
+ print "Sent updated appointment to " . $interviewer . " at " . $email . " for " . $appt_name . " ";
+
+ $subject = "Canceled: $appt_date $appt_time";
+ $action = "CANCEL";
+ $this->send_ical_appt($action, $email, $from, $subject, $dtstamp, $dtstart,
+ $dtend, $location, $appt_name, $description, $uid);
+
+ $uid = rand() . rand(); // Generate a random identifier for this appointment
+ $this->db->query("UPDATE eq_appointment set" .
+ " uid=" . $uid .
+ " WHERE appointment=" . $appointment,__LINE__,__FILE__);
+
+ $subject = "Updated: $appt_name";
+ $action = "PUBLISH";
+ $this->send_ical_appt($action, $email, $from, $subject, $dtstamp, $dtstart,
+ $dtend, $location, $appt_name, $description, $uid);
+ }
+
+ }
+
+ return true;
+ }
+
+ function send_ical_appt($action, $to, $from, $subject, $dtstamp, $dtstart, $dtend, $location, $summary, $description, $uid)
+ {
+ $headers = 'From: ' . "$from" . "\n" .
+ 'Reply-To: ' . "$from" . "\n" .
+ 'X-Mailer: PHP/' . phpversion() . "\n" .
+ 'Content-Type: text/calendar;' . "\n" .
+ 'Content-Transfer-Encoding: 7bit' . "\n";
+
+ //$message = "phone: $phone date: $date time: $time";
+ $message ="";
+ $message.="BEGIN:VCALENDAR" . "\n";
+ $message.="VERSION:2.0" . "\n";
+ $message.="PRODID:-//Microsoft Corporation//Outlook 11.0 MIMEDIR//EN" . "\n";
+ $message.="METHOD:$action" . "\n";
+ $message.="BEGIN:VEVENT" . "\n";
+ $message.="ORGANIZER:MAILTO:$from". "\n";
+ $message.="DTSTAMP:$dtstamp" . "\n";
+ $message.="DTSTART:$dtstart" . "\n";
+ $message.="DTEND:$dtend" . "\n";
+ $message.="SUMMARY:$summary" . "\n";
+ $message.="DESCRIPTION:$description" . "\n";
+ $message.="LOCATION:$location" . "\n";
+ $message.="UID:$uid" ."\n";
+ $message.="TRANSP:OPAQUE" . "\n";
+ $message.="SEQUENCE:0" . "\n";
+ $message.="CLASS:PUBLIC" . "\n";
+ $message.="END:VEVENT" . "\n";
+ $message.="END:VCALENDAR" . "\n";
+
+ mail($to, $subject, $message, $headers);
+
+ }
}
?>