0byt3m1n1
Path:
/
data
/
applications
/
aps.bak
/
vtiger
/
5.0.4
/
standard
/
htdocs
/
modules
/
HelpDesk
/
[
Home
]
File: ListView.php
<?php /********************************************************************************* ** The contents of this file are subject to the vtiger CRM Public License Version 1.0 * ("License"); You may not use this file except in compliance with the License * The Original Code is: vtiger CRM Open Source * The Initial Developer of the Original Code is vtiger. * Portions created by vtiger are Copyright (C) vtiger. * All Rights Reserved. * ********************************************************************************/ global $theme; $theme_path="themes/".$theme."/"; $image_path=$theme_path."images/"; require_once('modules/HelpDesk/HelpDesk.php'); require_once('include/database/PearDatabase.php'); require_once('Smarty_setup.php'); require_once("data/Tracker.php"); require_once('include/logging.php'); require_once('include/ListView/ListView.php'); require_once('include/ComboUtil.php'); require_once('include/utils/utils.php'); require_once('modules/CustomView/CustomView.php'); require_once('include/database/Postgres8.php'); require_once('include/DatabaseUtil.php'); global $app_strings; global $mod_strings; global $currentModule; $focus = new HelpDesk(); $smarty = new vtigerCRM_Smarty; $category = getParentTab(); $other_text = Array(); if(!$_SESSION['lvs'][$currentModule]) { unset($_SESSION['lvs']); $modObj = new ListViewSession(); $modObj->sorder = $sorder; $modObj->sortby = $order_by; $_SESSION['lvs'][$currentModule] = get_object_vars($modObj); } if($_REQUEST['errormsg'] != '') { $errormsg = $_REQUEST['errormsg']; $smarty->assign("ERROR","The User does not have permission to Change/Delete ".$errormsg." ".$currentModule); }else { $smarty->assign("ERROR",""); } $url_string = ''; // assigning http url string //<<<<<<<<<<<<<<<<<<< sorting - stored in session >>>>>>>>>>>>>>>>>>>> $sorder = $focus->getSortOrder(); $order_by = $focus->getOrderBy(); $_SESSION['HELPDESK_ORDER_BY'] = $order_by; $_SESSION['HELPDESK_SORT_ORDER'] = $sorder; //<<<<<<<<<<<<<<<<<<< sorting - stored in session >>>>>>>>>>>>>>>>>>>> if(isset($_REQUEST['query']) && $_REQUEST['query'] == 'true') { list($where, $ustring) = split("#@@#",getWhereCondition($currentModule)); // we have a query $url_string .="&query=true".$ustring; $log->info("Here is the where clause for the list view: $where"); $smarty->assign("SEARCH_URL",$url_string); } //<<<<cutomview>>>>>>> $oCustomView = new CustomView("HelpDesk"); $viewid = $oCustomView->getViewId($currentModule); $customviewcombo_html = $oCustomView->getCustomViewCombo($viewid); $viewnamedesc = $oCustomView->getCustomViewByCvid($viewid); //<<<<<customview>>>>> $smarty->assign("CHANGE_OWNER",getUserslist()); $smarty->assign("CHANGE_GROUP_OWNER",getGroupslist()); if($viewid != 0) { $CActionDtls = $oCustomView->getCustomActionDetails($viewid); } // Buttons and View options if(isPermitted('HelpDesk','Delete','') == 'yes') $other_text['del'] = $app_strings[LBL_MASS_DELETE]; if(isPermitted('HelpDesk','EditView','') == 'yes') { $other_text['c_owner'] = $app_strings[LBL_CHANGE_OWNER]; } if($viewnamedesc['viewname'] == 'All') { $smarty->assign("ALL", 'All'); } $smarty->assign("CUSTOMVIEW_OPTION",$customviewcombo_html); $smarty->assign("VIEWID", $viewid); $smarty->assign("MOD", $mod_strings); $smarty->assign("APP", $app_strings); $smarty->assign("IMAGE_PATH",$image_path); $smarty->assign("MODULE",$currentModule); $smarty->assign("BUTTONS",$other_text); $smarty->assign("CATEGORY",$category); $smarty->assign("SINGLE_MOD",'HelpDesk'); //Retreive the list from Database //<<<<<<<<<customview>>>>>>>>> if($viewid != "0") { $listquery = getListQuery("HelpDesk"); $list_query = $oCustomView->getModifiedCvListQuery($viewid,$listquery,"HelpDesk"); } else { $list_query = getListQuery("HelpDesk"); } //<<<<<<<<customview>>>>>>>>> if(isset($where) && $where != '') { if(isset($_REQUEST['from_homepagedb']) && $_REQUEST['from_homepagedb'] == 'true') $list_query .= ' and (vtiger_troubletickets.status!="Closed" or vtiger_troubletickets.status is null) and '.$where; $list_query .= ' and '.$where; $_SESSION['export_where'] = $where; } else unset($_SESSION['export_where']); //sort by "assignedto" and default sort by "ticketid"(DESC) if(isset($order_by) && $order_by != '') { if($order_by == 'smownerid') { if( $adb->dbType == "pgsql") $list_query .= ' GROUP BY vtiger_users.user_name'; $list_query .= " ORDER BY case when (vtiger_users.user_name not like '') then vtiger_users.user_name else vtiger_groups.groupname end ".$sorder; } else { $tablename = getTableNameForField('HelpDesk',$order_by); $tablename = (($tablename != '')?($tablename."."):''); if( $adb->dbType == "pgsql") $list_query .= ' GROUP BY '.$tablename.$order_by; $list_query .= ' ORDER BY '.$tablename.$order_by.' '.$sorder; } } else { if( $adb->dbType == "pgsql") $list_query .= ' GROUP BY vtiger_troubletickets.ticketid'; $list_query .= ' ORDER BY vtiger_troubletickets.ticketid DESC'; } //Constructing the list view //Retreiving the no of rows $count_result = $adb->query( mkCountQuery( $list_query)); $noofrows = $adb->query_result($count_result,0,"count"); //Storing Listview session object if($_SESSION['lvs'][$currentModule]) { setSessionVar($_SESSION['lvs'][$currentModule],$noofrows,$list_max_entries_per_page); } //added for 4600 if($noofrows <= $list_max_entries_per_page) $_SESSION['lvs'][$currentModule]['start'] = 1; //ends $start = $_SESSION['lvs'][$currentModule]['start']; //Retreive the Navigation array $navigation_array = getNavigationValues($start, $noofrows, $list_max_entries_per_page); //Postgres 8 fixes if( $adb->dbType == "pgsql") $list_query = fixPostgresQuery( $list_query, $log, 0); // Setting the record count string //modified by rdhital $start_rec = $navigation_array['start']; $end_rec = $navigation_array['end_val']; //By Raju Ends //By Pavani $_SESSION['nav_start']=$start_rec; $_SESSION['nav_end']=$end_rec; //limiting the query if ($start_rec ==0) $limit_start_rec = 0; else $limit_start_rec = $start_rec -1; if( $adb->dbType == "pgsql") $list_result = $adb->query($list_query. " OFFSET $limit_start_rec LIMIT $list_max_entries_per_page", array()); else $list_result = $adb->query($list_query. " LIMIT $limit_start_rec, $list_max_entries_per_page", array()); //mass merge for word templates -- *Raj*17/11 while($row = $adb->fetch_array($list_result)) { $ids[] = $row["crmid"]; } if(isset($ids)) { $smarty->assign("ALLIDS", implode($ids,";")); } if(isPermitted("HelpDesk","Merge") == 'yes') { $wordTemplateResult = fetchWordTemplateList("HelpDesk"); $tempCount = $adb->num_rows($wordTemplateResult); $tempVal = $adb->fetch_array($wordTemplateResult); for($templateCount=0;$templateCount<$tempCount;$templateCount++) { $optionString .="<option value=\"".$tempVal["templateid"]."\">" .$tempVal["filename"] ."</option>"; $tempVal = $adb->fetch_array($wordTemplateResult); } if($tempCount > 0) { $smarty->assign("WORDTEMPLATEOPTIONS","<td>".$app_strings['LBL_SELECT_TEMPLATE_TO_MAIL_MERGE']."</td><td style=\"padding-left:5px;padding-right:5px\"><select class=\"small\" name=\"mergefile\">".$optionString."</select></td>"); $smarty->assign("MERGEBUTTON","<td><input title=\"$app_strings[LBL_MERGE_BUTTON_TITLE]\" accessKey=\"$app_strings[LBL_MERGE_BUTTON_KEY]\" class=\"crmbutton small create\" onclick=\"return massMerge('HelpDesk')\" type=\"submit\" name=\"Merge\" value=\" $app_strings[LBL_MERGE_BUTTON_LABEL]\"></td>"); } else { global $current_user; require("user_privileges/user_privileges_".$current_user->id.".php"); if($is_admin == true) { $smarty->assign("MERGEBUTTON",'<td><a href=index.php?module=Settings&action=upload&tempModule='.$currentModule.'&parenttab=Settings>'. $app_strings["LBL_CREATE_MERGE_TEMPLATE"].'</td>'); } } } //mass merge for word templates $record_string= $app_strings[LBL_SHOWING]." " .$start_rec." - ".$end_rec." " .$app_strings[LBL_LIST_OF] ." ".$noofrows; //Retreive the List View Table Header if($viewid !='') $url_string .="&viewname=".$viewid; $listview_header = getListViewHeader($focus,"HelpDesk",$url_string,$sorder,$order_by,"",$oCustomView); $smarty->assign("LISTHEADER", $listview_header); $listview_header_search = getSearchListHeaderValues($focus,"HelpDesk",$url_string,$sorder,$order_by,"",$oCustomView); $smarty->assign("SEARCHLISTHEADER",$listview_header_search); $listview_entries = getListViewEntries($focus,"HelpDesk",$list_result,$navigation_array,"","","EditView","Delete",$oCustomView); $smarty->assign("LISTENTITY", $listview_entries); $smarty->assign("SELECT_SCRIPT", $view_script); //Added to select Multiple records in multiple pages $smarty->assign("SELECTEDIDS", $_REQUEST['selobjs']); $smarty->assign("ALLSELECTEDIDS", $_REQUEST['allselobjs']); $smarty->assign("CURRENT_PAGE_BOXES", implode(array_keys($listview_entries),";")); $navigationOutput = getTableHeaderNavigation($navigation_array, $url_string,"HelpDesk","index",$viewid); $alphabetical = AlphabeticalSearch($currentModule,'index','ticket_title','true','basic',"","","","",$viewid); $fieldnames = getAdvSearchfields($module); $criteria = getcriteria_options(); $smarty->assign("CRITERIA", $criteria); $smarty->assign("FIELDNAMES", $fieldnames); $smarty->assign("ALPHABETICAL", $alphabetical); $smarty->assign("NAVIGATION", $navigationOutput); $smarty->assign("RECORD_COUNTS", $record_string); $check_button = Button_Check($module); $smarty->assign("CHECK", $check_button); if(isset($_REQUEST['ajax']) && $_REQUEST['ajax'] != '') $smarty->display("ListViewEntries.tpl"); else $smarty->display("ListView.tpl"); ?>