Files
recipes/cookbook/templates/meal_plan.html
2020-06-02 22:52:28 +02:00

162 lines
4.9 KiB
HTML

{% extends "base.html" %}
{% load i18n %}
{% load static %}
{% block title %}{% trans 'Meal-Plan' %}{% endblock %}
{% block extra_head %}
{{ form.media }}
<script src="{% static 'js/vue.min.js' %}"></script>
<script src="{% static 'js/vue-resource.js' %}"></script>
<script src="{% static 'js/moment-with-locales.min.js' %}"></script>
<!-- CDNJS :: Sortable (https://cdnjs.com/) -->
<script src="//cdn.jsdelivr.net/npm/sortablejs@1.8.4/Sortable.min.js"></script>
<!-- CDNJS :: Vue.Draggable (https://cdnjs.com/) -->
<script src="//cdnjs.cloudflare.com/ajax/libs/Vue.Draggable/2.20.0/vuedraggable.umd.min.js"></script>
{% endblock %}
{% block content %}
<style>
.mealplan-cell .mealplan-add-button {
text-align: center;
display: block;
}
@media (hover: hover) {
.mealplan-cell .mealplan-add-button {
visibility: hidden;
float: right;
display: inline;
}
.mealplan-cell:hover .mealplan-add-button {
visibility: initial;
}
}
</style>
<h3>
{% trans 'Meal-Plan' %} <a href="{% url 'new_meal_plan' %}"><i class="fas fa-plus-circle"></i></a>
</h3>
<div id="app">
<table class="table">
<thead>
<tr>
<td v-for="d in days">[[d]]</td>
</tr>
</thead>
<tbody>
<tr v-for="t in meal_types">
<td>[[t]]</td>
</tr>
</tbody>
</table>
[[plan_entries]]
<h1>drag n drop</h1>
<div class="row">
<div class="col-3">
<h3>Draggable 1</h3>
<draggable class="list-group" :list="plan_entries" group="people" @change="log">
<div
class="list-group-item"
v-for="(element, index) in plan_entries"
:key="element.title"
>
[[element]]
</div>
</draggable>
</div>
<div class="col-3">
<h3>Draggable 2</h3>
<draggable class="list-group" :list="meal_types" group="people" @change="log">
<div
class="list-group-item"
v-for="(element, index) in meal_types"
:key="element.name"
>
[[element]]
</div>
</draggable>
</div>
<div class="col-3">
<h3>Draggable 2</h3>
<draggable class="list-group" :list="list3" group="people" @change="log">
<div
class="list-group-item"
v-for="(element, index) in list3"
:key="element.name"
>
[[element]]
</div>
</draggable>
</div>
</div>
</div>
<script type="application/javascript">
var week = moment().format('W')
moment.locale('{{request.LANGUAGE_CODE}}');
var app = new Vue({
delimiters: ['[[', ']]'],
el: '#app',
data: {
days: moment.weekdays(),
plan_entries: [],
meal_types: [],
list3: [],
meal_plan: null,
},
mounted: function () {
this.getPlanEntries();
this.getPlanTypes();
},
methods: {
getPlanEntries: function () {
this.loading = true;
this.$http.get("{% url 'api:mealplan-list' %}?week=" + week).then((response) => {
this.plan_entries = response.data;
this.loading = false;
})
.catch((err) => {
this.loading = false;
console.log(err);
})
},
getPlanTypes: function () {
this.loading = true;
this.$http.get("{% url 'api:mealtype-list' %}").then((response) => {
this.meal_types = response.data;
this.loading = false;
this.buildGrid();
})
.catch((err) => {
this.loading = false;
console.log(err);
})
},
buildGrid: function () {
},
log: function (evt) {
console.log(evt)
}
}
});
</script>
{% endblock %}