mirror of
https://github.com/grocy/grocy.git
synced 2025-09-23 12:58:41 +00:00
238 lines
6.5 KiB
JavaScript
238 lines
6.5 KiB
JavaScript
![]() |
$('#save-inventory-button').on('click', function(e)
|
|||
|
{
|
|||
|
e.preventDefault();
|
|||
|
|
|||
|
var jsonForm = $('#inventory-form').serializeJSON();
|
|||
|
|
|||
|
Grocy.FetchJson('/api/stock/get-product-details/' + jsonForm.product_id,
|
|||
|
function (productDetails)
|
|||
|
{
|
|||
|
Grocy.FetchJson('/api/stock/inventory-product/' + jsonForm.product_id + '/' + jsonForm.new_amount + '?bestbeforedate=' + $('#best_before_date').val(),
|
|||
|
function (result) {
|
|||
|
toastr.success('Stock amount of ' + productDetails.product.name + ' is now ' + jsonForm.new_amount.toString() + ' ' + productDetails.quantity_unit_stock.name);
|
|||
|
|
|||
|
$('#new_amount').val('');
|
|||
|
$('#best_before_date').val('');
|
|||
|
$('#product_id').val('');
|
|||
|
$('#product_id_text_input').focus();
|
|||
|
$('#product_id_text_input').val('');
|
|||
|
$('#product_id_text_input').trigger('change');
|
|||
|
$('#inventory-form').validator('validate');
|
|||
|
},
|
|||
|
function (xhr) {
|
|||
|
console.error(xhr);
|
|||
|
}
|
|||
|
);
|
|||
|
},
|
|||
|
function(xhr)
|
|||
|
{
|
|||
|
console.error(xhr);
|
|||
|
}
|
|||
|
);
|
|||
|
});
|
|||
|
|
|||
|
$('#product_id').on('change', function(e)
|
|||
|
{
|
|||
|
var productId = $(e.target).val();
|
|||
|
|
|||
|
if (productId)
|
|||
|
{
|
|||
|
Grocy.FetchJson('/api/stock/get-product-details/' + productId,
|
|||
|
function(productDetails)
|
|||
|
{
|
|||
|
$('#selected-product-name').text(productDetails.product.name);
|
|||
|
$('#selected-product-stock-amount').text(productDetails.stock_amount || '0');
|
|||
|
$('#selected-product-stock-qu-name').text(productDetails.quantity_unit_stock.name);
|
|||
|
$('#selected-product-purchase-qu-name').text(productDetails.quantity_unit_purchase.name);
|
|||
|
$('#selected-product-last-purchased').text((productDetails.last_purchased || 'never').substring(0, 10));
|
|||
|
$('#selected-product-last-purchased-timeago').text($.timeago(productDetails.last_purchased || ''));
|
|||
|
$('#selected-product-last-used').text((productDetails.last_used || 'never').substring(0, 10));
|
|||
|
$('#selected-product-last-used-timeago').text($.timeago(productDetails.last_used || ''));
|
|||
|
$('#new_amount').attr('not-equal', productDetails.stock_amount);
|
|||
|
$('#new_amount_qu_unit').text(productDetails.quantity_unit_stock.name);
|
|||
|
|
|||
|
Grocy.EmptyElementWhenMatches('#selected-product-last-purchased-timeago', 'NaN years ago');
|
|||
|
Grocy.EmptyElementWhenMatches('#selected-product-last-used-timeago', 'NaN years ago');
|
|||
|
},
|
|||
|
function(xhr)
|
|||
|
{
|
|||
|
console.error(xhr);
|
|||
|
}
|
|||
|
);
|
|||
|
}
|
|||
|
});
|
|||
|
|
|||
|
$(function()
|
|||
|
{
|
|||
|
$('.datepicker').datepicker(
|
|||
|
{
|
|||
|
format: 'yyyy-mm-dd',
|
|||
|
startDate: '+0d',
|
|||
|
todayHighlight: true,
|
|||
|
autoclose: true,
|
|||
|
calendarWeeks: true,
|
|||
|
orientation: 'bottom auto',
|
|||
|
weekStart: 1,
|
|||
|
showOnFocus: false
|
|||
|
});
|
|||
|
$('.datepicker').trigger('change');
|
|||
|
|
|||
|
$('.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');
|
|||
|
}
|
|||
|
});
|
|||
|
|
|||
|
$('#new_amount').val('');
|
|||
|
$('#best_before_date').val('');
|
|||
|
$('#product_id').val('');
|
|||
|
$('#product_id_text_input').focus();
|
|||
|
$('#product_id_text_input').val('');
|
|||
|
$('#product_id_text_input').trigger('change');
|
|||
|
|
|||
|
$('#inventory-form').validator({
|
|||
|
custom: {
|
|||
|
'isodate': function($el)
|
|||
|
{
|
|||
|
if ($el.val().length !== 0 && !moment($el.val(), 'YYYY-MM-DD', true).isValid())
|
|||
|
{
|
|||
|
return 'Wrong date format, needs to be YYYY-MM-DD';
|
|||
|
}
|
|||
|
},
|
|||
|
'notequal': function($el)
|
|||
|
{
|
|||
|
if ($el.val().length !== 0 && $el.val().toString() === $el.attr('not-equal').toString())
|
|||
|
{
|
|||
|
return 'This value cannot be equal to ' + $el.attr('not-equal').toString();
|
|||
|
}
|
|||
|
}
|
|||
|
}
|
|||
|
});
|
|||
|
$('#inventory-form').validator('validate');
|
|||
|
|
|||
|
$('#new_amount').on('focus', function(e)
|
|||
|
{
|
|||
|
if ($('#product_id_text_input').val().length === 0)
|
|||
|
{
|
|||
|
$('#product_id_text_input').focus();
|
|||
|
}
|
|||
|
});
|
|||
|
|
|||
|
$('#inventory-form input').keydown(function(event)
|
|||
|
{
|
|||
|
if (event.keyCode === 13) //Enter
|
|||
|
{
|
|||
|
if ($('#inventory-form').validator('validate').has('.has-error').length !== 0) //There is at least one validation error
|
|||
|
{
|
|||
|
event.preventDefault();
|
|||
|
return false;
|
|||
|
}
|
|||
|
}
|
|||
|
});
|
|||
|
});
|
|||
|
|
|||
|
$('#best_before_date-datepicker-button').on('click', function(e)
|
|||
|
{
|
|||
|
$('.datepicker').datepicker('show');
|
|||
|
});
|
|||
|
|
|||
|
$('#best_before_date').on('change', function(e)
|
|||
|
{
|
|||
|
var value = $('#best_before_date').val();
|
|||
|
if (value.length === 8 && $.isNumeric(value))
|
|||
|
{
|
|||
|
value = value.replace(/(\d{4})(\d{2})(\d{2})/, '$1-$2-$3');
|
|||
|
$('#best_before_date').val(value);
|
|||
|
$('#inventory-form').validator('validate');
|
|||
|
}
|
|||
|
});
|
|||
|
|
|||
|
$('#best_before_date').on('keypress', function(e)
|
|||
|
{
|
|||
|
var element = $(e.target);
|
|||
|
var value = element.val();
|
|||
|
var dateObj = moment(element.val(), 'YYYY-MM-DD', true);
|
|||
|
|
|||
|
$('.datepicker').datepicker('hide');
|
|||
|
|
|||
|
if (value.length === 0)
|
|||
|
{
|
|||
|
element.val(moment().format('YYYY-MM-DD'));
|
|||
|
}
|
|||
|
else if (dateObj.isValid())
|
|||
|
{
|
|||
|
if (e.keyCode === 38) //Up
|
|||
|
{
|
|||
|
element.val(dateObj.add(-1, 'days').format('YYYY-MM-DD'));
|
|||
|
}
|
|||
|
else if (e.keyCode === 40) //Down
|
|||
|
{
|
|||
|
element.val(dateObj.add(1, 'days').format('YYYY-MM-DD'));
|
|||
|
}
|
|||
|
else if (e.keyCode === 37) //Left
|
|||
|
{
|
|||
|
element.val(dateObj.add(-1, 'weeks').format('YYYY-MM-DD'));
|
|||
|
}
|
|||
|
else if (e.keyCode === 39) //Right
|
|||
|
{
|
|||
|
element.val(dateObj.add(1, 'weeks').format('YYYY-MM-DD'));
|
|||
|
}
|
|||
|
}
|
|||
|
|
|||
|
$('#inventory-form').validator('validate');
|
|||
|
});
|
|||
|
|
|||
|
$('#new_amount').on('change', function(e)
|
|||
|
{
|
|||
|
if ($('#product_id').parent().hasClass('has-error'))
|
|||
|
{
|
|||
|
$('#inventory-change-info').hide();
|
|||
|
return;
|
|||
|
}
|
|||
|
|
|||
|
var productId = $('#product_id').val();
|
|||
|
var newAmount = $('#new_amount').val();
|
|||
|
|
|||
|
if (productId)
|
|||
|
{
|
|||
|
Grocy.FetchJson('/api/stock/get-product-details/' + productId,
|
|||
|
function(productDetails)
|
|||
|
{
|
|||
|
var productStockAmount = productDetails.stock_amount || '0';
|
|||
|
|
|||
|
if (newAmount > productStockAmount)
|
|||
|
{
|
|||
|
var amountToAdd = newAmount - productDetails.stock_amount;
|
|||
|
$('#inventory-change-info').text('This means ' + amountToAdd.toString() + ' ' + productDetails.quantity_unit_stock.name + ' will be added to stock');
|
|||
|
$('#inventory-change-infoo').show();
|
|||
|
}
|
|||
|
else if (newAmount < productStockAmount)
|
|||
|
{
|
|||
|
var amountToRemove = productStockAmount - newAmount;
|
|||
|
$('#inventory-change-info').text('This means ' + amountToRemove.toString() + ' ' + productDetails.quantity_unit_stock.name + ' will be removed from stock');
|
|||
|
$('#inventory-change-info').show();
|
|||
|
}
|
|||
|
else
|
|||
|
{
|
|||
|
$('#inventory-change-info').hide();
|
|||
|
}
|
|||
|
},
|
|||
|
function(xhr)
|
|||
|
{
|
|||
|
console.error(xhr);
|
|||
|
}
|
|||
|
);
|
|||
|
}
|
|||
|
});
|