sugarwidgetfielddatetime.php
来自「SugarCRM5.1 开源PHP客户关系管理系统」· PHP 代码 · 共 907 行 · 第 1/3 页
PHP
907 行
<?phpif(!defined('sugarEntry') || !sugarEntry) die('Not A Valid Entry Point');/********************************************************************************* * SugarCRM is a customer relationship management program developed by * SugarCRM, Inc. Copyright (C) 2004 - 2007 SugarCRM Inc. * * This program is free software; you can redistribute it and/or modify it under * the terms of the GNU General Public License version 3 as published by the * Free Software Foundation with the addition of the following permission added * to Section 15 as permitted in Section 7(a): FOR ANY PART OF THE COVERED WORK * IN WHICH THE COPYRIGHT IS OWNED BY SUGARCRM, SUGARCRM DISCLAIMS THE WARRANTY * OF NON INFRINGEMENT OF THIRD PARTY RIGHTS. * * This program is distributed in the hope that it will be useful, but WITHOUT * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS * FOR A PARTICULAR PURPOSE. See the GNU General Public License for more * details. * * You should have received a copy of the GNU General Public License along with * this program; if not, see http://www.gnu.org/licenses or write to the Free * Software Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA * 02110-1301 USA. * * You can contact SugarCRM, Inc. headquarters at 10050 North Wolfe Road, * SW2-130, Cupertino, CA 95014, USA. or at email address contact@sugarcrm.com. * * The interactive user interfaces in modified source and object code versions * of this program must display Appropriate Legal Notices, as required under * Section 5 of the GNU General Public License version 3. * * In accordance with Section 7(b) of the GNU General Public License version 3, * these Appropriate Legal Notices must retain the display of the "Powered by * SugarCRM" logo. If the display of the logo is not reasonably feasible for * technical reasons, the Appropriate Legal Notices must display the words * "Powered by SugarCRM". ********************************************************************************/require_once('modules/Users/User.php');class SugarWidgetFieldDateTime extends SugarWidgetReportField { var $reporter; var $assigned_user=null; function SugarWidgetFieldDateTime(&$layout_manager) { parent::SugarWidgetReportField($layout_manager); $this->reporter = $this->layout_manager->getAttribute('reporter'); } // get the reporter attribute // deprecated, now called in the constructor function getReporter() {// $this->reporter = $this->layout_manager->getAttribute('reporter'); } // get the assigned user of the report function getAssignedUser() { $json_obj = getJSONobj(); $report_def_str = $json_obj->decode($this->reporter->report_def_str); if(empty($report_def_str['assigned_user_id'])) return false; $this->assigned_user = new User(); $this->assigned_user->retrieve($report_def_str['assigned_user_id']); return true; } function queryFilterOn(& $layout_def) { global $timedate; if($this->getAssignedUser()) { $begin = $timedate->handle_offset($layout_def['input_name0'] . ' 00:00:00', $timedate->get_db_date_time_format(), false, $this->assigned_user); $end = $timedate->handle_offset($layout_def['input_name0'] . ' 23:59:59', $timedate->get_db_date_time_format(), false, $this->assigned_user); } else { $begin = $layout_def['input_name0']." 00:00:00"; $end = $layout_def['input_name0']." 23:59:59"; } return $this->_get_column_select($layout_def).">='".PearDatabase :: quote($begin)."' AND ".$this->_get_column_select($layout_def)."<='".PearDatabase :: quote($end)."'\n"; } function queryFilterBefore(& $layout_def) { global $timedate; if($this->getAssignedUser()) { $begin = $timedate->handle_offset($layout_def['input_name0'] . ' 00:00:00', $timedate->get_db_date_time_format(), false, $this->assigned_user); } else { $begin = $layout_def['input_name0']." 00:00:00"; } return $this->_get_column_select($layout_def)."<'".PearDatabase :: quote($begin)."'\n"; } function queryFilterAfter(& $layout_def) { global $timedate; if($this->getAssignedUser()) { $begin = $timedate->handle_offset($layout_def['input_name0'] . ' 23:59:59', $timedate->get_db_date_time_format(), false, $this->assigned_user); } else { $begin = $layout_def['input_name0']." 23:59:59"; } return $this->_get_column_select($layout_def).">'".PearDatabase :: quote($begin)."'\n"; } function queryFilterBetween_Dates(& $layout_def) { global $timedate; if($this->getAssignedUser()) { $begin = $timedate->handle_offset($layout_def['input_name0'] . ' 00:00:00', $timedate->get_db_date_time_format(), false, $this->assigned_user); $end = $timedate->handle_offset($layout_def['input_name1'] . ' 23:59:59', $timedate->get_db_date_time_format(), false, $this->assigned_user); } else { $begin = $layout_def['input_name0']." 00:00:00"; $end = $layout_def['input_name1']." 23:59:59"; } return "(".$this->_get_column_select($layout_def).">='".PearDatabase :: quote($begin)."' AND \n".$this->_get_column_select($layout_def)."<='".PearDatabase :: quote($end)."')\n"; } function queryFilterNot_Equals_str(& $layout_def) { global $timedate; if($this->getAssignedUser()) { $begin = $timedate->handle_offset($layout_def['input_name0'] . ' 00:00:00', $timedate->get_db_date_time_format(), false, $this->assigned_user); $end = $timedate->handle_offset($layout_def['input_name0'] . ' 23:59:59', $timedate->get_db_date_time_format(), false, $this->assigned_user); } else { $begin = $layout_def['input_name0']." 00:00:00"; $end = $layout_def['input_name0']." 23:59:59"; } if ($this->reporter->db->dbType == 'oci8') { } elseif ($this->reporter->db->dbType == 'mssql'){ return "(".$this->_get_column_select($layout_def)."<'".PearDatabase :: quote($begin)."' OR ".$this->_get_column_select($layout_def).">'".PearDatabase :: quote($end)."')\n"; }else{ return "ISNULL(".$this->_get_column_select($layout_def).") OR \n(".$this->_get_column_select($layout_def)."<'".PearDatabase :: quote($begin)."' OR ".$this->_get_column_select($layout_def).">'".PearDatabase :: quote($end)."')\n"; } } function queryFilterTP_yesterday(& $layout_def) { global $timedate, $current_user; $begin_timestamp = time() - 86400; // begin conversion (same code as queryFilterTP_today) $begin = gmdate('Y-m-d H:i:s', $begin_timestamp); //kbrill bug #13884 //$begin = $timedate->to_display_date_time($begin); $begin = $timedate->handle_offset($begin, $timedate->get_db_date_time_format(), true, $this->assigned_user); $begin_parts = explode(' ', $begin); $be = $begin_parts[0] . ' 00:00:00'; $en = $begin_parts[0] . ' 23:59:59'; if($this->getAssignedUser()) { $begin = $timedate->handle_offset($be, $timedate->get_db_date_time_format(), false, $this->assigned_user); $end = $timedate->handle_offset($en, $timedate->get_db_date_time_format(), false, $this->assigned_user); } else{ $begin = $timedate->handle_offset($be, $timedate->get_db_date_time_format(), false, $current_user); // convert to GMT today relative to assigned_user $end = $timedate->handle_offset($en, $timedate->get_db_date_time_format(), false, $current_user); } if ($this->reporter->db->dbType == 'oci8') { } if ($this->reporter->db->dbType == 'mysql') { if (isset ($layout_def['rel_field'])) { $field_name = "CONCAT(".$this->_get_column_select($layout_def).",' ',".$layout_def['rel_field'].")"; } else { $field_name = $this->_get_column_select($layout_def); } return $field_name.">='".PearDatabase :: quote($begin)."' AND ".$field_name."<='".PearDatabase :: quote($end)."'\n"; } if ($this->reporter->db->dbType == 'mssql') { if (isset ($layout_def['rel_field'])) { $field_name = $this->_get_column_select($layout_def) . " + ' ' + " . $layout_def['rel_field'].")"; } else { $field_name = $this->_get_column_select($layout_def); } return $field_name.">='".PearDatabase :: quote($begin)."' AND ".$field_name."<='".PearDatabase :: quote($end)."'\n"; } } function queryFilterTP_today(& $layout_def) { global $timedate, $current_user; $begin_timestamp = time(); $begin = gmdate('Y-m-d H:i:s', $begin_timestamp); // get GMT today //kbrill bug #13884 //$begin = $timedate->to_display_date_time($begin); // convert and handle offset to user's 'display' today $begin = $timedate->handle_offset($begin, $timedate->get_db_date_time_format(), true, $this->assigned_user); $begin_parts = explode(' ', $begin); $be = $begin_parts[0] . ' 00:00:00'; $en = $begin_parts[0] . ' 23:59:59'; if($this->getAssignedUser()) { $begin = $timedate->handle_offset($be, $timedate->get_db_date_time_format(), false, $this->assigned_user); // convert to GMT today relative to assigned_user $end = $timedate->handle_offset($en, $timedate->get_db_date_time_format(), false, $this->assigned_user); } else{ $begin = $timedate->handle_offset($be, $timedate->get_db_date_time_format(), false, $current_user); // convert to GMT today relative to assigned_user $end = $timedate->handle_offset($en, $timedate->get_db_date_time_format(), false, $current_user); } if ($this->reporter->db->dbType == 'oci8') { }elseif($this->reporter->db->dbType == 'mssql'){ if (isset ($layout_def['rel_field'])) { $field_name = "(".$this->_get_column_select($layout_def)." + ' ' + ".$layout_def['rel_field'].")"; } else { $field_name = $this->_get_column_select($layout_def); } return $field_name.">='".PearDatabase :: quote($begin)."' AND ".$field_name."<='".PearDatabase :: quote($end)."'\n"; } else { if (isset ($layout_def['rel_field'])) { $field_name = "CONCAT(".$this->_get_column_select($layout_def).",' ',".$layout_def['rel_field'].")"; } else { $field_name = $this->_get_column_select($layout_def); } return $field_name.">='".PearDatabase :: quote($begin)."' AND ".$field_name."<='".PearDatabase :: quote($end)."'\n"; } } function queryFilterTP_tomorrow(& $layout_def) { global $timedate, $current_user; // get tomorrow $begin_timestamp =time()+ 86400; // begin conversion (same code as queryFilterTP_today) $begin = gmdate('Y-m-d H:i:s', $begin_timestamp); //kbrill bug #13884 //$begin = $timedate->to_display_date_time($begin); $begin = $timedate->handle_offset($begin, $timedate->get_db_date_time_format(), true, $this->assigned_user); $begin_parts = explode(' ', $begin); $be = $begin_parts[0] . ' 00:00:00';
⌨️ 快捷键说明
复制代码Ctrl + C
搜索代码Ctrl + F
全屏模式F11
增大字号Ctrl + =
减小字号Ctrl + -
显示快捷键?