mirror of
https://github.com/grocy/grocy.git
synced 2026-04-05 20:36:15 +02:00
186 lines
4.6 KiB
JavaScript
186 lines
4.6 KiB
JavaScript
import { WindowMessageBag } from '../helpers/messagebag';
|
|
|
|
function recipeposformView(Grocy, scope = null)
|
|
{
|
|
var $scope = $;
|
|
if (scope != null)
|
|
{
|
|
$scope = $(scope).find;
|
|
}
|
|
|
|
Grocy.Use("numberpicker");
|
|
var productamountpicker = Grocy.Use("productamountpicker");
|
|
var productcard = Grocy.Use("productcard");
|
|
var productpicker = Grocy.Use("productpicker");
|
|
|
|
Grocy.RecipePosFormInitialLoadDone = false;
|
|
|
|
$scope('#save-recipe-pos-button').on('click', function(e)
|
|
{
|
|
e.preventDefault();
|
|
|
|
if ($scope(".combobox-menu-visible").length)
|
|
{
|
|
return;
|
|
}
|
|
|
|
var jsonData = $scope('#recipe-pos-form').serializeJSON();
|
|
jsonData.recipe_id = Grocy.EditObjectParentId;
|
|
delete jsonData.display_amount;
|
|
|
|
Grocy.FrontendHelpers.BeginUiBusy("recipe-pos-form");
|
|
|
|
if (Grocy.EditMode === 'create')
|
|
{
|
|
Grocy.Api.Post('objects/recipes_pos', jsonData,
|
|
function(result)
|
|
{
|
|
window.parent.postMessage(WindowMessageBag("IngredientsChanged"), Grocy.BaseUrl);
|
|
window.parent.postMessage(WindowMessageBag("CloseAllModals"), Grocy.BaseUrl);
|
|
},
|
|
function(xhr)
|
|
{
|
|
Grocy.FrontendHelpers.EndUiBusy("recipe-pos-form");
|
|
Grocy.FrontendHelpers.ShowGenericError('Error while saving, probably this item already exists', xhr.response)
|
|
}
|
|
);
|
|
}
|
|
else
|
|
{
|
|
Grocy.Api.Put('objects/recipes_pos/' + Grocy.EditObjectId, jsonData,
|
|
function(result)
|
|
{
|
|
window.parent.postMessage(WindowMessageBag("IngredientsChanged"), Grocy.BaseUrl);
|
|
window.parent.postMessage(WindowMessageBag("CloseAllModals"), Grocy.BaseUrl);
|
|
},
|
|
function(xhr)
|
|
{
|
|
Grocy.FrontendHelpers.EndUiBusy("recipe-pos-form");
|
|
Grocy.FrontendHelpers.ShowGenericError('Error while saving, probably this item already exists', xhr.response)
|
|
}
|
|
);
|
|
}
|
|
});
|
|
|
|
productpicker.GetPicker().on('change', function(e)
|
|
{
|
|
var productId = $scope(e.target).val();
|
|
|
|
if (productId)
|
|
{
|
|
productcard.Refresh(productId);
|
|
|
|
Grocy.Api.Get('stock/products/' + productId,
|
|
function(productDetails)
|
|
{
|
|
if (!Grocy.RecipePosFormInitialLoadDone)
|
|
{
|
|
productamountpicker.Reload(productDetails.product.id, productDetails.quantity_unit_stock.id, true);
|
|
}
|
|
else
|
|
{
|
|
productamountpicker.Reload(productDetails.product.id, productDetails.quantity_unit_stock.id);
|
|
}
|
|
|
|
if (Grocy.Mode == "create")
|
|
{
|
|
$scope("#not_check_stock_fulfillment").prop("checked", productDetails.product.not_check_stock_fulfillment_for_recipes == 1);
|
|
}
|
|
|
|
if (!$scope("#only_check_single_unit_in_stock").prop("checked") && Grocy.RecipePosFormInitialLoadDone)
|
|
{
|
|
productamountpicker.SetQuantityUnit(productDetails.quantity_unit_stock.id);
|
|
}
|
|
|
|
$scope('#display_amount').focus();
|
|
Grocy.FrontendHelpers.ValidateForm('recipe-pos-form');
|
|
Grocy.RecipePosFormInitialLoadDone = true;
|
|
},
|
|
function(xhr)
|
|
{
|
|
console.error(xhr);
|
|
}
|
|
);
|
|
}
|
|
});
|
|
|
|
Grocy.FrontendHelpers.ValidateForm('recipe-pos-form');
|
|
|
|
if (productpicker.InProductAddWorkflow() === false)
|
|
{
|
|
productpicker.GetInputElement().focus();
|
|
}
|
|
productpicker.GetPicker().trigger('change');
|
|
|
|
if (Grocy.EditMode == "create")
|
|
{
|
|
Grocy.RecipePosFormInitialLoadDone = true;
|
|
}
|
|
|
|
$scope('#display_amount').on('focus', function(e)
|
|
{
|
|
if (productpicker.GetValue().length === 0)
|
|
{
|
|
productpicker.GetInputElement().focus();
|
|
}
|
|
else
|
|
{
|
|
$(this).select();
|
|
}
|
|
});
|
|
|
|
$scope('#recipe-pos-form input').keyup(function(event)
|
|
{
|
|
Grocy.FrontendHelpers.ValidateForm('recipe-pos-form');
|
|
});
|
|
|
|
$scope('#qu_id').change(function(event)
|
|
{
|
|
Grocy.FrontendHelpers.ValidateForm('recipe-pos-form');
|
|
});
|
|
|
|
$scope('#recipe-pos-form input').keydown(function(event)
|
|
{
|
|
if (event.keyCode === 13) //Enter
|
|
{
|
|
event.preventDefault();
|
|
|
|
if (document.getElementById('recipe-pos-form').checkValidity() === false) //There is at least one validation error
|
|
{
|
|
return false;
|
|
}
|
|
else
|
|
{
|
|
$scope('#save-recipe-pos-button').click();
|
|
}
|
|
}
|
|
});
|
|
|
|
$scope("#only_check_single_unit_in_stock").on("change", function()
|
|
{
|
|
if (this.checked)
|
|
{
|
|
$scope("#display_amount").attr("min", Grocy.DefaultMinAmount);
|
|
productamountpicker.AllowAnyQu(true);
|
|
Grocy.FrontendHelpers.ValidateForm("recipe-pos-form");
|
|
}
|
|
else
|
|
{
|
|
$scope("#display_amount").attr("min", "0");
|
|
productpicker.GetPicker().trigger("change"); // Selects the default quantity unit of the selected product
|
|
productamountpicker.AllowAnyQuEnabled = false;
|
|
Grocy.FrontendHelpers.ValidateForm("recipe-pos-form");
|
|
}
|
|
});
|
|
|
|
if ($scope("#only_check_single_unit_in_stock").prop("checked"))
|
|
{
|
|
productamountpicker.AllowAnyQu(true);
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
window.recipeposformView = recipeposformView
|