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 ********************************************************************************/
38 /*********************************************************************************
40 * Description: Defines the English language pack for the base application.
41 * Portions created by SugarCRM are Copyright (C) SugarCRM, Inc.
42 * All Rights Reserved.
43 * Contributor(s): ______________________________________..
44 ********************************************************************************/
46 require_once('include/SugarObjects/templates/basic/Basic.php');
47 class Sale extends Basic{
54 function create_new_list_query($order_by, $where,$filter=array(),$params=array(), $show_deleted = 0,$join_type='', $return_array = false,$parentbean=null, $singleSelect = false)
56 //Ensure that amount is always on list view queries if amount_usdollar is as well.
57 if (!empty($filter) && isset($filter['amount_usdollar']) && !isset($filter['amount']))
59 $filter['amount'] = true;
61 return parent::create_new_list_query($order_by, $where, $filter, $params, $show_deleted, $join_type, $return_array, $parentbean, $singleSelect);
64 function fill_in_additional_list_fields()
66 parent::fill_in_additional_list_fields();
68 //Ensure that the amount_usdollar field is not null.
69 if (empty($this->amount_usdollar) && !empty($this->amount))
71 $this->amount_usdollar = $this->amount;
75 function fill_in_additional_detail_fields()
77 parent::fill_in_additional_detail_fields();
78 //Ensure that the amount_usdollar field is not null.
79 if (empty($this->amount_usdollar) && !empty($this->amount))
81 $this->amount_usdollar = $this->amount;
86 function save($check_notify = FALSE) {
87 //"amount_usdollar" is really amount_basecurrency. We need to save a copy of the amount in the base currency.
88 if(isset($this->amount) && !number_empty($this->amount)){
89 if (!number_empty($this->currency_id))
91 $currency = new Currency();
92 $currency->retrieve($this->currency_id);
93 $this->amount_usdollar = $currency->convertToDollar($this->amount);
97 $this->amount_usdollar = $this->amount;
101 return parent::save($check_notify);