myItemsOnly = false;
parent::DashletGeneric($id, $def);
$this->myItemsOnly = false;
$this->isConfigurable = true;
$this->hasScript = true;
$pattern = array();
$pattern[] = "/-/";
$pattern[] = "/[0-9]/";
$replacements = array();
$replacements[] = '';
$replacements[] = '';
$this->idjs = preg_replace($pattern,$replacements,$this->id);
// Add in some default categories.
$this->categories['ALL'] = translate('LBL_ALL','SugarFeed');
// Need to get the rest of the active SugarFeed modules
$module_list = SugarFeed::getActiveFeedModules();
// Translate the category names
if ( ! is_array($module_list) ) { $module_list = array(); }
foreach ( $module_list as $module ) {
if ( $module == 'UserFeed' ) {
// Fake module, need to translate specially
$this->categories[$module] = translate('LBL_USER_FEED','SugarFeed');
} else {
$this->categories[$module] = $app_list_strings['moduleList'][$module];
}
}
// Need to add the external api's here
$this->externalAPIList = ExternalAPIFactory::getModuleDropDown('SugarFeed',true);
if ( !is_array($this->externalAPIList) ) { $this->externalAPIList = array(); }
foreach ( $this->externalAPIList as $apiObj => $apiName ) {
$this->categories[$apiObj] = $apiName;
}
if(empty($def['title'])) $this->title = translate('LBL_HOMEPAGE_TITLE', 'SugarFeed');
if(!empty($def['rows']))$this->displayRows = $def['rows'];
if(!empty($def['categories']))$this->selectedCategories = $def['categories'];
if(!empty($def['userfeed_created'])) $this->userfeed_created = $def['userfeed_created'];
$this->searchFields = $dashletData['SugarFeedDashlet']['searchFields'];
$this->columns = $dashletData['SugarFeedDashlet']['columns'];
$catCount = count($this->categories);
ACLController::filterModuleList($this->categories, false);
if(count($this->categories) < $catCount){
if(!empty($this->selectedCategories)){
ACLController::filterModuleList($this->selectedCategories, true);
}else{
$this->selectedCategories = array_keys($this->categories);
unset($this->selectedCategories[0]);
}
}
$this->seedBean = new SugarFeed();
}
function process($lvsParams = array()) {
global $current_user;
$currentSearchFields = array();
$configureView = true; // configure view or regular view
$query = false;
$whereArray = array();
$lvsParams['massupdate'] = false;
// apply filters
if(isset($this->filters) || $this->myItemsOnly) {
$whereArray = $this->buildWhere();
}
$this->lvs->export = false;
$this->lvs->multiSelect = false;
$this->lvs->quickViewLinks = false;
// columns
foreach($this->columns as $name => $val) {
if(!empty($val['default']) && $val['default']) {
$displayColumns[strtoupper($name)] = $val;
$displayColumns[strtoupper($name)]['label'] = trim($displayColumns[strtoupper($name)]['label'], ':');
}
}
$this->lvs->displayColumns = $displayColumns;
$this->lvs->lvd->setVariableName($this->seedBean->object_name, array());
$lvsParams['overrideOrder'] = true;
$lvsParams['orderBy'] = 'date_entered';
$lvsParams['sortOrder'] = 'DESC';
$lvsParams['custom_from'] = '';
// Get the real module list
if (empty($this->selectedCategories)){
$mod_list = $this->categories;
} else {
$mod_list = array_flip($this->selectedCategories);//27949, here the key of $this->selectedCategories is not module name, the value is module name, so array_flip it.
}
$external_modules = array();
$admin_modules = array();
$owner_modules = array();
$regular_modules = array();
foreach($mod_list as $module => $ignore) {
// Handle the UserFeed differently
if ( $module == 'UserFeed') {
$regular_modules[] = 'UserFeed';
continue;
}
if ( in_array($module,$this->externalAPIList) ) {
$external_modules[] = $module;
}
if (ACLAction::getUserAccessLevel($current_user->id,$module,'view') <= ACL_ALLOW_NONE ) {
// Not enough access to view any records, don't add it to any lists
continue;
}
if ( ACLAction::getUserAccessLevel($current_user->id,$module,'view') == ACL_ALLOW_OWNER ) {
$owner_modules[] = $module;
} else {
$regular_modules[] = $module;
}
}
if(!empty($this->displayTpl))
{
//MFH BUG #14296
$where = '';
if(!empty($whereArray)){
$where = '(' . implode(') AND (', $whereArray) . ')';
}
$additional_where = '';
$module_limiter = " sugarfeed.related_module in ('" . implode("','", $regular_modules) . "')";
if( is_admin($GLOBALS['current_user'] ) )
{
$all_modules = array_merge($regular_modules, $owner_modules, $admin_modules);
$module_limiter = " sugarfeed.related_module in ('" . implode("','", $all_modules) . "')";
}
else if ( count($owner_modules) > 0
) {
$module_limiter = " ((sugarfeed.related_module IN ('".implode("','", $regular_modules)."') "
.") ";
if ( count($owner_modules) > 0 ) {
$module_limiter .= "OR (sugarfeed.related_module IN('".implode("','", $owner_modules)."') AND sugarfeed.assigned_user_id = '".$current_user->id."' "
.") ";
}
$module_limiter .= ")";
}
if(!empty($where)) { $where .= ' AND '; }
$where .= $module_limiter;
$this->lvs->setup($this->seedBean, $this->displayTpl, $where , $lvsParams, 0, $this->displayRows,
array('name',
'description',
'date_entered',
'created_by',
'related_module',
'link_url',
'link_type'));
foreach($this->lvs->data['data'] as $row => $data) {
$this->lvs->data['data'][$row]['NAME'] = str_replace("{this.CREATED_BY}",get_assigned_user_name($this->lvs->data['data'][$row]['CREATED_BY']),$data['NAME']);
//Translate the SugarFeeds labels if necessary.
preg_match('/\{([^\^ }]+)\.([^\}]+)\}/', $this->lvs->data['data'][$row]['NAME'] ,$modStringMatches );
if(count($modStringMatches) == 3 && $modStringMatches[1] == 'SugarFeed' && !empty($data['RELATED_MODULE']) )
{
$modKey = $modStringMatches[2];
$modString = translate($modKey, $modStringMatches[1]);
if( strpos($modString, '{0}') === FALSE || !isset($GLOBALS['app_list_strings']['moduleListSingular'][$data['RELATED_MODULE']]) )
continue;
$modStringSingular = $GLOBALS['app_list_strings']['moduleListSingular'][$data['RELATED_MODULE']];
$modString = string_format($modString, array($modStringSingular) );
$this->lvs->data['data'][$row]['NAME'] = preg_replace('/' . $modStringMatches[0] . '/', strtolower($modString), $this->lvs->data['data'][$row]['NAME']);
}
}
// assign a baseURL w/ the action set as DisplayDashlet
foreach($this->lvs->data['pageData']['urls'] as $type => $url) {
// awu Replacing action=DisplayDashlet with action=DynamicAction&DynamicAction=DisplayDashlet
if($type == 'orderBy')
$this->lvs->data['pageData']['urls'][$type] = preg_replace('/(action=.*&)/Ui', 'action=DynamicAction&DynamicAction=displayDashlet&', $url);
else
$this->lvs->data['pageData']['urls'][$type] = preg_replace('/(action=.*&)/Ui', 'action=DynamicAction&DynamicAction=displayDashlet&', $url) . '&sugar_body_only=1&id=' . $this->id;
}
$this->lvs->ss->assign('dashletId', $this->id);
}
$td = $GLOBALS['timedate'];
$needResort = false;
$resortQueue = array();
$feedErrors = array();
$fetchRecordCount = $this->displayRows + $this->lvs->data['pageData']['offsets']['current'];
foreach ( $external_modules as $apiName ) {
$api = ExternalAPIFactory::loadAPI($apiName);
if ( $api !== FALSE ) {
// FIXME: Actually calculate the oldest sugar feed we can see, once we get an API that supports this sort of filter.
$reply = $api->getLatestUpdates(0,$fetchRecordCount);
if ( $reply['success'] && count($reply['messages']) > 0 ) {
array_splice($resortQueue, count($resortQueue), 0, $reply['messages']);
} else if ( !$reply['success'] ) {
$feedErrors[] = $reply['errorMessage'];
}
}
}
if ( count($feedErrors) > 0 ) {
$this->lvs->ss->assign('feedErrors',$feedErrors);
}
// If we need to resort, get to work!
foreach ( $this->lvs->data['data'] as $normalMessage ) {
list($user_date,$user_time) = explode(' ',$normalMessage['DATE_ENTERED']);
list($db_date,$db_time) = $td->to_db_date_time($user_date,$user_time);
$unix_timestamp = strtotime($db_date.' '.$db_time);
$normalMessage['sort_key'] = $unix_timestamp;
$normalMessage['NAME'] = ''.$normalMessage['NAME'];
$resortQueue[] = $normalMessage;
}
usort($resortQueue,create_function('$a,$b','return $a["sort_key"]<$b["sort_key"];'));
// Trim it down to the necessary number of records
$numRecords = count($resortQueue);
$numRecords = $numRecords - $this->lvs->data['pageData']['offsets']['current'];
$numRecords = min($this->displayRows,$numRecords);
$this->lvs->data['data'] = $resortQueue;
}
function deleteUserFeed() {
if(!empty($_REQUEST['record'])) {
$feed = new SugarFeed();
$feed->retrieve($_REQUEST['record']);
if(is_admin($GLOBALS['current_user']) || $feed->created_by == $GLOBALS['current_user']->id){
$feed->mark_deleted($_REQUEST['record']);
}
}
}
function pushUserFeed() {
if(!empty($_REQUEST['text']) || (!empty($_REQUEST['link_url']) && !empty($_REQUEST['link_type']))) {
$text = htmlspecialchars($_REQUEST['text']);
//allow for bold and italic user tags
$text = preg_replace('/<(\/*[bi])>/i','<$1>', $text);
SugarFeed::pushFeed($text, 'UserFeed', $GLOBALS['current_user']->id,
$GLOBALS['current_user']->id,
$_REQUEST['link_type'], $_REQUEST['link_url']
);
}
}
function pushUserFeedReply( ) {
if(!empty($_REQUEST['text'])&&!empty($_REQUEST['parentFeed'])) {
$text = htmlspecialchars($_REQUEST['text']);
//allow for bold and italic user tags
$text = preg_replace('/<(\/*[bi])>/i','<$1>', $text);
SugarFeed::pushFeed($text, 'SugarFeed', $_REQUEST['parentFeed'],
$GLOBALS['current_user']->id,
'', ''
);
}
}
function displayOptions() {
global $app_strings;
global $app_list_strings;
$ss = new Sugar_Smarty();
$ss->assign('titleLBL', translate('LBL_TITLE', 'SugarFeed'));
$ss->assign('categoriesLBL', translate('LBL_CATEGORIES', 'SugarFeed'));
$ss->assign('autenticationPendingLBL', translate('LBL_AUTHENTICATION_PENDING', 'SugarFeed'));
$ss->assign('rowsLBL', translate('LBL_ROWS', 'SugarFeed'));
$ss->assign('saveLBL', $app_strings['LBL_SAVE_BUTTON_LABEL']);
$ss->assign('clearLBL', $app_strings['LBL_CLEAR_BUTTON_LABEL']);
$ss->assign('title', $this->title);
$ss->assign('categories', $this->categories);
if ( empty($this->selectedCategories) ) {
$this->selectedCategories['ALL'] = 'ALL';
}
$ss->assign('selectedCategories', $this->selectedCategories);
$ss->assign('rows', $this->displayRows);
$externalApis = array();
foreach ( $this->externalAPIList as $apiObj => $apiName ) {
//only show external APis that the user has not created
if ( ! EAPM::getLoginInfo($apiName) ) {
$externalApis[] = $apiObj;
}
}
$ss->assign('externalApiList', JSON::encode($externalApis));
$ss->assign('authenticateLBL', translate('LBL_AUTHENTICATE', 'SugarFeed'));
$ss->assign('id', $this->id);
if($this->isAutoRefreshable()) {
$ss->assign('isRefreshable', true);
$ss->assign('autoRefresh', $GLOBALS['app_strings']['LBL_DASHLET_CONFIGURE_AUTOREFRESH']);
$ss->assign('autoRefreshOptions', $this->getAutoRefreshOptions());
$ss->assign('autoRefreshSelect', $this->autoRefresh);
}
return $ss->fetch('modules/SugarFeed/Dashlets/SugarFeedDashlet/Options.tpl');
}
/**
* creats the values
* @return
* @param $req Object
*/
function saveOptions($req) {
global $sugar_config, $timedate, $current_user, $theme;
$options = array();
$options['title'] = $req['title'];
$rows = intval($_REQUEST['rows']);
if($rows <= 0) {
$rows = 15;
}
if($rows > 100){
$rows = 100;
}
if ( isset($req['autoRefresh']) )
$options['autoRefresh'] = $req['autoRefresh'];
$options['rows'] = $rows;
$options['categories'] = $req['categories'];
foreach($options['categories'] as $cat){
if($cat == 'ALL'){
unset($options['categories']);
}
}
return $options;
}
function sugarFeedDisplayScript() {
// Forces the quicksearch to reload anytime the dashlet gets refreshed
return '';
}
/**
*
* @return javascript including QuickSearch for SugarFeeds
*/
function displayScript() {
require_once('include/QuickSearchDefaults.php');
$ss = new Sugar_Smarty();
$ss->assign('saving', translate('LBL_SAVING', 'SugarFeed'));
$ss->assign('saved', translate('LBL_SAVED', 'SugarFeed'));
$ss->assign('id', $this->id);
$ss->assign('idjs', $this->idjs);
$str = $ss->fetch('modules/SugarFeed/Dashlets/SugarFeedDashlet/SugarFeedScript.tpl');
return $str; // return parent::display for title and such
}
/**
*
* @return the fully rendered dashlet
*/
function display(){
$listview = parent::display();
$GLOBALS['current_sugarfeed'] = $this;
$listview = preg_replace_callback('/\{([^\^ }]+)\.([^\}]+)\}/', create_function(
'$matches',
'if($matches[1] == "this"){$var = $matches[2]; return $GLOBALS[\'current_sugarfeed\']->$var;}else{return translate($matches[2], $matches[1]);}'
),$listview);
//grab each token and store the module for later processing
preg_match_all('/\[(\w+)\:/', $listview, $alt_modules);
//now process each token to create the proper url and image tags in feed, leaving a string for the alt to be replaced in next step
$listview = preg_replace('/\[(\w+)\:([\w\-\d]*)\:([^\]]*)\]/', '$3', $listview); /*SKIP_IMAGE_TAG*/
//process each module for the singular version so we can populate the alt tag on the image
$altStrings = array();
foreach($alt_modules[1] as $alt){
//create the alt string and replace the alt token
$altString = 'alt="'.translate('LBL_VIEW','SugarFeed').' '.$GLOBALS['app_list_strings']['moduleListSingular'][$alt].'"';
$listview = preg_replace('/REPLACE_ALT/', $altString, $listview,1);
}
return $listview.'';
}
/**
*
* @return the title and the user post form
* @param $text Object
*/
function getHeader($text='') {
return parent::getHeader($text) . $this->getPostForm().$this->getDisabledWarning().$this->sugarFeedDisplayScript().'