2015-03-31 20:15:22 +02:00
|
|
|
|
{% extends "layout.html" %}
|
|
|
|
|
{% set active_page = "orders" -%}
|
2020-08-14 04:57:02 +02:00
|
|
|
|
{% if current_user.is_anonymous() %}
|
|
|
|
|
{% set my_items = order.for_user(anon=session.get("anon_name", "")) %}
|
|
|
|
|
{% else %}
|
|
|
|
|
{% set my_items = order.for_user(user=current_user) %}
|
|
|
|
|
{% endif %}
|
2020-01-26 02:28:20 +01:00
|
|
|
|
{% set courier_or_admin = not current_user.is_anonymous() and (current_user.is_admin() or current_user.id == order.courier_id) -%}
|
2015-03-31 20:15:22 +02:00
|
|
|
|
|
|
|
|
|
{% import "utils.html" as util %}
|
|
|
|
|
|
2020-09-26 00:39:50 +02:00
|
|
|
|
{% block metas %}
|
|
|
|
|
{{ super() }}
|
|
|
|
|
<meta name="robots" content="noindex, nofollow">
|
2022-04-20 02:35:44 +02:00
|
|
|
|
|
|
|
|
|
<script type="text/javascript" src="{{ url_for('static', filename='js/jquery.min.js') }}"></script>
|
|
|
|
|
<script type="text/javascript" src="{{ url_for('static', filename='js/qrcode.min.js') }}"></script>
|
2020-09-26 00:39:50 +02:00
|
|
|
|
{% endblock %}
|
|
|
|
|
|
2015-03-31 20:15:22 +02:00
|
|
|
|
{% block container %}
|
2022-04-20 02:35:44 +02:00
|
|
|
|
<header class="row">
|
|
|
|
|
<div class="col-md-2" style="padding-top: 2em">
|
|
|
|
|
<div id="qrcode"></div>
|
|
|
|
|
<script type="text/javascript">
|
|
|
|
|
var qrcode = new QRCode(document.getElementById("qrcode"), {
|
2022-05-25 13:55:31 +02:00
|
|
|
|
text: "{{ url_for("order_bp.order_from_slug", order_slug=order.slug, _external=True) }}",
|
2022-04-20 02:35:44 +02:00
|
|
|
|
width: 128,
|
|
|
|
|
height: 128,
|
|
|
|
|
colorDark : "#000000",
|
|
|
|
|
colorLight : "#ffffff",
|
|
|
|
|
correctLevel : QRCode.CorrectLevel.H
|
|
|
|
|
});
|
|
|
|
|
</script>
|
|
|
|
|
</div>
|
|
|
|
|
<div class="col-md-10">
|
|
|
|
|
<h2 id="order-title">Order {{ order.id }}</h2>
|
2020-08-14 04:57:02 +02:00
|
|
|
|
|
2022-04-20 02:35:44 +02:00
|
|
|
|
<div class="location">
|
|
|
|
|
{% if order.location %}
|
|
|
|
|
<a href="{{ url_for('general_bp.location', location_id=order.location_id) }}">{{ order.location_name }}</a>
|
|
|
|
|
{% else %}
|
|
|
|
|
{{ order.location_name }}
|
|
|
|
|
{% endif %}
|
|
|
|
|
</div>
|
|
|
|
|
<div>
|
2022-05-25 13:55:31 +02:00
|
|
|
|
Unique order link: <code>{{ url_for("order_bp.order_from_slug", order_slug=order.slug, _external=True) }}</code>
|
2022-04-20 02:35:44 +02:00
|
|
|
|
</div>
|
2020-02-29 17:23:20 +01:00
|
|
|
|
</div>
|
2020-08-14 04:57:02 +02:00
|
|
|
|
</header>
|
|
|
|
|
|
|
|
|
|
<section>
|
2020-08-21 15:17:10 +02:00
|
|
|
|
<div class="column">
|
2020-10-12 22:40:27 +02:00
|
|
|
|
<div class="box" id="my_items">
|
|
|
|
|
<h3>My items</h3>
|
|
|
|
|
{% if my_items %}
|
|
|
|
|
<ul>
|
|
|
|
|
{% for item in my_items %}
|
|
|
|
|
<li class="spacecake">
|
|
|
|
|
{% if item.can_delete(order.id, current_user.id, session.get('anon_name', '')) -%}
|
2022-05-25 13:55:31 +02:00
|
|
|
|
<form action="{{ url_for('order_bp.delete_item', order_slug=order.slug, item_id=item.id) }}" method="post" style="display:inline">
|
2020-10-12 22:40:27 +02:00
|
|
|
|
<button class="btn btn-link btn-sm" type="submit" style="padding: 0 0.5em;"><span class="glyphicon glyphicon-remove"></span></button>
|
|
|
|
|
</form>
|
|
|
|
|
{%- endif %}
|
2020-10-13 02:10:45 +02:00
|
|
|
|
<span>{{ item.dish_name }}{% if item.comment %}; {{ item.comment }}{% endif %}</span><span class="spacer"> </span><span class="price">{{ item.price | euro }}</span>
|
2020-10-12 22:40:27 +02:00
|
|
|
|
</li>
|
|
|
|
|
{% endfor %}
|
|
|
|
|
</ul>
|
|
|
|
|
{% else %}
|
|
|
|
|
<div>(None)</div>
|
|
|
|
|
{% endif %}
|
2020-08-21 15:17:10 +02:00
|
|
|
|
</div>
|
2020-02-23 23:29:39 +01:00
|
|
|
|
|
2020-02-21 18:38:30 +01:00
|
|
|
|
|
2020-08-21 15:17:10 +02:00
|
|
|
|
{% if form %}
|
2020-08-14 04:57:02 +02:00
|
|
|
|
|
2020-09-01 16:26:29 +02:00
|
|
|
|
<!--
|
2020-08-21 15:17:10 +02:00
|
|
|
|
<div class="box" id="from_favourites">
|
|
|
|
|
<h3>Add from favourites</h3>
|
|
|
|
|
<ul>
|
|
|
|
|
<li>Todo</li>
|
|
|
|
|
</ul>
|
|
|
|
|
</div>
|
2020-09-01 16:26:29 +02:00
|
|
|
|
-->
|
2020-08-14 04:57:02 +02:00
|
|
|
|
|
2020-08-21 15:17:10 +02:00
|
|
|
|
<div class="box" id="add_item">
|
|
|
|
|
<h3>Add item to order</h3>
|
2020-08-14 04:57:02 +02:00
|
|
|
|
|
2020-08-21 15:17:10 +02:00
|
|
|
|
{% for dish in order.location.dishes %}
|
2022-05-25 13:55:31 +02:00
|
|
|
|
<form method="post" action="{{ url_for('order_bp.order_item_create', order_slug=order.slug) }}" id="dish_{{ dish.id }}">
|
2020-08-21 15:17:10 +02:00
|
|
|
|
{{ form.csrf_token }}
|
|
|
|
|
<input type="hidden" name="dish_id" value="{{ dish.id }}" />
|
|
|
|
|
|
|
|
|
|
{% if form.dish_id.errors %}
|
|
|
|
|
<div class="form-group has-errors">
|
|
|
|
|
{{ util.render_form_field_errors(form.dish_id) }}
|
|
|
|
|
</div>
|
|
|
|
|
{% endif %}
|
|
|
|
|
|
|
|
|
|
<details {% if dish.id == selected_dish.id %}open="open"{% endif %}>
|
2020-09-25 21:12:41 +02:00
|
|
|
|
<summary class="spacecake">
|
|
|
|
|
<span class="dish_name">{{ dish.name }}</span>
|
2020-10-12 22:40:27 +02:00
|
|
|
|
<!--
|
2020-09-25 21:12:41 +02:00
|
|
|
|
{% if dish.tags %}<span class="tags"> {{ dish.tags | join(", ") }}</span>{% endif %}
|
2020-10-12 22:40:27 +02:00
|
|
|
|
-->
|
2020-09-25 21:12:41 +02:00
|
|
|
|
<span class="spacer"></span>
|
2020-10-13 02:10:45 +02:00
|
|
|
|
<span class="price">{{ dish.price_range() | price_range }}</span>
|
2020-09-25 21:12:41 +02:00
|
|
|
|
</summary>
|
2020-10-12 22:40:27 +02:00
|
|
|
|
{% if dish.description %}<div class="description">{{ dish.description }}</div>{% endif %}
|
2020-08-21 15:17:10 +02:00
|
|
|
|
{% for (choice_type, choice) in dish.choices %}
|
|
|
|
|
<div class="form-group select2-container select2">
|
|
|
|
|
<label class="control-label" for="choice_{{ choice.id }}">{{ choice.name }}</label><br/>
|
|
|
|
|
<select
|
|
|
|
|
{{ "multiple=multiple" if choice_type=="multi_choice" else "required=required" }}
|
|
|
|
|
name="choice_{{ choice.id }}"
|
|
|
|
|
class="form-control select">
|
|
|
|
|
{% for option in choice.options %}
|
|
|
|
|
<option value="{{ option.id }}"><!--
|
|
|
|
|
-->{{ option.name }}{{ ": " + option.price|euro if option.price else "" }}<!--
|
|
|
|
|
-->{{ " (" + option.description + ")" if option.description else "" }}<!--
|
|
|
|
|
--></option>
|
|
|
|
|
{% endfor %}
|
|
|
|
|
</select>
|
|
|
|
|
</div>
|
|
|
|
|
{% endfor %}
|
|
|
|
|
|
|
|
|
|
<div class="form-group {{ 'has-errors' if form.dish_id.errors }}">
|
|
|
|
|
{{ form.comment.label }}<br>
|
|
|
|
|
{{ form.comment(class='form-control', placeholder='Fill in comment, when applicable') }}
|
|
|
|
|
{{ util.render_form_field_errors(form.comment) }}
|
|
|
|
|
</div>
|
|
|
|
|
|
|
|
|
|
{% if current_user.is_anonymous() %}
|
|
|
|
|
<div class="form-group{{ ' has-error' if form.user_name.errors }}{{ ' required' if form.user_name.flags.required }}">
|
|
|
|
|
{{ form.user_name.label(class='control-label') }}
|
|
|
|
|
{{ form.user_name(class='form-control', placeholder='Fill in your name...') }}
|
|
|
|
|
{{ util.render_form_field_errors(form.user_name) }}
|
|
|
|
|
</div>
|
|
|
|
|
{% endif %}
|
|
|
|
|
<div class="form-group" style="padding-top: 8px;">
|
|
|
|
|
{{ form.submit_button(class='btn btn-primary') }}
|
|
|
|
|
</div>
|
|
|
|
|
</details>
|
|
|
|
|
</form>
|
|
|
|
|
{% endfor %}
|
|
|
|
|
</div>
|
2020-08-14 04:57:02 +02:00
|
|
|
|
|
|
|
|
|
{% endif %}
|
2020-08-21 15:17:10 +02:00
|
|
|
|
|
|
|
|
|
{% if form %}
|
2020-02-29 17:23:20 +01:00
|
|
|
|
</div>
|
2020-08-14 04:57:02 +02:00
|
|
|
|
|
2020-08-21 15:17:10 +02:00
|
|
|
|
<div class="column">
|
|
|
|
|
{% endif %}
|
|
|
|
|
|
|
|
|
|
|
2020-10-12 22:40:27 +02:00
|
|
|
|
<div class="box" id="order_info">
|
|
|
|
|
<h3>Order information</h3>
|
|
|
|
|
<dl>
|
2020-10-13 02:01:07 +02:00
|
|
|
|
<div>
|
|
|
|
|
<dt>Order opens</dt>
|
|
|
|
|
<dd>{{ order.starttime.strftime("%Y-%m-%d, %H:%M") }}</dd>
|
|
|
|
|
|
|
|
|
|
<dt>Order closes</dt>
|
|
|
|
|
<dd>
|
|
|
|
|
{% if order.stoptime %}
|
|
|
|
|
{% set stoptimefmt = (
|
|
|
|
|
"%H:%M" if order.stoptime.date() == order.starttime.date()
|
|
|
|
|
else "%Y-%m-%d, %H:%M"
|
|
|
|
|
) %}
|
|
|
|
|
{{ order.stoptime.strftime(stoptimefmt) }} ({{ order.stoptime|countdown }})
|
|
|
|
|
{% else %}
|
|
|
|
|
Never
|
|
|
|
|
{% endif %}
|
|
|
|
|
</dd>
|
|
|
|
|
</div>
|
|
|
|
|
|
|
|
|
|
<div>
|
|
|
|
|
<dt>Location</dt>
|
|
|
|
|
<dd>
|
|
|
|
|
{% if order.location %}
|
|
|
|
|
<a href="{{ url_for('general_bp.location', location_id=order.location_id) }}">{{ order.location_name }}</a>
|
|
|
|
|
{% else %}
|
|
|
|
|
{{ order.location_name }}
|
|
|
|
|
{% endif %}
|
|
|
|
|
</dd>
|
|
|
|
|
|
|
|
|
|
<dt>Courier</dt>
|
|
|
|
|
<dd>
|
|
|
|
|
{% if order.courier == None %}
|
|
|
|
|
{% if not current_user.is_anonymous() %}
|
2022-05-25 13:55:31 +02:00
|
|
|
|
<form action="{{ url_for('order_bp.volunteer', order_slug=order.slug) }}" method="post" style="display:inline">
|
2020-10-13 02:01:07 +02:00
|
|
|
|
<input type="submit" class="btn btn-primary btn-sm" value="Volunteer"></input>
|
|
|
|
|
</form>
|
2021-06-18 15:05:11 +02:00
|
|
|
|
{% else %}No-one yet{% endif %}
|
2020-10-13 02:01:07 +02:00
|
|
|
|
{% else %}
|
|
|
|
|
{{ order.courier.username }}
|
|
|
|
|
{% endif %}
|
|
|
|
|
</dd>
|
|
|
|
|
</div>
|
2020-10-12 22:40:27 +02:00
|
|
|
|
</dl>
|
|
|
|
|
|
|
|
|
|
<div>
|
|
|
|
|
{% if order.can_close(current_user.id) -%}
|
2022-05-25 13:55:31 +02:00
|
|
|
|
<form action="{{ url_for('order_bp.close_order', order_slug=order.slug) }}" method="post" style="display:inline">
|
2020-10-12 22:40:27 +02:00
|
|
|
|
<input type="submit" class="btn btn-danger" value="Close"></input>
|
|
|
|
|
</form>
|
|
|
|
|
{% endif %}
|
|
|
|
|
{% if courier_or_admin %}
|
2022-05-25 13:55:31 +02:00
|
|
|
|
<a class="btn" href="{{ url_for('order_bp.order_edit', order_slug=order.slug) }}">Edit</a>
|
2020-10-12 22:40:27 +02:00
|
|
|
|
{%- endif %}
|
|
|
|
|
</div>
|
2020-08-21 15:17:10 +02:00
|
|
|
|
</div>
|
2020-08-14 04:57:02 +02:00
|
|
|
|
|
2020-08-21 15:17:10 +02:00
|
|
|
|
<div class="box" id="how_to_order">
|
2020-10-13 01:42:03 +02:00
|
|
|
|
<h3>About {{ order.location_name }}</h3>
|
2020-08-21 15:17:10 +02:00
|
|
|
|
<dl>
|
|
|
|
|
{% if order.location.telephone %}
|
2020-10-13 02:01:07 +02:00
|
|
|
|
<div>
|
2020-08-21 15:17:10 +02:00
|
|
|
|
<dt>Telephone</dt>
|
2021-07-17 20:33:07 +02:00
|
|
|
|
<dd><a href="tel:{{ order.location.telephone }}">{{ order.location.telephone }}</a></dd>
|
2020-10-13 02:01:07 +02:00
|
|
|
|
</div>
|
2020-08-21 15:17:10 +02:00
|
|
|
|
{% endif %}
|
|
|
|
|
|
|
|
|
|
{% if order.location.website %}
|
2020-10-13 02:01:07 +02:00
|
|
|
|
<div>
|
2020-08-21 15:17:10 +02:00
|
|
|
|
<dt>Website</dt>
|
|
|
|
|
<dd><a href="{{ order.location.website }}">{{ order.location.website }}</a></dd>
|
2020-10-13 02:01:07 +02:00
|
|
|
|
</div>
|
2020-08-21 15:17:10 +02:00
|
|
|
|
{% endif %}
|
|
|
|
|
|
|
|
|
|
{% if order.location.address or order.location.osm %}
|
2020-10-13 02:01:07 +02:00
|
|
|
|
<div>
|
2020-08-21 15:17:10 +02:00
|
|
|
|
<dt>Location</dt>
|
|
|
|
|
<dd>
|
|
|
|
|
{% if order.location.osm %}
|
|
|
|
|
<a href="{{ order.location.osm }}">{{ order.location.address or "View on OSM" }}</a>
|
|
|
|
|
{% else %}
|
|
|
|
|
{{ order.location.address }}
|
|
|
|
|
{% endif %}
|
|
|
|
|
</dd>
|
2020-10-13 02:01:07 +02:00
|
|
|
|
</div>
|
2020-08-21 15:17:10 +02:00
|
|
|
|
{% endif %}
|
|
|
|
|
</dl>
|
2020-08-14 04:57:02 +02:00
|
|
|
|
</div>
|
|
|
|
|
|
2020-08-21 15:17:10 +02:00
|
|
|
|
{% if not form %}
|
|
|
|
|
</div>
|
2020-08-14 04:57:02 +02:00
|
|
|
|
|
2020-08-21 15:17:10 +02:00
|
|
|
|
<div class="column">
|
|
|
|
|
{% endif %}
|
|
|
|
|
|
|
|
|
|
<div class="box" id="per_dish">
|
|
|
|
|
<h3>Ordered dishes</h3>
|
2021-06-21 02:05:11 +02:00
|
|
|
|
{% for dish_name, dish_quantity, dish_comment_groups in order.group_by_dish() -%}
|
|
|
|
|
{% set has_comments = dish_comment_groups | length > 1 or (dish_comment_groups | map("first") | any) -%}
|
2020-10-13 02:18:43 +02:00
|
|
|
|
<div class="dish {{ 'spacecake no_comments' if not has_comments }}">
|
2020-08-21 15:17:10 +02:00
|
|
|
|
<h4>
|
2021-06-21 02:05:11 +02:00
|
|
|
|
<span class="quantity">{{ dish_quantity }}</span> ×
|
2020-08-21 15:17:10 +02:00
|
|
|
|
{{ dish_name }}
|
|
|
|
|
</h4>
|
|
|
|
|
|
|
|
|
|
{% if has_comments -%}
|
|
|
|
|
<ul class="comments">
|
2021-06-21 02:05:11 +02:00
|
|
|
|
{% for comment, items in dish_comment_groups -%}
|
2021-06-21 02:08:32 +02:00
|
|
|
|
<li class="spacecake"><span class="comment">
|
|
|
|
|
<span class="quantity">{{ items | length }}</span> ×
|
|
|
|
|
{% if comment %}{{ comment }}
|
2020-08-21 15:17:10 +02:00
|
|
|
|
{% else %}<i>No comment</i>
|
2021-06-21 02:05:11 +02:00
|
|
|
|
{% endif %}</span><span class="spacer"> </span><span class="item_for">for {{ items | map(attribute="for_name") | join(", ") }}</span></li>
|
2020-08-21 15:17:10 +02:00
|
|
|
|
{% endfor %}
|
|
|
|
|
</ul>
|
2020-08-14 04:57:02 +02:00
|
|
|
|
{% else %}
|
2021-06-21 02:05:11 +02:00
|
|
|
|
<span class="spacer"> </span><span class="item_for">for {{ dish_comment_groups[0][1] | map(attribute="for_name") | join(", ") }}</span>
|
2020-08-21 15:17:10 +02:00
|
|
|
|
{%- endif %}
|
|
|
|
|
|
|
|
|
|
</p>
|
|
|
|
|
</div>
|
|
|
|
|
{%- endfor %}
|
|
|
|
|
<div class="footer">
|
|
|
|
|
Total {{ order.items.count() }} items — {{ total_price|euro }}
|
2020-09-01 16:35:18 +02:00
|
|
|
|
|
2022-05-25 13:55:31 +02:00
|
|
|
|
<a class="btn btn-sm" href="{{ url_for('order_bp.items_shop_view', order_slug=order.slug) }}">Shop view</a>
|
2020-08-21 15:17:10 +02:00
|
|
|
|
</div>
|
|
|
|
|
</div>
|
2020-02-29 17:23:20 +01:00
|
|
|
|
</div>
|
2020-08-14 04:57:02 +02:00
|
|
|
|
</section>
|
|
|
|
|
|
|
|
|
|
<section class="single_column">
|
|
|
|
|
<div class="box" id="per_person">
|
|
|
|
|
<h3>Items per person</h3>
|
2022-05-25 13:55:31 +02:00
|
|
|
|
<form action="{{ url_for('order_bp.modify_items', order_slug=order.slug) }}" method="post">
|
2020-08-14 04:57:02 +02:00
|
|
|
|
<table class="table table-condensed">
|
|
|
|
|
<thead>
|
|
|
|
|
<tr><th>Total</th><th>Name</th><th>Items</th></tr>
|
|
|
|
|
</thead>
|
|
|
|
|
<tbody>
|
|
|
|
|
{% for user_name, order_items in order.group_by_user() -%}
|
|
|
|
|
<tr>
|
|
|
|
|
<td>
|
|
|
|
|
{% set paid = order_items | map(attribute="paid") | all %}
|
2022-03-27 19:33:14 +02:00
|
|
|
|
<input type="checkbox" name="user_names" value="{{ user_name }}"
|
2022-05-02 22:04:45 +02:00
|
|
|
|
{{ "disabled" if not order.can_modify_payment(current_user.id) }}>
|
2020-08-14 04:57:02 +02:00
|
|
|
|
|
2022-03-27 19:33:14 +02:00
|
|
|
|
<span class="price" style="{{ 'opacity: 0.5' if paid }}">
|
2022-05-11 02:43:08 +02:00
|
|
|
|
{{ order_items | map(attribute="price") | ignore_none | sum | euro }}
|
2022-03-27 19:33:14 +02:00
|
|
|
|
</span>
|
2020-08-14 04:57:02 +02:00
|
|
|
|
|
2022-05-02 21:56:38 +02:00
|
|
|
|
{% if paid %}<span class="glyphicon glyphicon-ok" style="opacity: 0.5"></span>{% endif %}
|
2020-08-14 04:57:02 +02:00
|
|
|
|
</td>
|
2022-05-02 21:56:38 +02:00
|
|
|
|
<td style="{{ 'opacity: 0.5' if paid }}">{{ user_name }}</td>
|
2020-08-14 04:57:02 +02:00
|
|
|
|
<td class="items">
|
|
|
|
|
<ul>
|
|
|
|
|
{% for item in order_items %}
|
|
|
|
|
<li class="{{ 'paid' if item.paid }}">
|
|
|
|
|
<div class="actions">
|
|
|
|
|
{% if item.can_delete(order.id, current_user.id, session.get('anon_name', '')) -%}
|
2022-05-25 13:55:31 +02:00
|
|
|
|
<form action="{{ url_for('order_bp.delete_item', order_slug=order.slug, item_id=item.id) }}" method="post" style="display:inline">
|
2022-04-20 02:05:10 +02:00
|
|
|
|
<button class="btn btn-link btn-sm" type="submit" style="padding: 0 0.5em;"><span class="glyphicon glyphicon-remove"></span></button>
|
|
|
|
|
</form>
|
2020-02-29 17:23:20 +01:00
|
|
|
|
{% else %}
|
2022-05-02 22:25:06 +02:00
|
|
|
|
<span class="glyphicon glyphicon-remove" style="color: var(--gray3); padding: 0 0.5em; cursor: not-allowed"></span>
|
2020-08-14 04:57:02 +02:00
|
|
|
|
{%- endif %}
|
|
|
|
|
</div>
|
|
|
|
|
|
2022-04-22 01:15:54 +02:00
|
|
|
|
<div class="price_aligned">
|
|
|
|
|
{{ item.price|euro }}
|
|
|
|
|
{% if item.price_modified %}
|
|
|
|
|
<span class="glyphicon glyphicon-pencil" style="opacity: 0.5" title="Edited"></span>
|
|
|
|
|
{% endif %}
|
|
|
|
|
</div>
|
2020-08-14 04:57:02 +02:00
|
|
|
|
<div class="item_description">{{ item.dish_name }}{{ "; " + item.comment if item.comment }}</div>
|
|
|
|
|
</li>
|
|
|
|
|
{% endfor %}
|
|
|
|
|
</ul>
|
|
|
|
|
</td>
|
|
|
|
|
|
|
|
|
|
</tr>
|
|
|
|
|
{%- endfor %}
|
|
|
|
|
</tbody>
|
|
|
|
|
</table>
|
|
|
|
|
|
|
|
|
|
<div class="footer">
|
2022-05-02 21:56:38 +02:00
|
|
|
|
{% if order.can_modify_payment(current_user.id) %}
|
2020-08-14 04:57:02 +02:00
|
|
|
|
On selected:
|
2022-03-27 19:33:14 +02:00
|
|
|
|
<button name="action" value="mark_paid" class="btn btn-sm"><span class="glyphicon glyphicon-ok"></span> Mark paid</button>
|
|
|
|
|
<button name="action" value="mark_unpaid" class="btn btn-sm">Mark unpaid</button>
|
2022-05-02 21:56:38 +02:00
|
|
|
|
{% endif %}
|
2022-04-22 01:15:54 +02:00
|
|
|
|
|
2022-05-02 21:56:38 +02:00
|
|
|
|
{% if order.can_modify_prices(current_user.id) %}
|
2022-04-22 01:15:54 +02:00
|
|
|
|
<span style="border-left: 1px solid var(--gray0); display: inline-block;"> </span>
|
2022-05-25 13:55:31 +02:00
|
|
|
|
<a href="{{ url_for('order_bp.prices', order_slug=order.slug) }}" class="btn btn-sm">
|
2022-04-22 01:15:54 +02:00
|
|
|
|
<span class="glyphicon glyphicon-pencil"></span> Edit prices
|
|
|
|
|
</a>
|
|
|
|
|
{% endif %}
|
|
|
|
|
|
2020-08-14 04:57:02 +02:00
|
|
|
|
</div>
|
2022-03-27 19:33:14 +02:00
|
|
|
|
</form>
|
2020-02-29 17:23:20 +01:00
|
|
|
|
</div>
|
2020-08-14 04:57:02 +02:00
|
|
|
|
</section>
|
2015-03-31 20:15:22 +02:00
|
|
|
|
{% endblock %}
|
|
|
|
|
|
|
|
|
|
{% block styles %}
|
2020-02-29 17:23:20 +01:00
|
|
|
|
{{ super() }}
|
|
|
|
|
<link rel="stylesheet" href="{{ url_for('static', filename='css/select2.min.css') }}" />
|
|
|
|
|
<link rel="stylesheet" href="{{ url_for('static', filename='css/select2-bootstrap.min.css') }}">
|
|
|
|
|
<link rel="stylesheet" href="{{ url_for('static', filename='css/print.css') }}">
|
2020-08-14 04:57:02 +02:00
|
|
|
|
|
|
|
|
|
<style>
|
|
|
|
|
body, h1, h2, h3, h4 {
|
2020-08-17 10:43:11 +02:00
|
|
|
|
color: var(--gray0);
|
2020-08-14 04:57:02 +02:00
|
|
|
|
}
|
|
|
|
|
table {
|
|
|
|
|
overflow-wrap: break-word;
|
|
|
|
|
}
|
2020-09-01 16:35:18 +02:00
|
|
|
|
@media (min-width: 1200px) {
|
|
|
|
|
section {
|
|
|
|
|
display: grid;
|
|
|
|
|
grid-template-columns: 1fr 1fr;
|
|
|
|
|
grid-gap: 0 30px;
|
|
|
|
|
align-items: start;
|
|
|
|
|
}
|
2020-08-14 04:57:02 +02:00
|
|
|
|
}
|
|
|
|
|
section.single_column {
|
2020-08-21 15:17:10 +02:00
|
|
|
|
grid-template-columns: unset;
|
2020-08-14 04:57:02 +02:00
|
|
|
|
}
|
2020-09-01 16:35:18 +02:00
|
|
|
|
.description {
|
2020-10-13 01:42:03 +02:00
|
|
|
|
margin-bottom: 10px;
|
2020-09-01 16:35:18 +02:00
|
|
|
|
}
|
2020-08-14 04:57:02 +02:00
|
|
|
|
header {
|
|
|
|
|
margin-bottom: 25px;
|
|
|
|
|
}
|
|
|
|
|
h2 {
|
|
|
|
|
margin-bottom: 0;
|
|
|
|
|
}
|
|
|
|
|
h3 {
|
|
|
|
|
margin-top: 0;
|
2020-08-21 15:17:10 +02:00
|
|
|
|
font-size: 150%;
|
|
|
|
|
font-weight: 500;
|
2020-08-14 04:57:02 +02:00
|
|
|
|
}
|
2020-10-13 02:18:43 +02:00
|
|
|
|
h4 {
|
2020-10-13 02:27:31 +02:00
|
|
|
|
margin-bottom: 0.5em;
|
2020-10-13 02:18:43 +02:00
|
|
|
|
font-size: 110%;
|
|
|
|
|
font-weight: 500;
|
|
|
|
|
}
|
2020-08-14 04:57:02 +02:00
|
|
|
|
.location {
|
2020-08-21 15:17:10 +02:00
|
|
|
|
font-size: 150%;
|
2020-08-14 04:57:02 +02:00
|
|
|
|
font-weight: 500;
|
2020-08-21 15:17:10 +02:00
|
|
|
|
margin-left: 3px;
|
2020-08-14 04:57:02 +02:00
|
|
|
|
margin-top: -5px;
|
|
|
|
|
}
|
|
|
|
|
.box {
|
|
|
|
|
width: 100%;
|
2020-08-17 10:43:11 +02:00
|
|
|
|
border: 2px solid var(--gray0);
|
2020-08-14 04:57:02 +02:00
|
|
|
|
padding: 10px;
|
2020-08-21 15:17:10 +02:00
|
|
|
|
margin-bottom: 30px;
|
2020-08-14 04:57:02 +02:00
|
|
|
|
}
|
|
|
|
|
|
2020-10-13 02:07:50 +02:00
|
|
|
|
@media (min-width: 500px) {
|
2020-10-13 02:01:07 +02:00
|
|
|
|
#order_info dl {
|
|
|
|
|
display: grid;
|
|
|
|
|
grid-template-columns: 1fr 1fr;
|
|
|
|
|
}
|
2020-08-14 04:57:02 +02:00
|
|
|
|
}
|
|
|
|
|
|
2020-08-17 10:57:10 +02:00
|
|
|
|
#from_favourites ul, #my_items ul, #per_person ul {
|
2020-08-14 04:57:02 +02:00
|
|
|
|
list-style-type: none;
|
|
|
|
|
padding: 0;
|
|
|
|
|
}
|
|
|
|
|
dl {
|
|
|
|
|
margin-bottom: 10px;
|
|
|
|
|
}
|
|
|
|
|
.box :last-child {
|
|
|
|
|
margin-bottom: 0;
|
|
|
|
|
}
|
|
|
|
|
|
2020-08-21 15:17:10 +02:00
|
|
|
|
.spacecake {
|
2020-08-14 04:57:02 +02:00
|
|
|
|
display: flex;
|
|
|
|
|
align-items: flex-end;
|
|
|
|
|
}
|
2020-09-25 21:12:41 +02:00
|
|
|
|
.spacecake .tags {
|
|
|
|
|
padding-left: 0.5em;
|
|
|
|
|
color: var(--gray2);
|
|
|
|
|
}
|
2020-08-21 15:17:10 +02:00
|
|
|
|
.spacecake .spacer {
|
2020-08-14 04:57:02 +02:00
|
|
|
|
content: ' ';
|
|
|
|
|
flex-grow: 1;
|
|
|
|
|
min-width: 10px;
|
2020-08-17 10:43:11 +02:00
|
|
|
|
border-bottom: 1px solid var(--gray3);
|
2020-08-14 04:57:02 +02:00
|
|
|
|
margin: 0.3em 0.5em;
|
|
|
|
|
}
|
2020-08-21 15:17:10 +02:00
|
|
|
|
|
2021-07-17 20:41:59 +02:00
|
|
|
|
.main li {
|
2020-08-21 15:17:10 +02:00
|
|
|
|
line-height: 1.5;
|
2020-10-13 02:27:31 +02:00
|
|
|
|
margin: 0.4em 0;
|
2020-08-21 15:17:10 +02:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
#my_items li form {
|
|
|
|
|
align-self: flex-start;
|
|
|
|
|
}
|
|
|
|
|
|
2020-10-13 02:27:31 +02:00
|
|
|
|
#per_dish ul {
|
|
|
|
|
margin-bottom: 0;
|
|
|
|
|
}
|
|
|
|
|
#per_dish h4 {
|
|
|
|
|
margin-top: 0;
|
2020-08-21 15:17:10 +02:00
|
|
|
|
}
|
|
|
|
|
#per_dish .dish.no_comments h4 {
|
|
|
|
|
margin-bottom: 0;
|
|
|
|
|
line-height: inherit;
|
|
|
|
|
}
|
2020-10-13 02:27:31 +02:00
|
|
|
|
#per_dish .dish {
|
|
|
|
|
margin-bottom: 13px;
|
|
|
|
|
}
|
2020-08-14 04:57:02 +02:00
|
|
|
|
#per_dish .item_for {
|
2020-08-17 10:43:11 +02:00
|
|
|
|
color: var(--gray2);
|
2020-08-14 04:57:02 +02:00
|
|
|
|
text-align: right;
|
|
|
|
|
}
|
2021-06-21 02:05:11 +02:00
|
|
|
|
#per_dish .comments {
|
|
|
|
|
padding-left: 1.5em;
|
|
|
|
|
list-style-type: none;
|
|
|
|
|
}
|
2020-08-14 04:57:02 +02:00
|
|
|
|
|
|
|
|
|
|
|
|
|
|
#per_person li {
|
|
|
|
|
white-space: nowrap;
|
2020-08-21 15:17:10 +02:00
|
|
|
|
margin-top: 0.15em;
|
2020-08-14 04:57:02 +02:00
|
|
|
|
vertical-align: top;
|
|
|
|
|
}
|
|
|
|
|
#per_person li > * {
|
|
|
|
|
display: inline-block;
|
|
|
|
|
vertical-align: top;
|
|
|
|
|
}
|
|
|
|
|
#per_person .item_description {
|
|
|
|
|
white-space: normal;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
.price, .price_aligned {
|
|
|
|
|
white-space: nowrap;
|
|
|
|
|
}
|
|
|
|
|
.price_aligned {
|
|
|
|
|
display: inline-block;
|
|
|
|
|
width: 4em;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
.items .paid {
|
|
|
|
|
opacity: 0.4;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
.footer {
|
|
|
|
|
margin-top: 1em;
|
|
|
|
|
}
|
2020-09-01 16:35:18 +02:00
|
|
|
|
|
|
|
|
|
summary {
|
|
|
|
|
line-height: 1.2;
|
2021-06-21 00:46:29 +02:00
|
|
|
|
margin: 0 -10px;
|
|
|
|
|
padding: 4px 10px;
|
2020-09-01 16:35:18 +02:00
|
|
|
|
}
|
|
|
|
|
summary .dish_name, summary:before {
|
|
|
|
|
align-self: flex-start;
|
2020-10-13 01:42:03 +02:00
|
|
|
|
}
|
|
|
|
|
details[open] summary .dish_name {
|
|
|
|
|
font-weight: bold;
|
|
|
|
|
}
|
2021-06-21 00:46:29 +02:00
|
|
|
|
details {
|
|
|
|
|
margin: 0 -10px;
|
|
|
|
|
padding: 0 10px;
|
|
|
|
|
}
|
2020-10-13 01:42:03 +02:00
|
|
|
|
details[open] {
|
|
|
|
|
background-color: var(--gray5);
|
2021-06-21 00:46:29 +02:00
|
|
|
|
padding-bottom: 5px;
|
|
|
|
|
}
|
|
|
|
|
details:not([open]) summary:hover {
|
|
|
|
|
background-color: var(--gray5);
|
2020-10-13 01:42:03 +02:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
.select2-container--default .select2-selection--multiple .select2-selection__rendered {
|
|
|
|
|
padding: 0 3px;
|
|
|
|
|
}
|
|
|
|
|
.select2-container .select2-selection--multiple {
|
|
|
|
|
min-height: 20px;
|
|
|
|
|
line-height: 1;
|
|
|
|
|
}
|
|
|
|
|
.select2-container .select2-search--inline .select2-search__field {
|
|
|
|
|
margin-top: 3px;
|
|
|
|
|
}
|
|
|
|
|
.select2-container--default .select2-selection--multiple .select2-selection__choice {
|
|
|
|
|
margin-top: 4px;
|
|
|
|
|
}
|
|
|
|
|
.select2-container li {
|
|
|
|
|
margin: 0;
|
|
|
|
|
}
|
|
|
|
|
.select2-selection--multiple .select2-search.select2-search--inline .select2-search__field:not(:focus) {
|
|
|
|
|
border-color: transparent;
|
|
|
|
|
box-shadow: none;
|
2020-09-01 16:35:18 +02:00
|
|
|
|
}
|
2020-08-14 04:57:02 +02:00
|
|
|
|
</style>
|
2015-03-31 20:15:22 +02:00
|
|
|
|
{% endblock %}
|
|
|
|
|
{% block scripts %}
|
2020-02-29 17:23:20 +01:00
|
|
|
|
{{ super() }}
|
|
|
|
|
<script src="{{ url_for('static', filename='js/select2.min.js') }}"></script>
|
2020-03-05 00:37:16 +01:00
|
|
|
|
{% if form %}
|
2020-10-13 01:42:03 +02:00
|
|
|
|
<script type="text/javascript">
|
|
|
|
|
"use strict";
|
|
|
|
|
function openDish(detailsEl, open=null) {
|
|
|
|
|
let openAttr = detailsEl.getAttribute("open");
|
|
|
|
|
let isOpen = openAttr || openAttr == "";
|
|
|
|
|
|
|
|
|
|
$("details").removeAttr("open");
|
|
|
|
|
if (open === true || open === null && !isOpen) {
|
|
|
|
|
detailsEl.setAttribute("open", true);
|
|
|
|
|
$(detailsEl).find(".select").select2({"sorter": x => x.sort()});
|
|
|
|
|
|
|
|
|
|
let id = detailsEl.parentNode.getAttribute("id");
|
|
|
|
|
window.history.replaceState(null, "", `#${id}`);
|
|
|
|
|
} else {
|
|
|
|
|
window.history.replaceState(null, "",
|
|
|
|
|
`${window.location.origin}${window.location.pathname}`);
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
$("summary").on("click", e => { openDish(e.currentTarget.parentNode); return false; });
|
|
|
|
|
$(window).on("load", () => {
|
|
|
|
|
let m = window.location.hash.match(/^#dish_[a-z0-9_-]*$/);
|
|
|
|
|
if (m[0]) {
|
|
|
|
|
openDish($(m[0]).find("details")[0], open=true);
|
|
|
|
|
}
|
|
|
|
|
});
|
2020-02-29 17:23:20 +01:00
|
|
|
|
</script>
|
2020-10-13 01:42:03 +02:00
|
|
|
|
{% endif %}
|
2015-04-05 13:08:02 +02:00
|
|
|
|
{% endblock %}
|