|
1 | 1 | @inject ApplicationSettings ApplicationSettings |
| 2 | +@inject IJSRuntime JSRuntime |
2 | 3 |
|
3 | 4 | <nav class="navbar navbar-expand-lg"> |
4 | 5 | <div class="container"> |
|
7 | 8 | @ApplicationSettings.Localized.Name |
8 | 9 | </a> |
9 | 10 |
|
10 | | - <!-- Desktop menu (hidden on mobile) --> |
11 | | - <div class="d-none d-lg-block"> |
12 | | - <ul class="navbar-nav ms-auto"> |
| 11 | + <!-- Mobile menu button and language selector --> |
| 12 | + <div class="d-lg-none d-flex align-items-center"> |
| 13 | + <SelectLanguage BtnCssClass="btn btn-outline-light border-0 me-2" |
| 14 | + ShowIcon="true" |
| 15 | + ShowShortName="true" |
| 16 | + ShowSelectedItem="true" |
| 17 | + IconCssClass="text-secondary fs-5" |
| 18 | + WrapperCssClass="language-selector-mobile" /> |
| 19 | + <button class="navbar-toggler" type="button" data-bs-toggle="offcanvas" data-bs-target="#offcanvasNavbar" aria-controls="offcanvasNavbar" aria-label="Toggle navigation"> |
| 20 | + <span class="navbar-toggler-icon"></span> |
| 21 | + </button> |
| 22 | + </div> |
| 23 | + |
| 24 | + <!-- Single Navigation Menu - Works for both desktop and mobile --> |
| 25 | + <div class="navbar-nav-container"> |
| 26 | + <ul class="navbar-nav responsive-nav" id="singleNavMenu"> |
13 | 27 | <li class="nav-item"> |
14 | | - <a class="nav-link" href="#home">@WebAppLocalizer[WebAppResource.Nav_Home]</a> |
| 28 | + <a class="nav-link" href="#home" data-bs-dismiss="offcanvas" data-scroll-to-section="true">@WebAppLocalizer[WebAppResource.Nav_Home]</a> |
15 | 29 | </li> |
16 | 30 | <li class="nav-item"> |
17 | | - <a class="nav-link" href="#pricing">@WebAppLocalizer[WebAppResource.Nav_Pricing]</a> |
| 31 | + <a class="nav-link" href="#pricing" data-bs-dismiss="offcanvas" data-scroll-to-section="true">@WebAppLocalizer[WebAppResource.Nav_Pricing]</a> |
18 | 32 | </li> |
19 | 33 | <li class="nav-item"> |
20 | | - <a class="nav-link" href="#">@WebAppLocalizer[WebAppResource.Nav_Contact]</a> |
| 34 | + <a class="nav-link" href="#" data-bs-dismiss="offcanvas">@WebAppLocalizer[WebAppResource.Nav_Contact]</a> |
21 | 35 | </li> |
22 | | - <li class="nav-item me-2"> |
| 36 | + <li class="nav-item language-selector-desktop"> |
23 | 37 | <SelectLanguage BtnCssClass="btn btn-outline-light border-0" |
24 | 38 | ShowIcon="true" |
25 | 39 | ShowShortName="true" |
|
28 | 42 | SelectedItemCssClass="text-secondary ms-1" |
29 | 43 | WrapperCssClass="language-selector" /> |
30 | 44 | </li> |
31 | | - <li class="nav-item ms-2"> |
| 45 | + <li class="nav-item dashboard-btn"> |
32 | 46 | @if (CurrentUser.IsAuthenticated()) |
33 | 47 | { |
34 | 48 | <a class="btn btn-warning-gradient" href="/dashboard"> |
|
46 | 60 | </li> |
47 | 61 | </ul> |
48 | 62 | </div> |
49 | | - |
50 | | - <!-- Mobile menu button and language selector --> |
51 | | - <div class="d-lg-none d-flex align-items-center"> |
52 | | - <SelectLanguage BtnCssClass="btn btn-outline-light border-0 me-2" |
53 | | - ShowIcon="true" |
54 | | - ShowShortName="true" |
55 | | - ShowSelectedItem="true" |
56 | | - IconCssClass="text-secondary fs-5" |
57 | | - WrapperCssClass="language-selector-mobile" /> |
58 | | - <button class="navbar-toggler" type="button" data-bs-toggle="offcanvas" data-bs-target="#offcanvasNavbar" aria-controls="offcanvasNavbar" aria-label="Toggle navigation"> |
59 | | - <span class="navbar-toggler-icon"></span> |
60 | | - </button> |
61 | | - </div> |
62 | 63 | </div> |
63 | 64 | </nav> |
64 | 65 |
|
|
72 | 73 | <button type="button" class="btn-close" data-bs-dismiss="offcanvas" aria-label="Close"></button> |
73 | 74 | </div> |
74 | 75 | <div class="offcanvas-body"> |
75 | | - <ul class="navbar-nav justify-content-end flex-grow-1 pe-3"> |
76 | | - <li class="nav-item"> |
77 | | - <a class="nav-link" href="#home" data-bs-dismiss="offcanvas">@WebAppLocalizer[WebAppResource.Nav_Home]</a> |
78 | | - </li> |
79 | | - <li class="nav-item"> |
80 | | - <a class="nav-link" href="#pricing" data-bs-dismiss="offcanvas">@WebAppLocalizer[WebAppResource.Nav_Pricing]</a> |
81 | | - </li> |
82 | | - <li class="nav-item"> |
83 | | - <a class="nav-link" href="#" data-bs-dismiss="offcanvas">@WebAppLocalizer[WebAppResource.Nav_Contact]</a> |
84 | | - </li> |
85 | | - <li class="nav-item mt-3"> |
86 | | - <a class="btn btn-outline-primary-gradient w-100 mb-2" href="/dashboard" data-bs-dismiss="offcanvas"> |
87 | | - <i class="bi bi-box-arrow-in-right"></i> @WebAppLocalizer[WebAppResource.Nav_Dashboard] |
88 | | - </a> |
89 | | - </li> |
| 76 | + <ul class="navbar-nav justify-content-end flex-grow-1 pe-3" id="offcanvasNavMenu"> |
| 77 | + <!-- Navigation items will be cloned here by JavaScript --> |
90 | 78 | </ul> |
91 | 79 | </div> |
92 | 80 | </div> |
| 81 | + |
| 82 | +@code { |
| 83 | + protected override async Task OnAfterRenderAsync(bool firstRender) |
| 84 | + { |
| 85 | + if (firstRender) |
| 86 | + { |
| 87 | + await JSRuntime.InvokeVoidAsync("setupSingleNavMenu"); |
| 88 | + } |
| 89 | + } |
| 90 | +} |
0 commit comments