mirror of
https://github.com/salesagility/SuiteCRM.git
synced 2024-11-21 23:47:57 +00:00
230 lines
8.1 KiB
PHP
Executable File
230 lines
8.1 KiB
PHP
Executable File
<?php
|
|
/**
|
|
*
|
|
* SugarCRM Community Edition is a customer relationship management program developed by
|
|
* SugarCRM, Inc. Copyright (C) 2004-2013 SugarCRM Inc.
|
|
*
|
|
* SuiteCRM is an extension to SugarCRM Community Edition developed by SalesAgility Ltd.
|
|
* Copyright (C) 2011 - 2018 SalesAgility Ltd.
|
|
*
|
|
* This program is free software; you can redistribute it and/or modify it under
|
|
* the terms of the GNU Affero 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 Affero General Public License for more
|
|
* details.
|
|
*
|
|
* You should have received a copy of the GNU Affero 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 Affero General Public License version 3.
|
|
*
|
|
* In accordance with Section 7(b) of the GNU Affero General Public License version 3,
|
|
* these Appropriate Legal Notices must retain the display of the "Powered by
|
|
* SugarCRM" logo and "Supercharged by SuiteCRM" logo. If the display of the logos is not
|
|
* reasonably feasible for technical reasons, the Appropriate Legal Notices must
|
|
* display the words "Powered by SugarCRM" and "Supercharged by SuiteCRM".
|
|
*/
|
|
#[\AllowDynamicProperties]
|
|
class Favorites extends Basic
|
|
{
|
|
public $new_schema = true;
|
|
public $module_dir = 'Favorites';
|
|
public $object_name = 'Favorites';
|
|
public $table_name = 'favorites';
|
|
public $importable = false;
|
|
public $tracker_visibility = false;
|
|
public $disable_row_level_security = true;
|
|
public $id;
|
|
public $name;
|
|
public $date_entered;
|
|
public $date_modified;
|
|
public $modified_user_id;
|
|
public $modified_by_name;
|
|
public $created_by;
|
|
public $created_by_name;
|
|
public $description;
|
|
public $deleted;
|
|
public $created_by_link;
|
|
public $modified_user_link;
|
|
public $assigned_user_id;
|
|
public $assigned_user_name;
|
|
public $assigned_user_link;
|
|
public $parent_id;
|
|
public $parent_type;
|
|
|
|
/**
|
|
* @param $id
|
|
* @return bool
|
|
*/
|
|
public function deleteFavorite($id)
|
|
{
|
|
if ($id) {
|
|
$favorite_record = BeanFactory::getBean('Favorites', $id);
|
|
$favorite_record->deleted = 1;
|
|
$favorite_record->save();
|
|
|
|
return true;
|
|
} else {
|
|
return false;
|
|
}
|
|
}
|
|
|
|
/**
|
|
* @param $module
|
|
* @param $record_id
|
|
* @return array
|
|
*/
|
|
public function getFavoriteID($module, $record_id)
|
|
{
|
|
global $current_user;
|
|
$db = DBManagerFactory::getInstance();
|
|
|
|
$recordIdQuote = $db->quote($record_id);
|
|
$moduleQuote = $db->quote($module);
|
|
$currentUserIdQuote = $db->quote($current_user->id);
|
|
|
|
$query = "SELECT id FROM favorites WHERE parent_id= '" . $recordIdQuote .
|
|
"' AND parent_type = '" . $moduleQuote . "' AND assigned_user_id = '" .
|
|
$currentUserIdQuote . "' AND deleted = 0 ORDER BY date_entered DESC";
|
|
|
|
return $db->getOne($query);
|
|
}
|
|
|
|
/**
|
|
* @param string $id
|
|
* @return array
|
|
*/
|
|
public function getCurrentUserSidebarFavorites($id = null)
|
|
{
|
|
global $current_user;
|
|
$db = DBManagerFactory::getInstance();
|
|
|
|
$return_array = array();
|
|
|
|
$currentUserIdQuote = $db->quote($current_user->id);
|
|
if ($id) {
|
|
$idQuote = $db->quote($id);
|
|
$query = "SELECT parent_id, parent_type FROM favorites WHERE assigned_user_id = '" .
|
|
$currentUserIdQuote . "' AND parent_id = '" . $idQuote .
|
|
"' AND deleted = 0 ORDER BY date_entered DESC";
|
|
} else {
|
|
$query = "SELECT parent_id, parent_type FROM favorites WHERE assigned_user_id = '" .
|
|
$currentUserIdQuote . "' AND deleted = 0 ORDER BY date_entered DESC";
|
|
}
|
|
|
|
$result = $db->query($query);
|
|
|
|
$i = 0;
|
|
while ($row = $db->fetchByAssoc($result)) {
|
|
$bean = BeanFactory::getBean($row['parent_type'], $row['parent_id']);
|
|
if ($bean) {
|
|
$return_array[$i]['item_summary'] = $bean->name;
|
|
$return_array[$i]['item_summary_short'] = to_html(getTrackerSubstring($bean->name));
|
|
$return_array[$i]['id'] = $row['parent_id'];
|
|
$return_array[$i]['module_name'] = $row['parent_type'];
|
|
|
|
// Change since 7.7 side bar icons can exist in images/sidebar.
|
|
$sidebarPath = 'themes/' . SugarThemeRegistry::current() . '/images/sidebar/modules/';
|
|
if (file_exists($sidebarPath)) {
|
|
$return_array[$i]['image'] = SugarThemeRegistry::current()->getImage('sidebar/modules/' . $row['parent_type'], 'border="0" align="absmiddle"', null, null, '.gif', $bean->name);
|
|
} else {
|
|
$return_array[$i]['image'] = SugarThemeRegistry::current()->getImage($row['parent_type'], 'border="0" align="absmiddle"', null, null, '.gif', $bean->name);
|
|
}
|
|
|
|
++$i;
|
|
}
|
|
}
|
|
|
|
return $return_array;
|
|
}
|
|
|
|
/**
|
|
* @parm string $module
|
|
* @return array Representing an array of \SuiteCRM\API\JsonApi\Resource\Resource
|
|
*/
|
|
public function getCurrentUserFavoritesForModule($module)
|
|
{
|
|
$db = DBManagerFactory::getInstance();
|
|
global $current_user;
|
|
global $moduleList;
|
|
|
|
if (empty($module)) {
|
|
throw new \SuiteCRM\Exception\Exception(
|
|
'[Favorites] [module not specified]',
|
|
\SuiteCRM\Enumerator\ExceptionCode::APPLICATION_UNHANDLED_BEHAVIOUR
|
|
);
|
|
}
|
|
|
|
if (in_array($module, $moduleList) === false) {
|
|
throw new \SuiteCRM\Exception\Exception(
|
|
'[Favorites] [module not found] ' . $module,
|
|
\SuiteCRM\Enumerator\ExceptionCode::APPLICTAION_MODULE_NOT_FOUND
|
|
);
|
|
}
|
|
|
|
$response = array();
|
|
|
|
$currentUserIdQuote = $db->quote($current_user->id);
|
|
$moduleQuote = $db->quote($module);
|
|
$dbResult = $db->query(
|
|
"SELECT parent_id, parent_type FROM favorites " .
|
|
" WHERE assigned_user_id = '" . $currentUserIdQuote . "'" .
|
|
" AND deleted = 0 " .
|
|
" AND parent_type = '" . $moduleQuote . "'" .
|
|
" ORDER BY date_entered DESC "
|
|
);
|
|
|
|
while ($row = $db->fetchByAssoc($dbResult)) {
|
|
/** @var \SugarBean $sugarBean */
|
|
$sugarBean = BeanFactory::getBean($row['parent_type'], $row['parent_id']);
|
|
if ($sugarBean !== false) {
|
|
$response[] = array(
|
|
'id' => $sugarBean->id,
|
|
'type' => $sugarBean->module_name,
|
|
'attributes' => array(
|
|
'name' => $sugarBean->name
|
|
)
|
|
);
|
|
}
|
|
}
|
|
|
|
return $response;
|
|
}
|
|
|
|
public function save($notify = false)
|
|
{
|
|
global $current_user;
|
|
|
|
if (empty($this->assigned_user_id)) {
|
|
$this->assigned_user_id = $current_user->id;
|
|
}
|
|
parent::save($notify);
|
|
}
|
|
/**
|
|
* @param string $interface
|
|
* @return bool
|
|
*/
|
|
public function bean_implements($interface)
|
|
{
|
|
switch ($interface) {
|
|
case 'ACL':
|
|
return false;
|
|
default:
|
|
return false;
|
|
}
|
|
}
|
|
}
|