X-Git-Url: http://git.pippins.net/embedvideo/.git/static/images/checkmark.gif?a=blobdiff_plain;f=inc%2Fclass.tc.inc.php;h=883884f76abfc8aab0ca4e2d608ac592f5e28a1f;hb=4c8106c717ade1fb6854922662ff87e7ff262c08;hp=a1bdaf28b1a16f47670299291f073856c1d1bd7d;hpb=99caca5e48c5336900cde692cbe1dba0c0fb87cc;p=eq%2F.git
diff --git a/inc/class.tc.inc.php b/inc/class.tc.inc.php
index a1bdaf2..883884f 100644
--- a/inc/class.tc.inc.php
+++ b/inc/class.tc.inc.php
@@ -35,6 +35,7 @@ class tc
var $script_path;
var $max_appointments;
var $max_presidency_members;
+ var $ppi_frequency_label;
var $public_functions = array
(
@@ -67,6 +68,7 @@ class tc
'assign_view' => True,
'assign_update' => True,
'get_time_selection_form' => True,
+ 'ht_sandbox' => True,
);
function tc()
@@ -105,6 +107,18 @@ class tc
$this->current_month = $this->current_month-0; // Make it numeric
$this->current_year = `date '+%Y'`;
$this->current_year = $this->current_year-0; // Make it numeric
+
+ if ($this->ppi_frequency == 12) {
+ $this->ppi_frequency_label = "Annual";
+ } else if ($this->ppi_frequency == 6) {
+ $this->ppi_frequency_label = "Semi-Annual";
+ } else if ($this->ppi_frequency == 3) {
+ $this->ppi_frequency_label = "Quarterly";
+ } else if ($this->ppi_frequency == 1) {
+ $this->ppi_frequency_label = "Monthly";
+ } else {
+ $this->ppi_frequency_label = "Periodic";
+ }
echo parse_navbar();
$this->display_app_header();
@@ -203,6 +217,9 @@ class 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;
@@ -381,6 +398,333 @@ class tc
}
+ 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','New Companionship ');
+ $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',''.$combined_companionship.' ');
+ $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',''.$districts[$num_districts].' ');
+ $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',''.$name.' ');
+ $this->t->fp('aht_list','assigned_ht_list',True);
+ } else {
+ $this->t->set_var('unassigned_ht',''.$name.' ');
+ $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',''.$name.' Family ');
+ $this->t->fp('af_list','assigned_family_list',True);
+ } else {
+ $this->t->set_var('unassigned_family',''.$name.' Family ');
+ $this->t->fp('uf_list','unassigned_family_list',True);
+ }
+ }
+
+ # populate ht districts table
+ $sandbox_table_data = "
";
+
+ # set up column headers
+ $sandbox_table_data .= "";
+ for ($d = 0; $d < $num_districts; $d++) {
+ $sandbox_table_data .= "District " . $districts[$d] . " ";
+ }
+
+ # get each companionship in each district
+ $sandbox_table_data .= " ";
+ for ($d = 0; $d < $num_districts; $d++) {
+ $sandbox_table_data .= "";
+ $sandbox_table_data .= "";
+ $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 .= "";
+ $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 .= "$companion_names ";
+ $sandbox_table_data .= "";
+
+ # 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 .= "";
+ $sandbox_table_data .= "$family_name ";
+
+ # 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 .= " ";
+ } else if($this->db3->f('visited') == 'n') {
+ $sandbox_table_data .= " ";
+ } else {
+ $sandbox_table_data .= " ";
+ }
+ } else {
+ $sandbox_table_data .= " ";
+ }
+ }
+ $sandbox_table_data .= " ";
+ }
+ $sandbox_table_data .= "
";
+ $sandbox_table_data .= "
";
+ }
+
+ $sandbox_table_data .= "
";
+ $sandbox_table_data .= " ";
+ }
+ $sandbox_table_data .= " ";
+
+ $sandbox_table_data .= "
";
+ $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'));
@@ -825,7 +1169,7 @@ class tc
$this->t->set_var('assignment_data',$assignment_data);
// Create individual selection boxes
- $sql = "SELECT * FROM tc_individual WHERE steward='$this->default_stewardship'";
+ $sql = "SELECT * FROM tc_individual";
$this->db->query($sql,__LINE__,__FILE__);
$i=0;
while ($this->db->next_record()) {
@@ -1344,42 +1688,26 @@ class tc
$this->t->set_var('lang_reset','Clear Changes');
$this->t->set_var('ppi_link',$GLOBALS['phpgw']->link('/tc/index.php','menuaction=tc.tc.ppi_view'));
- $this->t->set_var('ppi_link_title','Yearly PPIs');
+ $this->t->set_var('ppi_link_title',$this->ppi_frequency_label . ' PPIs');
$this->t->set_var('schedule_ppi_link',$GLOBALS['phpgw']->link('/tc/index.php','menuaction=tc.tc.ppi_sched'));
- $this->t->set_var('schedule_ppi_link_title','Schedule Yearly PPIs');
+ $this->t->set_var('schedule_ppi_link_title','Schedule ' . $this->ppi_frequency_label . ' PPIs');
$this->t->set_var('actionurl',$GLOBALS['phpgw']->link('/tc/index.php','menuaction=tc.tc.ppi_sched&action=save'));
- $this->t->set_var('title','Yearly PPI Scheduler');
-
- $indiv_width=500; $phone_width=25; $pri_width=10; $notes_width=128; $ppi_date_width=20;
- $table_width=$indiv_width + $phone_width + $pri_width + $notes_width + $ppi_date_width;
- $header_row = "individual Name ";
- $header_row.= "Phone ";
- $header_row.= "Priority ";
- $header_row.= "Last PPI ";
- $header_row.= "Scheduling Notes ";
+ $this->t->set_var('title',$this->ppi_frequency_label . ' PPI Scheduler');
+
+ $header_row = "Individual Name ";
+ $header_row.= "Phone ";
+ $header_row.= "Priority ";
+ $header_row.= "Last PPI ";
+ $header_row.= "Scheduling Notes ";
$table_data=""; $completed_data=""; $totals_data="";
$year = date('Y');
-
- // Get the President
- $sql = "SELECT * FROM tc_presidency AS tp JOIN tc_individual AS ti where tp.individual=ti.individual AND tp.president=1 AND tp.valid=1";
- $this->db->query($sql,__LINE__,__FILE__);
- if($this->db->next_record()) {
- $president_name = $this->db->f('name');
- $president_name_array = explode(",",$president_name);
- $president_last_name = $president_name_array[0];
- $president_id = $this->db->f('individual');
- $presidency_id = $this->db->f('presidency');
- $interviewer = $this->db->f('individual');
- $district_number = '*';
- $district_name = $president_name;
- $president_address = $this->db->f('address');
- } else {
- print "-E- Unable to locate President in tc_presidency table ";
- return;
- }
+ $month = date('m');
+ $period = intval(($month-1)/$this->ppi_frequency) + 1;
+ $start_of_period = ($period-1)*$this->ppi_frequency + 1;
+ $end_of_period = $period * $this->ppi_frequency;
if($action == 'save') {
// Save any changes made to the appointment table
@@ -1389,7 +1717,8 @@ class tc
$indiv = $entry['individual'];
$appointment = $entry['appointment'];
$location = $entry['location'];
- if($location == "") { $location = "$president_last_name"." home ($president_address)"; }
+ $presidency_location = $entry['presidency_location'];
+ if($location == "") { $location = $presidency_location; }
if($indiv == 0) { $location = ""; }
//Only perform a database update if we have made a change to this appointment
@@ -1442,39 +1771,52 @@ class tc
array_multisort($indiv_name, $individual);
// APPOINTMENT TABLE
- $date_width=250; $time_width=100; $indiv_width=200; $location_width=100;
- $appt_table_width=$date_width + $time_width + $indiv_width + $location_width;
- $appt_header_row = "Date ";
- $appt_header_row.= "Time ";
- $appt_header_row.= "indiv ";
- $appt_header_row.= "Location ";
- $appt_table_data = "";
+ $appt_header_row = "Date ";
+ $appt_header_row.= "Time ";
+ $appt_header_row.= "Individual ";
+ $appt_header_row.= "Location ";
+ $appt_table_data = "";
+ $table_data="";
$total_indivs=0; $indivs_with_yearly_ppi=0;
- // Display a scheduling table for the President
- $table_data=""; $appt_table_data="";
- $table_title = "District ".$district_number.": ".$district_name.": All indivs with Yearly PPI Not Completed";
- $appt_table_title = "District ".$district_number.": ".$district_name.": Yearly PPI Appointment Slots";
- $this->t->set_var('table_title',$table_title);
- $this->t->set_var('appt_table_title',$appt_table_title);
-
- // query the database for all the appointments
- $sql = "SELECT * FROM tc_appointment where presidency=".$presidency_id." and date>=CURDATE() ORDER BY date ASC, time ASC";
+ // Get the President
+ $sql = "SELECT * FROM tc_presidency AS tp JOIN tc_individual AS ti where tp.individual=ti.individual AND tp.valid=1 AND ";
+ if($this->yearly_ppi_interviewer == 1) { $sql .= " (tp.president=1)"; }
+ if($this->yearly_ppi_interviewer == 2) { $sql .= " (tp.president=1 OR tp.counselor=1)"; }
+ if($this->yearly_ppi_interviewer == 3) { $sql .= " (tp.president=1 OR tp.counselor=1 OR tp.secretary=1)"; }
$this->db->query($sql,__LINE__,__FILE__);
-
while ($this->db->next_record()) {
- $appointment = $this->db->f('appointment');
- $indiv = $this->db->f('individual');
- $location = $this->db->f('location');
- if(($location == "") && ($indiv > 0)) { $location = "$president_last_name"." home ($president_address)"; }
+ $presidency_name = $this->db->f('name');
+ $presidency_name_array = explode(",",$presidency_name);
+ $presidency_last_name = $presidency_name_array[0];
+ $presidency_id = $this->db->f('presidency');
+ $presidency_address = $this->db->f('address');
+ $presidency_location = "$presidency_last_name"." home ($presidency_address)";
+ $appt_table_data = "";
+
+ // Display a scheduling table for this presidency member
+ $not_completed_table_title = "All individuals with " . $this->ppi_frequency_label . " PPI Not Completed";
+ $appt_table_title = $presidency_name . ": " . $this->ppi_frequency_label." PPI Appointment Slots";
+ $this->t->set_var('not_completed_table_title',$not_completed_table_title);
+ $this->t->set_var('appt_table_title',$appt_table_title);
+
+ // query the database for all the appointments
+ $sql = "SELECT * FROM tc_appointment where presidency=".$presidency_id." and date>=CURDATE() ORDER BY date ASC, time ASC";
+ $this->db2->query($sql,__LINE__,__FILE__);
+
+ while ($this->db2->next_record()) {
+ $appointment = $this->db2->f('appointment');
+ $indiv = $this->db2->f('individual');
+ $location = $this->db2->f('location');
+ if(($location == "") && ($indiv > 0)) { $location = $presidency_location; }
- $date = $this->db->f('date');
+ $date = $this->db2->f('date');
$date_array = explode("-",$date);
$year = $date_array[0]; $month = $date_array[1]; $day = $date_array[2];
$day_string = date("l d-M-Y", mktime(0,0,0,$month,$day,$year));
- $time = $this->db->f('time');
+ $time = $this->db2->f('time');
$time_array = explode(":",$time);
$time_string = date("g:i a", mktime($time_array[0], $time_array[1], $time_array[2]));
@@ -1485,14 +1827,14 @@ class tc
$appt_table_data.= '';
$appt_table_data.= ' ';
for ($i=0; $i < count($individual); $i++) {
- $id = $individual[$i];
- $name = $indiv_name[$i];
- if($individual[$i] == $indiv) {
- $selected[$id] = 'selected="selected"';
- } else {
- $selected[$id] = '';
- }
- $appt_table_data.= ''.$name.' ';
+ $id = $individual[$i];
+ $name = $indiv_name[$i];
+ if($individual[$i] == $indiv) {
+ $selected[$id] = 'selected="selected"';
+ } else {
+ $selected[$id] = '';
+ }
+ $appt_table_data.= ''.$name.' ';
}
$appt_table_data.=' ';
@@ -1503,12 +1845,14 @@ class tc
$tr_color = $this->nextmatchs->alternate_row_color($tr_color);
$this->t->set_var('tr_color',$tr_color);
- }
-
- $this->t->set_var('appt_table_data',$appt_table_data);
- $this->t->set_var('appt_header_row',$appt_header_row);
- $this->t->set_var('appt_table_width',$appt_table_width);
+ }
+ $this->t->set_var('appt_table_data',$appt_table_data);
+ $this->t->set_var('appt_header_row',$appt_header_row);
+ $this->t->set_var('lang_save','Save Appts for ' . $presidency_name);
+ $this->t->fp('apptlist','appt_list',True);
+ }
+
// PPI SCHEDULING TABLE
$sql = "SELECT * FROM tc_individual AS ti JOIN tc_scheduling_priority AS tsp WHERE ti.scheduling_priority=tsp.scheduling_priority AND steward='$this->default_stewardship' AND valid=1 ORDER BY tsp.priority ASC, ti.name ASC";
$this->db->query($sql,__LINE__,__FILE__);
@@ -1526,7 +1870,7 @@ class tc
}
$max = count($individual);
-
+
for($i=0; $i < $max; $i++) {
$id = $individual[$i];
$name = $indiv_name[$i];
@@ -1534,10 +1878,11 @@ class tc
$priority = $indiv_priority[$id];
$notes = $indiv_notes[$id];
- // If this individual has had a yearly PPI this year, don't show him on the schedule list
- $year_start = $year - 1 . "-12-31"; $year_end = $year + 1 . "-01-01";
- $sql = "SELECT * FROM tc_interview WHERE date > '$year_start' AND date < '$year_end' ".
- "AND individual=" . $id . " AND interview_type='ppi'";
+ // If this individual has had a PPI this period, don't show him on the schedule list
+ $year_start = $year . "-" . $start_of_period . "-01";
+ $year_end = $year . "-" . $end_of_period . "-31";
+ $sql = "SELECT * FROM tc_interview WHERE date >= '$year_start' AND date <= '$year_end' ".
+ "AND individual=" . $id . " AND interview_type='ppi' ORDER BY date DESC";
$this->db2->query($sql,__LINE__,__FILE__);
if(!$this->db2->next_record()) {
@@ -1602,27 +1947,24 @@ class tc
}
} // End for individuals Loop
- $name_width=175; $phone_width=100; $date_width=100; $notes_width=300;
- $completed_table_width=$name_width + $phone_width + $date_width + $notes_width;
- $completed_header_row = "Individual Name ";
- $completed_header_row.= "Phone ";
- $completed_header_row.= "Date ";
- $completed_header_row.= "PPI Notes ";
+ $completed_table_title = "All individuals with " . $this->ppi_frequency_label . " PPI Completed";
+ $completed_header_row = "Individual ";
+ $completed_header_row.= "Phone ";
+ $completed_header_row.= "Date ";
+ $completed_header_row.= "PPI Notes ";
- $this->t->set_var('table_width',$table_width);
+ $this->t->set_var('completed_table_title',$completed_table_title);
$this->t->set_var('header_row',$header_row);
$this->t->set_var('table_data',$table_data);
$this->t->set_var('completed_header_row',$completed_header_row);
- $this->t->set_var('completed_table_width',$completed_table_width);
$this->t->set_var('completed',$completed_data);
+ $this->t->set_var('lang_save','Save Pri / Notes');
$this->t->fp('indivlist','individual_list',True);
- $indivs_width=300; $totals_width=100;
- $totals_table_width=$indivs_width + $totals_width;
- $totals_header_row = "Individuals ";
- $totals_header_row.= "$year ";
+ $totals_header_row = "Individuals ";
+ $totals_header_row.= "$year ";
$totals_data.= "";
- $totals_data.= "Total Individuals with yearly PPIs completed: ";
+ $totals_data.= "Total Individuals with " . $this->ppi_frequency_label . " PPIs completed: ";
$totals_data.= "$indivs_with_yearly_ppi / $total_indivs ";
$percent = ceil(($indivs_with_yearly_ppi / $total_indivs)*100);
$tr_color = $this->nextmatchs->alternate_row_color($tr_color);
@@ -1634,7 +1976,7 @@ class tc
$this->t->set_var('totals',$totals_data);
$this->t->set_var('totals_header_row',$totals_header_row);
- $this->t->set_var('totals_table_width',$totals_table_width);
+ $this->t->set_var('ppi_frequency_label',$this->ppi_frequency_label);
$this->t->pfp('out','ppi_sched_t');
$this->save_sessiondata();
@@ -1648,7 +1990,6 @@ class tc
$this->t->set_block('int_sched_t','appt_list','apptlist');
$action = get_var('action',array('GET','POST'));
- $this->t->set_var('lang_save','Save Appt / Pri / Notes');
$this->t->set_var('lang_reset','Clear Changes');
$this->t->set_var('int_link',$GLOBALS['phpgw']->link('/tc/index.php','menuaction=tc.tc.int_view'));
@@ -1660,13 +2001,11 @@ class tc
$this->t->set_var('actionurl',$GLOBALS['phpgw']->link('/tc/index.php','menuaction=tc.tc.int_sched&action=save'));
$this->t->set_var('title','Hometeaching Interviews Scheduler');
- $indiv_width=500; $phone_width=25; $pri_width=10; $notes_width=128; $int_date_width=20;
- $table_width=$indiv_width + $phone_width + $pri_width + $notes_width + $int_date_width;
- $header_row = "individual Name ";
- $header_row.= "Phone ";
- $header_row.= "Priority ";
- $header_row.= "Last Interview ";
- $header_row.= "Scheduling Notes ";
+ $header_row = "Individual ";
+ $header_row.= "Phone ";
+ $header_row.= "Priority ";
+ $header_row.= "Last Interview ";
+ $header_row.= "Scheduling Notes ";
$table_data=""; $completed_data=""; $totals_data="";
$year = date('Y');
@@ -1779,12 +2118,10 @@ class tc
// APPOINTMENT TABLE
$district = 1;
- $date_width=250; $time_width=100; $indiv_width=200; $location_width=100;
- $appt_table_width=$date_width + $time_width + $indiv_width + $location_width;
- $appt_header_row = "Date ";
- $appt_header_row.= "Time ";
- $appt_header_row.= "Individual ";
- $appt_header_row.= "Location ";
+ $appt_header_row = "Date ";
+ $appt_header_row.= "Time ";
+ $appt_header_row.= "Individual ";
+ $appt_header_row.= "Location ";
$appt_table_data = "";
$total_comps=0; $comps_with_quarterly_int=0;
@@ -1857,7 +2194,6 @@ class tc
$this->t->set_var('appt_table_data',$appt_table_data);
$this->t->set_var('appt_header_row',$appt_header_row);
- $this->t->set_var('appt_table_width',$appt_table_width);
// INTERVIEW SCHEDULING TABLE
@@ -1907,11 +2243,11 @@ class tc
}
// If this companionship has had a hometeaching interview this quarter, don't show them on the schedule list
- $sql = "SELECT * FROM tc_interview WHERE date >= '$quarter_start' AND date < '$quarter_end' AND individual='$id'";
+ $sql = "SELECT * FROM tc_interview WHERE date >= '$quarter_start' AND date < '$quarter_end' AND individual='$id' AND interview_type='hti'";
$this->db2->query($sql,__LINE__,__FILE__);
if(!$this->db2->next_record()) {
- $sql = "SELECT * FROM tc_interview WHERE individual='$id' ORDER BY date DESC";
+ $sql = "SELECT * FROM tc_interview WHERE individual='$id' AND interview_type='hti' ORDER BY date DESC";
$this->db3->query($sql,__LINE__,__FILE__);
if($this->db3->next_record()) {
$date = $this->db3->f('date');
@@ -1970,28 +2306,24 @@ class tc
}
}
- $name_width=175; $phone_width=100; $date_width=100; $notes_width=300;
- $completed_table_width=$name_width + $phone_width + $date_width + $notes_width;
- $completed_header_row = "Individual Name ";
- $completed_header_row.= "Phone ";
- $completed_header_row.= "Date ";
- $completed_header_row.= "Interview Notes ";
+ $completed_header_row = "Individual ";
+ $completed_header_row.= "Phone ";
+ $completed_header_row.= "Date ";
+ $completed_header_row.= "Interview Notes ";
- $this->t->set_var('table_width',$table_width);
$this->t->set_var('header_row',$header_row);
$this->t->set_var('table_data',$table_data);
$this->t->set_var('completed_header_row',$completed_header_row);
- $this->t->set_var('completed_table_width',$completed_table_width);
$this->t->set_var('completed',$completed_data);
+ $this->t->set_var('lang_save_appt','Save Appts for ' . $districts[$d]['name']);
+ $this->t->set_var('lang_save_pri_notes','Save Pri / Notes for '. $districts[$d]['name']);
$this->t->fp('indivlist','individual_list',True);
} // End for each district loop
- $indivs_width=300; $totals_width=100;
- $totals_table_width=$indivs_width + $totals_width;
- $totals_header_row = "Individuals ";
- $totals_header_row.= "$year ";
+ $totals_header_row = "Individuals ";
+ $totals_header_row.= "$year ";
$totals_data.= " ";
$totals_data.= "Total Companionships with interviews completed: ";
$totals_data.= "$comps_with_quarterly_int / $total_comps ";
@@ -2005,7 +2337,6 @@ class tc
$this->t->set_var('totals',$totals_data);
$this->t->set_var('totals_header_row',$totals_header_row);
- $this->t->set_var('totals_table_width',$totals_table_width);
$this->t->pfp('out','int_sched_t');
$this->save_sessiondata();
@@ -2019,7 +2350,6 @@ class tc
$this->t->set_block('vis_sched_t','appt_list','apptlist');
$action = get_var('action',array('GET','POST'));
- $this->t->set_var('lang_save','Save Appt / Pri / Notes');
$this->t->set_var('lang_reset','Clear Changes');
$this->t->set_var('vis_link',$GLOBALS['phpgw']->link('/tc/index.php','menuaction=tc.tc.vis_view'));
@@ -2031,13 +2361,11 @@ class tc
$this->t->set_var('actionurl',$GLOBALS['phpgw']->link('/tc/index.php','menuaction=tc.tc.vis_sched&action=save'));
$this->t->set_var('title','Presidency Yearly Visit Scheduler');
- $family_width=500; $phone_width=40; $pri_width=10; $notes_width=128; $visit_date_width=20;
- $table_width=$family_width + $phone_width + $pri_width + $notes_width + $visit_date_width;
- $header_row = "Family Name ";
- $header_row.= "Phone ";
- $header_row.= "Priority ";
- $header_row.= "Last Visit ";
- $header_row.= "Scheduling Notes ";
+ $header_row = "Family Name ";
+ $header_row.= "Phone ";
+ $header_row.= "Priority ";
+ $header_row.= "Last Visit ";
+ $header_row.= "Scheduling Notes ";
$table_data=""; $completed_data=""; $totals_data="";
$year = date('Y');
@@ -2107,12 +2435,10 @@ class tc
}
// APPOINTMENT TABLE
- $date_width=250; $time_width=100; $family_width=250; $location_width=100;
- $appt_table_width=$date_width + $time_width + $family_width + $location_width;
- $appt_header_row = "Date ";
- $appt_header_row.= "Time ";
- $appt_header_row.= "Family ";
- $appt_header_row.= "Location ";
+ $appt_header_row = "Date ";
+ $appt_header_row.= "Time ";
+ $appt_header_row.= "Family ";
+ $appt_header_row.= "Location ";
$appt_table_data = "";
// Find out what the President ID is
@@ -2177,7 +2503,6 @@ class tc
$this->t->set_var('appt_table_data',$appt_table_data);
$this->t->set_var('appt_header_row',$appt_header_row);
- $this->t->set_var('appt_table_width',$appt_table_width);
// VISIT SCHEDULING TABLE
@@ -2258,17 +2583,13 @@ class tc
}
}
- $name_width=190; $phone_width=100; $date_width=100; $notes_width=300;
- $completed_table_width=$name_width + $phone_width + $date_width + $notes_width;
- $completed_header_row = "Family Name ";
- $completed_header_row.= "Phone ";
- $completed_header_row.= "Date ";
- $completed_header_row.= "Visit Notes ";
+ $completed_header_row = "Family Name ";
+ $completed_header_row.= "Phone ";
+ $completed_header_row.= "Date ";
+ $completed_header_row.= "Visit Notes ";
- $family_width=300; $totals_width=100;
- $totals_table_width=$family_width + $totals_width;
- $totals_header_row = "Families ";
- $totals_header_row.= "$year ";
+ $totals_header_row = "Families ";
+ $totals_header_row.= "$year ";
$totals_data.= " ";
$totals_data.= "Total Families with yearly Visits completed: ";
$totals_data.= "$families_with_yearly_visit / $total_families ";
@@ -2280,16 +2601,15 @@ class tc
$totals_data.= "$percent% ";
$totals_data.= " ";
- $this->t->set_var('table_width',$table_width);
$this->t->set_var('header_row',$header_row);
$this->t->set_var('table_data',$table_data);
$this->t->set_var('totals_header_row',$totals_header_row);
- $this->t->set_var('totals_table_width',$totals_table_width);
$this->t->set_var('completed_header_row',$completed_header_row);
- $this->t->set_var('completed_table_width',$completed_table_width);
$this->t->set_var('completed',$completed_data);
$this->t->set_var('totals',$totals_data);
$this->t->fp('familylist','family_list',True);
+ $this->t->set_var('lang_save_appt','Save Appts');
+ $this->t->set_var('lang_save_pri_notes','Save Pri / Notes');
$this->t->fp('apptlist','appt_list',True);
$this->t->pfp('out','vis_sched_t');
@@ -2314,12 +2634,12 @@ class tc
$this->t->set_var('actionurl',$GLOBALS['phpgw']->link('/tc/index.php','menuaction=tc.tc.ppi_view'));
$this->t->set_var('ppi_link',$GLOBALS['phpgw']->link('/tc/index.php','menuaction=tc.tc.ppi_view'));
- $this->t->set_var('ppi_link_title','Yearly PPIs');
+ $this->t->set_var('ppi_link_title',$this->ppi_frequency_label . ' PPIs');
$this->t->set_var('schedule_ppi_link',$GLOBALS['phpgw']->link('/tc/index.php','menuaction=tc.tc.ppi_sched'));
- $this->t->set_var('schedule_ppi_link_title','Schedule Yearly PPIs');
+ $this->t->set_var('schedule_ppi_link_title','Schedule ' . $this->ppi_frequency_label . ' PPIs');
- $this->t->set_var('title','Yearly PPIs');
+ $this->t->set_var('title',$this->ppi_frequency_label . ' PPIs');
$num_months = get_var('num_months',array('GET','POST'));
if($num_months == '') { $num_months = $this->default_ppi_num_years; }
$this->t->set_var('num_months',$num_months);
@@ -2356,7 +2676,7 @@ class tc
array_multisort($indiv_name, $individual);
//var_dump($indiv_name); print " "; var_dump($individual);
- $header_row="Individual Name ";
+ $header_row="Individual ";
$indiv_width=400; $ppi_width=75; $table_width=$indiv_width + $num_months*$ppi_width;
$table_data="";
@@ -2387,7 +2707,7 @@ class tc
$year = date('Y') - $m;
$year_start = $year - 1 . "-12-31"; $year_end = $year + 1 . "-01-01";
$sql = "SELECT * FROM tc_interview WHERE date > '$year_start' AND date < '$year_end' ".
- "AND individual=" . $id . " AND interview_type='ppi'";
+ "AND individual=" . $id . " AND interview_type='ppi' ORDER BY date DESC";
$this->db2->query($sql,__LINE__,__FILE__);
if(!$total_ppis[$m]) { $total_ppis[$m] = 0; }
@@ -2451,21 +2771,25 @@ class tc
$notes = get_var('notes',array('GET','POST'));
$interview_type = get_var('interview_type',array('GET','POST'));
- $sql = "SELECT * FROM tc_presidency AS tp JOIN tc_individual AS ti WHERE tp.individual=ti.individual AND tp.valid=1 AND (tp.president=1 OR tp.counselor=1 OR tp.secretary=1)";
+ $sql = "SELECT * FROM tc_presidency AS tp JOIN tc_individual AS ti WHERE tp.individual=ti.individual AND tp.valid=1 AND ";
+ if($this->yearly_ppi_interviewer == 1) { $sql .= " (tp.president=1)"; }
+ if($this->yearly_ppi_interviewer == 2) { $sql .= " (tp.president=1 OR tp.counselor=1)"; }
+ if($this->yearly_ppi_interviewer == 3) { $sql .= " (tp.president=1 OR tp.counselor=1 OR tp.secretary=1)"; }
$this->db2->query($sql,__LINE__,__FILE__);
while ($this->db2->next_record()) {
$indiv = $this->db2->f('individual');
$interviewer_name = $this->db2->f('name');
if($indiv == $interviewer) {
- $this->t->set_var('interviewer',$interviewer . ' selected');
+ $this->t->set_var('interviewer',$indiv . ' selected');
} else {
- $this->t->set_var('interviewer',$interviewer);
+ $this->t->set_var('interviewer',$indiv);
}
+ #print "indiv: $indiv interviewer: $interviewer ";
$this->t->set_var('interviewer_name',$interviewer_name);
$this->t->set_var('eqpresppi_checked','checked');
$this->t->fp('int_list','interviewer_list',True);
}
-
+ #print "selected interviewer: $interviewer ";
if($action == 'save') {
$notes = get_var('notes',array('POST'));
$this->db->query("UPDATE tc_interview set " .
@@ -2506,7 +2830,7 @@ class tc
}
if($action == 'edit' || $action == 'view') {
- $sql = "SELECT * FROM tc_interview WHERE interview=".$interview;
+ $sql = "SELECT * FROM tc_interview WHERE interview=" . $interview . " AND interview_type='ppi'";
$this->db->query($sql,__LINE__,__FILE__);
$this->db->next_record();
$this->t->set_var('interview',$interview);
@@ -2669,7 +2993,7 @@ class tc
$month_end = "$year"."-"."$month"."-"."31";
$month = "$month"."/"."$year";
$sql = "SELECT * FROM tc_interview WHERE date >= '$month_start' AND date <= '$month_end' ".
- "AND individual=" . $individual;
+ "AND individual=" . $individual . " AND interview_type='hti' ORDER BY date DESC";
$this->db2->query($sql,__LINE__,__FILE__);
$header_row .= "$month ";
@@ -2782,9 +3106,9 @@ class tc
$indiv = $this->db2->f('individual');
$interviewer_name = $this->db2->f('name');
if($indiv == $interviewer) {
- $this->t->set_var('interviewer',$interviewer . ' selected');
+ $this->t->set_var('interviewer',$indiv . ' selected');
} else {
- $this->t->set_var('interviewer',$interviewer);
+ $this->t->set_var('interviewer',$indiv);
}
$this->t->set_var('interviewer_name',$interviewer_name);
$this->t->fp('int_list','interviewer_list',True);
@@ -2829,7 +3153,7 @@ class tc
}
if($action == 'edit' || $action == 'view') {
- $sql = "SELECT * FROM tc_interview WHERE interview=".$interview;
+ $sql = "SELECT * FROM tc_interview WHERE interview=" . $interview . " AND interview_type='hti'";
$this->db->query($sql,__LINE__,__FILE__);
$this->db->next_record();
$this->t->set_var('interview',$interview);
@@ -3510,13 +3834,13 @@ class tc
$this->t->set_var('schedule_int_link_title','Schedule Hometeaching Interviews');
$this->t->set_var('schedule_ppi_link',$GLOBALS['phpgw']->link('/tc/index.php','menuaction=tc.tc.ppi_sched'));
- $this->t->set_var('schedule_ppi_link_title','Schedule Yearly PPIs');
+ $this->t->set_var('schedule_ppi_link_title','Schedule ' . $this->ppi_frequency_label . ' PPIs');
$date_width=160; $time_width=220; $indiv_width=170; $family_width=180; $location_width=100;
$table_width=$date_width + $time_width + $indiv_width + $family_width + $location_width;
$header_row = "Date ";
$header_row.= "Time ";
- $header_row.= "individual ";
+ $header_row.= "Individual ";
$header_row.= "Family ";
$header_row.= "Location ";
$table_data = "";
@@ -3577,7 +3901,7 @@ class tc
} else if($indiv > 0) {
$supervisor_name_array = explode(",",$presidency2name[$presidency]);
$supervisor_last_name = $supervisor_name_array[0];
- print "presidency2indiv: $presidency $presidency2indiv[$presidency] ";
+ #print "presidency2indiv: $presidency $presidency2indiv[$presidency] ";
$sql = "SELECT * FROM tc_individual where individual='$presidency2indiv[$presidency]'";
$this->db2->query($sql,__LINE__,__FILE__);
if($this->db2->next_record()) {