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 ********************************************************************************/
39 require_once('modules/DynamicFields/templates/Fields/TemplateRange.php');
41 class TemplateDatetimecombo extends TemplateRange
43 var $type = 'datetimecombo';
45 var $dateStrings = array(
48 'yesterday'=> '-1 day',
50 'next week'=> '+1 week',
51 'next monday'=>'next monday',
52 'next friday'=>'next friday',
53 'two weeks'=> '+2 weeks',
54 'next month'=> '+1 month',
55 'first day of next month'=> 'first of next month', // must handle this non-GNU date string in SugarBean->populateDefaultValues; if we don't this will evaluate to 1969...
56 'three months'=> '+3 months', //kbrill Bug #17023
57 'six months'=> '+6 months',
58 'next year'=> '+1 year',
61 var $hoursStrings = array(
77 var $hoursStrings24 = array(
105 var $minutesStrings = array(
113 var $meridiemStrings = array(
119 function get_db_default($modify=false){
123 function get_field_def(){
124 $def = parent::get_field_def();
125 $def['dbType'] = 'datetime';
126 if(!empty($def['default'])){
127 $def['display_default'] = $def['default'];
128 $def['default'] = '';
133 function populateFromPost(){
134 parent::populateFromPost();
135 if(!empty($_REQUEST['defaultDate']) && !empty($_REQUEST['defaultTime'])){
136 $_REQUEST['default'] = $_REQUEST['defaultDate'].'&'.$_REQUEST['defaultTime'];
138 $defaultTime = $_REQUEST['defaultTime'];
139 $hours = substr($defaultTime, 0, 2);
140 $minutes = substr($defaultTime, 3, 2);
141 $meridiem = substr($defaultTime, 5, 2);
142 if(empty($meridiem)) {
146 } else if($hours > 12) {
152 $_REQUEST['default'] = $_REQUEST['defaultDate'].'&'.$hours.':'.$minutes.''.$meridiem;
155 $_REQUEST['default'] = '';
157 unset($_REQUEST['defaultDate']);
158 unset($_REQUEST['defaultTime']);
160 foreach($this->vardef_map as $vardef=>$field){
161 if(isset($_REQUEST[$vardef])){
162 // Bug #48826. Some fields are allowed to have special characters and must be decoded from the request
163 if (is_string($_REQUEST[$vardef]) && in_array($vardef, $this->decode_from_request_fields_map))
164 $this->$vardef = html_entity_decode($_REQUEST[$vardef]);
166 $this->$vardef = $_REQUEST[$vardef];
168 if($vardef != $field){
169 $this->$field = $this->$vardef;
173 $GLOBALS['log']->debug('populate: '.print_r($this,true));