calculate delivery date fix

This commit is contained in:
Michał Zieliński
2025-08-30 13:15:50 +02:00
parent eab6fc87b1
commit be27602ca3
2 changed files with 204 additions and 196 deletions

View File

@@ -1,6 +1,6 @@
//START:
$(document).ready(
function() {
function () {
//set sizes
$("#parent_name").attr("size", "70");
$("#parent_name_copy").attr("size", "70");
@@ -8,24 +8,24 @@ $(document).ready(
$("#payment_date_days").css("width", "40");
//$("#payment_method").css("width", "100");
//change parent select button
$("#btn_clr_parent_name").children().attr("src","themes/default/images/id-ff-add.png" );
$("#btn_clr_parent_name").attr("title","Dodaj" );
$("#btn_clr_parent_name").children().attr("src", "themes/default/images/id-ff-add.png");
$("#btn_clr_parent_name").attr("title", "Dodaj");
$("#btn_clr_parent_name").click(createAccount);
// confirm exit
window.onbeforeunload = confirmExit;
// prevent submit by enter press
lockEnter();
// parent info
$("#delivery_date").on('inputchange',function() {
$("#delivery_date").on('inputchange', function () {
calculateDate($("#delivery_date").val());
});
var previousVal;
var pollInterval = setInterval(function() {
var pollInterval = setInterval(function () {
var val = $('#parent_id').val();
if (val !== previousVal) {
if ($('#parent_id').val() == '') return;
$(".loading_panel").css("display", "block");
setTimeout(function() {
setTimeout(function () {
getParentInfo($("#parent_id").val(), 'Accounts');
}, 1000);
}
@@ -33,13 +33,13 @@ $(document).ready(
}, 500);
//newProduct
var previousVal2;
var prodInterval = setInterval(function() {
var prodInterval = setInterval(function () {
var val = $('#newProductId').val();
if (val !== previousVal2) {
if ($('#newProductId').val() == '') return;
$(".loading_panel").css("display", "block");
setTimeout(function() {
AddProduct(items.length-1, val);
setTimeout(function () {
AddProduct(items.length - 1, val);
}, 500);
}
previousVal2 = val;
@@ -50,7 +50,7 @@ $(document).ready(
manageOO();
var count = $('#' + itemsTable + '_T tr').length - 1; // -1 -
// thead row
for (var index = 0; index != count; index++){
for (var index = 0; index != count; index++) {
calculateRow(index);
}
@@ -59,7 +59,7 @@ $(document).ready(
getCategoriesList();
// its vat free change
$("#no_tax").change(function() {
$("#no_tax").change(function () {
// calculate totals
var count = $('#' + itemsTable + '_T tr').length - 1; // -1 -
// thead row
@@ -67,21 +67,21 @@ $(document).ready(
calculateRow(index);
});
// language channge
$("#ecmlanguage").change(function() {
$("#ecmlanguage").change(function () {
changeLanguage();
});
removeFromValidate('EditView', 'shipping_iln');
DrawHeaders();
// stock selector
$("#stock").change(function() {
$("#stock").change(function () {
$("#stock_id").val(($("#stock :selected").val()));
});
if($("#type :selected").val()=='sales_order'){
if ($("#type :selected").val() == 'sales_order') {
removeFromValidate('EditView', 'invoice_date');
}
$("#type").change(function() {
if($("#type :selected").val()=='sales_order'){
$("#type").change(function () {
if ($("#type :selected").val() == 'sales_order') {
removeFromValidate('EditView', 'invoice_date');
} else {
addToValidate('EditView', 'invoice_date', 'id', 'true', '');
@@ -89,15 +89,15 @@ $(document).ready(
});
if (($("#new_number").val() == true)
&& ($("#duplicate").val() != true) && ($("#ecmquote_id").val() =='')) {
&& ($("#duplicate").val() != true) && ($("#ecmquote_id").val() == '')) {
EcmDocumentNumberGenerator_getNumberTemplate('document_no', 'EcmSales');
//sale from subpanel??
var ecp = $("#ecommerce_products").val();
if (ecp && ecp.length > 0) {
loadECommerceProducts(ecp);
} else if ($("#parent_id").val()!='') {
} else if ($("#parent_id").val() != '') {
$(".loading_panel").css("display", "block");
setTimeout(function() {
setTimeout(function () {
getParentInfo($("#parent_id").val(), $(
"#parent_type :selected").val());
}, 1000);
@@ -125,7 +125,7 @@ $(document).ready(
$(".loading_panel").css("display", "none");
}
// handle setItems
setITEMS = function() {
setITEMS = function () {
var formname = 'EditView';
if (check_form_(formname) == true) {
SetTab('ITEMS');
@@ -134,22 +134,22 @@ $(document).ready(
//payment date functions
$('#payment_date_days').css('height', '18');
$('#payment_date_days').val('0');
$('#payment_date_days').change(function() {
$('#payment_date_days').change(function () {
calculatePaymentDate();
});
// parent info
var previousVal4;
var pollInterval4 = setInterval(function() {
var pollInterval4 = setInterval(function () {
var val = $('#payment_date').val();
if (val !== previousVal4) {
setTimeout(function() {
setTimeout(function () {
calculateDateDiff();
}, 1000);
}
previousVal4 = val;
}, 1000);
// wyszukiwanie start
$('#searchProductsInput').keyup(function(e) {
$('#searchProductsInput').keyup(function (e) {
if (e.keyCode == 13) {
// stronicowanie od 1 strony przy zmianie szukanego produktu
$('#searchStart').val(0);
@@ -157,17 +157,18 @@ $(document).ready(
}
});
AddSearchRecord();
calculateDate($("#delivery_date").val());
$(".loading_panel").css("display", "none");
});
// handle save
var check_form_ = check_form;
check_form = function(formname,event) {
check_form = function (formname, event) {
// zapobiega zapisywaniu dokumentu firefox bug, w przypadku nacisniecia enter w polu z autocomplete
if(event.clientY==0 && event.clientX==0){
if (event.clientY == 0 && event.clientX == 0) {
return false;
}
window.onbeforeunload = null;
if (items.length == 0 || items[0].product_id=='') {
if (items.length == 0 || items[0].product_id == '') {
alert("Brak produktów");
return false;
}
@@ -187,7 +188,6 @@ check_form = function(formname,event) {
$("#position_list").val(JSON.stringifyNoSecurity(items));
if (check_form_(formname) === true) {
return true;
} else {
@@ -196,6 +196,7 @@ check_form = function(formname,event) {
return false;
}
};
function confirmExit() {
return "";
}
@@ -203,9 +204,9 @@ function confirmExit() {
function lockEnter() {
// prevent default
$(window).keydown(function(event) {
$(window).keydown(function (event) {
if (event.keyCode == 13 && $(":focus").prop('tagName')!='input') {
if (event.keyCode == 13 && $(":focus").prop('tagName') != 'input') {
event.preventDefault();
return false;

View File

@@ -23,6 +23,13 @@ switch ($_POST['job']) {
function calculateDate($date){
$date = new Datetime($date);
$date->modify('-1 day');
$tmp['date']=$date->format("d.m.Y");
$tmp['date_day']=date('N', strtotime($tmp['date']));
if($tmp['date_day']==7){
$date->modify('-2 day');
} else if($tmp['date_day']==6){
$date->modify('-1 day');
}
$tmp['date']=$date->format("d.m.Y");
echo json_encode($tmp);
return '';