3 /*********************************************************************************
4 * SugarCRM is a customer relationship management program developed by
5 * SugarCRM, Inc. Copyright (C) 2004-2011 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 ********************************************************************************/
39 require_once('include/SugarFields/Fields/Base/SugarFieldBase.php');
41 class SugarFieldBool extends SugarFieldBase {
44 * @return The html for a drop down if the search field is not 'my_items_only' or a dropdown for all other fields.
45 * This strange behavior arises from the special needs of PM. They want the my items to be checkboxes and all other boolean fields to be dropdowns.
46 * @author Navjeet Singh
47 * @param $parentFieldArray -
49 function getSearchViewSmarty($parentFieldArray, $vardef, $displayParams, $tabindex) {
50 $this->setup($parentFieldArray, $vardef, $displayParams, $tabindex);
51 //If there was a type override to specifically render it as a boolean, show the EditView checkbox
52 if( preg_match("/(favorites|current_user|open)_only.*/", $vardef['name']))
54 return $this->fetch($this->findTemplate('EditView'));
56 return $this->fetch($this->findTemplate('SearchView'));
61 * @see SugarFieldBase::importSanitize()
63 public function importSanitize(
67 ImportFieldSanitize $settings
70 $bool_values = array(0=>'0',1=>'no',2=>'off',3=>'n',4=>'yes',5=>'y',6=>'on',7=>'1');
71 $bool_search = array_search($value,$bool_values);
72 if ( $bool_search === false ) {
76 //Convert all the values to a real bool.
77 $value = (int) ( $bool_search > 3 );
79 if ( isset($vardef['dbType']) && $vardef['dbType'] == 'varchar' )
80 $value = ( $value ? 'on' : 'off' );
85 public function getEmailTemplateValue($inputField, $vardef, $context = null){
86 global $app_list_strings;
87 // This does not return a smarty section, instead it returns a direct value
88 if ( $inputField == 'bool_true' || $inputField === true ) { // Note: true must be absolute true
89 return $app_list_strings['checkbox_dom']['1'];
90 } else if ( $inputField == 'bool_false' || $inputField === false){ // Note: false must be absolute false
91 return $app_list_strings['checkbox_dom']['2'];
92 } else { // otherwise we return blank display
97 public function unformatField($formattedField, $vardef){
98 if ( empty($formattedField) ) {
99 $unformattedField = false;
100 return $unformattedField;
102 if ( $formattedField == '0' || $formattedField == 'off' || $formattedField == 'false' || $formattedField == 'no' ) {
103 $unformattedField = false;
105 $unformattedField = true;
108 return $unformattedField;