Files
CRM/modules/Vtiger/views/Popup.php
BACHIR SOULDI 2794e62571 first commit
2025-09-28 08:49:37 +01:00

558 lines
21 KiB
PHP

<?php
/*+**********************************************************************************
* The contents of this file are subject to the vtiger CRM Public License Version 1.1
* ("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 'SUtiles.php';
class Vtiger_Popup_View extends Vtiger_Footer_View {
protected $listViewEntries = false;
protected $listViewHeaders = false;
protected $isVMPharma = true;
function checkPermission(Vtiger_Request $request) {
$moduleName = $request->getModule();
$moduleModel = Vtiger_Module_Model::getInstance($moduleName);
$currentUser = Users_Record_Model::getCurrentUserModel();
$roleid = $currentUser->get('roleid');
$currentUserPrivilegesModel = Users_Privileges_Model::getCurrentUserPrivilegesModel();
if(!$currentUserPrivilegesModel->hasModulePermission($moduleModel->getId()) && ($moduleName = "Accounts" && isResponsable($roleid)) && ($moduleName != 'Users')) {
throw new AppException(vtranslate($moduleName, $moduleName).' '.vtranslate('LBL_NOT_ACCESSIBLE'));
}
}
/**
* Function returns the module name for which the popup should be initialized
* @param Vtiger_request $request
* @return <String>
*/
function getModule(Vtiger_request $request) {
$moduleName = $request->getModule();
return $moduleName;
}
function process (Vtiger_Request $request) {
$viewer = $this->getViewer ($request);
$moduleName = $this->getModule($request);
$companyDetails = Vtiger_CompanyDetails_Model::getInstanceById();
$companyLogo = $companyDetails->getLogo();
$this->initializeListViewContents($request, $viewer);
$viewer->assign('COMPANY_LOGO',$companyLogo);
$viewer->view('Popup.tpl', $moduleName);
}
function postProcess(Vtiger_Request $request) {
$viewer = $this->getViewer ($request);
$moduleName = $this->getModule($request);
$viewer->view('PopupFooter.tpl', $moduleName);
}
/**
* Function to get the list of Script models to be included
* @param Vtiger_Request $request
* @return <Array> - List of Vtiger_JsScript_Model instances
*/
function getHeaderScripts(Vtiger_Request $request) {
$headerScriptInstances = parent::getHeaderScripts($request);
$moduleName = $request->getModule();
$jsFileNames = array(
'libraries.bootstrap.js.eternicode-bootstrap-datepicker.js.bootstrap-datepicker',
'~libraries/bootstrap/js/eternicode-bootstrap-datepicker/js/locales/bootstrap-datepicker.'.Vtiger_Language_Handler::getShortLanguageName().'.js',
'~libraries/jquery/timepicker/jquery.timepicker.min.js',
'modules.Vtiger.resources.Popup',
"modules.$moduleName.resources.Popup",
'modules.Vtiger.resources.BaseList',
"modules.$moduleName.resources.BaseList",
'libraries.jquery.jquery_windowmsg',
'modules.Vtiger.resources.validator.BaseValidator',
'modules.Vtiger.resources.validator.FieldValidator',
"modules.$moduleName.resources.validator.FieldValidator"
);
$jsScriptInstances = $this->checkAndConvertJsScripts($jsFileNames);
$headerScriptInstances = array_merge($headerScriptInstances, $jsScriptInstances);
return $headerScriptInstances;
}
private function customsearch($search_params, $moduleName) {
$searchParams = $search_params;
$currentUser = Users_Record_Model::getCurrentUserModel();
$roleid = $currentUser->get('roleid');
if($roleid != 'H2') {
$userid = $currentUser->get('id');
$username = $currentUser->get('first_name').' '.$currentUser->get('last_name');
$ville = $currentUser->get('address_city');
$state = $currentUser->get('address_country');
if($moduleName == 'Accounts') {
if(isByWilaya($currentUser->get('id'))) {
if(empty($searchParams)) {
$lieu = $currentUser->get('secteur1_id').','.$currentUser->get('secteur2_id').','.$currentUser->get('secteur3_id').','.$currentUser->get('secteur4_id');
$searchParams = [[["industry","c","Pharmacie"], ["cf_992","c",$lieu]]];
}
} else
if (isMedecin($roleid) || isPharma($roleid)) {
if(empty($searchParams)) {
$fullname = $username;
$sub = getSubordinateRoleAndUsers($roleid);
foreach($sub as $roleid=>$userids) {
foreach($userids as $roleid2=>$userids2) {
$fullname = $fullname.",".$userids2;
}
}
if($this->isVMPharma)
$searchParams = [[["assigned_user_id","c",$fullname], ["vm2_id","c",$fullname], ["industry","c","Pharmacie"]]];
else
$searchParams = [[["assigned_user_id","c",$fullname], ["vm2_id","c",$fullname], ["vm3_id","c",$fullname]]];
}
} else if(isGro($roleid)) {
if(empty($searchParams)) {
if(!empty($ville) || !empty($state))
$searchParams = [[["cf_990","c",$ville.",".$state]]];
else
$searchParams = [[["industry","c","Grossiste"]]];
}
}
}
}
return $searchParams;
}
private function correctTransformedSearch($transformed_searchParams) {
$transformedSearchParams = $transformed_searchParams;
$currentUser = Users_Record_Model::getCurrentUserModel();
$roleid = $currentUser->get('roleid');
if (isMedecin($roleid) || isPharma($roleid)) {
$userid = $currentUser->get('id');
$username = $currentUser->get('first_name').' '.$currentUser->get('last_name');
if(isByWilaya($currentUser->get('id'))) {
return $transformedSearchParams;
}
$fullname = $username;
$sub = getSubordinateRoleAndUsers($roleid);
foreach($sub as $roleid=>$userids) {
foreach($userids as $roleid2=>$userids2) {
$fullname = $fullname.",".$userids2;
}
}
$groupColumnsInfoAssign = array();
$groupColumnsInfoAssign['columnname'] = "vtiger_crmentity:smownerid:assigned_user_id:Accounts_Assigned_To:V";
$groupColumnsInfoAssign['comparator'] = "c";
$groupColumnsInfoAssign['value'] = $fullname;
$groupColumnsInfoAssign['column_condition'] = "or";
//visibility on pharmacies
if($this->isVMPharma) {
if($transformedSearchParams[0]['columns'][0]['columnname'] == 'vtiger_account:industry:industry:Accounts_industry:V' || $transformedSearchParams[0]['columns'][0]['columnname'] == 'vtiger_account:industry:industry:Accounts_industry:V') {
//if($transformedSearchParams[0]['columns'][1]['columnname'] == "vtiger_crmentity:smownerid:assigned_user_id:Accounts_Assigned_To:V") {
$temptransf = $transformedSearchParams[0]['columns'][1];
$transformedSearchParams[0]['columns'][1] = $transformedSearchParams[0]['columns'][0];
$transformedSearchParams[0]['columns'][0] = $temptransf;
//}
}
}
if(count($transformedSearchParams[0]['columns']) == 2) {
array_unshift($transformedSearchParams[0]['columns'], $groupColumnsInfoAssign);
}
if(count($transformedSearchParams[0]['columns']) >= 3) {
if($transformedSearchParams[0]['columns'][0]['columnname'] == "vtiger_crmentity:smownerid:assigned_user_id:Accounts_Assigned_To:V") {
$transformedSearchParams[0]['columns'][0]['column_condition'] = 'or';
$transformedSearchParams[0]['columns'][1]['column_condition'] = 'or';
if($transformedSearchParams[0]['columns'][1]['columnname'] == 'vtiger_account:vm2_id:vm2_id:Accounts_Visiteur_Medical_2:V')
$transformedSearchParams[0]['columns'][1]['columnname'] = 'vtiger_account:vm2_id:vm2_id:Accounts_VM2:V';
if($this->isVMPharma) {
if($transformedSearchParams[0]['columns'][2]['columnname'] == 'vtiger_account:industry:Accounts_industry:industry:V')
$transformedSearchParams[0]['columns'][2]['columnname'] = 'vtiger_account:industry:industry:Accounts_industry:V';
} else {
if($transformedSearchParams[0]['columns'][2]['columnname'] == 'vtiger_account:vm3_id:vm3_id:Accounts_Visiteur_Medical_3:V')
$transformedSearchParams[0]['columns'][2]['columnname'] = 'vtiger_account:vm3_id:vm3_id:Accounts_VM3:V';
}
unset($transformedSearchParams[0]['columns'][2]['column_condition']);
}else {
$tempSP = $transformedSearchParams[0]['columns'][0];
$newArray = array();
for($i = 0; $i < 3; $i++) {
if($i == 0) {
$newArray[] = $tempSP;
$newArray[] = $groupColumnsInfoAssign;
} else if($i == 1) {
$newArray[] = $tempSP;
$groupColumnsInfoVM2 = array();
$groupColumnsInfoVM2['columnname'] = "vtiger_account:vm2_id:vm2_id:Accounts_VM2:V";
$groupColumnsInfoVM2['comparator'] = "c";
$groupColumnsInfoVM2['value'] = $fullname;
$groupColumnsInfoVM2['column_condition'] = "or";
$newArray[] = $groupColumnsInfoVM2;
} else {
$newArray[] = $tempSP;
$groupColumnsInfoVM3 = array();
if($this->isVMPharma)
$groupColumnsInfoVM3['columnname'] = "vtiger_account:industry:industry:Accounts_industry:V";
else
$groupColumnsInfoVM3['columnname'] = "vtiger_account:vm3_id:vm3_id:Accounts_VM3:V";
$groupColumnsInfoVM3['comparator'] = "c";
if($this->isVMPharma)
$groupColumnsInfoVM3['value'] = "Pharmacie";
else
$groupColumnsInfoVM3['value'] = $fullname;
//$groupColumnsInfoVM3['column_condition'] = "or";
$newArray[] = $groupColumnsInfoVM3;
}
}
$transformedSearchParams[0]['columns'] = $newArray;
}
}
}
return $transformedSearchParams;
}
/*
* Function to initialize the required data in smarty to display the List View Contents
*/
public function initializeListViewContents(Vtiger_Request $request, Vtiger_Viewer $viewer) {
$moduleName = $this->getModule($request);
$cvId = $request->get('cvid');
$pageNumber = $request->get('page');
$orderBy = $request->get('orderby');
$sortOrder = $request->get('sortorder');
$sourceModule = $request->get('src_module');
$sourceField = $request->get('src_field');
$sourceRecord = $request->get('src_record');
$searchKey = $request->get('search_key');
$searchValue = $request->get('search_value');
$currencyId = $request->get('currency_id');
$relatedParentModule = $request->get('related_parent_module');
$relatedParentId = $request->get('related_parent_id');
$moduleModel = Vtiger_Module_Model::getInstance($moduleName);
$searchParams = $request->get('search_params');
$searchParams = $this->customSearch($searchParams, $moduleName);
//print_r($searchParams);
$currentUser = Users_Record_Model::getCurrentUserModel();
$roleid = $currentUser->get('roleid');
$relationId = $request->get('relationId');
//To handle special operation when selecting record from Popup
$getUrl = $request->get('get_url');
$autoFillModule = $moduleModel->getAutoFillModule($moduleName);
//Check whether the request is in multi select mode
$multiSelectMode = $request->get('multi_select');
if(empty($multiSelectMode)) {
$multiSelectMode = false;
}
if(empty($getUrl) && !empty($sourceField) && !empty($autoFillModule) && !$multiSelectMode) {
$getUrl = 'getParentPopupContentsUrl';
}
if(empty($cvId)) {
$cvId = '0';
}
if(empty ($pageNumber)){
$pageNumber = '1';
}
$pagingModel = new Vtiger_Paging_Model();
$pagingModel->set('page', $pageNumber);
$recordStructureInstance = Vtiger_RecordStructure_Model::getInstanceForModule($moduleModel);
$isRecordExists = Vtiger_Util_Helper::checkRecordExistance($relatedParentId);
if($isRecordExists) {
$relatedParentModule = '';
$relatedParentId = '';
} else if($isRecordExists === NULL) {
$relatedParentModule = '';
$relatedParentId = '';
}
if(!empty($relatedParentModule) && !empty($relatedParentId)) {
$parentRecordModel = Vtiger_Record_Model::getInstanceById($relatedParentId, $relatedParentModule);
$listViewModel = Vtiger_RelationListView_Model::getInstance($parentRecordModel, $moduleName, $label,$relationId);
$searchModuleModel = $listViewModel->getRelatedModuleModel();
}else{
$listViewModel = Vtiger_ListView_Model::getInstanceForPopup($moduleName);
$searchModuleModel = $listViewModel->getModule();
}
if($moduleName == 'Documents' && $sourceModule == 'Emails') {
$listViewModel->extendPopupFields(array('filename'=>'filename'));
}
if(!empty($orderBy)) {
$listViewModel->set('orderby', $orderBy);
$listViewModel->set('sortorder', $sortOrder);
}
if(!empty($sourceModule)) {
$listViewModel->set('src_module', $sourceModule);
$listViewModel->set('src_field', $sourceField);
$listViewModel->set('src_record', $sourceRecord);
}
if((!empty($searchKey)) && (!empty($searchValue))) {
$listViewModel->set('search_key', $searchKey);
$listViewModel->set('search_value', $searchValue);
}
$listViewModel->set('relationId',$relationId);
if(!empty($searchParams)){
$transformedSearchParams = $this->transferListSearchParamsToFilterCondition($searchParams, $searchModuleModel);
if (isMedecin($roleid) || isPharma($roleid)) {
$transformedSearchParams = $this->correctTransformedSearch($transformedSearchParams);
}
$listViewModel->set('search_params',$transformedSearchParams);
//print_r($transformedSearchParams);
}
if(!empty($relatedParentModule) && !empty($relatedParentId)) {
$this->listViewHeaders = $listViewModel->getHeaders();
$models = $listViewModel->getEntries($pagingModel);
$noOfEntries = count($models);
foreach ($models as $recordId => $recordModel) {
foreach ($this->listViewHeaders as $fieldName => $fieldModel) {
$recordModel->set($fieldName, $recordModel->getDisplayValue($fieldName));
}
$models[$recordId] = $recordModel;
}
$this->listViewEntries = $models;
if(count($this->listViewEntries) > 0 ){
$parent_related_records = true;
}
}else{
$this->listViewHeaders = $listViewModel->getListViewHeaders();
$this->listViewEntries = $listViewModel->getListViewEntries($pagingModel);
}
// If there are no related records with parent module then, we should show all the records
if(!$parent_related_records && !empty($relatedParentModule) && !empty($relatedParentId)){
$relatedParentModule = null;
$relatedParentId = null;
$listViewModel = Vtiger_ListView_Model::getInstanceForPopup($moduleName);
if(!empty($orderBy)) {
$listViewModel->set('orderby', $orderBy);
$listViewModel->set('sortorder', $sortOrder);
}
if(!empty($sourceModule)) {
$listViewModel->set('src_module', $sourceModule);
$listViewModel->set('src_field', $sourceField);
$listViewModel->set('src_record', $sourceRecord);
}
if((!empty($searchKey)) && (!empty($searchValue))) {
$listViewModel->set('search_key', $searchKey);
$listViewModel->set('search_value', $searchValue);
}
if(!empty($searchParams)) {
$transformedSearchParams = $this->transferListSearchParamsToFilterCondition($searchParams, $searchModuleModel);
$listViewModel->set('search_params',$transformedSearchParams);
}
$this->listViewHeaders = $listViewModel->getListViewHeaders();
$this->listViewEntries = $listViewModel->getListViewEntries($pagingModel);
}
// End
if(empty($searchParams)) {
$searchParams = array();
}
//To make smarty to get the details easily accesible
foreach($searchParams as $fieldListGroup){
foreach($fieldListGroup as $fieldSearchInfo){
$fieldSearchInfo['searchValue'] = $fieldSearchInfo[2];
$fieldSearchInfo['fieldName'] = $fieldName = $fieldSearchInfo[0];
$fieldSearchInfo['comparator'] = $fieldSearchInfo[1];
$searchParams[$fieldName] = $fieldSearchInfo;
}
}
$noOfEntries = count($this->listViewEntries);
if(empty($sortOrder)){
$sortOrder = "ASC";
}
if($sortOrder == "ASC"){
$nextSortOrder = "DESC";
$sortImage = "icon-chevron-down";
$faSortImage = "fa-sort-desc";
}else{
$nextSortOrder = "ASC";
$sortImage = "icon-chevron-up";
$faSortImage = "fa-sort-asc";
}
$viewer->assign('MODULE', $moduleName);
$viewer->assign('RELATED_MODULE', $moduleName);
$viewer->assign('MODULE_NAME',$moduleName);
$viewer->assign('SOURCE_MODULE', $sourceModule);
$viewer->assign('SOURCE_FIELD', $sourceField);
$viewer->assign('SOURCE_RECORD', $sourceRecord);
$viewer->assign('RELATED_PARENT_MODULE', $relatedParentModule);
$viewer->assign('RELATED_PARENT_ID', $relatedParentId);
$viewer->assign('SEARCH_KEY', $searchKey);
$viewer->assign('SEARCH_VALUE', $searchValue);
$viewer->assign('RELATION_ID',$relationId);
$viewer->assign('ORDER_BY',$orderBy);
$viewer->assign('SORT_ORDER',$sortOrder);
$viewer->assign('NEXT_SORT_ORDER',$nextSortOrder);
$viewer->assign('SORT_IMAGE',$sortImage);
$viewer->assign('FASORT_IMAGE',$faSortImage);
$viewer->assign('GETURL', $getUrl);
$viewer->assign('CURRENCY_ID', $currencyId);
$viewer->assign('RECORD_STRUCTURE_MODEL', $recordStructureInstance);
$viewer->assign('RECORD_STRUCTURE', $recordStructureInstance->getStructure());
$viewer->assign('PAGING_MODEL', $pagingModel);
$viewer->assign('PAGE_NUMBER',$pageNumber);
$viewer->assign('LISTVIEW_ENTRIES_COUNT',$noOfEntries);
$viewer->assign('LISTVIEW_HEADERS', $this->listViewHeaders);
$viewer->assign('LISTVIEW_ENTRIES', $this->listViewEntries);
$viewer->assign('SEARCH_DETAILS', $searchParams);
$viewer->assign('MODULE_MODEL', $moduleModel);
$viewer->assign('VIEW', $request->get('view'));
if (PerformancePrefs::getBoolean('LISTVIEW_COMPUTE_PAGE_COUNT', false) || $moduleName == 'Accounts') {
if(!$this->listViewCount){
$this->listViewCount = $listViewModel->getListViewCount();
}
$totalCount = $this->listViewCount;
$pageLimit = $pagingModel->getPageLimit();
$pageCount = ceil((int) $totalCount / (int) $pageLimit);
if($pageCount == 0){
$pageCount = 1;
}
$viewer->assign('PAGE_COUNT', $pageCount);
$viewer->assign('LISTVIEW_COUNT', $totalCount);
}
$viewer->assign('MULTI_SELECT', $multiSelectMode);
$viewer->assign('CURRENT_USER_MODEL', Users_Record_Model::getCurrentUserModel());
}
/**
* Function to get listView count
* @param Vtiger_Request $request
*/
function getListViewCount(Vtiger_Request $request){
$moduleName = $this->getModule($request);
$sourceModule = $request->get('src_module');
$sourceField = $request->get('src_field');
$sourceRecord = $request->get('src_record');
$orderBy = $request->get('orderby');
$sortOrder = $request->get('sortorder');
$currencyId = $request->get('currency_id');
$searchKey = $request->get('search_key');
$searchValue = $request->get('search_value');
$searchParams=$request->get('search_params');
$searchParams = $this->customSearch($searchParams, $moduleName);
$relatedParentModule = $request->get('related_parent_module');
$relatedParentId = $request->get('related_parent_id');
if(!empty($relatedParentModule) && !empty($relatedParentId)) {
$parentRecordModel = Vtiger_Record_Model::getInstanceById($relatedParentId, $relatedParentModule);
$listViewModel = Vtiger_RelationListView_Model::getInstance($parentRecordModel, $moduleName, $label);
}else{
$listViewModel = Vtiger_ListView_Model::getInstanceForPopup($moduleName);
}
if(!empty($sourceModule)) {
$listViewModel->set('src_module', $sourceModule);
$listViewModel->set('src_field', $sourceField);
$listViewModel->set('src_record', $sourceRecord);
$listViewModel->set('currency_id', $currencyId);
}
if(!empty($orderBy)) {
$listViewModel->set('orderby', $orderBy);
$listViewModel->set('sortorder', $sortOrder);
}
if((!empty($searchKey)) && (!empty($searchValue))) {
$listViewModel->set('search_key', $searchKey);
$listViewModel->set('search_value', $searchValue);
}
if(!empty($searchParams)) {
$transformedSearchParams = $this->transferListSearchParamsToFilterCondition($searchParams, $listViewModel->getModule());
$listViewModel->set('search_params',$transformedSearchParams);
}
if(!empty($relatedParentModule) && !empty($relatedParentId)) {
$count = $listViewModel->getRelatedEntriesCount();
}else{
$count = $listViewModel->getListViewCount();
}
return $count;
}
/**
* Function to get the page count for list
* @return total number of pages
*/
function getPageCount(Vtiger_Request $request){
$listViewCount = $this->getListViewCount($request);
$pagingModel = new Vtiger_Paging_Model();
$pageLimit = $pagingModel->getPageLimit();
$pageCount = ceil((int) $listViewCount / (int) $pageLimit);
if($pageCount == 0){
$pageCount = 1;
}
$result = array();
$result['page'] = $pageCount;
$result['numberOfRecords'] = $listViewCount;
$response = new Vtiger_Response();
$response->setResult($result);
$response->emit();
}
public function transferListSearchParamsToFilterCondition($listSearchParams, $moduleModel) {
return Vtiger_Util_Helper::transferListSearchParamsToFilterCondition($listSearchParams, $moduleModel);
}
}