Changes for page Menu Macro


on 2023-04-26 20:38


on 2023-04-26 18:21
Summary
Details
- XWiki.JavaScriptExtension[0]
-
- Code
-
... ... @@ -1,81 +1,28 @@ 1 -define('menu-ui-translation-keys', { 2 - prefix: 'menu.ui.', 3 - keys: [ 4 - "openSubMenu", 5 - "closeSubMenu" 6 - ] 7 -}); 8 -require(['jquery','xwiki-l10n!menu-ui-translation-keys'], function($, l10n) { 1 +require(['jquery'], function($) { 9 9 // It's not possible to write a CSS selector that targets list items containing lists so we rely on JavaScript. 10 10 // The 'dropdown' CSS class is used only to display the down/left arrow. 11 - // All nodes on the tree. 12 - $('.menu-horizontal ul , .menu-vertical ul') 13 - .attr('role', 'menu'); 14 - // All leaves on the tree. 15 - $('.menu-horizontal li, .menu-vertical li') 16 - .attr('role', 'menuitem'); 17 - $('.menu-horizontal li ul, .menu-vertical li ul') 18 - .parent() 19 - .addClass('xDropdown'); 4 + $('.menu-horizontal li ul').parent().addClass('xDropdown'); 5 + 20 20 // Make sure the menu separators are really empty. 21 - var menus = $('.menu-horizontal, .menu-vertical'); 22 - menus.find('li > br:first-child').remove(); 7 + $('.menu-horizontal, .menu-vertical').find('li > br:first-child').remove(); 23 23 24 - // Add aria attributes to the menu separators. 25 - menus.find('li') 26 - .filter(function() {return this.textContent.trim() === ""; }) 27 - .attr('role', 'separator') 28 - .attr('aria-hidden', 'true'); 29 - 30 - // Vertical menus are initially expanded 31 - $('.menu-vertical.collapsible').each(function() { 9 + // Collapsible menu bahavior. 10 + $('.menu-vertical.collapsible').each(function(){ 32 32 var open = $(this).hasClass('open'); 33 33 $(this).find('li ul').each(function() { 34 34 $(this).addClass('xDropdown-menu').parent().addClass('xDropdown' + (open ? ' open' : '')); 14 + // Wrap everything (including text nodes) before the sub-menu in a DIV that will toggle its state. 15 + var toggle = this.ownerDocument.createElement('div'); 16 + $(this).parent().prepend(toggle); 17 + for(var next = toggle.nextSibling; next != this; next = toggle.nextSibling) { 18 + toggle.appendChild(next); 19 + } 20 + $(toggle).addClass('xDropdown-toggle').on('click', function() { 21 + $(this).parent().toggleClass('open'); 22 + }); 35 35 }); 36 36 }); 37 37 38 - function setDropdownButtonTitle(dropDownButton) { 39 - var xDropdown = $(dropDownButton).parent().parent(); 40 - if($(xDropdown).hasClass('open')) { 41 - $(dropDownButton).attr('title', l10n['closeSubMenu']); 42 - $(xDropdown).attr('aria-expanded', "true"); 43 - } else { 44 - $(dropDownButton).attr('title', l10n['openSubMenu']); 45 - $(xDropdown).attr('aria-expanded', "false"); 46 - } 47 - } 48 - 49 - $('.xDropdown').each(function() { 50 - var dropDownHeader = this.ownerDocument.createElement("div"); 51 - $(dropDownHeader).addClass("xDropdown-header"); 52 - var dropDownButton = this.ownerDocument.createElement("button"); 53 - $(dropDownButton).addClass("xDropdown-header-toggle"); 54 - setDropdownButtonTitle(dropDownButton); 55 - dropDownButton.addEventListener('click',function() { 56 - //Swaps the state of the submenu. 57 - var xDropdown = $(this).parent().parent(); 58 - xDropdown.toggleClass('open'); 59 - setDropdownButtonTitle(dropDownButton); 60 - }); 61 - dropDownHeader.append($(this).contents()[0]); 62 - dropDownHeader.append(dropDownButton); 63 - $(this).prepend(dropDownHeader); 64 - $(dropDownHeader).next().addClass('xDropdown-menu'); 65 - }); 66 - 67 - $('.menu-horizontal .xDropdown').each(function() { 68 - // In case of horizontal menus, make it so that a class is added on hover, instead of using the :hover pseudo-class 69 - this.addEventListener("mouseover", function() { 70 - $(this).addClass('open'); 71 - setDropdownButtonTitle(this.firstChild.lastChild); 72 - }); 73 - this.addEventListener("mouseout", function() { 74 - $(this).removeClass('open'); 75 - setDropdownButtonTitle(this.firstChild.lastChild); 76 - }); 77 - }); 78 - 79 79 // In case of horizontal responsive menus, make sub-submenus in the navbar work on mobile devices 80 80 $(document).on('touchstart.dropdown.data-api', '.dropdown-submenu > a', function (event) { 81 81 event.preventDefault();
- XWiki.StyleSheetExtension[1]
-
- Code
-
... ... @@ -4,32 +4,6 @@ 4 4 } 5 5 } 6 6 .menu { 7 - /* Rotate the carets when the menu is opened. */ 8 - .xDropdown{ 9 - > .xDropdown-header > .xDropdown-header-toggle:before { 10 - transform: rotate(90deg); 11 - } 12 - &.open > .xDropdown-header > .xDropdown-header-toggle:before { 13 - transform: rotate(0); 14 - } 15 - } 16 - .xDropdown-header-toggle { 17 - background: transparent; 18 - border:none; 19 - border-radius: @border-radius-base; 20 - margin: 0 .3em; 21 - line-height: (@line-height-computed / 2); 22 - min-width: 24px; 23 - min-height: 24px; 24 - &:hover, &:focus-within { 25 - background-color: @dropdown-bg; 26 - } 27 - &:before { 28 - .caret; 29 - margin-left: 0; 30 - content: ''; 31 - } 32 - } 33 33 &.menu-vertical { 34 34 ul { 35 35 list-style-type: none; ... ... @@ -51,8 +51,32 @@ 51 51 .xDropdown-menu { 52 52 display: none; 53 53 } 28 + .xDropdown-toggle { 29 + cursor: pointer; 30 + position: relative; 31 + &:hover { 32 + background-color: @nav-link-hover-bg; 33 + } 34 + &:after { 35 + .caret; 36 + content: ''; 37 + /* Positioning */ 38 + position: absolute; 39 + margin-top: @line-height-computed / 3; 40 + right: 1em; 41 + /* Collapsed arrow style */ 42 + border-bottom: 4px solid transparent; 43 + border-right: 4px solid; 44 + border-top: 4px solid transparent; 45 + } 46 + } 54 54 .xDropdown.open { 55 - > ul { 48 + > .xDropdown-toggle:after { 49 + /* Expanded arrow style */ 50 + .caret; 51 + margin-top: @line-height-computed / 2; 52 + } 53 + > .xDropdown-menu { 56 56 display: block; 57 57 } 58 58 } ... ... @@ -66,35 +66,22 @@ 66 66 .box-shadow(0 2px 8px rgba(0,0,0,0.4) inset); 67 67 min-height: @navbar-height; 68 68 padding-left: 25px; 69 - .xDropdown.open { 70 - > .xDropdown-header > .xDropdown-header-toggle:before { 71 - transform: rotate(0); 72 - } 73 - > ul { 74 - display: block; 75 - } 76 - } 77 77 & > ul { 78 78 padding-left: 0; 79 79 list-style-type: none; 80 80 margin: 0; 81 - min-height: 50px; 82 - display: flex; 83 - align-items: stretch; 84 84 & > li { 85 85 position: relative; 86 - min-height: 50px; 87 - display: flex; 88 - align-items: center; 73 + display: block; 89 89 padding: @nav-link-padding; 90 - padding-top: 0;91 - padding-bottom: 0;75 + padding-top: @navbar-padding-vertical; 76 + padding-bottom: @navbar-padding-vertical; 92 92 @media (min-width: @grid-float-breakpoint) { 93 93 float: left; 94 94 } 95 95 line-height: @line-height-computed; 96 96 color: @navbar-default-link-color; 97 - &:hover ,&:focus-within{82 + &:hover { 98 98 color: @navbar-default-link-hover-color; 99 99 background-color: @navbar-default-link-hover-bg; 100 100 background-color: @navbar-default-link-active-bg; ... ... @@ -108,7 +108,7 @@ 108 108 /* Links inside menu */ 109 109 a { 110 110 color: @navbar-default-link-color; 111 - &:hover ,&:focus-within{96 + &:hover { 112 112 text-decoration: none; 113 113 } 114 114 } ... ... @@ -117,18 +117,7 @@ 117 117 /* Limit the height to the nav height minus the padding and minus border */ 118 118 max-height: @navbar-height - (2 * @navbar-padding-vertical) - 2px; 119 119 overflow: hidden; 120 - &.xDropdown-header{ 121 - /* No border on the dropdown header */ 122 - max-height: unset; 123 - } 124 124 } 125 - /* Horizontal menu top-level headers. */ 126 - & > .xDropdown-header > .xDropdown-header-toggle { 127 - &:hover, &:focus-within { 128 - /* Change background color of the caret when hovering on the navbar. */ 129 - background-color: @navbar-default-bg; 130 - } 131 - } 132 132 /* Separator vertical inside menu */ 133 133 &:empty { 134 134 height: @navbar-height; ... ... @@ -172,7 +172,7 @@ 172 172 color: @dropdown-link-color; 173 173 overflow: hidden; 174 174 text-overflow: ellipsis; // Displaying ... if the text is too long 175 - &:hover ,&:focus-within{149 + &:hover { 176 176 /* &:extend(.dropdown-menu>li>a:hover); */ 177 177 text-decoration: none; 178 178 color: @dropdown-link-hover-color; ... ... @@ -190,7 +190,7 @@ 190 190 color: @dropdown-link-color; 191 191 /* Empty dropdowns should have height in order to display the arrow */ 192 192 min-height: 2 * @font-size-base; 193 - &:hover ,&:focus-within{167 + &:hover { 194 194 text-decoration: none; 195 195 color: @dropdown-link-hover-color; 196 196 background-color: @dropdown-link-hover-bg; ... ... @@ -222,9 +222,17 @@ 222 222 /* Stylization: Generic */ 223 223 li { 224 224 /* Display submenus on hover */ 225 - & .open> ul {199 + &:hover > ul { 226 226 display: block; 227 227 } 202 + /* Display an arrow for expandable items */ 203 + &.xDropdown { 204 + &:after { 205 + .caret; 206 + content: ''; 207 + margin-left: .5em; 208 + } 209 + } 228 228 } 229 229 /* The only way to have a menu with more than 2 levels without JavaScript is to use a fixed width. */ 230 230 &.fixedWidth { ... ... @@ -246,7 +246,7 @@ 246 246 } 247 247 /* Resetting rules for mobile view */ 248 248 @media (max-width: @screen-xs-max) { 249 - > ul { 231 + > ul { 250 250 margin: 0 0 0 -25px; /* Remove padding added in normal view */ 251 251 > li { 252 252 &:empty { ... ... @@ -268,16 +268,19 @@ 268 268 /* Links inside menu */ 269 269 a { 270 270 color: @navbar-default-link-color; 253 + &:hover { 254 + /* Preserve the styling from dropdown */ 255 + } 271 271 } 272 272 /* Submenus inside menu */ 273 273 &.xDropdown { 274 274 color: @navbar-default-link-color; 275 - & .open{260 + &:hover { 276 276 background-color: transparent; 277 277 color: inherit; 278 278 } 279 279 /* When in dropdown we also have a link */ 280 - > span > a { 265 + > span > a { 281 281 color: @navbar-default-link-color; 282 282 } 283 283 }
- XWiki.WikiMacroClass[0]
-
- Macro code
-
... ... @@ -24,12 +24,12 @@ 24 24 </button> 25 25 {{/html}} 26 26 ))) 27 - (% id="$!{services.rendering.escape($id, 'xwiki/2.1')}" class="menu menu-${services.rendering.escape($!type, 'xwiki/2.1')} collapse navbar-collapse" role="menubar"%)(((27 + (% id="$!{services.rendering.escape($id, 'xwiki/2.1')}" class="menu menu-${services.rendering.escape($!type, 'xwiki/2.1')} collapse navbar-collapse" %)((( 28 28 {{wikimacrocontent/}} 29 29 ))) 30 30 ))) 31 31 #else 32 - (% #if ("$!id" != '') id="${services.rendering.escape($id, 'xwiki/2.1')}"#end class="menu menu-${services.rendering.escape($!type, 'xwiki/2.1')}" role="menu"%)(((32 + (% #if ("$!id" != '') id="${services.rendering.escape($id, 'xwiki/2.1')}"#end class="menu menu-${services.rendering.escape($!type, 'xwiki/2.1')}" %)((( 33 33 {{wikimacrocontent/}} 34 34 ))) 35 35 #end