function display() { if (is_admin($GLOBALS['current_user'])) { $json = getJSONobj(); require_once 'include/QuickSearchDefaults.php'; $qsd = new QuickSearchDefaults(); $sqs_objects = array('EditView_reports_to_name' => $qsd->getQSUser()); $sqs_objects['EditView_reports_to_name']['populate_list'] = array('reports_to_name', 'reports_to_id'); $quicksearch_js = '<script type="text/javascript" language="javascript">sqs_objects = ' . $json->encode($sqs_objects) . '; enableQS();</script>'; $this->ss->assign('REPORTS_TO_JS', $quicksearch_js); $this->ss->assign('EDIT_REPORTS_TO', true); } parent::display(); }
function display() { if (is_admin($GLOBALS['current_user'])) { $json = getJSONobj(); require_once 'include/QuickSearchDefaults.php'; $qsd = new QuickSearchDefaults(); $sqs_objects = array('EditView_reports_to_name' => $qsd->getQSUser()); $sqs_objects['EditView_reports_to_name']['populate_list'] = array('reports_to_name', 'reports_to_id'); $quicksearch_js = '<script type="text/javascript" language="javascript">sqs_objects = ' . $json->encode($sqs_objects) . '; enableQS();</script>'; $this->ss->assign('REPORTS_TO_JS', $quicksearch_js); $this->ss->assign('EDIT_REPORTS_TO', true); } //retrieve employee bean if it is not already in focus if (empty($this->bean->id) && !empty($_REQUEST['record'])) { $this->bean->retrieve($_REQUEST['record']); } //populate values for non admin users if (!empty($this->bean->id)) { global $app_list_strings; if (!empty($this->bean->status)) { $this->ss->assign('STATUS_READONLY', $app_list_strings['user_status_dom'][$this->bean->status]); } if (!empty($this->bean->employee_status)) { $this->ss->assign('EMPLOYEE_STATUS_READONLY', $app_list_strings['employee_status_dom'][$this->bean->employee_status]); } if (!empty($this->bean->reports_to_id)) { $reportsToUser = get_assigned_user_name($this->bean->reports_to_id); $reportsToUserField = "<input type='text' name='reports_to_name' id='reports_to_name' value='{$reportsToUser}' disabled>\n"; $reportsToUserField .= "<input type='hidden' name='reports_to_id' id='reports_to_id' value='{$this->bean->reports_to_id}'>"; $this->ss->assign('REPORTS_TO_READONLY', $reportsToUserField); } if (!empty($this->bean->title)) { $this->ss->assign('TITLE_READONLY', $this->bean->title); } if (!empty($this->bean->department)) { $this->ss->assign('DEPT_READONLY', $this->bean->department); } } parent::display(); }
function get_new_record_form() { if (!ACLController::checkAccess('Press', 'edit', true)) { return ''; } global $app_strings; global $mod_strings; global $currentModule; global $current_user; $the_form = get_left_form_header($mod_strings['LBL_QUICK_NEW_PRESS']); $form = new XTemplate('modules/Press/Forms.html'); $module_select = empty($_REQUEST['module_select']) ? '' : $_REQUEST['module_select']; $form->assign('mod', $mod_strings); $form->assign('app', $app_strings); $form->assign('module', $currentModule); $json = getJSONobj(); $popup_request_data = array('call_back_function' => 'set_return', 'form_name' => 'quick_save', 'field_to_name_array' => array('id' => 'assigned_user_id', 'user_name' => 'assigned_user_name')); $form->assign('encoded_users_popup_request_data', $json->encode($popup_request_data)); $form->parse('main'); $the_form .= $form->text('main'); require_once 'modules/Press/Press.php'; $focus = new Press(); require_once 'include/QuickSearchDefaults.php'; $qsd = new QuickSearchDefaults(); $sqs_objects = array('assigned_user_name' => $qsd->getQSUser()); $quicksearch_js = $qsd->getQSScripts(); $quicksearch_js .= '<script type="text/javascript" language="javascript">sqs_objects = ' . $json->encode($sqs_objects) . '</script>'; echo $quicksearch_js; require_once 'include/javascript/javascript.php'; $javascript = new javascript(); $javascript->setFormName('quick_save'); $javascript->setSugarBean($focus); $javascript->addRequiredFields(''); $javascript->addToValidateBinaryDependency('assigned_user_name', 'alpha', $app_strings['ERR_SQS_NO_MATCH_FIELD'] . $app_strings['LBL_ASSIGNED_TO'], 'false', '', 'assigned_user_id'); $jscript = $javascript->getScript(); $the_form .= $jscript . get_left_form_footer(); return $the_form; }
if (isset($_REQUEST['return_id'])) { $xtpl->assign("RETURN_ID", $_REQUEST['return_id']); } // handle Create $module then Cancel if (empty($_REQUEST['return_id'])) { $xtpl->assign("RETURN_ACTION", 'index'); } if (isset($_REQUEST['campaign_id'])) { $xtpl->assign("CAMPAIGN_ID", $_REQUEST['campaign_id']); } $xtpl->assign("THEME", $theme); $xtpl->assign("IMAGE_PATH", $image_path); $xtpl->assign("PRINT_URL", "index.php?" . $GLOBALS['request_string']); require_once 'include/QuickSearchDefaults.php'; $qsd = new QuickSearchDefaults(); $sqs_objects = array('assigned_user_name' => $qsd->getQSUser()); $quicksearch_js = $qsd->getQSScripts(); $quicksearch_js .= '<script type="text/javascript" language="javascript">sqs_objects = ' . $json->encode($sqs_objects) . '</script>'; $xtpl->assign("JAVASCRIPT", get_set_focus_js() . get_validate_record_js() . $quicksearch_js); if (empty($focus->assigned_user_id) && empty($focus->id)) { $focus->assigned_user_id = $current_user->id; } if (empty($focus->assigned_name) && empty($focus->id)) { $focus->assigned_user_name = $current_user->user_name; } $xtpl->assign("ASSIGNED_USER_OPTIONS", get_select_options_with_id(get_user_array(TRUE, "Active", $focus->assigned_user_id), $focus->assigned_user_id)); $xtpl->assign("ASSIGNED_USER_NAME", $focus->assigned_user_name); $xtpl->assign("ASSIGNED_USER_ID", $focus->assigned_user_id); $xtpl->assign("DATE_ENTERED", $focus->date_entered); $xtpl->assign("DATE_MODIFIED", $focus->date_modified); $xtpl->assign("CREATED_BY", $focus->created_by_name);
} if (isset($_REQUEST['return_action'])) { $ss->assign("RETURN_ACTION", $_REQUEST['return_action']); } if (isset($_REQUEST['return_id'])) { $ss->assign("RETURN_ID", $_REQUEST['return_id']); } // handle Create $module then Cancel if (empty($_REQUEST['return_id'])) { $ss->assign("RETURN_ACTION", 'index'); } $ss->assign("PRINT_URL", "index.php?" . $GLOBALS['request_string']); require_once 'include/QuickSearchDefaults.php'; $qsd = new QuickSearchDefaults(); $qsd->setFormName('wizform'); $sqs_objects = array('parent_name' => $qsd->getQSParent(), 'assigned_user_name' => $qsd->getQSUser(), 'test_name' => getProspectListQSObjects('prospect_list_type_test', 'test_name', 'wiz_step3_test_name_id'), 'unsubscription_name' => getProspectListQSObjects('prospect_list_type_exempt', 'unsubscription_name', 'wiz_step3_unsubscription_name_id'), 'subscription_name' => getProspectListQSObjects('prospect_list_type_default', 'subscription_name', 'wiz_step3_subscription_name_id')); $quicksearch_js = '<script type="text/javascript" language="javascript">sqs_objects = ' . $json->encode($sqs_objects) . '</script>'; $ss->assign("JAVASCRIPT", $quicksearch_js); //set the campaign type based on wizardtype value from request object $campaign_type = 'newsletter'; if (isset($_REQUEST['wizardtype']) && $_REQUEST['wizardtype'] == 1 || $focus->campaign_type == 'NewsLetter') { $campaign_type = 'newsletter'; $ss->assign("CAMPAIGN_DIAGNOSTIC_LINK", diagnose()); } elseif (isset($_REQUEST['wizardtype']) && $_REQUEST['wizardtype'] == 2 || $focus->campaign_type == 'Email') { $campaign_type = 'email'; $ss->assign("CAMPAIGN_DIAGNOSTIC_LINK", diagnose()); } else { $campaign_type = 'general'; } //******** CAMPAIGN HEADER AND BUDGET UI DIV Stuff (both divs) **********/ /// Users Popup
$xtpl->assign("RETURN_ACTION", 'index'); } if (isset($_REQUEST['parent_id'])) { $xtpl->assign('parent_id', $_REQUEST['parent_id']); } if (isset($_REQUEST['parent_name'])) { $xtpl->assign('parent_name', $_REQUEST['parent_name']); } if (isset($_REQUEST['add_component'])) { $xtpl->assign('add_component', $_REQUEST['add_component']); } $xtpl->assign("CALENDAR_DATEFORMAT", $timedate->get_cal_date_format()); $xtpl->assign("THEME", $theme); require_once 'include/QuickSearchDefaults.php'; $qsd = new QuickSearchDefaults(); $sqs_objects = array('parent_name' => $qsd->getQSParent(), 'assigned_user_name' => $qsd->getQSUser()); $sqs_objects['parent_name']['modules'] = array('Estimates'); $quicksearch_js = $qsd->getQSScripts(); $quicksearch_js .= '<script type="text/javascript" language="javascript">sqs_objects = ' . $json->encode($sqs_objects) . '</script>'; $xtpl->assign("JAVASCRIPT", get_set_focus_js() . get_validate_record_js() . get_layout_js() . $quicksearch_js); $xtpl->assign("IMAGE_PATH", $image_path); $xtpl->assign("PRINT_URL", "index.php?" . $GLOBALS['request_string']); $xtpl->assign("id", $focus->id); if (isset($focus->name)) { $xtpl->assign("NAME", $focus->name); } else { $xtpl->assign("NAME", ""); } //Add Custom Fields require_once 'modules/DynamicFields/templates/Files/EditView.php'; global $current_user;
$col_arr[2] = true; } else { $cols_name = $field_def['vname']; $col_arr[0] = $cols_name; $col_arr[1] = $field_def['name']; } if (!in_array($cols_name, $fields)) { array_push($fields, $col_arr); } $count++; } $xtpl->assign("WEB_POST_URL", $web_post_url); //$xtpl->assign("LEAD_SELECT_FIELDS",'MOD.LBL_SELECT_LEAD_FIELDS'); require_once 'include/QuickSearchDefaults.php'; $qsd = new QuickSearchDefaults(); $sqs_objects = array('account_name' => $qsd->getQSParent(), 'assigned_user_name' => $qsd->getQSUser(), 'campaign_name' => $qsd->getQSCampaigns()); $quicksearch_js = '<script type="text/javascript" language="javascript">sqs_objects = ' . $json->encode($sqs_objects) . '</script>'; $xtpl->assign("JAVASCRIPT", $quicksearch_js); if (empty($focus->assigned_user_id) && empty($focus->id)) { $focus->assigned_user_id = $current_user->id; } if (empty($focus->assigned_name) && empty($focus->id)) { $focus->assigned_user_name = $current_user->user_name; } $xtpl->assign("ASSIGNED_USER_OPTIONS", get_select_options_with_id(get_user_array(TRUE, "Active", $focus->assigned_user_id), $focus->assigned_user_id)); $xtpl->assign("ASSIGNED_USER_NAME", $focus->assigned_user_name); $xtpl->assign("ASSIGNED_USER_ID", $focus->assigned_user_id); $xtpl->assign("REDIRECT_URL_DEFAULT", 'http://'); //required fields on Webtolead form $campaign = new Campaign(); $javascript = new javascript();
/** * Renders the Import form from Smarty and returns HTML * @param array $vars request variable global * @param object $email Fetched email object * @param bool $addToAddressBook * @return array */ function getImportForm($vars, $email) { require_once 'include/json_config.php'; require_once "include/EditView/EditView2.php"; require_once "include/TemplateHandler/TemplateHandler.php"; require_once 'include/QuickSearchDefaults.php'; $qsd = new QuickSearchDefaults(); $qsd->setFormName('ImportEditView'); global $app_strings; global $current_user; global $app_list_strings; $sqs_objects = array('ImportEditView_parent_name' => $qsd->getQSParent()); $smarty = new Sugar_Smarty(); $smarty->assign("APP", $app_strings); $showAssignTo = false; if (!isset($vars['showAssignTo']) || $vars['showAssignTo'] == true) { $showAssignTo = true; } // if if ($showAssignTo) { if (empty($email->assigned_user_id) && empty($email->id)) { $email->assigned_user_id = $current_user->id; } if (empty($email->assigned_name) && empty($email->id)) { $email->assigned_user_name = $current_user->user_name; } $sqs_objects['ImportEditView_assigned_user_name'] = $qsd->getQSUser(); } $smarty->assign("showAssignedTo", $showAssignTo); $showDelete = false; if (!isset($vars['showDelete']) || $vars['showDelete'] == true) { $showDelete = true; } $smarty->assign("showDelete", $showDelete); $smarty->assign("userId", $email->assigned_user_id); $smarty->assign("userName", $email->assigned_user_name); $parent_types = $app_list_strings['record_type_display']; $smarty->assign('parentOptions', get_select_options_with_id($parent_types, $email->parent_type)); $quicksearch_js = '<script type="text/javascript" language="javascript">sqs_objects = ' . $json->encode($sqs_objects) . '</script>'; $smarty->assign('SQS', $quicksearch_js); $meta = array(); $meta['html'] = $smarty->fetch("modules/Emails/templates/importRelate.tpl"); return $meta; }
/////////////////////////////////////////////////////////////////////////////// if ($is_current_admin) { $employee_status = '<select tabindex="5" name="employee_status">'; $employee_status .= get_select_options_with_id($app_list_strings['employee_status_dom'], $focus->employee_status); $employee_status .= '</select>'; } else { $employee_status = $focus->employee_status; } $sugar_smarty->assign('EMPLOYEE_STATUS_OPTIONS', $employee_status); $sugar_smarty->assign('EMPLOYEE_STATUS_OPTIONS', $employee_status); $messenger_type = '<select tabindex="5" name="messenger_type">'; $messenger_type .= get_select_options_with_id($app_list_strings['messenger_type_dom'], $focus->messenger_type); $messenger_type .= '</select>'; $sugar_smarty->assign('MESSENGER_TYPE_OPTIONS', $messenger_type); $sugar_smarty->assign('MESSENGER_ID', $focus->messenger_id); $sugar_smarty->assign('CALENDAR_PUBLISH_KEY', $focus->getPreference('calendar_publish_key')); //$sugar_smarty->parse('main.freebusy'); $sugar_smarty->display('modules/Users/EditView.tpl'); $json = getJSONobj(); require_once 'include/QuickSearchDefaults.php'; $qsd = new QuickSearchDefaults(); $sqs_objects = array('EditView_reports_to_name' => $qsd->getQSUser()); $sqs_objects['EditView_reports_to_name']['populate_list'] = array('reports_to_name', 'reports_to_id'); $quicksearch_js = '<script type="text/javascript" language="javascript"> sqs_objects = ' . $json->encode($sqs_objects) . '; enableQS();</script>'; echo $quicksearch_js; $savedSearch = new SavedSearch(); $savedSearchSelects = $json->encode(array($GLOBALS['app_strings']['LBL_SAVED_SEARCH_SHORTCUT'] . '<br>' . $savedSearch->getSelect('Users'))); $str = "<script>\nYAHOO.util.Event.addListener(window, 'load', SUGAR.util.fillShortcuts, {$savedSearchSelects});\n</script>"; //echo $str; //BUG #16298
function createQuickSearchCode($returnAsJavascript = true) { $sqs_objects = array(); require_once 'include/QuickSearchDefaults.php'; $qsd = new QuickSearchDefaults(); $qsd->setFormName($this->form_name); for ($i = 0; $i < $this->numFields; $i++) { $name1 = "{$this->form_name}_{$this->name}_collection_{$i}"; if (!$this->skipModuleQuickSearch && preg_match('/(Campaigns|Teams|Users|Accounts)/si', $this->related_module, $matches)) { if ($matches[0] == 'Users') { $sqs_objects[$name1] = $qsd->getQSUser(); } else { if ($matches[0] == 'Campaigns') { $sqs_objects[$name1] = $qsd->getQSCampaigns(); } else { if ($matches[0] == 'Users') { $sqs_objects[$name1] = $qsd->getQSUser(); } else { if ($matches[0] == 'Accounts') { $nameKey = "{$this->name}_collection_{$i}"; $idKey = "id_{$this->name}_collection_{$i}"; //There are billingKey, shippingKey and additionalFields entries you can define in editviewdefs.php //entry to allow quick search to autocomplete fields with a suffix value of the //billing/shippingKey value (i.e. 'billingKey' => 'primary' in Contacts will populate //primary_XXX fields with the Account's billing address values). //addtionalFields are key/value pair of fields to fill from Accounts(key) to Contacts(value) $billingKey = isset($this->displayParams['billingKey']) ? $this->displayParams['billingKey'] : null; $shippingKey = isset($this->displayParams['shippingKey']) ? $this->displayParams['shippingKey'] : null; $additionalFields = isset($this->displayParams['additionalFields']) ? $this->displayParams['additionalFields'] : null; $sqs_objects[$name1] = $qsd->getQSAccount($nameKey, $idKey, $billingKey, $shippingKey, $additionalFields); } else { if ($matches[0] == 'Contacts') { $sqs_objects[$name1] = $qsd->getQSContact($name1, "id_" . $name1); } } } } } $temp_array = array('field_list' => array(), 'populate_list' => array()); foreach ($sqs_objects[$name1]['field_list'] as $k => $v) { if (!in_array($v, array('name', 'id'))) { $sqs_objects[$name1]['primary_field_list'][] = $v; $sqs_objects[$name1]['primary_populate_list'][] = $sqs_objects[$name1]['populate_list'][$k]; } else { $temp_array['field_list'][] = $v; $temp_array['populate_list'][] = $sqs_objects[$name1]['populate_list'][$k]; } } $sqs_objects[$name1]['field_list'] = $temp_array['field_list']; $sqs_objects[$name1]['populate_list'] = $temp_array['populate_list']; if (isset($this->displayParams['collection_field_list'])) { foreach ($this->displayParams['collection_field_list'] as $v) { $sqs_objects[$name1]['populate_list'][] = $v['vardefName'] . "_" . $this->name . "_collection_extra_" . $i; $sqs_objects[$name1]['field_list'][] = $v['vardefName']; } } } else { $sqs_objects[$name1] = $qsd->getQSParent($this->related_module); $sqs_objects[$name1]['populate_list'] = array("{$this->vardef['name']}_collection_{$i}", "id_{$this->vardef['name']}_collection_{$i}"); $sqs_objects[$name1]['field_list'] = array('name', 'id'); if (isset($this->displayParams['collection_field_list'])) { foreach ($this->displayParams['collection_field_list'] as $v) { $sqs_objects[$name1]['populate_list'][] = $v['vardefName'] . "_" . $this->name . "_collection_extra_" . $i; $sqs_objects[$name1]['field_list'][] = $v['vardefName']; } } if (isset($this->displayParams['field_to_name_array'])) { foreach ($this->displayParams['field_to_name_array'] as $k => $v) { /* * "primary_populate_list" and "primary_field_list" are used when the field is selected as a primary. * At this time the JS function changePrimary() will copy "primary_populate_list" and "primary_field_list" * into "populate_list" and "field_list" and remove the values from all the others which are secondaries. * "primary_populate_list" and "primary_field_list" contain the fields which has to be populated outside of * the collection field. For example the "Address Information" are populated with the "billing address" of the * selected account in a contact editview. */ $sqs_objects[$name1]['primary_populate_list'][] = $v; $sqs_objects[$name1]['primary_field_list'][] = $k; } } else { if (isset($field['field_list']) && isset($field['populate_list'])) { $sqs_objects[$name1]['primary_populate_list'] = array_merge($sqs_objects[$name1]['populate_list'], $field['field_list']); $sqs_objects[$name1]['primary_field_list'] = array_merge($sqs_objects[$name1]['field_list'], $field['populate_list']); } else { $sqs_objects[$name1]['primary_populate_list'] = array(); $sqs_objects[$name1]['primary_field_list'] = array(); } } } } $id = "{$this->form_name}_{$this->name}_collection_0"; if (!empty($sqs_objects) && count($sqs_objects) > 0) { foreach ($sqs_objects[$id]['field_list'] as $k => $v) { $this->field_to_name_array[$v] = $sqs_objects[$id]['populate_list'][$k]; } if ($returnAsJavascript) { $quicksearch_js = '<script language="javascript">'; $quicksearch_js .= "if(typeof sqs_objects == 'undefined'){var sqs_objects = new Array;}"; foreach ($sqs_objects as $sqsfield => $sqsfieldArray) { $quicksearch_js .= "sqs_objects['{$sqsfield}']={$this->json->encode($sqsfieldArray)};"; } return $quicksearch_js .= '</script>'; } else { return $sqs_objects; } } return ''; }
} else { $xtpl->assign('RETURN_ACTION', 'DetailView'); } if (isset($_REQUEST['return_id']) && !empty($_REQUEST['return_id'])) { $xtpl->assign('RETURN_ID', $_REQUEST['return_id']); } // handle Create $module then Cancel if (empty($_REQUEST['return_id']) && !isset($_REQUEST['type'])) { $xtpl->assign('RETURN_ACTION', 'index'); } $xtpl->assign('PRINT_URL', 'index.php?' . $GLOBALS['request_string']); /////////////////////////////////////////////////////////////////////////////// //// QUICKSEARCH CODE require_once 'include/QuickSearchDefaults.php'; $qsd = new QuickSearchDefaults(); $sqs_objects = array('EditView_parent_name' => $qsd->getQSParent(), 'EditView_assigned_user_name' => $qsd->getQSUser()); $json = getJSONobj(); $sqs_objects_encoded = $json->encode($sqs_objects); $quicksearch_js = <<<EOQ \t\t<script type="text/javascript" language="javascript">sqs_objects = {$sqs_objects_encoded}; var dialog_loaded; \t\t\tfunction parent_typechangeQS() { \t\t\t\t//new_module = document.getElementById('parent_type').value; \t\t\t\tnew_module = document.EditView.parent_type.value; \t\t\t\tif(new_module == 'Contacts' || new_module == 'Leads' || typeof(disabledModules[new_module]) != 'undefined') { \t\t\t\t\tsqs_objects['EditView_parent_name']['disable'] = true; \t\t\t\t\tdocument.getElementById('parent_name').readOnly = true; \t\t\t\t} \t\t\t\telse { \t\t\t\t\tsqs_objects['EditView_parent_name']['disable'] = false; \t\t\t\t\tdocument.getElementById('parent_name').readOnly = false; \t\t\t\t}
/** * createQuickSearchCode * This function creates the $sqs_objects array that will be used by the quicksearch Javascript * code. The $sqs_objects array is wrapped in a $json->encode call. * * @param $def The vardefs.php definitions * @param $defs2 The Meta-Data file definitions * */ function createQuickSearchCode($defs, $defs2, $view = '') { $sqs_objects = array(); require_once 'include/QuickSearchDefaults.php'; $qsd = new QuickSearchDefaults(); $qsd->setFormName($view); if (preg_match("/^SearchForm_.+/", $view)) { $qsd->setFormName('search_form'); $parsedView = preg_replace("/^SearchForm_/", "", $view); //Loop through the Meta-Data fields to see which ones need quick search support foreach ($defs as $f) { $field = $f; $name = $qsd->form_name . '_' . $field['name']; if ($field['type'] == 'relate' && isset($field['module']) && preg_match('/_name$|_c$/si', $name)) { if (preg_match('/^(Campaigns|Teams|Users|Contacts|Accounts)$/si', $field['module'], $matches)) { if ($matches[0] == 'Campaigns') { $sqs_objects[$name . '_' . $parsedView] = $qsd->getQSCampaigns(); } else { if ($matches[0] == 'Users') { if (!empty($f['name']) && !empty($f['id_name'])) { $sqs_objects[$name . '_' . $parsedView] = $qsd->getQSUser($f['name'], $f['id_name']); } else { $sqs_objects[$name . '_' . $parsedView] = $qsd->getQSUser(); } } else { if ($matches[0] == 'Accounts') { $nameKey = $name; $idKey = isset($field['id_name']) ? $field['id_name'] : 'account_id'; //There are billingKey, shippingKey and additionalFields entries you can define in editviewdefs.php //entry to allow quick search to autocomplete fields with a suffix value of the //billing/shippingKey value (i.e. 'billingKey' => 'primary' in Contacts will populate //primary_XXX fields with the Account's billing address values). //addtionalFields are key/value pair of fields to fill from Accounts(key) to Contacts(value) $billingKey = isset($f['displayParams']['billingKey']) ? $f['displayParams']['billingKey'] : null; $shippingKey = isset($f['displayParams']['shippingKey']) ? $f['displayParams']['shippingKey'] : null; $additionalFields = isset($f['displayParams']['additionalFields']) ? $f['displayParams']['additionalFields'] : null; $sqs_objects[$name . '_' . $parsedView] = $qsd->getQSAccount($nameKey, $idKey, $billingKey, $shippingKey, $additionalFields); } else { if ($matches[0] == 'Contacts') { $sqs_objects[$name . '_' . $parsedView] = $qsd->getQSContact($field['name'], $field['id_name']); } } } } } else { $sqs_objects[$name . '_' . $parsedView] = $qsd->getQSParent($field['module']); if (!isset($field['field_list']) && !isset($field['populate_list'])) { $sqs_objects[$name . '_' . $parsedView]['populate_list'] = array($field['name'], $field['id_name']); $sqs_objects[$name . '_' . $parsedView]['field_list'] = array('name', 'id'); } else { $sqs_objects[$name . '_' . $parsedView]['populate_list'] = $field['field_list']; $sqs_objects[$name . '_' . $parsedView]['field_list'] = $field['populate_list']; } } } else { if ($field['type'] == 'parent') { $sqs_objects[$name . '_' . $parsedView] = $qsd->getQSParent(); } } //if-else } //foreach //_pp($sqs_objects); foreach ($sqs_objects as $name => $field) { foreach ($field['populate_list'] as $key => $fieldname) { $sqs_objects[$name]['populate_list'][$key] = $sqs_objects[$name]['populate_list'][$key] . '_' . $parsedView; } } } else { //Loop through the Meta-Data fields to see which ones need quick search support foreach ($defs2 as $f) { if (!isset($defs[$f['name']])) { continue; } $field = $defs[$f['name']]; $name = $qsd->form_name . '_' . $field['name']; if ($field['type'] == 'relate' && isset($field['module']) && (preg_match('/_name$|_c$/si', $name) || !empty($field['quicksearch']))) { if (!preg_match('/_c$/si', $name) && preg_match('/^(Campaigns|Teams|Users|Contacts|Accounts)$/si', $field['module'], $matches)) { if ($matches[0] == 'Campaigns') { $sqs_objects[$name] = $qsd->getQSCampaigns(); } else { if ($matches[0] == 'Users') { if ($field['name'] == 'reports_to_name') { $sqs_objects[$name] = $qsd->getQSUser('reports_to_name', 'reports_to_id'); } else { $sqs_objects[$name] = $qsd->getQSUser(); } } else { if ($matches[0] == 'Accounts') { $nameKey = $name; $idKey = isset($field['id_name']) ? $field['id_name'] : 'account_id'; //There are billingKey, shippingKey and additionalFields entries you can define in editviewdefs.php //entry to allow quick search to autocomplete fields with a suffix value of the //billing/shippingKey value (i.e. 'billingKey' => 'primary' in Contacts will populate //primary_XXX fields with the Account's billing address values). //addtionalFields are key/value pair of fields to fill from Accounts(key) to Contacts(value) $billingKey = SugarArray::staticGet($f, 'displayParams.billingKey'); $shippingKey = SugarArray::staticGet($f, 'displayParams.shippingKey'); $additionalFields = SugarArray::staticGet($f, 'displayParams.additionalFields'); $sqs_objects[$name] = $qsd->getQSAccount($nameKey, $idKey, $billingKey, $shippingKey, $additionalFields); } else { if ($matches[0] == 'Contacts') { $sqs_objects[$name] = $qsd->getQSContact($field['name'], $field['id_name']); if (preg_match('/_c$/si', $name) || !empty($field['quicksearch'])) { $sqs_objects[$name]['field_list'] = array('salutation', 'first_name', 'last_name', 'id'); } } } } } } else { $sqs_objects[$name] = $qsd->getQSParent($field['module']); if (!isset($field['field_list']) && !isset($field['populate_list'])) { $sqs_objects[$name]['populate_list'] = array($field['name'], $field['id_name']); // now handle quicksearches where the column to match is not 'name' but rather specified in 'rname' if (!isset($field['rname'])) { $sqs_objects[$name]['field_list'] = array('name', 'id'); } else { $sqs_objects[$name]['field_list'] = array($field['rname'], 'id'); $sqs_objects[$name]['order'] = $field['rname']; $sqs_objects[$name]['conditions'] = array(array('name' => $field['rname'], 'op' => 'like_custom', 'end' => '%', 'value' => '')); } } else { $sqs_objects[$name]['populate_list'] = $field['field_list']; $sqs_objects[$name]['field_list'] = $field['populate_list']; } } } else { if ($field['type'] == 'parent') { $sqs_objects[$name] = $qsd->getQSParent(); } } //if-else } //foreach } //Implement QuickSearch for the field if (!empty($sqs_objects) && count($sqs_objects) > 0) { $quicksearch_js = '<script language="javascript">'; $quicksearch_js .= "if(typeof sqs_objects == 'undefined'){var sqs_objects = new Array;}"; $json = getJSONobj(); foreach ($sqs_objects as $sqsfield => $sqsfieldArray) { $quicksearch_js .= "sqs_objects['{$sqsfield}']={$json->encode($sqsfieldArray)};"; } return $quicksearch_js . '</script>'; } return ''; }