]> git.openstreetmap.org Git - rails.git/blob - app/views/layouts/_header.html.erb
Update maplibre-gl-leaflet to 0.1.3
[rails.git] / app / views / layouts / _header.html.erb
1 <header class="d-flex bg-body text-nowrap closed z-3">
2   <h1 class="d-flex m-0 align-items-center fw-semibold">
3     <a href="<%= root_path %>" class="icon-link gap-1 me-auto text-body-emphasis text-decoration-none geolink">
4       <%= image_tag "osm_logo.svg", :alt => t("layouts.logo.alt_text"), :size => 30 %>
5       <%= t "layouts.project_name.h1" %>
6     </a>
7     <%= render "layouts/select_language_button", :extra_classes => ["border-secondary border-opacity-10 d-md-none"] %>
8     <a href="#" id="menu-icon">
9       <%= inline_svg_tag "menu-icon.svg", :size => "30px" %>
10     </a>
11   </h1>
12   <nav class='primary'>
13     <%= content_for :header %>
14     <div id="edit_tab" class="btn-group">
15       <%= link_to t("layouts.edit"),
16                   edit_path,
17                   :class => "btn btn-outline-primary geolink editlink",
18                   :id => "editanchor",
19                   :data => { :editor => preferred_editor } %>
20       <button class='btn btn-outline-primary dropdown-toggle dropdown-toggle-split flex-grow-0' type='button' data-bs-toggle='dropdown'></button>
21       <ul class='dropdown-menu'>
22         <% Editors::RECOMMENDED_EDITORS.each do |editor| %>
23           <li>
24             <%= link_to t("layouts.edit_with", :editor => t("editor.#{editor}.description")),
25                         edit_path(:editor => editor),
26                         :data => { :editor => editor },
27                         :class => "geolink editlink dropdown-item" %>
28           </li>
29         <% end %>
30       </ul>
31     </div>
32   </nav>
33   <nav class='secondary d-flex gap-2 flex-grow-1 align-items-center'>
34     <ul id='secondary-nav-menu' class='nav flex-grow-1' data-turbo-permanent>
35       <% if Settings.status != "database_offline" && can?(:index, Issue) %>
36         <li class="nav-item">
37           <%= link_to issues_path(:status => "open"), :class => header_nav_link_class(issues_path) do %>
38             <%= t("layouts.issues") %>
39             <%= open_issues_count %>
40           <% end -%>
41         </li>
42       <% end %>
43       <li class="nav-item">
44         <%= link_to t("layouts.history"), history_path, :class => header_nav_link_class(history_path) %>
45       </li>
46       <li class="nav-item">
47         <%= link_to t("layouts.export"), export_path, :class => header_nav_link_class(export_path) %>
48       </li>
49       <li class="nav-item">
50         <%= link_to t("layouts.gps_traces"), traces_path, :class => header_nav_link_class(traces_path) %>
51       </li>
52       <li class="nav-item">
53         <%= link_to t("layouts.user_diaries"), diary_entries_path, :class => header_nav_link_class(diary_entries_path) %>
54       </li>
55       <li class="nav-item">
56         <%= link_to t("layouts.communities"), communities_path, :class => header_nav_link_class(communities_path) %>
57       </li>
58       <li class="nav-item">
59         <%= link_to t("layouts.copyright"), copyright_path, :class => header_nav_link_class(copyright_path) %>
60       </li>
61       <li class="nav-item">
62         <%= link_to t("layouts.help"), help_path, :class => header_nav_link_class(help_path) %>
63       </li>
64       <li class="nav-item">
65         <%= link_to t("layouts.about"), about_path, :class => header_nav_link_class(about_path) %>
66       </li>
67       <li id="compact-secondary-nav" class="dropdown nav-item ms-auto">
68         <button class="dropdown-toggle nav-link btn btn-outline-secondary border-0 bg-body text-secondary" type="button" data-bs-toggle="dropdown"><%= t "layouts.more" %></button>
69         <ul class="dropdown-menu">
70         </ul>
71       </li>
72     </ul>
73
74     <%= render "layouts/select_language_button", :extra_classes => ["d-none d-md-block", { "border-secondary-subtle" => current_user&.id }] %>
75     <% if current_user && current_user.id %>
76       <div class='d-inline-flex dropdown user-menu logged-in'>
77         <button class='d-flex gap-1 align-items-center justify-content-center dropdown-toggle btn btn-outline-secondary border-secondary-subtle bg-body text-secondary px-2 py-1 flex-grow-1 mw-100' type='button' data-bs-toggle='dropdown'>
78           <%= user_thumbnail_tiny(current_user, :class => "user_thumbnail_tiny rounded-1 bg-body") %>
79           <% if current_user.new_messages.size > 0 %>
80             <span class="badge count-number position-static m-1"><%= current_user.new_messages.size %></span>
81           <% end %>
82           <span class='username align-middle text-truncate' dir='auto'>
83             <%= current_user.display_name_was %>
84           </span>
85         </button>
86         <div class='dropdown-menu dropdown-menu-end'>
87           <%= link_to t("users.show.my_dashboard"), dashboard_path, :class => "dropdown-item" %>
88           <%= link_to messages_inbox_path, :class => "dropdown-item" do %>
89             <%= t("users.show.my messages") %>
90             <span class='badge count-number'><%= number_with_delimiter(current_user.new_messages.size) %></span>
91           <% end %>
92           <%= link_to t("users.show.my profile"), current_user, :class => "dropdown-item" %>
93           <%= link_to t("users.show.my_account"), account_path, :class => "dropdown-item" %>
94           <%= link_to t("users.show.my_preferences"), basic_preferences_path, :class => "dropdown-item" %>
95           <div class="dropdown-divider"></div>
96           <% if current_user.home_location? %>
97             <%= link_to t("layouts.home"), account_home_path, :class => "dropdown-item" %>
98           <% end %>
99           <%= link_to t("layouts.logout"), logout_path(:referer => request.fullpath), :method => "post", :class => "geolink dropdown-item" %>
100         </div>
101       </div>
102     <% else %>
103       <div class="d-inline-flex btn-group login-menu" role="">
104         <%= link_to t("layouts.log_in"), login_path(:referer => request.fullpath), :class => "geolink btn btn-outline-secondary" %>
105         <%= link_to t("layouts.sign_up"), new_user_path, :class => "btn btn-outline-secondary" %>
106       </div>
107     <% end %>
108   </nav>
109 </header>
110
111 <div class="modal fade" id="select_language_dialog" tabindex="-1" aria-labelledby="select_language_dialog_label" aria-hidden="true">
112   <div class="modal-dialog modal-lg modal-dialog-scrollable">
113     <div class="modal-content">
114       <div class="modal-header">
115         <h1 class="modal-title fs-5" id="select_language_dialog_label"><%= t ".select_language" %></h1>
116         <button type="button" class="btn-close" data-bs-dismiss="modal" aria-label="<%= t "javascripts.close" %>"></button>
117       </div>
118       <div class="modal-body px-1">
119         <% if current_user&.id %>
120           <%= form_tag basic_preferences_path, :method => "PUT" do %>
121             <%= hidden_field_tag "referer", request.fullpath %>
122             <%= hidden_field_tag "language", I18n.locale %>
123             <%= render "layouts/select_language_list" %>
124           <% end %>
125         <% else %>
126           <%= render "layouts/select_language_list" %>
127         <% end %>
128       </div>
129     </div>
130   </div>
131 </div>
132
133 <div class="modal fade" id="osm_alert_modal" tabindex="-1" aria-labelledby="osm_alert_title" aria-hidden="true">
134   <div class="modal-dialog modal-dialog-centered">
135     <div class="modal-content">
136       <div class="modal-header">
137         <h5 class="modal-title" id="osm_alert_title"><%= t "javascripts.alert" %></h5>
138         <button type="button" class="btn-close" data-bs-dismiss="modal" aria-label="<%= t "javascripts.close" %>"></button>
139       </div>
140       <div class="modal-body" id="osm_alert_message">
141       </div>
142       <div class="modal-footer">
143         <button type="button" class="btn btn-primary" data-bs-dismiss="modal"><%= t "javascripts.ok" %></button>
144       </div>
145     </div>
146   </div>
147 </div>