changeset 66:9834106678da

base: menu implementation: 2 menus are now handled: main menu and category menu (for submenus relative to a page). Main menu is displayed on the side bar on big screen. Added menu for tickets.
author Goffi <goffi@goffi.org>
date Fri, 01 Dec 2017 00:46:42 +0100 (2017-11-30)
parents dd15b6c0b1d3
children 3a9dae71aa6c
files default/base/base.html default/components/common.html default/input/xmlui.html default/static/styles.css default/static/ticket.css default/ticket/create.html default/ticket/item.html default/ticket/overview.html
diffstat 8 files changed, 243 insertions(+), 76 deletions(-) [+]
line wrap: on
line diff
--- a/default/base/base.html	Wed Nov 15 08:52:14 2017 +0100
+++ b/default/base/base.html	Fri Dec 01 00:46:42 2017 +0100
@@ -1,4 +1,5 @@
 {% set embedded = True %} {# embedded is set to avoid including base.html several times if a generic page is included (e.g. blog/articles.html) #}
+{% import 'components/common.html' as component with context %}
 {{ script.include('css') }} {# css.js is a common script, so it's useful to import it here #}
 <!DOCTYPE html>
 <html>
@@ -35,36 +36,37 @@
     {{ script.generate_scripts() }}
 </head>
 <body>
-
-    <header>
-        {% if confirm %}
-        {# confirmation message used when post data has been handled correctly #}
-            {% block confirm %}
-                <div class="box post_confirm">
-                    {% block confirm_message %}
-                        {% trans %}Your data has been sent correctly.{% endtrans %}
-                    {% endblock confirm_message %}
-                </div>
-            {% endblock confirm %}
-        {% endif %}
+    {% if main_menu is defined %}
+        {% block main_menu %}
+            {{ component.menu(main_menu, class="main_menu") }}
+        {% endblock main_menu %}
+    {% endif %}
 
-        {% if menus %}
-            {% block menu %}
-                <nav class="menu">
-                    <ul>
-                    {% for url,label,cls in menus %}
-                        <li><a class="menu_item button {{cls}}" {{ {'href': url}|xmlattr }}>{{ label }}</a></li>
-                    {% endfor %}
-                    </ul>
-                </nav>
-            {% endblock menu %}
-        {% endif %}
-    </header>
+    <div id='main_area'>
+        <header>
+            {% if confirm %}
+            {# confirmation message used when post data has been handled correctly #}
+                {% block confirm %}
+                    <div class="box post_confirm">
+                        {% block confirm_message %}
+                            {% trans %}Your data has been sent correctly.{% endtrans %}
+                        {% endblock confirm_message %}
+                    </div>
+                {% endblock confirm %}
+            {% endif %}
 
-    <div id="body">
-    {% block body %}
-    {% endblock body %}
+        </header>
+
+        <div id="body">
+        {% block category_menu scoped %}
+            {% if category_menu is defined %}
+                {{ component.menu(category_menu, class="category_menu") }}
+            {% endif %}
+        {% endblock category_menu %}
+        {% block body %}
+        {% endblock body %}
+        </div>
+        <footer>{% block footer %}{% trans app_name=C.APP_NAME %}Powered by {{app_name}}{% endtrans %}{% endblock %}</footer>
     </div>
-    <footer>{% block footer %}{% trans app_name=C.APP_NAME %}Powered by {{app_name}}{% endtrans %}{% endblock %}</footer>
 </body>
 </html>
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/default/components/common.html	Fri Dec 01 00:46:42 2017 +0100
@@ -0,0 +1,19 @@
+{# menu labels, map from menu names to labels #}
+{% set ml = {
+    'login': _('Session') if profile is defined else _('Log in'),
+    'blog_view': _('Blog'),
+    'merge-requests_list': _('Merge requests'),
+    'merge-request_new': _('Create new merge request'),
+    'tickets_list': _('Tickets'),
+    'ticket_new': _('Create new ticket'),
+} %}
+
+{% macro menu(menus, class='') %}
+    <nav class="menu {{class}}">
+        <ul>
+        {% for name,url in menus %}
+            <li><a class="menu_item button {{name}}" {{ {'href': url}|xmlattr }}>{{ml[name]}}</a></li>
+        {% endfor %}
+        </ul>
+    </nav>
+{% endmacro %}
--- a/default/input/xmlui.html	Wed Nov 15 08:52:14 2017 +0100
+++ b/default/input/xmlui.html	Fri Dec 01 00:46:42 2017 +0100
@@ -14,18 +14,18 @@
 
 {% macro generate_widget(wid, config, id=none) %}
     {% if wid.type == 'text' %}
-        {{ text_widget(wid, config, id=id) }}
+        {{ text_widget(wid, config, id=id) }}
     {% elif wid.type == 'label' %}
         {{ label_widget(wid, config) }}
     {% elif wid.type == 'string' %}
-        {{ string_widget(wid, config, id=id) }}
+        {{ string_widget(wid, config, id=id) }}
     {% elif wid.type == 'jid' %}
         {# TODO: proper JID widget #}
-        {{ string_widget(wid, config, id=id) }}
+        {{ string_widget(wid, config, id=id) }}
     {% elif wid.type == 'textbox' %}
-        {{ textbox_widget(wid, config, id=id) }}
+        {{ textbox_widget(wid, config, id=id) }}
     {% elif wid.type == 'list' %}
-        {{ list_widget(wid, config, id=id) }}
+        {{ list_widget(wid, config, id=id) }}
     {% endif %}
 {% endmacro %}
 
@@ -161,7 +161,7 @@
             {{- wid|item_filter(config.filters) -}}
         </textarea>
     {% else %}
-        <p class="xmlui_widget xmlui_textbox" {{ {'id':id}|xmlattr }}>
+        <p class="xmlui_widget xmlui_textbox" {{ {'id':id}|xmlattr }}>
             {{- wid|item_filter(config.filters) -}}
         </p>
     {% endif %}
@@ -177,7 +177,7 @@
             {% endfor %}
         </select>
     {% else %}
-        <div class="xmlui_widget xmlui_list" {{ {'id':id}|xmlattr }}>
+        <div class="xmlui_widget xmlui_list" {{ {'id':id}|xmlattr }}>
             {% for value,label in wid.items %}
                 <span class="xmlui_list_item value_{{value|attr_escape}}">
                     {{- label -}}
--- a/default/static/styles.css	Wed Nov 15 08:52:14 2017 +0100
+++ b/default/static/styles.css	Fri Dec 01 00:46:42 2017 +0100
@@ -3,11 +3,23 @@
 }
 
 body {
+    margin: 0;
+    padding: 0;
     display: flex;
     height: 100vh;
     flex-direction: column;
     box-sizing: border-box;
-    margin: 0;
+}
+
+#main_side_bar {
+    
+}
+
+#main_area {
+    flex: 1;
+    display: flex;
+    flex-direction: column;
+    box-sizing: border-box;
 }
 
 #body {
@@ -23,19 +35,7 @@
 .box {
     background-color: #edf2ff;
     border-radius: 0;
-}
-
-@media (min-width: 500px) {
-    html {
-        background-size: auto;
-    }
-    body {
-        padding: 8px;
-    }
-    .box {
-        border-radius: 1em;
-        box-shadow: 10px 10px 16px -5px rgba(0,0,0,0.5);
-    }
+    border-color: silver;
 }
 
 .title {
@@ -53,48 +53,164 @@
     margin: 1.5em auto;
 }
 
-/* generic */
+/*** Generic ***/
 
 .button:hover {
     background-color: #bc0000;
 }
 
-/* Menus */
+/*** Messages ***/
+
+.message_info {
+    max-width: 500px;
+    margin: 0 auto;
+    padding: 1em;
+    text-align: justify;
+}
+
+.message_info pre {
+    background: #ddd;
+    padding: 1em;
+}
+
+/*** Menus ***/
 
 .menu ul {
     display: flex;
-    justify-content: center;
+    padding: 0;
     margin-top: 8px;
-    padding: 0;
     list-style: none;
 }
 
-.menu li {
+.menu a {
+    display: block;
+    color: inherit;
+    text-decoration: none;
+    font-variant: small-caps;
+}
+
+.main_menu {
+    min-width: 200px;
+    /* background-color: #eaeaea; */
+    background-color: #333;
+    color: white;
+}
+
+.main_menu ul {
+    flex-direction: row;
+    flex-wrap: wrap;
+}
+
+.main_menu li {
+    flex: 1;
+    padding: 0;
+    margin: 0 1em;
+}
+
+.main_menu a {
+    display: inline;
+    white-space: nowrap;
+}
+
+.main_menu a:hover {
+    background-color: initial;
+    text-shadow: 1px 1px 2px;
+    font-weight: bold;
+}
+
+.category_menu ul {
+    justify-content: center;
+}
+
+.category_menu li {
     margin: 0.5em;
     text-align: center;
 }
 
-.menu a {
-    color: inherit;
-    text-decoration: none;
-	border: solid 1px;
-	padding: 0.5em;
-	font-variant: small-caps;
-	border-radius: 1em;
-	background: #eee;
+.category_menu a {
+    border: solid 1px;
+    padding: 0.5em;
+    border-radius: 0.2em;
+    background: #eee;
+}
+
+/*** containers ***/
+
+/* tabs */
+
+.tab_container {
+    max-width: 1000px;
+    margin: 0 auto;
+}
+
+.tab_header {
+    background-color: white;
+    border-bottom: 1px solid lightgrey;
+}
+
+.tab_header ul {
+    display: flex;
+    margin: 0;
+    padding: 0;
+    list-style: none;
+    background-color: white;
+}
+
+.tab_page {
+    box-sizing: border-box;
+    padding-top: 2em;
+    border: 1px solid lightgrey;
+    border-top: none;
+    display: None;
 }
 
-.menu a:hover {
+.tab_page.clicked {
+    display: block;
+}
+
+.tab_button {
+    display: inline;
+    color: grey;
+    background-color: white;
+    border-top: 1px solid lightgrey;
+    border-left: 1px solid lightgrey;
+    border-bottom: 1px solid lightgrey;
+    padding: 0 1em;
+    cursor: pointer;
+    /* we go down by 1px to remove bottom border from .tab_header */
+    margin-bottom: -1px;
 }
 
-/* Forms */
+.tab_button.clicked {
+    /* background: lightgrey; */
+    color: inherit;
+    border-bottom: none;
+}
+
+li.tab_button:last-child {
+    border-right: 1px solid lightgrey;
+}
+
+.tab_button input {
+    display: None;
+}
+
+.tab_button label {
+    margin: 1em;
+}
+
+.tab_button input:checked + label {
+    font-weight: bold;
+}
+
+/*** Forms ***/
 
 .form_submit {
     margin: 1em auto 0;
     display: block;
 }
 
-/* XMLUI */
+/*** XMLUI ***/
 
 .xmlui_cont_vertical>* {
     display: block;
@@ -118,3 +234,32 @@
   color: inherit;
   text-decoration: inherit;
 }
+
+@media (min-width: 500px) {
+    html {
+        background-size: auto;
+    }
+
+    body {
+        flex-direction: row;
+    }
+
+    #main_area {
+        overflow: auto;
+    }
+
+    .box {
+        border-radius: 1em;
+        box-shadow: 10px 10px 16px -5px rgba(0,0,0,0.5);
+    }
+
+    .main_menu a {
+        display: block;
+        padding: 2em 0;
+    }
+
+    .main_menu ul {
+        flex-direction: column;
+        padding-left: 2em;
+    }
+}
--- a/default/static/ticket.css	Wed Nov 15 08:52:14 2017 +0100
+++ b/default/static/ticket.css	Fri Dec 01 00:46:42 2017 +0100
@@ -11,6 +11,7 @@
 
 .tickets table {
     margin: 0 auto;
+    border-spacing: 0 0.5em;
 }
 
 .tickets tr:nth-child(even) {
@@ -90,12 +91,12 @@
 }
 
 .view #wid_labels span {
-	font-size: 0.8em;
-	background: #eae3e3;
-	font-variant: small-caps;
-	border: 1px solid black;
-	border-radius: 0.5em;
-	padding: 0 2px;
+    font-size: 0.8em;
+    background: #eae3e3;
+    font-variant: small-caps;
+    border: 1px solid black;
+    border-radius: 0.5em;
+    padding: 0 2px;
     white-space: nowrap;
 }
 
--- a/default/ticket/create.html	Wed Nov 15 08:52:14 2017 +0100
+++ b/default/ticket/create.html	Fri Dec 01 00:46:42 2017 +0100
@@ -1,6 +1,6 @@
 {# creata a new ticket #}
 
-{% set menus = [(url_tickets_list, _('Tickets list'), 'tickets_list')] %}
+{% set category_menu = [('tickets_list', url_tickets_list)] %}
 {% extends 'base/base.html' %}
 {% import 'input/form.html' as form with context %}
 {% import 'input/field.html' as field with context %}
--- a/default/ticket/item.html	Wed Nov 15 08:52:14 2017 +0100
+++ b/default/ticket/item.html	Fri Dec 01 00:46:42 2017 +0100
@@ -6,8 +6,8 @@
     @variable comments_node(unicode): node for adding comments
 #}
 
-{% set menus = [(url_tickets_list, _('Tickets list'), 'tickets_list'),
-                (url_tickets_new,  _('Create new ticket'), 'ticket_new')] %}
+{% set category_menus = [('tickets_list', url_tickets_list),
+                         ('ticket_new', url_tickets_new)] %}
 {% if not embedded %}{% extends 'base/base.html' %}{% endif %}
 {% import 'input/xmlui.html' as xmlui with context %}
 {% import 'blog/macros.html' as blog with context %}
@@ -21,7 +21,7 @@
 
 {% block body %}
 <div id="{{ item.widget_value['id'] }}" class="view single ticket box">
-    {{ xmlui.generate(item,
+    {{ xmlui.generate(item,
         form=false,
         filters={'created': {'filters': ['date_fmt'], 'filters_args':[{'fmt': 'short'}]},
                  'updated': {'filters': ['date_fmt'], 'filters_args':[{'fmt': 'short'}]},
--- a/default/ticket/overview.html	Wed Nov 15 08:52:14 2017 +0100
+++ b/default/ticket/overview.html	Fri Dec 01 00:46:42 2017 +0100
@@ -1,6 +1,6 @@
 {# display the list of tickets #}
 
-{% set menus = [(url_tickets_new, _('Create new ticket'), 'ticket_new')] %}
+{% set category_menu = [('ticket_new', url_tickets_new)] %}
 {% extends 'base/base.html' %}
 {% import 'input/xmlui.html' as xmlui with context %}