]> CyberLeo.Net >> Repos - Github/sugarcrm.git/blob - include/generic/SugarWidgets/SugarWidgetFielddatetimecombo.php
Release 6.2.0
[Github/sugarcrm.git] / include / generic / SugarWidgets / SugarWidgetFielddatetimecombo.php
1 <?php
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.
6  * 
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.
13  * 
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
17  * details.
18  * 
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
22  * 02110-1301 USA.
23  * 
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.
26  * 
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.
30  * 
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  ********************************************************************************/
37
38 require_once('include/generic/SugarWidgets/SugarWidgetFielddatetime.php');
39
40
41 class SugarWidgetFieldDateTimecombo extends SugarWidgetFieldDateTime {
42         var $reporter;
43         var $assigned_user=null;
44
45     function SugarWidgetFieldDateTimecombo(&$layout_manager) {
46         parent::SugarWidgetFieldDateTime($layout_manager);
47         $this->reporter = $this->layout_manager->getAttribute('reporter');
48     }
49
50         function queryFilterOn(& $layout_def) {
51                 global $timedate;
52                 if($this->getAssignedUser()) {
53                         $ontime = $timedate->handle_offset($layout_def['input_name0'], $timedate->get_db_date_time_format(), false, $this->assigned_user);
54                 }
55                 else {
56                         $ontime = $layout_def['input_name0'];
57                 }
58
59                         return $this->_get_column_select($layout_def)."='".$this->reporter->db->quote($ontime)."' \n";
60         }
61     function queryFilterBefore(& $layout_def) {
62         global $timedate;
63
64         if($this->getAssignedUser()) {
65             $begin = $timedate->handle_offset($layout_def['input_name0'], $timedate->get_db_date_time_format(), false, $this->assigned_user);
66         }
67         else {
68             $begin = $layout_def['input_name0'];
69         }
70
71             return $this->_get_column_select($layout_def)."<'".$this->reporter->db->quote($begin)."'\n";
72
73     }
74
75     function queryFilterAfter(& $layout_def) {
76         global $timedate;
77
78         if($this->getAssignedUser()) {
79             $begin = $timedate->handle_offset($layout_def['input_name0'] , $timedate->get_db_date_time_format(), false, $this->assigned_user);
80         }
81         else {
82             $begin = $layout_def['input_name0'];
83         }
84
85             return $this->_get_column_select($layout_def).">'".$this->reporter->db->quote($begin)."'\n";
86     }
87         //TODO:now for date time field , we just search from date start to date end. The time is from 00:00:00 to 23:59:59
88         //If there is requirement, we can modify report.js::addFilterInputDatetimesBetween and this function
89         function queryFilterBetween_Datetimes(& $layout_def) {
90                 global $timedate;
91                 if($this->getAssignedUser()) {
92                         $begin = $timedate->handle_offset($layout_def['input_name0'], $timedate->get_db_date_time_format(), false, $this->assigned_user);
93                         $end = $timedate->handle_offset($layout_def['input_name2'], $timedate->get_db_date_time_format(), false, $this->assigned_user);
94                 }
95                 else {
96                         $begin = $layout_def['input_name0'];
97                         $end = $layout_def['input_name1'];
98                 }
99                         return "(".$this->_get_column_select($layout_def).">='".$this->reporter->db->quote($begin)."' AND \n".$this->_get_column_select($layout_def)."<='".$this->reporter->db->quote($end)."')\n";
100         }
101         
102     function queryFilterNot_Equals_str(& $layout_def) {
103         global $timedate;
104
105         if($this->getAssignedUser()) {
106             $begin = $timedate->handle_offset($layout_def['input_name0'], $timedate->get_db_date_time_format(), false, $this->assigned_user);
107             $end = $timedate->handle_offset($layout_def['input_name0'], $timedate->get_db_date_time_format(), false, $this->assigned_user);
108         }
109         else {
110             $begin = $layout_def['input_name0'];
111             $end = $layout_def['input_name0'];
112         }
113
114         if ($this->reporter->db->dbType == 'oci8') {
115
116         } elseif ($this->reporter->db->dbType == 'mssql'){
117             return "(".$this->_get_column_select($layout_def)."<'".$this->reporter->db->quote($begin)."' OR ".$this->_get_column_select($layout_def).">'".$this->reporter->db->quote($end)."')\n";
118
119         }else{
120             return "ISNULL(".$this->_get_column_select($layout_def).") OR \n(".$this->_get_column_select($layout_def)."<'".$this->reporter->db->quote($begin)."' OR ".$this->_get_column_select($layout_def).">'".$this->reporter->db->quote($end)."')\n";
121         }
122     }   
123 }