This commit is contained in:
2024-04-27 09:23:34 +02:00
commit 11e713ca6f
11884 changed files with 3263371 additions and 0 deletions

View File

@@ -0,0 +1,70 @@
{*
/**
* SugarCRM is a customer relationship management program developed by
* SugarCRM, Inc. Copyright (C) 2004 - 2009 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".
*/
*}
<div style='width: 400px'>
<form name='configure_{$id}' action="index.php" method="post" onSubmit='return SUGAR.dashlets.postForm("configure_{$id}", SUGAR.mySugar.uncoverPage);'>
<input type='hidden' name='id' value='{$id}'>
<input type='hidden' name='module' value='{$module}'>
<input type='hidden' name='action' value='DynamicAction'>
<input type='hidden' name='DynamicAction' value='configureDashlet'>
<input type='hidden' name='to_pdf' value='true'>
<input type='hidden' name='configure' value='true'>
<input type='hidden' id='dashletType' name='dashletType' value='{$dashletType}' />
<table width="400" cellpadding="0" cellspacing="0" border="0" class="tabForm" align="center">
<tr>
<td valign='top' class='dataLabel' nowrap>{$LBL_CAMPAIGN_NAME}</td>
<td valign='top' class='dataField'>
<select name="campaign_id" size='5'>
{$campaign_list}
</select>
</td>
</tr>
<tr>
<td align="right" colspan="2">
<input type='submit' onclick="" class='button' value='{$LBL_SUBMIT_BUTTON_LABEL}'>
</td>
</tr>
</table>
</form>
</div>

View File

@@ -0,0 +1,47 @@
<?php
if(!defined('sugarEntry') || !sugarEntry) die('Not A Valid Entry Point');
/**
* SugarCRM is a customer relationship management program developed by
* SugarCRM, Inc. Copyright (C) 2004 - 2009 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".
*/
$dashletData['CampaignROIChartDashlet']['searchFields'] = array(
'campaign_id' => array(
'name' => 'campaign_id',
'vname' => 'LBL_CAMPAIGN_NAME',
'type' => 'enum',
)
);
?>

View File

@@ -0,0 +1,45 @@
<?php
if(!defined('sugarEntry') || !sugarEntry) die('Not A Valid Entry Point');
/**
* SugarCRM is a customer relationship management program developed by
* SugarCRM, Inc. Copyright (C) 2004 - 2009 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".
*/
$dashletStrings['CampaignROIChartDashlet'] = array('LBL_TITLE' => 'Campaign ROI',
'LBL_DESCRIPTION' => 'ROI Chart',
'LBL_REFRESH' => 'Refresh Chart');
?>

View File

@@ -0,0 +1,45 @@
<?php
if(!defined('sugarEntry') || !sugarEntry) die('Not A Valid Entry Point');
/**
* SugarCRM is a customer relationship management program developed by
* SugarCRM, Inc. Copyright (C) 2004 - 2009 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".
*/
$dashletStrings['CampaignROIChartDashlet'] = array('LBL_TITLE' => 'Kampagnen ROI',
'LBL_DESCRIPTION' => 'ROI Diagramm',
'LBL_REFRESH' => 'Diagramm neu laden');
?>

View File

@@ -0,0 +1,47 @@
<?php
if(!defined('sugarEntry') || !sugarEntry) die('Not A Valid Entry Point');
/**
* SugarCRM is a customer relationship management program developed by
* SugarCRM, Inc. Copyright (C) 2004 - 2009 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".
*/
global $app_strings, $current_language;
$dashletMeta['CampaignROIChartDashlet'] = array('title' => 'LBL_TITLE',
'description' => 'LBL_TITLE',
'icon' => 'themes/default/images/icon_Charts_GroupBy_32.gif',
'category' => 'Charts',
'module' => 'Campaigns',);
?>

View File

@@ -0,0 +1,86 @@
<?php
if(!defined('sugarEntry') || !sugarEntry) die('Not A Valid Entry Point');
/**
* SugarCRM is a customer relationship management program developed by
* SugarCRM, Inc. Copyright (C) 2004 - 2009 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('include/Dashlets/DashletGenericChart.php');
class CampaignROIChartDashlet extends DashletGenericChart
{
public $campaign_id;
protected $_seedName = 'Campaigns';
/**
* @see DashletGenericChart::displayOptions()
*/
public function displayOptions()
{
$this->getSeedBean()->disable_row_level_security = false;
$campaigns = $this->getSeedBean()->get_full_list("","");
if ( $campaigns != null )
foreach ($campaigns as $c)
$this->_searchFields['campaign_id']['options'][$c->id] = $c->name;
else
$this->_searchFields['campaign_id']['options'] = array();
return parent::displayOptions();
}
/**
* @see DashletGenericChart::display()
*/
public function display()
{
require_once('modules/Campaigns/Charts.php');
$roi_chart = new campaign_charts();
$chartStr = $roi_chart->campaign_response_roi(
$GLOBALS['app_list_strings']['roi_type_dom'],
$GLOBALS['app_list_strings']['roi_type_dom'],
$this->campaign_id[0],'',true,true,true,$this->id);
$returnStr = '<script type="text/javascript" src="' . getJSPath('include/javascript/swfobject.js') . '"></script>' . $chartStr;
return $this->getTitle('<div align="center"></div>') . '<div align="center">' . $returnStr . '</div><br />';
}
}
?>

View File

@@ -0,0 +1,37 @@
<?php
if(!defined('sugarEntry') || !sugarEntry) die('Not A Valid Entry Point');
/**
* The contents of this file are subject to the SugarCRM Professional Subscription
* Agreement ("License") which can be viewed at
* http://www.sugarcrm.com/crm/products/sugar-professional-eula.html
* By installing or using this file, You have unconditionally agreed to the
* terms and conditions of the License, and You may not use this file except in
* compliance with the License. Under the terms of the license, You shall not,
* among other things: 1) sublicense, resell, rent, lease, redistribute, assign
* or otherwise transfer Your rights to the Software, and 2) use the Software
* for timesharing or service bureau purposes such as hosting the Software for
* commercial gain and/or for the benefit of a third party. Use of the Software
* may be subject to applicable fees and any use of the Software without first
* paying applicable fees is strictly prohibited. You do not have the right to
* remove SugarCRM copyrights from the source code or user interface.
*
* All copies of the Covered Code must include on each user interface screen:
* (i) the "Powered by SugarCRM" logo and
* (ii) the SugarCRM copyright notice
* in the same form as they appear in the distribution. See full license for
* requirements.
*
* Your Warranty, Limitations of liability and Indemnity are expressly stated
* in the License. Please refer to the License for the specific language
* governing these rights and limitations under the License. Portions created
* by SugarCRM are Copyright (C) 2004-2007 SugarCRM, Inc.; All Rights Reserved.
*/
$dashletStrings['CampaignROIChartDashlet'] = array('LBL_TITLE' => 'Kampanie - Zwrot z Inwestycji',
'LBL_DESCRIPTION' => 'Wykres Zwrotu z Inwestycji',
'LBL_REFRESH' => 'Odświerz Wykres');
?>

View File

@@ -0,0 +1,145 @@
{*
/**
* 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".
*/
// $Id$
*}
<div style='width: 400px'>
<form name='configure_{$id}' action="index.php" method="post" onSubmit='return SUGAR.dashlets.postForm("configure_{$id}", SUGAR.mySugar.uncoverPage);'>
<input type='hidden' name='id' value='{$id}'>
<input type='hidden' name='module' value='{$module}'>
<input type='hidden' name='action' value='DynamicAction'>
<input type='hidden' name='DynamicAction' value='configureDashlet'>
<input type='hidden' name='to_pdf' value='true'>
<input type='hidden' name='configure' value='true'>
<input type='hidden' id='dashletType' name='dashletType' value='{$dashletType}' />
<table width="400" cellpadding="0" cellspacing="0" border="0" class="tabForm" align="center">
<tr>
<td valign='top' class='dataLabel' nowrap>{$LBL_TITLE} <br /></td>
<td valign='top' class='dataField'>
<input type="text" value="{$dashlet_title}" size="30" name="pbuts_dashlet_title"/>
</td>
</tr>
<tr>
<td valign='top' nowrap class='dataLabel'>{$LBL_ECMCALLS_DATE} <br><i>{$user_date_format}</i></td>
<td valign='top' class='dataField'>
<input onblur="parseDate(this, '{$cal_dateformat}');" class="text" name="pbuts_date" size='12' maxlength='10' id='pbuts_date' value='{$pbuts_date}'>
<img src="themes/default/images/jscalendar.gif" alt="{$LBL_ENTER_DATE}" id="pbuts_date_trigger" align="absmiddle">
</td>
</tr>
<tr>
<td valign='top' nowrap class='dataLabel'>{$LBL_ECMCALLS_DATE_SELECT}</td>
<td valign='top' class='dataField'>
<select name="pbuts_date_select">
{$pbuts_date_select_options}
</select>
</td>
</tr>
<tr>
<td valign='top' nowrap class='dataLabel'>{$LBL_ECMCALLS_TIME_FROM}</td>
<td valign='top' class='dataField'>
<select name="pbuts_time_from">
{$pbuts_time_from_options}
</select>
</td>
</tr>
<tr>
<td valign='top' nowrap class='dataLabel'>{$LBL_ECMCALLS_TIME_TO}</td>
<td valign='top' class='dataField'>
<select name="pbuts_time_to">
{$pbuts_time_to_options}
</select>
</td>
</tr>
<tr>
<td valign='top' class='dataLabel' nowrap>{$LBL_ECMCALLS_SHOW_NUMBERS}</td>
<td valign='top' class='dataField'>
<input type="checkbox" name="pbuts_show_numbers" {$pbuts_show_numbers}/>
</td>
</tr>
<tr>
<td valign='top' class='dataLabel' nowrap>{$LBL_ECMCALLS_USERS}</td>
<td valign='top' class='dataField'>
<select name="pbuts_users[]" multiple size='4'>
{$selected_datax_users}
</select><br /><br />
</td>
</tr>
<tr>
<td valign='top' class='dataLabel' nowrap>{$LBL_ECMCALLS_TYPE}</td>
<td valign='top' class='dataField'>
<select name="pbuts_type">
{$selected_datax_type}
</select>
</td>
</tr>
<tr>
<td valign='top' class='dataLabel' nowrap>{$LBL_ECMCALLS_WATCH}</td>
<td valign='top' class='dataField'>
<select name="pbuts_watch">
{$pbuts_watch}
</select>
&nbsp;>&nbsp;
<select name="pbuts_watch_seconds">
{$pbuts_watch_seconds}
</select>
</td>
</tr>
<tr>
<td align="right" colspan="2">
<input type='submit' onclick="" class='button' value='Submit'>
</td>
</tr>
</table>
</form>
{literal}
<script type="text/javascript">
Calendar.setup ({
inputField : "pbuts_date", ifFormat : "{/literal}{$cal_dateformat}{literal}", showsTime : false, button : "pbuts_date_trigger", singleClick : true, step : 1
});
{/literal}
</script>
</div>

View File

@@ -0,0 +1,47 @@
<?php
if(!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".
*/
$dashletStrings['EcmCallsDashlet'] = array(
'LBL_TITLE' => 'Calls',
'LBL_DESCRIPTION' => 'Scatter Graph',
'LBL_REFRESH' => 'Refresh Chart'
);
?>

View File

@@ -0,0 +1,40 @@
<?php
if(!defined('sugarEntry') || !sugarEntry) die('Not A Valid Entry Point');
/**
* The contents of this file are subject to the SugarCRM Enterprise Subscription
* Agreement ("License") which can be viewed at
* http://www.sugarcrm.com/crm/products/sugar-enterprise-eula.html
* By installing or using this file, You have unconditionally agreed to the
* terms and conditions of the License, and You may not use this file except in
* compliance with the License. Under the terms of the license, You shall not,
* among other things: 1) sublicense, resell, rent, lease, redistribute, assign
* or otherwise transfer Your rights to the Software, and 2) use the Software
* for timesharing or service bureau purposes such as hosting the Software for
* commercial gain and/or for the benefit of a third party. Use of the Software
* may be subject to applicable fees and any use of the Software without first
* paying applicable fees is strictly prohibited. You do not have the right to
* remove SugarCRM copyrights from the source code or user interface.
*
* All copies of the Covered Code must include on each user interface screen:
* (i) the "Powered by SugarCRM" logo and
* (ii) the SugarCRM copyright notice
* in the same form as they appear in the distribution. See full license for
* requirements.
*
* Your Warranty, Limitations of liability and Indemnity are expressly stated
* in the License. Please refer to the License for the specific language
* governing these rights and limitations under the License. Portions created
* by SugarCRM are Copyright (C) 2004-2007 SugarCRM, Inc.; All Rights Reserved.
*/
$dashletStrings['EcmCallsDashlet'] = array(
'LBL_TITLE' => 'Calls',
'LBL_DESCRIPTION' => 'Scatter Graph',
'LBL_REFRESH' => 'Refresh Chart'
);
?>

View File

@@ -0,0 +1,47 @@
<?php
if(!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".
*/
global $app_strings, $current_language;
$dashletMeta['EcmCallsDashlet'] = array('title' => translate('LBL_ECMCALLS_TITLE','Home'),
'description' => translate('LBL_ECMCALLS_TITLE','Home'),
'module' => 'EcmCalls',
'icon' => 'themes/default/images/icon_Charts_Funnel_32.gif',
'category' => 'Charts');
?>

View File

@@ -0,0 +1,586 @@
<?php
if(!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('include/Dashlets/Dashlet.php');
require_once('include/Sugar_Smarty.php');
require_once('include/charts/Charts.php');
require_once('modules/Dashboard/Forms.php');
$GLOBALS['db'] = new MysqlManager();
$GLOBALS['db']->connect();
class EcmCallsDashlet extends Dashlet {
var $pbuts_date;
var $pbuts_users = null;
var $pbuts_time_from;
var $pbuts_time_to;
var $pbuts_type;
var $pbuts_date_select;
var $pbuts_show_numbers;
var $pbuts_watch;
var $refresh = false;
function EcmCallsDashlet($id, $options) {
global $timedate,$current_user;
$_SESSION['EcmCallsChart'][$id][$current_user->id] = $options;
parent::Dashlet($id);
$this->isConfigurable = true;
$this->isRefreshable = true;
if(empty($options['pbuts_date']))
$this->pbuts_date = date($timedate->get_db_date_time_format(), time());
else
$this->pbuts_date = $options['pbuts_date'];
if(empty($options['pbuts_time_from']))
$this->pbuts_time_from = "07:00";//date($timedate->get_db_date_time_format(), time());
else
$this->pbuts_time_from = $options['pbuts_time_from'];
if(empty($options['pbuts_time_to']))
$this->pbuts_time_to = "18:00"; //date($timedate->get_db_date_time_format(), time());
else
$this->pbuts_time_to = $options['pbuts_time_to'];
if(empty($options['pbuts_type']))
$this->pbuts_type = "outgoing";
else
$this->pbuts_type = $options['pbuts_type'];
if(empty($options['pbuts_date_select']))
$this->pbuts_date_select = "THIS_DAY";
else
$this->pbuts_date_select = $options['pbuts_date_select'];
if(empty($options['pbuts_show_numbers']))
$this->pbuts_show_numbers = 0;
else
$this->pbuts_show_numbers = $options['pbuts_show_numbers'];
if(empty($options['pbuts_watch']))
$this->pbuts_watch = 'duration';
else
$this->pbuts_watch = $options['pbuts_watch'];
if(empty($options['pbuts_watch_seconds']))
$this->pbuts_watch_seconds = '60';
else
$this->pbuts_watch_seconds = $options['pbuts_watch_seconds'];
if(empty($options['pbuts_users']) || count($options['pbuts_users']) == 0) {
$query = "select id, user_name from users where deleted='0'";
$dbm = new MysqlManager();
$dbm->connect();
$results = $dbm->query($query);
$us = array();
if(is_resource($results))
while($row = $dbm->fetchByAssoc($results)) $us[] = $row['id'];
$this->pbuts_users = $us;
}
else
$this->pbuts_users = $options['pbuts_users'];
if(empty($options['title']))
$this->title = translate('LBL_ECMCALLS_TITLE', 'Home');
else
$this->title = $options['title'];
}
function saveOptions($req) {
global $sugar_config, $timedate, $current_user, $theme;
$options = array();
$options['title'] = $_REQUEST['pbuts_dashlet_title'];
$timeFormat = $current_user->getUserDateTimePreferences();
$options['pbuts_users'] = $_REQUEST['pbuts_users'];
$options['pbuts_date'] = $timedate->swap_formats($_REQUEST['pbuts_date'], $timeFormat['date'], $timedate->dbDayFormat);
$options['pbuts_time_from'] = $_REQUEST['pbuts_time_from'];
$options['pbuts_time_to'] = $_REQUEST['pbuts_time_to'];
$options['pbuts_type'] = $_REQUEST['pbuts_type'];
$options['pbuts_date_select'] = $_REQUEST['pbuts_date_select'];
$options['pbuts_watch'] = $_REQUEST['pbuts_watch'];
$options['pbuts_watch_seconds'] = $_REQUEST['pbuts_watch_seconds'];
if(isset($_REQUEST['pbuts_show_numbers']) && $_REQUEST['pbuts_show_numbers'] != '') $options['pbuts_show_numbers'] = 1; else $options['pbuts_show_numbers'] = 0;
return $options;
}
function displayOptions() {
global $timedate, $image_path, $app_strings, $current_user, $app_list_strings;
$ss = new Sugar_Smarty();
$ss->assign('id', $this->id);
$ss->assign('module', $_REQUEST['module']);
$ss->assign('dashletType', 'predefined_chart');
$ss->assign('LBL_TITLE', translate('LBL_ECMCALLS_TITLE', 'Charts'));
$ss->assign('LBL_CHART_TYPE', translate('LBL_CHART_TYPE', 'Charts'));
$ss->assign('LBL_ECMCALLS_DATE', translate('LBL_ECMCALLS_DATE', 'Charts'));
$ss->assign('LBL_ECMCALLS_USERS', translate('LBL_ECMCALLS_USERS', 'Charts'));
$ss->assign('LBL_ECMCALLS_TIME_TO', translate('LBL_ECMCALLS_TIME_TO', 'Charts'));
$ss->assign('LBL_ECMCALLS_TIME_FROM', translate('LBL_ECMCALLS_TIME_FROM', 'Charts'));
$ss->assign('LBL_ECMCALLS_TYPE', translate('LBL_ECMCALLS_TYPE', 'Charts'));
$ss->assign('LBL_ECMCALLS_DATE_SELECT', translate('LBL_ECMCALLS_DATE_SELECT', 'Charts'));
$ss->assign('LBL_ECMCALLS_SHOW_NUMBERS', translate('LBL_ECMCALLS_SHOW_NUMBERS', 'Charts'));
$ss->assign('LBL_ECMCALLS_WATCH', translate('LBL_ECMCALLS_WATCH', 'EcmCalls'));
$ss->assign('LBL_SELECT_BUTTON_TITLE', $app_strings['LBL_SELECT_BUTTON_TITLE']);
$ss->assign('image_path', $image_path);
//get the dates to display
$pbuts_date = $this->pbuts_date;
$timeFormat = $current_user->getUserDateTimePreferences();
$ss->assign('pbuts_date', $timedate->swap_formats($pbuts_date, $timedate->dbDayFormat, $timeFormat['date']));
$time_tf = array();
for($i=0; $i<=24*60; $i+=30) {
$time_tmp = sprintf("%02d:%02d",$i/60,$i%60);
$time_tf[$time_tmp] = $time_tmp;
}
$ss->assign('pbuts_time_from_options', get_select_options_with_id($time_tf,$this->pbuts_time_from));
$ss->assign('pbuts_time_to_options', get_select_options_with_id($time_tf,$this->pbuts_time_to));
$query = "select id, first_name,last_name from users where deleted='0'";
$dbm = new MysqlManager();
$dbm->connect();
$results = $dbm->query($query);
$us = array();
if(is_resource($results))
while($row = $dbm->fetchByAssoc($results)) $us[$row['id']] = $row['first_name']." ".$row['last_name'];
$ss->assign('dashlet_title', $this->title);
if(is_array($this->pbuts_users) && count($this->pbuts_users) > 0)
$selected_datax_users = $this->pbuts_users;
else
$selected_datax_users = $us;
$ss->assign('selected_datax_users', get_select_options_with_id($us, $selected_datax_users));
if(isset($this->pbuts_type) && $this->pbuts_type != '')
$selected_datax_type = $this->pbuts_type;
else
$selected_datax_type = 'outgoing';
$ss->assign('selected_datax_type', get_select_options_with_id($app_list_strings['ecmcalls_chart_call_type_dom'], $selected_datax_type));
if(isset($this->pbuts_date_select) && $this->pbuts_date_select != '')
$selected_datax_date_select = $this->pbuts_date_select;
else
$selected_datax_date_select = 'THIS_DAY';
$ss->assign('pbuts_date_select_options', get_select_options_with_id($app_list_strings['ecmcalls_chart_date_select_dom'], $selected_datax_date_select));
$ss->assign('pbuts_show_numbers', ($this->pbuts_show_numbers == 1 ? 'CHECKED' : ''));
$arr = array(
'duration' => translate('LBL_DURATION', 'EcmCalls'),
'billsec' => translate('LBL_BILLSEC', 'EcmCalls'),
);
$ss->assign('pbuts_watch', get_select_options_with_id($arr, $this->pbuts_watch));
$arr = array();
for($i=1;$i<=180;$i++) $arr[$i] = strval($i).'s';
$ss->assign('pbuts_watch_seconds', get_select_options_with_id($arr, $this->pbuts_watch_seconds));
$ss->assign('user_date_format', $timedate->get_user_date_format());
$ss->assign('cal_dateformat', $timedate->get_cal_date_format());
$ss->assign('module', $_REQUEST['module']);
return parent::displayOptions() . $ss->fetch('modules/Charts/Dashlets/EcmCallsDashlet/EcmCallsConfigure.tpl');
}
/**
* Displays the javascript for the dashlet
*
* @return string javascript to use with this dashlet
*/
function displayScript() {
global $sugar_config, $current_user, $current_language;
$xmlFile = $sugar_config['tmp_dir']. $current_user->id . '_' . $this->id . '.xml';
$chartStringsXML = 'cache/xml/chart_strings.' . $current_language .'.lang.xml';
$ss = new Sugar_Smarty();
$ss->assign('chartName', $this->id);
$ss->assign('chartXMLFile', $xmlFile);
$ss->assign('chartStyleCSS', chartStyle());
$ss->assign('chartColorsXML', chartColors());
$ss->assign('chartStringsXML', $chartStringsXML);
$str = '<script type="text/javascript">refreshMyEcmCallsChartDashlet("'.$this->id.'");</script>';
//$ss->fetch('modules/EcmCalls/chart/PredefinedChartDashletScript.tpl');
return $str;
}
function getTitle($text) {
global $image_path, $app_strings, $sugar_config;
if($this->isConfigurable)
$additionalTitle = '<table width="100%" cellspacing="0" cellpadding="0" border="0"><tr><td width="99%">' . $text
. '</td><td nowrap width="1%"><div style="width: 100%;text-align:right"><a href="#" onclick="SUGAR.mySugar.configureDashlet(\''
. $this->id . '\'); return false;" class="chartToolsLink">'
. get_image($image_path.'edit','title="' . translate('LBL_DASHLET_EDIT', 'Home') . '" alt="' . translate('LBL_DASHLET_EDIT', 'Home') . '" border="0" align="absmiddle"').'</a> '
. '';
else
$additionalTitle = '<table width="100%" cellspacing="0" cellpadding="0" border="0"><tr><td width="99%">' . $text
. '</td><td nowrap width="1%"><div style="width: 100%;text-align:right">';
if($this->isRefreshable)
$additionalTitle .= '<a href="#" onclick="refreshMyEcmCallsChartDashlet(\''.$this->id.'\');return false;"><img width="13" height="13" border="0" align="absmiddle" title="' . translate('LBL_DASHLET_REFRESH', 'Home') . '" alt="' . translate('LBL_DASHLET_REFRESH', 'Home') . '" src="'
. $image_path . 'refresh.gif"/></a> ';
$additionalTitle .= '<a href="#" onclick="SUGAR.mySugar.deleteDashlet(\''
. $this->id . '\'); return false;"><img width="13" height="13" border="0" align="absmiddle" title="' . translate('LBL_DASHLET_DELETE', 'Home') . '" alt="' . translate('LBL_DASHLET_DELETE', 'Home') . '" src="'
. $image_path . 'close_dashboard.gif"/></a></div></td></tr></table>';
if(!function_exists('get_form_header')) {
global $theme;
require_once('themes/'.$theme.'/layout_utils.php');
}
$str = '<div ';
if(empty($sugar_config['lock_homepage']) || $sugar_config['lock_homepage'] == false) $str .= ' onmouseover="this.style.cursor = \'move\';"';
$str .= 'id="dashlet_header_' . $this->id . '">' . get_form_header($this->title, $additionalTitle, false) . '</div>';
//$str .= $this->createAutoRefreshCode("refreshMyEcmCallsChartDashlet('".$this->id."');", true);
return $str;
}
function display() {
global $app_list_strings, $current_language, $sugar_config, $currentModule, $action, $current_user, $theme, $timedate, $image_path;
$this->loadLanguage('EcmCallsDashlet', 'modules/Charts/Dashlets/');
$returnStr = '';
$user_dateFormat = $timedate->get_date_format();
$current_module_strings = return_module_language($current_language, 'Charts');
if(isset($_REQUEST['pbuts_refresh'])) {
$refresh = $_REQUEST['pbuts_refresh'];
}
else {
$refresh = false;
}
$date_start = $this->pbuts_date_start;
$date_end = $this->pbuts_date_end;
// cn: format date_start|end to user's preferred
$dateStartDisplay = strftime($timedate->get_user_date_format(), strtotime($date_start));
$dateEndDisplay = strftime($timedate->get_user_date_format(), strtotime($date_end));
$seps = array("-", "/");
$dates = array($date_start, $date_end);
$dateFileNameSafe = str_replace($seps, "_", $dates);
$dateXml[0] = $date_start;
$dateXml[1] = $date_end;
$datax = array();
$selected_datax = array();
//get list of sales stage keys to display
$user_bug_status = $this->pbuts_ecmcall_status;
$tempx = $user_bug_status;
//set $datax using selected sales stage keys
if (count($tempx) > 0) {
foreach ($tempx as $key) {
$datax[$key] = $app_list_strings['bug_status_dom'][$key];
array_push($selected_datax, $key);
}
}
else {
$datax = $app_list_strings['bug_status_dom'];
$selected_datax = array_keys($app_list_strings['bug_status_dom']);
}
$GLOBALS['log']->debug("datax is:");
$GLOBALS['log']->debug($datax);
$ids = array();
$new_ids = array();
$user_ids = $current_user->getPreference('pbuts_ids');
//get list of user ids for which to display data
if (!empty($user_ids) && count($user_ids) != 0 && !isset($_REQUEST['pbuts_ids'])) {
$ids = $user_ids;
$GLOBALS['log']->debug("USER PREFERENCES['pbuts_ids'] is:");
$GLOBALS['log']->debug($user_ids);
}
elseif (isset($_REQUEST['pbuts_ids']) && count($_REQUEST['pbuts_ids']) > 0) {
$ids = $_REQUEST['pbuts_ids'];
$current_user->setPreference('pbuts_ids', $_REQUEST['pbuts_ids']);
$GLOBALS['log']->debug("_REQUEST['pbuts_ids'] is:");
$GLOBALS['log']->debug($_REQUEST['pbuts_ids']);
$GLOBALS['log']->debug("USER PREFERENCES['pbuts_ids'] is:");
$GLOBALS['log']->debug($current_user->getPreference('pbuts_ids'));
}
else {
$ids = get_user_array(false);
$ids = array_keys($ids);
}
//create unique prefix based on selected users for image files
$id_hash = '1';
if (isset($ids)) {
sort($ids);
$id_hash = crc32(implode('',$ids));
if($id_hash < 0)
{
$id_hash = $id_hash * -1;
}
}
$GLOBALS['log']->debug("ids is:");
$GLOBALS['log']->debug($ids);
$id_md5 = substr(md5($current_user->id),0,9);
$seps = array("-", "/");
$dates = array($dateStartDisplay, $dateEndDisplay);
$dateFileNameSafe = str_replace($seps, "_", $dates);
$cache_file_name = $current_user->getUserPrivGuid()."_".$theme."_my_pipeline_".$dateFileNameSafe[0]."_".$dateFileNameSafe[1].".xml";
$GLOBALS['log']->debug("cache file name is: $cache_file_name");
if (file_exists($sugar_config['tmp_dir'].$cache_file_name)) {
$file_date = date($timedate->get_date_format()." ".$timedate->get_time_format(), filemtime($sugar_config['tmp_dir'].$cache_file_name));
}
else {
$file_date = '';
}
require_once('include/Sugar_Smarty.php');
require_once('modules/EcmCalls/chart/EcmCallsChart.php');
$sugar_smarty = new Sugar_Smarty();
$charts = array();
$sugarChart = new EcmCallsChart();
$sugarChart->base_url = array( 'module' => 'Bugs',
'action' => 'index',
'query' => 'true',
'searchFormTab' => 'advanced_search',
);
$sugarChart->url_params = array();
$ids = $this->pbuts_ecmcall_users;
global $app_list_strings;
$sugarChart->enum_for_labels = array( 'status' => $app_list_strings['bug_status_dom'] );
$sugarChart->group_by = $this->constructGroupBy();
$query = $this->constructQuery($datax, $dateXml[0], $dateXml[1], $ids, $sugar_config['tmp_dir'].$cache_file_name, $refresh,'hBarS',$current_module_strings);
$sugarChart->setData($this->getChartData($query));
$total = $sugarChart->getTotal();
$currency_symbol = $sugar_config['default_currency_symbol'];
if ($current_user->getPreference('currency')){
require_once('modules/Currencies/Currency.php');
$currency = new Currency();
$currency->retrieve($current_user->getPreference('currency'));
$currency_symbol = $currency->symbol;
}
$sugarChart->is_currency = false;
$sugarChart->currency_symbol = '';
$sugarChart->thousands_symbol = '';//translate('LBL_OPP_THOUSANDS', 'Charts');
$subtitle = translate('LBL_BUG_SIZE', 'Charts');
$pipeline_total_string = translate('LBL_BUGS_TOTAL', 'Charts') . $total;
$sugarChart->setProperties($pipeline_total_string, $subtitle, 'horizontal group by chart');
$xmlFile = $sugar_config['tmp_dir']. $current_user->id . '_' . $this->id . '.xml';
//$sugarChart->saveXMLFile($xmlFile, $sugarChart->generateXML());
$returnStr .= $sugarChart->display($this->id, $xmlFile, '100%', '480', false);
return $this->getTitle('') . '<div align="center">' .$returnStr. '</div><br />';
}
// awu: Bug 16794 - this function is a hack to get the correct sales stage order until i can clean it up later
function getChartData($query){
/*
global $app_list_strings, $current_user, $sugar_config;
$data = array();
$temp_data = array();
$selected_datax = array();
$user_bug_status = $this->pbuts_ecmcall_status;
$tempx = $user_bug_status;
//set $datax using selected sales stage keys
if (count($tempx) > 0) {
foreach ($tempx as $key) {
$datax[$key] = $app_list_strings['bug_status_dom'][$key];
array_push($selected_datax, $key);
}
}
else {
$datax = $app_list_strings['bug_status_dom'];
$selected_datax = array_keys($app_list_strings['bug_status_dom']);
}
$db = &PearDatabase::getInstance();
$result = $db->query($query);
$row = $db->fetchByAssoc($result, -1, false);
while($row != null){
array_push($temp_data, $row);
$row = $db->fetchByAssoc($result, -1, false);
}
// reorder and set the array based on the order of selected_datax
foreach($selected_datax as $bug_status){
foreach($temp_data as $key => $value){
if ($value['status'] == $bug_status){
//$value['total'] = $symbol . $value['total'];
//$value['status'] = $app_list_strings['bug_status_dom'][$value['status']];
array_push($data, $value);
unset($temp_data[$key]);
}
}
}
*/
//echo '<br><br>'; var_dump($data);
return $data;
}
function constructQuery($datax=array('foo','bar'), $date_start='2071-10-15', $date_end='2071-10-15', $user_id=array('1'), $cache_file_name='a_file', $refresh=false,$chart_size='hBarF',$current_module_strings) {
/*
global $app_strings, $charset, $lang, $barChartColors, $current_user;
require_once('modules/Opportunities/Opportunity.php');
require_once('modules/Currencies/Currency.php');
$kDelim = $current_user->getPreference('num_grp_sep');
global $timedate;
$opp = new Opportunity;
$where="";
//build the where clause for the query that matches $user
$count = count($user_id);
$id = array();
$user_list = get_user_array(false);
foreach ($user_id as $key) {
$new_ids[$key] = $user_list[$key];
}
if ($count>0) {
foreach ($new_ids as $the_id=>$the_name) {
$id[] = "'".$the_id."'";
}
$ids = join(",",$id);
$where .= " bugs.assigned_user_id IN ($ids) ";
}
//build the where clause for the query that matches $datax
$count = count($datax);
$dataxArr = array();
if ($count>0) {
foreach ($datax as $key=>$value) {
$dataxArr[] = "'".$key."'";
}
$dataxArr = join(",",$dataxArr);
$where .= "AND bugs.status IN ($dataxArr) ";
}
//build the where clause for the query that matches $date_start and $date_end
$where .= " AND bugs.date_entered >= ". db_convert("'".$date_start."'",'datetime'). "
AND bugs.date_entered <= ".db_convert("'".$date_end."'",'datetime') ;
$where .= " AND bugs.assigned_user_id = users.id AND bugs.deleted=0 ";
//Now do the db queries
//query for opportunity data that matches $datax and $user
$query = " SELECT bugs.status as status,
users.user_name,
bugs.assigned_user_id,
count( * ) AS opp_count,
count( bugs.assigned_user_id ) AS total
FROM users, bugs ";
$query .= "WHERE " .$where;
$query .= " GROUP BY bugs.status";
$query .= ", users.user_name, bugs.assigned_user_id";
//var_dump($query);
//$res = $GLOBALS['db']->query($query);
//var_dump($res);
//var_dump($query);
*/
return $query;
}
function constructGroupBy(){
return array();
}
}
?>

View File

@@ -0,0 +1,37 @@
<?php
if(!defined('sugarEntry') || !sugarEntry) die('Not A Valid Entry Point');
/**
* The contents of this file are subject to the SugarCRM Professional Subscription
* Agreement ("License") which can be viewed at
* http://www.sugarcrm.com/crm/products/sugar-professional-eula.html
* By installing or using this file, You have unconditionally agreed to the
* terms and conditions of the License, and You may not use this file except in
* compliance with the License. Under the terms of the license, You shall not,
* among other things: 1) sublicense, resell, rent, lease, redistribute, assign
* or otherwise transfer Your rights to the Software, and 2) use the Software
* for timesharing or service bureau purposes such as hosting the Software for
* commercial gain and/or for the benefit of a third party. Use of the Software
* may be subject to applicable fees and any use of the Software without first
* paying applicable fees is strictly prohibited. You do not have the right to
* remove SugarCRM copyrights from the source code or user interface.
*
* All copies of the Covered Code must include on each user interface screen:
* (i) the "Powered by SugarCRM" logo and
* (ii) the SugarCRM copyright notice
* in the same form as they appear in the distribution. See full license for
* requirements.
*
* Your Warranty, Limitations of liability and Indemnity are expressly stated
* in the License. Please refer to the License for the specific language
* governing these rights and limitations under the License. Portions created
* by SugarCRM are Copyright (C) 2004-2007 SugarCRM, Inc.; All Rights Reserved.
*/
$dashletStrings['MyForecastingChartDashlet'] = array('LBL_TITLE' => 'Moje Prognozy',
'LBL_DESCRIPTION' => 'Udział Założony/Aktualny',
'LBL_REFRESH' => 'Odświerz Wykres');
?>

View File

@@ -0,0 +1,37 @@
<?php
if(!defined('sugarEntry') || !sugarEntry) die('Not A Valid Entry Point');
/**
* The contents of this file are subject to the SugarCRM Professional Subscription
* Agreement ("License") which can be viewed at
* http://www.sugarcrm.com/crm/products/sugar-professional-eula.html
* By installing or using this file, You have unconditionally agreed to the
* terms and conditions of the License, and You may not use this file except in
* compliance with the License. Under the terms of the license, You shall not,
* among other things: 1) sublicense, resell, rent, lease, redistribute, assign
* or otherwise transfer Your rights to the Software, and 2) use the Software
* for timesharing or service bureau purposes such as hosting the Software for
* commercial gain and/or for the benefit of a third party. Use of the Software
* may be subject to applicable fees and any use of the Software without first
* paying applicable fees is strictly prohibited. You do not have the right to
* remove SugarCRM copyrights from the source code or user interface.
*
* All copies of the Covered Code must include on each user interface screen:
* (i) the "Powered by SugarCRM" logo and
* (ii) the SugarCRM copyright notice
* in the same form as they appear in the distribution. See full license for
* requirements.
*
* Your Warranty, Limitations of liability and Indemnity are expressly stated
* in the License. Please refer to the License for the specific language
* governing these rights and limitations under the License. Portions created
* by SugarCRM are Copyright (C) 2004-2007 SugarCRM, Inc.; All Rights Reserved.
*/
$dashletStrings['MyOpportunitiesGaugeDashlet'] = array('LBL_TITLE' => 'Moje zamknięte Tematy',
'LBL_DESCRIPTION' => 'Wskaźnik Tematów',
'LBL_REFRESH' => 'Odswierz Wykres');
?>

View File

@@ -0,0 +1,109 @@
{*
/**
* SugarCRM is a customer relationship management program developed by
* SugarCRM, Inc. Copyright (C) 2004 - 2009 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".
*/
*}
<div style='width: 400px'>
<form name='configure_{$id}' action="index.php" method="post" onSubmit='return SUGAR.dashlets.postForm("configure_{$id}", SUGAR.mySugar.uncoverPage);'>
<input type='hidden' name='id' value='{$id}'>
<input type='hidden' name='module' value='{$module}'>
<input type='hidden' name='action' value='DynamicAction'>
<input type='hidden' name='DynamicAction' value='configureDashlet'>
<input type='hidden' name='to_pdf' value='true'>
<input type='hidden' name='configure' value='true'>
<input type='hidden' id='dashletType' name='dashletType' value='{$dashletType}' />
<table width="400" cellpadding="0" cellspacing="0" border="0" class="tabForm" align="center">
<tr>
<td valign='top' class='dataLabel' nowrap>{$LBL_TITLE} <br /></td>
<td valign='top' class='dataField'>
<input type="text" value="{$dashlet_title}" size="30" name="mypbss_dashlet_title"/>
</td>
</tr>
<tr>
<td valign='top' nowrap class='dataLabel'>{$LBL_DATE_START} <br><i>{$user_date_format}</i></td>
<td valign='top' class='dataField'>
<input onblur="parseDate(this, '{$cal_dateformat}');" class="text" name="mypbss_date_start" size='12' maxlength='10' id='date_start' value='{$date_start}'>
<img src="themes/default/images/jscalendar.gif" alt="{$LBL_ENTER_DATE}" id="date_start_trigger" align="absmiddle">
</td>
</tr>
<tr>
<td valign='top' nowrap class='dataLabel'>{$LBL_DATE_END}<br><i>{$user_date_format}</i></td>
<td valign='top' class='dataField'>
<input onblur="parseDate(this, '{$cal_dateformat}');" class="text" name="mypbss_date_end" size='12' maxlength='10' id='date_end' value='{$date_end}'>
<img src="themes/default/images/jscalendar.gif" alt="{$LBL_ENTER_DATE}" id="date_end_trigger" align="absmiddle">
</td>
</tr>
<tr>
<td valign='top' class='dataLabel' nowrap>{$LBL_SALES_STAGES}</td>
<td valign='top' class='dataField'>
<select name="mypbss_sales_stages[]" multiple size='3'>
{$selected_datax}
</select></td>
</tr>
<tr>
<td align="right" colspan="2">
<input type='submit' onclick="" class='button' value='{$LBL_SUBMIT_BUTTON_LABEL}'>
</td>
</tr>
</table>
</form>
{literal}
<script type="text/javascript">
Calendar.setup ({
inputField : "date_start", ifFormat : "{/literal}{$cal_dateformat}{literal}", showsTime : false, button : "date_start_trigger", singleClick : true, step : 1
});
Calendar.setup ({
inputField : "date_end", ifFormat : "{/literal}{$cal_dateformat}{literal}", showsTime : false, button : "date_end_trigger", singleClick : true, step : 1
});
{/literal}
</script>
</div>

View File

@@ -0,0 +1,64 @@
<?php
if(!defined('sugarEntry') || !sugarEntry) die('Not A Valid Entry Point');
/**
* SugarCRM is a customer relationship management program developed by
* SugarCRM, Inc. Copyright (C) 2004 - 2009 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".
*/
$dashletData['MyPipelineBySalesStageDashlet']['searchFields'] = array(
'mypbss_date_start' => array(
'name' => 'mypbss_date_start',
'vname' => 'LBL_DATE_START',
'type' => 'datepicker',
),
'mypbss_date_end' => array(
'name' => 'mypbss_date_end',
'vname' => 'LBL_DATE_END',
'type' => 'datepicker',
),
'mypbss_sales_stages' => array(
'name' => 'mypbss_sales_stages',
'vname' => 'LBL_SALES_STAGES',
'type' => 'enum',
),
);
?>

View File

@@ -0,0 +1,45 @@
<?php
if(!defined('sugarEntry') || !sugarEntry) die('Not A Valid Entry Point');
/**
* SugarCRM is a customer relationship management program developed by
* SugarCRM, Inc. Copyright (C) 2004 - 2009 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".
*/
$dashletStrings['MyPipelineBySalesStageDashlet'] = array('LBL_TITLE' => 'My Pipeline By Sales Stage',
'LBL_DESCRIPTION' => 'Vertical Bar Chart of My Sales Stage Pipeline',
'LBL_REFRESH' => 'Refresh Chart');
?>

View File

@@ -0,0 +1,45 @@
<?php
if(!defined('sugarEntry') || !sugarEntry) die('Not A Valid Entry Point');
/**
* SugarCRM is a customer relationship management program developed by
* SugarCRM, Inc. Copyright (C) 2004 - 2009 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".
*/
$dashletStrings['MyPipelineBySalesStageDashlet'] = array('LBL_TITLE' => 'Meine Pipeline nach Verkaufsphasen',
'LBL_DESCRIPTION' => 'Vertikales Balkendiagramm der Pipeline nach Verkaufsphasen',
'LBL_REFRESH' => 'Diagramm neu laden');
?>

View File

@@ -0,0 +1,47 @@
<?php
if(!defined('sugarEntry') || !sugarEntry) die('Not A Valid Entry Point');
/**
* SugarCRM is a customer relationship management program developed by
* SugarCRM, Inc. Copyright (C) 2004 - 2009 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".
*/
global $app_strings, $current_language;
$dashletMeta['MyPipelineBySalesStageDashlet'] = array('title' => 'LBL_TITLE',
'description' => 'LBL_TITLE',
'icon' => 'themes/default/images/icon_Charts_Funnel_32.gif',
'module' => 'Opportunities',
'category' => 'Charts');
?>

View File

@@ -0,0 +1,282 @@
<?php
if(!defined('sugarEntry') || !sugarEntry) die('Not A Valid Entry Point');
/**
* SugarCRM is a customer relationship management program developed by
* SugarCRM, Inc. Copyright (C) 2004 - 2009 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('include/Dashlets/DashletGenericChart.php');
class MyPipelineBySalesStageDashlet extends DashletGenericChart
{
public $mypbss_date_start;
public $mypbss_date_end;
public $mypbss_sales_stages = array();
protected $_seedName = 'Opportunities';
/**
* @see DashletGenericChart::__construct()
*/
public function __construct(
$id,
array $options = null
)
{
global $timedate;
if(empty($options['mypbss_date_start']))
$options['mypbss_date_start'] = date($timedate->get_db_date_time_format(), time());
if(empty($options['mypbss_date_end']))
$options['mypbss_date_end'] = date($timedate->get_db_date_time_format(), strtotime('2010-01-01'));
if(empty($options['title']))
$options['title'] = translate('LBL_MY_PIPELINE_FORM_TITLE', 'Home');
parent::__construct($id,$options);
}
/**
* @see DashletGenericChart::displayOptions()
*/
public function displayOptions()
{
global $app_list_strings;
$selected_datax = array();
if (count($this->mypbss_sales_stages) > 0)
foreach ($this->mypbss_sales_stages as $key)
$selected_datax[] = $key;
else
$selected_datax = array_keys($app_list_strings['sales_stage_dom']);
$this->_searchFields['mypbss_sales_stages']['options'] = $app_list_strings['sales_stage_dom'];
$this->_searchFields['mypbss_sales_stages']['input_name0'] = $selected_datax;
return parent::displayOptions();
}
/**
* @see DashletGenericChart::display()
*/
public function display()
{
global $sugar_config, $current_user;
require_once('include/SugarCharts/SugarChart.php');
$sugarChart = new SugarChart();
$sugarChart->base_url = array( 'module' => 'Opportunities',
'action' => 'index',
'query' => 'true',
'searchFormTab' => 'advanced_search',
);
$sugarChart->url_params = array( 'assigned_user_id' => $current_user->id );
$sugarChart->group_by = $this->constructGroupBy();
$currency_symbol = $sugar_config['default_currency_symbol'];
if ($current_user->getPreference('currency')){
require_once('modules/Currencies/Currency.php');
$currency = new Currency();
$currency->retrieve($current_user->getPreference('currency'));
$currency_symbol = $currency->symbol;
}
$sugarChart->is_currency = true;
$sugarChart->thousands_symbol = translate('LBL_OPP_THOUSANDS', 'Charts');
$subtitle = translate('LBL_OPP_SIZE', 'Charts') . " " . $currency_symbol . "1" . translate('LBL_OPP_THOUSANDS', 'Charts');
$query = $this->constructQuery();
$dataset = $this->constructCEChartData($this->getChartData($query));
$sugarChart->setData($dataset);
$total = format_number($this->getHorizBarTotal($dataset), 0, 0);
$pipeline_total_string = translate('LBL_TOTAL_PIPELINE', 'Charts') . $sugarChart->currency_symbol . $total . $sugarChart->thousands_symbol;
$sugarChart->setProperties($pipeline_total_string, $subtitle, 'horizontal bar chart');
$xmlFile = $sugarChart->getXMLFileName($this->id);
$sugarChart->saveXMLFile($xmlFile, $sugarChart->generateXML());
return $this->getTitle('') .
'<div align="center">' .$sugarChart->display($this->id, $xmlFile, '100%', '480', false) . '</div><br />';
}
/**
* awu: Bug 16794 - this function is a hack to get the correct sales stage order
* until i can clean it up later
*
* @param $query string
* @return array
*/
private function getChartData(
$query
)
{
global $app_list_strings, $db;
$data = array();
$temp_data = array();
$selected_datax = array();
$user_sales_stage = $this->mypbss_sales_stages;
$tempx = $user_sales_stage;
//set $datax using selected sales stage keys
if (count($tempx) > 0) {
foreach ($tempx as $key) {
$datax[$key] = $app_list_strings['sales_stage_dom'][$key];
array_push($selected_datax, $key);
}
}
else {
$datax = $app_list_strings['sales_stage_dom'];
$selected_datax = array_keys($app_list_strings['sales_stage_dom']);
}
$result = $db->query($query);
$row = $db->fetchByAssoc($result, -1, false);
while($row != null){
$temp_data[] = $row;
$row = $db->fetchByAssoc($result, -1, false);
}
// reorder and set the array based on the order of selected_datax
foreach($selected_datax as $sales_stage){
foreach($temp_data as $key => $value){
if ($value['sales_stage'] == $sales_stage){
$value['sales_stage'] = $app_list_strings['sales_stage_dom'][$value['sales_stage']];
$value['key'] = $sales_stage;
$value['value'] = $value['sales_stage'];
$data[] = $value;
unset($temp_data[$key]);
}
}
}
return $data;
}
/**
* @param $dataset array
* @return int
*/
private function getHorizBarTotal(
$dataset
)
{
$total = 0;
foreach($dataset as $value){
$total += $value;
}
return $total;
}
/**
* @param $dataset array
* @return array
*/
private function constructCEChartData(
$dataset
)
{
$newData = array();
foreach($dataset as $key=>$value){
$newData[$value['sales_stage']] = $value['total'];
}
return $newData;
}
/**
* @see DashletGenericChart::constructQuery()
*/
protected function constructQuery()
{
$query = "SELECT opportunities.sales_stage,
users.user_name,
opportunities.assigned_user_id,
count( * ) AS opp_count,
sum(amount_usdollar/1000) AS total
FROM users,opportunities ";
$query .= " WHERE opportunities.assigned_user_id IN ('{$GLOBALS['current_user']->id}') " .
" AND opportunities.date_closed >= ". db_convert("'".$this->mypbss_date_start."'",'datetime').
" AND opportunities.date_closed <= ".db_convert("'".$this->mypbss_date_end."'",'datetime') .
" AND opportunities.assigned_user_id = users.id AND opportunities.deleted=0 ";
if ( count($this->mypbss_sales_stages) > 0 )
$query .= " AND opportunities.sales_stage IN ('" . implode("','",$this->mypbss_sales_stages) . "') ";
$query .= " GROUP BY opportunities.sales_stage ,users.user_name,opportunities.assigned_user_id";
return $query;
}
/**
* @see DashletGenericChart::constructGroupBy()
*/
protected function constructGroupBy()
{
$groupBy = array('sales_stage');
array_push($groupBy, 'user_name');
return $groupBy;
}
}
?>

View File

@@ -0,0 +1,42 @@
<?php
if(!defined('sugarEntry') || !sugarEntry) die('Not A Valid Entry Point');
/*********************************************************************************
* The contents of this file are subject to the SugarCRM Public License Version
* 1.1.3 ("License"); You may not use this file except in compliance with the
* License. You may obtain a copy of the License at http://www.sugarcrm.com/SPL
* Software distributed under the License is distributed on an "AS IS" basis,
* WITHOUT WARRANTY OF ANY KIND, either express or implied. See the License
* for the specific language governing rights and limitations under the
* License.
*
* All copies of the Covered Code must include on each user interface screen:
* (i) the "Powered by SugarCRM" logo and
* (ii) the SugarCRM copyright notice
* in the same form as they appear in the distribution. See full license for
* requirements.
*
* The Original Code is: SugarCRM Open Source
* The Initial Developer of the Original Code is SugarCRM, Inc.
* Portions created by SugarCRM are Copyright (C) 2004-2005 SugarCRM, Inc.;
* All Rights Reserved.
* Contributor(s): ______________________________________.
********************************************************************************/
/*********************************************************************************
* pl_pl.lang.ext.php,v for SugarCRM 4.5-->>
* Translator: Krzysztof Morawski
* All Rights Reserved.
* Any bugs report welcome: krzysiek<at>mojsklepik<dot>net
* Contributor(s): ______________________________________..
********************************************************************************/
// $Id: MyPipelineBySalesStageDashlet.en_us.lang.php,v 1.3 2006/08/22 20:14:45 wayne Exp $
$dashletStrings['MyPipelineBySalesStageDashlet'] = array('LBL_TITLE' => 'Lejek Etapów Sprzedaży',
'LBL_DESCRIPTION' => 'Pionowa Belka Wykresu Lejka Etapów Sprzedaży',
'LBL_REFRESH' => 'Odświerz Wykres');
?>

View File

@@ -0,0 +1,78 @@
{*
/**
* SugarCRM is a customer relationship management program developed by
* SugarCRM, Inc. Copyright (C) 2004 - 2009 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".
*/
*}
<div style='width: 400px'>
<form name='configure_{$id}' action="index.php" method="post" onSubmit='return SUGAR.dashlets.postForm("configure_{$id}", SUGAR.mySugar.uncoverPage);' />
<input type='hidden' name='id' value='{$id}' />
<input type='hidden' name='module' value='{$module}' />
<input type='hidden' name='action' value='DynamicAction' />
<input type='hidden' name='DynamicAction' value='configureDashlet' />
<input type='hidden' name='to_pdf' value='true' />
<input type='hidden' name='configure' value='true' />
<input type='hidden' id='dashletType' name='dashletType' value='{$dashletType}' />
<table width="400" cellpadding="10" cellspacing="0" border="0" class="tabForm" align="center">
<tr>
<td valign='top' nowrap class='dataLabel'>{$LBL_LEAD_SOURCES}</td>
<td valign='top' class='dataField'>
<select name="lsbo_lead_sources[]" multiple size='3'>
{$selected_datax}
</select>
</td>
</tr>
<tr>
<td valign='top' nowrap class='dataLabel'>{$LBL_USERS}</td>
<td valign='top' class='dataField'>
<select name="lsbo_ids[]" multiple size='3'>
{$lsbo_ids}
</select>
</td>
</tr>
<tr>
<td align="right" colspan="2">
<input type='submit' onclick="" class='button' value='{$LBL_SUBMIT_BUTTON_LABEL}'>
</td>
</tr>
</table>
</form>
</div>

View File

@@ -0,0 +1,52 @@
<?php
if(!defined('sugarEntry') || !sugarEntry) die('Not A Valid Entry Point');
/**
* SugarCRM is a customer relationship management program developed by
* SugarCRM, Inc. Copyright (C) 2004 - 2009 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".
*/
$dashletData['OpportunitiesByLeadSourceByOutcomeDashlet']['searchFields'] = array(
'lsbo_lead_sources' => array(
'name' => 'lsbo_lead_sources',
'vname' => 'LBL_LEAD_SOURCES',
'type' => 'enum',
),
'lsbo_ids' => array(
'name' => 'lsbo_ids',
'vname' => 'LBL_USERS',
'type' => 'user_name',
),
);
?>

View File

@@ -0,0 +1,45 @@
<?php
if(!defined('sugarEntry') || !sugarEntry) die('Not A Valid Entry Point');
/**
* SugarCRM is a customer relationship management program developed by
* SugarCRM, Inc. Copyright (C) 2004 - 2009 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".
*/
$dashletStrings['OpportunitiesByLeadSourceByOutcomeDashlet'] = array('LBL_TITLE' => 'All Opportunities By Lead Source By Outcome',
'LBL_DESCRIPTION' => 'Horizontal stacked chart of Opportunities By Lead Source By Outcome',
'LBL_REFRESH' => 'Refresh Chart');
?>

View File

@@ -0,0 +1,45 @@
<?php
if(!defined('sugarEntry') || !sugarEntry) die('Not A Valid Entry Point');
/**
* SugarCRM is a customer relationship management program developed by
* SugarCRM, Inc. Copyright (C) 2004 - 2009 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".
*/
$dashletStrings['OpportunitiesByLeadSourceByOutcomeDashlet'] = array('LBL_TITLE' => 'Alle Verkaufschancen nach Quelle und Ergebnis',
'LBL_DESCRIPTION' => 'Horizontal geschichtetes Diagramm der Verkaufschancen nach Quelle und Ergebnis',
'LBL_REFRESH' => 'Diagramm neu laden');
?>

View File

@@ -0,0 +1,47 @@
<?php
if(!defined('sugarEntry') || !sugarEntry) die('Not A Valid Entry Point');
/**
* SugarCRM is a customer relationship management program developed by
* SugarCRM, Inc. Copyright (C) 2004 - 2009 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".
*/
global $app_strings, $current_language;
$dashletMeta['OpportunitiesByLeadSourceByOutcomeDashlet'] = array('title' => 'LBL_TITLE',
'description' => 'LBL_TITLE',
'icon' => 'themes/default/images/icon_Charts_Horizontal_32.gif',
'module' => 'Opportunities',
'category' => 'Charts');
?>

View File

@@ -0,0 +1,121 @@
<?php
if(!defined('sugarEntry') || !sugarEntry) die('Not A Valid Entry Point');
/**
* SugarCRM is a customer relationship management program developed by
* SugarCRM, Inc. Copyright (C) 2004 - 2009 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('include/Dashlets/DashletGenericChart.php');
class OpportunitiesByLeadSourceByOutcomeDashlet extends DashletGenericChart
{
public $lsbo_lead_sources = array();
public $lsbo_ids = array();
protected $_seedName = 'Opportunities';
public function displayOptions()
{
global $app_list_strings;
$selected_datax = array();
if (!empty($this->lsbo_lead_sources) && sizeof($this->lsbo_lead_sources) > 0)
foreach ($this->lsbo_lead_sources as $key)
$selected_datax[] = $key;
else
$selected_datax = array_keys($app_list_strings['lead_source_dom']);
$this->_searchFields['lsbo_lead_sources']['options'] = array_filter($app_list_strings['lead_source_dom']);
$this->_searchFields['lsbo_lead_sources']['input_name0'] = $selected_datax;
if (!isset($this->lsbo_ids) || count($this->lsbo_ids) == 0)
$this->_searchFields['lsbo_ids']['input_name0'] = array_keys(get_user_array(false));
return parent::displayOptions();
}
public function display()
{
global $current_user, $sugar_config;
require("modules/Charts/chartdefs.php");
$chartDef = $chartDefs['lead_source_by_outcome'];
require_once('include/SugarCharts/SugarChart.php');
$sugarChart = new SugarChart();
$sugarChart->is_currency = true;
$currency_symbol = $sugar_config['default_currency_symbol'];
if ($current_user->getPreference('currency')){
require_once('modules/Currencies/Currency.php');
$currency = new Currency();
$currency->retrieve($current_user->getPreference('currency'));
$currency_symbol = $currency->symbol;
}
$subtitle = translate('LBL_OPP_SIZE', 'Charts') . " " . $currency_symbol . "1" . translate('LBL_OPP_THOUSANDS', 'Charts');
$sugarChart->setProperties('', $subtitle, $chartDef['chartType']);
$sugarChart->base_url = $chartDef['base_url'];
$sugarChart->group_by = $chartDef['groupBy'];
$sugarChart->url_params = array();
if ( count($this->lsbo_ids) > 0 )
$sugarChart->url_params['assigned_user_id'] = array_values($this->lsbo_ids);
$sugarChart->getData($this->constuctQuery());
$sugarChart->data_set = $sugarChart->sortData($sugarChart->data_set, 'lead_source', true, 'sales_stage', true, true);
$xmlFile = $sugarChart->getXMLFileName($this->id);
$sugarChart->saveXMLFile($xmlFile, $sugarChart->generateXML());
return $this->getTitle('<div align="center"></div>') .
'<div align="center">' . $sugarChart->display($this->id, $xmlFile, '100%', '480', false) . '</div><br />';
}
protected function constuctQuery()
{
$query = "SELECT lead_source,sales_stage,sum(amount_usdollar/1000) as total, ".
"count(*) as opp_count FROM opportunities ";
$query .= " WHERE opportunities.deleted=0 ";
if ( count($this->lsbo_ids) > 0 )
$query .= "AND opportunities.assigned_user_id IN ('".implode("','",$this->lsbo_ids)."') ";
if ( count($this->lsbo_lead_sources) > 0 )
$query .= "AND opportunities.lead_source IN ('".implode("','",$this->lsbo_lead_sources)."') ";
else
$query .= "AND opportunities.lead_source IN ('".implode("','",array_keys($GLOBALS['app_list_strings']['lead_source_dom']))."') ";
$query .= " GROUP BY sales_stage,lead_source ORDER BY lead_source,sales_stage";
return $query;
}
}
?>

View File

@@ -0,0 +1,37 @@
<?php
if(!defined('sugarEntry') || !sugarEntry) die('Not A Valid Entry Point');
/**
* The contents of this file are subject to the SugarCRM Professional Subscription
* Agreement ("License") which can be viewed at
* http://www.sugarcrm.com/crm/products/sugar-professional-eula.html
* By installing or using this file, You have unconditionally agreed to the
* terms and conditions of the License, and You may not use this file except in
* compliance with the License. Under the terms of the license, You shall not,
* among other things: 1) sublicense, resell, rent, lease, redistribute, assign
* or otherwise transfer Your rights to the Software, and 2) use the Software
* for timesharing or service bureau purposes such as hosting the Software for
* commercial gain and/or for the benefit of a third party. Use of the Software
* may be subject to applicable fees and any use of the Software without first
* paying applicable fees is strictly prohibited. You do not have the right to
* remove SugarCRM copyrights from the source code or user interface.
*
* All copies of the Covered Code must include on each user interface screen:
* (i) the "Powered by SugarCRM" logo and
* (ii) the SugarCRM copyright notice
* in the same form as they appear in the distribution. See full license for
* requirements.
*
* Your Warranty, Limitations of liability and Indemnity are expressly stated
* in the License. Please refer to the License for the specific language
* governing these rights and limitations under the License. Portions created
* by SugarCRM are Copyright (C) 2004-2007 SugarCRM, Inc.; All Rights Reserved.
*/
$dashletStrings['OpportunitiesByLeadSourceByOutcomeDashlet'] = array('LBL_TITLE' => 'Wszystkie Tematy przez Źródła Wizytówek przez Wynik',
'LBL_DESCRIPTION' => 'Poziome przedstawienie wykresów Tematówprzez Źródła Wizytówek przez Wynik',
'LBL_REFRESH' => 'Odświerz Wykres');
?>

View File

@@ -0,0 +1,78 @@
{*
/**
* SugarCRM is a customer relationship management program developed by
* SugarCRM, Inc. Copyright (C) 2004 - 2009 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".
*/
*}
<div style='width: 400px'>
<form name='configure_{$id}' action="index.php" method="post" onSubmit='return SUGAR.dashlets.postForm("configure_{$id}", SUGAR.mySugar.uncoverPage);' />
<input type='hidden' name='id' value='{$id}' />
<input type='hidden' name='module' value='{$module}' />
<input type='hidden' name='action' value='DynamicAction' />
<input type='hidden' name='DynamicAction' value='configureDashlet' />
<input type='hidden' name='to_pdf' value='true' />
<input type='hidden' name='configure' value='true' />
<input type='hidden' id='dashletType' name='dashletType' value='{$dashletType}' />
<table width="400" cellpadding="10" cellspacing="0" border="0" class="tabForm" align="center">
<tr>
<td valign='top' nowrap class='dataLabel'>{$LBL_LEAD_SOURCES}</td>
<td valign='top' class='dataField'>
<select name="pbls_lead_sources[]" multiple size='3'>
{$selected_datax}
</select>
</td>
</tr>
<tr>
<td valign='top' nowrap class='dataLabel'>{$LBL_USERS}</td>
<td valign='top' class='dataField'>
<select name="pbls_ids[]" multiple size='3'>
{$pbls_ids}
</select>
</td>
</tr>
<tr>
<td align="right" colspan="2">
<input type='submit' onclick="" class='button' value='{$LBL_SUBMIT_BUTTON_LABEL}'>
</td>
</tr>
</table>
</form>
</div>

View File

@@ -0,0 +1,52 @@
<?php
if(!defined('sugarEntry') || !sugarEntry) die('Not A Valid Entry Point');
/**
* SugarCRM is a customer relationship management program developed by
* SugarCRM, Inc. Copyright (C) 2004 - 2009 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".
*/
$dashletData['OpportunitiesByLeadSourceDashlet']['searchFields'] = array(
'pbls_lead_sources' => array(
'name' => 'pbls_lead_sources',
'vname' => 'LBL_LEAD_SOURCES',
'type' => 'enum',
),
'pbls_ids' => array(
'name' => 'pbls_ids',
'vname' => 'LBL_USERS',
'type' => 'user_name',
),
);
?>

View File

@@ -0,0 +1,45 @@
<?php
if(!defined('sugarEntry') || !sugarEntry) die('Not A Valid Entry Point');
/**
* SugarCRM is a customer relationship management program developed by
* SugarCRM, Inc. Copyright (C) 2004 - 2009 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".
*/
$dashletStrings['OpportunitiesByLeadSourceDashlet'] = array('LBL_TITLE' => 'All Opportunities by Lead Source',
'LBL_DESCRIPTION' => 'Pie Chart of Opportunities by Lead Source',
'LBL_REFRESH' => 'Refresh Chart');
?>

View File

@@ -0,0 +1,45 @@
<?php
if(!defined('sugarEntry') || !sugarEntry) die('Not A Valid Entry Point');
/**
* SugarCRM is a customer relationship management program developed by
* SugarCRM, Inc. Copyright (C) 2004 - 2009 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".
*/
$dashletStrings['OpportunitiesByLeadSourceDashlet'] = array('LBL_TITLE' => 'Alle Verkaufschancen nach Quelle',
'LBL_DESCRIPTION' => 'Tortendiagramm der Verkaufschancen nach Quelle',
'LBL_REFRESH' => 'Diagramm neu laden');
?>

View File

@@ -0,0 +1,47 @@
<?php
if(!defined('sugarEntry') || !sugarEntry) die('Not A Valid Entry Point');
/**
* SugarCRM is a customer relationship management program developed by
* SugarCRM, Inc. Copyright (C) 2004 - 2009 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".
*/
global $app_strings, $current_language;
$dashletMeta['OpportunitiesByLeadSourceDashlet'] = array('title' => 'LBL_TITLE',
'description' => 'LBL_TITLE',
'icon' => 'themes/default/images/icon_Charts_Pie_32.gif',
'module' => 'Opportunities',
'category' => 'Charts');
?>

View File

@@ -0,0 +1,123 @@
<?php
if(!defined('sugarEntry') || !sugarEntry) die('Not A Valid Entry Point');
/**
* SugarCRM is a customer relationship management program developed by
* SugarCRM, Inc. Copyright (C) 2004 - 2009 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('include/Dashlets/DashletGenericChart.php');
class OpportunitiesByLeadSourceDashlet extends DashletGenericChart
{
public $pbls_lead_sources = array();
public $pbls_ids = array();
protected $_seedName = 'Opportunities';
public function displayOptions()
{
global $app_list_strings;
$selected_datax = array();
if (!empty($this->pbls_lead_sources) && sizeof($this->pbls_lead_sources) > 0)
foreach ($this->pbls_lead_sources as $key)
$selected_datax[] = $key;
else
$selected_datax = array_keys($app_list_strings['lead_source_dom']);
$this->_searchFields['pbls_lead_sources']['options'] = array_filter($app_list_strings['lead_source_dom']);
$this->_searchFields['pbls_lead_sources']['input_name0'] = $selected_datax;
if (!isset($this->pbls_ids) || count($this->pbls_ids) == 0)
$this->_searchFields['pbls_ids']['input_name0'] = array_keys(get_user_array(false));
return parent::displayOptions();
}
public function display()
{
global $current_user, $sugar_config;
require("modules/Charts/chartdefs.php");
$chartDef = $chartDefs['pipeline_by_lead_source'];
require_once('include/SugarCharts/SugarChart.php');
$sugarChart = new SugarChart();
$sugarChart->is_currency = true;
$currency_symbol = $sugar_config['default_currency_symbol'];
if ($current_user->getPreference('currency')){
require_once('modules/Currencies/Currency.php');
$currency = new Currency();
$currency->retrieve($current_user->getPreference('currency'));
$currency_symbol = $currency->symbol;
}
$subtitle = translate('LBL_OPP_SIZE', 'Charts') . " " . $currency_symbol . "1" . translate('LBL_OPP_THOUSANDS', 'Charts');
$sugarChart->setProperties('', $subtitle, $chartDef['chartType']);
$sugarChart->base_url = $chartDef['base_url'];
$sugarChart->group_by = $chartDef['groupBy'];
$sugarChart->url_params = array();
if ( count($this->pbls_ids) > 0 )
$sugarChart->url_params['assigned_user_id'] = array_values($this->pbls_ids);
$sugarChart->getData($this->constructQuery());
$sugarChart->data_set = $sugarChart->sortData($sugarChart->data_set, 'lead_source', true);
$xmlFile = $sugarChart->getXMLFileName($this->id);
$sugarChart->saveXMLFile($xmlFile, $sugarChart->generateXML());
return $this->getTitle('<div align="center"></div>') .
'<div align="center">' . $sugarChart->display($this->id, $xmlFile, '100%', '480', false) . '</div><br />';
}
protected function constructQuery()
{
$query = "SELECT lead_source,sum(amount_usdollar/1000) as total,count(*) as opp_count ".
"FROM opportunities ";
$query .= "WHERE opportunities.deleted=0 ";
if ( count($this->pbls_ids) > 0 )
$query .= "AND opportunities.assigned_user_id IN ('".implode("','",$this->pbls_ids)."') ";
if ( count($this->pbls_lead_sources) > 0 )
$query .= "AND opportunities.lead_source IN ('".implode("','",$this->pbls_lead_sources)."') ";
else
$query .= "AND opportunities.lead_source IN ('".implode("','",array_keys($GLOBALS['app_list_strings']['lead_source_dom']))."') ";
$query .= "GROUP BY lead_source ORDER BY total DESC";
return $query;
}
}
?>

View File

@@ -0,0 +1,37 @@
<?php
if(!defined('sugarEntry') || !sugarEntry) die('Not A Valid Entry Point');
/**
* The contents of this file are subject to the SugarCRM Professional Subscription
* Agreement ("License") which can be viewed at
* http://www.sugarcrm.com/crm/products/sugar-professional-eula.html
* By installing or using this file, You have unconditionally agreed to the
* terms and conditions of the License, and You may not use this file except in
* compliance with the License. Under the terms of the license, You shall not,
* among other things: 1) sublicense, resell, rent, lease, redistribute, assign
* or otherwise transfer Your rights to the Software, and 2) use the Software
* for timesharing or service bureau purposes such as hosting the Software for
* commercial gain and/or for the benefit of a third party. Use of the Software
* may be subject to applicable fees and any use of the Software without first
* paying applicable fees is strictly prohibited. You do not have the right to
* remove SugarCRM copyrights from the source code or user interface.
*
* All copies of the Covered Code must include on each user interface screen:
* (i) the "Powered by SugarCRM" logo and
* (ii) the SugarCRM copyright notice
* in the same form as they appear in the distribution. See full license for
* requirements.
*
* Your Warranty, Limitations of liability and Indemnity are expressly stated
* in the License. Please refer to the License for the specific language
* governing these rights and limitations under the License. Portions created
* by SugarCRM are Copyright (C) 2004-2007 SugarCRM, Inc.; All Rights Reserved.
*/
$dashletStrings['OpportunitiesByLeadSourceDashlet'] = array('LBL_TITLE' => 'Wszystkie Tematy przez Źródła Wizytówek',
'LBL_DESCRIPTION' => 'Wykres Okrągły Tematy przez Źródła Wizytówek',
'LBL_REFRESH' => 'Odświerz Wykres');
?>

View File

@@ -0,0 +1,99 @@
{*
/**
* SugarCRM is a customer relationship management program developed by
* SugarCRM, Inc. Copyright (C) 2004 - 2009 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".
*/
// $Id$
*}
<div style='width: 400px'>
<form name='configure_{$id}' action="index.php" method="post" onSubmit='return SUGAR.dashlets.postForm("configure_{$id}", SUGAR.mySugar.uncoverPage);'>
<input type='hidden' name='id' value='{$id}'>
<input type='hidden' name='module' value='{$module}'>
<input type='hidden' name='action' value='DynamicAction'>
<input type='hidden' name='DynamicAction' value='configureDashlet'>
<input type='hidden' name='to_pdf' value='true'>
<input type='hidden' name='configure' value='true'>
<input type='hidden' id='dashletType' name='dashletType' value='{$dashletType}' />
<table width="400" cellpadding="0" cellspacing="0" border="0" class="tabForm" align="center">
<tr>
<td valign='top' class='dataLabel' nowrap>{$LBL_TITLE} <br /></td>
<td valign='top' class='dataField'>
<input type="text" value="{$dashlet_title}" size="30" name="obm_dashlet_title"/>
</td>
</tr>
<tr>
<td valign='top' nowrap class='dataLabel'>{$LBL_DATE_START} <br><i>{$user_date_format}</i></td>
<td valign='top' class='dataField'>
<input onblur="parseDate(this, '{$cal_dateformat}');" class="text" name="obm_date_start" size='12' maxlength='10' id='date_start' value='{$date_start}'>
<img src="themes/default/images/jscalendar.gif" alt="{$LBL_ENTER_DATE}" id="date_start_trigger" align="absmiddle">
</td>
</tr>
<tr>
<td valign='top' nowrap class='dataLabel'>{$LBL_DATE_END}<br><i>{$user_date_format}</i></td>
<td valign='top' class='dataField'>
<input onblur="parseDate(this, '{$cal_dateformat}');" class="text" name="obm_date_end" size='12' maxlength='10' id='date_end' value='{$date_end}'>
<img src="themes/default/images/jscalendar.gif" alt="{$LBL_ENTER_DATE}" id="date_end_trigger" align="absmiddle">
</td>
</tr>
<tr>
<td valign='top' nowrap class='dataLabel'>{$LBL_USERS}</td>
<td valign='top' class='dataField'>
<select name="obm_ids[]" multiple size='3'>
{$obm_ids}
</select>
</td>
</tr>
<tr>
<td align="right" colspan="2">
<input type='submit' onclick="" class='button' value='{$LBL_SUBMIT_BUTTON_LABEL}'>
</td>
</tr>
</table>
</form>
{literal}
<script type="text/javascript">
Calendar.setup ({
inputField : "date_start", ifFormat : "{/literal}{$cal_dateformat}{literal}", showsTime : false, button : "date_start_trigger", singleClick : true, step : 1
});
Calendar.setup ({
inputField : "date_end", ifFormat : "{/literal}{$cal_dateformat}{literal}", showsTime : false, button : "date_end_trigger", singleClick : true, step : 1
});
{/literal}
</script>
</div>

View File

@@ -0,0 +1,57 @@
<?php
if(!defined('sugarEntry') || !sugarEntry) die('Not A Valid Entry Point');
/**
* SugarCRM is a customer relationship management program developed by
* SugarCRM, Inc. Copyright (C) 2004 - 2009 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".
*/
$dashletData['OutcomeByMonthDashlet']['searchFields'] = array(
'obm_date_start' => array(
'name' => 'obm_date_start',
'vname' => 'LBL_DATE_START',
'type' => 'datepicker',
),
'obm_date_end' => array(
'name' => 'obm_date_end',
'vname' => 'LBL_DATE_END',
'type' => 'datepicker',
),
'obm_ids' => array(
'name' => 'obm_ids',
'vname' => 'LBL_USERS',
'type' => 'user_name',
),
);
?>

View File

@@ -0,0 +1,45 @@
<?php
if(!defined('sugarEntry') || !sugarEntry) die('Not A Valid Entry Point');
/**
* SugarCRM is a customer relationship management program developed by
* SugarCRM, Inc. Copyright (C) 2004 - 2009 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".
*/
$dashletStrings['OutcomeByMonthDashlet'] = array('LBL_TITLE' => 'Outcome by Month',
'LBL_DESCRIPTION' => 'Chart of the Monthly Outcomes',
'LBL_REFRESH' => 'Refresh Chart');
?>

View File

@@ -0,0 +1,45 @@
<?php
if(!defined('sugarEntry') || !sugarEntry) die('Not A Valid Entry Point');
/**
* SugarCRM is a customer relationship management program developed by
* SugarCRM, Inc. Copyright (C) 2004 - 2009 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".
*/
$dashletStrings['OutcomeByMonthDashlet'] = array('LBL_TITLE' => 'Resultat nach Monat',
'LBL_DESCRIPTION' => 'Diagramm der monatlichen Ergebnisse',
'LBL_REFRESH' => 'Diagramm neu laden');
?>

View File

@@ -0,0 +1,47 @@
<?php
if(!defined('sugarEntry') || !sugarEntry) die('Not A Valid Entry Point');
/**
* SugarCRM is a customer relationship management program developed by
* SugarCRM, Inc. Copyright (C) 2004 - 2009 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".
*/
global $app_strings, $current_language;
$dashletMeta['OutcomeByMonthDashlet'] = array('title' => 'LBL_TITLE',
'description' => 'LBL_TITLE',
'icon' => 'themes/default/images/icon_Charts_Vertical_32.gif',
'module' => 'Opportunities',
'category' => 'Charts');
?>

View File

@@ -0,0 +1,139 @@
<?php
if(!defined('sugarEntry') || !sugarEntry) die('Not A Valid Entry Point');
/**
* SugarCRM is a customer relationship management program developed by
* SugarCRM, Inc. Copyright (C) 2004 - 2009 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('include/Dashlets/DashletGenericChart.php');
class OutcomeByMonthDashlet extends DashletGenericChart
{
public $obm_ids = array();
public $obm_date_start;
public $obm_date_end;
protected $_seedName = 'Opportunities';
/**
* @see DashletGenericChart::__construct()
*/
public function __construct(
$id,
array $options = null
)
{
global $timedate;
if(empty($options['obm_date_start']))
$options['obm_date_start'] = date($timedate->get_db_date_time_format(), time());
if(empty($options['obm_date_end']))
$options['obm_date_end'] = date($timedate->get_db_date_time_format(), strtotime('2010-01-01'));
parent::__construct($id,$options);
}
/**
* @see DashletGenericChart::displayOptions()
*/
public function displayOptions()
{
if (!isset($this->obm_ids) || count($this->obm_ids) == 0)
$this->_searchFields['obm_ids']['input_name0'] = array_keys(get_user_array(false));
return parent::displayOptions();
}
/**
* @see DashletGenericChart::display()
*/
public function display()
{
$currency_symbol = $GLOBALS['sugar_config']['default_currency_symbol'];
if ($GLOBALS['current_user']->getPreference('currency')){
require_once('modules/Currencies/Currency.php');
$currency = new Currency();
$currency->retrieve($GLOBALS['current_user']->getPreference('currency'));
$currency_symbol = $currency->symbol;
}
require("modules/Charts/chartdefs.php");
$chartDef = $chartDefs['outcome_by_month'];
require_once('include/SugarCharts/SugarChart.php');
$sugarChart = new SugarChart();
$sugarChart->setProperties('',
translate('LBL_OPP_SIZE', 'Charts') . ' ' . $currency_symbol . '1' .translate('LBL_OPP_THOUSANDS', 'Charts'),
$chartDef['chartType']);
$sugarChart->base_url = $chartDef['base_url'];
$sugarChart->group_by = $chartDef['groupBy'];
$sugarChart->url_params = array();
$sugarChart->getData($this->constructQuery());
$sugarChart->is_currency = true;
$sugarChart->data_set = $sugarChart->sortData($sugarChart->data_set, 'm', false, 'sales_stage', true, true);
$xmlFile = $sugarChart->getXMLFileName($this->id);
$sugarChart->saveXMLFile($xmlFile, $sugarChart->generateXML());
return $this->getTitle('<div align="center"></div>') .
'<div align="center">' . $sugarChart->display($this->id, $xmlFile, '100%', '480', false) . '</div><br />';
}
/**
* @see DashletGenericChart::constructQuery()
*/
protected function constructQuery()
{
$query = "SELECT sales_stage,".
db_convert('opportunities.date_closed','date_format',array("'%Y-%m'"),array("'YYYY-MM'"))." as m, ".
"sum(amount_usdollar/1000) as total, count(*) as opp_count FROM opportunities ";
$query .= " WHERE opportunities.date_closed >= ".db_convert("'".$this->obm_date_start."'",'datetime') .
" AND opportunities.date_closed <= ".db_convert("'".$this->obm_date_end."'",'datetime') .
" AND opportunities.deleted=0";
if (count($this->obm_ids) > 0)
$query .= " AND opportunities.assigned_user_id IN ('" . implode("','",$this->obm_ids) . "')";
$query .= " GROUP BY sales_stage,".
db_convert('opportunities.date_closed','date_format',array("'%Y-%m'"),array("'YYYY-MM'")) .
" ORDER BY m";
return $query;
}
}
?>

View File

@@ -0,0 +1,37 @@
<?php
if(!defined('sugarEntry') || !sugarEntry) die('Not A Valid Entry Point');
/**
* The contents of this file are subject to the SugarCRM Professional Subscription
* Agreement ("License") which can be viewed at
* http://www.sugarcrm.com/crm/products/sugar-professional-eula.html
* By installing or using this file, You have unconditionally agreed to the
* terms and conditions of the License, and You may not use this file except in
* compliance with the License. Under the terms of the license, You shall not,
* among other things: 1) sublicense, resell, rent, lease, redistribute, assign
* or otherwise transfer Your rights to the Software, and 2) use the Software
* for timesharing or service bureau purposes such as hosting the Software for
* commercial gain and/or for the benefit of a third party. Use of the Software
* may be subject to applicable fees and any use of the Software without first
* paying applicable fees is strictly prohibited. You do not have the right to
* remove SugarCRM copyrights from the source code or user interface.
*
* All copies of the Covered Code must include on each user interface screen:
* (i) the "Powered by SugarCRM" logo and
* (ii) the SugarCRM copyright notice
* in the same form as they appear in the distribution. See full license for
* requirements.
*
* Your Warranty, Limitations of liability and Indemnity are expressly stated
* in the License. Please refer to the License for the specific language
* governing these rights and limitations under the License. Portions created
* by SugarCRM are Copyright (C) 2004-2007 SugarCRM, Inc.; All Rights Reserved.
*/
$dashletStrings['OutcomeByMonthDashlet'] = array('LBL_TITLE' => 'Wyniki na Miesiąc',
'LBL_DESCRIPTION' => 'Wykres Miesięcznych Wyników',
'LBL_REFRESH' => 'Odświerz Wykres');
?>

View File

@@ -0,0 +1,115 @@
{*
/**
* 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".
*/
// $Id$
*}
<div style='width: 400px'>
<form name='configure_{$id}' action="index.php" method="post" onSubmit='return SUGAR.dashlets.postForm("configure_{$id}", SUGAR.mySugar.uncoverPage);'>
<input type='hidden' name='id' value='{$id}'>
<input type='hidden' name='module' value='{$module}'>
<input type='hidden' name='action' value='DynamicAction'>
<input type='hidden' name='DynamicAction' value='configureDashlet'>
<input type='hidden' name='to_pdf' value='true'>
<input type='hidden' name='configure' value='true'>
<input type='hidden' id='dashletType' name='dashletType' value='{$dashletType}' />
<table width="400" cellpadding="0" cellspacing="0" border="0" class="tabForm" align="center">
<tr>
<td valign='top' class='dataLabel' nowrap>{$LBL_TITLE} <br /></td>
<td valign='top' class='dataField'>
<input type="text" value="{$dashlet_title}" size="30" name="pbuts_dashlet_title"/>
</td>
</tr>
<tr>
<td valign='top' nowrap class='dataLabel'>{$LBL_DATE_START} <br><i>{$user_date_format}</i></td>
<td valign='top' class='dataField'>
<input onblur="parseDate(this, '{$cal_dateformat}');" class="text" name="pbuts_date_start" size='12' maxlength='10' id='date_start' value='{$date_start}'>
<img src="themes/default/images/jscalendar.gif" alt="{$LBL_ENTER_DATE}" id="date_start_trigger" align="absmiddle">
</td>
</tr>
<tr>
<td valign='top' nowrap class='dataLabel'>{$LBL_DATE_END}<br><i>{$user_date_format}</i></td>
<td valign='top' class='dataField'>
<input onblur="parseDate(this, '{$cal_dateformat}');" class="text" name="pbuts_date_end" size='12' maxlength='10' id='date_end' value='{$date_end}'>
<img src="themes/default/images/jscalendar.gif" alt="{$LBL_ENTER_DATE}" id="date_end_trigger" align="absmiddle">
</td>
</tr>
<tr>
<td valign='top' class='dataLabel' nowrap>{$LBL_ECMINVOICEOUT_STATUS}</td>
<td valign='top' class='dataField'>
<select name="pbuts_ecminvoiceout_status[]" multiple size='3'>
{$selected_datax}
</select><br /><br /></td>
</tr>
<tr>
<td valign='top' class='dataLabel' nowrap>{$LBL_ECMINVOICEOUT_USERS}</td>
<td valign='top' class='dataField'>
<select name="pbuts_ecminvoiceout_users[]" multiple size='4'>
{$selected_datax_users}
</select></td>
</tr>
<tr>
<td align="right" colspan="2">
<input type='submit' onclick="" class='button' value='Submit'>
</td>
</tr>
</table>
</form>
{literal}
<script type="text/javascript">
Calendar.setup ({
inputField : "date_start", ifFormat : "{/literal}{$cal_dateformat}{literal}", showsTime : false, button : "date_start_trigger", singleClick : true, step : 1
});
Calendar.setup ({
inputField : "date_end", ifFormat : "{/literal}{$cal_dateformat}{literal}", showsTime : false, button : "date_end_trigger", singleClick : true, step : 1
});
{/literal}
</script>
</div>

View File

@@ -0,0 +1,48 @@
<?php
if(!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".
*/
$dashletStrings['PipelineByInvoiceOutsStatusDashlet'] = array(
'LBL_TITLE' => 'Pipeline By Invoices Status',
'LBL_DESCRIPTION' => 'Vertical Bar Chart of Invoices Status',
'LBL_REFRESH' => 'Refresh Chart'
);
?>

View File

@@ -0,0 +1,40 @@
<?php
if(!defined('sugarEntry') || !sugarEntry) die('Not A Valid Entry Point');
/**
* The contents of this file are subject to the SugarCRM Enterprise Subscription
* Agreement ("License") which can be viewed at
* http://www.sugarcrm.com/crm/products/sugar-enterprise-eula.html
* By installing or using this file, You have unconditionally agreed to the
* terms and conditions of the License, and You may not use this file except in
* compliance with the License. Under the terms of the license, You shall not,
* among other things: 1) sublicense, resell, rent, lease, redistribute, assign
* or otherwise transfer Your rights to the Software, and 2) use the Software
* for timesharing or service bureau purposes such as hosting the Software for
* commercial gain and/or for the benefit of a third party. Use of the Software
* may be subject to applicable fees and any use of the Software without first
* paying applicable fees is strictly prohibited. You do not have the right to
* remove SugarCRM copyrights from the source code or user interface.
*
* All copies of the Covered Code must include on each user interface screen:
* (i) the "Powered by SugarCRM" logo and
* (ii) the SugarCRM copyright notice
* in the same form as they appear in the distribution. See full license for
* requirements.
*
* Your Warranty, Limitations of liability and Indemnity are expressly stated
* in the License. Please refer to the License for the specific language
* governing these rights and limitations under the License. Portions created
* by SugarCRM are Copyright (C) 2004-2007 SugarCRM, Inc.; All Rights Reserved.
*/
$dashletStrings['PipelineByInvoiceOutsStatusDashlet'] = array(
'LBL_TITLE' => 'Pipeline By Invoices Status',
'LBL_DESCRIPTION' => 'Vertical Bar Chart of Invoices Status',
'LBL_REFRESH' => 'Refresh Chart'
);
?>

View File

@@ -0,0 +1,47 @@
<?php
if(!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".
*/
global $app_strings, $current_language;
$dashletMeta['PipelineByInvoiceOutsStatusDashlet'] = array('title' => translate('LBL_PIPELINE_BY_ECMINVOICEOUTS_TITLE', 'Home'),
'description' => translate('LBL_PIPELINE_BY_ECMINVOICEOUTS_TITLE', 'Home'),
'module' => 'EcmInvoiceOuts',
'icon' => 'themes/default/images/icon_Charts_Funnel_32.gif',
'category' => 'Charts');
?>

View File

@@ -0,0 +1,554 @@
<?php
if(!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('include/Dashlets/Dashlet.php');
require_once('include/Sugar_Smarty.php');
require_once('include/charts/Charts.php');
require_once('modules/Dashboard/Forms.php');
class PipelineByInvoiceOutsStatusDashlet extends Dashlet {
var $pbuts_date_start;
var $pbuts_date_end;
var $pbuts_ecminvoiceout_status = null;
var $pbuts_ecminvoiceout_users = null;
var $refresh = false;
function PipelineByInvoiceOutsStatusDashlet($id, $options) {
global $timedate;
parent::Dashlet($id);
$this->isConfigurable = true;
$this->isRefreshable = true;
if(empty($options['pbuts_date_start']))
$this->pbuts_date_start = date($timedate->get_db_date_time_format(), time());
else
$this->pbuts_date_start = $options['pbuts_date_start'];
if(empty($options['pbuts_date_end']))
$this->pbuts_date_end = date($timedate->get_db_date_time_format(), strtotime('2010-01-01'));
else
$this->pbuts_date_end = $options['pbuts_date_end'];
if(empty($options['pbuts_ecminvoiceout_status']))
$this->pbuts_ecminvoiceout_status = array();
else
$this->pbuts_ecminvoiceout_status = $options['pbuts_ecminvoiceout_status'];
if(empty($options['pbuts_ecminvoiceout_users']))
$this->pbuts_ecminvoiceout_users = array();
else
$this->pbuts_ecminvoiceout_users = $options['pbuts_ecminvoiceout_users'];
if(empty($options['title']))
$this->title = translate('LBL_PIPELINE_BY_ECMINVOICEOUTS_TITLE', 'Home');
else
$this->title = $options['title'];
}
function saveOptions($req) {
global $sugar_config, $timedate, $current_user, $theme;
$options = array();
$date_start = $this->pbuts_date_start;
$date_end = $this->pbuts_date_end;
$dateStartDisplay = strftime($timedate->get_user_date_format(), strtotime($date_start));
$dateEndDisplay = strftime($timedate->get_user_date_format(), strtotime($date_end));
$seps = array("-", "/");
$dates = array($dateStartDisplay, $dateEndDisplay);
$dateFileNameSafe = str_replace($seps, "_", $dates);
if(is_file($sugar_config['tmp_dir'] . $current_user->getUserPrivGuid()."_".$theme."_my_pipeline_".$dateFileNameSafe[0]."_".$dateFileNameSafe[1].".xml"))
unlink($sugar_config['tmp_dir'] . $current_user->getUserPrivGuid()."_".$theme."_my_pipeline_".$dateFileNameSafe[0]."_".$dateFileNameSafe[1].".xml");
$options['title'] = $_REQUEST['pbuts_dashlet_title'];
$options['pbuts_ecminvoiceout_status'] = $_REQUEST['pbuts_ecminvoiceout_status'];
$timeFormat = $current_user->getUserDateTimePreferences();
$options['pbuts_ecminvoiceout_users'] = $_REQUEST['pbuts_ecminvoiceout_users'];
$options['pbuts_date_start'] = $timedate->swap_formats($_REQUEST['pbuts_date_start'], $timeFormat['date'], $timedate->dbDayFormat);
$options['pbuts_date_end'] = $timedate->swap_formats($_REQUEST['pbuts_date_end'], $timeFormat['date'], $timedate->dbDayFormat);
return $options;
}
function displayOptions() {
global $timedate, $image_path, $app_strings, $current_user, $app_list_strings;
$ss = new Sugar_Smarty();
$ss->assign('id', $this->id);
$ss->assign('module', $_REQUEST['module']);
$ss->assign('dashletType', 'predefined_chart');
$ss->assign('LBL_TITLE', translate('LBL_TITLE', 'Charts'));
$ss->assign('LBL_CHART_TYPE', translate('LBL_CHART_TYPE', 'Charts'));
$ss->assign('LBL_DATE_START', translate('LBL_DATE_START', 'Charts'));
$ss->assign('LBL_DATE_END', translate('LBL_DATE_END', 'Charts'));
$ss->assign('LBL_ECMINVOICEOUT_STATUS', translate('LBL_ECMINVOICEOUT_STATUS', 'Charts'));
$ss->assign('LBL_ENTER_DATE', translate('LBL_ENTER_DATE', 'Charts'));
$ss->assign('LBL_ECMINVOICEOUT_USERS', translate('LBL_ECMINVOICEOUT_USERS', 'Charts'));
$ss->assign('LBL_SELECT_BUTTON_TITLE', $app_strings['LBL_SELECT_BUTTON_TITLE']);
$ss->assign('image_path', $image_path);
//get the dates to display
$date_start = $this->pbuts_date_start;
$date_end = $this->pbuts_date_end;
$timeFormat = $current_user->getUserDateTimePreferences();
$ss->assign('date_start', $timedate->swap_formats($date_start, $timedate->dbDayFormat, $timeFormat['date']));
$ss->assign('date_end', $timedate->swap_formats($date_end, $timedate->dbDayFormat, $timeFormat['date']));
$tempx = array();
$datax = array();
$selected_datax = array();
//get list of sales stage keys to display
$user_ecminvoiceout_status = $this->pbuts_ecminvoiceout_status;
$tempx = $user_ecminvoiceout_status;
//set $datax using selected sales stage keys
if (count($tempx) > 0) {
foreach ($tempx as $key) {
$datax[$key] = $app_list_strings['ecminvoiceouts_status_dom'][$key];
array_push($selected_datax, $key);
}
}
else {
$datax = $app_list_strings['ecminvoiceouts_status_dom'];
$selected_datax = array_keys($app_list_strings['ecminvoiceouts_status_dom']);
}
$query = "select id, user_name from users where deleted='0'";
$dbm = new MysqlManager();
$dbm->connect();
$results = $dbm->query($query);
$us = array();
if(is_resource($results))
while($row = $dbm->fetchByAssoc($results)) $us[$row['id']] = $row['user_name'];
$ss->assign('dashlet_title', $this->title);
$ss->assign('selected_datax', get_select_options_with_id($app_list_strings['ecminvoiceouts_status_dom'], $selected_datax));
if(is_array($this->pbuts_ecminvoiceout_users) && count($this->pbuts_ecminvoiceout_users) > 0)
$selected_datax_users = $this->pbuts_ecminvoiceout_users;
else
$selected_datax_users = $us;
$ss->assign('selected_datax_users', get_select_options_with_id($us, $selected_datax_users));
$ss->assign('user_date_format', $timedate->get_user_date_format());
$ss->assign('cal_dateformat', $timedate->get_cal_date_format());
$ss->assign('module', $_REQUEST['module']);
return parent::displayOptions() . $ss->fetch('modules/Charts/Dashlets/PipelineByInvoiceOutsStatusDashlet/PipelineByInvoiceOutsStatusConfigure.tpl');
}
/**
* Displays the javascript for the dashlet
*
* @return string javascript to use with this dashlet
*/
function displayScript() {
global $sugar_config, $current_user, $current_language;
$xmlFile = $sugar_config['tmp_dir']. $current_user->id . '_' . $this->id . '.xml';
$chartStringsXML = 'cache/xml/chart_strings.' . $current_language .'.lang.xml';
$ss = new Sugar_Smarty();
$ss->assign('chartName', $this->id);
$ss->assign('chartXMLFile', $xmlFile);
$ss->assign('chartStyleCSS', chartStyle());
$ss->assign('chartColorsXML', chartColors());
$ss->assign('chartStringsXML', $chartStringsXML);
$str = $ss->fetch('modules/Charts/Dashlets/PredefinedChartDashletScript.tpl');
return $str;
}
function getTitle($text) {
global $image_path, $app_strings, $sugar_config;
if($this->isConfigurable)
$additionalTitle = '<table width="100%" cellspacing="0" cellpadding="0" border="0"><tr><td width="99%">' . $text
. '</td><td nowrap width="1%"><div style="width: 100%;text-align:right"><a href="#" onclick="SUGAR.mySugar.configureDashlet(\''
. $this->id . '\'); return false;" class="chartToolsLink">'
. get_image($image_path.'edit','title="' . translate('LBL_DASHLET_EDIT', 'Home') . '" alt="' . translate('LBL_DASHLET_EDIT', 'Home') . '" border="0" align="absmiddle"').'</a> '
. '';
else
$additionalTitle = '<table width="100%" cellspacing="0" cellpadding="0" border="0"><tr><td width="99%">' . $text
. '</td><td nowrap width="1%"><div style="width: 100%;text-align:right">';
if($this->isRefreshable)
$additionalTitle .= '<a href="#" onclick="SUGAR.mySugar.retrieveDashlet(\''
. $this->id . '\',\'predefined_chart\'); return false;"><img width="13" height="13" border="0" align="absmiddle" title="' . translate('LBL_DASHLET_REFRESH', 'Home') . '" alt="' . translate('LBL_DASHLET_REFRESH', 'Home') . '" src="'
. $image_path . 'refresh.gif"/></a> ';
$additionalTitle .= '<a href="#" onclick="SUGAR.mySugar.deleteDashlet(\''
. $this->id . '\'); return false;"><img width="13" height="13" border="0" align="absmiddle" title="' . translate('LBL_DASHLET_DELETE', 'Home') . '" alt="' . translate('LBL_DASHLET_DELETE', 'Home') . '" src="'
. $image_path . 'close_dashboard.gif"/></a></div></td></tr></table>';
if(!function_exists('get_form_header')) {
global $theme;
require_once('themes/'.$theme.'/layout_utils.php');
}
$str = '<div ';
if(empty($sugar_config['lock_homepage']) || $sugar_config['lock_homepage'] == false) $str .= ' onmouseover="this.style.cursor = \'move\';"';
$str .= 'id="dashlet_header_' . $this->id . '">' . get_form_header($this->title, $additionalTitle, false) . '</div>';
return $str;
}
function display() {
global $app_list_strings, $current_language, $sugar_config, $currentModule, $action, $current_user, $theme, $timedate, $image_path;
$this->loadLanguage('PipelineByInvoiceOutsStatusDashlet', 'modules/Charts/Dashlets/');
$returnStr = '';
$user_dateFormat = $timedate->get_date_format();
$current_module_strings = return_module_language($current_language, 'Charts');
if(isset($_REQUEST['pbuts_refresh'])) {
$refresh = $_REQUEST['pbuts_refresh'];
}
else {
$refresh = false;
}
$date_start = $this->pbuts_date_start;
$date_end = $this->pbuts_date_end;
// cn: format date_start|end to user's preferred
$dateStartDisplay = strftime($timedate->get_user_date_format(), strtotime($date_start));
$dateEndDisplay = strftime($timedate->get_user_date_format(), strtotime($date_end));
$seps = array("-", "/");
$dates = array($date_start, $date_end);
$dateFileNameSafe = str_replace($seps, "_", $dates);
$dateXml[0] = $date_start;
$dateXml[1] = $date_end;
$datax = array();
$selected_datax = array();
//get list of sales stage keys to display
$user_ecminvoiceout_status = $this->pbuts_ecminvoiceout_status;
$tempx = $user_ecminvoiceout_status;
//set $datax using selected sales stage keys
if (count($tempx) > 0) {
foreach ($tempx as $key) {
$datax[$key] = $app_list_strings['ecminvoiceouts_status_dom'][$key];
array_push($selected_datax, $key);
}
}
else {
$datax = $app_list_strings['ecminvoiceouts_status_dom'];
$selected_datax = array_keys($app_list_strings['ecminvoiceouts_status_dom']);
}
$GLOBALS['log']->debug("datax is:");
$GLOBALS['log']->debug($datax);
$ids = array();
$new_ids = array();
$user_ids = $current_user->getPreference('pbuts_ids');
//get list of user ids for which to display data
if (!empty($user_ids) && count($user_ids) != 0 && !isset($_REQUEST['pbuts_ids'])) {
$ids = $user_ids;
$GLOBALS['log']->debug("USER PREFERENCES['pbuts_ids'] is:");
$GLOBALS['log']->debug($user_ids);
}
elseif (isset($_REQUEST['pbuts_ids']) && count($_REQUEST['pbuts_ids']) > 0) {
$ids = $_REQUEST['pbuts_ids'];
$current_user->setPreference('pbuts_ids', $_REQUEST['pbuts_ids']);
$GLOBALS['log']->debug("_REQUEST['pbuts_ids'] is:");
$GLOBALS['log']->debug($_REQUEST['pbuts_ids']);
$GLOBALS['log']->debug("USER PREFERENCES['pbuts_ids'] is:");
$GLOBALS['log']->debug($current_user->getPreference('pbuts_ids'));
}
else {
$ids = get_user_array(false);
$ids = array_keys($ids);
}
//create unique prefix based on selected users for image files
$id_hash = '1';
if (isset($ids)) {
sort($ids);
$id_hash = crc32(implode('',$ids));
if($id_hash < 0)
{
$id_hash = $id_hash * -1;
}
}
$GLOBALS['log']->debug("ids is:");
$GLOBALS['log']->debug($ids);
$id_md5 = substr(md5($current_user->id),0,9);
$seps = array("-", "/");
$dates = array($dateStartDisplay, $dateEndDisplay);
$dateFileNameSafe = str_replace($seps, "_", $dates);
$cache_file_name = $current_user->getUserPrivGuid()."_".$theme."_my_pipeline_".$dateFileNameSafe[0]."_".$dateFileNameSafe[1].".xml";
$GLOBALS['log']->debug("cache file name is: $cache_file_name");
if (file_exists($sugar_config['tmp_dir'].$cache_file_name)) {
$file_date = date($timedate->get_date_format()." ".$timedate->get_time_format(), filemtime($sugar_config['tmp_dir'].$cache_file_name));
}
else {
$file_date = '';
}
require_once('include/Sugar_Smarty.php');
require_once('include/SugarCharts/SugarChart.php');
$sugar_smarty = new Sugar_Smarty();
$charts = array();
$sugarChart = new SugarChart();
$sugarChart->base_url = array( 'module' => 'EcmInvoiceOuts',
'action' => 'index',
'query' => 'true',
'searchFormTab' => 'advanced_search',
);
$sugarChart->url_params = array();
$ids = $this->pbuts_ecminvoiceout_users;
global $app_list_strings;
$sugarChart->enum_for_labels = array( 'status' => $app_list_strings['ecminvoiceouts_status_dom'] );
$sugarChart->group_by = $this->constructGroupBy();
$query = $this->constructQuery($datax, $dateXml[0], $dateXml[1], $ids, $sugar_config['tmp_dir'].$cache_file_name, $refresh,'hBarS',$current_module_strings);
$sugarChart->setData($this->getChartData($query));
$total = $sugarChart->getTotal();
$currency_symbol = $sugar_config['default_currency_symbol'];
if ($current_user->getPreference('currency')){
require_once('modules/Currencies/Currency.php');
$currency = new Currency();
$currency->retrieve($current_user->getPreference('currency'));
$currency_symbol = $currency->symbol;
}
$sugarChart->is_currency = true;
//$sugarChart->currency_symbol = '';
$sugarChart->thousands_symbol = translate('LBL_OPP_THOUSANDS', 'Charts');
$subtitle = translate('LBL_ECMINVOICEOUTS_SIZE', 'Charts') . " " . $currency_symbol . "1" . translate('LBL_ECMINVOICEOUTS_THOUSANDS', 'Charts');
$pipeline_total_string = translate('LBL_ECMINVOICEOUTS_TOTAL', 'Charts') . ' '. $sugarChart->currency_symbol . format_number($total) . $sugarChart->thousands_symbol;
$sugarChart->setProperties($pipeline_total_string, $subtitle, 'horizontal group by chart');
$xmlFile = $sugar_config['tmp_dir']. $current_user->id . '_' . $this->id . '.xml';
$sugarChart->saveXMLFile($xmlFile, $sugarChart->generateXML());
$returnStr .= $sugarChart->display($this->id, $xmlFile, '100%', '480', false);
return $this->getTitle('') . '<div align="center">' .$returnStr . '</div><br />';
}
// awu: Bug 16794 - this function is a hack to get the correct sales stage order until i can clean it up later
function getChartData($query){
global $app_list_strings, $current_user, $sugar_config;
$data = array();
$temp_data = array();
$selected_datax = array();
$user_ecminvoiceout_status = $this->pbuts_ecminvoiceout_status;
$tempx = $user_ecminvoiceout_status;
//set $datax using selected sales stage keys
if (count($tempx) > 0) {
foreach ($tempx as $key) {
$datax[$key] = $app_list_strings['ecminvoiceouts_status_dom'][$key];
array_push($selected_datax, $key);
}
}
else {
$datax = $app_list_strings['ecminvoiceouts_status_dom'];
$selected_datax = array_keys($app_list_strings['ecminvoiceouts_status_dom']);
}
$db = &PearDatabase::getInstance();
$result = $db->query($query);
$row = $db->fetchByAssoc($result, -1, false);
while($row != null){
array_push($temp_data, $row);
$row = $db->fetchByAssoc($result, -1, false);
}
// reorder and set the array based on the order of selected_datax
foreach($selected_datax as $ecminvoiceout_status){
foreach($temp_data as $key => $value){
if ($value['status'] == $ecminvoiceout_status){
//$value['total'] = $symbol . $value['total'];
//$value['status'] = $app_list_strings['ecminvoiceouts_status_dom'][$value['status']];
array_push($data, $value);
unset($temp_data[$key]);
}
}
}
//echo '<br><br>'; var_dump($data);
return $data;
}
function constructQuery($datax=array('foo','bar'), $date_start='2071-10-15', $date_end='2071-10-15', $user_id=array('1'), $cache_file_name='a_file', $refresh=false,$chart_size='hBarF',$current_module_strings) {
global $app_strings, $charset, $lang, $barChartColors, $current_user;
require_once('modules/Opportunities/Opportunity.php');
require_once('modules/Currencies/Currency.php');
$kDelim = $current_user->getPreference('num_grp_sep');
global $timedate;
$opp = new Opportunity;
$where="";
//build the where clause for the query that matches $user
$count = count($user_id);
$id = array();
$user_list = get_user_array(false);
foreach ($user_id as $key) {
$new_ids[$key] = $user_list[$key];
}
if ($count>0) {
foreach ($new_ids as $the_id=>$the_name) {
$id[] = "'".$the_id."'";
}
$ids = join(",",$id);
$where .= " ecminvoiceouts.assigned_user_id IN ($ids) ";
}
//build the where clause for the query that matches $datax
$count = count($datax);
$dataxArr = array();
if ($count>0) {
foreach ($datax as $key=>$value) {
$dataxArr[] = "'".$key."'";
}
$dataxArr = join(",",$dataxArr);
$where .= "AND ecminvoiceouts.status IN ($dataxArr) ";
}
//build the where clause for the query that matches $date_start and $date_end
$where .= " AND ecminvoiceouts.date_entered >= ". db_convert("'".$date_start."'",'datetime'). "
AND ecminvoiceouts.date_entered <= ".db_convert("'".$date_end."'",'datetime') ;
$where .= " AND ecminvoiceouts.assigned_user_id = users.id AND ecminvoiceouts.deleted=0 ";
//Now do the db queries
//query for opportunity data that matches $datax and $user
/*
$query = " SELECT opportunities.sales_stage,
users.user_name,
opportunities.assigned_user_id,
count( * ) AS opp_count,
sum(amount_usdollar/1000) AS total
FROM users,opportunities ";
$query .= "WHERE " .$where;
$query .= " GROUP BY opportunities.sales_stage";
$query .= ",users.user_name,opportunities.assigned_user_id";
*/
$query = " SELECT ecminvoiceouts.status as status,
users.user_name,
ecminvoiceouts.assigned_user_id,
count( * ) AS opp_count,
sum(total/1000) AS total
FROM users, ecminvoiceouts ";
$query .= "WHERE " .$where;
$query .= " GROUP BY ecminvoiceouts.status";
$query .= ", users.user_name, ecminvoiceouts.assigned_user_id";
//var_dump($query);
//$res = $GLOBALS['db']->query($query);
//var_dump($res);
return $query;
}
function constructGroupBy(){
return array(
'status',
'user_name',
);
}
}
?>

View File

@@ -0,0 +1,115 @@
{*
/**
* 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".
*/
// $Id$
*}
<div style='width: 400px'>
<form name='configure_{$id}' action="index.php" method="post" onSubmit='return SUGAR.dashlets.postForm("configure_{$id}", SUGAR.mySugar.uncoverPage);'>
<input type='hidden' name='id' value='{$id}'>
<input type='hidden' name='module' value='{$module}'>
<input type='hidden' name='action' value='DynamicAction'>
<input type='hidden' name='DynamicAction' value='configureDashlet'>
<input type='hidden' name='to_pdf' value='true'>
<input type='hidden' name='configure' value='true'>
<input type='hidden' id='dashletType' name='dashletType' value='{$dashletType}' />
<table width="400" cellpadding="0" cellspacing="0" border="0" class="tabForm" align="center">
<tr>
<td valign='top' class='dataLabel' nowrap>{$LBL_TITLE} <br /></td>
<td valign='top' class='dataField'>
<input type="text" value="{$dashlet_title}" size="30" name="pbuts_dashlet_title"/>
</td>
</tr>
<tr>
<td valign='top' nowrap class='dataLabel'>{$LBL_DATE_START} <br><i>{$user_date_format}</i></td>
<td valign='top' class='dataField'>
<input onblur="parseDate(this, '{$cal_dateformat}');" class="text" name="pbuts_date_start" size='12' maxlength='10' id='date_start' value='{$date_start}'>
<img src="themes/default/images/jscalendar.gif" alt="{$LBL_ENTER_DATE}" id="date_start_trigger" align="absmiddle">
</td>
</tr>
<tr>
<td valign='top' nowrap class='dataLabel'>{$LBL_DATE_END}<br><i>{$user_date_format}</i></td>
<td valign='top' class='dataField'>
<input onblur="parseDate(this, '{$cal_dateformat}');" class="text" name="pbuts_date_end" size='12' maxlength='10' id='date_end' value='{$date_end}'>
<img src="themes/default/images/jscalendar.gif" alt="{$LBL_ENTER_DATE}" id="date_end_trigger" align="absmiddle">
</td>
</tr>
<tr>
<td valign='top' class='dataLabel' nowrap>{$LBL_ECMQUOTE_STATUS}</td>
<td valign='top' class='dataField'>
<select name="pbuts_ecmquote_status[]" multiple size='3'>
{$selected_datax}
</select><br /><br /></td>
</tr>
<tr>
<td valign='top' class='dataLabel' nowrap>{$LBL_ECMQUOTE_USERS}</td>
<td valign='top' class='dataField'>
<select name="pbuts_ecmquote_users[]" multiple size='4'>
{$selected_datax_users}
</select></td>
</tr>
<tr>
<td align="right" colspan="2">
<input type='submit' onclick="" class='button' value='Submit'>
</td>
</tr>
</table>
</form>
{literal}
<script type="text/javascript">
Calendar.setup ({
inputField : "date_start", ifFormat : "{/literal}{$cal_dateformat}{literal}", showsTime : false, button : "date_start_trigger", singleClick : true, step : 1
});
Calendar.setup ({
inputField : "date_end", ifFormat : "{/literal}{$cal_dateformat}{literal}", showsTime : false, button : "date_end_trigger", singleClick : true, step : 1
});
{/literal}
</script>
</div>

View File

@@ -0,0 +1,48 @@
<?php
if(!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".
*/
$dashletStrings['PipelineByQuotesStatusDashlet'] = array(
'LBL_TITLE' => 'Pipeline By Quotes Status',
'LBL_DESCRIPTION' => 'Vertical Bar Chart of Quotes Status',
'LBL_REFRESH' => 'Refresh Chart'
);
?>

View File

@@ -0,0 +1,39 @@
<?php
if(!defined('sugarEntry') || !sugarEntry) die('Not A Valid Entry Point');
/**
* The contents of this file are subject to the SugarCRM Enterprise Subscription
* Agreement ("License") which can be viewed at
* http://www.sugarcrm.com/crm/products/sugar-enterprise-eula.html
* By installing or using this file, You have unconditionally agreed to the
* terms and conditions of the License, and You may not use this file except in
* compliance with the License. Under the terms of the license, You shall not,
* among other things: 1) sublicense, resell, rent, lease, redistribute, assign
* or otherwise transfer Your rights to the Software, and 2) use the Software
* for timesharing or service bureau purposes such as hosting the Software for
* commercial gain and/or for the benefit of a third party. Use of the Software
* may be subject to applicable fees and any use of the Software without first
* paying applicable fees is strictly prohibited. You do not have the right to
* remove SugarCRM copyrights from the source code or user interface.
*
* All copies of the Covered Code must include on each user interface screen:
* (i) the "Powered by SugarCRM" logo and
* (ii) the SugarCRM copyright notice
* in the same form as they appear in the distribution. See full license for
* requirements.
*
* Your Warranty, Limitations of liability and Indemnity are expressly stated
* in the License. Please refer to the License for the specific language
* governing these rights and limitations under the License. Portions created
* by SugarCRM are Copyright (C) 2004-2007 SugarCRM, Inc.; All Rights Reserved.
*/
$dashletStrings['PipelineByQuotesStatusDashlet'] = array(
'LBL_TITLE' => 'Pipeline By Quotes Status',
'LBL_DESCRIPTION' => 'Vertical Bar Chart of Quotes Status',
'LBL_REFRESH' => 'Refresh Chart'
);
?>

View File

@@ -0,0 +1,47 @@
<?php
if(!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".
*/
global $app_strings, $current_language;
$dashletMeta['PipelineByQuotesStatusDashlet'] = array('title' => translate('LBL_PIPELINE_BY_ECMQUOTES_TITLE', 'Home'),
'description' => translate('LBL_PIPELINE_BY_ECMQUOTES_TITLE', 'Home'),
'module' => 'EcmQuotes',
'icon' => 'themes/default/images/icon_Charts_Funnel_32.gif',
'category' => 'Charts');
?>

View File

@@ -0,0 +1,558 @@
<?php
if(!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('include/Dashlets/Dashlet.php');
require_once('include/Sugar_Smarty.php');
require_once('include/charts/Charts.php');
require_once('modules/Dashboard/Forms.php');
class PipelineByQuotesStatusDashlet extends Dashlet {
var $pbuts_date_start;
var $pbuts_date_end;
var $pbuts_ecmquote_status = null;
var $pbuts_ecmquote_users = null;
var $refresh = false;
function PipelineByQuotesStatusDashlet($id, $options) {
global $timedate;
parent::Dashlet($id);
$this->isConfigurable = true;
$this->isRefreshable = true;
if(empty($options['pbuts_date_start']))
$this->pbuts_date_start = date($timedate->get_db_date_time_format(), time());
else
$this->pbuts_date_start = $options['pbuts_date_start'];
if(empty($options['pbuts_date_end']))
$this->pbuts_date_end = date($timedate->get_db_date_time_format(), strtotime('2010-01-01'));
else
$this->pbuts_date_end = $options['pbuts_date_end'];
if(empty($options['pbuts_ecmquote_status']))
$this->pbuts_ecmquote_status = array();
else
$this->pbuts_ecmquote_status = $options['pbuts_ecmquote_status'];
if(empty($options['pbuts_ecmquote_users']))
$this->pbuts_ecmquote_users = array();
else
$this->pbuts_ecmquote_users = $options['pbuts_ecmquote_users'];
if(empty($options['title']))
$this->title = translate('LBL_PIPELINE_BY_ECMQUOTES_TITLE', 'Home');
else
$this->title = $options['title'];
}
function saveOptions($req) {
global $sugar_config, $timedate, $current_user, $theme;
$options = array();
$date_start = $this->pbuts_date_start;
$date_end = $this->pbuts_date_end;
$dateStartDisplay = strftime($timedate->get_user_date_format(), strtotime($date_start));
$dateEndDisplay = strftime($timedate->get_user_date_format(), strtotime($date_end));
$seps = array("-", "/");
$dates = array($dateStartDisplay, $dateEndDisplay);
$dateFileNameSafe = str_replace($seps, "_", $dates);
if(is_file($sugar_config['tmp_dir'] . $current_user->getUserPrivGuid()."_".$theme."_my_pipeline_".$dateFileNameSafe[0]."_".$dateFileNameSafe[1].".xml"))
unlink($sugar_config['tmp_dir'] . $current_user->getUserPrivGuid()."_".$theme."_my_pipeline_".$dateFileNameSafe[0]."_".$dateFileNameSafe[1].".xml");
$options['title'] = $_REQUEST['pbuts_dashlet_title'];
$options['pbuts_ecmquote_status'] = $_REQUEST['pbuts_ecmquote_status'];
$timeFormat = $current_user->getUserDateTimePreferences();
$options['pbuts_ecmquote_users'] = $_REQUEST['pbuts_ecmquote_users'];
$options['pbuts_date_start'] = $timedate->swap_formats($_REQUEST['pbuts_date_start'], $timeFormat['date'], $timedate->dbDayFormat);
$options['pbuts_date_end'] = $timedate->swap_formats($_REQUEST['pbuts_date_end'], $timeFormat['date'], $timedate->dbDayFormat);
return $options;
}
function displayOptions() {
global $timedate, $image_path, $app_strings, $current_user, $app_list_strings;
$ss = new Sugar_Smarty();
$ss->assign('id', $this->id);
$ss->assign('module', $_REQUEST['module']);
$ss->assign('dashletType', 'predefined_chart');
$ss->assign('LBL_TITLE', translate('LBL_TITLE', 'Charts'));
$ss->assign('LBL_CHART_TYPE', translate('LBL_CHART_TYPE', 'Charts'));
$ss->assign('LBL_DATE_START', translate('LBL_DATE_START', 'Charts'));
$ss->assign('LBL_DATE_END', translate('LBL_DATE_END', 'Charts'));
$ss->assign('LBL_ECMQUOTE_STATUS', translate('LBL_ECMQUOTE_STATUS', 'Charts'));
$ss->assign('LBL_ENTER_DATE', translate('LBL_ENTER_DATE', 'Charts'));
$ss->assign('LBL_ECMQUOTE_USERS', translate('LBL_ECMQUOTE_USERS', 'Charts'));
$ss->assign('LBL_SELECT_BUTTON_TITLE', $app_strings['LBL_SELECT_BUTTON_TITLE']);
$ss->assign('image_path', $image_path);
//get the dates to display
$date_start = $this->pbuts_date_start;
$date_end = $this->pbuts_date_end;
$timeFormat = $current_user->getUserDateTimePreferences();
$ss->assign('date_start', $timedate->swap_formats($date_start, $timedate->dbDayFormat, $timeFormat['date']));
$ss->assign('date_end', $timedate->swap_formats($date_end, $timedate->dbDayFormat, $timeFormat['date']));
$tempx = array();
$datax = array();
$selected_datax = array();
//get list of sales stage keys to display
$user_ecmquote_status = $this->pbuts_ecmquote_status;
$tempx = $user_ecmquote_status;
//set $datax using selected sales stage keys
if (count($tempx) > 0) {
foreach ($tempx as $key) {
$datax[$key] = $app_list_strings['ecmquotes_status_dom'][$key];
array_push($selected_datax, $key);
}
}
else {
$datax = $app_list_strings['ecmquotes_status_dom'];
$selected_datax = array_keys($app_list_strings['ecmquotes_status_dom']);
}
$query = "select id, first_name, last_name from users where deleted='0' and status='Active'";
$dbm = new MysqlManager();
$dbm->connect();
$results = $dbm->query($query);
$us = array();
if(is_resource($results))
while($row = $dbm->fetchByAssoc($results)) $us[$row['id']] = $row['first_name'].' '.$row['last_name'];
$ss->assign('dashlet_title', $this->title);
$ss->assign('selected_datax', get_select_options_with_id($app_list_strings['ecmquotes_status_dom'], $selected_datax));
if(is_array($this->pbuts_ecmquote_users) && count($this->pbuts_ecmquote_users) > 0)
$selected_datax_users = $this->pbuts_ecmquote_users;
else
$selected_datax_users = $us;
$ss->assign('selected_datax_users', get_select_options_with_id($us, $selected_datax_users));
$ss->assign('user_date_format', $timedate->get_user_date_format());
$ss->assign('cal_dateformat', $timedate->get_cal_date_format());
$ss->assign('module', $_REQUEST['module']);
return parent::displayOptions() . $ss->fetch('modules/Charts/Dashlets/PipelineByQuotesStatusDashlet/PipelineByQuotesStatusConfigure.tpl');
}
/**
* Displays the javascript for the dashlet
*
* @return string javascript to use with this dashlet
*/
function displayScript() {
global $sugar_config, $current_user, $current_language;
$xmlFile = $sugar_config['tmp_dir']. $current_user->id . '_' . $this->id . '.xml';
$chartStringsXML = 'cache/xml/chart_strings.' . $current_language .'.lang.xml';
$ss = new Sugar_Smarty();
$ss->assign('chartName', $this->id);
$ss->assign('chartXMLFile', $xmlFile);
$ss->assign('chartStyleCSS', chartStyle());
$ss->assign('chartColorsXML', chartColors());
$ss->assign('chartStringsXML', $chartStringsXML);
$str = $ss->fetch('modules/Charts/Dashlets/PredefinedChartDashletScript.tpl');
return $str;
}
function getTitle($text) {
global $image_path, $app_strings, $sugar_config;
if($this->isConfigurable)
$additionalTitle = '<table width="100%" cellspacing="0" cellpadding="0" border="0"><tr><td width="99%">' . $text
. '</td><td nowrap width="1%"><div style="width: 100%;text-align:right"><a href="#" onclick="SUGAR.mySugar.configureDashlet(\''
. $this->id . '\'); return false;" class="chartToolsLink">'
. get_image($image_path.'edit','title="' . translate('LBL_DASHLET_EDIT', 'Home') . '" alt="' . translate('LBL_DASHLET_EDIT', 'Home') . '" border="0" align="absmiddle"').'</a> '
. '';
else
$additionalTitle = '<table width="100%" cellspacing="0" cellpadding="0" border="0"><tr><td width="99%">' . $text
. '</td><td nowrap width="1%"><div style="width: 100%;text-align:right">';
if($this->isRefreshable)
$additionalTitle .= '<a href="#" onclick="SUGAR.mySugar.retrieveDashlet(\''
. $this->id . '\',\'predefined_chart\'); return false;"><img width="13" height="13" border="0" align="absmiddle" title="' . translate('LBL_DASHLET_REFRESH', 'Home') . '" alt="' . translate('LBL_DASHLET_REFRESH', 'Home') . '" src="'
. $image_path . 'refresh.gif"/></a> ';
$additionalTitle .= '<a href="#" onclick="SUGAR.mySugar.deleteDashlet(\''
. $this->id . '\'); return false;"><img width="13" height="13" border="0" align="absmiddle" title="' . translate('LBL_DASHLET_DELETE', 'Home') . '" alt="' . translate('LBL_DASHLET_DELETE', 'Home') . '" src="'
. $image_path . 'close_dashboard.gif"/></a></div></td></tr></table>';
if(!function_exists('get_form_header')) {
global $theme;
require_once('themes/'.$theme.'/layout_utils.php');
}
$str = '<div ';
if(empty($sugar_config['lock_homepage']) || $sugar_config['lock_homepage'] == false) $str .= ' onmouseover="this.style.cursor = \'move\';"';
$str .= 'id="dashlet_header_' . $this->id . '">' . get_form_header($this->title, $additionalTitle, false) . '</div>';
return $str;
}
function display() {
global $app_list_strings, $current_language, $sugar_config, $currentModule, $action, $current_user, $theme, $timedate, $image_path;
$this->loadLanguage('PipelineByQuotesStatusDashlet', 'modules/Charts/Dashlets/');
$returnStr = '';
$user_dateFormat = $timedate->get_date_format();
$current_module_strings = return_module_language($current_language, 'Charts');
if(isset($_REQUEST['pbuts_refresh'])) {
$refresh = $_REQUEST['pbuts_refresh'];
}
else {
$refresh = false;
}
$date_start = $this->pbuts_date_start;
$date_end = $this->pbuts_date_end;
// cn: format date_start|end to user's preferred
$dateStartDisplay = strftime($timedate->get_user_date_format(), strtotime($date_start));
$dateEndDisplay = strftime($timedate->get_user_date_format(), strtotime($date_end));
$seps = array("-", "/");
$dates = array($date_start, $date_end);
$dateFileNameSafe = str_replace($seps, "_", $dates);
$dateXml[0] = $date_start;
$dateXml[1] = $date_end;
$datax = array();
$selected_datax = array();
//get list of sales stage keys to display
$user_ecmquote_status = $this->pbuts_ecmquote_status;
$tempx = $user_ecmquote_status;
//set $datax using selected sales stage keys
if (count($tempx) > 0) {
foreach ($tempx as $key) {
$datax[$key] = $app_list_strings['ecmquotes_status_dom'][$key];
array_push($selected_datax, $key);
}
}
else {
$datax = $app_list_strings['ecmquotes_status_dom'];
$selected_datax = array_keys($app_list_strings['ecmquotes_status_dom']);
}
$GLOBALS['log']->debug("datax is:");
$GLOBALS['log']->debug($datax);
$ids = array();
$new_ids = array();
$user_ids = $current_user->getPreference('pbuts_ids');
//get list of user ids for which to display data
if (!empty($user_ids) && count($user_ids) != 0 && !isset($_REQUEST['pbuts_ids'])) {
$ids = $user_ids;
$GLOBALS['log']->debug("USER PREFERENCES['pbuts_ids'] is:");
$GLOBALS['log']->debug($user_ids);
}
elseif (isset($_REQUEST['pbuts_ids']) && count($_REQUEST['pbuts_ids']) > 0) {
$ids = $_REQUEST['pbuts_ids'];
$current_user->setPreference('pbuts_ids', $_REQUEST['pbuts_ids']);
$GLOBALS['log']->debug("_REQUEST['pbuts_ids'] is:");
$GLOBALS['log']->debug($_REQUEST['pbuts_ids']);
$GLOBALS['log']->debug("USER PREFERENCES['pbuts_ids'] is:");
$GLOBALS['log']->debug($current_user->getPreference('pbuts_ids'));
}
else {
$ids = get_user_array(false);
$ids = array_keys($ids);
}
//create unique prefix based on selected users for image files
$id_hash = '1';
if (isset($ids)) {
sort($ids);
$id_hash = crc32(implode('',$ids));
if($id_hash < 0)
{
$id_hash = $id_hash * -1;
}
}
$GLOBALS['log']->debug("ids is:");
$GLOBALS['log']->debug($ids);
$id_md5 = substr(md5($current_user->id),0,9);
$seps = array("-", "/");
$dates = array($dateStartDisplay, $dateEndDisplay);
$dateFileNameSafe = str_replace($seps, "_", $dates);
$cache_file_name = $current_user->getUserPrivGuid()."_".$theme."_my_pipeline_".$dateFileNameSafe[0]."_".$dateFileNameSafe[1].".xml";
$GLOBALS['log']->debug("cache file name is: $cache_file_name");
if (file_exists($sugar_config['tmp_dir'].$cache_file_name)) {
$file_date = date($timedate->get_date_format()." ".$timedate->get_time_format(), filemtime($sugar_config['tmp_dir'].$cache_file_name));
}
else {
$file_date = '';
}
require_once('include/Sugar_Smarty.php');
require_once('include/SugarCharts/SugarChart.php');
$sugar_smarty = new Sugar_Smarty();
$charts = array();
$sugarChart = new SugarChart();
$sugarChart->base_url = array( 'module' => 'EcmQuotes',
'action' => 'index',
'query' => 'true',
'searchFormTab' => 'advanced_search',
);
$sugarChart->url_params = array();
$ids = $this->pbuts_ecmquote_users;
global $app_list_strings;
$sugarChart->enum_for_labels = array( 'status' => $app_list_strings['ecmquotes_status_dom'] );
$sugarChart->group_by = $this->constructGroupBy();
$query = $this->constructQuery($datax, $dateXml[0], $dateXml[1], $ids, $sugar_config['tmp_dir'].$cache_file_name, $refresh,'hBarS',$current_module_strings);
//echo '<pre>';print_r($this->getChartData($query));echo '</pre>';
$sugarChart->setData($this->getChartData($query));
$total = $sugarChart->getTotal();
$currency_symbol = $sugar_config['default_currency_symbol'];
if ($current_user->getPreference('currency')){
require_once('modules/Currencies/Currency.php');
$currency = new Currency();
$currency->retrieve($current_user->getPreference('currency'));
$currency_symbol = $currency->symbol;
}
$sugarChart->is_currency = true;
//$sugarChart->currency_symbol = '';
$sugarChart->thousands_symbol = translate('LBL_OPP_THOUSANDS', 'Charts');
$subtitle = translate('LBL_ECMQUOTES_SIZE', 'Charts') . " " . $currency_symbol . "1" . translate('LBL_ECMQUOTES_THOUSANDS', 'Charts');
$pipeline_total_string = translate('LBL_ECMQUOTES_TOTAL', 'Charts') . ' '. $sugarChart->currency_symbol . format_number($total) . $sugarChart->thousands_symbol;
$sugarChart->setProperties($pipeline_total_string, $subtitle, 'horizontal group by chart');
$xmlFile = $sugar_config['tmp_dir']. $current_user->id . '_' . $this->id . '.xml';
$sugarChart->saveXMLFile($xmlFile, $sugarChart->generateXML());
$returnStr .= $sugarChart->display($this->id, $xmlFile, '100%', '480', false);
return $this->getTitle('') . '<div align="center">' .$returnStr . '</div><br />';
}
// awu: Bug 16794 - this function is a hack to get the correct sales stage order until i can clean it up later
function getChartData($query){
global $app_list_strings, $current_user, $sugar_config;
$data = array();
$temp_data = array();
$selected_datax = array();
$user_ecmquote_status = $this->pbuts_ecmquote_status;
$tempx = $user_ecmquote_status;
//set $datax using selected sales stage keys
if (count($tempx) > 0) {
foreach ($tempx as $key) {
$datax[$key] = $app_list_strings['ecmquotes_status_dom'][$key];
array_push($selected_datax, $key);
}
}
else {
$datax = $app_list_strings['ecmquotes_status_dom'];
$selected_datax = array_keys($app_list_strings['ecmquotes_status_dom']);
}
$db = &PearDatabase::getInstance();
$result = $db->query($query);
$row = $db->fetchByAssoc($result, -1, false);
while($row != null){
array_push($temp_data, $row);
$row = $db->fetchByAssoc($result, -1, false);
}
// reorder and set the array based on the order of selected_datax
foreach($selected_datax as $ecmquote_status){
foreach($temp_data as $key => $value){
if ($value['status'] == $ecmquote_status){
//$value['total'] = $symbol . $value['total'];
$value['status'] = $app_list_strings['ecmquotes_status_dom'][$value['status']];
array_push($data, $value);
unset($temp_data[$key]);
}
}
}
//echo '<br><br>'; var_dump($data);
//echo '<pre>';print_r($data);echo '</pre>';
return $data;
}
function constructQuery($datax=array('foo','bar'), $date_start='2071-10-15', $date_end='2071-10-15', $user_id=array('1'), $cache_file_name='a_file', $refresh=false,$chart_size='hBarF',$current_module_strings) {
global $app_strings, $charset, $lang, $barChartColors, $current_user;
require_once('modules/Opportunities/Opportunity.php');
require_once('modules/Currencies/Currency.php');
$kDelim = $current_user->getPreference('num_grp_sep');
global $timedate;
$opp = new Opportunity;
$where="";
//build the where clause for the query that matches $user
$count = count($user_id);
$id = array();
$user_list = get_user_array(false);
foreach ($user_id as $key) {
$new_ids[$key] = $user_list[$key];
}
if ($count>0) {
foreach ($new_ids as $the_id=>$the_name) {
$id[] = "'".$the_id."'";
}
$ids = join(",",$id);
$where .= " ecmquotes.assigned_user_id IN ($ids) ";
}
//build the where clause for the query that matches $datax
$count = count($datax);
$dataxArr = array();
if ($count>0) {
foreach ($datax as $key=>$value) {
$dataxArr[] = "'".$key."'";
}
$dataxArr = join(",",$dataxArr);
$where .= "AND ecmquotes.status IN ($dataxArr) ";
}
//build the where clause for the query that matches $date_start and $date_end
$where .= " AND ecmquotes.date_entered >= ". db_convert("'".$date_start."'",'datetime'). "
AND ecmquotes.date_entered <= ".db_convert("'".$date_end."'",'datetime') ;
$where .= " AND ecmquotes.assigned_user_id = users.id AND ecmquotes.deleted=0 ";
//Now do the db queries
//query for opportunity data that matches $datax and $user
/*
$query = " SELECT opportunities.sales_stage,
users.user_name,
opportunities.assigned_user_id,
count( * ) AS opp_count,
sum(amount_usdollar/1000) AS total
FROM users,opportunities ";
$query .= "WHERE " .$where;
$query .= " GROUP BY opportunities.sales_stage";
$query .= ",users.user_name,opportunities.assigned_user_id";
*/
$query = " SELECT
concat(users.first_name, ' ', users.last_name) as user_name,
ecmquotes.status,
ecmquotes.assigned_user_id,
count( * ) AS opp_count,
sum(total/1000) AS total
FROM users, ecmquotes ";
$query .= "WHERE " .$where;
$query .= " GROUP BY concat(users.first_name, ' ', users.last_name)";
$query .= ", ecmquotes.status, ecmquotes.assigned_user_id";
//var_dump($query);
//$res = $GLOBALS['db']->query($query);
//var_dump($res);
return $query;
}
function constructGroupBy(){
return array( 'user_name',
'status',
);
}
}
?>

View File

@@ -0,0 +1,109 @@
{*
/**
* SugarCRM is a customer relationship management program developed by
* SugarCRM, Inc. Copyright (C) 2004 - 2009 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".
*/
// $Id$
*}
<div style='width: 400px'>
<form name='configure_{$id}' action="index.php" method="post" onSubmit='return SUGAR.dashlets.postForm("configure_{$id}", SUGAR.mySugar.uncoverPage);'>
<input type='hidden' name='id' value='{$id}'>
<input type='hidden' name='module' value='{$module}'>
<input type='hidden' name='action' value='DynamicAction'>
<input type='hidden' name='DynamicAction' value='configureDashlet'>
<input type='hidden' name='to_pdf' value='true'>
<input type='hidden' name='configure' value='true'>
<input type='hidden' id='dashletType' name='dashletType' value='{$dashletType}' />
<table width="400" cellpadding="0" cellspacing="0" border="0" class="tabForm" align="center">
<tr>
<td valign='top' class='dataLabel' nowrap>{$LBL_TITLE} <br /></td>
<td valign='top' class='dataField'>
<input type="text" value="{$dashlet_title}" size="30" name="pbss_dashlet_title"/>
</td>
</tr>
<tr>
<td valign='top' nowrap class='dataLabel'>{$LBL_DATE_START} <br><i>{$user_date_format}</i></td>
<td valign='top' class='dataField'>
<input onblur="parseDate(this, '{$cal_dateformat}');" class="text" name="pbss_date_start" size='12' maxlength='10' id='date_start' value='{$date_start}'>
<img src="themes/default/images/jscalendar.gif" alt="{$LBL_ENTER_DATE}" id="date_start_trigger" align="absmiddle">
</td>
</tr>
<tr>
<td valign='top' nowrap class='dataLabel'>{$LBL_DATE_END}<br><i>{$user_date_format}</i></td>
<td valign='top' class='dataField'>
<input onblur="parseDate(this, '{$cal_dateformat}');" class="text" name="pbss_date_end" size='12' maxlength='10' id='date_end' value='{$date_end}'>
<img src="themes/default/images/jscalendar.gif" alt="{$LBL_ENTER_DATE}" id="date_end_trigger" align="absmiddle">
</td>
</tr>
<tr>
<td valign='top' class='dataLabel' nowrap>{$LBL_SALES_STAGES}</td>
<td valign='top' class='dataField'>
<select name="pbss_sales_stages[]" multiple size='3'>
{$selected_datax}
</select></td>
</tr>
<tr>
<td align="right" colspan="2">
<input type='submit' onclick="" class='button' value='{$LBL_SUBMIT_BUTTON_LABEL}'>
</td>
</tr>
</table>
</form>
{literal}
<script type="text/javascript">
Calendar.setup ({
inputField : "date_start", ifFormat : "{/literal}{$cal_dateformat}{literal}", showsTime : false, button : "date_start_trigger", singleClick : true, step : 1
});
Calendar.setup ({
inputField : "date_end", ifFormat : "{/literal}{$cal_dateformat}{literal}", showsTime : false, button : "date_end_trigger", singleClick : true, step : 1
});
{/literal}
</script>
</div>

View File

@@ -0,0 +1,64 @@
<?php
if(!defined('sugarEntry') || !sugarEntry) die('Not A Valid Entry Point');
/**
* SugarCRM is a customer relationship management program developed by
* SugarCRM, Inc. Copyright (C) 2004 - 2009 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".
*/
$dashletData['PipelineBySalesStageDashlet']['searchFields'] = array(
'pbss_date_start' => array(
'name' => 'pbss_date_start',
'vname' => 'LBL_DATE_START',
'type' => 'datepicker',
),
'pbss_date_end' => array(
'name' => 'pbss_date_end',
'vname' => 'LBL_DATE_END',
'type' => 'datepicker',
),
'pbss_sales_stages' => array(
'name' => 'pbss_sales_stages',
'vname' => 'LBL_SALES_STAGES',
'type' => 'enum',
),
);
?>

View File

@@ -0,0 +1,45 @@
<?php
if(!defined('sugarEntry') || !sugarEntry) die('Not A Valid Entry Point');
/**
* SugarCRM is a customer relationship management program developed by
* SugarCRM, Inc. Copyright (C) 2004 - 2009 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".
*/
$dashletStrings['PipelineBySalesStageDashlet'] = array('LBL_TITLE' => 'Pipeline By Sales Stage',
'LBL_DESCRIPTION' => 'Vertical Bar Chart of Sales Stage Pipeline',
'LBL_REFRESH' => 'Refresh Chart');
?>

View File

@@ -0,0 +1,45 @@
<?php
if(!defined('sugarEntry') || !sugarEntry) die('Not A Valid Entry Point');
/**
* SugarCRM is a customer relationship management program developed by
* SugarCRM, Inc. Copyright (C) 2004 - 2009 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".
*/
$dashletStrings['PipelineBySalesStageDashlet'] = array('LBL_TITLE' => 'Pipeline nach Verkaufsphasen',
'LBL_DESCRIPTION' => 'Vertikales Balkendiagramm der Pipeline nach Verkaufsphasen',
'LBL_REFRESH' => 'Diagramm neu laden');
?>

View File

@@ -0,0 +1,47 @@
<?php
if(!defined('sugarEntry') || !sugarEntry) die('Not A Valid Entry Point');
/**
* SugarCRM is a customer relationship management program developed by
* SugarCRM, Inc. Copyright (C) 2004 - 2009 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".
*/
global $app_strings, $current_language;
$dashletMeta['PipelineBySalesStageDashlet'] = array('title' => 'LBL_TITLE',
'description' => 'LBL_TITLE',
'module' => 'Opportunities',
'icon' => 'themes/default/images/icon_Charts_Funnel_32.gif',
'category' => 'Charts');
?>

View File

@@ -0,0 +1,231 @@
<?php
if(!defined('sugarEntry') || !sugarEntry) die('Not A Valid Entry Point');
/**
* SugarCRM is a customer relationship management program developed by
* SugarCRM, Inc. Copyright (C) 2004 - 2009 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('include/Dashlets/DashletGenericChart.php');
class PipelineBySalesStageDashlet extends DashletGenericChart
{
public $pbss_date_start;
public $pbss_date_end;
public $pbss_sales_stages = array();
protected $_seedName = 'Opportunities';
/**
* @see DashletGenericChart::__construct()
*/
public function __construct(
$id,
array $options = null
)
{
global $timedate;
if(empty($options['pbss_date_start']))
$options['pbss_date_start'] = date($timedate->get_db_date_time_format(), time());
if(empty($options['pbss_date_end']))
$options['pbss_date_end'] = date($timedate->get_db_date_time_format(), strtotime('2010-01-01'));
if(empty($options['title']))
$options['title'] = translate('LBL_PIPELINE_FORM_TITLE', 'Home');
parent::__construct($id,$options);
}
/**
* @see DashletGenericChart::displayOptions()
*/
public function displayOptions()
{
global $app_list_strings;
if (!empty($this->pbss_sales_stages) && count($this->pbss_sales_stages) > 0)
foreach ($this->pbss_sales_stages as $key)
$selected_datax[] = $key;
else
$selected_datax = array_keys($app_list_strings['sales_stage_dom']);
$this->_searchFields['pbss_sales_stages']['options'] = $app_list_strings['sales_stage_dom'];
$this->_searchFields['pbss_sales_stages']['input_name0'] = $selected_datax;
return parent::displayOptions();
}
/**
* @see DashletGenericChart::display()
*/
public function display()
{
global $current_user, $sugar_config;
require_once('include/SugarCharts/SugarChart.php');
$sugarChart = new SugarChart();
$sugarChart->base_url = array(
'module' => 'Opportunities',
'action' => 'index',
'query' => 'true',
'searchFormTab' => 'advanced_search',
);
$sugarChart->url_params = array( );
$sugarChart->group_by = $this->constructGroupBy();
$sugarChart->setData($this->getChartData($this->constructQuery()));
$sugarChart->is_currency = true;
$sugarChart->thousands_symbol = translate('LBL_OPP_THOUSANDS', 'Charts');
$currency_symbol = $sugar_config['default_currency_symbol'];
if ($current_user->getPreference('currency')){
require_once('modules/Currencies/Currency.php');
$currency = new Currency();
$currency->retrieve($current_user->getPreference('currency'));
$currency_symbol = $currency->symbol;
}
$subtitle = translate('LBL_OPP_SIZE', 'Charts') . " " . $currency_symbol . "1" . translate('LBL_OPP_THOUSANDS', 'Charts');
$pipeline_total_string = translate('LBL_TOTAL_PIPELINE', 'Charts') . $sugarChart->currency_symbol . format_number($sugarChart->getTotal(), 0, 0, array('convert'=>true)) . $sugarChart->thousands_symbol;
$sugarChart->setProperties($pipeline_total_string, $subtitle, 'horizontal group by chart');
$xmlFile = $sugarChart->getXMLFileName($this->id);
$sugarChart->saveXMLFile($xmlFile, $sugarChart->generateXML());
return $this->getTitle('') . '<div align="center">' . $sugarChart->display($this->id, $xmlFile, '100%', '480', false) . '</div><br />';
}
/**
* awu: Bug 16794 - this function is a hack to get the correct sales stage order until
* i can clean it up later
*
* @param $query string
* @return array
*/
private function getChartData(
$query
)
{
global $app_list_strings, $db;
$data = array();
$temp_data = array();
$selected_datax = array();
$user_sales_stage = $this->pbss_sales_stages;
$tempx = $user_sales_stage;
//set $datax using selected sales stage keys
if (count($tempx) > 0) {
foreach ($tempx as $key) {
$datax[$key] = $app_list_strings['sales_stage_dom'][$key];
$selected_datax[] = $key;
}
}
else {
$datax = $app_list_strings['sales_stage_dom'];
$selected_datax = array_keys($app_list_strings['sales_stage_dom']);
}
$result = $db->query($query);
while($row = $db->fetchByAssoc($result, -1, false))
$temp_data[] = $row;
// reorder and set the array based on the order of selected_datax
foreach($selected_datax as $sales_stage){
foreach($temp_data as $key => $value){
if ($value['sales_stage'] == $sales_stage){
$value['sales_stage'] = $app_list_strings['sales_stage_dom'][$value['sales_stage']];
$value['key'] = $sales_stage;
$value['value'] = $value['sales_stage'];
$data[] = $value;
unset($temp_data[$key]);
}
}
}
return $data;
}
/**
* @see DashletGenericChart::constructQuery()
*/
protected function constructQuery()
{
$query = " SELECT opportunities.sales_stage,
users.user_name,
opportunities.assigned_user_id,
count( * ) AS opp_count,
sum(amount_usdollar/1000) AS total
FROM users,opportunities ";
$query .= " WHERE opportunities.date_closed >= ". db_convert("'".$this->pbss_date_start."'",'datetime').
" AND opportunities.date_closed <= ".db_convert("'".$this->pbss_date_end."'",'datetime') .
" AND opportunities.assigned_user_id = users.id AND opportunities.deleted=0 ";
if ( count($this->pbss_sales_stages) > 0 )
$query .= " AND opportunities.sales_stage IN ('" . implode("','",$this->pbss_sales_stages) . "') ";
$query .= " GROUP BY opportunities.sales_stage ,users.user_name,opportunities.assigned_user_id";
return $query;
}
/**
* @see DashletGenericChart::constructGroupBy()
*/
protected function constructGroupBy()
{
return array(
'sales_stage',
'user_name',
);
}
}
?>

View File

@@ -0,0 +1,37 @@
<?php
if(!defined('sugarEntry') || !sugarEntry) die('Not A Valid Entry Point');
/**
* The contents of this file are subject to the SugarCRM Professional Subscription
* Agreement ("License") which can be viewed at
* http://www.sugarcrm.com/crm/products/sugar-professional-eula.html
* By installing or using this file, You have unconditionally agreed to the
* terms and conditions of the License, and You may not use this file except in
* compliance with the License. Under the terms of the license, You shall not,
* among other things: 1) sublicense, resell, rent, lease, redistribute, assign
* or otherwise transfer Your rights to the Software, and 2) use the Software
* for timesharing or service bureau purposes such as hosting the Software for
* commercial gain and/or for the benefit of a third party. Use of the Software
* may be subject to applicable fees and any use of the Software without first
* paying applicable fees is strictly prohibited. You do not have the right to
* remove SugarCRM copyrights from the source code or user interface.
*
* All copies of the Covered Code must include on each user interface screen:
* (i) the "Powered by SugarCRM" logo and
* (ii) the SugarCRM copyright notice
* in the same form as they appear in the distribution. See full license for
* requirements.
*
* Your Warranty, Limitations of liability and Indemnity are expressly stated
* in the License. Please refer to the License for the specific language
* governing these rights and limitations under the License. Portions created
* by SugarCRM are Copyright (C) 2004-2007 SugarCRM, Inc.; All Rights Reserved.
*/
$dashletStrings['PipelineBySalesStageDashlet'] = array('LBL_TITLE' => 'Lejek Etapów Sprzedaży',
'LBL_DESCRIPTION' => 'Wykres Lejka Poziomych Belek Etapów Sprzedaży',
'LBL_REFRESH' => 'Odświerz Wykres');
?>

View File

@@ -0,0 +1,115 @@
{*
/**
* 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".
*/
// $Id$
*}
<div style='width: 400px'>
<form name='configure_{$id}' action="index.php" method="post" onSubmit='return SUGAR.dashlets.postForm("configure_{$id}", SUGAR.mySugar.uncoverPage);'>
<input type='hidden' name='id' value='{$id}'>
<input type='hidden' name='module' value='{$module}'>
<input type='hidden' name='action' value='DynamicAction'>
<input type='hidden' name='DynamicAction' value='configureDashlet'>
<input type='hidden' name='to_pdf' value='true'>
<input type='hidden' name='configure' value='true'>
<input type='hidden' id='dashletType' name='dashletType' value='{$dashletType}' />
<table width="400" cellpadding="0" cellspacing="0" border="0" class="tabForm" align="center">
<tr>
<td valign='top' class='dataLabel' nowrap>{$LBL_TITLE} <br /></td>
<td valign='top' class='dataField'>
<input type="text" value="{$dashlet_title}" size="30" name="pbuts_dashlet_title"/>
</td>
</tr>
<tr>
<td valign='top' nowrap class='dataLabel'>{$LBL_DATE_START} <br><i>{$user_date_format}</i></td>
<td valign='top' class='dataField'>
<input onblur="parseDate(this, '{$cal_dateformat}');" class="text" name="pbuts_date_start" size='12' maxlength='10' id='date_start' value='{$date_start}'>
<img src="themes/default/images/jscalendar.gif" alt="{$LBL_ENTER_DATE}" id="date_start_trigger" align="absmiddle">
</td>
</tr>
<tr>
<td valign='top' nowrap class='dataLabel'>{$LBL_DATE_END}<br><i>{$user_date_format}</i></td>
<td valign='top' class='dataField'>
<input onblur="parseDate(this, '{$cal_dateformat}');" class="text" name="pbuts_date_end" size='12' maxlength='10' id='date_end' value='{$date_end}'>
<img src="themes/default/images/jscalendar.gif" alt="{$LBL_ENTER_DATE}" id="date_end_trigger" align="absmiddle">
</td>
</tr>
<tr>
<td valign='top' class='dataLabel' nowrap>{$LBL_BUG_STATUS}</td>
<td valign='top' class='dataField'>
<select name="pbuts_bug_status[]" multiple size='3'>
{$selected_datax}
</select><br /><br /></td>
</tr>
<tr>
<td valign='top' class='dataLabel' nowrap>{$LBL_BUG_USERS}</td>
<td valign='top' class='dataField'>
<select name="pbuts_bug_users[]" multiple size='4'>
{$selected_datax_users}
</select></td>
</tr>
<tr>
<td align="right" colspan="2">
<input type='submit' onclick="" class='button' value='Submit'>
</td>
</tr>
</table>
</form>
{literal}
<script type="text/javascript">
Calendar.setup ({
inputField : "date_start", ifFormat : "{/literal}{$cal_dateformat}{literal}", showsTime : false, button : "date_start_trigger", singleClick : true, step : 1
});
Calendar.setup ({
inputField : "date_end", ifFormat : "{/literal}{$cal_dateformat}{literal}", showsTime : false, button : "date_end_trigger", singleClick : true, step : 1
});
{/literal}
</script>
</div>

View File

@@ -0,0 +1,48 @@
<?php
if(!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".
*/
$dashletStrings['PipelineByUserBugsStatusDashlet'] = array(
'LBL_TITLE' => 'Pipeline By User Bugs Status',
'LBL_DESCRIPTION' => 'Vertical Bar Chart of User Bugs Status',
'LBL_REFRESH' => 'Refresh Chart'
);
?>

View File

@@ -0,0 +1,39 @@
<?php
if(!defined('sugarEntry') || !sugarEntry) die('Not A Valid Entry Point');
/**
* The contents of this file are subject to the SugarCRM Enterprise Subscription
* Agreement ("License") which can be viewed at
* http://www.sugarcrm.com/crm/products/sugar-enterprise-eula.html
* By installing or using this file, You have unconditionally agreed to the
* terms and conditions of the License, and You may not use this file except in
* compliance with the License. Under the terms of the license, You shall not,
* among other things: 1) sublicense, resell, rent, lease, redistribute, assign
* or otherwise transfer Your rights to the Software, and 2) use the Software
* for timesharing or service bureau purposes such as hosting the Software for
* commercial gain and/or for the benefit of a third party. Use of the Software
* may be subject to applicable fees and any use of the Software without first
* paying applicable fees is strictly prohibited. You do not have the right to
* remove SugarCRM copyrights from the source code or user interface.
*
* All copies of the Covered Code must include on each user interface screen:
* (i) the "Powered by SugarCRM" logo and
* (ii) the SugarCRM copyright notice
* in the same form as they appear in the distribution. See full license for
* requirements.
*
* Your Warranty, Limitations of liability and Indemnity are expressly stated
* in the License. Please refer to the License for the specific language
* governing these rights and limitations under the License. Portions created
* by SugarCRM are Copyright (C) 2004-2007 SugarCRM, Inc.; All Rights Reserved.
*/
$dashletStrings['PipelineByUserBugsStatusDashlet'] = array(
'LBL_TITLE' => 'Pipeline By User Bugs Status',
'LBL_DESCRIPTION' => 'Vertical Bar Chart of User Bugs Status',
'LBL_REFRESH' => 'Refresh Chart'
);
?>

View File

@@ -0,0 +1,47 @@
<?php
if(!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".
*/
global $app_strings, $current_language;
$dashletMeta['PipelineByUserBugsStatusDashlet'] = array('title' => 'LBL_TITLE',
'description' => 'LBL_TITLE',
'module' => 'Bugs',
'icon' => 'themes/default/images/icon_Charts_Funnel_32.gif',
'category' => 'Charts');
?>

View File

@@ -0,0 +1,553 @@
<?php
if(!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('include/Dashlets/Dashlet.php');
require_once('include/Sugar_Smarty.php');
require_once('include/charts/Charts.php');
require_once('modules/Dashboard/Forms.php');
class PipelineByUserBugsStatusDashlet extends Dashlet {
var $pbuts_date_start;
var $pbuts_date_end;
var $pbuts_bug_status = null;
var $pbuts_bug_users = null;
var $refresh = false;
function PipelineByUserBugsStatusDashlet($id, $options) {
global $timedate;
parent::Dashlet($id);
$this->isConfigurable = true;
$this->isRefreshable = true;
if(empty($options['pbuts_date_start']))
$this->pbuts_date_start = date($timedate->get_db_date_time_format(), time());
else
$this->pbuts_date_start = $options['pbuts_date_start'];
if(empty($options['pbuts_date_end']))
$this->pbuts_date_end = date($timedate->get_db_date_time_format(), strtotime('2010-01-01'));
else
$this->pbuts_date_end = $options['pbuts_date_end'];
if(empty($options['pbuts_bug_status']))
$this->pbuts_bug_status = array();
else
$this->pbuts_bug_status = $options['pbuts_bug_status'];
if(empty($options['pbuts_bug_users']))
$this->pbuts_bug_users = array();
else
$this->pbuts_bug_users = $options['pbuts_bug_users'];
if(empty($options['title']))
$this->title = translate('LBL_PIPELINE_BY_USER_BUGS_STATUS_FORM_TITLE', 'Home');
else
$this->title = $options['title'];
}
function saveOptions($req) {
global $sugar_config, $timedate, $current_user, $theme;
$options = array();
$date_start = $this->pbuts_date_start;
$date_end = $this->pbuts_date_end;
$dateStartDisplay = strftime($timedate->get_user_date_format(), strtotime($date_start));
$dateEndDisplay = strftime($timedate->get_user_date_format(), strtotime($date_end));
$seps = array("-", "/");
$dates = array($dateStartDisplay, $dateEndDisplay);
$dateFileNameSafe = str_replace($seps, "_", $dates);
if(is_file($sugar_config['tmp_dir'] . $current_user->getUserPrivGuid()."_".$theme."_my_pipeline_".$dateFileNameSafe[0]."_".$dateFileNameSafe[1].".xml"))
unlink($sugar_config['tmp_dir'] . $current_user->getUserPrivGuid()."_".$theme."_my_pipeline_".$dateFileNameSafe[0]."_".$dateFileNameSafe[1].".xml");
$options['title'] = $_REQUEST['pbuts_dashlet_title'];
$options['pbuts_bug_status'] = $_REQUEST['pbuts_bug_status'];
$timeFormat = $current_user->getUserDateTimePreferences();
$options['pbuts_bug_users'] = $_REQUEST['pbuts_bug_users'];
$options['pbuts_date_start'] = $timedate->swap_formats($_REQUEST['pbuts_date_start'], $timeFormat['date'], $timedate->dbDayFormat);
$options['pbuts_date_end'] = $timedate->swap_formats($_REQUEST['pbuts_date_end'], $timeFormat['date'], $timedate->dbDayFormat);
return $options;
}
function displayOptions() {
global $timedate, $image_path, $app_strings, $current_user, $app_list_strings;
$ss = new Sugar_Smarty();
$ss->assign('id', $this->id);
$ss->assign('module', $_REQUEST['module']);
$ss->assign('dashletType', 'predefined_chart');
$ss->assign('LBL_TITLE', translate('LBL_TITLE', 'Charts'));
$ss->assign('LBL_CHART_TYPE', translate('LBL_CHART_TYPE', 'Charts'));
$ss->assign('LBL_DATE_START', translate('LBL_DATE_START', 'Charts'));
$ss->assign('LBL_DATE_END', translate('LBL_DATE_END', 'Charts'));
$ss->assign('LBL_BUG_STATUS', translate('LBL_BUG_STATUS', 'Charts'));
$ss->assign('LBL_ENTER_DATE', translate('LBL_ENTER_DATE', 'Charts'));
$ss->assign('LBL_BUG_USERS', translate('LBL_BUG_USERS', 'Charts'));
$ss->assign('LBL_SELECT_BUTTON_TITLE', $app_strings['LBL_SELECT_BUTTON_TITLE']);
$ss->assign('image_path', $image_path);
//get the dates to display
$date_start = $this->pbuts_date_start;
$date_end = $this->pbuts_date_end;
$timeFormat = $current_user->getUserDateTimePreferences();
$ss->assign('date_start', $timedate->swap_formats($date_start, $timedate->dbDayFormat, $timeFormat['date']));
$ss->assign('date_end', $timedate->swap_formats($date_end, $timedate->dbDayFormat, $timeFormat['date']));
$tempx = array();
$datax = array();
$selected_datax = array();
//get list of sales stage keys to display
$user_bug_status = $this->pbuts_bug_status;
$tempx = $user_bug_status;
//set $datax using selected sales stage keys
if (count($tempx) > 0) {
foreach ($tempx as $key) {
$datax[$key] = $app_list_strings['bug_status_dom'][$key];
array_push($selected_datax, $key);
}
}
else {
$datax = $app_list_strings['bug_status_dom'];
$selected_datax = array_keys($app_list_strings['bug_status_dom']);
}
$query = "select id, user_name from users where deleted='0'";
$dbm = new MysqlManager();
$dbm->connect();
$results = $dbm->query($query);
$us = array();
if(is_resource($results))
while($row = $dbm->fetchByAssoc($results)) $us[$row['id']] = $row['user_name'];
$ss->assign('dashlet_title', $this->title);
$ss->assign('selected_datax', get_select_options_with_id($app_list_strings['bug_status_dom'], $selected_datax));
if(is_array($this->pbuts_bug_users) && count($this->pbuts_bug_users) > 0)
$selected_datax_users = $this->pbuts_bug_users;
else
$selected_datax_users = $us;
$ss->assign('selected_datax_users', get_select_options_with_id($us, $selected_datax_users));
$ss->assign('user_date_format', $timedate->get_user_date_format());
$ss->assign('cal_dateformat', $timedate->get_cal_date_format());
$ss->assign('module', $_REQUEST['module']);
return parent::displayOptions() . $ss->fetch('modules/Charts/Dashlets/PipelineByUserBugsStatusDashlet/PipelineByUserBugsStatusConfigure.tpl');
}
/**
* Displays the javascript for the dashlet
*
* @return string javascript to use with this dashlet
*/
function displayScript() {
global $sugar_config, $current_user, $current_language;
$xmlFile = $sugar_config['tmp_dir']. $current_user->id . '_' . $this->id . '.xml';
$chartStringsXML = 'cache/xml/chart_strings.' . $current_language .'.lang.xml';
$ss = new Sugar_Smarty();
$ss->assign('chartName', $this->id);
$ss->assign('chartXMLFile', $xmlFile);
$ss->assign('chartStyleCSS', chartStyle());
$ss->assign('chartColorsXML', chartColors());
$ss->assign('chartStringsXML', $chartStringsXML);
$str = $ss->fetch('modules/Charts/Dashlets/PredefinedChartDashletScript.tpl');
return $str;
}
function getTitle($text) {
global $image_path, $app_strings, $sugar_config;
if($this->isConfigurable)
$additionalTitle = '<table width="100%" cellspacing="0" cellpadding="0" border="0"><tr><td width="99%">' . $text
. '</td><td nowrap width="1%"><div style="width: 100%;text-align:right"><a href="#" onclick="SUGAR.mySugar.configureDashlet(\''
. $this->id . '\'); return false;" class="chartToolsLink">'
. get_image($image_path.'edit','title="' . translate('LBL_DASHLET_EDIT', 'Home') . '" alt="' . translate('LBL_DASHLET_EDIT', 'Home') . '" border="0" align="absmiddle"').'</a> '
. '';
else
$additionalTitle = '<table width="100%" cellspacing="0" cellpadding="0" border="0"><tr><td width="99%">' . $text
. '</td><td nowrap width="1%"><div style="width: 100%;text-align:right">';
if($this->isRefreshable)
$additionalTitle .= '<a href="#" onclick="SUGAR.mySugar.retrieveDashlet(\''
. $this->id . '\',\'predefined_chart\'); return false;"><img width="13" height="13" border="0" align="absmiddle" title="' . translate('LBL_DASHLET_REFRESH', 'Home') . '" alt="' . translate('LBL_DASHLET_REFRESH', 'Home') . '" src="'
. $image_path . 'refresh.gif"/></a> ';
$additionalTitle .= '<a href="#" onclick="SUGAR.mySugar.deleteDashlet(\''
. $this->id . '\'); return false;"><img width="13" height="13" border="0" align="absmiddle" title="' . translate('LBL_DASHLET_DELETE', 'Home') . '" alt="' . translate('LBL_DASHLET_DELETE', 'Home') . '" src="'
. $image_path . 'close_dashboard.gif"/></a></div></td></tr></table>';
if(!function_exists('get_form_header')) {
global $theme;
require_once('themes/'.$theme.'/layout_utils.php');
}
$str = '<div ';
if(empty($sugar_config['lock_homepage']) || $sugar_config['lock_homepage'] == false) $str .= ' onmouseover="this.style.cursor = \'move\';"';
$str .= 'id="dashlet_header_' . $this->id . '">' . get_form_header($this->title, $additionalTitle, false) . '</div>';
return $str;
}
function display() {
global $app_list_strings, $current_language, $sugar_config, $currentModule, $action, $current_user, $theme, $timedate, $image_path;
$this->loadLanguage('PipelineByUserBugsStatusDashlet', 'modules/Charts/Dashlets/');
$returnStr = '';
$user_dateFormat = $timedate->get_date_format();
$current_module_strings = return_module_language($current_language, 'Charts');
if(isset($_REQUEST['pbuts_refresh'])) {
$refresh = $_REQUEST['pbuts_refresh'];
}
else {
$refresh = false;
}
$date_start = $this->pbuts_date_start;
$date_end = $this->pbuts_date_end;
// cn: format date_start|end to user's preferred
$dateStartDisplay = strftime($timedate->get_user_date_format(), strtotime($date_start));
$dateEndDisplay = strftime($timedate->get_user_date_format(), strtotime($date_end));
$seps = array("-", "/");
$dates = array($date_start, $date_end);
$dateFileNameSafe = str_replace($seps, "_", $dates);
$dateXml[0] = $date_start;
$dateXml[1] = $date_end;
$datax = array();
$selected_datax = array();
//get list of sales stage keys to display
$user_bug_status = $this->pbuts_bug_status;
$tempx = $user_bug_status;
//set $datax using selected sales stage keys
if (count($tempx) > 0) {
foreach ($tempx as $key) {
$datax[$key] = $app_list_strings['bug_status_dom'][$key];
array_push($selected_datax, $key);
}
}
else {
$datax = $app_list_strings['bug_status_dom'];
$selected_datax = array_keys($app_list_strings['bug_status_dom']);
}
$GLOBALS['log']->debug("datax is:");
$GLOBALS['log']->debug($datax);
$ids = array();
$new_ids = array();
$user_ids = $current_user->getPreference('pbuts_ids');
//get list of user ids for which to display data
if (!empty($user_ids) && count($user_ids) != 0 && !isset($_REQUEST['pbuts_ids'])) {
$ids = $user_ids;
$GLOBALS['log']->debug("USER PREFERENCES['pbuts_ids'] is:");
$GLOBALS['log']->debug($user_ids);
}
elseif (isset($_REQUEST['pbuts_ids']) && count($_REQUEST['pbuts_ids']) > 0) {
$ids = $_REQUEST['pbuts_ids'];
$current_user->setPreference('pbuts_ids', $_REQUEST['pbuts_ids']);
$GLOBALS['log']->debug("_REQUEST['pbuts_ids'] is:");
$GLOBALS['log']->debug($_REQUEST['pbuts_ids']);
$GLOBALS['log']->debug("USER PREFERENCES['pbuts_ids'] is:");
$GLOBALS['log']->debug($current_user->getPreference('pbuts_ids'));
}
else {
$ids = get_user_array(false);
$ids = array_keys($ids);
}
//create unique prefix based on selected users for image files
$id_hash = '1';
if (isset($ids)) {
sort($ids);
$id_hash = crc32(implode('',$ids));
if($id_hash < 0)
{
$id_hash = $id_hash * -1;
}
}
$GLOBALS['log']->debug("ids is:");
$GLOBALS['log']->debug($ids);
$id_md5 = substr(md5($current_user->id),0,9);
$seps = array("-", "/");
$dates = array($dateStartDisplay, $dateEndDisplay);
$dateFileNameSafe = str_replace($seps, "_", $dates);
$cache_file_name = $current_user->getUserPrivGuid()."_".$theme."_my_pipeline_".$dateFileNameSafe[0]."_".$dateFileNameSafe[1].".xml";
$GLOBALS['log']->debug("cache file name is: $cache_file_name");
if (file_exists($sugar_config['tmp_dir'].$cache_file_name)) {
$file_date = date($timedate->get_date_format()." ".$timedate->get_time_format(), filemtime($sugar_config['tmp_dir'].$cache_file_name));
}
else {
$file_date = '';
}
require_once('include/Sugar_Smarty.php');
require_once('include/SugarCharts/SugarChart.php');
$sugar_smarty = new Sugar_Smarty();
$charts = array();
$sugarChart = new SugarChart();
$sugarChart->base_url = array( 'module' => 'Bugs',
'action' => 'index',
'query' => 'true',
'searchFormTab' => 'advanced_search',
);
$sugarChart->url_params = array();
$ids = $this->pbuts_bug_users;
global $app_list_strings;
$sugarChart->enum_for_labels = array( 'status' => $app_list_strings['bug_status_dom'] );
$sugarChart->group_by = $this->constructGroupBy();
$query = $this->constructQuery($datax, $dateXml[0], $dateXml[1], $ids, $sugar_config['tmp_dir'].$cache_file_name, $refresh,'hBarS',$current_module_strings);
$sugarChart->setData($this->getChartData($query));
$total = $sugarChart->getTotal();
$currency_symbol = $sugar_config['default_currency_symbol'];
if ($current_user->getPreference('currency')){
require_once('modules/Currencies/Currency.php');
$currency = new Currency();
$currency->retrieve($current_user->getPreference('currency'));
$currency_symbol = $currency->symbol;
}
$sugarChart->is_currency = false;
$sugarChart->currency_symbol = '';
$sugarChart->thousands_symbol = '';//translate('LBL_OPP_THOUSANDS', 'Charts');
$subtitle = translate('LBL_BUG_SIZE', 'Charts');
$pipeline_total_string = translate('LBL_BUGS_TOTAL', 'Charts') . $total;
$sugarChart->setProperties($pipeline_total_string, $subtitle, 'horizontal group by chart');
$xmlFile = $sugar_config['tmp_dir']. $current_user->id . '_' . $this->id . '.xml';
$sugarChart->saveXMLFile($xmlFile, $sugarChart->generateXML());
$returnStr .= $sugarChart->display($this->id, $xmlFile, '100%', '480', false);
return $this->getTitle('') . '<div align="center">' .$returnStr . '</div><br />';
}
// awu: Bug 16794 - this function is a hack to get the correct sales stage order until i can clean it up later
function getChartData($query){
global $app_list_strings, $current_user, $sugar_config;
$data = array();
$temp_data = array();
$selected_datax = array();
$user_bug_status = $this->pbuts_bug_status;
$tempx = $user_bug_status;
//set $datax using selected sales stage keys
if (count($tempx) > 0) {
foreach ($tempx as $key) {
$datax[$key] = $app_list_strings['bug_status_dom'][$key];
array_push($selected_datax, $key);
}
}
else {
$datax = $app_list_strings['bug_status_dom'];
$selected_datax = array_keys($app_list_strings['bug_status_dom']);
}
$db = &PearDatabase::getInstance();
$result = $db->query($query);
$row = $db->fetchByAssoc($result, -1, false);
while($row != null){
array_push($temp_data, $row);
$row = $db->fetchByAssoc($result, -1, false);
}
// reorder and set the array based on the order of selected_datax
foreach($selected_datax as $bug_status){
foreach($temp_data as $key => $value){
if ($value['status'] == $bug_status){
//$value['total'] = $symbol . $value['total'];
//$value['status'] = $app_list_strings['bug_status_dom'][$value['status']];
array_push($data, $value);
unset($temp_data[$key]);
}
}
}
//echo '<br><br>'; var_dump($data);
return $data;
}
function constructQuery($datax=array('foo','bar'), $date_start='2071-10-15', $date_end='2071-10-15', $user_id=array('1'), $cache_file_name='a_file', $refresh=false,$chart_size='hBarF',$current_module_strings) {
global $app_strings, $charset, $lang, $barChartColors, $current_user;
require_once('modules/Opportunities/Opportunity.php');
require_once('modules/Currencies/Currency.php');
$kDelim = $current_user->getPreference('num_grp_sep');
global $timedate;
$opp = new Opportunity;
$where="";
//build the where clause for the query that matches $user
$count = count($user_id);
$id = array();
$user_list = get_user_array(false);
foreach ($user_id as $key) {
$new_ids[$key] = $user_list[$key];
}
if ($count>0) {
foreach ($new_ids as $the_id=>$the_name) {
$id[] = "'".$the_id."'";
}
$ids = join(",",$id);
$where .= " bugs.assigned_user_id IN ($ids) ";
}
//build the where clause for the query that matches $datax
$count = count($datax);
$dataxArr = array();
if ($count>0) {
foreach ($datax as $key=>$value) {
$dataxArr[] = "'".$key."'";
}
$dataxArr = join(",",$dataxArr);
$where .= "AND bugs.status IN ($dataxArr) ";
}
//build the where clause for the query that matches $date_start and $date_end
$where .= " AND bugs.date_entered >= ". db_convert("'".$date_start."'",'datetime'). "
AND bugs.date_entered <= ".db_convert("'".$date_end."'",'datetime') ;
$where .= " AND bugs.assigned_user_id = users.id AND bugs.deleted=0 ";
//Now do the db queries
//query for opportunity data that matches $datax and $user
/*
$query = " SELECT opportunities.sales_stage,
users.user_name,
opportunities.assigned_user_id,
count( * ) AS opp_count,
sum(amount_usdollar/1000) AS total
FROM users,opportunities ";
$query .= "WHERE " .$where;
$query .= " GROUP BY opportunities.sales_stage";
$query .= ",users.user_name,opportunities.assigned_user_id";
*/
$query = " SELECT bugs.status as status,
users.user_name,
bugs.assigned_user_id,
count( * ) AS opp_count,
count( bugs.assigned_user_id ) AS total
FROM users, bugs ";
$query .= "WHERE " .$where;
$query .= " GROUP BY bugs.status";
$query .= ", users.user_name, bugs.assigned_user_id";
//var_dump($query);
//$res = $GLOBALS['db']->query($query);
//var_dump($res);
return $query;
}
function constructGroupBy(){
return array(
'status',
'user_name',
);
}
}
?>

View File

@@ -0,0 +1,115 @@
{*
/**
* 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".
*/
// $Id$
*}
<div style='width: 400px'>
<form name='configure_{$id}' action="index.php" method="post" onSubmit='return SUGAR.dashlets.postForm("configure_{$id}", SUGAR.mySugar.uncoverPage);'>
<input type='hidden' name='id' value='{$id}'>
<input type='hidden' name='module' value='{$module}'>
<input type='hidden' name='action' value='DynamicAction'>
<input type='hidden' name='DynamicAction' value='configureDashlet'>
<input type='hidden' name='to_pdf' value='true'>
<input type='hidden' name='configure' value='true'>
<input type='hidden' id='dashletType' name='dashletType' value='{$dashletType}' />
<table width="400" cellpadding="0" cellspacing="0" border="0" class="tabForm" align="center">
<tr>
<td valign='top' class='dataLabel' nowrap>{$LBL_TITLE} <br /></td>
<td valign='top' class='dataField'>
<input type="text" value="{$dashlet_title}" size="30" name="pbuts_dashlet_title"/>
</td>
</tr>
<tr>
<td valign='top' nowrap class='dataLabel'>{$LBL_DATE_START} <br><i>{$user_date_format}</i></td>
<td valign='top' class='dataField'>
<input onblur="parseDate(this, '{$cal_dateformat}');" class="text" name="pbuts_date_start" size='12' maxlength='10' id='date_start' value='{$date_start}'>
<img src="themes/default/images/jscalendar.gif" alt="{$LBL_ENTER_DATE}" id="date_start_trigger" align="absmiddle">
</td>
</tr>
<tr>
<td valign='top' nowrap class='dataLabel'>{$LBL_DATE_END}<br><i>{$user_date_format}</i></td>
<td valign='top' class='dataField'>
<input onblur="parseDate(this, '{$cal_dateformat}');" class="text" name="pbuts_date_end" size='12' maxlength='10' id='date_end' value='{$date_end}'>
<img src="themes/default/images/jscalendar.gif" alt="{$LBL_ENTER_DATE}" id="date_end_trigger" align="absmiddle">
</td>
</tr>
<tr>
<td valign='top' class='dataLabel' nowrap>{$LBL_TASK_STATUS}</td>
<td valign='top' class='dataField'>
<select name="pbuts_task_status[]" multiple size='3'>
{$selected_datax}
</select><br /><br /></td>
</tr>
<tr>
<td valign='top' class='dataLabel' nowrap>{$LBL_TASK_USERS}</td>
<td valign='top' class='dataField'>
<select name="pbuts_task_users[]" multiple size='4'>
{$selected_datax_users}
</select></td>
</tr>
<tr>
<td align="right" colspan="2">
<input type='submit' onclick="" class='button' value='Submit'>
</td>
</tr>
</table>
</form>
{literal}
<script type="text/javascript">
Calendar.setup ({
inputField : "date_start", ifFormat : "{/literal}{$cal_dateformat}{literal}", showsTime : false, button : "date_start_trigger", singleClick : true, step : 1
});
Calendar.setup ({
inputField : "date_end", ifFormat : "{/literal}{$cal_dateformat}{literal}", showsTime : false, button : "date_end_trigger", singleClick : true, step : 1
});
{/literal}
</script>
</div>

View File

@@ -0,0 +1,48 @@
<?php
if(!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".
*/
$dashletStrings['PipelineByUserTasksStatusDashlet'] = array(
'LBL_TITLE' => 'Pipeline By User Tasks Status',
'LBL_DESCRIPTION' => 'Vertical Bar Chart of User Tasks Status',
'LBL_REFRESH' => 'Refresh Chart'
);
?>

View File

@@ -0,0 +1,39 @@
<?php
if(!defined('sugarEntry') || !sugarEntry) die('Not A Valid Entry Point');
/**
* The contents of this file are subject to the SugarCRM Enterprise Subscription
* Agreement ("License") which can be viewed at
* http://www.sugarcrm.com/crm/products/sugar-enterprise-eula.html
* By installing or using this file, You have unconditionally agreed to the
* terms and conditions of the License, and You may not use this file except in
* compliance with the License. Under the terms of the license, You shall not,
* among other things: 1) sublicense, resell, rent, lease, redistribute, assign
* or otherwise transfer Your rights to the Software, and 2) use the Software
* for timesharing or service bureau purposes such as hosting the Software for
* commercial gain and/or for the benefit of a third party. Use of the Software
* may be subject to applicable fees and any use of the Software without first
* paying applicable fees is strictly prohibited. You do not have the right to
* remove SugarCRM copyrights from the source code or user interface.
*
* All copies of the Covered Code must include on each user interface screen:
* (i) the "Powered by SugarCRM" logo and
* (ii) the SugarCRM copyright notice
* in the same form as they appear in the distribution. See full license for
* requirements.
*
* Your Warranty, Limitations of liability and Indemnity are expressly stated
* in the License. Please refer to the License for the specific language
* governing these rights and limitations under the License. Portions created
* by SugarCRM are Copyright (C) 2004-2007 SugarCRM, Inc.; All Rights Reserved.
*/
$dashletStrings['PipelineByUserTasksStatusDashlet'] = array(
'LBL_TITLE' => 'Pipeline By User Tasks Status',
'LBL_DESCRIPTION' => 'Vertical Bar Chart of User Tasks Status',
'LBL_REFRESH' => 'Refresh Chart'
);
?>

View File

@@ -0,0 +1,47 @@
<?php
if(!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".
*/
global $app_strings, $current_language;
$dashletMeta['PipelineByUserTasksStatusDashlet'] = array('title' => 'LBL_TITLE',
'description' => 'LBL_TITLE',
'module' => 'Tasks',
'icon' => 'themes/default/images/icon_Charts_Funnel_32.gif',
'category' => 'Charts');
?>

View File

@@ -0,0 +1,557 @@
<?php
if(!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('include/Dashlets/Dashlet.php');
require_once('include/Sugar_Smarty.php');
require_once('include/charts/Charts.php');
require_once('modules/Dashboard/Forms.php');
class PipelineByUserTasksStatusDashlet extends Dashlet {
var $pbuts_date_start;
var $pbuts_date_end;
var $pbuts_task_status = null;
var $pbuts_task_users = null;
var $refresh = false;
function PipelineByUserTasksStatusDashlet($id, $options) {
global $timedate;
parent::Dashlet($id);
$this->isConfigurable = true;
$this->isRefreshable = true;
if(empty($options['pbuts_date_start']))
$this->pbuts_date_start = date($timedate->get_db_date_time_format(), time());
else
$this->pbuts_date_start = $options['pbuts_date_start'];
if(empty($options['pbuts_date_end']))
$this->pbuts_date_end = date($timedate->get_db_date_time_format(), strtotime('2010-01-01'));
else
$this->pbuts_date_end = $options['pbuts_date_end'];
if(empty($options['pbuts_task_status']))
$this->pbuts_task_status = array();
else
$this->pbuts_task_status = $options['pbuts_task_status'];
if(empty($options['pbuts_task_users']))
$this->pbuts_task_users = array();
else
$this->pbuts_task_users = $options['pbuts_task_users'];
if(empty($options['title']))
$this->title = translate('LBL_PIPELINE_BY_USER_TASKS_STATUS_FORM_TITLE', 'Home');
else
$this->title = $options['title'];
}
function saveOptions($req) {
global $sugar_config, $timedate, $current_user, $theme;
$options = array();
$date_start = $this->pbuts_date_start;
$date_end = $this->pbuts_date_end;
$dateStartDisplay = strftime($timedate->get_user_date_format(), strtotime($date_start));
$dateEndDisplay = strftime($timedate->get_user_date_format(), strtotime($date_end));
$seps = array("-", "/");
$dates = array($dateStartDisplay, $dateEndDisplay);
$dateFileNameSafe = str_replace($seps, "_", $dates);
if(is_file($sugar_config['tmp_dir'] . $current_user->getUserPrivGuid()."_".$theme."_my_pipeline_".$dateFileNameSafe[0]."_".$dateFileNameSafe[1].".xml"))
unlink($sugar_config['tmp_dir'] . $current_user->getUserPrivGuid()."_".$theme."_my_pipeline_".$dateFileNameSafe[0]."_".$dateFileNameSafe[1].".xml");
$options['title'] = $_REQUEST['pbuts_dashlet_title'];
$options['pbuts_task_status'] = $_REQUEST['pbuts_task_status'];
$timeFormat = $current_user->getUserDateTimePreferences();
$options['pbuts_task_users'] = $_REQUEST['pbuts_task_users'];
$options['pbuts_date_start'] = $timedate->swap_formats($_REQUEST['pbuts_date_start'], $timeFormat['date'], $timedate->dbDayFormat);
$options['pbuts_date_end'] = $timedate->swap_formats($_REQUEST['pbuts_date_end'], $timeFormat['date'], $timedate->dbDayFormat);
return $options;
}
function displayOptions() {
global $timedate, $image_path, $app_strings, $current_user, $app_list_strings;
$ss = new Sugar_Smarty();
$ss->assign('id', $this->id);
$ss->assign('module', $_REQUEST['module']);
$ss->assign('dashletType', 'predefined_chart');
$ss->assign('LBL_TITLE', translate('LBL_TITLE', 'Charts'));
$ss->assign('LBL_CHART_TYPE', translate('LBL_CHART_TYPE', 'Charts'));
$ss->assign('LBL_DATE_START', translate('LBL_DATE_START', 'Charts'));
$ss->assign('LBL_DATE_END', translate('LBL_DATE_END', 'Charts'));
$ss->assign('LBL_TASK_STATUS', translate('LBL_TASK_STATUS', 'Charts'));
$ss->assign('LBL_ENTER_DATE', translate('LBL_ENTER_DATE', 'Charts'));
$ss->assign('LBL_TASK_USERS', translate('LBL_TASK_USERS', 'Charts'));
$ss->assign('LBL_SELECT_BUTTON_TITLE', $app_strings['LBL_SELECT_BUTTON_TITLE']);
$ss->assign('image_path', $image_path);
//get the dates to display
$date_start = $this->pbuts_date_start;
$date_end = $this->pbuts_date_end;
$timeFormat = $current_user->getUserDateTimePreferences();
$ss->assign('date_start', $timedate->swap_formats($date_start, $timedate->dbDayFormat, $timeFormat['date']));
$ss->assign('date_end', $timedate->swap_formats($date_end, $timedate->dbDayFormat, $timeFormat['date']));
$tempx = array();
$datax = array();
$selected_datax = array();
//get list of sales stage keys to display
$user_task_status = $this->pbuts_task_status;
$tempx = $user_task_status;
//set $datax using selected sales stage keys
if (count($tempx) > 0) {
foreach ($tempx as $key) {
$datax[$key] = $app_list_strings['task_status_dom'][$key];
array_push($selected_datax, $key);
}
}
else {
$datax = $app_list_strings['task_status_dom'];
$selected_datax = array_keys($app_list_strings['task_status_dom']);
}
$query = "select id, user_name from users where deleted='0'";
$dbm = new MysqlManager();
$dbm->connect();
$results = $dbm->query($query);
$us = array();
if(is_resource($results))
while($row = $dbm->fetchByAssoc($results)) $us[$row['id']] = $row['user_name'];
$ss->assign('dashlet_title', $this->title);
$ss->assign('selected_datax', get_select_options_with_id($app_list_strings['task_status_dom'], $selected_datax));
if(is_array($this->pbuts_task_users) && count($this->pbuts_task_users) > 0)
$selected_datax_users = $this->pbuts_task_users;
else
$selected_datax_users = $us;
$ss->assign('selected_datax_users', get_select_options_with_id($us, $selected_datax_users));
$ss->assign('user_date_format', $timedate->get_user_date_format());
$ss->assign('cal_dateformat', $timedate->get_cal_date_format());
$ss->assign('module', $_REQUEST['module']);
return parent::displayOptions() . $ss->fetch('modules/Charts/Dashlets/PipelineByUserTasksStatusDashlet/PipelineByUserTasksStatusConfigure.tpl');
}
/**
* Displays the javascript for the dashlet
*
* @return string javascript to use with this dashlet
*/
function displayScript() {
global $sugar_config, $current_user, $current_language;
$xmlFile = $sugar_config['tmp_dir']. $current_user->id . '_' . $this->id . '.xml';
$chartStringsXML = 'cache/xml/chart_strings.' . $current_language .'.lang.xml';
$ss = new Sugar_Smarty();
$ss->assign('chartName', $this->id);
$ss->assign('chartXMLFile', $xmlFile);
$ss->assign('chartStyleCSS', chartStyle());
$ss->assign('chartColorsXML', chartColors());
$ss->assign('chartStringsXML', $chartStringsXML);
$str = $ss->fetch('modules/Charts/Dashlets/PredefinedChartDashletScript.tpl');
return $str;
}
function getTitle($text) {
global $image_path, $app_strings, $sugar_config;
if($this->isConfigurable)
$additionalTitle = '<table width="100%" cellspacing="0" cellpadding="0" border="0"><tr><td width="99%">' . $text
. '</td><td nowrap width="1%"><div style="width: 100%;text-align:right"><a href="#" onclick="SUGAR.mySugar.configureDashlet(\''
. $this->id . '\'); return false;" class="chartToolsLink">'
. get_image($image_path.'edit','title="' . translate('LBL_DASHLET_EDIT', 'Home') . '" alt="' . translate('LBL_DASHLET_EDIT', 'Home') . '" border="0" align="absmiddle"').'</a> '
. '';
else
$additionalTitle = '<table width="100%" cellspacing="0" cellpadding="0" border="0"><tr><td width="99%">' . $text
. '</td><td nowrap width="1%"><div style="width: 100%;text-align:right">';
if($this->isRefreshable)
$additionalTitle .= '<a href="#" onclick="SUGAR.mySugar.retrieveDashlet(\''
. $this->id . '\',\'predefined_chart\'); return false;"><img width="13" height="13" border="0" align="absmiddle" title="' . translate('LBL_DASHLET_REFRESH', 'Home') . '" alt="' . translate('LBL_DASHLET_REFRESH', 'Home') . '" src="'
. $image_path . 'refresh.gif"/></a> ';
$additionalTitle .= '<a href="#" onclick="SUGAR.mySugar.deleteDashlet(\''
. $this->id . '\'); return false;"><img width="13" height="13" border="0" align="absmiddle" title="' . translate('LBL_DASHLET_DELETE', 'Home') . '" alt="' . translate('LBL_DASHLET_DELETE', 'Home') . '" src="'
. $image_path . 'close_dashboard.gif"/></a></div></td></tr></table>';
if(!function_exists('get_form_header')) {
global $theme;
require_once('themes/'.$theme.'/layout_utils.php');
}
$str = '<div ';
if(empty($sugar_config['lock_homepage']) || $sugar_config['lock_homepage'] == false) $str .= ' onmouseover="this.style.cursor = \'move\';"';
$str .= 'id="dashlet_header_' . $this->id . '">' . get_form_header($this->title, $additionalTitle, false) . '</div>';
return $str;
}
function display() {
global $app_list_strings, $current_language, $sugar_config, $currentModule, $action, $current_user, $theme, $timedate, $image_path;
$this->loadLanguage('PipelineByUserTasksStatusDashlet', 'modules/Charts/Dashlets/');
$returnStr = '';
$user_dateFormat = $timedate->get_date_format();
$current_module_strings = return_module_language($current_language, 'Charts');
if(isset($_REQUEST['pbuts_refresh'])) {
$refresh = $_REQUEST['pbuts_refresh'];
}
else {
$refresh = false;
}
$date_start = $this->pbuts_date_start;
$date_end = $this->pbuts_date_end;
// cn: format date_start|end to user's preferred
$dateStartDisplay = strftime($timedate->get_user_date_format(), strtotime($date_start));
$dateEndDisplay = strftime($timedate->get_user_date_format(), strtotime($date_end));
$seps = array("-", "/");
$dates = array($date_start, $date_end);
$dateFileNameSafe = str_replace($seps, "_", $dates);
$dateXml[0] = $date_start;
$dateXml[1] = $date_end;
$datax = array();
$selected_datax = array();
//get list of sales stage keys to display
$user_task_status = $this->pbuts_task_status;
$tempx = $user_task_status;
//set $datax using selected sales stage keys
if (count($tempx) > 0) {
foreach ($tempx as $key) {
$datax[$key] = $app_list_strings['task_status_dom'][$key];
array_push($selected_datax, $key);
}
}
else {
$datax = $app_list_strings['task_status_dom'];
$selected_datax = array_keys($app_list_strings['task_status_dom']);
}
$GLOBALS['log']->debug("datax is:");
$GLOBALS['log']->debug($datax);
$ids = array();
$new_ids = array();
$user_ids = $current_user->getPreference('pbuts_ids');
//get list of user ids for which to display data
if (!empty($user_ids) && count($user_ids) != 0 && !isset($_REQUEST['pbuts_ids'])) {
$ids = $user_ids;
$GLOBALS['log']->debug("USER PREFERENCES['pbuts_ids'] is:");
$GLOBALS['log']->debug($user_ids);
}
elseif (isset($_REQUEST['pbuts_ids']) && count($_REQUEST['pbuts_ids']) > 0) {
$ids = $_REQUEST['pbuts_ids'];
$current_user->setPreference('pbuts_ids', $_REQUEST['pbuts_ids']);
$GLOBALS['log']->debug("_REQUEST['pbuts_ids'] is:");
$GLOBALS['log']->debug($_REQUEST['pbuts_ids']);
$GLOBALS['log']->debug("USER PREFERENCES['pbuts_ids'] is:");
$GLOBALS['log']->debug($current_user->getPreference('pbuts_ids'));
}
else {
$ids = get_user_array(false);
$ids = array_keys($ids);
}
//create unique prefix based on selected users for image files
$id_hash = '1';
if (isset($ids)) {
sort($ids);
$id_hash = crc32(implode('',$ids));
if($id_hash < 0)
{
$id_hash = $id_hash * -1;
}
}
$GLOBALS['log']->debug("ids is:");
$GLOBALS['log']->debug($ids);
$id_md5 = substr(md5($current_user->id),0,9);
$seps = array("-", "/");
$dates = array($dateStartDisplay, $dateEndDisplay);
$dateFileNameSafe = str_replace($seps, "_", $dates);
$cache_file_name = $current_user->getUserPrivGuid()."_".$theme."_my_pipeline_".$dateFileNameSafe[0]."_".$dateFileNameSafe[1].".xml";
$GLOBALS['log']->debug("cache file name is: $cache_file_name");
if (file_exists($sugar_config['tmp_dir'].$cache_file_name)) {
$file_date = date($timedate->get_date_format()." ".$timedate->get_time_format(), filemtime($sugar_config['tmp_dir'].$cache_file_name));
}
else {
$file_date = '';
}
require_once('include/Sugar_Smarty.php');
require_once('include/SugarCharts/SugarChart.php');
$sugar_smarty = new Sugar_Smarty();
$charts = array();
$sugarChart = new SugarChart();
$sugarChart->base_url = array( 'module' => 'Tasks',
'action' => 'index',
'query' => 'true',
'searchFormTab' => 'advanced_search',
);
$sugarChart->url_params = array();
$ids = $this->pbuts_task_users;
global $app_list_strings;
$sugarChart->enum_for_labels = array( 'status' => $app_list_strings['task_status_dom'] );
$sugarChart->group_by = $this->constructGroupBy();
$query = $this->constructQuery($datax, $dateXml[0], $dateXml[1], $ids, $sugar_config['tmp_dir'].$cache_file_name, $refresh,'hBarS',$current_module_strings);
//$ddd = $this->getChartData($query);
$sugarChart->setData($this->getChartData($query));
//print_r($sugarChart->data_set); echo '<br><br>';
$total = $sugarChart->getTotal();
$currency_symbol = $sugar_config['default_currency_symbol'];
if ($current_user->getPreference('currency')){
require_once('modules/Currencies/Currency.php');
$currency = new Currency();
$currency->retrieve($current_user->getPreference('currency'));
$currency_symbol = $currency->symbol;
}
$sugarChart->is_currency = false;
$sugarChart->currency_symbol = '';
$sugarChart->thousands_symbol = '';//translate('LBL_OPP_THOUSANDS', 'Charts');
$subtitle = translate('LBL_TASK_SIZE', 'Charts');
$pipeline_total_string = translate('LBL_TASKS_TOTAL', 'Charts') . $total;
$sugarChart->setProperties($pipeline_total_string, $subtitle, 'horizontal group by chart');
$xmlFile = $sugar_config['tmp_dir']. $current_user->id . '_' . $this->id . '.xml';
$sugarChart->saveXMLFile($xmlFile, $sugarChart->generateXML());
$returnStr .= $sugarChart->display($this->id, $xmlFile, '100%', '480', false);
return $this->getTitle('') . '<div align="center">' .$returnStr . '</div><br />';
}
// awu: Bug 16794 - this function is a hack to get the correct sales stage order until i can clean it up later
function getChartData($query){
global $app_list_strings, $current_user, $sugar_config;
$data = array();
$temp_data = array();
$selected_datax = array();
$user_task_status = $this->pbuts_task_status;
$tempx = $user_task_status;
//set $datax using selected sales stage keys
if (count($tempx) > 0) {
foreach ($tempx as $key) {
$datax[$key] = $app_list_strings['task_status_dom'][$key];
array_push($selected_datax, $key);
}
}
else {
$datax = $app_list_strings['task_status_dom'];
$selected_datax = array_keys($app_list_strings['task_status_dom']);
}
$db = &PearDatabase::getInstance();
$result = $db->query($query);
$row = $db->fetchByAssoc($result, -1, false);
while($row != null){
array_push($temp_data, $row);
$row = $db->fetchByAssoc($result, -1, false);
}
// reorder and set the array based on the order of selected_datax
foreach($selected_datax as $task_status){
foreach($temp_data as $key => $value){
if ($value['status'] == $task_status){
//$value['total'] = $symbol . $value['total'];
//$value['status'] = $app_list_strings['task_status_dom'][$value['status']];
array_push($data, $value);
unset($temp_data[$key]);
}
}
}
//echo '<br><br>'; var_dump($data);
return $data;
}
function constructQuery($datax=array('foo','bar'), $date_start='2071-10-15', $date_end='2071-10-15', $user_id=array('1'), $cache_file_name='a_file', $refresh=false,$chart_size='hBarF',$current_module_strings) {
global $app_strings, $charset, $lang, $barChartColors, $current_user;
require_once('modules/Opportunities/Opportunity.php');
require_once('modules/Currencies/Currency.php');
$kDelim = $current_user->getPreference('num_grp_sep');
global $timedate;
$opp = new Opportunity;
$where="";
//build the where clause for the query that matches $user
$count = count($user_id);
$id = array();
$user_list = get_user_array(false);
foreach ($user_id as $key) {
$new_ids[$key] = $user_list[$key];
}
if ($count>0) {
foreach ($new_ids as $the_id=>$the_name) {
$id[] = "'".$the_id."'";
}
$ids = join(",",$id);
$where .= " tasks.assigned_user_id IN ($ids) ";
}
//build the where clause for the query that matches $datax
$count = count($datax);
$dataxArr = array();
if ($count>0) {
foreach ($datax as $key=>$value) {
$dataxArr[] = "'".$key."'";
}
$dataxArr = join(",",$dataxArr);
$where .= "AND tasks.status IN ($dataxArr) ";
}
//build the where clause for the query that matches $date_start and $date_end
$where .= " AND tasks.date_entered >= ". db_convert("'".$date_start."'",'datetime'). "
AND tasks.date_entered <= ".db_convert("'".$date_end."'",'datetime') ;
$where .= " AND tasks.assigned_user_id = users.id AND tasks.deleted=0 ";
//Now do the db queries
//query for opportunity data that matches $datax and $user
/*
$query = " SELECT opportunities.sales_stage,
users.user_name,
opportunities.assigned_user_id,
count( * ) AS opp_count,
sum(amount_usdollar/1000) AS total
FROM users,opportunities ";
$query .= "WHERE " .$where;
$query .= " GROUP BY opportunities.sales_stage";
$query .= ",users.user_name,opportunities.assigned_user_id";
*/
$query = " SELECT tasks.status as status,
users.user_name,
tasks.assigned_user_id,
count( * ) AS opp_count,
count( tasks.assigned_user_id ) AS total
FROM users, tasks ";
$query .= "WHERE " .$where;
$query .= " GROUP BY tasks.status";
$query .= ", users.user_name, tasks.assigned_user_id";
//var_dump($query);
//$res = $GLOBALS['db']->query($query);
//var_dump($res);
return $query;
}
function constructGroupBy(){
return array(
'status',
'user_name',
);
}
}
?>

View File

@@ -0,0 +1,44 @@
{*
/**
* SugarCRM is a customer relationship management program developed by
* SugarCRM, Inc. Copyright (C) 2004 - 2009 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".
*/
// $Id$
*}
<script>
SUGAR.mySugar.addToChartsArray('{$chartName}', '{$chartXMLFile}', '100%', '480', '{$chartStyleCSS}', '{$chartColorsXML}', '{$chartStringsXML}');
</script>