Skip to content

Commit

Permalink
Burger menu available when not logged in.
Browse files Browse the repository at this point in the history
  • Loading branch information
gjb2048 committed Dec 19, 2024
1 parent 6616006 commit 8be4792
Show file tree
Hide file tree
Showing 2 changed files with 123 additions and 0 deletions.
4 changes: 4 additions & 0 deletions scss/lexa.scss
Original file line number Diff line number Diff line change
Expand Up @@ -68,6 +68,10 @@
height: 100%;
justify-content: center;
margin: auto 0;

.loggedinasguest {
padding: .25rem 1.75rem .25rem .75rem;
}
}

.dropdown-divider {
Expand Down
119 changes: 119 additions & 0 deletions templates/core/user_menu.mustache
Original file line number Diff line number Diff line change
@@ -0,0 +1,119 @@
{{!
This file is part of Moodle - http://moodle.org/
Moodle is free software: you can redistribute it and/or modify
it under the terms of the GNU General Public License as published by
the Free Software Foundation, either version 3 of the License, or
(at your option) any later version.
Moodle is distributed in the hope that it will be useful,
but WITHOUT ANY WARRANTY; without even the implied warranty of
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
GNU General Public License for more details.
You should have received a copy of the GNU General Public License
along with Moodle. If not, see <http://www.gnu.org/licenses/>.
}}
{{!
@template theme_lexa/core/user_menu
Action link template.
Context variables required for this template:
* unauthenticateduseruser - (Optional) Items to be displayed if an an unautheticated user is accessing the site
* content - The content to be displayed in the header.
* url - The login url
* items - Array of user menu items used in user_action_menu_items. Required if the above not provided.
* metadata - Array of additional metadata to be displayed in the dropdown button.
* avatardata - Array of avatars to be displayed. Usually only the current user's avatar. If viewing as another user,
includes that user's avatar.
* userfullname - The name of the logged in user
* submenus - Array of submenus within the user menu.
* id - The id of the submenu.
* title - The title of the submenu.
* items - Array of the submenu items used in core/user_action_menu_submenu_items.
Example context (json):
{
"unauthenticateduser": {
"content": "You are not logged in",
"url": "https://yourmoodlesite/login/index.php"
},
"items": [],
"metadata": [],
"avatardata": [],
"userfullname": "Admin User",
"submenus": [
{
"id": "86cebd87",
"title": "Submenu title",
"items": []
}
],
"showfullnameinusermenu": true
}
}}
{{!
This template is a modified version of theme_boost_union/core/user_menu
Modifications compared to the original template:
* Include submenus custom return id, helps to get back to the submenus parent from third level child.
* Add icon support to items.
* Add user full name at the top of the user menu.
}}
<div class="usermenu lexausermenu">
<div class="dropdown show">
<a href="#" role="button" id="user-menu-toggle" data-toggle="dropdown" aria-label="{{#str}}usermenu{{/str}}"
aria-haspopup="true" aria-controls="user-action-menu" class="btn dropdown-toggle">
<span class="userbutton">
{{> core/user_menu_metadata }}
</span>
</a>
<div id="user-action-menu" class="dropdown-menu dropdown-menu-right">
<div id="usermenu-carousel" class="carousel slide" data-touch="false" data-interval="false" data-keyboard="false">
<div class="carousel-inner">
<div id="carousel-item-main" class="carousel-item active" role="menu" tabindex="-1" aria-label="{{#str}}user{{/str}}">
{{#showfullnameinusermenu}}
<div class="loggedinas">
<small>{{#str}}showfullnameinusermenussetting_loggedinas, theme_boost_union{{/str}}</small><br />
<strong>{{userfullname}}</strong>
</div>
<div class="dropdown-divider"></div>
{{/showfullnameinusermenu}}
{{> core/user_action_menu_items }}
{{#unauthenticateduser}}
{{#guest}}
<span class="loggedinasguest">{{#str}} loggedinasguest, core {{/str}}</span>
{{/guest}}
{{#url}}
<a href="{{url}}" class="dropdown-item" role="menuitem" tabindex="-1">{{#str}} login, core {{/str}}</a>
{{/url}}
{{/unauthenticateduser}}
</div>
{{#submenus}}
<div id="carousel-item-{{id}}" role="menu" class="carousel-item submenu" tabindex="-1" aria-label="{{title}}">
<div class="d-flex flex-column h-100">
<div class="header">
<button type="button" class="btn btn-icon carousel-navigation-link text-decoration-none text-body" data-carousel-target-id="carousel-item-{{#returnid}}{{returnid}}{{/returnid}}{{^returnid}}main{{/returnid}}" aria-label="{{#str}}usermenugoback{{/str}}">
<span class="dir-rtl-hide">{{#pix}}i/arrow-left{{/pix}}</span>
<span class="dir-ltr-hide">{{#pix}}i/arrow-right{{/pix}}</span>
</button>
<span class="ps-2" id="carousel-item-title-{{id}}">{{#text}}{{{text}}}{{/text}}{{^text}}{{title}}{{/text}}</span>
</div>
<div class="dropdown-divider"></div>
<div class="items h-100 overflow-auto" role="menu" aria-labelledby="carousel-item-title-{{id}}">
{{> core/user_action_menu_submenu_items }}
</div>
</div>
</div>
{{/submenus}}
</div>
</div>
</div>
</div>
</div>
{{#js}}
require(['core/usermenu'], function(UserMenu) {
UserMenu.init();
});
{{/js}}

0 comments on commit 8be4792

Please sign in to comment.