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-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('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 __construct()
121 parent::__construct();
124 function get_db_type(){
125 if($GLOBALS['db']->dbType == 'oci8'){
132 function get_db_default($modify=false){
136 function get_field_def(){
137 $def = parent::get_field_def();
138 if($GLOBALS['db']->dbType == 'oci8'){
139 $def['dbType'] = 'date';
141 $def['dbType'] = 'datetime';
143 if(!empty($def['default'])){
144 $def['display_default'] = $def['default'];
145 $def['default'] = '';
154 function populateFromPost(){
155 parent::populateFromPost();
156 if(!empty($_REQUEST['defaultDate']) && !empty($_REQUEST['defaultTime'])){
157 $_REQUEST['default'] = $_REQUEST['defaultDate'].'&'.$_REQUEST['defaultTime'];
159 $defaultTime = $_REQUEST['defaultTime'];
160 $hours = substr($defaultTime, 0, 2);
161 $minutes = substr($defaultTime, 3, 2);
162 $meridiem = substr($defaultTime, 5, 2);
163 if(empty($meridiem)) {
167 } else if($hours > 12) {
173 $_REQUEST['default'] = $_REQUEST['defaultDate'].'&'.$hours.':'.$minutes.''.$meridiem;
176 $_REQUEST['default'] = '';
178 unset($_REQUEST['defaultDate']);
179 unset($_REQUEST['defaultTime']);
181 foreach($this->vardef_map as $vardef=>$field){
182 if(isset($_REQUEST[$vardef])){
183 $this->$vardef = $_REQUEST[$vardef];
184 if($vardef != $field){
185 $this->$field = $this->$vardef;
189 $GLOBALS['log']->debug('populate: '.print_r($this,true));