X-Git-Url: http://git.pippins.net/embedvideo/.git/static/gitweb.js?a=blobdiff_plain;f=inc%2Fclass.eq.inc.php;h=4198742697a8bd37196a62f2f05f8f6d326404a3;hb=a100da6eaa771d531566cd9280ab98c8b0268c34;hp=7890ba1c6f2fd619f3c8fa10fa1bb73347abab1b;hpb=7a92fd777c036652da0b72138ca1cf32da9a9dd8;p=eq%2F.git
diff --git a/inc/class.eq.inc.php b/inc/class.eq.inc.php
index 7890ba1..4198742 100644
--- a/inc/class.eq.inc.php
+++ b/inc/class.eq.inc.php
@@ -8,7 +8,7 @@
* Free Software Foundation; either version 2 of the License, or (at your *
* option) any later version. *
\**************************************************************************/
- /* $Id: class.eq.inc.php,v 1.1.1.1 2001/05/20 07:40:32 seek3r Exp $ */
+ /* $Id: class.eq.inc.php,v 1.1.1.1 2005/07/20 07:40:32 ajp Exp $ */
class eq
{
@@ -22,13 +22,17 @@ 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 $max_num_districts;
var $current_year;
var $current_month;
var $upload_target_path;
var $script_path;
+ var $max_appointments;
+ var $max_presidency_members;
var $public_functions = array
(
@@ -43,6 +47,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,22 +56,35 @@ class eq
'dir_view' => True,
'org_view' => True,
'schedule' => True,
- 'admin' => True
+ 'admin' => True,
+ 'email_appt' => True,
+ 'willing_view' => True,
+ 'willing_update' => True,
+ 'send_ical_appt' => True,
+ 'assign_view' => True,
+ 'assign_update' => True,
);
function eq()
{
+ // LOCAL CONFIGURATION. PLEASE UPDATE AS APPROPRIATE.
+ $this->upload_target_path = "/home/users/eqpres/eq_data/";
+ $this->script_path = "/usr/share/phpgroupware/eq/bin/";
$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->upload_target_path = "/home/users/eqpres/eq_data/";
- $this->script_path = "/usr/share/phpgroupware/eq/";
+ $this->default_att_num_quarters = 1;
+ $this->default_vis_num_years = 1;
+ $this->max_num_districts = 4;
+ $this->max_presidency_members = 99;
+ $this->max_appointments = 32768;
+ // END LOCAL CONFIGURATION
$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'];
@@ -79,7 +97,7 @@ class eq
mondayFirst : false,
weekNumbers : false';
- $GLOBALS['phpgw_info']['flags']['app_header'] = 'Elders Quorum Tools';
+ $GLOBALS['phpgw_info']['flags']['app_header'] = 'Elders Quorum Tools - The 3rd Counselor';
$GLOBALS['phpgw']->common->phpgw_header();
$this->current_day = `date '+%d'`;
@@ -119,6 +137,12 @@ class eq
$link_data['menuaction'] = 'eq.eq.act_list';
$this->t->set_var('link_activity',$GLOBALS['phpgw']->link('/eq/index.php',$link_data));
$this->t->set_var('lang_activity','Activities');
+ $link_data['menuaction'] = 'eq.eq.willing_view';
+ $this->t->set_var('link_willing',$GLOBALS['phpgw']->link('/eq/index.php',$link_data));
+ $this->t->set_var('lang_willing','Willingness');
+ $link_data['menuaction'] = 'eq.eq.assign_view';
+ $this->t->set_var('link_assignment',$GLOBALS['phpgw']->link('/eq/index.php',$link_data));
+ $this->t->set_var('lang_assignment','Assignments');
$link_data['menuaction'] = 'eq.eq.par_view';
$this->t->set_var('link_participation',$GLOBALS['phpgw']->link('/eq/index.php',$link_data));
$this->t->set_var('lang_participation','Participation');
@@ -295,10 +319,10 @@ class eq
if($this->db2->next_record()) {
if($this->db2->f('visited') == 'y') {
$visits[$m]++; $total_visits[$m]++;
- $table_data .= '
$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);
@@ -2059,7 +2777,7 @@ class eq
if($action == 'save')
{
- $notes = $this->db->db_addslashes(get_var('notes',array('POST')));
+ $notes = get_var('notes',array('POST'));
$this->db->query("UPDATE eq_interview set " .
" interview='" . $interview . "'" .
", interviewer='" . $interviewer . "'" .
@@ -2074,7 +2792,7 @@ class eq
if($action == 'insert')
{
- $notes = $this->db->db_addslashes(get_var('notes',array('POST')));
+ $notes = get_var('notes',array('POST'));
$this->db->query("INSERT INTO eq_interview (interviewer,elder,aaronic,date,notes) "
. "VALUES ('" . $interviewer . "','" . $elder . "','" . $aaronic . "','"
. $date . "','" . $notes ."')",__LINE__,__FILE__);
@@ -2162,9 +2880,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();
@@ -2262,7 +2990,7 @@ class eq
if($action == 'save')
{
- $notes = $this->db->db_addslashes(get_var('notes',array('POST')));
+ $notes = get_var('notes',array('POST'));
$this->db->query("UPDATE eq_visit set " .
" date='" . $date . "'" .
", notes='" . $notes . "'" .
@@ -2273,7 +3001,7 @@ class eq
if($action == 'insert')
{
- $notes = $this->db->db_addslashes(get_var('notes',array('POST')));
+ $notes = get_var('notes',array('POST'));
$this->db->query("INSERT INTO eq_visit (family,companionship,date,notes) "
. "VALUES ('" . $family . "','" . $companionship . "','"
. $date . "','" . $notes . "')",__LINE__,__FILE__);
@@ -2345,6 +3073,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 +3085,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 +3109,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 +3122,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 +3176,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,9 +3195,9 @@ class eq
$cur_month = $sunday_list[$j]['month'];
if($attended[$i][$cur_month] != 1) {
$attended[$i][$cur_month]=1;
- $attendance[$cur_month]++;
- }
- $att_table .= ' ';
+ $attendance[$monthnum[$cur_month]]++;
+ }
+ $att_table .= ' ';
} else {
$att_table .= ' ';
}
@@ -2477,6 +3216,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 +3297,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 +3375,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 +3498,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 +3508,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 +3528,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,28 +3542,66 @@ class eq
$family = $entry['family'];
if($pm) { $hour = $hour + 12; }
$time = $hour.':'.$minute.':'.'00';
+ $uid = 0;
+ // Zero out the family or elder if date = NULL
+ if($date == "") {
+ $elder = 0;
+ $family = 0;
+ }
+
// Update an existing appointment
- if($appointment != 0)
+ if($appointment < $this->max_appointments)
{
- $this->db->query("UPDATE eq_appointment set" .
- " family=" . $family .
- " ,elder=" . $elder .
- " ,date='" . $date . "'" .
- " ,time='" . $time . "'" .
- " WHERE appointment=" . $appointment,__LINE__,__FILE__);
-
- //print "updating entry: appt=$appointment date: $date time: $time elder: $elder family: $family ";
+ //Only perform a database update if we have made a change to this appointment
+ $sql = "SELECT * FROM eq_appointment where " .
+ "appointment='$appointment'" .
+ " and presidency='$presidency'" .
+ " and elder='$elder'" .
+ " and family='$family'" .
+ " and date='$date'" .
+ " and time='$time'";
+ $this->db->query($sql,__LINE__,__FILE__);
+ if(!$this->db->next_record()) {
+ $old_date = $this->db->f('date');
+ $old_time = $this->db->f('time');
+ $this->db2->query("UPDATE eq_appointment set" .
+ " family=" . $family .
+ " ,elder=" . $elder .
+ " ,date='" . $date . "'" .
+ " ,time='" . $time . "'" .
+ " ,presidency='" . $presidency . "'" .
+ " WHERE appointment=" . $appointment,__LINE__,__FILE__);
+
+ // Email the appointment
+ $this->email_appt($appointment);
+ }
}
// Add a new appointment
- else if(($appointment == 0) && ($date != "") && ($time != ""))
+ else if(($appointment >= $this->max_appointments) && ($date != "") && ($time != ""))
{
- $this->db->query("INSERT INTO eq_appointment (appointment,district,family,elder,date,time) "
- . "VALUES ('" . $appointment . "','" . $district . "','" . $family . "','"
- . $elder . "','" . $date . "','" . $time ."')",__LINE__,__FILE__);
-
- //print "adding entry: appt=$appointment date: $date time: $time elder: $elder family: $family ";
+ //print "adding entry: appt=$appointment date: $date time: $time elder: $elder family: $family ";
+ $this->db2->query("INSERT INTO eq_appointment (appointment,presidency,family,elder,date,time,uid) "
+ . "VALUES (NULL,'" . $presidency . "','" . $family . "','"
+ . $elder . "','" . $date . "','" . $time . "','" . $uid ."')",__LINE__,__FILE__);
+
+ // Now reselect this entry from the database to see if we need
+ // to send an appointment out for it.
+ $sql = "SELECT * FROM eq_appointment where " .
+ "elder='$elder'" .
+ " and family='$family'" .
+ " and presidency='$presidency'" .
+ " and date='$date'" .
+ " and time='$time'" .
+ " and uid='$uid'";
+ $this->db3->query($sql,__LINE__,__FILE__);
+ if($this->db3->next_record()) {
+ // Email the appointment if warranted
+ if(($date != "") && ($time != "") && (($elder > 0) || $family > 0)) {
+ $this->email_appt($this->db3->f('appointment'));
+ }
+ }
}
}
}
@@ -2825,15 +3609,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 +3644,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 +3679,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 +3716,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 +3726,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);
@@ -2951,64 +3735,69 @@ class eq
}
// Create blank appointment slot
- $appointment = 0;
- $table_data.= "";
-
- // Date selection
- $table_data.= '';
- $table_data.= $this->jscal->input('sched['.$district.']['.$appointment.'][date]','','','','','','',$this->cal_options);
- $table_data.= ' ';
-
- // Time selection
- $table_data.= "";
- $table_data.= '';
- $table_data.= ' ';
- foreach(range(1,12) as $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"; }
- $table_data.= ''.$num.' ';
- }
- $table_data.= ' ';
- $table_data.= '';
- $table_data.= ' ';
- $table_data.= 'am ';
- $table_data.= 'pm ';
- $table_data.= ' ';
- $table_data.= " ";
-
- // Elder drop down list
- $table_data.= '';
- $table_data.= ' ';
- for ($j=0; $j < count($elder_id); $j++) {
- $id = $elder_id[$j];
- $name = $elder_name[$j];
- $table_data.= ''.$name.' ';
- }
- $table_data.=' ';
+ for ($b=0; $b < 4; $b++) {
+ $appointment = $this->max_appointments + $b;
+ $table_data.= " ";
+
+ // Date selection
+ $table_data.= '';
+ $table_data.= $this->jscal->input('sched['.$presidency.']['.$appointment.'][date]','','','','','','',$this->cal_options);
+ $table_data.= ' ';
- // Family drop down list
- $table_data.= '';
- $table_data.= ' ';
- for ($j=0; $j < count($elder_id); $j++) {
- $id = $family_id[$j];
- $name = $family_name[$j];
- $table_data.= ''.$name.' Family ';
- }
- $table_data.=' ';
-
- $table_data.= ' ';
- $table_data.= ' ';
+ // Time selection
+ $table_data.= "";
+ $table_data.= '';
+ $table_data.= ' ';
+ foreach(range(1,12) as $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"; }
+ $table_data.= ''.$num.' ';
+ }
+ $table_data.= ' ';
+ $table_data.= '';
+ $table_data.= ' ';
+ $table_data.= 'am ';
+ $table_data.= 'pm ';
+ $table_data.= ' ';
+ $table_data.= " ";
+
+ // Elder drop down list
+ $table_data.= '';
+ $table_data.= ' ';
+ for ($j=0; $j < count($elder_id); $j++) {
+ $id = $elder_id[$j];
+ $name = $elder_name[$j];
+ $table_data.= ''.$name.' ';
+ }
+ $table_data.=' ';
+
+ // Family drop down list
+ $table_data.= '';
+ $table_data.= ' ';
+ for ($j=0; $j < count($elder_id); $j++) {
+ $id = $family_id[$j];
+ $name = $family_name[$j];
+ $table_data.= ''.$name.' Family ';
+ }
+ $table_data.=' ';
+
+ $table_data.= ' ';
+ $table_data.= ' ';
+
+ $tr_color = $this->nextmatchs->alternate_row_color($tr_color);
+ $this->t->set_var('tr_color',$tr_color);
+ }
$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);
}
@@ -3022,13 +3811,27 @@ class eq
$this->t->set_block('admin_t','upload','uploadhandle');
$this->t->set_block('admin_t','admin','adminhandle');
$this->t->set_block('admin_t','cmd','cmdhandle');
+ $this->t->set_block('admin_t','presidency','presidencyhandle');
$this->t->set_var('upload_action',$GLOBALS['phpgw']->link('/eq/index.php','menuaction=eq.eq.admin&action=upload'));
+ $this->t->set_var('presidency_action',$GLOBALS['phpgw']->link('/eq/index.php','menuaction=eq.eq.admin&action=presidency'));
$action = get_var('action',array('GET','POST'));
$this->t->pfp('out','admin_t');
-
+
+ $sql = "SELECT * FROM eq_elder where valid=1 ORDER BY elder ASC";
+ $this->db->query($sql,__LINE__,__FILE__);
+ $i=0;
+ while ($this->db->next_record())
+ {
+ $elder_id[$i] = $this->db->f('elder');
+ $elder_name[$i] = $this->db->f('name');
+ $elder2name[$elder_id[$i]] = $elder_name[$i];
+ $i++;
+ }
+ array_multisort($elder_name, $elder_id);
+
if($action == 'upload')
{
$target_path = $this->upload_target_path . basename( $_FILES['uploadedfile']['name']);
@@ -3132,15 +3935,409 @@ class eq
$this->t->pfp('uploadhandle','upload',True);
}
}
+ else if($action == "presidency")
+ {
+ $new_data = get_var('eqpres',array('POST'));
+ foreach ($new_data as $entry)
+ {
+ $id = $entry['id'];
+ $email = $entry['email'];
+ $elder = $entry['elder'];
+ $name = $entry['name'];
+ $district = $entry['district'];
+ $president = $entry['president'];
+ $counselor = $entry['counselor'];
+ $secretary = $entry['secretary'];
+ $eqpresidency = $entry['eqpresidency'];
+ // Set the elder id to 0 for EQ Presidency tagged entry
+ if($eqpresidency == 1) { $elder="0"; }
+ // Re-look up the elder name for the ID if we aren't an EQ Presidency tagged entry
+ else { $name = $elder2name[$elder]; }
+ //print "id=$id elder=$elder name=$name email=$email district=$district president=$president ";
+ //print "counselor=$counselor secretary=$secretary eqpres=$eqpresidency ";
+
+ if(($elder > 0) || ($name != "")) {
+ if($id < $this->max_presidency_members) {
+ //print "Updating Existing Entry ";
+ $this->db2->query("UPDATE eq_presidency set" .
+ " elder=" . $elder .
+ " ,district=" . $district .
+ " ,name='" . $name . "'" .
+ " ,email='" . $email . "'" .
+ " ,president='" . $president . "'" .
+ " ,counselor='" . $counselor . "'" .
+ " ,secretary='" . $secretary . "'" .
+ " ,eqpres='" . $eqpresidency . "'" .
+ " WHERE presidency=" . $id,__LINE__,__FILE__);
+
+ } else {
+ //print "Adding New Entry ";
+ $this->db2->query("INSERT INTO eq_presidency (presidency,elder,district,name,"
+ . "email,president,counselor,secretary,eqpres,valid) "
+ . "VALUES (NULL,'" . $elder . "','" . $district . "','"
+ . $name . "','" . $email . "','" . $president . "','"
+ . $counselor . "','" . $secretary . "','" . $eqpres . "','1'"
+ .")",__LINE__,__FILE__);
+ }
+ } else {
+ //print "Ignoring Blank Entry ";
+ }
+ }
+
+ // Now update the eq_district table appropriately
+
+ // Delete all the previous district entries from the table
+ $this->db->query("DELETE from eq_district where valid=1",__LINE__,__FILE__);
+ $this->db->query("DELETE from eq_district where valid=0",__LINE__,__FILE__);
+
+ // Always add a "District 0" assigned to the High Priests Group
+ $district = 0;
+ $name = "High Priests";
+ $elder = 0;
+ $valid = 0;
+ $this->db2->query("INSERT INTO eq_district (district,name,supervisor,valid) "
+ . "VALUES ('" . $district . "','" . $name . "','"
+ . $elder . "','" . $valid . "'"
+ .")",__LINE__,__FILE__);
+
+
+ // Requery the eq_presidency table
+ $sql = "SELECT * FROM eq_presidency where valid=1";
+ $this->db->query($sql,__LINE__,__FILE__);
+ while ($this->db->next_record())
+ {
+ // Extract the data for each presidency record
+ $id = $this->db->f('presidency');
+ $elder = $this->db->f('elder');
+ $name = $this->db->f('name');
+ $district = $this->db->f('district');
+ $name = $this->db->f('name');
+ $valid = 1;
+
+ // If we have a valid district, add it to the district table
+ if($district > 0) {
+ $this->db2->query("INSERT INTO eq_district (district,name,supervisor,valid) "
+ . "VALUES ('" . $district . "','" . $name . "','"
+ . $elder . "','" . $valid . "'"
+ .")",__LINE__,__FILE__);
+ }
+
+ }
+
+ $this->t->set_var('adminhandle','');
+ $this->t->pfp('adminhandle','admin');
+ }
else
{
$this->t->set_var('adminhandle','');
$this->t->pfp('adminhandle','admin');
}
+
+ // Now save off the data needed for an EQ Presidency Table Update
+
+ $sql = "SELECT * FROM eq_presidency where valid=1";
+ $this->db->query($sql,__LINE__,__FILE__);
+ $table_data = "";
+ $header_row = "Elder Email District President Counselor Secretary EQ Presidency ";
+ while ($this->db->next_record())
+ {
+ // Extract the data for each presidency record
+ $id = $this->db->f('presidency');
+ $elder = $this->db->f('elder');
+ $district = $this->db->f('district');
+ $name = $this->db->f('name');
+ $email = $this->db->f('email');
+ $president = $this->db->f('president');
+ $counselor = $this->db->f('counselor');
+ $secretary = $this->db->f('secretary');
+ $eqpresidency = $this->db->f('eqpres');
+
+ // Create the forms needed in the table
+ $table_data .= " ";
+
+ // Presidency ID
+ $table_data .= ' ';
+
+ // Elder
+ if($eqpresidency == 0) {
+ $table_data.= '';
+ $table_data.= ' ';
+ for ($j=0; $j < count($elder_id); $j++) {
+ $tmp_id = $elder_id[$j];
+ $name = $elder_name[$j];
+ if($elder_id[$j] == $elder) { $eldername = $name; $selected = 'selected="selected"'; } else { $selected = ''; }
+ $table_data.= ''.$name.' ';
+ }
+ $table_data.=' ';
+ $table_data.=' ';
+ } else {
+ $table_data.= ' ';
+ $table_data.= ' ';
+ }
+
+ // Email Address
+ $table_data .= ' ';
+
+ // District
+ $table_data.= '';
+ $table_data.= ' ';
+ for ($j=0; $j <= $this->max_num_districts; $j++) {
+ if($district == $j) { $selected = 'selected="selected"'; } else { $selected = ''; }
+ $table_data.= ''.$j.' ';
+ }
+ $table_data.=' ';
+
+ // President
+ $table_data.= '';
+ if($president == 1) { $table_data .= '0 1 '; }
+ else { $table_data .= '0 1 '; }
+ $table_data.=' ';
+
+ // Counselor
+ $table_data.= '';
+ if($counselor == 1) { $table_data .= '0 1 '; }
+ else { $table_data .= '0 1 '; }
+ $table_data.=' ';
+
+ // Secretary
+ $table_data.= '';
+ if($secretary == 1) { $table_data .= '0 1 '; }
+ else { $table_data .= '0 1 '; }
+ $table_data.=' ';
+
+ // EQ Presidency
+ $table_data.= '';
+ if($eqpresidency == 1) { $table_data .= '0 1 '; }
+ else { $table_data .= '0 1 '; }
+ $table_data.=' ';
+
+ // End of ROW
+ $table_data .= " \n";
+ $tr_color = $this->nextmatchs->alternate_row_color($tr_color);
+ $this->t->set_var('tr_color',$tr_color);
+ }
+
+ // Now create 1 blank row to always have a line available to add a new elder with
+ $id = $this->max_presidency_members;
+ $table_data .= "";
+ // Presidency ID
+ $table_data .= ' ';
+ // Elder
+ $table_data.= '';
+ $table_data.= ' ';
+ for ($j=0; $j < count($elder_id); $j++) {
+ $tmp_id = $elder_id[$j];
+ $name = $elder_name[$j];
+ $table_data.= ''.$name.' ';
+ }
+ $table_data.=' ';
+ $table_data.=' ';
+ // Email Address
+ $table_data.=' ';
+ // District
+ $table_data.= '';
+ $table_data.= ' ';
+ for ($j=0; $j <= $this->max_num_districts; $j++) {
+ if($j == 0) { $selected = 'selected="selected"'; } else { $selected = ''; }
+ $table_data.= ''.$j.' ';
+ }
+ $table_data.=' ';
+ // President
+ $table_data.= '';
+ $table_data.= '0 1 ';
+ $table_data.=' ';
+ // Counselor
+ $table_data.= '';
+ $table_data.= '0 1 ';
+ $table_data.=' ';
+ // Secretary
+ $table_data.= '';
+ $table_data.= '0 1 ';
+ $table_data.=' ';
+ // EQ Presidency
+ $table_data.= '';
+ $table_data.= '0 1 ';
+ $table_data.=' ';
+ // End of ROW
+ $table_data .= " \n";
+ $tr_color = $this->nextmatchs->alternate_row_color($tr_color);
+ $this->t->set_var('tr_color',$tr_color);
+ $this->t->set_var('header_row',$header_row);
+ $this->t->set_var('table_data',$table_data);
+ $this->t->pfp('presidencyhandle','presidency',True);
+
$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);
+
+ }
}
?>