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 + -
显示快捷键?