]> git.ipfire.org Git - ipfire.org.git/blob - src/templates/base.html
Make the wiki slightly narrower by dropping the sidebar
[ipfire.org.git] / src / templates / base.html
1 <!DOCTYPE html>
2 <html lang="en">
3 <head>
4 <title>{{ hostname }} - {% block title %}{{ _("No title given") }}{% end block %}</title>
5 <meta http-equiv="content-type" content="text/html; charset=utf-8" />
6 <meta name="author" content="IPFire.org - IPFire Development Team" />
7
8 <meta name="keywords" content="Linux, Firewall, IPFire, Security, IPCop, Open Source, Free, ARM, VPN, Proxy, IDS, IPS" />
9
10 <link rel="icon" sizes="192x192" href="{{ static_url("img/apple-touch-icon-192x192-precomposed.png") }}">
11 {% for res in ("72x72", "76x76", "120x120", "144x144", "152x152", "180x180") %}
12 <link rel="apple-touch-icon-precomposed" sizes="{{ res }}" href="{{ static_url("img/apple-touch-icon-%s-precomposed.png" % res )}}">
13 {% end %}
14 <link rel="apple-touch-icon-precomposed" href="{{ static_url("img/apple-touch-icon-60x60-precomposed.png") }}">
15
16 <!-- styling stuff -->
17 <link rel="stylesheet" type="text/css" href="{{ static_url("main.css") }}" />
18 <meta name="viewport" content="width=device-width, initial-scale=1.0">
19
20 {% block head %}{% end block %}
21 </head>
22
23 <body id="page-top" class="{{ hostname.replace(".", "-") }}">
24 <nav class="navbar navbar-dark navbar-expand-lg mb-4">
25 <div class="container">
26 <a class="navbar-brand" href="/">
27 <strong>IPFire</strong>
28
29 {% if hostname == "blog.ipfire.org" %}
30 {{ _("Blog") }}
31 {% elif hostname == "fireinfo.ipfire.org" %}
32 {{ _("Fireinfo") }}
33 {% elif hostname == "location.ipfire.org" %}
34 {{ _("Location") }}
35 <span class="badge badge-primary">{{ _("BETA") }}</span>
36 {% elif hostname == "mirrors.ipfire.org" %}
37 {{ _("Mirrors") }}
38 {% elif hostname == "people.ipfire.org" %}
39 {{ _("People") }}
40 {% elif hostname == "wiki.ipfire.org" %}
41 {{ _("Wiki") }}
42 {% end %}
43 </a>
44
45 {% block menu %}
46 {% if hostname in ("www.ipfire.org", "dev.ipfire.org") %}
47 <button class="navbar-toggler" type="button" data-toggle="collapse" data-target="#navbar"
48 aria-controls="navbar" aria-expanded="false" aria-label="Toggle navigation">
49 <span class="fas fa-bars"></span>
50 </button>
51
52 <div class="collapse navbar-collapse" id="navbar">
53 <ul class="navbar-nav ml-auto">
54 <li class="nav-item d-sm-block d-md-block d-lg-none">
55 <a class="nav-link {% if request.path == "/" %}active{% end %}" href="/">{{ _("Home") }}</a>
56 </li>
57
58 <li class="nav-item">
59 <a class="nav-link {% if request.path == "/features" %}active{% end %}" href="/features">{{ _("Features") }}</a>
60 </li>
61
62 <li class="nav-item">
63 <a class="nav-link {% if request.path == "/support" %}active{% end %}" href="/support">{{ _("Support") }}</a>
64 </li>
65
66 <li class="nav-item">
67 <a class="nav-link" href="https://blog.ipfire.org/">{{ _("Blog") }}</a>
68 </li>
69
70 <li class="nav-item">
71 <a class="nav-link" href="https://community.ipfire.org/">{{ _("Community") }}</a>
72 </li>
73
74 <li class="nav-item">
75 <a class="nav-link {% if request.path.startswith("/download") %}active{% end %}" href="/download">{{ _("Download") }}</a>
76 </li>
77 </ul>
78
79 <a class="btn btn-primary mt-2 mt-lg-0 ml-lg-2" href="/donate">
80 {{ _("Donate") }}
81 </a>
82 </div>
83 {% elif hostname == "blog.ipfire.org" %}
84 <button class="navbar-toggler" type="button" data-toggle="collapse" data-target="#navbar"
85 aria-controls="navbar" aria-expanded="false" aria-label="Toggle navigation">
86 <span class="fas fa-bars"></span>
87 </button>
88
89 <div class="collapse navbar-collapse" id="navbar">
90 <ul class="navbar-nav ml-auto d-lg-none">
91 <li class="nav-item">
92 <a class="nav-link {% if request.path == "/" %}active{% end %}" href="/">
93 {{ _("Newest") }}
94 </a>
95 </li>
96
97 {% if current_user %}
98 <li class="nav-item">
99 <a class="nav-link {% if request.path == "/drafts" %}active{% end %}" href="/drafts">
100 {{ _("My Drafts") }}
101 </a>
102 </li>
103 {% end %}
104
105 <li class="nav-item">
106 <a class="nav-link {% if request.path == "/tags/featured" %}active{% end %}" href="/tags/featured">
107 {{ _("Featured") }}
108 </a>
109 </li>
110
111 <li class="nav-item">
112 <a class="nav-link {% if request.path == "/tags/lightningwirelabs.com" %}active{% end %} d-flex justify-content-between"
113 href="/tags/lightningwirelabs.com">
114 <span>{{ _("Lightning Wire Labs") }}</span>
115
116 <img class="img-fluid" src="{{ static_url("img/lightningwirelabs-logo.svg") }}"
117 alt="{{ _("Lightning Wire Labs") }}">
118 </a>
119 </li>
120
121 <li class="nav-item">
122 <a class="nav-link d-flex justify-content-between" href="/feed.xml">
123 <span>{{ _("RSS Feed") }}</span> <span class="fas fa-rss"></span>
124 </a>
125 </li>
126 </ul>
127
128 <form class="form-inline ml-lg-auto my-2 my-lg-0" action="/search" method="GET">
129 <input class="form-control form-control-sm" type="search" name="q"
130 placeholder="{{ _("Search...") }}" aria-label="{{ _("Search") }}" value="{% try %}{{ q }}{% except %}{% end %}">
131 </form>
132
133 <a class="btn btn-primary ml-lg-2" href="https://www.ipfire.org/donate">
134 {{ _("Donate") }}
135 </a>
136 </div>
137 {% elif hostname == "fireinfo.ipfire.org" %}
138 <button class="navbar-toggler" type="button" data-toggle="collapse" data-target="#navbar"
139 aria-controls="navbar" aria-expanded="false" aria-label="Toggle navigation">
140 <span class="fas fa-bars"></span>
141 </button>
142
143 <div class="collapse navbar-collapse" id="navbar">
144 <ul class="navbar-nav ml-auto">
145 {% if current_user and current_user.is_staff() %}
146 <li class="nav-item">
147 <a class="nav-link {% if request.path.startswith("/admin") %}active{% end %}" href="/admin">
148 {{ _("Admin") }}
149 </a>
150 </li>
151 {% end %}
152
153 <li class="nav-item">
154 <a class="nav-link {% if request.path.startswith("/vendors") %}active{% end %}" href="/vendors">
155 {{ _("Vendors") }}
156 </a>
157 </li>
158 </ul>
159 </div>
160 {% elif hostname == "location.ipfire.org" %}
161 <button class="navbar-toggler" type="button" data-toggle="collapse" data-target="#navbar"
162 aria-controls="navbar" aria-expanded="false" aria-label="Toggle navigation">
163 <span class="fas fa-bars"></span>
164 </button>
165
166 <div class="collapse navbar-collapse" id="navbar">
167 <ul class="navbar-nav ml-auto">
168 <li class="nav-item">
169 <a class="nav-link {% if request.path == "/how-to-use" %}active{% end %}" href="/how-to-use">
170 {{ _("How To Use") }}
171 </a>
172 </li>
173
174 <li class="nav-item">
175 <a class="nav-link {% if request.path == "/download" %}active{% end %}" href="/download">
176 {{ _("Download") }}
177 </a>
178 </li>
179 </ul>
180
181 <a class="btn btn-primary ml-lg-2" href="https://www.ipfire.org/donate">
182 {{ _("Donate") }}
183 </a>
184 </div>
185 {% elif hostname == "nopaste.ipfire.org" %}
186 <button class="navbar-toggler" type="button" data-toggle="collapse" data-target="#navbar"
187 aria-controls="navbar" aria-expanded="false" aria-label="Toggle navigation">
188 <span class="fas fa-bars"></span>
189 </button>
190
191 <div class="collapse navbar-collapse" id="navbar">
192 <ul class="navbar-nav ml-auto">
193 <li class="nav-item">
194 <a class="nav-link" href="/?mode=upload">{{ _("Upload File") }}</a>
195 </li>
196 </ul>
197 </div>
198 {% elif hostname == "people.ipfire.org" %}
199 {% if current_user %}
200 <button class="navbar-toggler" type="button" data-toggle="collapse" data-target="#navbar"
201 aria-controls="navbar" aria-expanded="false" aria-label="Toggle navigation">
202 <span class="fas fa-bars"></span>
203 </button>
204
205 <div class="collapse navbar-collapse" id="navbar">
206 <ul class="navbar-nav ml-auto mr-3">
207 <li class="nav-item">
208 <a class="nav-link {% if request.path == "/users/%s" % current_user.uid %}active{% end %}" href="/users/{{ current_user.uid }}">
209 {{ _("My Profile") }}
210 </a>
211 </li>
212
213 {% if current_user.is_staff() %}
214 <li class="nav-item">
215 <a class="nav-link {% if request.path == "/users" %}active{% end %}" href="/users">
216 {{ _("Users") }}
217 </a>
218 </li>
219
220 <li class="nav-item">
221 <a class="nav-link {% if request.path.startswith("/groups") %}active{% end %}" href="/groups">
222 {{ _("Groups") }}
223 </a>
224 </li>
225
226 <li class="nav-item">
227 <a class="nav-link {% if request.path == "/stats" %}active{% end %}" href="/stats">
228 {{ _("Stats") }}
229 </a>
230 </li>
231 {% end %}
232
233 {% if current_user.has_sip() %}
234 <li class="nav-item">
235 <a class="nav-link {% if request.path.startswith("/conferences") %}active{% end %}" href="/conferences">
236 {{ _("Conferences") }}
237 </a>
238 </li>
239 {% end %}
240 </ul>
241
242 <form class="form-inline my-2 my-lg-0" action="/search" method="GET">
243 <input class="form-control form-control-sm mr-sm-2" type="search" name="q"
244 placeholder="{{ _("Search") }}" aria-label="{{ _("Search") }}" value="{% try %}{{ q }}{% except %}{% end %}">
245 </form>
246 </div>
247 {% end %}
248 {% elif hostname == "wiki.ipfire.org" %}
249 <button class="navbar-toggler" type="button" data-toggle="collapse" data-target="#navbar"
250 aria-controls="navbar" aria-expanded="false" aria-label="Toggle navigation">
251 <span class="fas fa-bars"></span>
252 </button>
253
254 <div class="collapse navbar-collapse" id="navbar">
255 <ul class="navbar-nav ml-auto mr-3">
256 <li class="nav-item">
257 <a class="nav-link {% if request.path == "/recent-changes" %}active{% end %}" href="/recent-changes">
258 {{ _("Recent Changes") }}
259 </a>
260 </li>
261
262 <li class="nav-item">
263 <a class="nav-link {% if request.path == "/watchlist" %}active{% end %}" href="/watchlist">
264 {{ _("Watchlist") }}
265 </a>
266 </li>
267 </ul>
268
269 <form class="form-inline my-2 my-lg-0" action="/search" method="GET">
270 <input class="form-control form-control-sm" type="search" name="q"
271 placeholder="{{ _("Search...") }}" aria-label="{{ _("Search") }}" value="{% try %}{{ q }}{% except %}{% end %}">
272 </form>
273
274 <a class="btn btn-primary ml-lg-2" href="https://www.ipfire.org/donate">
275 {{ _("Donate") }}
276 </a>
277 </div>
278 {% end %}
279 {% end block %}
280 </div>
281 </nav>
282
283 {% block container %}
284 <div class="container">
285 {% block content %}{% end block %}
286 </div>
287 {% end block %}
288
289 {% block footer %}
290 <footer>
291 <div class="footer">
292 {% if hostname in ("www.ipfire.org", "dev.ipfire.org") %}
293 <div class="footer-info">
294 <div class="container pb-3">
295 <div class="row mb-6 justify-content-between">
296 <div class="col-12 col-lg-4 mb-4">
297 <a class="btn btn-primary btn-block mb-3" href="https://people.ipfire.org/register">
298 {{ _("Join Us To Stay Up To Date") }}
299 </a>
300
301 <p>
302 {{ _("Sign up to our community to take part and get the latest news") }}
303 </p>
304 </div>
305
306 <div class="col-12 col-lg-3 mb-4 small">
307 <h6>{{ _("Looking For More?") }}</h6>
308
309 <div class="row">
310 <div class="col">
311 <ul class="list-unstyled">
312 <li>
313 <a href="/features">{{ _("Features") }}</a>
314 </li>
315
316 <li>
317 <a href="/support">{{ _("Support") }}</a>
318 </li>
319
320 <li>
321 <a href="https://wiki.ipfire.org/devel">{{ _("Development") }}</a>
322 </li>
323 </ul>
324 </div>
325
326 <div class="col">
327 <ul class="list-unstyled">
328 <li>
329 <a href="/download">{{ _("Download") }}</a>
330 </li>
331
332 <li>
333 <a href="https://blog.ipfire.org">{{ _("Blog") }}</a>
334 </li>
335
336 <li>
337 <a href="https://community.ipfire.org/">{{ _("Community") }}</a>
338 </li>
339 </ul>
340 </div>
341 </div>
342 </div>
343
344 <div class="col-12 col-lg-4 text-center mb-4">
345 <a class="btn btn-primary btn-lg px-4 my-3" href="/donate">
346 {{ _("Donate") }}
347 </a>
348
349 <div class="btn-toolbar justify-content-center">
350 <a class="btn btn-link" href="https://twitter.com/ipfire">
351 <span class="fab fa-twitter"></span>
352 </a>
353
354 <a class="btn btn-link" href="https://www.facebook.com/IPFire.org">
355 <span class="fab fa-facebook"></span>
356 </a>
357
358 <a class="btn btn-link" href="https://youtube.com/user/ipfireproject">
359 <span class="fab fa-youtube"></span>
360 </a>
361 </div>
362 </div>
363 </div>
364 </div>
365 </div>
366 {% end %}
367
368 <div class="copyright">
369 <div class="container">
370 <div class="row flex-lg-row-reverse">
371 <div class="col-12 col-lg-6 text-center text-lg-right">
372 {% if not current_user and hostname in ("blog.ipfire.org", "fireinfo.ipfire.org", "nopaste.ipfire.org", "wiki.ipfire.org") %}
373 <a href="/login">{{ _("Login") }}</a>
374 {% elif current_user %}
375 <p class="mb-0">
376 <span class="mr-2">
377 {{ _("You are currently logged in as %s") % current_user }}
378 </span>
379
380 <a href="/logout">{{ _("Logout") }}</a>
381 </p>
382 {% end %}
383 </div>
384
385 <div class="col-12 col-lg-6 text-center text-lg-left">
386 &copy; {{ year }} - IPFire - {{ _("The Open Source Firewall") }}
387 - <a href="https://www.ipfire.org/legal">{{ _("Legal") }}</a>
388 </div>
389 </div>
390 </div>
391 </div>
392 </div>
393 </footer>
394 {% end block %}
395
396 <script src="{{ static_url("js/jquery-3.3.1.min.js") }}"></script>
397 <script src="{{ static_url("js/popper.min.js") }}"></script>
398 <script src="{{ static_url("js/bootstrap.min.js") }}"></script>
399 {% block javascript %}{% end block %}
400 </body>
401 </html>