mirror of
https://github.com/grocy/grocy.git
synced 2025-04-29 17:45:39 +00:00
Modularize product picker
This commit is contained in:
parent
aa0771877f
commit
71fc49252f
155
public/viewjs/components/productpicker.js
Normal file
155
public/viewjs/components/productpicker.js
Normal file
@ -0,0 +1,155 @@
|
|||||||
|
Grocy.Components.ProductPicker = { };
|
||||||
|
|
||||||
|
Grocy.Components.ProductPicker.GetPicker = function ()
|
||||||
|
{
|
||||||
|
return $('#product_id');
|
||||||
|
}
|
||||||
|
|
||||||
|
Grocy.Components.ProductPicker.GetInputElement = function()
|
||||||
|
{
|
||||||
|
return $('#product_id_text_input');
|
||||||
|
}
|
||||||
|
|
||||||
|
Grocy.Components.ProductPicker.GetValue = function()
|
||||||
|
{
|
||||||
|
return $('#product_id').val();
|
||||||
|
}
|
||||||
|
|
||||||
|
Grocy.Components.ProductPicker.SetValue = function(value)
|
||||||
|
{
|
||||||
|
Grocy.Components.ProductPicker.GetInputElement().val(value);
|
||||||
|
Grocy.Components.ProductPicker.GetInputElement().trigger('change');
|
||||||
|
}
|
||||||
|
|
||||||
|
Grocy.Components.ProductPicker.InProductAddWorkflow = function()
|
||||||
|
{
|
||||||
|
return typeof GetUriParam('createdproduct') !== "undefined";
|
||||||
|
}
|
||||||
|
|
||||||
|
Grocy.Components.ProductPicker.InProductModifyWorkflow = function()
|
||||||
|
{
|
||||||
|
return typeof GetUriParam('addbarcodetoselection') !== "undefined";
|
||||||
|
}
|
||||||
|
|
||||||
|
Grocy.Components.ProductPicker.ShowCustomError = function(text)
|
||||||
|
{
|
||||||
|
var element = $("#custom-productpicker-error");
|
||||||
|
element.text(text);
|
||||||
|
element.removeClass("d-none");
|
||||||
|
}
|
||||||
|
|
||||||
|
Grocy.Components.ProductPicker.HideCustomError = function()
|
||||||
|
{
|
||||||
|
$("#custom-productpicker-error").addClass("d-none");
|
||||||
|
}
|
||||||
|
|
||||||
|
$('.combobox').combobox({
|
||||||
|
appendId: '_text_input',
|
||||||
|
bsVersion: '4'
|
||||||
|
});
|
||||||
|
|
||||||
|
var prefillProduct = GetUriParam('createdproduct');
|
||||||
|
if (typeof prefillProduct !== "undefined")
|
||||||
|
{
|
||||||
|
var possibleOptionElement = $("#product_id option[data-additional-searchdata*='" + prefillProduct + "']").first();
|
||||||
|
if (possibleOptionElement.length === 0)
|
||||||
|
{
|
||||||
|
possibleOptionElement = $("#product_id option:contains('" + prefillProduct + "')").first();
|
||||||
|
}
|
||||||
|
|
||||||
|
if (possibleOptionElement.length > 0)
|
||||||
|
{
|
||||||
|
$('#product_id').val(possibleOptionElement.val());
|
||||||
|
$('#product_id').data('combobox').refresh();
|
||||||
|
$('#product_id').trigger('change');
|
||||||
|
|
||||||
|
var nextInputElement = $(Grocy.Components.ProductPicker.GetPicker().parent().data('next-input-selector').toString());
|
||||||
|
nextInputElement.focus();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
var addBarcode = GetUriParam('addbarcodetoselection');
|
||||||
|
if (addBarcode !== undefined)
|
||||||
|
{
|
||||||
|
$('#addbarcodetoselection').text(addBarcode);
|
||||||
|
$('#flow-info-addbarcodetoselection').removeClass('d-none');
|
||||||
|
$('#barcode-lookup-disabled-hint').removeClass('d-none');
|
||||||
|
}
|
||||||
|
|
||||||
|
$('#product_id_text_input').on('change', function(e)
|
||||||
|
{
|
||||||
|
var input = $('#product_id_text_input').val().toString();
|
||||||
|
var possibleOptionElement = $("#product_id option[data-additional-searchdata*='" + input + "']").first();
|
||||||
|
|
||||||
|
if (GetUriParam('addbarcodetoselection') === undefined && possibleOptionElement.length > 0)
|
||||||
|
{
|
||||||
|
$('#product_id').val(possibleOptionElement.val());
|
||||||
|
$('#product_id').data('combobox').refresh();
|
||||||
|
$('#product_id').trigger('change');
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
var optionElement = $("#product_id option:contains('" + input + "')").first();
|
||||||
|
if (input.length > 0 && optionElement.length === 0 && typeof GetUriParam('addbarcodetoselection') === "undefined")
|
||||||
|
{
|
||||||
|
var addProductWorkflowsAdditionalCssClasses = "";
|
||||||
|
if (Grocy.Components.ProductPicker.GetPicker().parent().data('disallow-add-product-workflows').toString() === "true")
|
||||||
|
{
|
||||||
|
addProductWorkflowsAdditionalCssClasses = "d-none";
|
||||||
|
}
|
||||||
|
|
||||||
|
bootbox.dialog({
|
||||||
|
message: L('"#1" could not be resolved to a product, how do you want to proceed?', input),
|
||||||
|
title: L('Create or assign product'),
|
||||||
|
onEscape: function() { },
|
||||||
|
size: 'large',
|
||||||
|
backdrop: true,
|
||||||
|
buttons: {
|
||||||
|
cancel: {
|
||||||
|
label: 'Cancel',
|
||||||
|
className: 'btn-default responsive-button',
|
||||||
|
callback: function() { }
|
||||||
|
},
|
||||||
|
addnewproduct: {
|
||||||
|
label: '<strong>P</strong> ' + L('Add as new product'),
|
||||||
|
className: 'btn-success add-new-product-dialog-button responsive-button ' + addProductWorkflowsAdditionalCssClasses,
|
||||||
|
callback: function()
|
||||||
|
{
|
||||||
|
window.location.href = U('/product/new?prefillname=' + encodeURIComponent(input) + '&returnto=' + encodeURIComponent(window.location.pathname));
|
||||||
|
}
|
||||||
|
},
|
||||||
|
addbarcode: {
|
||||||
|
label: '<strong>B</strong> ' + L('Add as barcode to existing product'),
|
||||||
|
className: 'btn-info add-new-barcode-dialog-button responsive-button',
|
||||||
|
callback: function()
|
||||||
|
{
|
||||||
|
window.location.href = U(window.location.pathname + '?addbarcodetoselection=' + encodeURIComponent(input));
|
||||||
|
}
|
||||||
|
},
|
||||||
|
addnewproductwithbarcode: {
|
||||||
|
label: '<strong>A</strong> ' + L('Add as new product and prefill barcode'),
|
||||||
|
className: 'btn-warning add-new-product-with-barcode-dialog-button responsive-button ' + addProductWorkflowsAdditionalCssClasses,
|
||||||
|
callback: function()
|
||||||
|
{
|
||||||
|
window.location.href = U('/product/new?prefillbarcode=' + encodeURIComponent(input) + '&returnto=' + encodeURIComponent(window.location.pathname));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}).on('keypress', function(e)
|
||||||
|
{
|
||||||
|
if (e.key === 'B' || e.key === 'b')
|
||||||
|
{
|
||||||
|
$('.add-new-barcode-dialog-button').not(".d-none").click();
|
||||||
|
}
|
||||||
|
if (e.key === 'p' || e.key === 'P')
|
||||||
|
{
|
||||||
|
$('.add-new-product-dialog-button').not(".d-none").click();
|
||||||
|
}
|
||||||
|
if (e.key === 'a' || e.key === 'A')
|
||||||
|
{
|
||||||
|
$('.add-new-product-with-barcode-dialog-button').not(".d-none").click();
|
||||||
|
}
|
||||||
|
});
|
||||||
|
}
|
||||||
|
}
|
||||||
|
});
|
@ -19,10 +19,8 @@
|
|||||||
toastr.success(L('Removed #1 #2 of #3 from stock', jsonForm.amount, productDetails.quantity_unit_stock.name, productDetails.product.name));
|
toastr.success(L('Removed #1 #2 of #3 from stock', jsonForm.amount, productDetails.quantity_unit_stock.name, productDetails.product.name));
|
||||||
|
|
||||||
$('#amount').val(1);
|
$('#amount').val(1);
|
||||||
$('#product_id').val('');
|
Grocy.Components.ProductPicker.SetValue('');
|
||||||
$('#product_id_text_input').focus();
|
Grocy.Components.ProductPicker.GetInputElement().focus();
|
||||||
$('#product_id_text_input').val('');
|
|
||||||
$('#product_id_text_input').trigger('change');
|
|
||||||
Grocy.FrontendHelpers.ValidateForm('consume-form');
|
Grocy.FrontendHelpers.ValidateForm('consume-form');
|
||||||
},
|
},
|
||||||
function(xhr)
|
function(xhr)
|
||||||
@ -38,7 +36,7 @@
|
|||||||
);
|
);
|
||||||
});
|
});
|
||||||
|
|
||||||
$('#product_id').on('change', function(e)
|
Grocy.Components.ProductPicker.GetPicker().on('change', function(e)
|
||||||
{
|
{
|
||||||
var productId = $(e.target).val();
|
var productId = $(e.target).val();
|
||||||
|
|
||||||
@ -54,14 +52,14 @@ $('#product_id').on('change', function(e)
|
|||||||
|
|
||||||
if ((productDetails.stock_amount || 0) === 0)
|
if ((productDetails.stock_amount || 0) === 0)
|
||||||
{
|
{
|
||||||
$('#product_id').val('');
|
Grocy.Components.ProductPicker.SetValue('');
|
||||||
$('#product_id_text_input').val('');
|
|
||||||
Grocy.FrontendHelpers.ValidateForm('consume-form');
|
Grocy.FrontendHelpers.ValidateForm('consume-form');
|
||||||
$('#product-error').text(L('This product is not in stock'));
|
Grocy.Components.ProductPicker.ShowCustomError(L('This product is not in stock'));
|
||||||
$('#product_id_text_input').focus();
|
Grocy.Components.ProductPicker.GetInputElement().focus();
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
|
Grocy.Components.ProductPicker.HideCustomError();
|
||||||
Grocy.FrontendHelpers.ValidateForm('consume-form');
|
Grocy.FrontendHelpers.ValidateForm('consume-form');
|
||||||
$('#amount').focus();
|
$('#amount').focus();
|
||||||
}
|
}
|
||||||
@ -74,28 +72,8 @@ $('#product_id').on('change', function(e)
|
|||||||
}
|
}
|
||||||
});
|
});
|
||||||
|
|
||||||
$('.combobox').combobox({
|
|
||||||
appendId: '_text_input'
|
|
||||||
});
|
|
||||||
|
|
||||||
$('#product_id_text_input').on('change', function(e)
|
|
||||||
{
|
|
||||||
var input = $('#product_id_text_input').val().toString();
|
|
||||||
var possibleOptionElement = $("#product_id option[data-additional-searchdata*='" + input + "']").first();
|
|
||||||
|
|
||||||
if (possibleOptionElement.length > 0)
|
|
||||||
{
|
|
||||||
$('#product_id').val(possibleOptionElement.val());
|
|
||||||
$('#product_id').data('combobox').refresh();
|
|
||||||
$('#product_id').trigger('change');
|
|
||||||
}
|
|
||||||
});
|
|
||||||
|
|
||||||
$('#amount').val(1);
|
$('#amount').val(1);
|
||||||
$('#product_id').val('');
|
Grocy.Components.ProductPicker.GetInputElement().focus();
|
||||||
$('#product_id_text_input').focus();
|
|
||||||
$('#product_id_text_input').val('');
|
|
||||||
$('#product_id_text_input').trigger('change');
|
|
||||||
Grocy.FrontendHelpers.ValidateForm('consume-form');
|
Grocy.FrontendHelpers.ValidateForm('consume-form');
|
||||||
|
|
||||||
$('#amount').on('focus', function(e)
|
$('#amount').on('focus', function(e)
|
||||||
|
@ -43,10 +43,8 @@
|
|||||||
$('#inventory-change-info').addClass('d-none');
|
$('#inventory-change-info').addClass('d-none');
|
||||||
$('#new_amount').val('');
|
$('#new_amount').val('');
|
||||||
Grocy.Components.DateTimePicker.SetValue('');
|
Grocy.Components.DateTimePicker.SetValue('');
|
||||||
$('#product_id').val('');
|
Grocy.Components.ProductPicker.SetValue('');
|
||||||
$('#product_id_text_input').focus();
|
Grocy.Components.ProductPicker.GetInputElement().focus();
|
||||||
$('#product_id_text_input').val('');
|
|
||||||
$('#product_id_text_input').trigger('change');
|
|
||||||
Grocy.FrontendHelpers.ValidateForm('inventory-form');
|
Grocy.FrontendHelpers.ValidateForm('inventory-form');
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
@ -63,7 +61,7 @@
|
|||||||
);
|
);
|
||||||
});
|
});
|
||||||
|
|
||||||
$('#product_id').on('change', function(e)
|
Grocy.Components.ProductPicker.GetPicker().on('change', function(e)
|
||||||
{
|
{
|
||||||
var productId = $(e.target).val();
|
var productId = $(e.target).val();
|
||||||
|
|
||||||
@ -87,94 +85,23 @@ $('#product_id').on('change', function(e)
|
|||||||
}
|
}
|
||||||
});
|
});
|
||||||
|
|
||||||
$('.combobox').combobox({
|
|
||||||
appendId: '_text_input'
|
|
||||||
});
|
|
||||||
|
|
||||||
$('#product_id_text_input').on('change', function(e)
|
|
||||||
{
|
|
||||||
var input = $('#product_id_text_input').val().toString();
|
|
||||||
var possibleOptionElement = $("#product_id option[data-additional-searchdata*='" + input + "']").first();
|
|
||||||
|
|
||||||
if (GetUriParam('addbarcodetoselection') === undefined && possibleOptionElement.length > 0)
|
|
||||||
{
|
|
||||||
$('#product_id').val(possibleOptionElement.val());
|
|
||||||
$('#product_id').data('combobox').refresh();
|
|
||||||
$('#product_id').trigger('change');
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
var optionElement = $("#product_id option:contains('" + input + "')").first();
|
|
||||||
if (input.length > 0 && optionElement.length === 0 && GetUriParam('addbarcodetoselection') === undefined )
|
|
||||||
{
|
|
||||||
bootbox.dialog({
|
|
||||||
message: L('#1 could not be resolved to a product, how do you want to proceed?', input),
|
|
||||||
title: L('Create or assign product'),
|
|
||||||
onEscape: function() { },
|
|
||||||
size: 'large',
|
|
||||||
backdrop: true,
|
|
||||||
buttons: {
|
|
||||||
cancel: {
|
|
||||||
label: L('Cancel'),
|
|
||||||
className: 'btn-default',
|
|
||||||
callback: function() { }
|
|
||||||
},
|
|
||||||
addnewproduct: {
|
|
||||||
label: '<strong>P</strong> ' + L('Add as new product'),
|
|
||||||
className: 'btn-success add-new-product-dialog-button',
|
|
||||||
callback: function()
|
|
||||||
{
|
|
||||||
window.location.href = U('/product/new?prefillname=' + encodeURIComponent(input) + '&returnto=' + encodeURIComponent(window.location.pathname));
|
|
||||||
}
|
|
||||||
},
|
|
||||||
addbarcode: {
|
|
||||||
label: '<strong>B</strong> ' + L('Add as barcode to existing product'),
|
|
||||||
className: 'btn-info add-new-barcode-dialog-button',
|
|
||||||
callback: function()
|
|
||||||
{
|
|
||||||
window.location.href = U('/inventory?addbarcodetoselection=' + encodeURIComponent(input));
|
|
||||||
}
|
|
||||||
},
|
|
||||||
addnewproductwithbarcode: {
|
|
||||||
label: '<strong>A</strong> ' + L('Add as new product and prefill barcode'),
|
|
||||||
className: 'btn-warning add-new-product-with-barcode-dialog-button',
|
|
||||||
callback: function()
|
|
||||||
{
|
|
||||||
window.location.href = U('/product/new?prefillbarcode=' + encodeURIComponent(input) + '&returnto=' + encodeURIComponent(window.location.pathname));
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}).on('keypress', function(e)
|
|
||||||
{
|
|
||||||
if (e.key === 'B' || e.key === 'b')
|
|
||||||
{
|
|
||||||
$('.add-new-barcode-dialog-button').click();
|
|
||||||
}
|
|
||||||
if (e.key === 'p' || e.key === 'P')
|
|
||||||
{
|
|
||||||
$('.add-new-product-dialog-button').click();
|
|
||||||
}
|
|
||||||
if (e.key === 'a' || e.key === 'A')
|
|
||||||
{
|
|
||||||
$('.add-new-product-with-barcode-dialog-button').click();
|
|
||||||
}
|
|
||||||
});
|
|
||||||
}
|
|
||||||
}
|
|
||||||
});
|
|
||||||
|
|
||||||
$('#new_amount').val('');
|
$('#new_amount').val('');
|
||||||
$('#product_id').val('');
|
|
||||||
$('#product_id_text_input').focus();
|
|
||||||
$('#product_id_text_input').val('');
|
|
||||||
$('#product_id_text_input').trigger('change');
|
|
||||||
Grocy.FrontendHelpers.ValidateForm('inventory-form');
|
Grocy.FrontendHelpers.ValidateForm('inventory-form');
|
||||||
|
|
||||||
|
if (Grocy.Components.ProductPicker.InProductAddWorkflow() === false)
|
||||||
|
{
|
||||||
|
Grocy.Components.ProductPicker.GetInputElement().focus();
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
Grocy.Components.ProductPicker.GetPicker().trigger('change');
|
||||||
|
}
|
||||||
|
|
||||||
$('#new_amount').on('focus', function(e)
|
$('#new_amount').on('focus', function(e)
|
||||||
{
|
{
|
||||||
if ($('#product_id_text_input').val().length === 0)
|
if (Grocy.Components.ProductPicker.GetValue().length === 0)
|
||||||
{
|
{
|
||||||
$('#product_id_text_input').focus();
|
Grocy.Components.ProductPicker.GetInputElement().focus();
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
@ -203,32 +130,6 @@ $('#inventory-form input').keydown(function(event)
|
|||||||
}
|
}
|
||||||
});
|
});
|
||||||
|
|
||||||
var prefillProduct = GetUriParam('createdproduct');
|
|
||||||
if (prefillProduct !== undefined)
|
|
||||||
{
|
|
||||||
var possibleOptionElement = $("#product_id option[data-additional-searchdata*='" + prefillProduct + "']").first();
|
|
||||||
if (possibleOptionElement.length === 0)
|
|
||||||
{
|
|
||||||
possibleOptionElement = $("#product_id option:contains('" + prefillProduct + "')").first();
|
|
||||||
}
|
|
||||||
|
|
||||||
if (possibleOptionElement.length > 0)
|
|
||||||
{
|
|
||||||
$('#product_id').val(possibleOptionElement.val());
|
|
||||||
$('#product_id').data('combobox').refresh();
|
|
||||||
$('#product_id').trigger('change');
|
|
||||||
$('#new_amount').focus();
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
var addBarcode = GetUriParam('addbarcodetoselection');
|
|
||||||
if (addBarcode !== undefined)
|
|
||||||
{
|
|
||||||
$('#addbarcodetoselection').text(addBarcode);
|
|
||||||
$('#flow-info-addbarcodetoselection').removeClass('d-none');
|
|
||||||
$('#barcode-lookup-disabled-hint').removeClass('d-none');
|
|
||||||
}
|
|
||||||
|
|
||||||
$('#new_amount').on('keypress', function(e)
|
$('#new_amount').on('keypress', function(e)
|
||||||
{
|
{
|
||||||
$('#new_amount').trigger('change');
|
$('#new_amount').trigger('change');
|
||||||
@ -246,7 +147,7 @@ Grocy.Components.DateTimePicker.GetInputElement().on('keypress', function(e)
|
|||||||
|
|
||||||
$('#new_amount').on('keyup', function(e)
|
$('#new_amount').on('keyup', function(e)
|
||||||
{
|
{
|
||||||
var productId = $('#product_id').val();
|
var productId = Grocy.Components.ProductPicker.GetValue();
|
||||||
var newAmount = parseInt($('#new_amount').val());
|
var newAmount = parseInt($('#new_amount').val());
|
||||||
|
|
||||||
if (productId)
|
if (productId)
|
||||||
|
@ -44,10 +44,8 @@
|
|||||||
{
|
{
|
||||||
$('#amount').val(0);
|
$('#amount').val(0);
|
||||||
Grocy.Components.DateTimePicker.SetValue('');
|
Grocy.Components.DateTimePicker.SetValue('');
|
||||||
$('#product_id').val('');
|
Grocy.Components.ProductPicker.SetValue('');
|
||||||
$('#product_id_text_input').focus();
|
Grocy.Components.ProductPicker.GetInputElement().focus();
|
||||||
$('#product_id_text_input').val('');
|
|
||||||
$('#product_id_text_input').trigger('change');
|
|
||||||
Grocy.FrontendHelpers.ValidateForm('purchase-form');
|
Grocy.FrontendHelpers.ValidateForm('purchase-form');
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
@ -64,7 +62,7 @@
|
|||||||
);
|
);
|
||||||
});
|
});
|
||||||
|
|
||||||
$('#product_id').on('change', function(e)
|
Grocy.Components.ProductPicker.GetPicker().on('change', function(e)
|
||||||
{
|
{
|
||||||
var productId = $(e.target).val();
|
var productId = $(e.target).val();
|
||||||
|
|
||||||
@ -95,95 +93,23 @@ $('#product_id').on('change', function(e)
|
|||||||
}
|
}
|
||||||
});
|
});
|
||||||
|
|
||||||
$('.combobox').combobox({
|
|
||||||
appendId: '_text_input',
|
|
||||||
bsVersion: '4'
|
|
||||||
});
|
|
||||||
|
|
||||||
$('#product_id_text_input').on('change', function(e)
|
|
||||||
{
|
|
||||||
var input = $('#product_id_text_input').val().toString();
|
|
||||||
var possibleOptionElement = $("#product_id option[data-additional-searchdata*='" + input + "']").first();
|
|
||||||
|
|
||||||
if (GetUriParam('addbarcodetoselection') === undefined && possibleOptionElement.length > 0)
|
|
||||||
{
|
|
||||||
$('#product_id').val(possibleOptionElement.val());
|
|
||||||
$('#product_id').data('combobox').refresh();
|
|
||||||
$('#product_id').trigger('change');
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
var optionElement = $("#product_id option:contains('" + input + "')").first();
|
|
||||||
if (input.length > 0 && optionElement.length === 0 && GetUriParam('addbarcodetoselection') === undefined )
|
|
||||||
{
|
|
||||||
bootbox.dialog({
|
|
||||||
message: L('"#1" could not be resolved to a product, how do you want to proceed?', input),
|
|
||||||
title: L('Create or assign product'),
|
|
||||||
onEscape: function() { },
|
|
||||||
size: 'large',
|
|
||||||
backdrop: true,
|
|
||||||
buttons: {
|
|
||||||
cancel: {
|
|
||||||
label: 'Cancel',
|
|
||||||
className: 'btn-default',
|
|
||||||
callback: function() { }
|
|
||||||
},
|
|
||||||
addnewproduct: {
|
|
||||||
label: '<strong>P</strong> ' + L('Add as new product'),
|
|
||||||
className: 'btn-success add-new-product-dialog-button',
|
|
||||||
callback: function()
|
|
||||||
{
|
|
||||||
window.location.href = U('/product/new?prefillname=' + encodeURIComponent(input) + '&returnto=' + encodeURIComponent(window.location.pathname));
|
|
||||||
}
|
|
||||||
},
|
|
||||||
addbarcode: {
|
|
||||||
label: '<strong>B</strong> ' + L('Add as barcode to existing product'),
|
|
||||||
className: 'btn-info add-new-barcode-dialog-button',
|
|
||||||
callback: function()
|
|
||||||
{
|
|
||||||
window.location.href = U('/purchase?addbarcodetoselection=' + encodeURIComponent(input));
|
|
||||||
}
|
|
||||||
},
|
|
||||||
addnewproductwithbarcode: {
|
|
||||||
label: '<strong>A</strong> ' + L('Add as new product and prefill barcode'),
|
|
||||||
className: 'btn-warning add-new-product-with-barcode-dialog-button',
|
|
||||||
callback: function()
|
|
||||||
{
|
|
||||||
window.location.href = U('/product/new?prefillbarcode=' + encodeURIComponent(input) + '&returnto=' + encodeURIComponent(window.location.pathname));
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}).on('keypress', function(e)
|
|
||||||
{
|
|
||||||
if (e.key === 'B' || e.key === 'b')
|
|
||||||
{
|
|
||||||
$('.add-new-barcode-dialog-button').click();
|
|
||||||
}
|
|
||||||
if (e.key === 'p' || e.key === 'P')
|
|
||||||
{
|
|
||||||
$('.add-new-product-dialog-button').click();
|
|
||||||
}
|
|
||||||
if (e.key === 'a' || e.key === 'A')
|
|
||||||
{
|
|
||||||
$('.add-new-product-with-barcode-dialog-button').click();
|
|
||||||
}
|
|
||||||
});
|
|
||||||
}
|
|
||||||
}
|
|
||||||
});
|
|
||||||
|
|
||||||
$('#amount').val(0);
|
$('#amount').val(0);
|
||||||
$('#product_id').val('');
|
|
||||||
$('#product_id_text_input').focus();
|
|
||||||
$('#product_id_text_input').val('');
|
|
||||||
$('#product_id_text_input').trigger('change');
|
|
||||||
Grocy.FrontendHelpers.ValidateForm('purchase-form');
|
Grocy.FrontendHelpers.ValidateForm('purchase-form');
|
||||||
|
|
||||||
|
if (Grocy.Components.ProductPicker.InProductAddWorkflow() === false)
|
||||||
|
{
|
||||||
|
Grocy.Components.ProductPicker.GetInputElement().focus();
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
Grocy.Components.ProductPicker.GetPicker().trigger('change');
|
||||||
|
}
|
||||||
|
|
||||||
$('#amount').on('focus', function(e)
|
$('#amount').on('focus', function(e)
|
||||||
{
|
{
|
||||||
if ($('#product_id_text_input').val().length === 0)
|
if (Grocy.Components.ProductPicker.GetValue().length === 0)
|
||||||
{
|
{
|
||||||
$('#product_id_text_input').focus();
|
Grocy.Components.ProductPicker.GetInputElement().focus();
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
@ -212,32 +138,6 @@ $('#purchase-form input').keydown(function(event)
|
|||||||
}
|
}
|
||||||
});
|
});
|
||||||
|
|
||||||
var prefillProduct = GetUriParam('createdproduct');
|
|
||||||
if (prefillProduct !== undefined)
|
|
||||||
{
|
|
||||||
var possibleOptionElement = $("#product_id option[data-additional-searchdata*='" + prefillProduct + "']").first();
|
|
||||||
if (possibleOptionElement.length === 0)
|
|
||||||
{
|
|
||||||
possibleOptionElement = $("#product_id option:contains('" + prefillProduct + "')").first();
|
|
||||||
}
|
|
||||||
|
|
||||||
if (possibleOptionElement.length > 0)
|
|
||||||
{
|
|
||||||
$('#product_id').val(possibleOptionElement.val());
|
|
||||||
$('#product_id').data('combobox').refresh();
|
|
||||||
$('#product_id').trigger('change');
|
|
||||||
Grocy.Components.DateTimePicker.GetInputElement().focus();
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
var addBarcode = GetUriParam('addbarcodetoselection');
|
|
||||||
if (addBarcode !== undefined)
|
|
||||||
{
|
|
||||||
$('#addbarcodetoselection').text(addBarcode);
|
|
||||||
$('#flow-info-addbarcodetoselection').removeClass('d-none');
|
|
||||||
$('#barcode-lookup-disabled-hint').removeClass('d-none');
|
|
||||||
}
|
|
||||||
|
|
||||||
Grocy.Components.DateTimePicker.GetInputElement().on('change', function(e)
|
Grocy.Components.DateTimePicker.GetInputElement().on('change', function(e)
|
||||||
{
|
{
|
||||||
Grocy.FrontendHelpers.ValidateForm('purchase-form');
|
Grocy.FrontendHelpers.ValidateForm('purchase-form');
|
||||||
|
@ -30,7 +30,7 @@
|
|||||||
}
|
}
|
||||||
});
|
});
|
||||||
|
|
||||||
$('#product_id').on('change', function(e)
|
Grocy.Components.ProductPicker.GetPicker().on('change', function(e)
|
||||||
{
|
{
|
||||||
var productId = $(e.target).val();
|
var productId = $(e.target).val();
|
||||||
|
|
||||||
@ -52,39 +52,22 @@ $('#product_id').on('change', function(e)
|
|||||||
}
|
}
|
||||||
});
|
});
|
||||||
|
|
||||||
$('.combobox').combobox({
|
|
||||||
appendId: '_text_input'
|
|
||||||
});
|
|
||||||
|
|
||||||
$('#product_id_text_input').on('change', function(e)
|
|
||||||
{
|
|
||||||
var input = $('#product_id_text_input').val().toString();
|
|
||||||
var possibleOptionElement = $("#product_id option[data-additional-searchdata*='" + input + "']").first();
|
|
||||||
|
|
||||||
if (possibleOptionElement.length > 0 && possibleOptionElement.text().length > 0)
|
|
||||||
{
|
|
||||||
$('#product_id').val(possibleOptionElement.val());
|
|
||||||
$('#product_id').data('combobox').refresh();
|
|
||||||
$('#product_id').trigger('change');
|
|
||||||
}
|
|
||||||
});
|
|
||||||
|
|
||||||
$('#product_id_text_input').focus();
|
|
||||||
$('#product_id_text_input').trigger('change');
|
|
||||||
|
|
||||||
if (Grocy.EditMode === 'edit')
|
|
||||||
{
|
|
||||||
$('#product_id').addClass('suppress-next-custom-validate-event');
|
|
||||||
$('#product_id').trigger('change');
|
|
||||||
}
|
|
||||||
|
|
||||||
Grocy.FrontendHelpers.ValidateForm('shoppinglist-form');
|
Grocy.FrontendHelpers.ValidateForm('shoppinglist-form');
|
||||||
|
|
||||||
|
if (Grocy.Components.ProductPicker.InProductAddWorkflow() === false)
|
||||||
|
{
|
||||||
|
Grocy.Components.ProductPicker.GetInputElement().focus();
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
Grocy.Components.ProductPicker.GetPicker().trigger('change');
|
||||||
|
}
|
||||||
|
|
||||||
$('#amount').on('focus', function(e)
|
$('#amount').on('focus', function(e)
|
||||||
{
|
{
|
||||||
if ($('#product_id_text_input').val().length === 0)
|
if (Grocy.Components.ProductPicker.GetValue().length === 0)
|
||||||
{
|
{
|
||||||
$('#product_id_text_input').focus();
|
Grocy.Components.ProductPicker.GetInputElement().focus();
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
|
18
views/components/productpicker.blade.php
Normal file
18
views/components/productpicker.blade.php
Normal file
@ -0,0 +1,18 @@
|
|||||||
|
@push('componentScripts')
|
||||||
|
<script src="{{ $U('/viewjs/components/productpicker.js', true) }}?v={{ $version }}"></script>
|
||||||
|
@endpush
|
||||||
|
|
||||||
|
@php if(empty($disallowAddProductWorkflows)) { $disallowAddProductWorkflows = false; } @endphp
|
||||||
|
|
||||||
|
<div class="form-group" data-next-input-selector="{{ $nextInputSelector }}" data-disallow-add-product-workflows="{{ BoolToString($disallowAddProductWorkflows) }}">
|
||||||
|
<label for="product_id">{{ $L('Product') }} <i class="fas fa-barcode"></i><span id="barcode-lookup-disabled-hint" class="small text-muted d-none"> Barcode lookup is disabled</span></label>
|
||||||
|
<select class="form-control combobox" id="product_id" name="product_id" required>
|
||||||
|
<option value=""></option>
|
||||||
|
@foreach($products as $product)
|
||||||
|
<option data-additional-searchdata="{{ $product->barcode }}" value="{{ $product->id }}">{{ $product->name }}</option>
|
||||||
|
@endforeach
|
||||||
|
</select>
|
||||||
|
<div class="invalid-feedback">{{ $L('You have to select a product') }}</div>
|
||||||
|
<div id="custom-productpicker-error" class="form-text text-danger d-none"></div>
|
||||||
|
<div id="flow-info-addbarcodetoselection" class="form-text text-muted small d-none"><strong><span id="addbarcodetoselection"></span></strong> {{ $L('will be added to the list of barcodes for the selected product on submit') }}</div>
|
||||||
|
</div>
|
@ -11,16 +11,11 @@
|
|||||||
|
|
||||||
<form id="consume-form" novalidate>
|
<form id="consume-form" novalidate>
|
||||||
|
|
||||||
<div class="form-group">
|
@include('components.productpicker', array(
|
||||||
<label for="product_id">{{ $L('Product') }} <i class="fas fa-barcode"></i></label>
|
'products' => $products,
|
||||||
<select class="form-control combobox" id="product_id" name="product_id" required>
|
'nextInputSelector' => '#amount',
|
||||||
<option value=""></option>
|
'disallowAddProductWorkflows' => true
|
||||||
@foreach($products as $product)
|
))
|
||||||
<option data-additional-searchdata="{{ $product->barcode }}" value="{{ $product->id }}">{{ $product->name }}</option>
|
|
||||||
@endforeach
|
|
||||||
</select>
|
|
||||||
<div id="product-error" class="invalid-feedback">{{ $L('You have to select a product') }}</div>
|
|
||||||
</div>
|
|
||||||
|
|
||||||
<div class="form-group">
|
<div class="form-group">
|
||||||
<label for="amount">{{ $L('Amount') }} <span id="amount_qu_unit" class="small text-muted"></span></label>
|
<label for="amount">{{ $L('Amount') }} <span id="amount_qu_unit" class="small text-muted"></span></label>
|
||||||
|
@ -11,17 +11,10 @@
|
|||||||
|
|
||||||
<form id="inventory-form" novalidate>
|
<form id="inventory-form" novalidate>
|
||||||
|
|
||||||
<div class="form-group">
|
@include('components.productpicker', array(
|
||||||
<label for="product_id">{{ $L('Product') }} <i class="fas fa-barcode"></i><span id="barcode-lookup-disabled-hint" class="small text-muted d-none"> {{ $L('Barcode lookup is disabled') }}</span></label>
|
'products' => $products,
|
||||||
<select class="form-control combobox" id="product_id" name="product_id" required>
|
'nextInputSelector' => '#new_amount'
|
||||||
<option value=""></option>
|
))
|
||||||
@foreach($products as $product)
|
|
||||||
<option data-additional-searchdata="{{ $product->barcode }}" value="{{ $product->id }}">{{ $product->name }}</option>
|
|
||||||
@endforeach
|
|
||||||
</select>
|
|
||||||
<div class="invalid-feedback">{{ $L('You have to select a product') }}</div>
|
|
||||||
<div id="flow-info-addbarcodetoselection" class="form-text text-muted small d-none"><strong><span id="addbarcodetoselection"></span></strong> {{ $L('will be added to the list of barcodes for the selected product on submit') }}</div>
|
|
||||||
</div>
|
|
||||||
|
|
||||||
<div class="form-group">
|
<div class="form-group">
|
||||||
<label for="new_amount">{{ $L('New amount') }} <span id="new_amount_qu_unit" class="small text-muted"></span></label>
|
<label for="new_amount">{{ $L('New amount') }} <span id="new_amount_qu_unit" class="small text-muted"></span></label>
|
||||||
|
@ -11,17 +11,10 @@
|
|||||||
|
|
||||||
<form id="purchase-form" novalidate>
|
<form id="purchase-form" novalidate>
|
||||||
|
|
||||||
<div class="form-group">
|
@include('components.productpicker', array(
|
||||||
<label for="product_id">{{ $L('Product') }} <i class="fas fa-barcode"></i><span id="barcode-lookup-disabled-hint" class="small text-muted d-none"> Barcode lookup is disabled</span></label>
|
'products' => $products,
|
||||||
<select class="form-control combobox" id="product_id" name="product_id" required>
|
'nextInputSelector' => '#best_before_date .datetimepicker-input'
|
||||||
<option value=""></option>
|
))
|
||||||
@foreach($products as $product)
|
|
||||||
<option data-additional-searchdata="{{ $product->barcode }}" value="{{ $product->id }}">{{ $product->name }}</option>
|
|
||||||
@endforeach
|
|
||||||
</select>
|
|
||||||
<div class="invalid-feedback">{{ $L('You have to select a product') }}</div>
|
|
||||||
<div id="flow-info-addbarcodetoselection" class="form-text text-muted small d-none"><strong><span id="addbarcodetoselection"></span></strong> {{ $L('will be added to the list of barcodes for the selected product on submit') }}</div>
|
|
||||||
</div>
|
|
||||||
|
|
||||||
@include('components.datetimepicker', array(
|
@include('components.datetimepicker', array(
|
||||||
'id' => 'best_before_date',
|
'id' => 'best_before_date',
|
||||||
|
@ -21,15 +21,10 @@
|
|||||||
|
|
||||||
<form id="shoppinglist-form" novalidate>
|
<form id="shoppinglist-form" novalidate>
|
||||||
|
|
||||||
<div class="form-group">
|
@include('components.productpicker', array(
|
||||||
<label for="product_id">{{ $L('Product') }} <i class="fas fa-barcode"></i></label>
|
'products' => $products,
|
||||||
<select class="form-control combobox" id="product_id" name="product_id" value="@if($mode == 'edit') {{ $listItem->product_id }} @endif">
|
'nextInputSelector' => '#amount'
|
||||||
<option value=""></option>
|
))
|
||||||
@foreach($products as $product)
|
|
||||||
<option @if($mode == 'edit' && $product->id == $listItem->product_id) selected="selected" @endif data-additional-searchdata="{{ $product->barcode }}" value="{{ $product->id }}">{{ $product->name }}</option>
|
|
||||||
@endforeach
|
|
||||||
</select>
|
|
||||||
</div>
|
|
||||||
|
|
||||||
<div class="form-group">
|
<div class="form-group">
|
||||||
<label for="amount">{{ $L('Amount') }} <span id="amount_qu_unit" class="small text-muted"></span><br><span class="small text-muted">@if($mode == 'edit' && $listItem->amount_autoadded > 0){{ $L('#1 units were automatically added and will apply in addition to the amount entered here', $listItem->amount_autoadded) }}@endif</span></label>
|
<label for="amount">{{ $L('Amount') }} <span id="amount_qu_unit" class="small text-muted"></span><br><span class="small text-muted">@if($mode == 'edit' && $listItem->amount_autoadded > 0){{ $L('#1 units were automatically added and will apply in addition to the amount entered here', $listItem->amount_autoadded) }}@endif</span></label>
|
||||||
|
Loading…
x
Reference in New Issue
Block a user