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">&nbsp;</div>';?>
-		                <ul  >
-		                    <?php
-		                    //here we building the maarch menu
-		                    $core->build_menu($_SESSION['menu']);
-		                   ?>
-		                </ul>
-		                    <div class="header_menu_blank">&nbsp;</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">&nbsp;</div>';?>
-	                <ul  >
-	                    <?php
-	                    //here we building the maarch menu
-	                    $core->build_menu($_SESSION['menu']);
-	                   ?>
-	                </ul>
-	                    <div class="header_menu_blank">&nbsp;</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">&nbsp;</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">&nbsp;</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">&nbsp;</div>
-                        <ul>
-                            <?php
-                                //here we building the maarch menu
-                                $core->build_menu($_SESSION['menu']);
-                            ?>
-                        </ul>
-                        <div class="header_menu_blank">&nbsp;</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']."&nbsp;<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&amp;page=logout&amp;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