]> CyberLeo.Net >> Repos - Github/sugarcrm.git/blob - modules/Campaigns/Dashlets/TopCampaignsDashlet/TopCampaignsDashlet.php
Release 6.2.0
[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 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
39
40
41 require_once('include/Dashlets/Dashlet.php');
42
43 class TopCampaignsDashlet extends Dashlet 
44
45         protected $top_campaigns = array();
46         
47         /**
48          * Constructor
49          *
50          * @see Dashlet::Dashlet()
51          */
52         public function __construct($id, $def = null) 
53         {
54         global $current_user, $app_strings;
55         parent::Dashlet($id);
56         $this->isConfigurable = true;
57         $this->isRefreshable = true;        
58
59         if(empty($def['title'])) { 
60             $this->title = translate('LBL_TOP_CAMPAIGNS', 'Campaigns');
61         } 
62         else {
63             $this->title = $def['title'];
64         }
65         
66         if(isset($def['autoRefresh'])) $this->autoRefresh = $def['autoRefresh'];
67         
68         $this->seedBean = new Opportunity();      
69
70         $qry = "SELECT C.name AS campaign_name, SUM(O.amount) AS revenue, C.id as campaign_id " .
71                            "FROM campaigns C, opportunities O " .
72                            "WHERE C.id = O.campaign_id " . 
73                            "AND O.sales_stage = 'Closed Won' " . 
74                            "GROUP BY C.name,C.id ORDER BY revenue desc";
75
76                 $result = $this->seedBean->db->limitQuery($qry, 0, 10);
77                 $row = $this->seedBean->db->fetchByAssoc($result);
78
79                 while ($row != null){
80                         array_push($this->top_campaigns, $row);
81                         $row = $this->seedBean->db->fetchByAssoc($result);                      
82                 }
83     }
84     
85     /**
86          * @see Dashlet::display()
87          */
88         public function display()
89         {
90         $ss = new Sugar_Smarty();
91         $ss->assign('lbl_campaign_name', translate('LBL_TOP_CAMPAIGNS_NAME', 'Campaigns'));
92         $ss->assign('lbl_revenue', translate('LBL_TOP_CAMPAIGNS_REVENUE', 'Campaigns'));        
93         $ss->assign('top_campaigns', $this->top_campaigns);
94         
95         return parent::display() . $ss->fetch('modules/Campaigns/Dashlets/TopCampaignsDashlet/TopCampaignsDashlet.tpl');
96     }
97     
98     /**
99          * @see Dashlet::displayOptions()
100          */
101         public function displayOptions() 
102     {
103         $ss = new Sugar_Smarty();
104         $ss->assign('titleLBL', translate('LBL_DASHLET_OPT_TITLE', 'Home'));
105         $ss->assign('title', $this->title);
106         $ss->assign('id', $this->id);
107         $ss->assign('saveLBL', $GLOBALS['app_strings']['LBL_SAVE_BUTTON_LABEL']);
108         if($this->isAutoRefreshable()) {
109                 $ss->assign('isRefreshable', true);
110                         $ss->assign('autoRefresh', $GLOBALS['app_strings']['LBL_DASHLET_CONFIGURE_AUTOREFRESH']);
111                         $ss->assign('autoRefreshOptions', $this->getAutoRefreshOptions());
112                         $ss->assign('autoRefreshSelect', $this->autoRefresh);
113                 }
114         
115                 return $ss->fetch('modules/Opportunities/Dashlets/MyClosedOpportunitiesDashlet/MyClosedOpportunitiesDashletConfigure.tpl');        
116     }
117
118     /**
119          * @see Dashlet::saveOptions()
120          */
121         public function saveOptions($req) 
122     {
123         $options = array();
124         
125         if ( isset($req['title']) ) {
126             $options['title'] = $req['title'];
127         }
128         $options['autoRefresh'] = empty($req['autoRefresh']) ? '0' : $req['autoRefresh'];
129         
130         return $options;
131     }
132 }