660 lines
25 KiB
PHP
660 lines
25 KiB
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.
|
|
*
|
|
********************************************************************************/
|
|
|
|
|
|
require_once('include/utils/UserInfoUtil.php');
|
|
require_once("include/utils/utils.php");
|
|
require_once("include/ListView/ListViewSession.php");
|
|
require_once("include/ListView/RelatedListViewSession.php");
|
|
require_once("include/DatabaseUtil.php");
|
|
|
|
if(!function_exists('GetRelatedList')) {
|
|
function GetRelatedList($module,$relatedmodule,$focus,$query,$button,$returnset,$id='',
|
|
$edit_val='',$del_val='',$skipActions=false) {
|
|
return GetRelatedListBase($module, $relatedmodule, $focus, $query, $button, $returnset, $id, $edit_val, $del_val, $skipActions);
|
|
}
|
|
}
|
|
|
|
/** Function to get related list entries in detailed array format
|
|
* @param $module -- modulename:: Type string
|
|
* @param $relatedmodule -- relatedmodule:: Type string
|
|
* @param $focus -- focus:: Type object
|
|
* @param $query -- query:: Type string
|
|
* @param $button -- buttons:: Type string
|
|
* @param $returnset -- returnset:: Type string
|
|
* @param $id -- id:: Type string
|
|
* @param $edit_val -- edit value:: Type string
|
|
* @param $del_val -- delete value:: Type string
|
|
* @returns $related_entries -- related entires:: Type string array
|
|
*
|
|
*/
|
|
|
|
function GetRelatedListBase($module,$relatedmodule,$focus,$query,$button,$returnset,$id='',$edit_val='',$del_val='',$skipActions=false)
|
|
{
|
|
$log = LoggerManager::getLogger('account_list');
|
|
$log->debug("Entering GetRelatedList(".$module.",".$relatedmodule.",".get_class($focus).",".$query.",".$button.",".$returnset.",".$edit_val.",".$del_val.") method ...");
|
|
|
|
require_once('Smarty_setup.php');
|
|
require_once("data/Tracker.php");
|
|
require_once('include/database/PearDatabase.php');
|
|
|
|
global $adb;
|
|
global $app_strings;
|
|
global $current_language;
|
|
|
|
$current_module_strings = return_module_language($current_language, $module);
|
|
|
|
global $list_max_entries_per_page;
|
|
global $urlPrefix;
|
|
|
|
|
|
global $currentModule;
|
|
global $theme;
|
|
global $theme_path;
|
|
global $theme_path;
|
|
global $mod_strings;
|
|
// focus_list is the means of passing data to a ListView.
|
|
global $focus_list;
|
|
$smarty = new vtigerCRM_Smarty;
|
|
if (!isset($where)) $where = "";
|
|
|
|
|
|
$button = '<table cellspacing=0 cellpadding=2><tr><td>'.$button.'</td></tr></table>';
|
|
|
|
// Added to have Purchase Order as form Title
|
|
$theme_path="themes/".$theme."/";
|
|
$image_path=$theme_path."images/";
|
|
$smarty->assign("MOD", $mod_strings);
|
|
$smarty->assign("APP", $app_strings);
|
|
$smarty->assign("THEME", $theme);
|
|
$smarty->assign("IMAGE_PATH",$image_path);
|
|
$smarty->assign("MODULE",$relatedmodule);
|
|
|
|
// We do not have RelatedListView in Detail View mode of Calendar module. So need to skip it.
|
|
if ($module!= 'Calendar') {
|
|
$focus->initSortByField($relatedmodule);
|
|
}
|
|
//Retreive the list from Database
|
|
//Appending the security parameter Security fix by Don
|
|
if($relatedmodule != 'Faq' && $relatedmodule != 'PriceBook'
|
|
&& $relatedmodule != 'Vendors' && $relatedmodule != 'Users') {
|
|
global $current_user;
|
|
$secQuery = getNonAdminAccessControlQuery($relatedmodule, $current_user);
|
|
if(strlen($secQuery) > 1) {
|
|
$query = appendFromClauseToQuery($query, $secQuery);
|
|
}
|
|
}
|
|
if($relatedmodule == 'Leads') {
|
|
$query .= " AND vtiger_leaddetails.converted = 0";
|
|
}
|
|
|
|
|
|
if(isset($where) && $where != '')
|
|
{
|
|
$query .= ' and '.$where;
|
|
}
|
|
|
|
if(!$_SESSION['rlvs'][$module][$relatedmodule])
|
|
{
|
|
$modObj = new ListViewSession();
|
|
$modObj->sortby = $focus->default_order_by;
|
|
$modObj->sorder = $focus->default_sort_order;
|
|
$_SESSION['rlvs'][$module][$relatedmodule] = get_object_vars($modObj);
|
|
}
|
|
|
|
if(!empty($_REQUEST['order_by'])) {
|
|
if(method_exists($focus,getSortOrder))
|
|
$sorder = $focus->getSortOrder();
|
|
if(method_exists($focus,getOrderBy))
|
|
$order_by = $focus->getOrderBy();
|
|
|
|
if(isset($order_by) && $order_by != '') {
|
|
$_SESSION['rlvs'][$module][$relatedmodule]['sorder'] = $sorder;
|
|
$_SESSION['rlvs'][$module][$relatedmodule]['sortby'] = $order_by;
|
|
}
|
|
|
|
} elseif($_SESSION['rlvs'][$module][$relatedmodule]) {
|
|
$sorder = $_SESSION['rlvs'][$module][$relatedmodule]['sorder'];
|
|
$order_by = $_SESSION['rlvs'][$module][$relatedmodule]['sortby'];
|
|
} else {
|
|
$order_by = $focus->default_order_by;
|
|
$sorder = $focus->default_sort_order;
|
|
}
|
|
|
|
//Added by Don for AssignedTo ordering issue in Related Lists
|
|
$query_order_by = $order_by;
|
|
if($order_by == 'smownerid') {
|
|
$userNameSql = getSqlForNameInDisplayFormat(array('first_name'=>'vtiger_users.first_name',
|
|
'last_name' => 'vtiger_users.last_name'), 'Users');
|
|
$query_order_by = "case when (vtiger_users.user_name not like '') then $userNameSql else vtiger_groups.groupname end ";
|
|
} elseif($order_by != 'crmid' && !empty($order_by)) {
|
|
$tabname = getTableNameForField($relatedmodule, $order_by);
|
|
if($tabname !== '' and $tabname != NULL)
|
|
$query_order_by = $tabname.".".$query_order_by;
|
|
}
|
|
if(!empty($query_order_by)){
|
|
$query .= ' ORDER BY '.$query_order_by.' '.$sorder;
|
|
}
|
|
|
|
if($relatedmodule == 'Calendar')
|
|
$mod_listquery = "activity_listquery";
|
|
else
|
|
$mod_listquery = strtolower($relatedmodule)."_listquery";
|
|
$_SESSION[$mod_listquery] = $query;
|
|
|
|
$url_qry .="&order_by=".$order_by."&sorder=".$sorder;
|
|
$computeCount = $_REQUEST['withCount'];
|
|
if(PerformancePrefs::getBoolean('LISTVIEW_COMPUTE_PAGE_COUNT', false) === true ||
|
|
(boolean) $computeCount == true){
|
|
//Retreiving the no of rows
|
|
if($relatedmodule == "Calendar") {
|
|
//for calendar related list, count will increase when we have multiple contacts
|
|
//relationship for single activity
|
|
$count_query = mkCountQuery($query);
|
|
$count_result = $adb->query($count_query);
|
|
$noofrows =$adb->query_result($count_result,0,"count");
|
|
} else {
|
|
$count_query = mkCountQuery($query);
|
|
$count_result = $adb->query($count_query);
|
|
|
|
if($adb->num_rows($count_result) > 0)
|
|
$noofrows =$adb->query_result($count_result,0,"count");
|
|
else
|
|
$noofrows = $adb->num_rows($count_result);
|
|
}
|
|
}else{
|
|
$noofrows = null;
|
|
}
|
|
|
|
//Setting Listview session object while sorting/pagination
|
|
if(isset($_REQUEST['relmodule']) && $_REQUEST['relmodule']!='' && $_REQUEST['relmodule'] == $relatedmodule)
|
|
{
|
|
$relmodule = vtlib_purify($_REQUEST['relmodule']);
|
|
if($_SESSION['rlvs'][$module][$relmodule])
|
|
{
|
|
setSessionVar($_SESSION['rlvs'][$module][$relmodule],$noofrows,$list_max_entries_per_page,$module,$relmodule);
|
|
}
|
|
}
|
|
global $relationId;
|
|
$start = RelatedListViewSession::getRequestCurrentPage($relationId, $query);
|
|
$navigation_array = VT_getSimpleNavigationValues($start, $list_max_entries_per_page,
|
|
$noofrows);
|
|
|
|
$limit_start_rec = ($start-1) * $list_max_entries_per_page;
|
|
|
|
if( $adb->dbType == "pgsql")
|
|
$list_result = $adb->pquery($query.
|
|
" OFFSET $limit_start_rec LIMIT $list_max_entries_per_page", array());
|
|
else
|
|
$list_result = $adb->pquery($query.
|
|
" LIMIT $limit_start_rec, $list_max_entries_per_page", array());
|
|
|
|
//Retreive the List View Table Header
|
|
$id = vtlib_purify($_REQUEST['record']);
|
|
$listview_header = getListViewHeader($focus,$relatedmodule,'',$sorder,$order_by,$id,'',$module,$skipActions);//"Accounts");
|
|
if ($noofrows > 15) {
|
|
$smarty->assign('SCROLLSTART','<div style="overflow:auto;height:315px;width:100%;">');
|
|
$smarty->assign('SCROLLSTOP','</div>');
|
|
}
|
|
$smarty->assign("LISTHEADER", $listview_header);
|
|
|
|
if($module == 'PriceBook' && $relatedmodule == 'Products') {
|
|
$listview_entries = getListViewEntries($focus,$relatedmodule,$list_result,$navigation_array,'relatedlist',$returnset,$edit_val,$del_val,'','','','',$skipActions);
|
|
}
|
|
if($module == 'Products' && $relatedmodule == 'PriceBook') {
|
|
$listview_entries = getListViewEntries($focus,$relatedmodule,$list_result,$navigation_array,'relatedlist',$returnset,'EditListPrice','DeletePriceBookProductRel','','','','',$skipActions);
|
|
} elseif($relatedmodule == 'SalesOrder') {
|
|
$listview_entries = getListViewEntries($focus,$relatedmodule,$list_result,$navigation_array,'relatedlist',$returnset,'SalesOrderEditView','DeleteSalesOrder','','','','',$skipActions);
|
|
}else {
|
|
$listview_entries = getListViewEntries($focus,$relatedmodule,$list_result,$navigation_array,'relatedlist',$returnset,$edit_val,$del_val,'','','','',$skipActions);
|
|
}
|
|
|
|
$navigationOutput = Array();
|
|
$navigationOutput[] = getRecordRangeMessage($list_result, $limit_start_rec,$noofrows);
|
|
if(empty($id) && !empty($_REQUEST['record'])) $id = vtlib_purify($_REQUEST['record']);
|
|
$navigationOutput[] = getRelatedTableHeaderNavigation($navigation_array, $url_qry,$module,$relatedmodule,$id);
|
|
|
|
$related_entries = array('header'=>$listview_header,'entries'=>$listview_entries,'navigation'=>$navigationOutput);
|
|
|
|
$log->debug("Exiting GetRelatedList method ...");
|
|
return $related_entries;
|
|
}
|
|
|
|
/** Function to get related list entries in detailed array format
|
|
* @param $parentmodule -- parentmodulename:: Type string
|
|
* @param $query -- query:: Type string
|
|
* @param $id -- id:: Type string
|
|
* @returns $entries_list -- entries list:: Type string array
|
|
*
|
|
*/
|
|
|
|
function getAttachmentsAndNotes($parentmodule,$query,$id,$sid='')
|
|
{
|
|
global $log;
|
|
$log->debug("Entering getAttachmentsAndNotes(".$parentmodule.",".$query.",".$id.",".$sid.") method ...");
|
|
global $theme;
|
|
|
|
$list = '<script>
|
|
function confirmdelete(url)
|
|
{
|
|
if(confirm("'.$app_strings['ARE_YOU_SURE'].'"))
|
|
{
|
|
document.location.href=url;
|
|
}
|
|
}
|
|
</script>';
|
|
|
|
$theme_path="themes/".$theme."/";
|
|
$image_path=$theme_path."images/";
|
|
|
|
global $adb,$current_user;
|
|
global $mod_strings;
|
|
global $app_strings, $listview_max_textlength;
|
|
|
|
$result=$adb->query($query);
|
|
$noofrows = $adb->num_rows($result);
|
|
|
|
$_SESSION['Documents_listquery'] = $query;
|
|
$header[] = $app_strings['LBL_TITLE'];
|
|
$header[] = $app_strings['LBL_DESCRIPTION'];
|
|
$header[] = $app_strings['LBL_ATTACHMENTS'];
|
|
$header[] = $app_strings['LBL_ASSIGNED_TO'];
|
|
$header[] = $app_strings['LBL_ACTION'];
|
|
|
|
if($result)
|
|
{
|
|
while($row = $adb->fetch_array($result))
|
|
{
|
|
if($row['activitytype'] == 'Attachments') {
|
|
$query1="select setype,createdtime from vtiger_crmentity where crmid=?";
|
|
$params1 = array($row['attachmentsid']);
|
|
} else {
|
|
$query1="select setype,createdtime from vtiger_crmentity where crmid=?";
|
|
$params1 = array($row['crmid']);
|
|
}
|
|
|
|
$query1 .=" order by createdtime desc";
|
|
$res=$adb->pquery($query1, $params1);
|
|
$num_rows = $adb->num_rows($res);
|
|
for($i=0; $i<$num_rows; $i++)
|
|
{
|
|
$setype = $adb->query_result($res,$i,'setype');
|
|
$createdtime = $adb->query_result($res,$i,'createdtime');
|
|
}
|
|
|
|
if(($setype != "Products Image") && ($setype != "Contacts Image"))
|
|
{
|
|
$entries = Array();
|
|
if(trim($row['activitytype']) == 'Documents')
|
|
{
|
|
$module = 'Documents';
|
|
$editaction = 'EditView';
|
|
$deleteaction = 'Delete';
|
|
}
|
|
elseif($row['activitytype'] == 'Attachments')
|
|
{
|
|
$module = 'uploads';
|
|
$editaction = 'upload';
|
|
$deleteaction = 'deleteattachments';
|
|
}
|
|
if($module == 'Documents')
|
|
{
|
|
$entries[] = '<a href="index.php?module='.$module.'&action=DetailView&return_module='.$parentmodule.'&return_action='.$return_action.'&record='.$row["crmid"].'&filename='.$row['filename'].'&fileid='.$row['attachmentsid'].'&return_id='.vtlib_purify($_REQUEST["record"]).'&parenttab='.vtlib_purify($_REQUEST["parenttab"]).'">'.textlength_check($row['title']).'</a>';
|
|
}
|
|
elseif($module == 'uploads')
|
|
{
|
|
$entries[] = $row['title'];
|
|
}
|
|
if((getFieldVisibilityPermission('Documents', $current_user->id, 'notecontent') == '0') || $row['activitytype'] == 'Documents')
|
|
{
|
|
$row['description'] = preg_replace("/(<\/?)(\w+)([^>]*>)/i","",$row['description']);
|
|
if($listview_max_textlength && (strlen($row['description']) > $listview_max_textlength))
|
|
{
|
|
$row['description'] = substr($row['description'],0,$listview_max_textlength).'...';
|
|
}
|
|
$entries[] = nl2br($row['description']);
|
|
}
|
|
else
|
|
$entries[] = " <font color ='red' >" .$app_strings['LBL_NOT_ACCESSIBLE']."</font>";
|
|
|
|
$attachmentname = $row['filename'];//explode('_',$row['filename'],2);
|
|
|
|
if((getFieldVisibilityPermission('Documents', $current_user->id, 'filename') == 0))
|
|
{
|
|
global $adb;
|
|
|
|
$prof_id = fetchUserProfileId($current_user->id);
|
|
$modulepermissionQuery = "select permissions from vtiger_profile2tab where tabid=8 and profileid= ?";
|
|
$modulepermissionresult = $adb->pquery($modulepermissionQuery,array($prof_id));
|
|
$moduleviewpermission = $adb->query_result($modulepermissionresult,0,'permissions');
|
|
|
|
$folderQuery = 'select folderid,filelocationtype,filestatus,filename from vtiger_notes where notesid = ?';
|
|
$folderresult = $adb->pquery($folderQuery,array($row["crmid"]));
|
|
$folder_id = $adb->query_result($folderresult,0,'folderid');
|
|
$download_type = $adb->query_result($folderresult,0,'filelocationtype');
|
|
$filestatus = $adb->query_result($folderresult,0,'filestatus');
|
|
$filename = $adb->query_result($folderresult,0,'filename');
|
|
|
|
$fileQuery = $adb->pquery("select attachmentsid from vtiger_seattachmentsrel where crmid = ?",array($row['crmid']));
|
|
$fileid = $adb->query_result($fileQuery,0,'attachmentsid');
|
|
if($moduleviewpermission == 0)
|
|
{
|
|
if($download_type == 'I' )
|
|
{
|
|
if($filestatus == 1 )
|
|
$entries[] = '<a href="index.php?module=Documents&action=DownloadFile&fileid='.$fileid.'&folderid='.$folder_id.'">'.textlength_check($attachmentname).'</a>';
|
|
elseif(isset($attachmentname) && $attachmentname != '')
|
|
$entries[] = textlength_check($attachmentname);
|
|
else
|
|
$entries[] = ' --';
|
|
}
|
|
elseif($download_type == 'E' )
|
|
{
|
|
if($filestatus == 1)
|
|
$entries[] = '<a target="_blank" href="'.$filename.'" onClick="javascript:dldCntIncrease('.$row['crmid'].');">'.textlength_check($attachmentname).'</a>';
|
|
elseif(isset($attachmentname) && $attachmentname != '')
|
|
$entries[] = textlength_check($attachmentname);
|
|
else
|
|
$entries[] = ' --';
|
|
}
|
|
else{
|
|
$entries[] = ' --';
|
|
}
|
|
}
|
|
else
|
|
{
|
|
if(isset($attachmentname))
|
|
$entries[] = textlength_check($attachmentname);
|
|
else
|
|
$entries[] = ' --';
|
|
}
|
|
}
|
|
else
|
|
$entries[]='';
|
|
|
|
$assignedToQuery = $adb->pquery('SELECT smownerid FROM vtiger_crmentity WHERE crmid = ?',array($row['crmid']));
|
|
$assignedTo = $adb->query_result($assignedToQuery,0,'smownerid');
|
|
if($assignedTo != '' ){
|
|
$entries[] = $assignedTo;
|
|
}
|
|
$del_param = 'index.php?module='.$module.'&action='.$deleteaction.'&return_module='.$parentmodule.'&return_action='.vtlib_purify($_REQUEST['action']).'&record='.$row["crmid"].'&return_id='.vtlib_purify($_REQUEST["record"]).'&parenttab='.vtlib_purify($_REQUEST["parenttab"]);
|
|
|
|
if($module == 'Documents')
|
|
{
|
|
$edit_param = 'index.php?module='.$module.'&action='.$editaction.'&return_module='.$parentmodule.'&return_action='.vtlib_purify($_REQUEST['action']).'&record='.$row["crmid"].'&filename='.$row['filename'].'&fileid='.$row['attachmentsid'].'&return_id='.vtlib_purify($_REQUEST["record"]).'&parenttab='.vtlib_purify($_REQUEST["parenttab"]);
|
|
|
|
$entries[] .= '<a href="'.$edit_param.'">'.$app_strings['LNK_EDIT'].'</a> | <a href=\'javascript:confirmdelete("'.$del_param.'")\'>'.$app_strings['LNK_DELETE'].'</a>';
|
|
}
|
|
else
|
|
{
|
|
$entries[] = '<a href=\'javascript:confirmdelete("'.$del_param.'")\'>'.$app_strings['LNK_DELETE'].'</a>';
|
|
}
|
|
$entries_list[] = $entries;
|
|
}
|
|
}
|
|
}
|
|
|
|
if($entries_list != '')
|
|
$return_data = array('header'=>$header,'entries'=>$entries_list);
|
|
$log->debug("Exiting getAttachmentsAndNotes method ...");
|
|
return $return_data;
|
|
|
|
}
|
|
|
|
/** Function to get related list entries in detailed array format
|
|
* @param $parentmodule -- parentmodulename:: Type string
|
|
* @param $query -- query:: Type string
|
|
* @param $id -- id:: Type string
|
|
* @returns $return_data -- return data:: Type string array
|
|
*
|
|
*/
|
|
|
|
function getHistory($parentmodule,$query,$id)
|
|
{
|
|
global $log;
|
|
$log->debug("Entering getHistory(".$parentmodule.",".$query.",".$id.") method ...");
|
|
$parentaction = vtlib_purify($_REQUEST['action']);
|
|
global $theme;
|
|
$theme_path="themes/".$theme."/";
|
|
$image_path=$theme_path."images/";
|
|
|
|
global $adb;
|
|
global $mod_strings;
|
|
global $app_strings;
|
|
|
|
//Appending the security parameter
|
|
global $current_user;
|
|
$rel_tab_id = getTabid("Calendar");
|
|
|
|
global $current_user;
|
|
require('user_privileges/user_privileges_'.$current_user->id.'.php');
|
|
require('user_privileges/sharing_privileges_'.$current_user->id.'.php');
|
|
$tab_id = getTabid('Calendar');
|
|
if($is_admin == false && $profileGlobalPermission[1] == 1 && $profileGlobalPermission[2] == 1 && $defaultOrgSharingPermission[$tab_id] == 3)
|
|
{
|
|
$sec_parameter=getListViewSecurityParameter('Calendar');
|
|
$query .= ' '.$sec_parameter;
|
|
}
|
|
$query.= ' '."ORDER BY vtiger_activity.date_start DESC,vtiger_activity.time_start DESC";
|
|
$result=$adb->query($query);
|
|
$noofrows = $adb->num_rows($result);
|
|
|
|
if($noofrows == 0)
|
|
{
|
|
//There is no entries for history
|
|
}
|
|
else
|
|
{
|
|
//Form the header columns
|
|
$header[] = $app_strings['LBL_TYPE'];
|
|
$header[] = $app_strings['LBL_SUBJECT'];
|
|
$header[] = $app_strings['LBL_RELATED_TO'];
|
|
$header[] = $app_strings['LBL_START_DATE']." & ".$app_strings['LBL_TIME'];
|
|
$header[] = $app_strings['LBL_END_DATE']." & ".$app_strings['LBL_TIME'];
|
|
//$header[] = $app_strings['LBL_DESCRIPTION'];
|
|
$header[] = $app_strings['LBL_STATUS'];
|
|
$header[] = $app_strings['LBL_ASSIGNED_TO'];
|
|
|
|
$i = 1;
|
|
while($row = $adb->fetch_array($result))
|
|
{
|
|
$entries = Array();
|
|
if($row['activitytype'] == 'Task')
|
|
{
|
|
$activitymode = 'Task';
|
|
$icon = 'Tasks.gif';
|
|
$status = $row['status'];
|
|
$status = $app_strings[$status];
|
|
}
|
|
else
|
|
{
|
|
$activitymode = 'Events';
|
|
$icon = 'Activities.gif';
|
|
$status = $row['eventstatus'];
|
|
$status = $app_strings[$status];
|
|
}
|
|
|
|
$typeofactivity = $row['activitytype'];
|
|
$typeofactivity = getTranslatedString($typeofactivity, 'Calendar');
|
|
$entries[] = $typeofactivity;
|
|
|
|
$activity = '<a href="index.php?module=Calendar&action=DetailView&return_module='.$parentmodule.'&return_action=DetailView&record='.$row["activityid"] .'&activity_mode='.$activitymode.'&return_id='.vtlib_purify($_REQUEST['record']).'&parenttab='.vtlib_purify($_REQUEST['parenttab']).'">'.$row['subject'].'</a></td>';
|
|
$entries[] = $activity;
|
|
|
|
$parentname = getRelatedTo('Calendar',$result,$i-1);
|
|
$entries[] = $parentname;
|
|
|
|
$date = new DateTimeField($row['date_start']." ".$row['time_start']);
|
|
$entries[] = $date->getDisplayDateTimeValue();
|
|
$date = new DateTimeField($row['due_date']." ".$row['time_end']);
|
|
$entries[] = $date->getDisplayDate();
|
|
|
|
$entries[] = $status;
|
|
|
|
if($row['user_name'] == null && $row['groupname'] != null)
|
|
{
|
|
$entries[] = $row['groupname'];
|
|
}
|
|
else
|
|
{
|
|
$entries[] = $row['user_name'];
|
|
}
|
|
|
|
$i++;
|
|
$entries_list[] = $entries;
|
|
}
|
|
|
|
$return_data = array('header'=>$header,'entries'=>$entries_list);
|
|
$log->debug("Exiting getHistory method ...");
|
|
return $return_data;
|
|
}
|
|
}
|
|
|
|
/** Function to display the Products which are related to the PriceBook
|
|
* @param string $query - query to get the list of products which are related to the current PriceBook
|
|
* @param object $focus - PriceBook object which contains all the information of the current PriceBook
|
|
* @param string $returnset - return_module, return_action and return_id which are sequenced with & to pass to the URL which is optional
|
|
* return array $return_data which will be formed like array('header'=>$header,'entries'=>$entries_list) where as $header contains all the header columns and $entries_list will contain all the Product entries
|
|
*/
|
|
function getPriceBookRelatedProducts($query,$focus,$returnset='')
|
|
{
|
|
global $log;
|
|
$log->debug("Entering getPriceBookRelatedProducts(".$query.",".get_class($focus).",".$returnset.") method ...");
|
|
|
|
global $adb;
|
|
global $app_strings;
|
|
global $mod_strings;
|
|
global $current_language,$current_user;
|
|
$current_module_strings = return_module_language($current_language, 'PriceBook');
|
|
|
|
global $list_max_entries_per_page;
|
|
global $urlPrefix;
|
|
|
|
global $theme;
|
|
$pricebook_id = vtlib_purify($_REQUEST['record']);
|
|
$theme_path="themes/".$theme."/";
|
|
$image_path=$theme_path."images/";
|
|
|
|
$computeCount = $_REQUEST['withCount'];
|
|
if(PerformancePrefs::getBoolean('LISTVIEW_COMPUTE_PAGE_COUNT', false) === true ||
|
|
((boolean) $computeCount) == true){
|
|
$noofrows = $adb->query_result($adb->query(mkCountQuery($query)),0,'count');
|
|
}else{
|
|
$noofrows = null;
|
|
}
|
|
|
|
$module = 'PriceBooks';
|
|
$relatedmodule = 'Products';
|
|
if(!$_SESSION['rlvs'][$module][$relatedmodule])
|
|
{
|
|
$modObj = new ListViewSession();
|
|
$modObj->sortby = $focus->default_order_by;
|
|
$modObj->sorder = $focus->default_sort_order;
|
|
$_SESSION['rlvs'][$module][$relatedmodule] = get_object_vars($modObj);
|
|
}
|
|
|
|
|
|
if(isset($_REQUEST['relmodule']) && $_REQUEST['relmodule']!='' && $_REQUEST['relmodule'] == $relatedmodule) {
|
|
$relmodule = vtlib_purify($_REQUEST['relmodule']);
|
|
if($_SESSION['rlvs'][$module][$relmodule]) {
|
|
setSessionVar($_SESSION['rlvs'][$module][$relmodule],$noofrows,$list_max_entries_per_page,$module,$relmodule);
|
|
}
|
|
}
|
|
global $relationId;
|
|
$start = RelatedListViewSession::getRequestCurrentPage($relationId, $query);
|
|
$navigation_array = VT_getSimpleNavigationValues($start, $list_max_entries_per_page,
|
|
$noofrows);
|
|
|
|
$limit_start_rec = ($start-1) * $list_max_entries_per_page;
|
|
|
|
if( $adb->dbType == "pgsql")
|
|
$list_result = $adb->pquery($query.
|
|
" OFFSET $limit_start_rec LIMIT $list_max_entries_per_page", array());
|
|
else
|
|
$list_result = $adb->pquery($query.
|
|
" LIMIT $limit_start_rec, $list_max_entries_per_page", array());
|
|
|
|
$header=array();
|
|
$header[]=$mod_strings['LBL_LIST_PRODUCT_NAME'];
|
|
if(getFieldVisibilityPermission('Products', $current_user->id, 'productcode') == '0')
|
|
$header[]=$mod_strings['LBL_PRODUCT_CODE'];
|
|
if(getFieldVisibilityPermission('Products', $current_user->id, 'unit_price') == '0')
|
|
$header[]=$mod_strings['LBL_PRODUCT_UNIT_PRICE'];
|
|
$header[]=$mod_strings['LBL_PB_LIST_PRICE'];
|
|
if(isPermitted("PriceBooks","EditView","") == 'yes' || isPermitted("PriceBooks","Delete","") == 'yes')
|
|
$header[]=$mod_strings['LBL_ACTION'];
|
|
|
|
$currency_id = $focus->column_fields['currency_id'];
|
|
$numRows = $adb->num_rows($list_result);
|
|
for($i=0; $i<$numRows; $i++) {
|
|
$entity_id = $adb->query_result($list_result,$i,"crmid");
|
|
$unit_price = $adb->query_result($list_result,$i,"unit_price");
|
|
if($currency_id != null) {
|
|
$prod_prices = getPricesForProducts($currency_id, array($entity_id));
|
|
$unit_price = $prod_prices[$entity_id];
|
|
}
|
|
$listprice = $adb->query_result($list_result,$i,"listprice");
|
|
$field_name=$entity_id."_listprice";
|
|
|
|
$entries = Array();
|
|
$entries[] = textlength_check($adb->query_result($list_result,$i,"productname"));
|
|
if(getFieldVisibilityPermission('Products', $current_user->id, 'productcode') == '0')
|
|
$entries[] = $adb->query_result($list_result,$i,"productcode");
|
|
if(getFieldVisibilityPermission('Products', $current_user->id, 'unit_price') == '0')
|
|
$entries[] = CurrencyField::convertToUserFormat($unit_price, null, true);
|
|
|
|
$entries[] = CurrencyField::convertToUserFormat($listprice, null, true);
|
|
$action = "";
|
|
if(isPermitted("PriceBooks","EditView","") == 'yes' && isPermitted('Products', 'EditView', $entity_id) == 'yes') {
|
|
$action .= '<img style="cursor:pointer;" src="'. vtiger_imageurl('editfield.gif', $theme).'" border="0" onClick="fnvshobj(this,\'editlistprice\'),editProductListPrice(\''.$entity_id.'\',\''.$pricebook_id.'\',\''.$listprice.'\')" alt="'.$app_strings["LBL_EDIT_BUTTON"].'" title="'.$app_strings["LBL_EDIT_BUTTON"].'"/>';
|
|
} else {
|
|
$action .= '<img src="'. vtiger_imageurl('blank.gif', $theme).'" border="0" />';
|
|
}
|
|
if(isPermitted("PriceBooks","Delete","") == 'yes' && isPermitted('Products', 'Delete', $entity_id) == 'yes') {
|
|
if($action != "")
|
|
$action .= ' | ';
|
|
$action .= '<img src="'. vtiger_imageurl('delete.gif', $theme).'" onclick="if(confirm(\''.$app_strings['ARE_YOU_SURE'].'\')) deletePriceBookProductRel('.$entity_id.','.$pricebook_id.');" alt="'.$app_strings["LBL_DELETE"].'" title="'.$app_strings["LBL_DELETE"].'" style="cursor:pointer;" border="0">';
|
|
}
|
|
if($action != "")
|
|
$entries[] = $action;
|
|
$entries_list[] = $entries;
|
|
}
|
|
$navigationOutput[] = getRecordRangeMessage($list_result, $limit_start_rec,$noofrows);
|
|
$navigationOutput[] = getRelatedTableHeaderNavigation($navigation_array, '',$module,
|
|
$relatedmodule,$focus->id);
|
|
$return_data = array('header'=>$header,'entries'=>$entries_list,'navigation'=>$navigationOutput);
|
|
|
|
$log->debug("Exiting getPriceBookRelatedProducts method ...");
|
|
return $return_data;
|
|
}
|
|
|
|
function CheckFieldPermission($fieldname,$module) {
|
|
global $current_user,$adb;
|
|
require('user_privileges/user_privileges_'.$current_user->id.'.php');
|
|
if($fieldname == '' || $module == '') {
|
|
return "false";
|
|
}
|
|
|
|
if(getFieldVisibilityPermission($module, $current_user->id, $fieldname) == '0') {
|
|
return "true";
|
|
}
|
|
return "false";
|
|
}
|
|
|
|
function CheckColumnPermission($tablename, $columnname, $module)
|
|
{
|
|
global $adb;
|
|
|
|
$res = $adb->pquery("select fieldname from vtiger_field where tablename=? and columnname=? and vtiger_field.presence in (0,2)", array($tablename, $columnname));
|
|
$fieldname = $adb->query_result($res, 0, 'fieldname');
|
|
return CheckFieldPermission($fieldname, $module);
|
|
}
|
|
?>
|