From b0446e29b678176643b82a47e107a4e7325e40d9 Mon Sep 17 00:00:00 2001 From: Damien <damien.burel@maarch.org> Date: Fri, 25 Oct 2019 11:35:52 +0200 Subject: [PATCH] FEAT #12003 TIME 0:45 Remove menu V1 --- .../contact_purposes/contact_purposes_up.php | 29 +- .../contact_types/contact_types_up.php | 27 -- .../admin/update_control/update_control.php | 149 ------- apps/maarch_entreprise/lang/en.php | 91 ----- apps/maarch_entreprise/log.php | 4 - apps/maarch_entreprise/shibbolethConnect.php | 1 - apps/maarch_entreprise/template/header.html | 32 +- core/class/class_core_tools.php | 367 ------------------ modules/export_seda/RequestSeda.php | 1 - .../folder-pinned/folder-pinned.component.ts | 2 +- 10 files changed, 3 insertions(+), 700 deletions(-) delete mode 100755 apps/maarch_entreprise/admin/update_control/update_control.php diff --git a/apps/maarch_entreprise/admin/contacts/contact_purposes/contact_purposes_up.php b/apps/maarch_entreprise/admin/contacts/contact_purposes/contact_purposes_up.php index 69a93c2b6bf..3733ce1fae1 100755 --- a/apps/maarch_entreprise/admin/contacts/contact_purposes/contact_purposes_up.php +++ b/apps/maarch_entreprise/admin/contacts/contact_purposes/contact_purposes_up.php @@ -220,33 +220,6 @@ if (isset($_REQUEST['valid'])) { ?> <div id="header"> <div id="nav"> - <div id="menu" onmouseover="ShowHideMenu('menunav','on');" onmouseout="ShowHideMenu('menunav','off');" class="off"> - <p> - <span style="background:url('');background-position: 10px 2px;background-size:25%; - background-repeat: no-repeat; - height: 30px; - font-weight: bold; - width: 85px; - display: block; - font-size: 23px; - padding-left: 65px; - padding-top: 4px; - color: #ffffff;">Menu</span> - </p> - <div id="menunav" style="display: none;"> - <?php - echo '<div class="header_menu"></div>'; - echo '<div class="header_menu_blank"> </div>';?> - <ul > - <?php - //here we building the maarch menu - $core->build_menu($_SESSION['menu']); - ?> - </ul> - <div class="header_menu_blank"> </div> - <div class="footer_menu"><a onclick="triggerAngular('#/about-us')" style="cursor: pointer;color:white;float:right;"><?php echo _MAARCH_CREDITS ;?></a></div> - </div> - </div> <div><p id="ariane"><?php ?></p></div> <p id="gauchemenu"></p> @@ -377,4 +350,4 @@ if (isset($_REQUEST['valid']) && $mode <> 'popup') { </div> </div> <?php -} \ No newline at end of file +} diff --git a/apps/maarch_entreprise/admin/contacts/contact_types/contact_types_up.php b/apps/maarch_entreprise/admin/contacts/contact_types/contact_types_up.php index 9aa1d57fa5c..83a7d6233f8 100755 --- a/apps/maarch_entreprise/admin/contacts/contact_types/contact_types_up.php +++ b/apps/maarch_entreprise/admin/contacts/contact_types/contact_types_up.php @@ -209,33 +209,6 @@ if (isset($_REQUEST['valid'])) { ?> <div id="header"> <div id="nav"> - <div id="menu" onmouseover="ShowHideMenu('menunav','on');" onmouseout="ShowHideMenu('menunav','off');" class="off"> - <p> - <span style="background:url('');background-position: 10px 2px;background-size:25%; - background-repeat: no-repeat; - height: 30px; - font-weight: bold; - width: 85px; - display: block; - font-size: 23px; - padding-left: 65px; - padding-top: 4px; - color: #ffffff;">Menu</span> - </p> - <div id="menunav" style="display: none;"> - <?php - echo '<div class="header_menu"></div>'; - echo '<div class="header_menu_blank"> </div>';?> - <ul > - <?php - //here we building the maarch menu - $core->build_menu($_SESSION['menu']); - ?> - </ul> - <div class="header_menu_blank"> </div> - <div class="footer_menu"><a onclick="triggerAngular('#/about-us')" style="cursor: pointer;color:white;float:right;"><?php echo _MAARCH_CREDITS ;?></a></div> - </div> - </div> <div><p id="ariane"><?php ?></p></div> <p id="gauchemenu"></p> diff --git a/apps/maarch_entreprise/admin/update_control/update_control.php b/apps/maarch_entreprise/admin/update_control/update_control.php deleted file mode 100755 index 4ee0c84748e..00000000000 --- a/apps/maarch_entreprise/admin/update_control/update_control.php +++ /dev/null @@ -1,149 +0,0 @@ -<?php - -/** - * Copyright Maarch since 2008 under licence GPLv3. - * See LICENCE.txt file at the root folder for more details. - * This file is part of Maarch software. - */ -/** - * @brief Maarch version test - * - * @file - * - * @author dev@maarch.org - * @date $date$ - * - * @version $Revision$ - * @ingroup admin - */ -core_tools::load_lang(); -$core_tools = new core_tools(); -$core_tools->test_admin('admin_update_control', 'apps'); - -$init = false; -if (isset($_REQUEST['reinit']) && $_REQUEST['reinit'] == 'true') { - $init = true; -} - -$pagePath = $_SESSION['config']['businessappurl'].'index.php?page='.'update_control&admin=update_control'; -$pageLabel = _ADMIN_UPDATE_CONTROL; -$pageId = 'update_control'; -$level = ''; -if (isset($_REQUEST['level']) - && ($_REQUEST['level'] == 2 || $_REQUEST['level'] == 3 - || $_REQUEST['level'] == 4 || $_REQUEST['level'] == 1)) { - $level = $_REQUEST['level']; -} -$core_tools->manage_location_bar($pagePath, $pageLabel, $pageId, $init, $level); - -//retrives tags -$client = new \Gitlab\Client('https://labs.maarch.org/api/v4/'); - -$tags = $client->api('tags')->all('12'); - -//retrieve current version -$db = new Database(); -$query = "SELECT param_value_string FROM parameters WHERE id = 'database_version'"; -$stmt = $db->query($query, []); -$currentVersion = $stmt->fetchObject(); - -$currentVersionBranch = substr($currentVersion->param_value_string, 0, 5); -$currentVersionBranchYear = substr($currentVersion->param_value_string, 0, 2); -$currentVersionBranchMonth = substr($currentVersion->param_value_string, 3, 2); -$currentVersionTag = substr($currentVersion->param_value_string, 6); - -$allCurrentTags = []; -$allNextTags = []; -$cptCurrentTags = 0; -$isAnyAvailableTag = false; - -foreach ($tags as $value) { - if (!preg_match("/^\d{2}\.\d{2}\.\d+$/", $value['name'])) { - continue; - } - $tag = substr($value['name'], 6); - $pos = strpos($value['name'], $currentVersionBranch); - if ($pos === false) { - $year = substr($value['name'], 0, 2); - $month = substr($value['name'], 3, 2); - if (($year == $currentVersionBranchYear && $month > $currentVersionBranchMonth) || $year > $currentVersionBranchYear) { - $allNextTags[] = $value['name']; - } - } else { - $allCurrentTags[$cptCurrentTags] = []; - $allCurrentTags[$cptCurrentTags]['name'] = $value['name']; - if ($tag > $currentVersionTag) { - $allCurrentTags[$cptCurrentTags]['enabled'] = true; - $isAnyAvailableTag = true; - } else { - $allCurrentTags[$cptCurrentTags]['enabled'] = false; - } - ++$cptCurrentTags; - } -} -?> -<h1><i class="fa fa-download fa-2x"></i> <?php echo _ADMIN_UPDATE_CONTROL; ?></h1> - -<div id="inner_content"> -<table align="center" style="margin-top:100px"> - <tr> - <td><?php echo _YOUR_VERSION; ?></td> - <td>:</td> - <td> - <?php echo '<b>'.$currentVersion->param_value_string.'</b>'; ?> - </td> - </tr> - <tr> - <td colspan="3"> </td> - </tr> - <tr> - <td><?php echo _AVAILABLE_VERSION_TO_UPDATE; ?></td> - <td>:</td> - <td> - <?php - if (count($tags) > 0) { - ?> - <select id="version" id="name"> - <?php - for ($i = 0; $i < count($allCurrentTags); ++$i) { - if ($allCurrentTags[$i]['enabled']) { - echo '<option value="'.$allCurrentTags[$i]['name'].'">'; - echo $allCurrentTags[$i]['name']; - echo '</option>'; - } else { - echo '<option value="'.$allCurrentTags[$i]['name'].'" disabled>'; - echo $allCurrentTags[$i]['name']; - echo '</option>'; - } - } ?> - </select> - <?php - } else { - echo _NO_AVAILABLE_TAG_TO_UPDATE.'<br />'; - } - ?> - </td> - </tr> - <tr><td colspan="3"> </td></tr> -</table> - -<div align="center" style="margin-bottom:150px"> - <?php - if ($isAnyAvailableTag && count($tags) > 0) { - if ($_SESSION['user']['UserId'] != 'superadmin') { - echo _CONNECT_YOU_IN_SUPERADMIN; - } else { - echo '<a style="margin-top:100px" href="'.$_SESSION['config']['coreurl'].'install/index.php?step=update_language"><input class="button" value="'._CLICK_HERE_TO_GO_TO_UPDATE_MANAGEMENT.'" type="button"></a>'; - } - } - - if (!empty($allNextTags)) { - echo '<br><br><br><b>'._NEW_MAJOR_VERSION_AVAILABLE.'</b> : <br>'; - for ($j = 0; $j < count($allNextTags); ++$j) { - echo $allNextTags[$j].'<br />'; - } - } - ?> -</div> - -</div> \ No newline at end of file diff --git a/apps/maarch_entreprise/lang/en.php b/apps/maarch_entreprise/lang/en.php index 1391efc7a77..a59c34f6e0a 100755 --- a/apps/maarch_entreprise/lang/en.php +++ b/apps/maarch_entreprise/lang/en.php @@ -4449,97 +4449,6 @@ if (!defined('_DELETED_PRIORITY')) { } /***** Administration *****/ -/**** admin update control ****/ -if (!defined('_ADMIN_UPDATE_CONTROL')) { - define('_ADMIN_UPDATE_CONTROL', 'Verify update'); -} -if (!defined('_ADMIN_UPDATE_CONTROL_DESC')) { - define('_ADMIN_UPDATE_CONTROL_DESC', 'Check new tags of Maarch Courrier and update application in latest tag.'); -} -if (!defined('_YOUR_VERSION')) { - define('_YOUR_VERSION', 'Your version'); -} -if (!defined('_AVAILABLE_VERSION_TO_UPDATE')) { - define('_AVAILABLE_VERSION_TO_UPDATE', 'Available versions'); -} -if (!defined('_CLICK_HERE_TO_GO_TO_UPDATE_MANAGEMENT')) { - define('_CLICK_HERE_TO_GO_TO_UPDATE_MANAGEMENT', 'To begin the update process'); -} -if (!defined('_NEW_MAJOR_VERSION_AVAILABLE')) { - define('_NEW_MAJOR_VERSION_AVAILABLE', 'New major version available'); -} -if (!defined('_BRANCH_VERSION')) { - define('_BRANCH_VERSION', 'Branch'); -} -if (!defined('_TAG_VERSION')) { - define('_TAG_VERSION', 'Tag'); -} -if (!defined('_CONNECT_YOU_IN_SUPERADMIN')) { - define('_CONNECT_YOU_IN_SUPERADMIN', 'You have to be connected with superadmin profile to process update'); -} -if (!defined('_UPDATE_WELCOME')) { - define('_UPDATE_WELCOME', 'Update'); -} -if (!defined('_UPDATE_WELCOME_INSTALL')) { - define('_UPDATE_WELCOME_INSTALL', 'Update process'); -} -if (!defined('_UPDATE_DESC_INSTALL')) { - define('_UPDATE_DESC_INSTALL', 'Update MaarchCourrier (only minor version)'); -} -if (!defined('_UPDATE_BACKUP')) { - define('_UPDATE_BACKUP', 'Backup'); -} -if (!defined('_UPDATE_BACKUP_INFOS')) { - define('_UPDATE_BACKUP_INFOS', 'Backup your version'); -} -if (!defined('_UPDATE_BACKUP_DETAILS')) { - define('_UPDATE_BACKUP_DETAILS', 'Backup your version, you can restore it if necessary'); -} -if (!defined('_ACTUAL_VERSION_PATH')) { - define('_ACTUAL_VERSION_PATH', 'Path of your installation'); -} -if (!defined('_UPDATE_BACKUP_PATH')) { - define('_UPDATE_BACKUP_PATH', 'Path of your backup'); -} -if (!defined('_BACKUP_ACTUAL_VERSION')) { - define('_BACKUP_ACTUAL_VERSION', 'Backup your version'); -} -if (!defined('_UPDATE_DOWNLOAD')) { - define('_UPDATE_DOWNLOAD', 'Download'); -} -if (!defined('_LAST_RELEASE_INFOS')) { - define('_LAST_RELEASE_INFOS', 'Download last minor version'); -} -if (!defined('_LAST_RELEASE_DETAILS')) { - define('_LAST_RELEASE_DETAILS', 'Available minor versions'); -} -if (!defined('_CHOOSE_VERSION_TO_UPDATE')) { - define('_CHOOSE_VERSION_TO_UPDATE', 'Choose the version'); -} -if (!defined('_DOWNLOAD_VERSION')) { - define('_DOWNLOAD_VERSION', 'Download the version'); -} -if (!defined('_UPDATE_DEPLOY')) { - define('_UPDATE_DEPLOY', 'Deploiement'); -} -if (!defined('_UPDATE_DEPLOY_INFOS')) { - define('_UPDATE_DEPLOY_INFOS', 'Deploiement of the downloaded version'); -} -if (!defined('_UPDATE_DEPLOY_DETAILS')) { - define('_UPDATE_DEPLOY_DETAILS', 'Deploiement of the downloaded version'); -} -if (!defined('_DEPLOY_VERSION')) { - define('_DEPLOY_VERSION', 'Deploy the version'); -} -if (!defined('_UPDATE_END')) { - define('_UPDATE_END', 'Update sucessful'); -} -if (!defined('_UPDATE_DESC_END')) { - define('_UPDATE_DESC_END', 'Update sucessful'); -} -if (!defined('_NO_AVAILABLE_TAG_TO_UPDATE')) { - define('_NO_AVAILABLE_TAG_TO_UPDATE', 'No available tag to update'); -} if (!defined('_ADDRESS_NB')) { define('_ADDRESS_NB', 'Address number'); } diff --git a/apps/maarch_entreprise/log.php b/apps/maarch_entreprise/log.php index a53173278d2..48aa5afb66a 100755 --- a/apps/maarch_entreprise/log.php +++ b/apps/maarch_entreprise/log.php @@ -104,7 +104,6 @@ if (empty($_SESSION['config']['databasename'])) { $businessAppTools->build_business_app_config(); $core->load_modules_config($_SESSION['modules']); - $core->load_menu($_SESSION['modules']); $core->load_lang(); $core->load_app_services(); $core->load_modules_services($_SESSION['modules']); @@ -195,7 +194,6 @@ if (!empty($_SESSION['error'])) { \SrcCore\models\AuthenticationModel::setCookieAuth(['userId' => $login]); \SrcCore\models\AuthenticationModel::resetFailedAuthentication(['userId' => $login]); $user = \User\models\UserModel::getByLogin(['login' => $login, 'select' => ['id']]); - $core->load_menu($_SESSION['modules']); header( 'location: ' . $_SESSION['config']['businessappurl'] . $res['url'] @@ -261,7 +259,6 @@ if (!empty($_SESSION['error'])) { } else { $_SESSION['error'] = $res['error']; } - $core->load_menu($_SESSION['modules']); header( 'location: ' . $_SESSION['config']['businessappurl'] . $res['url'] @@ -299,7 +296,6 @@ if (!empty($_SESSION['error'])) { if (empty($res['error'])) { \SrcCore\models\AuthenticationModel::setCookieAuth(['userId' => $login]); \SrcCore\models\AuthenticationModel::resetFailedAuthentication(['userId' => $login]); - $core->load_menu($_SESSION['modules']); } else { $_SESSION['error'] = $res['error']; } diff --git a/apps/maarch_entreprise/shibbolethConnect.php b/apps/maarch_entreprise/shibbolethConnect.php index 2f92585c895..cf9ce2a4934 100755 --- a/apps/maarch_entreprise/shibbolethConnect.php +++ b/apps/maarch_entreprise/shibbolethConnect.php @@ -35,7 +35,6 @@ if ($_SERVER['REMOTE_USER'] <> '' && $_SERVER['AUTH_TYPE'] = 'shibboleth') { if ($res['error'] == '') { \SrcCore\models\AuthenticationModel::setCookieAuth(['userId' => $login]); - $core->load_menu($_SESSION['modules']); //login OK $trace = new history(); header('location: ' . $_SESSION['config']['businessappurl']. $res['url']); diff --git a/apps/maarch_entreprise/template/header.html b/apps/maarch_entreprise/template/header.html index 4677dfe0f1b..1f403f2e9e0 100755 --- a/apps/maarch_entreprise/template/header.html +++ b/apps/maarch_entreprise/template/header.html @@ -6,36 +6,6 @@ </div> </a> <div style="justify-content: flex-end;display: flex;width: 100%;color: white;align-items: center;"> - <span class="maarchToolButton" style="cursor:pointer;padding:15px;padding-left: 20px;padding-right: 20px;position: relative;margin-right: 15px;" onclick="$j('#menunav').slideToggle('fast');event.stopPropagation();" title="Menu"> - <i class="fa fa-th fa-2x" style="font-size: 20px;"></i> - <div id="menunav" class="menunav" style="left: -225px;display:none;"> - <div class="header_menu_blank"> </div> - <ul> - <?php - //here we building the maarch menu - $core->build_menu($_SESSION['menu']); - ?> - </ul> - <div class="header_menu_blank"> </div> - <div class="footer_menu"> - <i style="font-style:normal;color:white;float:left;"> - <?php echo $_SESSION['config']['applicationname']; ?> - </i> - <a onclick="triggerAngular('#/about-us')" style="cursor: pointer;color:white;float:right;"><?php echo _MAARCH_CREDITS ;?></a> - <div style="clear:both;"></div> - </div> - </div> - <script> - $j(window).click(function(event) { - if ($j('#menunav').css('display') != 'none') { - $j('#menunav').slideToggle('fast'); - } - if ($j('#profilenav').css('display') != 'none') { - $j('#profilenav').slideToggle('fast'); - } - }); - </script> - </span> <span class="maarchToolButton" style="padding-left:10px;padding-right:10px;font-size: 14px;text-align: center;display: flex;align-items: center;position: relative;cursor:pointer;" onclick="$j('#profilenav').slideToggle('fast');event.stopPropagation();" title="Mes groupes"> <?php $strUserInfos = '<i class="fa fa-user fa-2x" style="padding-right:5px;"></i> ' . $_SESSION['user']['FirstName']." <b>".$_SESSION['user']['LastName']."</b>"; @@ -72,4 +42,4 @@ </div> </div> </div> -<div><p id="ariane"></p></div> \ No newline at end of file +<div><p id="ariane"></p></div> diff --git a/core/class/class_core_tools.php b/core/class/class_core_tools.php index 5881c9536ce..f090ac00100 100755 --- a/core/class/class_core_tools.php +++ b/core/class/class_core_tools.php @@ -68,12 +68,9 @@ class core_tools extends functions // Loads core tables into session ($_SESSION['tablename'] array) $TABLENAME = $xmlconfig->TABLENAME; $_SESSION['tablename']['actions'] = (string) $TABLENAME->actions; - $_SESSION['tablename']['authors'] = (string) $TABLENAME->authors; $_SESSION['tablename']['docservers'] = (string) $TABLENAME->docservers; $_SESSION['tablename']['doctypes'] = (string) $TABLENAME->doctypes; $_SESSION['tablename']['history'] = (string) $TABLENAME->history; - $_SESSION['tablename']['history_batch'] = (string) $TABLENAME->history_batch; - $_SESSION['tablename']['param'] = (string) $TABLENAME->param; $_SESSION['tablename']['security'] = (string) $TABLENAME->security; $_SESSION['tablename']['status'] = (string) $TABLENAME->status; $_SESSION['tablename']['usergroups'] = (string) $TABLENAME->usergroups; @@ -328,370 +325,6 @@ class core_tools extends functions } } - /** - * Loads menu items of each module and the application into session from menu.xml files. - * - * @param $modules array Enabled modules of the application - */ - public function load_menu($modules) - { - $k = 0; - if (file_exists( - $_SESSION['config']['corepath'].'custom'.DIRECTORY_SEPARATOR - .$_SESSION['custom_override_id'].DIRECTORY_SEPARATOR.'apps' - .DIRECTORY_SEPARATOR.$_SESSION['config']['app_id'] - .DIRECTORY_SEPARATOR.'xml'.DIRECTORY_SEPARATOR.'menu.xml' - ) - ) { - $path = $_SESSION['config']['corepath'].'custom' - .DIRECTORY_SEPARATOR.$_SESSION['custom_override_id'] - .DIRECTORY_SEPARATOR.'apps'.DIRECTORY_SEPARATOR - .$_SESSION['config']['app_id'].DIRECTORY_SEPARATOR.'xml' - .DIRECTORY_SEPARATOR.'menu.xml'; - } else { - $path = 'apps'.DIRECTORY_SEPARATOR.$_SESSION['config']['app_id'] - .DIRECTORY_SEPARATOR.'xml'.DIRECTORY_SEPARATOR.'menu.xml'; - } - // Reads the apps/apps_name/xml/menu.xml file and loads into session - $xmlconfig = simplexml_load_file($path); - foreach ($xmlconfig->MENU as $MENU2) { - $_SESSION['menu'][$k]['id'] = (string) $MENU2->id; - $_SESSION['menu'][$k]['angular'] = empty((string) $MENU2->angular) ? 'false' : (string) $MENU2->angular; - if (isset($_SESSION['menu'][$k]['id']) - && isset($_SESSION['user']['services'][$_SESSION['menu'][$k]['id']]) - && $_SESSION['user']['services'][$_SESSION['menu'][$k]['id']] == true - ) { // Menu Identifier must be equal to the Service identifier - $libmenu = (string) $MENU2->libconst; - if (!empty($libmenu) && defined($libmenu) - && constant($libmenu) != null - ) { - $libmenu = constant($libmenu); - } - $_SESSION['menu'][$k]['libconst'] = $libmenu; - if ($_SESSION['menu'][$k]['angular'] == 'true') { - $_SESSION['menu'][$k]['url'] = (string) $MENU2->url; - } else { - $_SESSION['menu'][$k]['url'] = $_SESSION['config']['businessappurl'].(string) $MENU2->url; - } - if (trim((string) $MENU2->target) != '') { - $tmp = preg_replace( - '/\/core\/$/', '/', $_SESSION['urltocore'] - ); - $_SESSION['menu'][$k]['url'] = $tmp.(string) $MENU2->url; - $_SESSION['menu'][$k]['target'] = (string) $MENU2->target; - } - $_SESSION['menu'][$k]['style'] = (string) $MENU2->style; - $_SESSION['menu'][$k]['show'] = true; - } else { - $_SESSION['menu'][$k]['libconst'] = ''; - $_SESSION['menu'][$k]['url'] = ''; - $_SESSION['menu'][$k]['style'] = ''; - $_SESSION['menu'][$k]['show'] = false; - } - ++$k; - } - // Browses the enabled modules array - for ($i = 0; $i < count($modules); ++$i) { - if (file_exists( - $_SESSION['config']['corepath'].'custom'.DIRECTORY_SEPARATOR - .$_SESSION['custom_override_id'].DIRECTORY_SEPARATOR - .'modules'.DIRECTORY_SEPARATOR.$modules[$i]['moduleid'] - .DIRECTORY_SEPARATOR.'xml'.DIRECTORY_SEPARATOR.'menu.xml' - ) - ) { - $menuPath = $_SESSION['config']['corepath'].'custom' - .DIRECTORY_SEPARATOR.$_SESSION['custom_override_id'] - .DIRECTORY_SEPARATOR.'modules'.DIRECTORY_SEPARATOR - .$modules[$i]['moduleid'].DIRECTORY_SEPARATOR.'xml' - .DIRECTORY_SEPARATOR.'menu.xml'; - } else { - $menuPath = 'modules'.DIRECTORY_SEPARATOR - .$modules[$i]['moduleid'].DIRECTORY_SEPARATOR.'xml' - .DIRECTORY_SEPARATOR.'menu.xml'; - } - - if (file_exists( - $_SESSION['config']['corepath'].'modules' - .DIRECTORY_SEPARATOR.$modules[$i]['moduleid'] - .DIRECTORY_SEPARATOR.'xml'.DIRECTORY_SEPARATOR.'menu.xml' - ) || file_exists( - $_SESSION['config']['corepath'].'custom'.DIRECTORY_SEPARATOR - .$_SESSION['custom_override_id'].DIRECTORY_SEPARATOR - .'modules'.DIRECTORY_SEPARATOR.$modules[$i]['moduleid'] - .DIRECTORY_SEPARATOR.'xml'.DIRECTORY_SEPARATOR.'menu.xml' - ) - ) { - $xmlconfig = simplexml_load_file($menuPath); - foreach ($xmlconfig->MENU as $MENU) { - $_SESSION['menu'][$k]['id'] = (string) $MENU->id; - $_SESSION['menu'][$k]['angular'] = empty((string) $MENU->angular) ? 'false' : (string) $MENU->angular; - if (isset( - $_SESSION['user']['services'][$_SESSION['menu'][$k]['id']] - ) - && $_SESSION['user']['services'][$_SESSION['menu'][$k]['id']] == true - ) { - $libmenu = (string) $MENU->libconst; - if (!empty($libmenu) && defined($libmenu) - && constant($libmenu) != null - ) { - $libmenu = constant($libmenu); - } - $_SESSION['menu'][$k]['libconst'] = $libmenu; - if ($_SESSION['menu'][$k]['angular'] == 'true') { - $_SESSION['menu'][$k]['url'] = (string) $MENU->url; - } else { - $_SESSION['menu'][$k]['url'] = $_SESSION['config']['businessappurl'].(string) $MENU->url; - } - - if (trim((string) $MENU->target) != '') { - $tmp = preg_replace( - '/\/core\/$/', '/', $_SESSION['urltocore'] - ); - $_SESSION['menu'][$k]['url'] = $tmp - .(string) $MENU->url; - $_SESSION['menu'][$k]['target'] = (string) $MENU->target; - } - $_SESSION['menu'][$k]['style'] = (string) $MENU->style; - $_SESSION['menu'][$k]['show'] = true; - } else { - $_SESSION['menu'][$k]['libconst'] = ''; - $_SESSION['menu'][$k]['url'] = ''; - $_SESSION['menu'][$k]['style'] = ''; - $_SESSION['menu'][$k]['show'] = false; - } - ++$k; - } - } - } - $this->load_quicklaunch($modules); - } - - /** - * Builds the application menu from the session var menu. - * - * @param $menu array Enabled menu items - * @param $myProfil boolean Enabled my profil item - * @param $logout boolean Enabled logout item - */ - public function build_menu($menu, $myProfil = true, $logout = true) - { - //menu tri - $i = 0; - foreach ($menu as $key => $row) { - $label[$i] = $row['libconst']; - ++$i; - } - // Trie les données par volume décroissant, edition croissant - // Ajoute $data en tant que dernier paramètre, pour trier par la clé commune - array_multisort($label, SORT_ASC, $label, SORT_ASC, $menu); - - // Browses the menu items - for ($i = 0; $i < count($menu); ++$i) { - if ($menu[$i]['show'] == true) { - if ($menu[$i]['angular'] == 'true') { - echo '<li onmouseover="this.className=\'on\';" onmouseout="this.className=\'\';">'; - echo '<a style="display:flex;align-items:center;" onClick="triggerAngular(\'#'.$menu[$i]['url'].'\')">'; - echo "<i style='width:40px;text-align:center;' class='{$menu[$i]['style']} fa-2x'></i>"; - echo '<span>'; - echo trim($menu[$i]['libconst']); - echo '</span></span></a></li>'; - } else { - $tmp = $menu[$i]['url']; - - if (preg_match('/php$/', $tmp)) { - $tmp .= '?reinit=true'; - } else { - $tmp .= '&reinit=true'; - } - $tmp = htmlentities($tmp, ENT_COMPAT, 'UTF-8', true); // Encodes - echo "<li onmouseover=\"this.className='on';\" onmouseout=\"this.className='';\">"; - echo '<a style="display:flex;align-items:center;" href="#" '; - if ($menu[$i]['id'] == 'index_mlb') { - echo 'onclick="checkMultiIndexingGroup(\''.$tmp.'\');">'; - } else { - echo 'onclick="window.open(\''.$tmp.'\',\''; - if (isset($menu[$i]['target']) && $menu[$i]['target'] != '') { - echo $menu[$i]['target']; - } else { - echo '_self'; - } - echo '\');">'; - } - echo '<i style="width:40px;text-align:center;" class="'.$menu[$i]['style'].' fa-2x"></i>'; - echo '<span>'; - echo trim($menu[$i]['libconst']); - echo '</span></span></a></li>'; - } - } - } - - $userGroups = \User\models\UserModel::getGroupsByLogin(['login' => $_SESSION['user']['UserId']]); - $indexingGroups = []; - foreach ($userGroups as $group) { - if ($group['can_index']) { - $indexingGroups[] = ['id' => $group['id'], 'label' => $group['group_desc']]; - } - } - if (!empty($indexingGroups)) { - echo '<li onmouseover="this.className=\'on\';" onmouseout="this.className=\'\';">'; - echo '<a style="display:flex;align-items:center;" onClick="">'; - echo '<i style="width:40px;text-align:center;" class="fa fa-file-medical fa-2x"></i>'; - echo '<span>'._INDEXING_MLB.'</span></a></li>'; - } - - // Menu items always displayed - if ($myProfil) { - echo '<li onmouseover="this.className=\'on\';" onmouseout="this.className=\'\';">'; - echo '<a style="display:flex;align-items:center;" onClick="triggerAngular(\'#/profile\')">'; - echo '<i style="width:40px;text-align:center;" class="fa fa-user fa-2x"></i>'; - echo '<span>'._MY_INFO.'</span></a></li>'; - } - if ($logout) { - echo '<li onmouseover="this.className=\'on\';" onmouseout="this.className=\'\';">'; - echo '<a style="display:flex;align-items:center;" href="'.$_SESSION['config']['businessappurl'].'index.php?display=true&page=logout&logout=true">'; - echo '<i style="width:40px;text-align:center;" class="fa fa-power-off fa-2x"></i>'; - echo '<span>'._LOGOUT.'</span></a></li>'; - } - } - - /** - * Loads menu items of each module and the application into session from menu.xml files. - * - * @param $modules array Enabled modules of the application - */ - public function load_quicklaunch($modules) - { - $k = 0; - if (file_exists( - $_SESSION['config']['corepath'].'custom'.DIRECTORY_SEPARATOR - .$_SESSION['custom_override_id'].DIRECTORY_SEPARATOR.'apps' - .DIRECTORY_SEPARATOR.$_SESSION['config']['app_id'] - .DIRECTORY_SEPARATOR.'xml'.DIRECTORY_SEPARATOR.'menu.xml' - ) - ) { - $path = $_SESSION['config']['corepath'].'custom' - .DIRECTORY_SEPARATOR.$_SESSION['custom_override_id'] - .DIRECTORY_SEPARATOR.'apps'.DIRECTORY_SEPARATOR - .$_SESSION['config']['app_id'].DIRECTORY_SEPARATOR.'xml' - .DIRECTORY_SEPARATOR.'menu.xml'; - } else { - $path = 'apps'.DIRECTORY_SEPARATOR.$_SESSION['config']['app_id'] - .DIRECTORY_SEPARATOR.'xml'.DIRECTORY_SEPARATOR.'menu.xml'; - } - // Reads the apps/apps_name/xml/menu.xml file and loads into session - $xmlconfig = simplexml_load_file($path); - foreach ($xmlconfig->MENU as $MENU2) { - $_SESSION['quicklaunch'][$k]['id'] = (string) $MENU2->id; - $_SESSION['quicklaunch'][$k]['angular'] = empty((string) $MENU2->angular) ? 'false' : (string) $MENU2->angular; - if (isset($_SESSION['quicklaunch'][$k]['id']) - && isset($_SESSION['user']['services'][$_SESSION['quicklaunch'][$k]['id']]) - && $_SESSION['user']['services'][$_SESSION['quicklaunch'][$k]['id']] == true - ) { // Menu Identifier must be equal to the Service identifier - $libmenu = (string) $MENU2->libconst; - if (!empty($libmenu) && defined($libmenu) - && constant($libmenu) != null - ) { - $libmenu = constant($libmenu); - } - $_SESSION['quicklaunch'][$k]['libconst'] = $libmenu; - - if ($_SESSION['quicklaunch'][$k]['angular'] == 'true') { - $_SESSION['quicklaunch'][$k]['url'] = (string) $MENU2->url; - } else { - $_SESSION['quicklaunch'][$k]['url'] = $_SESSION['config']['businessappurl'].(string) $MENU2->url; - } - - if (trim((string) $MENU2->target) != '') { - $tmp = preg_replace( - '/\/core\/$/', '/', $_SESSION['urltocore'] - ); - $_SESSION['quicklaunch'][$k]['url'] = $tmp.(string) $MENU2->url; - $_SESSION['quicklaunch'][$k]['target'] = (string) $MENU2->target; - } - $_SESSION['quicklaunch'][$k]['style'] = (string) $MENU2->style; - $_SESSION['quicklaunch'][$k]['show'] = true; - } else { - $_SESSION['quicklaunch'][$k]['libconst'] = ''; - $_SESSION['quicklaunch'][$k]['url'] = ''; - $_SESSION['quicklaunch'][$k]['style'] = ''; - $_SESSION['quicklaunch'][$k]['show'] = false; - } - ++$k; - } - // Browses the enabled modules array - for ($i = 0; $i < count($modules); ++$i) { - if (file_exists( - $_SESSION['config']['corepath'].'custom'.DIRECTORY_SEPARATOR - .$_SESSION['custom_override_id'].DIRECTORY_SEPARATOR - .'modules'.DIRECTORY_SEPARATOR.$modules[$i]['moduleid'] - .DIRECTORY_SEPARATOR.'xml'.DIRECTORY_SEPARATOR.'menu.xml' - ) - ) { - $menuPath = $_SESSION['config']['corepath'].'custom' - .DIRECTORY_SEPARATOR.$_SESSION['custom_override_id'] - .DIRECTORY_SEPARATOR.'modules'.DIRECTORY_SEPARATOR - .$modules[$i]['moduleid'].DIRECTORY_SEPARATOR.'xml' - .DIRECTORY_SEPARATOR.'menu.xml'; - } else { - $menuPath = 'modules'.DIRECTORY_SEPARATOR - .$modules[$i]['moduleid'].DIRECTORY_SEPARATOR.'xml' - .DIRECTORY_SEPARATOR.'menu.xml'; - } - - if (file_exists( - $_SESSION['config']['corepath'].'modules' - .DIRECTORY_SEPARATOR.$modules[$i]['moduleid'] - .DIRECTORY_SEPARATOR.'xml'.DIRECTORY_SEPARATOR.'menu.xml' - ) || file_exists( - $_SESSION['config']['corepath'].'custom'.DIRECTORY_SEPARATOR - .$_SESSION['custom_override_id'].DIRECTORY_SEPARATOR - .'modules'.DIRECTORY_SEPARATOR.$modules[$i]['moduleid'] - .DIRECTORY_SEPARATOR.'xml'.DIRECTORY_SEPARATOR.'menu.xml' - ) - ) { - $xmlconfig = simplexml_load_file($menuPath); - foreach ($xmlconfig->MENU as $MENU) { - $_SESSION['quicklaunch'][$k]['id'] = (string) $MENU->id; - $_SESSION['quicklaunch'][$k]['angular'] = empty((string) $MENU->angular) ? 'false' : (string) $MENU->angular; - if (isset( - $_SESSION['user']['services'][$_SESSION['quicklaunch'][$k]['id']] - ) - && $_SESSION['user']['services'][$_SESSION['quicklaunch'][$k]['id']] == true - ) { - $libmenu = (string) $MENU->libconst; - if (!empty($libmenu) && defined($libmenu) - && constant($libmenu) != null - ) { - $libmenu = constant($libmenu); - } - $_SESSION['quicklaunch'][$k]['libconst'] = $libmenu; - if ($_SESSION['quicklaunch'][$k]['angular'] == 'true') { - $_SESSION['quicklaunch'][$k]['url'] = (string) $MENU->url; - } else { - $_SESSION['quicklaunch'][$k]['url'] = $_SESSION['config']['businessappurl'].(string) $MENU->url; - } - if (trim((string) $MENU->target) != '') { - $tmp = preg_replace( - '/\/core\/$/', '/', $_SESSION['urltocore'] - ); - $_SESSION['quicklaunch'][$k]['url'] = $tmp - .(string) $MENU->url; - $_SESSION['quicklaunch'][$k]['target'] = (string) $MENU->target; - } - $_SESSION['quicklaunch'][$k]['style'] = (string) $MENU->style; - $_SESSION['quicklaunch'][$k]['show'] = true; - } else { - $_SESSION['quicklaunch'][$k]['libconst'] = ''; - $_SESSION['quicklaunch'][$k]['url'] = ''; - $_SESSION['quicklaunch'][$k]['style'] = ''; - $_SESSION['quicklaunch'][$k]['show'] = false; - } - ++$k; - } - } - } - } - /** * Loads application services into session. */ diff --git a/modules/export_seda/RequestSeda.php b/modules/export_seda/RequestSeda.php index b40358cd8a6..32ef1020989 100755 --- a/modules/export_seda/RequestSeda.php +++ b/modules/export_seda/RequestSeda.php @@ -74,7 +74,6 @@ class RequestSeda $businessAppTools->build_business_app_config(); $coreTools->load_modules_config($_SESSION['modules']); - $coreTools->load_menu($_SESSION['modules']); } $this->statement = []; diff --git a/src/frontend/app/folder/folder-pinned/folder-pinned.component.ts b/src/frontend/app/folder/folder-pinned/folder-pinned.component.ts index f4291921f3e..1e5972e6da8 100644 --- a/src/frontend/app/folder/folder-pinned/folder-pinned.component.ts +++ b/src/frontend/app/folder/folder-pinned/folder-pinned.component.ts @@ -28,7 +28,7 @@ export class FolderPinnedComponent implements OnInit { private notify: NotificationService, private dialog: MatDialog, private router: Router, - private foldersService: FoldersService + public foldersService: FoldersService ) { // Event after process action this.subscription = this.foldersService.catchEvent().subscribe((result: any) => { -- GitLab