var shoppingListTable = $('#shoppinglist-table').DataTable({ 'paginate': false, 'order': [[1, 'asc']], "orderFixed": [[3, 'asc']], 'columnDefs': [ { 'orderable': false, 'targets': 0 }, { 'visible': false, 'targets': 3 } ], 'language': IsJsonString(__t('datatables_localization')) ? JSON.parse(__t('datatables_localization')) : { }, 'scrollY': false, 'colReorder': true, 'stateSave': true, 'stateSaveParams': function(settings, data) { data.search.search = ""; data.columns.forEach(column => { column.search.search = ""; }); }, 'rowGroup': { dataSrc: 3 } }); $('#shoppinglist-table tbody').removeClass("d-none"); shoppingListTable.columns.adjust().draw(); $("#search").on("keyup", function() { var value = $(this).val(); if (value === "all") { value = ""; } shoppingListTable.search(value).draw(); }); $("#status-filter").on("change", function() { var value = $(this).val(); if (value === "all") { value = ""; } // Transfer CSS classes of selected element to dropdown element (for background) $(this).attr("class", $("#" + $(this).attr("id") + " option[value='" + value + "']").attr("class") + " form-control"); shoppingListTable.column(4).search(value).draw(); }); $("#selected-shopping-list").on("change", function() { var value = $(this).val(); window.location.href = U('/shoppinglist?list=' + value); }); $(".status-filter-button").on("click", function() { var value = $(this).data("status-filter"); $("#status-filter").val(value); $("#status-filter").trigger("change"); }); $("#delete-selected-shopping-list").on("click", function() { var objectName = $("#selected-shopping-list option:selected").text(); var objectId = $("#selected-shopping-list").val(); bootbox.confirm({ message: __t('Are you sure to delete shopping list "%s"?', objectName), buttons: { confirm: { label: __t('Yes'), className: 'btn-success' }, cancel: { label: __t('No'), className: 'btn-danger' } }, callback: function (result) { if (result === true) { Grocy.Api.Delete('objects/shopping_lists/' + objectId, {}, function (result) { window.location.href = U('/shoppinglist'); }, function (xhr) { console.error(xhr); } ); } } }); }); $(document).on('click', '.shoppinglist-delete-button', function(e) { e.preventDefault(); var shoppingListItemId = $(e.currentTarget).attr('data-shoppinglist-id'); Grocy.FrontendHelpers.BeginUiBusy(); Grocy.Api.Delete('objects/shopping_list/' + shoppingListItemId, {}, function(result) { $('#shoppinglistitem-' + shoppingListItemId + '-row').fadeOut(500, function() { Grocy.FrontendHelpers.EndUiBusy(); $(this).remove(); OnListItemRemoved(); }); }, function(xhr) { Grocy.FrontendHelpers.EndUiBusy(); console.error(xhr); } ); }); $(document).on('click', '#add-products-below-min-stock-amount', function(e) { Grocy.Api.Post('stock/shoppinglist/add-missing-products', { "list_id": $("#selected-shopping-list").val() }, function(result) { window.location.href = U('/shoppinglist?list=' + $("#selected-shopping-list").val()); }, function(xhr) { console.error(xhr); } ); }); $(document).on('click', '#clear-shopping-list', function(e) { bootbox.confirm({ message: __t('Are you sure to empty shopping list "%s"?', $("#selected-shopping-list option:selected").text()), buttons: { confirm: { label: __t('Yes'), className: 'btn-success' }, cancel: { label: __t('No'), className: 'btn-danger' } }, callback: function(result) { if (result === true) { Grocy.FrontendHelpers.BeginUiBusy(); Grocy.Api.Post('stock/shoppinglist/clear', { "list_id": $("#selected-shopping-list").val() }, function(result) { $('#shoppinglist-table tbody tr').fadeOut(500, function() { Grocy.FrontendHelpers.EndUiBusy(); $(this).remove(); OnListItemRemoved(); }); }, function(xhr) { Grocy.FrontendHelpers.EndUiBusy(); console.error(xhr); } ); } } }); }); $(document).on('click', '.shopping-list-stock-add-workflow-list-item-button', function(e) { e.preventDefault(); var href = $(e.currentTarget).attr('href'); $("#shopping-list-stock-add-workflow-purchase-form-frame").attr("src", href); $("#shopping-list-stock-add-workflow-modal").modal("show"); if (Grocy.ShoppingListToStockWorkflowAll) { $("#shopping-list-stock-add-workflow-purchase-item-count").removeClass("d-none"); $("#shopping-list-stock-add-workflow-purchase-item-count").text(__t("Adding shopping list item %1$s of %2$s", Grocy.ShoppingListToStockWorkflowCurrent, Grocy.ShoppingListToStockWorkflowCount)); $("#shopping-list-stock-add-workflow-skip-button").removeClass("d-none"); } else { $("#shopping-list-stock-add-workflow-skip-button").addClass("d-none"); } }); Grocy.ShoppingListToStockWorkflowAll = false; Grocy.ShoppingListToStockWorkflowCount = 0; Grocy.ShoppingListToStockWorkflowCurrent = 0; $(document).on('click', '#add-all-items-to-stock-button', function(e) { Grocy.ShoppingListToStockWorkflowAll = true; Grocy.ShoppingListToStockWorkflowCount = $(".shopping-list-stock-add-workflow-list-item-button").length; Grocy.ShoppingListToStockWorkflowCurrent++; $(".shopping-list-stock-add-workflow-list-item-button").first().click(); }); $("#shopping-list-stock-add-workflow-modal").on("hidden.bs.modal", function(e) { Grocy.ShoppingListToStockWorkflowAll = false; Grocy.ShoppingListToStockWorkflowCount = 0; Grocy.ShoppingListToStockWorkflowCurrent = 0; }) $(window).on("message", function(e) { var data = e.originalEvent.data; if (data.Message === "AfterItemAdded") { $(".shoppinglist-delete-button[data-shoppinglist-id='" + data.Payload + "']").click(); } else if (data.Message === "Ready") { if (!Grocy.ShoppingListToStockWorkflowAll) { $("#shopping-list-stock-add-workflow-modal").modal("hide"); } else { Grocy.ShoppingListToStockWorkflowCurrent++; if (Grocy.ShoppingListToStockWorkflowCurrent <= Grocy.ShoppingListToStockWorkflowCount) { $(".shopping-list-stock-add-workflow-list-item-button")[1].click(); } else { $("#shopping-list-stock-add-workflow-modal").modal("hide"); } } } }); $(document).on('click', '#shopping-list-stock-add-workflow-skip-button', function(e) { e.preventDefault(); window.postMessage(WindowMessageBag("Ready"), Grocy.BaseUrl); }); $(document).on('click', '.order-listitem-button', function(e) { e.preventDefault(); Grocy.FrontendHelpers.BeginUiBusy(); var listItemId = $(e.currentTarget).attr('data-item-id'); var done = 1; if ($(e.currentTarget).attr('data-item-done') == 1) { done = 0; } $(e.currentTarget).attr('data-item-done', done); Grocy.Api.Put('objects/shopping_list/' + listItemId, { 'done': done }, function() { if (done == 1) { $('#shoppinglistitem-' + listItemId + '-row').addClass("text-muted"); $('#shoppinglistitem-' + listItemId + '-row').addClass("text-strike-through"); } else { $('#shoppinglistitem-' + listItemId + '-row').removeClass("text-muted"); $('#shoppinglistitem-' + listItemId + '-row').removeClass("text-strike-through"); } Grocy.FrontendHelpers.EndUiBusy(); }, function(xhr) { Grocy.FrontendHelpers.EndUiBusy(); console.error(xhr); } ); }); function OnListItemRemoved() { if ($(".shopping-list-stock-add-workflow-list-item-button").length === 0) { $("#add-all-items-to-stock-button").addClass("disabled"); } } OnListItemRemoved(); $(document).on("click", "#print-shopping-list-button", function(e) { $(".print-timestamp").text(moment().format("l LT")); window.print(); });