mirror of
https://github.com/TandoorRecipes/recipes.git
synced 2026-01-08 23:58:15 -05:00
188 lines
5.6 KiB
HTML
188 lines
5.6 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]]
|
|
|
|
|
|
</div>
|
|
|
|
<template>
|
|
<div class="row">
|
|
<div class="col-3">
|
|
<h3>Draggable 1</h3>
|
|
<draggable class="list-group" :list="list1" group="people" @change="log">
|
|
<div
|
|
class="list-group-item"
|
|
v-for="(element, index) in list1"
|
|
:key="element.name"
|
|
>
|
|
{{ element.name }} {{ index }}
|
|
</div>
|
|
</draggable>
|
|
</div>
|
|
|
|
<div class="col-3">
|
|
<h3>Draggable 2</h3>
|
|
<draggable class="list-group" :list="list2" group="people" @change="log">
|
|
<div
|
|
class="list-group-item"
|
|
v-for="(element, index) in list2"
|
|
:key="element.name"
|
|
>
|
|
{{ element.name }} {{ index }}
|
|
</div>
|
|
</draggable>
|
|
</div>
|
|
|
|
<rawDisplayer class="col-3" :value="list1" title="List 1"/>
|
|
|
|
<rawDisplayer class="col-3" :value="list2" title="List 2"/>
|
|
</div>
|
|
</template>
|
|
|
|
<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: []
|
|
},
|
|
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 () {
|
|
|
|
},
|
|
}
|
|
});
|
|
|
|
import draggable from 'vuedraggable';
|
|
|
|
export default {
|
|
name: "two-lists",
|
|
display: "Two Lists",
|
|
order: 1,
|
|
components: {
|
|
vuedraggable
|
|
},
|
|
data() {
|
|
return {
|
|
list1: [
|
|
{name: "John", id: 1},
|
|
{name: "Joao", id: 2},
|
|
{name: "Jean", id: 3},
|
|
{name: "Gerard", id: 4}
|
|
],
|
|
list2: [
|
|
{name: "Juan", id: 5},
|
|
{name: "Edgard", id: 6},
|
|
{name: "Johnson", id: 7}
|
|
]
|
|
};
|
|
},
|
|
methods: {
|
|
add: function () {
|
|
this.list.push({name: "Juan"});
|
|
},
|
|
replace: function () {
|
|
this.list = [{name: "Edgard"}];
|
|
},
|
|
clone: function (el) {
|
|
return {
|
|
name: el.name + " cloned"
|
|
};
|
|
},
|
|
log: function (evt) {
|
|
window.console.log(evt);
|
|
}
|
|
}
|
|
};
|
|
|
|
|
|
</script>
|
|
{% endblock %} |