Example #1
0
 function awe_preview_report_output()
 {
     $this->load->model('awesimreport_model', 'awe');
     $this->load->model('characters_model', 'char');
     $this->load->model('positions_model', 'pos');
     $this->load->model('depts_model', 'dept');
     $this->load->model('personallogs_model', 'logs');
     $this->load->model('posts_model', 'posts');
     $this->load->model('ranks_model', 'ranks');
     $this->load->model('news_model', 'news');
     $this->load->model('users_model', 'user');
     // grab the settings
     $settings_array = array('sim_name', 'awe_txtSimStart', 'awe_txtSimEnd', 'awe_txtDateFormat', 'awe_txtEmailSubject', 'awe_txtReportTitle', 'awe_txtEmailRecipients', 'awe_chkPresenceTags', 'awe_txtReportDuration', 'awe_txtPresenceTag_Present', 'awe_txtPresenceTag_Unexcused', 'awe_txtPresenceTag_Excused', 'awe_chkShowRankImagesRoster', 'awe_chkShowRankImagesCOC', 'awe_ActiveTemplate', 'awe_txtTemplateFooter');
     $aweSettings = $this->settings->get_settings($settings_array);
     //get current template
     $tmplID = $aweSettings['awe_ActiveTemplate'];
     //get all variables
     $tDateStart = $this->input->post('txtReportDateStart', TRUE);
     $tDateEnd = $this->input->post('txtReportDateEnd', TRUE);
     $arrRosterUsers = $this->input->post('chkRosterShowUsers', TRUE);
     $arrRosterAttendance = $this->input->post('rAttendance', TRUE);
     $arrSections = $this->input->post('sections', TRUE);
     //see if this is a 'load file' request, and replace the vars
     if ($this->uri->segment(3) > 0) {
         //structure: ajax/awe_preview_report_output/reportID/templateID
         $reportID = $this->uri->segment(3);
         //check if report exists in db:
         $rep = $this->awe->get_saved_report_details($reportID);
         if ($rep !== FALSE) {
             //report exists. Load it:
             $repData = unserialize($rep->report_data);
             $tDateStart = date('n/j/Y', $rep->report_date_start);
             $tDateEnd = date('n/j/Y', $rep->report_date_end);
             $arrRosterUsers = $repData['ShowUsers'];
             $arrRosterAttendance = $repData['UserAttendance'];
             $arrSections = $repData['CustomSections'];
         } else {
             print 'ERROR: The report you\'re looking for has not been found. Check your link and try again.';
         }
         $templateID = $this->uri->segment(4);
         if ($this->awe->get_template_content($templateID) !== FALSE) {
             $tmplID = $templateID;
         }
     }
     //LOAD THE TEMPLATE
     $template = $this->awe->get_template_content($tmplID);
     if ($template === FALSE) {
         print "The requested template cannot be found. Please make sure you picked a correct template from the 'templates' section.<br />";
     }
     //prepare output array:
     $tOutput = array();
     //get section order:
     $sectionQuery = $this->awe->get_section_order();
     $c = 1;
     if ($sectionQuery->num_rows() > 0) {
         foreach ($sectionQuery->result() as $sID) {
             $sec = $this->awe->get_section_details($sID->section_id);
             if ($sec->num_rows() > 0) {
                 //get section info:
                 $section = $sec->row();
                 $tOutput[$c]['title'] = $section->section_title;
                 switch (strtolower($section->section_name)) {
                     case 'chain of command':
                         $coc = $this->char->get_coc();
                         $defaultRankset = $this->ranks->get_rank_default();
                         $rank_ext = $this->ranks->get_rankcat($defaultRankset, 'rankcat_location', 'rankcat_extension');
                         if ($coc->num_rows() > 0) {
                             $cocHtml = '<table cellspacing="0" cellpadding="0" class="coctable">';
                             foreach ($coc->result() as $item) {
                                 $cocHtml .= '<tr>';
                                 if ($item->crew_type == 'active' && empty($item->user)) {
                                     // skip
                                 } else {
                                     if ($aweSettings['awe_chkShowRankImagesCOC'] == 'checked') {
                                         $charinf = $this->char->get_character($item->charid);
                                         //get rank image:
                                         $rankdata = $this->ranks->get_rank($charinf->rank, array('rank_name', 'rank_image'));
                                         /*	$rank = $this->ranks->get_rankcat($defaultRankset);
                                         											/* build the rank image array 
                                         											$rank_img = array(
                                         												'src' => rank_location($defaultRankset, $rankdata['rank_image'],$rank->rankcat_extension),
                                         												'alt' => $rankdata['rank_name'],
                                         												'class' => 'image');
                                         */
                                         $img_rank = array('src' => rank_location($defaultRankset, $item->rank_image, $rank_ext), 'alt' => $item->rank_name, 'class' => 'image', 'border' => 0);
                                         $cocHtml .= '<td width="80" class="coc_rank">' . img($img_rank) . '</td>';
                                     }
                                     $coc_id = $item->charid;
                                     $coc_name = $this->char->get_character_name($item->charid, TRUE);
                                     $coc_position = $item->pos_name;
                                     $coc_item['id'] = $item->charid;
                                     $coc_item['coc_name'] = $this->char->get_character_name($item->charid, TRUE);
                                     $coc_item['coc_position'] = $item->pos_name;
                                     $cocHtml .= '<td class="coc_char">';
                                     $cocHtml .= '<strong>' . anchor('personnel/character/' . $item->charid, $coc_name) . '</strong><br />';
                                     $cocHtml .= '<span style="size: 90%;">(' . $coc_position . ')</span>';
                                     $cocHtml .= '</td>';
                                 }
                                 $cocHtml .= '</tr>';
                             }
                             //foreach coc item
                             $cocHtml .= '</table>';
                         }
                         //end if coc has records
                         $html = $cocHtml;
                         break;
                         /*	case 'report date':
                         			$html = '<span class="reportDate">Dates: '.date($aweSettings['awe_txtDateFormat'],$tDateStart).' to '.date($aweSettings['awe_txtDateFormat'],$tDateEnd).'</span>';
                         			break;*/
                     /*	case 'report date':
                     			$html = '<span class="reportDate">Dates: '.date($aweSettings['awe_txtDateFormat'],$tDateStart).' to '.date($aweSettings['awe_txtDateFormat'],$tDateEnd).'</span>';
                     			break;*/
                     case 'reporting officer':
                         $uid = $this->session->userdata('userid');
                         $charid = $this->user->get_main_character($uid);
                         $curr_char = $this->char->get_character($charid);
                         $posts = $this->pos->get_position($curr_char->position_1);
                         $positions = $posts !== FALSE ? $posts->pos_name : '';
                         if ((int) $curr_char->position_2 > 0) {
                             $positions .= " & " . $this->pos->get_position($curr_char->position_2, 'pos_name');
                         }
                         $html = '<span class="reportingOfficer">';
                         $html .= $this->char->get_character_name($charid, TRUE) . '<br />';
                         $html .= $positions . '<br />';
                         $html .= $aweSettings['sim_name'];
                         $html .= '</span>';
                         break;
                     case 'roster':
                         $arrRosterAttendanceTags = '';
                         //go over the 'checked users' checkboxes:
                         if ($aweSettings['awe_chkPresenceTags'] == 'checked') {
                             $arrRosterAttendanceTags['P'] = $aweSettings['awe_txtPresenceTag_Present'];
                             $arrRosterAttendanceTags['U'] = $aweSettings['awe_txtPresenceTag_Unexcused'];
                             $arrRosterAttendanceTags['E'] = $aweSettings['awe_txtPresenceTag_Excused'];
                         }
                         $depts = $this->dept->get_all_depts('asc', '');
                         if ($depts->num_rows() > 0) {
                             foreach ($depts->result() as $d) {
                                 $characters[$d->dept_id]['deptname'] = $d->dept_name;
                                 $subdepts = $this->dept->get_sub_depts($d->dept_id);
                                 if ($subdepts->num_rows() > 0) {
                                     foreach ($subdepts->result() as $subd) {
                                         $characters[$d->dept_id]['subdept'][$subd->dept_id]['deptname'] = $subd->dept_name;
                                     }
                                 }
                             }
                         }
                         if (count($arrRosterUsers) > 0) {
                             foreach ($arrRosterUsers as $uid => $val) {
                                 $charid = $this->user->get_main_character($uid);
                                 $charinf = $this->char->get_character($charid);
                                 //get rank image:
                                 $rankdata = $this->ranks->get_rank($charinf->rank, array('rank_name', 'rank_image'));
                                 $defaultRankset = $this->ranks->get_rank_default();
                                 $rank = $this->ranks->get_rankcat($defaultRankset);
                                 /* build the rank image array */
                                 $rank_img = array('src' => rank_location($defaultRankset, $rankdata['rank_image'], $rank->rankcat_extension), 'alt' => $rankdata['rank_name'], 'class' => 'image');
                                 $posts = $this->pos->get_position($charinf->position_1);
                                 $positions = $posts !== FALSE ? $posts->pos_name : '';
                                 if ((int) $charinf->position_2 > 0) {
                                     $positions .= " & " . $this->pos->get_position($charinf->position_2, 'pos_name');
                                 }
                                 $currdept = $this->dept->get_dept($posts->pos_dept);
                                 $cdept = $currdept->dept_id;
                                 $parentDep = $currdept->dept_parent;
                                 $u = $this->user->get_user($uid);
                                 $loa = $u->loa;
                                 if ((int) $parentDep > 0) {
                                     //there is a 'parent' to the dept
                                     $characters[$parentDep]['subdept'][$cdept]['chars'][$uid] = array('id' => $uid, 'name' => $u->name, 'email' => $u->email, 'char_name' => $this->char->get_character_name($charid, TRUE), 'position' => $positions, 'rank_img' => $rank_img, 'charid' => $charid, 'attendance' => $arrRosterAttendance[$uid], 'logcount' => $this->awe->count_user_log_post($uid, strtotime($tDateStart), strtotime($tDateEnd), 'logs'), 'postcount' => $this->awe->count_user_log_post($uid, strtotime($tDateStart), strtotime($tDateEnd), 'posts'), 'totalcount' => $this->awe->count_user_log_post($uid, strtotime($tDateStart), strtotime($tDateEnd)));
                                     //										$departments[$charid] = $cdept;
                                 } else {
                                     //the dept is the parent
                                     $characters[$cdept]['chars'][$uid] = array('id' => $uid, 'name' => $u->name, 'email' => $u->email, 'char_name' => $this->char->get_character_name($charid, TRUE), 'position' => $positions, 'rank_img' => $rank_img, 'charid' => $charid, 'attendance' => $arrRosterAttendance[$uid], 'logcount' => $this->awe->count_user_log_post($uid, strtotime($tDateStart), strtotime($tDateEnd), 'logs'), 'postcount' => $this->awe->count_user_log_post($uid, strtotime($tDateStart), strtotime($tDateEnd), 'posts'), 'totalcount' => $this->awe->count_user_log_post($uid, strtotime($tDateStart), strtotime($tDateEnd)));
                                     //										$departments[$charid] = $cdept;
                                 }
                             }
                             //end foreach users
                         }
                         $html = '';
                         $html = '<span class="reportDate">Dates: ' . strftime($aweSettings['awe_txtDateFormat'], $tDateStart) . ' to ' . strftime($aweSettings['awe_txtDateFormat'], $tDateEnd) . '</span>';
                         $out = $this->awe->template_make_roster_html($characters, $aweSettings['awe_chkPresenceTags'], $arrRosterAttendanceTags, $aweSettings['awe_chkShowRankImagesRoster']);
                         $html = $out['html'];
                         break;
                     case 'statistics':
                         $dates = array();
                         $result = array();
                         $sPeriod = $aweSettings['awe_txtReportDuration'];
                         if (empty($sPeriod)) {
                             $sPeriod = 30;
                             //approx a month
                         }
                         $rawStatPeriod = $sPeriod * 86400;
                         //turn into seconds
                         $counter = 0;
                         if ($aweSettings['awe_txtStatOccurences'] < 1) {
                             $repOccurences = 10;
                         } else {
                             $repOccurences = $aweSettings['awe_txtStatOccurences'];
                         }
                         $endDate = now();
                         while ($counter <= $repOccurences) {
                             $startDate = (int) ($endDate - $rawStatPeriod);
                             $curr_month = date('n', $endDate);
                             $result[] = $this->awe->stats_total_logcount($startDate, $endDate) + 1;
                             $dates[] = date('Mj', $endDate);
                             $endDate = $startDate - 1;
                             //next occurence start a month ago, a second earlier
                             $counter++;
                         }
                         $maxval = max($result);
                         $newresult = array();
                         foreach ($result as $sig) {
                             //turn it into percentages:
                             $newresult[] = $sig / $maxval * 100;
                         }
                         $data['dates'] = $dates;
                         $data['result'] = $newresult;
                         $halfmaxvalue = $maxval / 2;
                         $imgsrc = "http://chart.apis.google.com/chart?";
                         $imgsrc .= "chxl=0:|" . implode('|', $dates);
                         $imgsrc .= "&chxr=0,0,0|1,0," . (int) $maxval;
                         $imgsrc .= "&chxs=0,AA0033,11.5,0,lt,676767|1,676767,11.5,0,lt,676767";
                         $imgsrc .= "&chxt=x,y";
                         $imgsrc .= "&chbh=a,5";
                         $imgsrc .= "&chs=500x400";
                         $imgsrc .= "&cht=bvg";
                         $imgsrc .= "&chd=t:" . implode(',', $newresult);
                         $imgsrc .= "&chds=a";
                         $imgsrc .= "&chdlp=b";
                         $imgsrc .= "&chp=0";
                         $imgsrc .= "&chg=10,10,0,9";
                         $imgsrc .= "&chma=5";
                         $imgsrc .= "&chtt=Total+Log+Count";
                         $imggraph = array('src' => $imgsrc, 'alt' => 'Total Log Count', 'class' => 'image');
                         $html = img($imggraph);
                         break;
                     default:
                         //freetext
                         $html = nl2br($arrSections[$section->section_id]);
                         break;
                 }
                 $tOutput[$c]['html'] = $html;
             }
             //end if sec->num_rows >0
             $c++;
             //counter
         }
         //end foreach section
     }
     //end if sectionquery
     //print out the html result:
     echo $this->awe->template_replace_tag($template['header'], '%%reporttitle%%', $aweSettings['awe_txtReportTitle']);
     //print out sections:
     foreach ($tOutput as $sec) {
         if (!empty($sec['html'])) {
             echo $this->awe->template_replace_tag($template['section_title'], '%%section_title%%', $sec['title']);
             echo $this->awe->template_replace_tag($template['section_content'], '%%section_content%%', $sec['html']);
         }
     }
     $credits = '<div style="font-size: 80%;">Report generated by <a href="https://github.com/mooeypoo/aweSimReport-2.0" target="_blank">aweSimReport Generator.</a></div>';
     echo $this->awe->template_replace_tag($template['section_content'], '%%section_content%%', $credits);
     echo $this->awe->template_replace_tag($template['footer'], '%%footer%%', $aweSettings['awe_txtTemplateFooter']);
 }
Example #2
0
 /** ====================== **/
 function awesimreport()
 {
     /* load resources */
     $this->load->model('awesimreport_model', 'awe');
     $this->load->model('characters_model', 'char');
     $this->load->model('positions_model', 'pos');
     $this->load->model('depts_model', 'dept');
     $this->load->model('personallogs_model', 'logs');
     $this->load->model('posts_model', 'posts');
     $this->load->model('ranks_model', 'ranks');
     $this->load->model('news_model', 'news');
     $this->load->model('users_model', 'user');
     $data['images']['loading'] = array('src' => img_location('loading-bar.gif', $this->skin, 'admin'), 'alt' => 'Loading', 'class' => 'image');
     /** SET UP MENU **/
     $data['images']['menu'] = array('generator' => array('src' => asset_location('images/awesimreport', 'awe_menu_generator.png'), 'class' => 'image inline_img_left', 'height' => 48, 'alt' => 'Generator', 'title' => 'Generator'), 'archive' => array('src' => asset_location('images/awesimreport', 'awe_menu_archive.png'), 'class' => 'image inline_img_left', 'height' => 48, 'alt' => 'Archive'), 'sections' => array('src' => asset_location('images/awesimreport', 'awe_menu_sections.png'), 'class' => 'image inline_img_left', 'height' => 48, 'alt' => 'Sections'), 'settings' => array('src' => asset_location('images/awesimreport', 'awe_menu_settings.png'), 'class' => 'image inline_img_left', 'height' => 48, 'alt' => 'Settings'), 'templates' => array('src' => asset_location('images/awesimreport', 'awe_menu_templates.png'), 'class' => 'image inline_img_left', 'height' => 48, 'alt' => 'Templates'));
     /* grab the settings */
     $settings_array = array('awe_txtSimStart', 'awe_txtSimEnd', 'awe_txtDateFormat', 'awe_txtEmailSubject', 'awe_txtReportTitle', 'awe_txtEmailRecipients', 'awe_chkPresenceTags', 'awe_txtReportDuration', 'awe_txtStatOccurences', 'awe_txtPresenceTag_Present', 'awe_txtPresenceTag_Unexcused', 'awe_txtPresenceTag_Excused', 'awe_chkShowRankImagesRoster', 'awe_chkShowRankImagesCOC', 'awe_ActiveTemplate', 'awe_txtTemplateFooter');
     $aweSettings = $this->settings->get_settings($settings_array);
     //info about email:
     $mail_uid = $this->session->userdata('userid');
     $charid = $this->user->get_main_character($mail_uid);
     $myaddress = $this->user->get_email_address($mail_uid);
     $myname = $this->char->get_character_name($charid, TRUE);
     $mailsubject = $aweSettings['awe_txtEmailSubject'];
     $mailrecipients = explode(',', $aweSettings['awe_txtEmailRecipients']);
     if ($myaddress == FALSE) {
         $myaddress = '*****@*****.**';
     }
     $js_data['email']['myaddress'] = $myaddress;
     $js_data['email']['myname'] = $myname;
     $js_data['email']['mailsubject'] = $mailsubject;
     $js_data['email']['mailrecipients'] = $mailrecipients;
     switch ($this->uri->segment(3)) {
         default:
         case "generator":
             /* set the variables */
             $id = $this->uri->segment(4, FALSE, TRUE);
             $data['debug']['id'] = $id;
             $data['reportid'] = $id;
             //DEAL WITH POST REQUESTS:
             if (isset($_POST['submit'])) {
                 $action = strtolower($this->input->post('submit', TRUE));
                 switch ($action) {
                     case 'save report':
                         $dateStart = $this->input->post('txtReportDateStart');
                         $dateEnd = $this->input->post('txtReportDateEnd');
                         $chkShowUsers = $this->input->post('chkRosterShowUsers', TRUE);
                         $customSections = $this->input->post('sections', TRUE);
                         $dataArray = array('CustomSections' => $customSections, 'ShowUsers' => $chkShowUsers);
                         /* build the insert array */
                         $insert_array = array('report_date_start' => strtotime($dateStart), 'report_date_end' => strtotime($dateEnd), 'report_author' => $this->session->userdata('userid'), 'report_data' => serialize($dataArray), 'report_status' => 'saved', 'report_template' => $aweSettings['awe_ActiveTemplate'], 'report_saved_date' => now());
                         /* do the insert */
                         $insert = $this->awe->add_saved_report($insert_array);
                         /* grab the insert id */
                         $insert_id = $this->db->insert_id();
                         /* optimize the table */
                         $this->sys->optimize_table('awe_saved_reports');
                         if ($insert > 0) {
                             $message = 'Report saved successfully. Please wait to be redirected to your saved report...';
                             $flash['status'] = 'success';
                             $flash['message'] = text_output($message);
                         } else {
                             $message = '201: An error occured while saving this report. Please try again later.';
                             $flash['status'] = 'error';
                             $flash['message'] = text_output($message);
                         }
                         /* add a quick redirect */
                         $this->template->add_redirect('report/awesimreport/generator/' . $insert_id);
                         break;
                         //save
                     //save
                     case 'update report':
                         $dateStart = $this->input->post('txtReportDateStart');
                         $dateEnd = $this->input->post('txtReportDateEnd');
                         $chkShowUsers = $this->input->post('chkRosterShowUsers', TRUE);
                         $customSections = $this->input->post('sections', TRUE);
                         $dataArray = array('CustomSections' => $customSections, 'ShowUsers' => $chkShowUsers);
                         /* if there is an ID, it is a previously saved report */
                         $update_array = array('report_date_start' => strtotime($dateStart), 'report_date_end' => strtotime($dateEnd), 'report_author' => $this->session->userdata('userid'), 'report_data' => serialize($dataArray), 'report_status' => 'saved', 'report_template' => $aweSettings['awe_ActiveTemplate'], 'report_saved_date' => now());
                         /* do the update */
                         $update = $this->awe->update_saved_report($id, $update_array);
                         if ($update > 0) {
                             $message = 'Report updated successfully.';
                             $flash['status'] = 'success';
                             $flash['message'] = text_output($message);
                         } else {
                             $message = 'An error occured while trying to update this report. Please try again later.';
                             $flash['status'] = 'error';
                             $flash['message'] = text_output($message);
                         }
                         break;
                         //update
                     //update
                     case 'generate report':
                         //get all variables
                         $tDateStart = $this->input->post('txtReportDateStart', TRUE);
                         $tDateEnd = $this->input->post('txtReportDateEnd', TRUE);
                         $arrRosterUsers = $this->input->post('chkRosterShowUsers', TRUE);
                         $arrRosterAttendance = $this->input->post('rAttendance', TRUE);
                         $arrSections = $this->input->post('sections', TRUE);
                         //get current template
                         $tmplID = $aweSettings['awe_ActiveTemplate'];
                         $template = $this->awe->get_template_content($tmplID);
                         //prepare output array:
                         $tOutput = array();
                         //get section order:
                         $sectionQuery = $this->awe->get_section_order();
                         $c = 1;
                         if ($sectionQuery->num_rows() > 0) {
                             foreach ($sectionQuery->result() as $sID) {
                                 $sec = $this->awe->get_section_details($sID->section_id);
                                 if ($sec->num_rows() > 0) {
                                     //get section info:
                                     $section = $sec->row();
                                     $tOutput[$c]['title'] = $section->section_title;
                                     switch (strtolower($section->section_name)) {
                                         case 'chain of command':
                                             $plaintext = '';
                                             $coc = $this->char->get_coc();
                                             $defaultRankset = $this->ranks->get_rank_default();
                                             $rank_ext = $this->ranks->get_rankcat($defaultRankset, 'rankcat_location', 'rankcat_extension');
                                             if ($coc->num_rows() > 0) {
                                                 $cocHtml = '<table cellspacing="0" cellpadding="0" class="coctable">';
                                                 foreach ($coc->result() as $item) {
                                                     $cocHtml .= '<tr>';
                                                     if ($item->crew_type == 'active' && empty($item->user)) {
                                                         // skip
                                                     } else {
                                                         if ($aweSettings['awe_chkShowRankImagesCOC'] == 'checked') {
                                                             $charinf = $this->char->get_character($item->charid);
                                                             //get rank image:
                                                             $rankdata = $this->ranks->get_rank($charinf->rank, array('rank_name', 'rank_image'));
                                                             $img_rank = array('src' => rank_location($defaultRankset, $item->rank_image, $rank_ext), 'alt' => $item->rank_name, 'class' => 'image', 'border' => 0);
                                                             $cocHtml .= '<td width="80" class="coc_rank">' . img($img_rank) . '</td>';
                                                         }
                                                         $coc_id = $item->charid;
                                                         $coc_name = $this->char->get_character_name($item->charid, TRUE);
                                                         $coc_position = $item->pos_name;
                                                         $coc_item['id'] = $item->charid;
                                                         $coc_item['coc_name'] = $this->char->get_character_name($item->charid, TRUE);
                                                         $coc_item['coc_position'] = $item->pos_name;
                                                         $cocHtml .= '<td class="coc_char">';
                                                         $cocHtml .= '<strong>' . anchor('personnel/character/' . $item->charid, $coc_name) . '</strong><br />';
                                                         $cocHtml .= '<span style="size: 90%;">(' . $coc_position . ')</span>';
                                                         $cocHtml .= '</td>';
                                                         $cocPlain = "* " . $coc_name . " (" . $coc_position . ")\r\n";
                                                     }
                                                     $cocHtml .= '</tr>';
                                                 }
                                                 //foreach coc item
                                                 $cocHtml .= '</table>';
                                             }
                                             //end if coc has records
                                             $html = $cocHtml;
                                             $plaintext = $cocPlain;
                                             break;
                                         case 'report date':
                                             $html = '<span class="reportDate">Dates: ' . strftime($aweSettings['awe_txtDateFormat'], $tDateStart) . ' to ' . strftime($aweSettings['awe_txtDateFormat'], $tDateEnd) . '</span>';
                                             $plaintext = 'Dates: ' . strftime($aweSettings['awe_txtDateFormat'], $tDateStart) . ' to ' . strftime($aweSettings['awe_txtDateFormat'], $tDateEnd) . "\r\n";
                                             break;
                                         case 'reporting officer':
                                             $uid = $this->session->userdata('userid');
                                             $charid = $this->user->get_main_character($uid);
                                             $curr_char = $this->char->get_character($charid);
                                             $posts = $this->pos->get_position($curr_char->position_1);
                                             $positions = $posts !== FALSE ? $posts->pos_name : '';
                                             if ((int) $curr_char->position_2 > 0) {
                                                 $positions .= " & " . $this->pos->get_position($curr_char->position_2, 'pos_name');
                                             }
                                             $html = '<span class="reportingOfficer">';
                                             $html .= $this->char->get_character_name($charid, TRUE) . '<br />';
                                             $html .= $positions . '<br />';
                                             $html .= $aweSettings['sim_name'];
                                             $html .= '</span>';
                                             $plaintext = $this->char->get_character_name($charid, TRUE) . "\r\n";
                                             $plaintext .= $positions . "\r\n";
                                             $plaintext .= $aweSettings['sim_name'] . "\r\n";
                                             break;
                                         case 'roster':
                                             $arrRosterAttendanceTags = '';
                                             //go over the 'checked users' checkboxes:
                                             if ($aweSettings['awe_chkPresenceTags'] == 'checked') {
                                                 $arrRosterAttendanceTags['P'] = $aweSettings['awe_txtPresenceTag_Present'];
                                                 $arrRosterAttendanceTags['U'] = $aweSettings['awe_txtPresenceTag_Unexcused'];
                                                 $arrRosterAttendanceTags['E'] = $aweSettings['awe_txtPresenceTag_Excused'];
                                             }
                                             $depts = $this->dept->get_all_depts('asc', '');
                                             if ($depts->num_rows() > 0) {
                                                 foreach ($depts->result() as $d) {
                                                     $characters[$d->dept_id]['deptname'] = $d->dept_name;
                                                     $subdepts = $this->dept->get_sub_depts($d->dept_id);
                                                     if ($subdepts->num_rows() > 0) {
                                                         foreach ($subdepts->result() as $subd) {
                                                             $characters[$d->dept_id]['subdept'][$subd->dept_id]['deptname'] = $subd->dept_name;
                                                         }
                                                     }
                                                 }
                                             }
                                             if (count($arrRosterUsers) > 0) {
                                                 foreach ($arrRosterUsers as $uid => $val) {
                                                     $charid = $this->user->get_main_character($uid);
                                                     $charinf = $this->char->get_character($charid);
                                                     //get rank image:
                                                     $rankdata = $this->ranks->get_rank($charinf->rank, array('rank_name', 'rank_image'));
                                                     $defaultRankset = $this->ranks->get_rank_default();
                                                     $rank = $this->ranks->get_rankcat($defaultRankset);
                                                     /* build the rank image array */
                                                     $rank_img = array('src' => rank_location($defaultRankset, $rankdata['rank_image'], $rank->rankcat_extension), 'alt' => $rankdata['rank_name'], 'class' => 'image');
                                                     $posts = $this->pos->get_position($charinf->position_1);
                                                     $positions = $posts !== FALSE ? $posts->pos_name : '';
                                                     if ((int) $charinf->position_2 > 0) {
                                                         $positions .= " & " . $this->pos->get_position($charinf->position_2, 'pos_name');
                                                     }
                                                     $currdept = $this->dept->get_dept($posts->pos_dept);
                                                     $cdept = $currdept->dept_id;
                                                     $parentDep = $currdept->dept_parent;
                                                     $u = $this->user->get_user($uid);
                                                     $loa = $u->loa;
                                                     if ((int) $parentDep > 0) {
                                                         //there is a 'parent' to the dept
                                                         $characters[$parentDep]['subdept'][$cdept]['chars'][$uid] = array('id' => $uid, 'name' => $u->name, 'email' => $u->email, 'char_name' => $this->char->get_character_name($charid, TRUE), 'position' => $positions, 'rank_name' => $rankdata['rank_name'], 'rank_img' => $rank_img, 'charid' => $charid, 'attendance' => $arrRosterAttendance[$uid], 'logcount' => $this->awe->count_user_log_post($uid, strtotime($tDateStart), strtotime($tDateEnd), 'logs'), 'postcount' => $this->awe->count_user_log_post($uid, strtotime($tDateStart), strtotime($tDateEnd), 'posts'), 'totalcount' => $this->awe->count_user_log_post($uid, strtotime($tDateStart), strtotime($tDateEnd)));
                                                         //										$departments[$charid] = $cdept;
                                                     } else {
                                                         //the dept is the parent
                                                         $characters[$cdept]['chars'][$uid] = array('id' => $uid, 'name' => $u->name, 'email' => $u->email, 'char_name' => $this->char->get_character_name($charid, TRUE), 'position' => $positions, 'rank_img' => $rank_img, 'charid' => $charid, 'attendance' => $arrRosterAttendance[$uid], 'logcount' => $this->awe->count_user_log_post($uid, strtotime($tDateStart), strtotime($tDateEnd), 'logs'), 'postcount' => $this->awe->count_user_log_post($uid, strtotime($tDateStart), strtotime($tDateEnd), 'posts'), 'totalcount' => $this->awe->count_user_log_post($uid, strtotime($tDateStart), strtotime($tDateEnd)));
                                                         //										$departments[$charid] = $cdept;
                                                     }
                                                 }
                                                 //end foreach users
                                             }
                                             $html = '';
                                             $out = $this->awe->template_make_roster_html($characters, $aweSettings['awe_chkPresenceTags'], $arrRosterAttendanceTags, $aweSettings['awe_chkShowRankImagesRoster']);
                                             $html = $out['html'];
                                             $plaintext = $out['plain'];
                                             break;
                                         case 'statistics':
                                             $dates = array();
                                             $result = array();
                                             $sPeriod = $aweSettings['awe_txtReportDuration'];
                                             if (empty($sPeriod)) {
                                                 $sPeriod = 30;
                                                 //approx a month
                                             }
                                             $rawStatPeriod = $sPeriod * 86400;
                                             //turn into seconds
                                             $counter = 0;
                                             if ($aweSettings['awe_txtStatOccurences'] < 1) {
                                                 $repOccurences = 10;
                                             } else {
                                                 $repOccurences = $aweSettings['awe_txtStatOccurences'];
                                             }
                                             $endDate = now();
                                             while ($counter <= $repOccurences) {
                                                 $startDate = (int) ($endDate - $rawStatPeriod);
                                                 $curr_month = date('n', $endDate);
                                                 $result[] = $this->awe->stats_total_logcount($startDate, $endDate) + 1;
                                                 $dates[] = date('Mj', $endDate);
                                                 $endDate = $startDate - 1;
                                                 //next occurence start a month ago, a second earlier
                                                 $counter++;
                                             }
                                             $maxval = max($result);
                                             $newresult = array();
                                             foreach ($result as $sig) {
                                                 //turn it into percentages:
                                                 $newresult[] = $sig / $maxval * 100;
                                             }
                                             $data['dates'] = $dates;
                                             $data['result'] = $newresult;
                                             $halfmaxvalue = $maxval / 2;
                                             $imgsrc = "http://chart.apis.google.com/chart?";
                                             $imgsrc .= "chxl=0:|" . implode('|', $dates);
                                             $imgsrc .= "&chxr=0,0,0|1,0," . (int) $maxval;
                                             $imgsrc .= "&chxs=0,AA0033,11.5,0,lt,676767|1,676767,11.5,0,lt,676767";
                                             $imgsrc .= "&chxt=x,y";
                                             $imgsrc .= "&chbh=a,5";
                                             $imgsrc .= "&chs=500x400";
                                             $imgsrc .= "&cht=bvg";
                                             $imgsrc .= "&chd=t:" . implode(',', $newresult);
                                             $imgsrc .= "&chds=a";
                                             $imgsrc .= "&chdlp=b";
                                             $imgsrc .= "&chp=0";
                                             $imgsrc .= "&chg=10,10,0,9";
                                             $imgsrc .= "&chma=5";
                                             $imgsrc .= "&chtt=Total+Log+Count";
                                             $imggraph = array('src' => $imgsrc, 'alt' => 'Total Log Count', 'class' => 'image');
                                             $html = img($imggraph);
                                             $plaintext = 'To view statistics graph, please visit: ' . $imgsrc;
                                             break;
                                         default:
                                             //freetext
                                             $html = nl2br($arrSections[$section->section_id]);
                                             $plaintext = $arrSections[$section->section_id];
                                             break;
                                     }
                                     $tOutput[$c]['html'] = $html;
                                     $tOutput[$c]['plaintext'] = $plaintext;
                                 }
                                 //end if sec->num_rows >0
                                 $c++;
                                 //counter
                             }
                             //end foreach section
                         }
                         //end if sectionquery
                         //print out the html result:
                         $htmlMail = $this->awe->template_replace_tag($template['header'], '%%reporttitle%%', $aweSettings['awe_txtReportTitle']);
                         $txtMail = $aweSettings['awe_txtReportTitle'] . '\\r\\n';
                         $txtMail .= "========================================\r\n\r\n\r\n";
                         //print out sections:
                         foreach ($tOutput as $sec) {
                             if (!empty($sec['html'])) {
                                 $htmlMail .= $this->awe->template_replace_tag($template['section_title'], '%%section_title%%', $sec['title']);
                                 $htmlMail .= $this->awe->template_replace_tag($template['section_content'], '%%section_content%%', $sec['html']);
                             }
                             if (!empty($sec['plaintext'])) {
                                 $txtMail .= $sec['title'];
                                 $txtMail .= "========================================\r\n";
                                 $txtMail .= $sec['plaintext'];
                                 $txtMail .= "\r\n\r\n";
                             }
                         }
                         $credits = '<div style="font-size: 80%;">Report generated by <a href="https://github.com/mooeypoo/aweSimReport-2.0" target="_blank">aweSimReport Generator.</a></div>';
                         $htmlMail .= $this->awe->template_replace_tag($template['section_content'], '%%section_content%%', $credits);
                         $htmlMail .= $this->awe->template_replace_tag($template['footer'], '%%footer%%', $aweSettings['awe_txtTemplateFooter']);
                         $txtMail .= "--\r\n";
                         $txtMail .= $aweSettings['awe_txtTemplateFooter'];
                         $txtMail .= "--\r\n";
                         $txtMail .= "Report Generated by aweSimReport (https://github.com/mooeypoo/aweSimReport-2.0)\r\n";
                         $txtMail .= "--\r\n";
                         /** Put this report in the archives **/
                         $dataArray = array('CustomSections' => $arrSections, 'UserAttendance' => $arrRosterUsers, 'ShowUsers' => $arrRosterAttendance);
                         /* build the insert array */
                         $insert_array = array('report_date_start' => strtotime($tDateStart), 'report_date_end' => strtotime($tDateEnd), 'report_author' => $this->session->userdata('userid'), 'report_data' => serialize($dataArray), 'report_status' => 'published', 'report_template' => $aweSettings['awe_ActiveTemplate'], 'report_date_sent' => now());
                         if ($id > 0) {
                             //this report exists
                             /* do the update */
                             $update = $this->awe->update_saved_report($id, $insert_array);
                             if ($update > 0) {
                                 $message = 'Report sent to your lists and updated in the archive.';
                                 $flash['status'] = 'success';
                                 $flash['message'] = text_output($message);
                             } else {
                                 $message = 'An error occured while trying to update this report. Please try again later.';
                                 $flash['status'] = 'error';
                                 $flash['message'] = text_output($message);
                             }
                         } else {
                             //new report. insert into the system
                             /* do the insert */
                             $insert = $this->awe->add_saved_report($insert_array);
                             /* grab the insert id */
                             $insert_id = $this->db->insert_id();
                             /* optimize the table */
                             $this->sys->optimize_table('awe_saved_reports');
                             if ($insert > 0) {
                                 $message = 'Report sent to your lists and inserted into the archive.';
                                 $flash['status'] = 'success';
                                 $flash['message'] = text_output($message);
                             } else {
                                 $message = '201: An error occured while saving this report to the archives. Please try again later.';
                                 $flash['status'] = 'error';
                                 $flash['message'] = text_output($message);
                             }
                         }
                         /** PREPARE TO SEND EMAIL **/
                         $this->load->library('email');
                         $this->email->from($myaddress, $myname);
                         $this->email->to($mailrecipients);
                         $this->email->subject($mailsubject);
                         $this->email->message($htmlMail);
                         $this->email->set_alt_message($txtMail);
                         $this->email->send();
                         break;
                         //generate
                     //generate
                     case 'delete saved report':
                         //get info:
                         $reportRow = $this->awe->get_saved_report_details($id);
                         if ($reportRow !== FALSE) {
                             if ($reportRow->report_status == 'saved') {
                                 //exists, and not a published report.
                                 //go ahead an delete:
                                 $delete = $this->awe->delete_saved_report($id);
                                 if ($delete > 0) {
                                     $message = 'Report deleted successfully. Please wait to be redirected...';
                                     $flash['status'] = 'success';
                                     $flash['message'] = text_output($message);
                                 } else {
                                     $message = '102: There was an error deleting this report. Try again later.';
                                     $flash['status'] = 'error';
                                     $flash['message'] = text_output($message);
                                 }
                             } else {
                                 //this is a published report
                                 $message = 'Cannot delete published report.';
                                 $flash['status'] = 'еrror';
                                 $flash['message'] = text_output($message);
                             }
                             /* add an automatic redirect */
                             $this->template->add_redirect('report/awesimreport');
                         } else {
                             //report doesn't exist
                             $message = 'There was a problem deleting this report. It appears the ID doesn\'t exist anymore! Please try again later.';
                             $flash['status'] = 'еrror';
                             $flash['message'] = text_output($message);
                         }
                         break;
                         //delete
                     //delete
                     default:
                         $flash['status'] = 'error';
                         $flash['message'] = lang_output('error_generic', '');
                 }
                 /* write everything to the template */
                 $this->template->write_view('flash_message', '_base/admin/pages/flash', $flash);
             }
             //end if 'isset submit'
             $chkShowUsers = array();
             $customSections = array();
             $inputVal['txtReportDateStart'] = '';
             $inputVal['txtReportDateStart'] = '';
             if ($id !== FALSE) {
                 /* if there is an ID, it is a previously saved report */
                 //load the report:
                 $report = $this->awe->get_saved_report_details($id);
                 if ($report !== FALSE) {
                     //it exists!
                     $repdata = unserialize($report->report_data);
                     $chkShowUsers = $repdata['ShowUsers'];
                     $customSections = $repdata['CustomSections'];
                     $inputVal['txtReportDateStart'] = $report->report_date_start > 0 ? date('n/j/Y', $report->report_date_start) : '';
                     $inputVal['txtReportDateEnd'] = $report->report_date_end > 0 ? date('n/j/Y', $report->report_date_end) : '';
                 }
             }
             $data['debug']['action'] = $action;
             //set up inputs:
             $data['inputs'] = array('formAttributes' => array('name' => 'frmGenerate', 'id' => 'frmGenerate'), 'txtReportDateStart' => array('style' => 'width:150px;', 'name' => 'txtReportDateStart', 'id' => 'txtReportDateStart', 'value' => $inputVal['txtReportDateStart']), 'txtReportDateEnd' => array('style' => 'width:150px;', 'name' => 'txtReportDateEnd', 'id' => 'txtReportDateEnd', 'value' => $inputVal['txtReportDateEnd']), 'butGenerate' => array('type' => 'submit', 'class' => 'button-main', 'name' => 'submit', 'value' => 'generate', 'id' => 'submitGenerate', 'content' => ucwords('Generate Report')), 'preview' => array('type' => 'submit', 'class' => 'button-sec', 'name' => 'preview', 'value' => 'preview', 'id' => 'preview', 'content' => ucwords('Preview Report')), 'save' => array('type' => 'submit', 'class' => 'button-sec', 'name' => 'submit', 'value' => 'save', 'id' => 'save', 'content' => ucwords('Save Report')), 'update' => array('type' => 'submit', 'class' => 'button-sec', 'name' => 'submit', 'value' => 'update', 'id' => 'save', 'content' => ucwords('Update Report')), 'delete' => array('type' => 'submit', 'class' => 'button-sec', 'name' => 'submit', 'value' => 'delete', 'id' => 'submitDelete', 'content' => ucwords('Delete Saved Report')));
             /** ROSTER! **/
             $secID = $this->awe->get_section_by_name('Roster');
             $isActive = $this->awe->check_section_active($secID);
             $js_data['RosterActive'] = $isActive;
             if ($isActive > 0) {
                 //roster exists.
                 //get settings:
                 $data['roster']['Enabled'] = (int) $isActive;
                 $data['roster']['UseTags'] = $aweSettings['awe_chkPresenceTags'];
                 $data['roster']['Present'] = $aweSettings['awe_txtPresenceTag_Present'];
                 $data['roster']['Unexcused'] = $aweSettings['awe_txtPresenceTag_Unexcused'];
                 $data['roster']['Excused'] = $aweSettings['awe_txtPresenceTag_Excused'];
                 $data['roster']['ShowRankImages'] = $aweSettings['awe_chkShowRankImagesRoster'];
                 if ($aweSettings['awe_chkShowRankImagesRoster'] == 'checked') {
                     $sRosterImages = true;
                 }
                 $rank = $this->ranks->get_rankcat($this->rank);
                 /* build the blank image array */
                 $blank_img = array('src' => rank_location($this->rank, 'blank', $rank->rankcat_extension), 'alt' => '', 'class' => 'image');
                 $data['debug']['chkShowUsers'] = $chkShowUsers;
                 $depts = $this->dept->get_all_depts('asc', '');
                 if ($depts->num_rows() > 0) {
                     foreach ($depts->result() as $d) {
                         $data['characters'][$d->dept_id]['deptname'] = $d->dept_name;
                         $subdepts = $this->dept->get_sub_depts($d->dept_id);
                         if ($subdepts->num_rows() > 0) {
                             foreach ($subdepts->result() as $subd) {
                                 $data['characters'][$d->dept_id]['subdept'][$subd->dept_id]['deptname'] = $subd->dept_name;
                             }
                         }
                     }
                 }
                 $users = $this->user->get_users();
                 if ($users->num_rows() > 0) {
                     /* set the posting requirement threshold */
                     foreach ($users->result() as $p) {
                         if (empty($id)) {
                             $chkVal = 'checked';
                         } else {
                             if (empty($chkShowUsers[$p->userid])) {
                                 $chkVal = '';
                             } else {
                                 $chkVal = $chkShowUsers[$p->userid];
                             }
                         }
                         //							$chkValue = ((empty($chkShowUsers[$p->userid])) ? $chkShowUsers[$p->userid] : 'checked');
                         $data['chkRosterShowUsers'][$p->userid] = array('name' => 'chkRosterShowUsers[' . $p->userid . ']', 'id' => 'chkRosterShowUsers[' . $p->userid . ']', 'value' => 'checked', 'checked' => $chkVal);
                         $charinf = $this->char->get_character($p->main_char);
                         $posts = $this->pos->get_position($charinf->position_1);
                         $positions = $posts !== FALSE ? $posts->pos_name : '';
                         if ((int) $charinf->position_2 > 0) {
                             $positions .= " & " . $this->pos->get_position($charinf->position_2, 'pos_name');
                         }
                         $currdept = $this->dept->get_dept($posts->pos_dept);
                         $cdept = $currdept->dept_id;
                         //$this->dept->get_dept($posts->pos_dept, 'dept_id');
                         $parentDep = $currdept->dept_parent;
                         //$this->dept->get_dept($posts->pos_dept, 'dept_parent');
                         //get rank image:
                         $rankdata = $this->ranks->get_rank($charinf->rank, array('rank_name', 'rank_image'));
                         /* build the rank image array */
                         $rank_img = array('src' => rank_location($this->rank, $rankdata['rank_image'], $rank->rankcat_extension), 'alt' => $rankdata['rank_name'], 'class' => 'image');
                         if ((int) $parentDep > 0) {
                             //there is a 'parent' to the dept
                             $data['characters'][$parentDep]['subdept'][$cdept]['chars'][$p->userid] = array('id' => $p->userid, 'name' => $p->name, 'email' => $p->email, 'char_name' => $this->char->get_character_name($p->main_char, TRUE), 'position' => $positions, 'rank_img' => $rank_img, 'charid' => $p->main_char, 'loa' => $p->loa != 'active' ? '[' . strtoupper($p->loa) . ']' : '');
                             $data['department'][$p->main_char] = $cdept;
                         } else {
                             //the dept is the parent
                             $data['characters'][$cdept]['chars'][$p->userid] = array('id' => $p->userid, 'name' => $p->name, 'email' => $p->email, 'char_name' => $this->char->get_character_name($p->main_char, TRUE), 'position' => $positions, 'rank_img' => $rank_img, 'charid' => $p->main_char, 'loa' => $p->loa != 'active' ? '[' . strtoupper($p->loa) . ']' : '');
                             $data['department'][$p->main_char] = $cdept;
                         }
                         if ($p->loa == 'active') {
                             $data['radAttendance'][$p->main_char] = array('U' => array('name' => 'rAttendance[' . $p->main_char . ']', 'id' => 'rAttendance[' . $p->main_char . ']', 'value' => 'U'), 'E' => array('name' => 'rAttendance[' . $p->main_char . ']', 'id' => 'rAttendance[' . $p->main_char . ']', 'value' => 'E'), 'P' => array('name' => 'rAttendance[' . $p->main_char . ']', 'checked' => 'checked', 'id' => 'rAttendance[' . $p->main_char . ']', 'value' => 'P'));
                         } else {
                             $data['radAttendance'][$p->main_char] = array('LOA' => array('name' => 'rAttendance[' . $p->main_char . ']', 'checked' => 'checked', 'id' => 'rAttendance[' . $p->main_char . ']', 'value' => 'LOA'), 'ELOA' => array('name' => 'rAttendance[' . $p->main_char . ']', 'id' => 'rAttendance[' . $p->main_char . ']', 'value' => 'ELOA'));
                         }
                     }
                 }
                 /* sort the keys */
                 ksort($data['characters']);
             }
             //end if -- roster exists
             /* CUSTOM SECTIONS */
             //check the active sections:
             $cSections = $this->awe->get_all_userdefined_sections();
             if ($cSections->num_rows() > 0) {
                 foreach ($cSections->result() as $sec) {
                     if ($id !== FALSE) {
                         /* if there is an ID, it is a previously saved report */
                         $secVal = $customSections[$sec->section_id];
                     } else {
                         $secVal = $this->awe->get_section_default($sec->section_id);
                     }
                     /*						$secVal = (empty($customSections[$sec->section_id]) ? $customSections[$sec->section_id] : $this->awe->get_section_default($sec->section_id));*/
                     if ($this->awe->check_section_active($sec->section_id) > 0) {
                         $data['sections'][$sec->section_id]['title'] = $sec->section_title;
                         $data['sections'][$sec->section_id]['input'] = array('name' => 'sections[' . $sec->section_id . ']', 'secname' => 'sections[' . $sec->section_id . ']', 'secID' => $sec->section_id, 'id' => 'sections', 'rows' => 5, 'value' => $secVal);
                     }
                     //end if active section
                 }
                 //end foreach custom section
             }
             //end if custom sections
             //display saved reports:
             $savedReports = $this->awe->get_saved_reports('saved');
             $sReports = array();
             if ($savedReports !== FALSE) {
                 if ($savedReports->num_rows() > 0) {
                     foreach ($savedReports->result() as $row) {
                         $author_id = 0;
                         $author = $this->user->get_user($row->report_author);
                         if ($author !== FALSE) {
                             $author_id = $author->name;
                         }
                         $sel = '';
                         if ($id == $row->report_id) {
                             $sel = 'selected';
                         }
                         $sReports[$row->report_id] = array('id' => $row->report_id, 'dateStart' => strftime('n/j/Y', $row->report_date_start), 'dateEnd' => strftime('n/j/Y', $row->report_date_end), 'author' => $author_id, 'selected' => $sel);
                     }
                 }
             }
             $data['savedReports'] = $sReports;
             /** SETUP VIEW **/
             $data['header'] = 'aweSimReport: Generator';
             /* view locations */
             $currpage = 'reports_awesimreport_generator';
             $currpage_js = 'report_awesimreport_generator_js';
             break;
             /* GENERATOR */
         /* GENERATOR */
         case "sections":
             //DEAL WITH POST REQUESTS:
             if (isset($_POST['submit'])) {
                 switch ($this->uri->segment(4)) {
                     case 'add':
                         $secName = trim($this->input->post('secName', TRUE));
                         $secTitle = trim($this->input->post('secTitle', TRUE));
                         $secDefaultContent = trim($this->input->post('secDefaultContent', TRUE));
                         //make sure both aren't empty, just in case:
                         if (empty($secName)) {
                             /* set the content of the message */
                             $message = '101: There was a problem adding this section. Please try again later.';
                             $flash['status'] = 'error';
                             $flash['message'] = text_output($message);
                             /* write everything to the template */
                             $this->template->write_view('flash_message', '_base/admin/pages/flash', $flash);
                         } else {
                             //not empty
                             //check that section name doesn't exist:
                             $check = $this->awe->get_section_by_name($secName);
                             if ($check === FALSE) {
                                 //it doesn't exist. GOOD! ADD!
                                 $secName = str_replace('&', '&amp;', $secName);
                                 $secTitle = str_replace('&', '&amp;', $secTitle);
                                 $secDefaultContent = str_replace('&', '&amp;', $secDefaultContent);
                                 //if (empty($secTitle)) { $secTitle = $secName; }
                                 $insert_array = array('section_name' => $secName, 'section_title' => $secTitle, 'section_default' => $secDefaultContent, 'section_added_user' => $this->session->userdata('userid'), 'section_added_date' => time(), 'section_userdefined' => 1);
                                 /* insert the record */
                                 $insert = $this->awe->add_new_section($insert_array);
                                 if ($insert > 0) {
                                     $message = "Section added successfully.";
                                     $flash['status'] = 'success';
                                     $flash['message'] = text_output($message);
                                 } else {
                                     $message = '102: There was a problem adding the requested section. Please try again later.';
                                     $flash['status'] = 'error';
                                     $flash['message'] = text_output($message);
                                 }
                             } else {
                                 $message = sprintf(lang('flash_duplicate_key'), lang('labels_site') . ' ' . lang('labels_message'));
                                 $flash['status'] = 'error';
                                 $flash['message'] = text_output($message);
                             }
                             /* write everything to the template */
                             $this->template->write_view('flash_message', '_base/admin/pages/flash', $flash);
                         }
                         break;
                     case 'edit':
                         $secID = (int) $this->input->post('secID', TRUE);
                         $secName = trim($this->input->post('secName', TRUE));
                         $secTitle = trim($this->input->post('secTitle', TRUE));
                         $secDefaultContent = trim($this->input->post('secDefaultContent', TRUE));
                         //make sure both aren't empty, just in case:
                         if (empty($secName)) {
                             /* set the content of the message */
                             $message = 'Err 101: There was a problem adding this section. Please try again later.';
                             /*								$message .= '<br>secDefaultContent: '.$secDefaultContent;
                             								$message .= '<br>secName: '.$secName;*/
                             $flash['status'] = 'error';
                             $flash['message'] = text_output($message);
                             /* write everything to the template */
                             $this->template->write_view('flash_message', '_base/admin/pages/flash', $flash);
                         } else {
                             //not empty
                             //check that ID is valid:
                             $section = $this->awe->get_section_details($secID);
                             if ($section != false) {
                                 if ($section->num_rows() > 0) {
                                     $row = $section->row();
                                     $secName = str_replace('&', '&amp;', $secName);
                                     $secTitle = str_replace('&', '&amp;', $secTitle);
                                     $secDefaultContent = str_replace('&', '&amp;', $secDefaultContent);
                                     if (empty($secTitle)) {
                                         $secTitle = $secName;
                                     }
                                     $update_array = array('section_name' => $secName, 'section_title' => $secTitle, 'section_default' => $secDefaultContent, 'section_last_edit_user' => $this->session->userdata('userid'), 'section_last_edit_date' => time(), 'section_userdefined' => 1);
                                     /* insert the record */
                                     $insert = $this->awe->update_section($secID, $update_array);
                                     if ($insert > 0) {
                                         $message = "Section edited successfully.";
                                         $flash['status'] = 'success';
                                         $flash['message'] = text_output($message);
                                     } else {
                                         $message = 'Err 102: There was a problem editing the requested section. Please try again later.';
                                         $flash['status'] = 'error';
                                         $flash['message'] = text_output($message);
                                     }
                                 } else {
                                     $message = 'Error: This section seems to not exist anymore. If this persists, please submit a bug report.';
                                     $message .= '<br>[DEBUG] SecID: ' . $secID;
                                     $flash['status'] = 'error';
                                     $flash['message'] = text_output($message);
                                 }
                             } else {
                                 $message = 'Error: This section seems to not exist anymore. If this persists, please submit a bug report.';
                                 $message .= '<br>[DEBUG] SecID: ' . $secID;
                                 $flash['status'] = 'error';
                                 $flash['message'] = text_output($message);
                             }
                             /* write everything to the template */
                             $this->template->write_view('flash_message', '_base/admin/pages/flash', $flash);
                         }
                         break;
                     case 'sysedit':
                         $secID = (int) $this->input->post('secID', TRUE);
                         $secName = trim($this->input->post('secName', TRUE));
                         $secTitle = trim($this->input->post('secTitle', TRUE));
                         //make sure both aren't empty, just in case:
                         if (empty($secName)) {
                             /* set the content of the message */
                             $message = 'Err 201: There was a problem editing this section. Please try again later.';
                             $flash['status'] = 'error';
                             $flash['message'] = text_output($message);
                             /* write everything to the template */
                             $this->template->write_view('flash_message', '_base/admin/pages/flash', $flash);
                         } else {
                             //not empty
                             //check that ID is valid:
                             $section = $this->awe->get_section_details($secID);
                             if ($section != false) {
                                 if ($section->num_rows() > 0) {
                                     $row = $section->row();
                                     $secName = str_replace('&', '&amp;', $secName);
                                     $secDefaultContent = str_replace('&', '&amp;', $secDefaultContent);
                                     if (empty($secTitle)) {
                                         $secTitle = $secName;
                                     }
                                     $update_array = array('section_title' => $secTitle, 'section_last_edit_user' => $this->session->userdata('userid'), 'section_last_edit_date' => time());
                                     /* insert the record */
                                     $insert = $this->awe->update_section($secID, $update_array);
                                     if ($insert > 0) {
                                         $message = "Section edited successfully.";
                                         $flash['status'] = 'success';
                                         $flash['message'] = text_output($message);
                                     } else {
                                         $message = 'Err 202: There was a problem editing the requested section. Please try again later.';
                                         $flash['status'] = 'error';
                                         $flash['message'] = text_output($message);
                                     }
                                 } else {
                                     $message = 'Error: There was an error reading the fields information. If this persists, please submit a bug report.';
                                     $message .= '<br>[DEBUG] SecID: ' . $secID;
                                     $flash['status'] = 'error';
                                     $flash['message'] = text_output($message);
                                 }
                             } else {
                                 $message = 'Error: There was an error reading the fields information. If this persists, please submit a bug report.';
                                 $message .= '<br>[DEBUG] SecID: ' . $secID;
                                 $flash['status'] = 'error';
                                 $flash['message'] = text_output($message);
                             }
                             /* write everything to the template */
                             $this->template->write_view('flash_message', '_base/admin/pages/flash', $flash);
                         }
                         break;
                 }
             }
             //get sections:
             $allsections = $this->awe->get_all_sections();
             if ($allsections->num_rows() > 0) {
                 foreach ($allsections->result() as $row) {
                     $chkactive = $this->awe->check_section_active($row->section_id);
                     $data['sections'][$chkactive][$row->section_id] = array('id' => $row->section_id, 'userdefined' => $row->section_userdefined, 'name' => $row->section_name, 'title' => $row->section_title, 'default' => $row->section_default);
                 }
             }
             //get section order:
             $data['reorganize'] = $this->awe->renumber_sections_order();
             $sectionorder = $this->awe->get_section_order();
             if ($sectionorder->num_rows() > 0) {
                 foreach ($sectionorder->result() as $row) {
                     //make sure these are active sections:
                     if ($this->awe->check_section_active($row->section_id) > 0 && $this->awe->get_section_details($row->section_id) > 0) {
                         $data['sections']['order'][$row->section_order] = $row->section_id;
                     }
                     //						$data['sections']['order'][$row->section_order] = 1;
                 }
             }
             $data['inputs'] = array('txtAddSection' => array('style' => 'width:100px;', 'name' => 'txtAddSection', 'id' => 'txtAddSection', 'value' => ''), 'txtDefaultContent' => array('rows' => 5, 'cols' => 15, 'name' => 'txtDefaultContent', 'id' => 'txtDefaultContent', 'value' => ''), 'addSection' => array('type' => 'submit', 'class' => 'button-main', 'name' => 'submit', 'value' => 'addSection', 'id' => 'addSection', 'content' => ucwords('Add Section')), 'saveSections' => array('type' => 'button', 'class' => 'button-main', 'name' => 'saveSections', 'id' => 'saveSections', 'content' => ucwords('Save Order')));
             /** SETUP VIEW **/
             $data['header'] = 'aweSimReport: Custom Sections';
             /* view locations */
             $currpage = 'reports_awesimreport_sections';
             $currpage_js = 'report_awesimreport_sections_js';
             break;
             /* SECTIONS */
         /* SECTIONS */
         case "settings":
             $data['inputs'] = array('txtSimStart' => array('style' => 'width:100px;', 'name' => 'txtSimStart', 'id' => 'txtSimStart', 'value' => $aweSettings['awe_txtSimStart']), 'txtSimEnd' => array('style' => 'width:100px;', 'name' => 'txtSimEnd', 'id' => 'txtSimEnd', 'value' => $aweSettings['awe_txtSimEnd']), 'txtDateFormat' => array('style' => 'width:250px;', 'name' => 'txtDateFormat', 'id' => 'txtDateFormat', 'value' => $aweSettings['awe_txtDateFormat']), 'txtReportDuration' => array('style' => 'width:70px;', 'name' => 'txtReportDuration', 'id' => 'txtReportDuration', 'value' => $aweSettings['awe_txtReportDuration']), 'txtStatOccurences' => array('style' => 'width:70px;', 'name' => 'txtStatOccurences', 'id' => 'txtStatOccurences', 'value' => $aweSettings['awe_txtStatOccurences']), 'txtTemplateFooter' => array('rows' => '5', 'name' => 'txtTemplateFooter', 'id' => 'txtTemplateFooter', 'value' => $aweSettings['awe_txtTemplateFooter']), 'txtEmailSubject' => array('style' => 'width:400px;', 'name' => 'txtEmailSubject', 'id' => 'txtEmailSubject', 'value' => $aweSettings['awe_txtEmailSubject']), 'txtReportTitle' => array('style' => 'width:400px;', 'name' => 'txtReportTitle', 'id' => 'txtReportTitle', 'value' => $aweSettings['awe_txtReportTitle']), 'txtEmailRecipients' => array('style' => 'width:400px;', 'name' => 'txtEmailRecipients', 'id' => 'txtEmailRecipients', 'value' => $aweSettings['awe_txtEmailRecipients']), 'chkPresenceTags' => array('name' => 'chkPresenceTags', 'id' => 'chkPresenceTags', 'value' => 'checked', 'checked' => $aweSettings['awe_chkPresenceTags']), 'txtPresenceTag_Present' => array('style' => 'width:100px;', 'name' => 'txtPresenceTag_Present', 'id' => 'txtPresenceTag_Present', 'value' => $aweSettings['awe_txtPresenceTag_Present']), 'txtPresenceTag_Unexcused' => array('style' => 'width:100px;', 'name' => 'txtPresenceTag_Unexcused', 'id' => 'txtPresenceTag_Unexcused', 'value' => $aweSettings['awe_txtPresenceTag_Unexcused']), 'txtPresenceTag_Excused' => array('style' => 'width:100px;', 'name' => 'txtPresenceTag_Excused', 'id' => 'txtPresenceTag_Excused', 'value' => $aweSettings['awe_txtPresenceTag_Excused']), 'chkShowRankImagesRoster' => array('name' => 'chkShowRankImagesRoster', 'id' => 'chkShowRankImagesRoster', 'value' => 'checked', 'checked' => $aweSettings['awe_chkShowRankImagesRoster']), 'chkShowRankImagesCOC' => array('name' => 'chkShowRankImagesCOC', 'id' => 'chkShowRankImagesCOC', 'value' => 'checked', 'checked' => $aweSettings['awe_chkShowRankImagesCOC']), 'saveSettings' => array('type' => 'button', 'class' => 'button-main', 'name' => 'saveSettings', 'id' => 'saveSettings', 'content' => ucwords('Save Settings')), 'saveSettings2' => array('type' => 'button', 'class' => 'button-main', 'name' => 'saveSettings', 'id' => 'saveSettings', 'content' => ucwords('Save Settings')));
             /** SETUP VIEW **/
             $data['header'] = 'aweSimReport: Settings';
             /* view locations */
             $currpage = 'reports_awesimreport_settings';
             $currpage_js = 'report_awesimreport_settings_js';
             break;
             /* SETTINGS */
         /* SETTINGS */
         case "templates":
             /* get all templates */
             $templatelist = $this->awe->get_all_templates();
             $templates = array();
             if ($templatelist->num_rows() > 0) {
                 foreach ($templatelist->result() as $row) {
                     $isActive = 'no';
                     if ($row->template_id == $aweSettings['awe_ActiveTemplate']) {
                         $isActive = 'yes';
                     }
                     /*						$templatefolder = 'aweSimReportTemplates/'.$row->template_folder; */
                     $templates[$row->template_id] = array('id' => $row->template_id, 'name' => $row->template_name, 'author' => $row->template_author, 'author_email' => $row->template_author_email, 'author_url' => $row->template_author_url, 'version' => $row->template_version, 'created_date' => $row->template_created_date, 'description' => $row->template_description, 'imagefolder' => $row->template_imagefolder, 'active' => $isActive, 'thumbnail' => array('src' => asset_location('aweSimReportTemplates/' . $row->template_folder, 'thumbnail.png'), 'class' => 'image', 'alt' => $row->template_name, 'title' => $row->template_name, 'id' => 'templ_img'));
                 }
             }
             $data['templates'] = $templates;
             /** SETUP VIEW **/
             $data['header'] = 'aweSimReport: Templates';
             /* view locations */
             $currpage = 'reports_awesimreport_templates';
             $currpage_js = 'report_awesimreport_templates_js';
             break;
             /* TEMPLATES */
         /* TEMPLATES */
         case "archive":
             $archnum = $this->awe->count_archive();
             $pages = ceil((int) $archnum / 10);
             $pg = '1';
             $min = 0;
             $data['archnum'] = $archnum;
             if ($this->uri->segment(4, 0, TRUE) > 1) {
                 $pg = $this->uri->segment(4, 0, TRUE);
             }
             if ($pg > $pages) {
                 $pg = $pages;
             }
             $min = $pg * 10 - 10;
             $data['pg'] = $pg;
             $data['pages'] = $pages;
             $data['images']['icons']['loading'] = array('src' => img_location('loading-circle.gif', $this->skin, 'admin'), 'alt' => '', 'class' => 'image');
             //go over archive list:
             $archive = $this->awe->get_archived_reports('', $min);
             $dateFormat = $aweSettings['awe_txtDateFormat'];
             if ($archive->num_rows() > 0) {
                 foreach ($archive->result() as $item) {
                     $curruserid = $item->report_author;
                     $currchar = $this->char->get_character($curruserid);
                     $curruser = $this->user->get_user($curruserid);
                     //get the current user (reporting officer):
                     $posts = $this->pos->get_position($currchar->position_1);
                     $positions = $posts !== FALSE ? $posts->pos_name : '';
                     if ((int) $currchar->position_2 > 0) {
                         $positions .= " & " . $this->pos->get_position($currchar->position_2, 'pos_name');
                     }
                     if ($item->report_date_start <= 100 || $item->report_date_end <= 100) {
                         $dStart = '';
                         $dEnd = '';
                     } else {
                         $dStart = strftime($dateFormat, (int) $item->report_date_start);
                         $dEnd = strftime($dateFormat, (int) $item->report_date_end);
                     }
                     $data['archive'][$item->report_id] = array('id' => $item->report_id, 'date_start' => $dStart, 'date_end' => $dEnd, 'repofficer' => $this->char->get_character_name($curruserid, TRUE), 'repofficer_userid' => $item->arch_repofficer_userid, 'repofficer_charid' => $curruser->main_char, 'repofficer_position' => $positions, 'display' => $item->report_status, 'template' => $item->report_template, 'date_sent' => $item->report_date_sent);
                     $pubcheck = '';
                     if ($item->report_status == 'published') {
                         $pubcheck = 'checked';
                     }
                     $data['chkPublish'][$item->report_id] = array('name' => 'chkPublish', 'id' => 'chkPublish', 'checked' => $pubcheck, 'value' => $item->report_id);
                 }
                 //end foreach
             } else {
                 $data['archive'] = '';
             }
             //end if archive exists
             /* build the images array */
             $data['images']['icons'] = array('hidden' => array('src' => img_location('user-reject.png', $this->skin, 'admin'), 'class' => 'image', 'title' => 'Hidden (Click to make public)'), 'published' => array('src' => img_location('user-accept.png', $this->skin, 'admin'), 'class' => 'image', 'title' => 'Published (Click to make private)'), 'delete' => array('src' => img_location('minus-circle.png', $this->skin, 'admin'), 'class' => 'image', 'title' => 'Delete'));
             $data['inputs'] = array('submit' => array('type' => 'submit', 'class' => 'button-main', 'name' => 'submit', 'id' => 'submit', 'content' => ucwords('Apply All')));
             $data['currReportTemplate'] = $aweSettings['awe_ActiveTemplate'];
             /** SETUP VIEW **/
             $data['header'] = 'aweSimReport: Archive';
             /* view locations */
             $currpage = 'reports_awesimreport_archive';
             $currpage_js = 'report_awesimreport_archive_js';
             break;
             /* ARCHIVE */
         /* ARCHIVE */
         case "stats":
             $dates = array();
             $result = array();
             $sPeriod = $aweSettings['awe_txtReportDuration'];
             if (empty($sPeriod)) {
                 $sPeriod = 30;
                 //approx a month
             }
             $rawStatPeriod = $sPeriod * 86400;
             //turn into seconds
             $counter = 0;
             if ($aweSettings['awe_txtStatOccurences'] < 1) {
                 $repOccurences = 10;
             } else {
                 $repOccurences = $aweSettings['awe_txtStatOccurences'];
             }
             $endDate = now();
             while ($counter <= $repOccurences) {
                 $startDate = (int) ($endDate - $rawStatPeriod);
                 $curr_month = date('n', $endDate);
                 $result[] = $this->awe->stats_total_logcount($startDate, $endDate) + 1;
                 $dates[] = date('Mj', $endDate);
                 $endDate = $startDate - 1;
                 //next occurence start a month ago, a second earlier
                 $counter++;
             }
             $maxval = max($result);
             $newresult = array();
             foreach ($result as $sig) {
                 //turn it into percentages:
                 $newresult[] = $sig / $maxval * 100;
             }
             $data['dates'] = $dates;
             $data['result'] = $newresult;
             $halfmaxvalue = $maxval / 2;
             $imgsrc = "http://chart.apis.google.com/chart?";
             $imgsrc .= "chxl=0:|" . implode('|', $dates);
             $imgsrc .= "&chxr=0,0,0|1,0," . (int) $maxval;
             $imgsrc .= "&chxs=0,AA0033,11.5,0,lt,676767|1,676767,11.5,0,lt,676767";
             $imgsrc .= "&chxt=x,y";
             $imgsrc .= "&chbh=a,5";
             $imgsrc .= "&chs=500x400";
             $imgsrc .= "&cht=bvg";
             $imgsrc .= "&chd=t:" . implode(',', $newresult);
             $imgsrc .= "&chds=a";
             $imgsrc .= "&chdlp=b";
             $imgsrc .= "&chp=0";
             $imgsrc .= "&chg=10,10,0,9";
             $imgsrc .= "&chma=5";
             $imgsrc .= "&chtt=Total+Log+Count";
             $data['imggraph'] = array('src' => $imgsrc, 'alt' => 'Total Log Count', 'class' => 'image');
             /** SETUP VIEW **/
             $data['header'] = 'aweSimReport: Stats';
             $currpage = 'reports_awesimreport_stats';
             $currpage_js = 'report_awesimreport_stats_js';
             break;
     }
     /* END SWITCH URI SEGMENT */
     /** DISPLAY VIEW **/
     $view_loc = view_location($currpage, $this->skin, 'admin');
     $js_loc = js_location($currpage_js, $this->skin, 'admin');
     /* produce write the header */
     $this->template->write('title', $data['header']);
     /* produce view */
     $this->template->write_view('javascript', $js_loc, $js_data);
     $this->template->write_view('content', $view_loc, $data);
     /* render the template */
     $this->template->render();
 }