query_string = $query_string;
}
}
}
function getDropDownDiv($tpl = 'modules/Home/UnifiedSearchAdvanced.tpl') {
global $app_list_strings, $app_strings;
if(!file_exists($GLOBALS['sugar_config']['cache_dir'].'modules/unified_search_modules.php'))
{
$this->buildCache();
}
include($GLOBALS['sugar_config']['cache_dir'].'modules/unified_search_modules.php');
if(!file_exists('custom/modules/unified_search_modules_display.php'))
{
$this->createUnifiedSearchModulesDisplay();
}
include('custom/modules/unified_search_modules_display.php');
global $mod_strings, $modListHeader, $app_list_strings, $current_user, $app_strings, $beanList;
$users_modules = $current_user->getPreference('globalSearch', 'search');
// preferences are empty, select all
if(empty($users_modules)) {
$users_modules = array();
foreach($unified_search_modules_display as $module=>$data) {
if (!empty($data['visible']) ) {
$users_modules[$module] = $beanList[$module];
}
}
$current_user->setPreference('globalSearch', $users_modules, 0, 'search');
}
$sugar_smarty = new Sugar_Smarty();
$modules_to_search = array();
foreach($users_modules as $key=>$module)
{
if(ACLController::checkAccess($key, 'list', true))
{
$modules_to_search[$key]['checked'] = true;
}
}
if(!empty($this->query_string))
{
$sugar_smarty->assign('query_string', securexss($this->query_string));
} else {
$sugar_smarty->assign('query_string', '');
}
$sugar_smarty->assign('MOD', return_module_language($GLOBALS['current_language'], 'Administration'));
$sugar_smarty->assign('APP', $app_strings);
$sugar_smarty->assign('USE_SEARCH_GIF', 0);
$sugar_smarty->assign('LBL_SEARCH_BUTTON_LABEL', $app_strings['LBL_SEARCH_BUTTON_LABEL']);
$json_enabled = array();
$json_disabled = array();
//Now add the rest of the modules that are searchable via Global Search settings
foreach($unified_search_modules_display as $module=>$data)
{
if(!isset($modules_to_search[$module]) && $data['visible'] && ACLController::checkAccess($module, 'list', true))
{
$modules_to_search[$module]['checked'] = false;
} else if (isset($modules_to_search[$module]) && !$data['visible']) {
unset($modules_to_search[$module]);
}
}
//Create the two lists (doing it this way preserves the user's ordering choice for enabled modules)
foreach($modules_to_search as $module=>$data)
{
$label = isset($app_list_strings['moduleList'][$module]) ? $app_list_strings['moduleList'][$module] : $module;
if(!empty($data['checked']))
{
$json_enabled[] = array("module" => $module, 'label' => $label);
} else {
$json_disabled[] = array("module" => $module, 'label' => $label);
}
}
$sugar_smarty->assign('enabled_modules', json_encode($json_enabled));
$sugar_smarty->assign('disabled_modules', json_encode($json_disabled));
$showDiv = $current_user->getPreference('showGSDiv', 'search');
if(!isset($showDiv))
{
$showDiv = 'no';
}
$sugar_smarty->assign('SHOWGSDIV', $showDiv);
$sugar_smarty->debugging = true;
return $sugar_smarty->fetch($tpl);
}
function search() {
if(!file_exists($GLOBALS['sugar_config']['cache_dir'].'modules/unified_search_modules.php'))
{
$this->buildCache();
}
include $GLOBALS['sugar_config']['cache_dir'].'modules/unified_search_modules.php';
if(!file_exists('custom/modules/unified_search_modules_display.php'))
{
$this->createUnifiedSearchModulesDisplay();
}
include('custom/modules/unified_search_modules_display.php');
require_once 'include/ListView/ListViewSmarty.php';
global $modListHeader, $beanList, $beanFiles, $current_language, $app_strings, $current_user, $mod_strings;
$home_mod_strings = return_module_language($current_language, 'Home');
$overlib = true;
$this->query_string = $GLOBALS['db']->quote(securexss(from_html(clean_string($this->query_string, 'UNIFIED_SEARCH'))));
if(!empty($_REQUEST['advanced']) && $_REQUEST['advanced'] != 'false') {
$modules_to_search = array();
if(!empty($_REQUEST['search_modules']))
{
foreach(explode (',', $_REQUEST['search_modules'] ) as $e)
{
$modules_to_search[$e] = $beanList[$e];
}
}
$current_user->setPreference('showGSDiv', isset($_REQUEST['showGSDiv']) ? $_REQUEST['showGSDiv'] : 'no', 0, 'search');
$current_user->setPreference('globalSearch', $modules_to_search, 0, 'search'); // save selections to user preference
} else {
$users_modules = $current_user->getPreference('globalSearch', 'search');
$modules_to_search = array();
if(!empty($users_modules)) {
// use user's previous selections
foreach ( $users_modules as $key => $value ) {
if (isset($unified_search_modules_display[$key]) && !empty($unified_search_modules_display[$key]['visible'])) {
$modules_to_search[$key] = $beanList[$key];
}
}
} else {
foreach($unified_search_modules_display as $module=>$data) {
if (!empty($data['visible']) ) {
$modules_to_search[$module] = $beanList[$module];
}
}
}
$current_user->setPreference('globalSearch', $modules_to_search, 'search');
}
$templateFile = 'modules/Home/UnifiedSearchAdvancedForm.tpl';
if(file_exists('custom/' . $templateFile))
{
$templateFile = 'custom/'.$templateFile;
}
echo $this->getDropDownDiv($templateFile);
$module_results = array();
$module_counts = array();
$has_results = false;
if(!empty($this->query_string)) {
foreach($modules_to_search as $moduleName => $beanName) {
require_once $beanFiles[$beanName] ;
$seed = new $beanName();
$lv = new ListViewSmarty();
$lv->lvd->additionalDetails = false;
$mod_strings = return_module_language($current_language, $seed->module_dir);
//retrieve the original list view defs and store for processing in case of custom layout changes
require('modules/'.$seed->module_dir.'/metadata/listviewdefs.php');
$orig_listViewDefs = $listViewDefs;
if(file_exists('custom/modules/'.$seed->module_dir.'/metadata/listviewdefs.php'))
{
require('custom/modules/'.$seed->module_dir.'/metadata/listviewdefs.php');
}
if ( !isset($listViewDefs) || !isset($listViewDefs[$seed->module_dir]) )
{
continue;
}
$unifiedSearchFields = array () ;
$innerJoins = array();
foreach ( $unified_search_modules[ $moduleName ]['fields'] as $field=>$def )
{
$listViewCheckField = strtoupper($field);
//check to see if the field is in listview defs
if ( empty($listViewDefs[$seed->module_dir][$listViewCheckField]['default']) ) {
//check to see if field is in original list view defs (in case we are using custom layout defs)
if (!empty($orig_listViewDefs[$seed->module_dir][$listViewCheckField]['default']) ) {
//if we are here then the layout has been customized, but the field is still needed for query creation
$listViewDefs[$seed->module_dir][$listViewCheckField] = $orig_listViewDefs[$seed->module_dir][$listViewCheckField];
}
}
//bug: 34125 we might want to try to use the LEFT JOIN operator instead of the INNER JOIN in the case we are
//joining against a field that has not been populated.
if(!empty($def['innerjoin']) )
{
if (empty($def['db_field']) )
{
continue;
}
$innerJoins[$field] = $def;
$def['innerjoin'] = str_replace('INNER', 'LEFT', $def['innerjoin']);
}
$unifiedSearchFields[ $moduleName ] [ $field ] = $def ;
$unifiedSearchFields[ $moduleName ] [ $field ][ 'value' ] = $this->query_string ;
}
/*
* Use searchForm2->generateSearchWhere() to create the search query, as it can generate SQL for the full set of comparisons required
* generateSearchWhere() expects to find the search conditions for a field in the 'value' parameter of the searchFields entry for that field
*/
require_once $beanFiles[$beanName] ;
$seed = new $beanName();
require_once 'include/SearchForm/SearchForm2.php' ;
$searchForm = new SearchForm ( $seed, $moduleName ) ;
$searchForm->setup (array ( $moduleName => array() ) , $unifiedSearchFields , '' , 'saved_views' /* hack to avoid setup doing further unwanted processing */ ) ;
$where_clauses = $searchForm->generateSearchWhere() ;
//add inner joins back into the where clause
$params = array('custom_select' => "");
foreach($innerJoins as $field=>$def) {
if (isset ($def['db_field'])) {
foreach($def['db_field'] as $dbfield)
$where_clauses[] = $dbfield . " LIKE '" . $this->query_string . "%'";
$params['custom_select'] .= ", $dbfield";
$params['distinct'] = true;
//$filterFields[$dbfield] = $dbfield;
}
}
if (count($where_clauses) > 0)
{
$where = '(('. implode(' ) OR ( ', $where_clauses) . '))';
}
$displayColumns = array();
foreach($listViewDefs[$seed->module_dir] as $colName => $param)
{
if(!empty($param['default']) && $param['default'] == true)
{
$param['url_sort'] = true;//bug 27933
$displayColumns[$colName] = $param;
}
}
if(count($displayColumns) > 0)
{
$lv->displayColumns = $displayColumns;
} else {
$lv->displayColumns = $listViewDefs[$seed->module_dir];
}
$lv->export = false;
$lv->mergeduplicates = false;
$lv->multiSelect = false;
$lv->delete = false;
$lv->select = false;
$lv->showMassupdateFields = false;
$lv->email = false;
if($overlib) {
$lv->overlib = true;
$overlib = false;
} else {
$lv->overlib = false;
}
$lv->setup($seed, 'include/ListView/ListViewNoMassUpdate.tpl', $where, $params, 0, 10);
$module_results[$moduleName] = '
' . get_form_header($GLOBALS['app_list_strings']['moduleList'][$seed->module_dir] . ' (' . $lv->data['pageData']['offsets']['total'] . ')', '', false);
$module_counts[$moduleName] = $lv->data['pageData']['offsets']['total'];
if($lv->data['pageData']['offsets']['total'] == 0) {
//$module_results[$moduleName] .= "