sorder = $sorder; $modObj->sortby = $order_by; $_SESSION['lvs'][$currentModule] = get_object_vars($modObj); } //<<<>>>>>> $oCustomView = new CustomView("Documents"); $viewid = $oCustomView->getViewId($currentModule); $customviewcombo_html = $oCustomView->getCustomViewCombo($viewid); $viewnamedesc = $oCustomView->getCustomViewByCvid($viewid); //<<<<>>>> if (!isset($where)) $where = ""; $url_string = ''; // assigning http url string $focus = new Documents(); // Initialize sort by fields $focus->initSortbyField('Documents'); // END $smarty = new vtigerCRM_Smarty; $other_text = Array(); if($_REQUEST['errormsg'] != '') { $errormsg = vtlib_purify($_REQUEST['errormsg']); $smarty->assign("ERROR","The User does not have permission to delete ".$errormsg." ".$currentModule); }else { $smarty->assign("ERROR",""); } if(ListViewSession::hasViewChanged($currentModule,$viewid)) { $_SESSION['NOTES_ORDER_BY'] = ''; } //<<<<<<<<<<<<<<<<<<< sorting - stored in session >>>>>>>>>>>>>>>>>>>> $sorder = $focus->getSortOrder(); $order_by = $focus->getOrderBy(); if(empty($_REQUEST['folderid'])) { $_SESSION['NOTES_ORDER_BY'] = $order_by; $_SESSION['NOTES_SORT_ORDER'] = $sorder; } //<<<<<<<<<<<<<<<<<<< sorting - stored in session >>>>>>>>>>>>>>>>>>>> if(isPermitted('Documents','Delete','') == 'yes') { $smarty->assign("MASS_DELETE","yes"); $other_text['del'] = $app_strings['LBL_MASS_DELETE']; } if($viewnamedesc['viewname'] == 'All') { $smarty->assign("ALL", 'All'); } //Added to handle approving or denying status-public by the admin in CustomView $statusdetails = $oCustomView->isPermittedChangeStatus($viewnamedesc['status']); $smarty->assign("CUSTOMVIEW_PERMISSION",$statusdetails); //To check if a user is able to edit/delete a customview $edit_permit = $oCustomView->isPermittedCustomView($viewid,'EditView',$currentModule); $delete_permit = $oCustomView->isPermittedCustomView($viewid,'Delete',$currentModule); $smarty->assign("CV_EDIT_PERMIT",$edit_permit); $smarty->assign("CV_DELETE_PERMIT",$delete_permit); $theme_path="themes/".$theme."/"; $image_path=$theme_path."images/"; $smarty->assign("CUSTOMVIEW_OPTION",$customviewcombo_html); $smarty->assign("VIEWID", $viewid); $smarty->assign("MOD", $mod_strings); $smarty->assign("APP", $app_strings); $smarty->assign("THEME", $theme); $smarty->assign("IMAGE_PATH",$image_path); $smarty->assign("MODULE",$currentModule); $smarty->assign("SINGLE_MOD",getTranslatedString('SINGLE_'.$currentModule, $currentModule)); $smarty->assign("BUTTONS",$other_text); $smarty->assign("CATEGORY",$category); $smarty->assign('MAX_RECORDS', $list_max_entries_per_page); //Retreive the list from Database //<<<<<<<<>>>>>>>> global $current_user; $queryGenerator = new QueryGenerator($currentModule, $current_user); if ($viewid != "0") { $queryGenerator->initForCustomViewById($viewid); } else { $queryGenerator->initForDefaultCustomView(); } //<<<<<<<>>>>>>>> $hide_empty_folders = 'no'; // Enabling Module Search $url_string = ''; if($_REQUEST['query'] == 'true') { $queryGenerator->addUserSearchConditions($_REQUEST); $ustring = getSearchURL($_REQUEST); $url_string .= "&query=true$ustring"; $smarty->assign('SEARCH_URL', $url_string); } $query = $queryGenerator->getQuery(); $where = $queryGenerator->getConditionalWhere(); if(isset($where) && $where != '') { $_SESSION['export_where'] = $where; } else { unset($_SESSION['export_where']); } $focus->query = $query; if($viewid ==0) { echo "
"; echo "
$app_strings[LBL_PERMISSION]
$app_strings[LBL_GO_BACK]
"; echo "
"; exit; } //Retreive the List View Table Header if($viewid !='') $url_string .="&viewname=".$viewid; $controller = new ListViewController($adb, $current_user, $queryGenerator); $listview_header_search = $controller->getBasicSearchFieldInfoList(); $smarty->assign("SEARCHLISTHEADER",$listview_header_search); $smarty->assign("SELECT_SCRIPT", $view_script); $start = Array(); $request_folderid = ''; if($_REQUEST['action'] == 'DocumentsAjax' && isset($_REQUEST['folderid'])) { $request_folderid = vtlib_purify($_REQUEST['folderid']); $start[$request_folderid] = vtlib_purify($_REQUEST['start']); } $focus->del_create_def_folder($focus->query); $dbQuery = "select * from vtiger_attachmentsfolder"; $result = $adb->pquery($dbQuery,array()); $foldercount = $adb->num_rows($result); $folders = Array(); $emptyfolders = Array(); if($foldercount > 0 ) { for($i=0;$i<$foldercount;$i++) { $query = ''; $displayFolder=''; $query = $focus->query; $list_query = ''; $list_query = $focus->query; $folder_id = $adb->query_result($result,$i,"folderid"); $query .= " and vtiger_notes.folderid = $folder_id"; $sorder = $focus->getSortOrderForFolder($folder_id); if(!is_array($_SESSION['NOTES_FOLDER_SORT_ORDER'])) { $_SESSION['NOTES_FOLDER_SORT_ORDER'] = array(); } $_SESSION['NOTES_FOLDER_SORT_ORDER'][$folder_id] = $sorder; $order_by = $focus->getOrderByForFolder($folder_id); if(!is_array($_SESSION['NOTES_FOLDER_ORDER_BY'])) { $_SESSION['NOTES_FOLDER_ORDER_BY'] = array(); } $_SESSION['NOTES_FOLDER_ORDER_BY'][$folder_id] = $order_by; if($folder_id != $request_folderid) { $start[$folder_id] = 1; } if(isset($order_by) && $order_by != '') { $tablename = getTableNameForField('Documents',$order_by); $tablename = (($tablename != '')?($tablename."."):''); if( $adb->dbType == "pgsql") { $query .= ' GROUP BY '.$tablename.$order_by; $list_query .= ' GROUP BY '.$tablename.$order_by; $focus->additional_query .= ' GROUP BY '.$tablename.$order_by; } $query .= ' ORDER BY '.$tablename.$order_by.' '.$sorder; $list_query .= ' ORDER BY '.$tablename.$order_by.' '.$sorder; $focus->additional_query .= ' ORDER BY '.$tablename.$order_by.' '.$sorder; } //Retreiving the no of rows $count_result = $adb->query( mkCountQuery( $query)); $num_records = $adb->query_result($count_result,0,"count"); if($num_records > 0){ $displayFolder=true; } //navigation start $max_entries_per_page = $list_max_entries_per_page; //Postgres 8 fixes if( $adb->dbType == "pgsql") $list_query = fixPostgresQuery( $query, $log, 0); if($folder_id == $request_folderid){ $start[$folder_id] = 1; if(!empty($_REQUEST['start'])){ $start[$folder_id] = ListViewSession::getRequestStartPage(); if($start[$folder_id] == 'last'){ if($num_records > 0){ $start[$folder_id] = ceil($num_records/$max_entries_per_page); } } if(!is_numeric($start[$folder_id])){ $start[$folder_id] = 1; } } } $navigation_array = VT_getSimpleNavigationValues($start[$folder_id],$max_entries_per_page,$num_records); if($folder_id == $request_folderid){ if(!is_array($_SESSION['lvs'][$currentModule]['start'])){ $_SESSION['lvs'][$currentModule]['start'] = array(); } $_SESSION['lvs'][$currentModule]['start'][$folder_id] = $start[$folder_id]; } $limit_start_rec = ($start[$folder_id]-1) * $max_entries_per_page; if( $adb->dbType == "pgsql") $list_result = $adb->pquery($query. " OFFSET $limit_start_rec LIMIT $max_entries_per_page", array()); else $list_result = $adb->pquery($query. " LIMIT $limit_start_rec, $max_entries_per_page", array()); //navigation end $folder_details=Array(); $folderid = $adb->query_result($result,$i,"folderid"); $folder_details['folderid']=$folderid; $folder_details['foldername']=$adb->query_result($result,$i,"foldername"); $foldername = $folder_details['foldername']; $folder_details['description']=$adb->query_result($result,$i,"description"); $folder_url_string = $url_string . "&folderid=$folderid"; $folder_details['header'] = $controller->getListViewHeader($focus,$currentModule, $folder_url_string,$sorder, $order_by); $folder_files = $controller->getListViewEntries($focus,$currentModule,$list_result, $navigation_array); $folder_details['entries']= $folder_files; $folder_details['navigation'] = getTableHeaderSimpleNavigation($navigation_array, $url_string,"Documents",$folder_id,$viewid); $folder_details['recordListRange'] = getRecordRangeMessage($list_result, $limit_start_rec, $num_records); if ($displayFolder == true) { $folders[$foldername] = $folder_details; } else{ $emptyfolders[$foldername] = $folder_details; } if ($folderid == 1) $default_folder_details = $folder_details; } if (count($folders) == 0) $folders[$default_folder_details['foldername']] = $default_folder_details; } else { $smarty->assign("NO_FOLDERS","yes"); } $smarty->assign("NO_OF_FOLDERS",$foldercount); $smarty->assign("FOLDERS", $folders); $smarty->assign("EMPTY_FOLDERS", $emptyfolders); $smarty->assign("ALL_FOLDERS", array_merge($folders, $emptyfolders)); //Added to select Multiple records in multiple pages $smarty->assign("SELECTEDIDS", vtlib_purify($_REQUEST['selobjs'])); $smarty->assign("ALLSELECTEDIDS", vtlib_purify($_REQUEST['allselobjs'])); $alphabetical = AlphabeticalSearch($currentModule,'index','notes_title','true','basic',"","","","",$viewid); $fieldnames = $controller->getAdvancedSearchOptionString(); $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); $adminuser = is_admin($current_user); $smarty->assign("IS_ADMIN",$adminuser); $check_button = Button_Check($module); $smarty->assign("CHECK", $check_button); ListViewSession::setSessionQuery($currentModule,$focus->query,$viewid); // Gather the custom link information to display include_once('vtlib/Vtiger/Link.php'); $customlink_params = Array('MODULE'=>$currentModule, 'ACTION'=>vtlib_purify($_REQUEST['action']), 'CATEGORY'=> $category); $smarty->assign('CUSTOM_LINKS', Vtiger_Link::getAllByType(getTabid($currentModule), Array('LISTVIEWBASIC','LISTVIEW'), $customlink_params)); // END if(isset($_REQUEST['ajax']) && $_REQUEST['ajax'] != '' || $_REQUEST['mode'] == 'ajax') $smarty->display("DocumentsListViewEntries.tpl"); else $smarty->display("DocumentsListView.tpl"); ?>