hasModulePermission($projectTaskInstance->getId())) { $quickLinks[] = array( 'linktype' => 'SIDEBARLINK', 'linklabel' => 'LBL_TASKS_LIST', 'linkurl' => $this->getTasksListUrl(), 'linkicon' => '', ); } $projectMileStoneInstance = Vtiger_Module_Model::getInstance('ProjectMilestone'); if($userPrivilegesModel->hasModulePermission($projectMileStoneInstance->getId())) { $quickLinks[] = array( 'linktype' => 'SIDEBARLINK', 'linklabel' => 'LBL_MILESTONES_LIST', 'linkurl' => $this->getMilestonesListUrl(), 'linkicon' => '', ); } foreach($quickLinks as $quickLink) { $links['SIDEBARLINK'][] = Vtiger_Link_Model::getInstanceFromValues($quickLink); } return $links; } public function getTasksListUrl() { $taskModel = Vtiger_Module_Model::getInstance('ProjectTask'); return $taskModel->getListViewUrl(); } public function getMilestonesListUrl() { $milestoneModel = Vtiger_Module_Model::getInstance('ProjectMilestone'); return $milestoneModel->getListViewUrl(); } /* * Function to get supported utility actions for a module */ function getUtilityActionsNames() { return array('Import', 'Export', 'DuplicatesHandling'); } /** * Function to get relation query for particular module with function name * @param $recordId * @param $functionName * @param Vtiger_Module_Model $relatedModule * @return */ public function getRelationQuery($recordId, $functionName, $relatedModule, $relationId) { $relatedModuleName = $relatedModule->getName(); $query = parent::getRelationQuery($recordId, $functionName, $relatedModule, $relationId); return $query; } /** * Function to get list view query for popup window * @param $sourceModule Parent module * @param $field parent fieldname * @param $record parent id * @param $listQuery * @return Listview Query */ public function getQueryByModuleField($sourceModule, $field, $record, $listQuery) { if ($sourceModule === 'HelpDesk') { $condition = " vtiger_project.projectid NOT IN (SELECT relcrmid FROM vtiger_crmentityrel WHERE crmid = ? UNION SELECT crmid FROM vtiger_crmentityrel WHERE relcrmid = ?) "; $db = PearDatabase::getInstance(); $condition = $db->convert2Sql($condition, array($record, $record)); $pos = stripos($listQuery, 'where'); if ($pos) { $split = preg_split('/where/i', $listQuery); $overRideQuery = $split[0].' WHERE '.$split[1].' AND '.$condition; } else { $overRideQuery = $listQuery.' WHERE '.$condition; } return $overRideQuery; } } }