]> CyberLeo.Net >> Repos - Github/sugarcrm.git/blob - modules/Campaigns/Dashlets/TopCampaignsDashlet/TopCampaignsDashlet.php
Release 6.1.4
[Github/sugarcrm.git] / modules / Campaigns / Dashlets / TopCampaignsDashlet / TopCampaignsDashlet.php
1 <?php
2 if(!defined('sugarEntry') || !sugarEntry) die('Not A Valid Entry Point');
3 /*********************************************************************************
4  * SugarCRM 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
39
40
41
42 require_once('include/Dashlets/Dashlet.php');
43
44
45 class TopCampaignsDashlet extends Dashlet { 
46         var $top_campaigns = array();
47         
48         function TopCampaignsDashlet($id, $def = null) {
49         global $current_user, $app_strings;
50         parent::Dashlet($id);
51         $this->isConfigurable = false;
52         $this->isRefreshable = true;        
53
54         if(empty($def['title'])) $this->title = translate('LBL_TOP_CAMPAIGNS', 'Campaigns');
55         
56         $this->seedBean = new Opportunity();      
57
58         $qry = "SELECT C.name AS campaign_name, SUM(O.amount) AS revenue, C.id as campaign_id " .
59                            "FROM campaigns C, opportunities O " .
60                            "WHERE C.id = O.campaign_id " . 
61                            "AND O.sales_stage = 'Closed Won' " . 
62                            "GROUP BY C.name,C.id ORDER BY revenue desc";
63
64                 $result = $this->seedBean->db->limitQuery($qry, 0, 10);
65                 $row = $this->seedBean->db->fetchByAssoc($result);
66
67                 while ($row != null){
68                         array_push($this->top_campaigns, $row);
69                         $row = $this->seedBean->db->fetchByAssoc($result);                      
70                 }
71     }
72     
73     function display(){
74         
75         
76         $ss = new Sugar_Smarty();
77         $ss->assign('lbl_campaign_name', translate('LBL_TOP_CAMPAIGNS_NAME', 'Campaigns'));
78         $ss->assign('lbl_revenue', translate('LBL_TOP_CAMPAIGNS_REVENUE', 'Campaigns'));        
79         $ss->assign('top_campaigns', $this->top_campaigns);
80         
81         return parent::display() . $ss->fetch('modules/Campaigns/Dashlets/TopCampaignsDashlet/TopCampaignsDashlet.tpl');
82     }
83     
84 }
85
86 ?>