]> CyberLeo.Net >> Repos - Github/sugarcrm.git/blob - modules/Campaigns/Dashlets/TopCampaignsDashlet/TopCampaignsDashlet.php
Release 6.5.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-2012 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                "AND O.deleted = 0 " .
75                            "GROUP BY C.name,C.id ORDER BY revenue desc";
76
77                 $result = $this->seedBean->db->limitQuery($qry, 0, 10);
78                 $row = $this->seedBean->db->fetchByAssoc($result);
79
80                 while ($row != null){
81                         array_push($this->top_campaigns, $row);
82                         $row = $this->seedBean->db->fetchByAssoc($result);                      
83                 }
84     }
85     
86     /**
87          * @see Dashlet::display()
88          */
89         public function display()
90         {
91         $ss = new Sugar_Smarty();
92         $ss->assign('lbl_campaign_name', translate('LBL_TOP_CAMPAIGNS_NAME', 'Campaigns'));
93         $ss->assign('lbl_revenue', translate('LBL_TOP_CAMPAIGNS_REVENUE', 'Campaigns'));        
94         $ss->assign('top_campaigns', $this->top_campaigns);
95         
96         return parent::display() . $ss->fetch('modules/Campaigns/Dashlets/TopCampaignsDashlet/TopCampaignsDashlet.tpl');
97     }
98     
99     /**
100          * @see Dashlet::displayOptions()
101          */
102         public function displayOptions() 
103     {
104         $ss = new Sugar_Smarty();
105         $ss->assign('titleLBL', translate('LBL_DASHLET_OPT_TITLE', 'Home'));
106         $ss->assign('title', $this->title);
107         $ss->assign('id', $this->id);
108         $ss->assign('saveLBL', $GLOBALS['app_strings']['LBL_SAVE_BUTTON_LABEL']);
109         if($this->isAutoRefreshable()) {
110                 $ss->assign('isRefreshable', true);
111                         $ss->assign('autoRefresh', $GLOBALS['app_strings']['LBL_DASHLET_CONFIGURE_AUTOREFRESH']);
112                         $ss->assign('autoRefreshOptions', $this->getAutoRefreshOptions());
113                         $ss->assign('autoRefreshSelect', $this->autoRefresh);
114                 }
115         
116                 return $ss->fetch('modules/Opportunities/Dashlets/MyClosedOpportunitiesDashlet/MyClosedOpportunitiesDashletConfigure.tpl');        
117     }
118
119     /**
120          * @see Dashlet::saveOptions()
121          */
122         public function saveOptions($req) 
123     {
124         $options = array();
125         
126         if ( isset($req['title']) ) {
127             $options['title'] = $req['title'];
128         }
129         $options['autoRefresh'] = empty($req['autoRefresh']) ? '0' : $req['autoRefresh'];
130         
131         return $options;
132     }
133 }