'assign_view' => True,
'assign_update' => True,
'get_time_selection_form' => True,
+ 'ht_sandbox' => True,
);
function tc()
$this->t->set_var('actionurl',$GLOBALS['phpgw']->link('/tc/index.php','menuaction=tc.tc.ht_view'));
$this->t->set_var('title','Hometeaching');
+ $this->t->set_var('ht_sandbox_link',$GLOBALS['phpgw']->link('/tc/index.php','menuaction=tc.tc.ht_sandbox'));
+ $this->t->set_var('ht_sandbox_link_title','Hometeaching Sandbox');
+
$sql = "SELECT * FROM tc_district AS td JOIN tc_individual AS ti WHERE td.supervisor=ti.individual AND td.valid=1 ORDER BY td.district ASC";
$this->db->query($sql,__LINE__,__FILE__);
$i=0;
}
+ function ht_sandbox()
+ {
+ $this->t->set_file(array('ht_sandbox_t' => 'ht_sandbox.tpl'));
+ $this->t->set_block('ht_sandbox_t','comp_list','c_list');
+ $this->t->set_block('ht_sandbox_t','district_list','d_list');
+ $this->t->set_block('ht_sandbox_t','unassigned_ht_list','uht_list');
+ $this->t->set_block('ht_sandbox_t','assigned_ht_list','aht_list');
+ $this->t->set_block('ht_sandbox_t','unassigned_family_list','uf_list');
+ $this->t->set_block('ht_sandbox_t','assigned_family_list','af_list');
+ $this->t->set_block('ht_sandbox_t','district_table_list','dt_list');
+ $this->t->set_block('ht_sandbox_t','companionship_table_list','ct_list');
+
+ $this->t->set_var('submit_action',$GLOBALS['phpgw']->link('/tc/index.php','menuaction=tc.tc.ht_sandbox&action=add'));
+
+ $action = get_var('action',array('GET','POST'));
+
+ $this->t->set_var('title','Hometeaching Sandbox');
+
+ if ($_POST['add']) {
+ #$this->t->set_var('debug_list',$_POST['add']);
+ $companionship = get_var('companionship',array('POST'));
+ $district = get_var('district',array('POST'));
+ $assignedHT_list = get_var('assignedHT',array('POST'));
+ $unassignedHT_list = get_var('unassignedHT',array('POST'));
+ $assigned_family_list = get_var('assignedFamiles',array('POST'));
+ $unassigned_family_list = get_var('unassignedFamilies',array('POST'));
+
+ if ($assignedHT_list || $unassignedHT_list) {
+ $sql = "INSERT INTO tc_companionship_sandbox (tc_companionship,district) VALUES (\"NULL\",\"$district\")";
+ $this->db2->query($sql,__LINE__,__FILE__);
+ $companionship_sandbox = mysql_insert_id();
+
+ foreach ($assignedHT_list as $individual) {
+ $sql = "INSERT INTO tc_companion_sandbox (individual,companionship) VALUES (\"$individual\",\"$companionship_sandbox\")";
+ $this->db->query($sql,__LINE__,__FILE__);
+ }
+ foreach ($unassignedHT_list as $individual) {
+ $sql = "INSERT INTO tc_companion_sandbox (individual,companionship) VALUES (\"$individual\",\"$companionship_sandbox\")";
+ $this->db->query($sql,__LINE__,__FILE__);
+ }
+ foreach ($assigned_family_list as $family) {
+ $sql = "UPDATE tc_family_sandbox SET companionship=$companionship_sandbox WHERE family=$family";
+ $this->db->query($sql,__LINE__,__FILE__);
+ }
+ foreach ($unassigned_family_list as $family) {
+ $sql = "UPDATE tc_family_sandbox SET companionship=$companionship_sandbox WHERE family=$family";
+ $this->db->query($sql,__LINE__,__FILE__);
+ }
+ } else {
+ $this->t->set_var('debug_list','You must select at least one companion!');
+ }
+ } else if ($_POST['delete']) {
+ #$this->t->set_var('debug_list',$_POST['delete']);
+ $companionship = get_var('companionship',array('POST'));
+ #$this->t->set_var('debug_list',$companionship);
+
+ if ($companionship > 0) {
+ # unassign families
+ $sql = "UPDATE tc_family_sandbox SET companionship=NULL WHERE companionship=$companionship";
+ $this->db->query($sql,__LINE__,__FILE__);
+
+ # remove companions
+ $sql = "DELETE FROM tc_companion_sandbox WHERE companionship=$companionship";
+ $this->db->query($sql,__LINE__,__FILE__);
+
+ # remove companionship
+ $sql = "DELETE FROM tc_companionship_sandbox WHERE companionship=$companionship";
+ $this->db->query($sql,__LINE__,__FILE__);
+ } else {
+ $this->t->set_var('debug_list','You must select a companionship to delete!');
+ }
+ } else if ($_POST['update']) {
+ #$this->t->set_var('debug_list',$_POST['update']);
+ $companionship = get_var('companionship',array('POST'));
+ $district = get_var('district',array('POST'));
+ $assignedHT_list = get_var('assignedHT',array('POST'));
+ $unassignedHT_list = get_var('unassignedHT',array('POST'));
+ $assigned_family_list = get_var('assignedFamiles',array('POST'));
+ $unassigned_family_list = get_var('unassignedFamilies',array('POST'));
+ #$this->t->set_var('debug_list',$district);
+
+ if ($companionship > 0) {
+ if ($assignedHT_list || $unassignedHT_list) {
+ # clear out existing info about companionship
+ $sql = "UPDATE tc_family_sandbox SET companionship=NULL WHERE companionship=$companionship";
+ $this->db->query($sql,__LINE__,__FILE__);
+ $sql = "DELETE FROM tc_companion_sandbox WHERE companionship=$companionship";
+ $this->db->query($sql,__LINE__,__FILE__);
+
+ # set new info about companionship
+ $sql = "UPDATE tc_companionship_sandbox SET district=$district WHERE companionship=$companionship";
+ $this->db->query($sql,__LINE__,__FILE__);
+ foreach ($assignedHT_list as $individual) {
+ $sql = "INSERT INTO tc_companion_sandbox (individual,companionship) VALUES (\"$individual\",\"$companionship\")";
+ $this->db->query($sql,__LINE__,__FILE__);
+ }
+ foreach ($unassignedHT_list as $individual) {
+ $sql = "INSERT INTO tc_companion_sandbox (individual,companionship) VALUES (\"$individual\",\"$companionship\")";
+ $this->db->query($sql,__LINE__,__FILE__);
+ }
+ foreach ($assigned_family_list as $family) {
+ $sql = "UPDATE tc_family_sandbox SET companionship=$companionship WHERE family=$family";
+ $this->db->query($sql,__LINE__,__FILE__);
+ }
+ foreach ($unassigned_family_list as $family) {
+ $sql = "UPDATE tc_family_sandbox SET companionship=$companionship WHERE family=$family";
+ $this->db->query($sql,__LINE__,__FILE__);
+ }
+ } else {
+ $this->t->set_var('debug_list','You must select at least one companion!');
+ }
+ } else {
+ $this->t->set_var('debug_list','You must select a companionship to update!');
+ }
+ } else if ($_POST['reset']) {
+ #$this->t->set_var('debug_list',$_POST['reset']);
+
+ $sql = "TRUNCATE TABLE tc_district_sandbox";
+ $this->db->query($sql,__LINE__,__FILE__);
+ $sql = "TRUNCATE TABLE tc_family_sandbox";
+ $this->db->query($sql,__LINE__,__FILE__);
+ $sql = "TRUNCATE TABLE tc_companion_sandbox";
+ $this->db->query($sql,__LINE__,__FILE__);
+ $sql = "TRUNCATE TABLE tc_companionship_sandbox";
+ $this->db->query($sql,__LINE__,__FILE__);
+
+ # populate tc_district_sandbox
+ $sql = "SELECT * FROM tc_district WHERE valid=1";
+ $this->db->query($sql,__LINE__,__FILE__);
+ while ($this->db->next_record()) {
+ $district = $this->db->f('district');
+ $supervisor = $this->db->f('supervisor');
+ $sql = "INSERT INTO tc_district_sandbox (district,supervisor) VALUES (\"$district\",\"$supervisor\")";
+ $this->db2->query($sql,__LINE__,__FILE__);
+ }
+
+ # populate family, companion, and companionship tables
+ $sql = "SELECT * FROM tc_companionship WHERE valid=1";
+ $this->db->query($sql,__LINE__,__FILE__);
+ while ($this->db->next_record()) {
+ $companionship = $this->db->f('companionship');
+ $district = $this->db->f('district');
+ $sql = "INSERT INTO tc_companionship_sandbox (tc_companionship,district) VALUES (\"$companionship\",\"$district\")";
+ $this->db2->query($sql,__LINE__,__FILE__);
+ $companionship_sandbox = mysql_insert_id();
+
+ $sql = "SELECT * FROM tc_companion AS tc JOIN tc_individual AS ti WHERE tc.individual=ti.individual AND tc.companionship=$companionship AND tc.valid=1 AND ti.valid=1";
+ $this->db2->query($sql,__LINE__,__FILE__);
+ while ($this->db2->next_record()) {
+ $individual = $this->db2->f('individual');
+ $sql = "INSERT INTO tc_companion_sandbox (individual,companionship) VALUES (\"$individual\",\"$companionship_sandbox\")";
+ $this->db3->query($sql,__LINE__,__FILE__);
+ }
+
+ $sql = "SELECT * FROM tc_family WHERE companionship=$companionship AND valid=1";
+ $this->db2->query($sql,__LINE__,__FILE__);
+ while ($this->db2->next_record()) {
+ $individual = $this->db2->f('individual');
+ $family = $this->db2->f('family');
+ $sql = "INSERT INTO tc_family_sandbox (tc_family,individual,companionship) VALUES (\"$family\",\"$individual\",\"$companionship_sandbox\")";
+ $this->db3->query($sql,__LINE__,__FILE__);
+ }
+ }
+ }
+
+ // get list of companionships
+ $sql = "SELECT DISTINCT companionship FROM tc_companionship_sandbox ORDER BY companionship ASC";
+ $this->db->query($sql,__LINE__,__FILE__);
+ $unique_companionships = '';
+ $unique_companionships[0]['companionship'] = 0;
+ $this->t->set_var('companionship_list','<option value="0">New Companionship</option>');
+ $this->t->fp('c_list','comp_list',True);
+ $j=1;
+ while ($this->db->next_record()) {
+ $companionship = $this->db->f('companionship');
+ $unique_companionships[$j]['companionship'] = $companionship;
+ $combined_companionship = "";
+ $sql = "SELECT * FROM tc_companion_sandbox AS tc JOIN tc_individual AS ti WHERE tc.individual=ti.individual AND tc.companionship=$companionship ORDER BY ti.name ASC";
+ $this->db2->query($sql,__LINE__,__FILE__);
+ while ($this->db2->next_record()) {
+ if ($combined_companionship == "") {
+ $combined_companionship .= $this->db2->f('name');
+ } else {
+ $combined_companionship .= " / " . $this->db2->f('name');
+ }
+ }
+ $this->t->set_var('companionship_list','<option value="'.$companionship.'">'.$combined_companionship.'</option>');
+ $this->t->fp('c_list','comp_list',True);
+ $j++;
+ }
+
+ # get list of districts
+ $sql = "SELECT DISTINCT district FROM tc_district_sandbox ORDER BY district ASC";
+ $this->db->query($sql,__LINE__,__FILE__);
+ $districts = '';
+ $num_districts=0;
+ while ($this->db->next_record()) {
+ $districts[$num_districts] = $this->db->f('district');
+ $this->t->set_var('district','<option value="'.$districts[$num_districts].'">'.$districts[$num_districts].'</option>');
+ $this->t->fp('d_list','district_list',True);
+ $num_districts++;
+ }
+
+ # get list of individuals who are and are not home teachers
+ $sql = "SELECT * FROM tc_individual WHERE steward='$this->default_stewardship' AND valid=1 ORDER BY name ASC";
+ $this->db->query($sql,__LINE__,__FILE__);
+ while ($this->db->next_record()) {
+ $individual = $this->db->f('individual');
+ $name = $this->db->f('name');
+ $sql = "SELECT DISTINCT * FROM tc_companion_sandbox WHERE individual=$individual";
+ $this->db2->query($sql,__LINE__,__FILE__);
+ if ($this->db2->next_record()) {
+ $this->t->set_var('assigned_ht','<option value="'.$individual.'">'.$name.'</option>');
+ $this->t->fp('aht_list','assigned_ht_list',True);
+ } else {
+ $this->t->set_var('unassigned_ht','<option value="'.$individual.'">'.$name.'</option>');
+ $this->t->fp('uht_list','unassigned_ht_list',True);
+ }
+ }
+
+ # get list of families who are and are not assigned home teachers
+ $sql = "SELECT * FROM tc_family_sandbox AS tf JOIN tc_individual AS ti WHERE tf.individual=ti.individual ORDER BY ti.name ASC";
+ $this->db->query($sql,__LINE__,__FILE__);
+ while ($this->db->next_record()) {
+ $individual = $this->db->f('individual');
+ $family = $this->db->f('family');
+ $name = $this->db->f('name');
+ if ($this->db->f('companionship') != 0) {
+ $this->t->set_var('assigned_family','<option value="'.$family.'">'.$name.' Family</option>');
+ $this->t->fp('af_list','assigned_family_list',True);
+ } else {
+ $this->t->set_var('unassigned_family','<option value="'.$family.'">'.$name.' Family</option>');
+ $this->t->fp('uf_list','unassigned_family_list',True);
+ }
+ }
+
+ # populate ht districts table
+ $sandbox_table_data = "<table border=\"0\" cellspacing=\"2\" cellpadding=\"2\">";
+
+ # set up column headers
+ $sandbox_table_data .= "<tr>";
+ for ($d = 0; $d < $num_districts; $d++) {
+ $sandbox_table_data .= "<th align=\"center\" bgcolor=\"#c9c9c9\">District " . $districts[$d] . "</th>";
+ }
+
+ # get each companionship in each district
+ $sandbox_table_data .= "<tr>";
+ for ($d = 0; $d < $num_districts; $d++) {
+ $sandbox_table_data .= "<td valign=\"Top\">";
+ $sandbox_table_data .= "<table>";
+ $sql = "SELECT DISTINCT companionship FROM tc_companionship_sandbox WHERE district=$districts[$d] ORDER BY companionship ASC";
+ $this->db->query($sql,__LINE__,__FILE__);
+ while ($this->db->next_record()) {
+ $sandbox_table_data .= "<tr><td><table>";
+ $companionship = $this->db->f('companionship');
+ # get names of companions in this companionship
+ $sql = "SELECT * FROM tc_companion_sandbox AS tc JOIN tc_individual AS ti WHERE tc.individual=ti.individual AND companionship=$companionship ORDER BY ti.name ASC";
+ $this->db2->query($sql,__LINE__,__FILE__);
+ $companion_names = "";
+ while ($this->db2->next_record()) {
+ if ($companion_names == "") {
+ $companion_names .= $this->db2->f('name');
+ } else {
+ $companion_names .= " / " . $this->db2->f('name');
+ }
+ }
+ $sandbox_table_data .= "<tr><th align=\"Left\" bgcolor=\"#c9c9c9\">$companion_names</th></tr>";
+ $sandbox_table_data .= "<tr><td><table>";
+
+ # get families they visit
+ $sql = "SELECT * FROM tc_companionship_sandbox AS tcp JOIN (tc_family_sandbox AS tf, tc_individual AS ti) WHERE tcp.companionship=$companionship AND tcp.companionship=tf.companionship AND tf.individual=ti.individual";
+ $this->db2->query($sql,__LINE__,__FILE__);
+ while ($this->db2->next_record()) {
+ $family_name = $this->db2->f('name') . " Family";
+ $family_id = $this->db2->f('tc_family');
+ $tc_companionship = $this->db2->f('tc_companionship');
+ $sandbox_table_data .= "<tr>";
+ $sandbox_table_data .= "<td align=\"Left\" width=\"1000\">$family_name</td>";
+
+ # get 12 months visit data for given family
+ for($m=$this->sandbox_stats_num_months; $m >= 0; $m--) {
+ $month = $this->current_month - $m;
+ $year = $this->current_year;
+ if($month <= 0) { $remainder = $month; $month = 12 + $remainder; $year=$year-1; }
+ if($month < 10) { $month = "0"."$month"; }
+ $month_start = "$year"."-"."$month"."-"."01";
+ $month_end = "$year"."-"."$month"."-"."31";
+ $month = "$month"."/"."$year";
+
+ if ($this->sandbox_visits_comp_only == 0) {
+ $sql = "SELECT * FROM tc_visit WHERE date >= '$month_start' AND date <= '$month_end' AND companionship!=0 AND family=". $family_id;
+ } else {
+ $sql = "SELECT * FROM tc_visit WHERE date >= '$month_start' AND date <= '$month_end' AND companionship=$tc_companionship AND family=". $family_id;
+ }
+ $query_id = $this->db3->query($sql,__LINE__,__FILE__);
+
+ if($this->db3->next_record()) {
+ if($this->db3->f('visited') == 'y') {
+ $sandbox_table_data .= "<td align=\"Right\"><img src=\"images/checkmark.gif\"></td>";
+ } else if($this->db3->f('visited') == 'n') {
+ $sandbox_table_data .= "<td align=\"Right\"><img src=\"images/x.gif\"></td>";
+ } else {
+ $sandbox_table_data .= "<td> </td>";
+ }
+ } else {
+ $sandbox_table_data .= "<td> </td>";
+ }
+ }
+ $sandbox_table_data .= "</tr>";
+ }
+ $sandbox_table_data .= "</table></td></tr>";
+ $sandbox_table_data .= "</table></td></tr>";
+ }
+
+ $sandbox_table_data .= "</table>";
+ $sandbox_table_data .= "</td>";
+ }
+ $sandbox_table_data .= "</tr>";
+
+ $sandbox_table_data .= "</table>";
+ $this->t->set_var('district_table',$sandbox_table_data);
+
+ $this->t->pfp('out','ht_sandbox_t');
+ $this->save_sessiondata();
+ }
+
+
function ht_update()
{
$this->t->set_file(array('ht_update_t' => 'ht_update.tpl'));
// Update an existing appointment
if($appointment < $this->max_appointments)
{
+ // If we deleted the appointment, we still need to send a cancellation to the right people
+ // Make a note of the old email now in case we need it later
+ $old_indiv_email = "";
+ $sql = "SELECT * FROM tc_appointment where appointment='$appointment'";
+ $this->db->query($sql,__LINE__,__FILE__);
+ if($this->db->next_record()) {
+ $old_individual = $this->db->f('individual');
+ $old_family = $this->db->f('family');
+ if($old_individual > 0) {
+ $sql = "SELECT * FROM tc_individual where individual='$old_individual'";
+ $this->db2->query($sql,__LINE__,__FILE__);
+ if($this->db2->next_record()) {
+ $old_indiv_email = $this->db2->f('email');
+ }
+ }
+ if($old_family > 0) {
+ $sql = "SELECT * FROM tc_family WHERE family='$old_family'";
+ $this->db2->query($sql,__LINE__,__FILE__);
+ if($this->db2->next_record()) {
+ $old_individual = $this->db2->f('individual');
+ $sql = "SELECT * FROM tc_individual where individual='$old_individual'";
+ $this->db3->query($sql,__LINE__,__FILE__);
+ if($this->db3->next_record()) {
+ $old_indiv_email = $this->db3->f('email');
+ }
+ }
+ }
+ }
+
//Only perform a database update if we have made a change to this appointment
$sql = "SELECT * FROM tc_appointment where " .
"appointment='$appointment'" .
" WHERE appointment=" . $appointment,__LINE__,__FILE__);
// Email the appointment
- $this->email_appt($appointment);
+ $this->email_appt($appointment, $old_indiv_email);
}
}
$this->save_sessiondata();
}
- function email_appt($appointment)
+ function email_appt($appointment, $old_indiv_email)
{
//print "Emailing notification of appointment: $appointment <br>";
$appt_name = "";
$phone = "";
$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);
if($this->db2->next_record()) {
$indiv_name = $this->db2->f('name');
$phone = $this->db2->f('phone');
+ $indiv_email = $this->db2->f('email');
+ if(($this->email_individual_appt == 1) && ($indiv_email != "")) {
+ $email .= ", $indiv_email";
+ }
$appt_name = $indiv_name . " Interview";
$duration = $this->default_ppi_appt_duration * 60;
}
$phone = $this->db3->f('phone');
$family_name = $this->db3->f('name');
$phone = $this->db3->f('phone');
+ $indiv_email = $this->db3->f('email');
+ if(($this->email_individual_appt == 1) && ($indiv_email != "")) {
+ $email .= ", $indiv_email";
+ }
}
$appt_name = $family_name . " Family Visit";
$duration = $this->default_visit_appt_duration * 60;
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 . "<br>";
+ print "Sent new appointment for " . $interviewer . " to '" . $email . "' for " . $appt_name . "<br>";
$uid = rand() . rand(); // Generate a random identifier for this appointment
$subject = "Created: $appt_name";
} 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 . "<br>";
+ if(($this->email_individual_appt == 1) && ($old_indiv_email != "")) {
+ $email .= ", $old_indiv_email";
+ }
+ print "Sent deleted appointment for " . $interviewer . " to '" . $email . "' for " . $appt_date . " " . $appt_time . "<br>";
$subject = "Canceled: $appt_date $appt_time";
$this->db->query("UPDATE tc_appointment set" .
$dtend, $date, $location, $subject, $subject, $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 . "<br>";
+ print "Sent updated appointment for " . $interviewer . " to '" . $email . "' for " . $appt_name . "<br>";
$subject = "Canceled: $appt_date $appt_time";
$action = "CANCEL";