3
0
Fork 0
mirror of https://github.com/nanoy42/coope synced 2024-12-25 00:13:46 +00:00

Merge branch 'product_autocomplete_manage' into dev

Close #20
This commit is contained in:
Yoann Pétri 2018-12-23 23:55:50 +01:00
commit db2c82cfe7
5 changed files with 41 additions and 22 deletions

View file

@ -55,6 +55,7 @@ class SearchMenuForm(forms.Form):
class GestionForm(forms.Form): class GestionForm(forms.Form):
client = forms.ModelChoiceField(queryset=User.objects.filter(is_active=True), required=True, label="Client", widget=autocomplete.ModelSelect2(url='users:active-users-autocomplete', attrs={'data-minimum-input-length':2})) client = forms.ModelChoiceField(queryset=User.objects.filter(is_active=True), required=True, label="Client", widget=autocomplete.ModelSelect2(url='users:active-users-autocomplete', attrs={'data-minimum-input-length':2}))
product = forms.ModelChoiceField(queryset=Product.objects.filter(is_active=True), required=True, label="Produit", widget=autocomplete.ModelSelect2(url='gestion:active-products-autocomplete', attrs={'data-minimum-input-length':2}))
class SelectPositiveKegForm(forms.Form): class SelectPositiveKegForm(forms.Form):
keg = forms.ModelChoiceField(queryset=Keg.objects.filter(stockHold__gt = 0), required=True, label="Fût", widget=autocomplete.ModelSelect2(url='gestion:kegs-positive-autocomplete')) keg = forms.ModelChoiceField(queryset=Keg.objects.filter(stockHold__gt = 0), required=True, label="Fût", widget=autocomplete.ModelSelect2(url='gestion:kegs-positive-autocomplete'))

View file

@ -99,7 +99,7 @@
{% if forloop.counter0|divisibleby:4 %} {% if forloop.counter0|divisibleby:4 %}
<tr style="text-align:center"> <tr style="text-align:center">
{% endif %} {% endif %}
<td><button class="product {% if product.adherentRequired %}special{% endif%}" target="{{product.barcode}}">{{product.name}}</button></td> <td><button class="product {% if product.adherentRequired %}special{% endif%}" target="{{product.pk}}">{{product.name}}</button></td>
{% if forloop.counter|divisibleby:4 %} {% if forloop.counter|divisibleby:4 %}
</tr> </tr>
{% endif %} {% endif %}
@ -112,7 +112,7 @@
{% if forloop.counter0|divisibleby:4 %} {% if forloop.counter0|divisibleby:4 %}
<tr style="text-align:center"> <tr style="text-align:center">
{% endif %} {% endif %}
<td><button class="product {% if product.adherentRequired %}special{% endif%}" target="{{product.barcode}}">{{product.name}}</button></td> <td><button class="product {% if product.adherentRequired %}special{% endif%}" target="{{product.pk}}">{{product.name}}</button></td>
{% if forloop.counter|divisibleby:4 %} {% if forloop.counter|divisibleby:4 %}
</tr> </tr>
{% endif %} {% endif %}
@ -125,7 +125,7 @@
{% if forloop.counter0|divisibleby:4 %} {% if forloop.counter0|divisibleby:4 %}
<tr style="text-align:center"> <tr style="text-align:center">
{% endif %} {% endif %}
<td><button class="product {% if product.adherentRequired %}special{% endif%}" target="{{product.barcode}}">{{product.name}}</button></td> <td><button class="product {% if product.adherentRequired %}special{% endif%}" target="{{product.pk}}">{{product.name}}</button></td>
{% if forloop.counter|divisibleby:4 %} {% if forloop.counter|divisibleby:4 %}
</tr> </tr>
{% endif %} {% endif %}
@ -138,7 +138,7 @@
{% if forloop.counter0|divisibleby:4 %} {% if forloop.counter0|divisibleby:4 %}
<tr style="text-align:center"> <tr style="text-align:center">
{% endif %} {% endif %}
<td><button class="product {% if product.adherentRequired %}special{% endif%}" target="{{product.barcode}}">{{product.name}}</button></td> <td><button class="product {% if product.adherentRequired %}special{% endif%}" target="{{product.pk}}">{{product.name}}</button></td>
{% if forloop.counter|divisibleby:4 %} {% if forloop.counter|divisibleby:4 %}
</tr> </tr>
{% endif %} {% endif %}
@ -152,7 +152,7 @@
{% if forloop.counter0|divisibleby:4 %} {% if forloop.counter0|divisibleby:4 %}
<tr style="text-align:center"> <tr style="text-align:center">
{% endif %} {% endif %}
<td><button class="product {% if product.adherentRequired %}special{% endif%}" target="{{product.barcode}}">{{product.name}}</button></td> <td><button class="product {% if product.adherentRequired %}special{% endif%}" target="{{product.pk}}">{{product.name}}</button></td>
{% if forloop.counter|divisibleby:4 %} {% if forloop.counter|divisibleby:4 %}
</tr> </tr>
{% endif %} {% endif %}
@ -166,7 +166,7 @@
{% if forloop.counter0|divisibleby:4 %} {% if forloop.counter0|divisibleby:4 %}
<tr style="text-align:center"> <tr style="text-align:center">
{% endif %} {% endif %}
<td><button class="menu {% if product.adherent_required %}special{% endif%}" target="{{product.barcode}}">{{product.name}}</button></td> <td><button class="menu {% if product.adherent_required %}special{% endif%}" target="{{product.pk}}">{{product.name}}</button></td>
{% if forloop.counter|divisibleby:4 %} {% if forloop.counter|divisibleby:4 %}
</tr> </tr>
{% endif %} {% endif %}

View file

@ -24,9 +24,9 @@ urlpatterns = [
path('searchMenu', views.searchMenu, name="searchMenu"), path('searchMenu', views.searchMenu, name="searchMenu"),
path('editMenu/<int:pk>', views.edit_menu, name="editMenu"), path('editMenu/<int:pk>', views.edit_menu, name="editMenu"),
path('menusList', views.menus_list, name="menusList"), path('menusList', views.menus_list, name="menusList"),
path('getMenu/<str:barcode>', views.get_menu, name="getMenu"), path('getMenu/<int:pk>', views.get_menu, name="getMenu"),
path('swicthActivateMenu/<int:pk>', views.switch_activate_menu, name="switchActivateMenu"), path('swicthActivateMenu/<int:pk>', views.switch_activate_menu, name="switchActivateMenu"),
path('getProduct/<str:barcode>', views.getProduct, name="getProduct"), path('getProduct/<int:pk>', views.getProduct, name="getProduct"),
path('order', views.order, name="order"), path('order', views.order, name="order"),
path('ranking', views.ranking, name="ranking"), path('ranking', views.ranking, name="ranking"),
path('searchProduct', views.searchProduct, name="searchProduct"), path('searchProduct', views.searchProduct, name="searchProduct"),
@ -39,6 +39,7 @@ urlpatterns = [
path('release/<int:pinte_pk>', views.release, name="release"), path('release/<int:pinte_pk>', views.release, name="release"),
path('pintesUserList', views.pintes_user_list, name="pintesUserList"), path('pintesUserList', views.pintes_user_list, name="pintesUserList"),
path('products-autocomplete', views.ProductsAutocomplete.as_view(), name="products-autocomplete"), path('products-autocomplete', views.ProductsAutocomplete.as_view(), name="products-autocomplete"),
path('active-products-autocomplete', views.ActiveProductsAutocomplete.as_view(), name="active-products-autocomplete"),
path('kegs-positive-autocomplete', views.KegPositiveAutocomplete.as_view(), name="kegs-positive-autocomplete"), path('kegs-positive-autocomplete', views.KegPositiveAutocomplete.as_view(), name="kegs-positive-autocomplete"),
path('kegs-active-autocomplete', views.KegActiveAutocomplete.as_view(), name="kegs-active-autocomplete"), path('kegs-active-autocomplete', views.KegActiveAutocomplete.as_view(), name="kegs-active-autocomplete"),
path('menus-autcomplete', views.MenusAutocomplete.as_view(), name="menus-autocomplete"), path('menus-autcomplete', views.MenusAutocomplete.as_view(), name="menus-autocomplete"),

View file

@ -420,14 +420,14 @@ def productProfile(request, pk):
@active_required @active_required
@login_required @login_required
def getProduct(request, barcode): def getProduct(request, pk):
""" """
Get :model:`gestion.Product` by barcode. Called by a js/JQuery script Get :model:`gestion.Product` by barcode. Called by a js/JQuery script
``barcode`` ``pk``
The requested barcode The requested pk
""" """
product = Product.objects.get(barcode=barcode) product = Product.objects.get(pk=pk)
if product.category == Product.P_PRESSION: if product.category == Product.P_PRESSION:
nb_pintes = 1 nb_pintes = 1
else: else:
@ -461,6 +461,16 @@ class ProductsAutocomplete(autocomplete.Select2QuerySetView):
qs = qs.filter(name__istartswith=self.q) qs = qs.filter(name__istartswith=self.q)
return qs return qs
class ActiveProductsAutocomplete(autocomplete.Select2QuerySetView):
"""
Autocomplete view for active :model:`gestion.Product`
"""
def get_queryset(self):
qs = Product.objects.filter(is_active=True)
if self.q:
qs = qs.filter(name__istartswith=self.q)
return qs
########## Kegs ########## ########## Kegs ##########
@active_required @active_required
@ -851,14 +861,14 @@ def switch_activate_menu(request, pk):
@active_required @active_required
@login_required @login_required
@permission_required('gestion.view_menu') @permission_required('gestion.view_menu')
def get_menu(request, barcode): def get_menu(request, pk):
""" """
Search :model:`gestion.Menu` by barcode Search :model:`gestion.Menu` by barcode
``barcode`` ``pk``
The requested barcode The requested pk
""" """
menu = get_object_or_404(Menu, barcode=barcode) menu = get_object_or_404(Menu, pk=pk)
nb_pintes = 0 nb_pintes = 0
for article in menu.articles: for article in menu.articles:
if article.category == Product.P_PRESSION: if article.category == Product.P_PRESSION:

View file

@ -11,20 +11,19 @@ use_pinte_monitoring = false;
function get_config(){ function get_config(){
res = $.get("../preferences/getConfig", function(data){ res = $.get("../preferences/getConfig", function(data){
console.log(data.use_pinte_monitoring)
use_pinte_monitoring = data.use_pinte_monitoring; use_pinte_monitoring = data.use_pinte_monitoring;
}); });
} }
function get_product(barcode){ function get_product(id){
res = $.get("getProduct/" + barcode, function(data){ res = $.get("getProduct/" + id, function(data){
nbPintes += data.nb_pintes; nbPintes += data.nb_pintes;
add_product(data.pk, data.barcode, data.name, data.amount, data.needQuantityButton); add_product(data.pk, data.barcode, data.name, data.amount, data.needQuantityButton);
}); });
} }
function get_menu(barcode){ function get_menu(id){
res = $.get("getMenu/" + barcode, function(data){ res = $.get("getMenu/" + id, function(data){
nbPintes += data.nb_pintes; nbPintes += data.nb_pintes;
add_menu(data.pk, data.barcode, data.name, data.amount, data.needQuantityButton); add_menu(data.pk, data.barcode, data.name, data.amount, data.needQuantityButton);
}); });
@ -115,12 +114,15 @@ function updateMenuInput(a){
$(document).ready(function(){ $(document).ready(function(){
get_config(); get_config();
$(".product").click(function(){ $(".product").click(function(){
product = get_product($(this).attr('target')); product = get_product($(this).attr('target'));
}); });
$(".menu").click(function(){ $(".menu").click(function(){
menu = get_menu($(this).attr('target')); menu = get_menu($(this).attr('target'));
}) });
$("#id_client").on('change', function(){ $("#id_client").on('change', function(){
id = $("#id_client").val(); id = $("#id_client").val();
$.get("/users/getUser/" + id, function(data){ $.get("/users/getUser/" + id, function(data){
@ -133,6 +135,11 @@ $(document).ready(function(){
window.location.reload() window.location.reload()
}); });
}); });
$("#id_product").on('change', function(){
product = get_product(parseInt($("#id_product").val()));
});
$(".pay_button").click(function(){ $(".pay_button").click(function(){
if(use_pinte_monitoring){ if(use_pinte_monitoring){
message = "Il reste " + nbPintes.toString() + " pintes à renseigner. Numéro de la pinte ?" message = "Il reste " + nbPintes.toString() + " pintes à renseigner. Numéro de la pinte ?"