2 if(!defined('sugarEntry') || !sugarEntry) die('Not A Valid Entry Point');
3 /*********************************************************************************
4 * SugarCRM Community Edition is a customer relationship management program developed by
5 * SugarCRM, Inc. Copyright (C) 2004-2012 SugarCRM Inc.
7 * This program is free software; you can redistribute it and/or modify it under
8 * the terms of the GNU Affero General Public License version 3 as published by the
9 * Free Software Foundation with the addition of the following permission added
10 * to Section 15 as permitted in Section 7(a): FOR ANY PART OF THE COVERED WORK
11 * IN WHICH THE COPYRIGHT IS OWNED BY SUGARCRM, SUGARCRM DISCLAIMS THE WARRANTY
12 * OF NON INFRINGEMENT OF THIRD PARTY RIGHTS.
14 * This program is distributed in the hope that it will be useful, but WITHOUT
15 * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS
16 * FOR A PARTICULAR PURPOSE. See the GNU Affero General Public License for more
19 * You should have received a copy of the GNU Affero General Public License along with
20 * this program; if not, see http://www.gnu.org/licenses or write to the Free
21 * Software Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA
24 * You can contact SugarCRM, Inc. headquarters at 10050 North Wolfe Road,
25 * SW2-130, Cupertino, CA 95014, USA. or at email address contact@sugarcrm.com.
27 * The interactive user interfaces in modified source and object code versions
28 * of this program must display Appropriate Legal Notices, as required under
29 * Section 5 of the GNU Affero General Public License version 3.
31 * In accordance with Section 7(b) of the GNU Affero General Public License version 3,
32 * these Appropriate Legal Notices must retain the display of the "Powered by
33 * SugarCRM" logo. If the display of the logo is not reasonably feasible for
34 * technical reasons, the Appropriate Legal Notices must display the words
35 * "Powered by SugarCRM".
36 ********************************************************************************/
38 /*********************************************************************************
40 * Description: is a form helper
41 * Portions created by SugarCRM are Copyright (C) SugarCRM, Inc.
42 * All Rights Reserved.
43 * Contributor(s): ______________________________________..
44 ********************************************************************************/
47 * Check for null or zero for list of values
48 * @param $prefix the prefix of value to be checked
49 * @param $required array of value to be checked
50 * @return boolean true if all values are set in the array
52 function checkRequired($prefix, $required)
54 foreach($required as $key)
56 if(!isset($_POST[$prefix.$key]) || number_empty($_POST[$prefix.$key]))
64 function populateFromPost($prefix, &$focus, $skipRetrieve=false) {
67 if(!empty($_REQUEST[$prefix.'record']) && !$skipRetrieve)
68 $focus->retrieve($_REQUEST[$prefix.'record']);
70 if(!empty($_POST['assigned_user_id']) &&
71 ($focus->assigned_user_id != $_POST['assigned_user_id']) &&
72 ($_POST['assigned_user_id'] != $current_user->id)) {
73 $GLOBALS['check_notify'] = true;
75 require_once('include/SugarFields/SugarFieldHandler.php');
76 $sfh = new SugarFieldHandler();
78 foreach($focus->field_defs as $field=>$def) {
79 if ( $field == 'id' && !empty($focus->id) ) {
80 // Don't try and overwrite the ID
83 $type = !empty($def['custom_type']) ? $def['custom_type'] : $def['type'];
84 $sf = $sfh->getSugarField($type);
86 $sf->save($focus, $_POST, $field, $def, $prefix);
88 $GLOBALS['log']->fatal("Field '$field' does not have a SugarField handler");
92 if(isset($_POST[$prefix.$field])) {
93 if(is_array($_POST[$prefix.$field]) && !empty($focus->field_defs[$field]['isMultiSelect'])) {
94 if($_POST[$prefix.$field][0] === '' && !empty($_POST[$prefix.$field][1]) ) {
95 unset($_POST[$prefix.$field][0]);
97 $_POST[$prefix.$field] = encodeMultienumValue($_POST[$prefix.$field]);
100 $focus->$field = $_POST[$prefix.$field];
102 * overrides the passed value for booleans.
103 * this will be fully deprecated when the change to binary booleans is complete.
105 if(isset($focus->field_defs[$prefix.$field]) && $focus->field_defs[$prefix.$field]['type'] == 'bool' && isset($focus->field_defs[$prefix.$field]['options'])) {
106 $opts = explode("|", $focus->field_defs[$prefix.$field]['options']);
107 $bool = $_POST[$prefix.$field];
109 if(is_int($bool) || ($bool === "0" || $bool === "1" || $bool === "2")) {
111 $selection = ($_POST[$prefix.$field] == "0") ? 1 : 0;
112 } elseif(is_bool($_POST[$prefix.$field])) {
113 // true=on, false=off
114 $selection = ($_POST[$prefix.$field]) ? 0 : 1;
116 $focus->$field = $opts[$selection];
118 } else if(!empty($focus->field_defs[$field]['isMultiSelect']) && !isset($_POST[$prefix.$field]) && isset($_POST[$prefix.$field . '_multiselect'])) {
124 foreach($focus->additional_column_fields as $field) {
125 if(isset($_POST[$prefix.$field])) {
126 $value = $_POST[$prefix.$field];
127 $focus->$field = $value;
135 function add_hidden_elements($key, $value) {
139 // if it's an array, we need to loop into the array and use square brackets []
140 if (is_array($value)) {
141 foreach ($value as $k=>$v) {
142 $elements .= "<input type='hidden' name='$key"."[$k]' value='$v'>\n";
145 $elements = "<input type='hidden' name='$key' value='$value'>\n";
152 function getPostToForm($ignore='', $isRegularExpression=false)
155 if(!empty($ignore) && $isRegularExpression) {
156 foreach ($_POST as $key=>$value){
157 if(!preg_match($ignore, $key)) {
158 $fields .= add_hidden_elements($key, $value);
162 foreach ($_POST as $key=>$value){
163 if($key != $ignore) {
164 $fields .= add_hidden_elements($key, $value);
171 function getGetToForm($ignore='', $usePostAsAuthority = false)
174 foreach ($_GET as $key=>$value)
177 if(!$usePostAsAuthority || !isset($_POST[$key])){
178 $fields.= "<input type='hidden' name='$key' value='$value'>";
185 function getAnyToForm($ignore='', $usePostAsAuthority = false)
187 $fields = getPostToForm($ignore);
188 $fields .= getGetToForm($ignore, $usePostAsAuthority);
193 function handleRedirect($return_id='', $return_module='', $additionalFlags = false)
195 if(isset($_REQUEST['return_url']) && $_REQUEST['return_url'] != "")
197 header("Location: ". $_REQUEST['return_url']);
201 $url = buildRedirectURL($return_id, $return_module);
206 //eggsurplus: abstract to simplify unit testing
207 function buildRedirectURL($return_id='', $return_module='')
209 if(isset($_REQUEST['return_module']) && $_REQUEST['return_module'] != "")
211 $return_module = $_REQUEST['return_module'];
215 $return_module = $return_module;
217 if(isset($_REQUEST['return_action']) && $_REQUEST['return_action'] != "")
220 //if we are doing a "Close and Create New"
221 if(isCloseAndCreateNewPressed())
223 $return_action = "EditView";
224 $isDuplicate = "true";
227 // Meeting Integration
228 if(isset($_REQUEST['meetingIntegrationFlag']) && $_REQUEST['meetingIntegrationFlag'] == 1) {
229 $additionalFlags = array('meetingIntegrationShowForm' => '1');
231 // END Meeting Integration
233 // if we create a new record "Save", we want to redirect to the DetailView
234 else if(isset($_REQUEST['action']) && $_REQUEST['action'] == "Save"
235 && $_REQUEST['return_module'] != 'Activities'
236 && $_REQUEST['return_module'] != 'Home'
237 && $_REQUEST['return_module'] != 'Forecasts'
238 && $_REQUEST['return_module'] != 'Calendar'
239 && $_REQUEST['return_module'] != 'MailMerge'
242 $return_action = 'DetailView';
243 } elseif($_REQUEST['return_module'] == 'Activities' || $_REQUEST['return_module'] == 'Calendar') {
244 $return_module = $_REQUEST['module'];
245 $return_action = $_REQUEST['return_action'];
246 // wp: return action needs to be set for one-click close in task list
250 // if we "Cancel", we go back to the list view.
251 $return_action = $_REQUEST['return_action'];
256 $return_action = "DetailView";
259 if(isset($_REQUEST['return_id']) && $_REQUEST['return_id'] != "")
261 $return_id = $_REQUEST['return_id'];
265 if(isset($additionalFlags) && !empty($additionalFlags)) {
266 foreach($additionalFlags as $k => $v) {
267 $add .= "&{$k}={$v}";
271 if (!isset($isDuplicate) || !$isDuplicate)
273 $url="index.php?action=$return_action&module=$return_module&record=$return_id&return_module=$return_module&return_action=$return_action{$add}";
274 if(isset($_REQUEST['offset']) && empty($_REQUEST['duplicateSave'])) {
275 $url .= "&offset=".$_REQUEST['offset'];
277 if(!empty($_REQUEST['ajax_load']))
280 'content' => "<script>SUGAR.ajaxUI.loadContent('$url');</script>\n",
282 'module' => $return_module,
283 'label' => translate($return_module),
286 $json = getJSONobj();
287 echo $json->encode($ajax_ret);
289 return "Location: $url";
292 $standard = "action=$return_action&module=$return_module&record=$return_id&isDuplicate=true&return_module=$return_module&return_action=$return_action&status=$status";
293 $url="index.php?{$standard}{$add}";
294 if(!empty($_REQUEST['ajax_load']))
297 'content' => "<script>SUGAR.ajaxUI.loadContent('$url');</script>\n",
299 'module' => $return_module,
300 'label' => translate($return_module),
303 $json = getJSONobj();
304 echo $json->encode($ajax_ret);
306 return "Location: $url";
311 function getLikeForEachWord($fieldname, $value, $minsize=4)
313 $value = trim($value);
314 $values = explode(' ',$value);
316 foreach($values as $val)
318 if(strlen($val) >= $minsize)
324 $ret .= ' '. $fieldname . ' LIKE %'.$val.'%';
332 function isCloseAndCreateNewPressed() {
333 return isset($_REQUEST['action']) &&
334 $_REQUEST['action'] == "Save" &&
335 isset($_REQUEST['isSaveAndNew']) &&
336 $_REQUEST['isSaveAndNew'] == 'true';