= "7.0"):
// require_once("../PEAR/HTML/Template/IT.php");
//else:
// require_once("HTML/IT.php");
//endif;
if (!(isset($check_jb_permanent_flag) && $check_jb_permanent_flag == true))
{
include_once ("../admin/menu.php");
}
$usr_id_block = (isset($usr_id) ? $usr_id : 0);
// wenn von "check_jb_permanent.php" aufgerufen, dann sind
// die Variablen alle schon gesetzt
if (!(isset($check_jb_permanent_flag) && $check_jb_permanent_flag == true)):
writeLog_("../log/job2_options_", var_export($HTTP_POST_VARS, true));
list($csc_id_orderer_ec) = getHttpVars(array("csc_id_orderer"));
getSecHttpVars("1", array("csc_id_orderer", "jb_id", "csc_id_start"));
list ($dbhistory) = getHttpVars(array("dbhistory"));
if ($dbhistory == "")
$dbhistory = 0;
getDBNames($dbhistory);
list ($jb_copy) = getHttpVars(array("jb_copy"));
if ($jb_copy == "")
$jb_copy = "false";
list ($toursubmit, $jobListOri, $cr_id_order, $jb_waittime_hour, $jb_waittime_minute,
$jb_waitstorno, $jb_weight, $jb_crvh_length, $jb_crvh_width, $jb_crvh_height, $jb_crvh_position, $vht_id, $tag, $monat, $jahr, $stunde, $minute, $jb_permanent,
$jb_tourname, $jb_fixprice, $jb_serviceprice, $jb_cr_price, $jb_cr_serviceprice, $jb_discount, $jb_discount_rate, $afterwards, $statusMessage, $jb_cash, $getPriceOnly,
$csc_id_payer, $comp_payer, /*$jb_type,*/ $jb_globaljob, $jb_freetext_1, $jb_costsplit, $jb_permanent2,
$jb_sales_tax_rate, $jb_sales_tax_rate_sign, $endetag, $endemonat, $endejahr, $jb_cr_filter, $jb_cr_filter_opt, $jb_status,
$accept_all_addresses, $jb_id_org, $jb_status_manual, $jb_incomplete, $jb_dispoinfo, $jb_warntag, $jb_warnmonat, $jb_warnjahr, $jb_warnstunde, $jb_warnminute, $jb_jam_waittime,
$jb_tourname_hidden_vht_id, $jb_tourname_hidden, $km_price_params, $request_token, $jb_commission_no) =
getHttpVars(array("toursubmit", "jobList", "cr_id_order", "jb_waittime_hour",
"jb_waittime_minute", "jb_waitstorno", "jb_weight", "jb_crvh_length", "jb_crvh_width", "jb_crvh_height", "jb_crvh_position", "vht_id", "tag", "monat", "jahr",
"stunde", "minute", "jb_permanent", "jb_tourname", "jb_fixprice", "jb_serviceprice", "jb_cr_price", "jb_cr_serviceprice", "jb_discount", "jb_discount_rate", "afterwards",
"statusMessage", "jb_cash_hidden", "getPriceOnly", "csc_id_payer", "comp_payer",
/*"jb_type",*/ "jb_globaljob", "jb_freetext_1", "jb_costsplit_hidden", "jb_permanent2_hidden",
"jb_sales_tax_rate", "jb_sales_tax_rate_sign", "endetag", "endemonat", "endejahr",
"jb_cr_filter", "jb_cr_filter_opt", "jb_status", "accept_all_addresses", "jb_id_org", "jb_status_manual", "jb_incomplete", "jb_dispoinfo",
"jb_warntag", "jb_warnmonat", "jb_warnjahr", "jb_warnstunde", "jb_warnminute", "jb_jam_waittime", "jb_tourname_hidden_vht_id", "jb_tourname_hidden", "km_price_params",
"request_token", "jb_commission_no_hidden"
));
if ($toursubmit == "Senden" && $getPriceOnly != 1 && $request_token != ""): // e.g. no request_token when storno
$sp_id_request = $db->getOne("SELECT sp_id FROM phoenix_log.semaphor WHERE sp_obj_type = 'usr' AND sp_fieldname = 'request_token' AND sp_content = '" . $request_token . "'");
if ($sp_id_request != "") // nur zur Sicherheit
$sp_context = $db->getOne("SELECT sp_context FROM phoenix_log.semaphor WHERE sp_id = " . $sp_id_request);
writeLog_("../log/job2_options_", "\$request_token = " . $request_token . ", \$sp_id_request = " . $sp_id_request . ", \$sp_context = " . $sp_context);
if ($sp_id_request != "" && trim($sp_context) != "NOT_SENT"):
writeLog_("../log/job2_options_", "double post for \$request_token = " . $request_token . " already been processed for jb_id = " . trim($sp_context));
include_once("../include/email/htmlMimeMail.php");
$mailObj = new htmlMimeMail();
$mailObj->setFrom("support@assecutor.de");
$mailObj->setSubject("Doppelter Post für Auftrag " . trim($sp_context) . "!");
$mailObj->setText("Das request_token " . $request_token . " wurde doppelt gepostet!");
$mailResult = $mailObj->send(array("ca@assecutor.de"), 'smtp');
exit();
endif;
endif;
else:
$usr_id_block = 1;
endif;
$sp_id = 0;
$sp_id_block = 0;
if ($toursubmit == "Senden" && $getPriceOnly != 1):
$locked = "NOT_LOCKED";
if ($jb_id == "") {
do {
do {
$sp_id_block = $db->getOne("SELECT sp_id FROM phoenix_log.semaphor WHERE sp_obj_type = 'usr' AND sp_fieldname = 'job_options_user' AND (sp_obj_id = 0 OR sp_createtime < DATE_SUB(NOW(), INTERVAL 40 SECOND))");
if ($sp_id_block == "" || $sp_id_block == 0)
// Warte 100 Millisekunden (d.h. eine Zehntelsekunde)
usleep(100000);
} while ($sp_id_block == "" || $sp_id_block == 0);
updateStmt("phoenix_log.semaphor", "sp_id", $sp_id_block, array("sp_obj_id", $usr_id_block, "sp_createtime", date("Y-m-d H:i:s")), "(sp_obj_id = 0 OR sp_createtime < DATE_SUB(NOW(), INTERVAL 40 SECOND))");
$sp_id_block = $db->getOne("SELECT sp_id FROM phoenix_log.semaphor WHERE sp_obj_type = 'usr' AND sp_fieldname = 'job_options_user' AND sp_obj_id = " . $usr_id_block);
if ($sp_id_block)
$locked = "LOCKED";
} while ($locked == "NOT_LOCKED");
}
insertStmt("phoenix_log.semaphor", array("sp_obj_type", "jb", "sp_obj_id", 0, "sp_fieldname", "job_options", "sp_content", $locked, "sp_context",
($jb_id != "" ? "EDIT_CS" : "NEW_CS") . ((isset($check_jb_permanent_flag) && $check_jb_permanent_flag == true) ? ",PERM" : "") . (isset($jb_storno) ? ",\$jb_storno=" . $jb_storno : ""),
"sp_createtime", date("Y-m-d H:i:s")));
$sp_id = getLastInsertId();
endif;
if (trim($jb_id_org) == "")
list ($jb_id_org) = getHttpVars(array("jb_id_org"));
if (!isset($jb_storno))
$jb_storno = 0;
// Kostenstellennummer des Kunden ist Parameter
if ($csc_id_orderer == "" && $csc_id_orderer != '0'):
reportDie ("$PHP_SELF: Parameter 'csc_id_orderer' fehlt!", false);
endif;
// wegen einer noch nicht geklärten Merkwürdigkeit (Session-Problematik) kann es manchmal passieren, dass $csc_id_orderer negativ ist;
if ($csc_id_orderer < 0)
$csc_id_orderer = 0;
$self_service_discount = 0;
if ($csc_id_orderer != '0'):
// Kundenauftrag
$cs_id = getFieldValueFromId("costcenter", "csc_id", "$csc_id_orderer", "cs_id");
$hq_id = getFieldValueFromId("customer", "cs_id", "$cs_id", "hq_id");
$cs_ar = getFieldValueFromId("customer", "cs_id", "$cs_id", "cs_ar");
// wenn Kundenauftrag, dann entscheidet der zentralenabhängige Modus darüber, ob manuell oder automatisch
// ab 14.04.2020 muss berücksichtigt werden, dass es Kunden gibt, die manuelle Dispo anklicken können
// ab 18.05.2020 overrult MASK_MANUAL_DISPOSITION_CUSTOMER_MANDATORY alles (d.h. alle Kundenaufträge gehen immer in die manuelle Dispo)
// if ((MASK_MANUAL_DISPOSITION == '1' && getParameterValue("0", "CUSTOMER_MANUAL_DISPO_" . $cs_id, "0") != "1") || MASK_MANUAL_DISPOSITION_CUSTOMER_MANDATORY == '1'):
// ab 12.07.2023 overrult das neue Feld customer.cs_ar alles (1 = autoranking, 0 = automatische Vermittlung)
if ($cs_ar == 0):
$jb_status_manual = 1;
endif;
// cs_invmode ist vom Bezahler abhängig!!!
// $cs_invmode = getFieldValueFromId("customer", "cs_id", "$cs_id", "cs_invmode");
if (getParameterValue("0", "CUSTOMER_MASK_JB_CREATOR_DISCOUNT_" . $cs_id, "0") == "1"):
$self_service_discount = getParameterValue("0", "MASK_CS_SELF_SERVICE_DISCOUNT", $hq_id);
endif;
else:
// Zentralenauftrag
// wenn von "check_jb_permanent.php" aufgerufen, dann ist hq_id gesetzt
if (!(isset($check_jb_permanent_flag) && $check_jb_permanent_flag == true))
$hq_id = $HTTP_SESSION_VARS['hq_id'];
// *** cs_invmode wird jetzt auch für Hansetrans aus der DB ermittelt
// ACHTUNG: NUR HANSETRANS! MUSS UNBEDINGT AUS DB ERMITTELT WERDEN!
// $cs_id = 0;
// $cs_invmode = 1;
// ***
$cs_id = getFieldValueFromId("costcenter", "csc_id", "$csc_id_orderer", "cs_id");
// $cs_invmode = getFieldValueFromId("customer", "cs_id", "$cs_id", "cs_invmode");
// cs_id muss wieder auf 0 gesetzt werden, da vorerst hier
// die Unterscheidung Kundenauftrag/Zentralenauftrag getroffen wird
$cs_id = 0;
// ***
endif;
// // wegen einer noch nicht geklärten Merkwürdigkeit in auth.inc.php kann es manchmal passieren, dass
// // $HTTP_SESSION_VARS['hq_id'] leer ist; dann wird hq_id einfach auf eins gesetzt
// // (wir werden voraussichtlich für jede Zentrale einen eigenen MySQL-Server laufen haben, also
// // ist hq_id sowieso immer 1)
// if ($hq_id == "" || $hq_id <= 0)
// $hq_id = 1;
$hq_workmode = getFieldValueFromId("headquarters", "hq_id", "$hq_id", "hq_workmode");
$jobbatch_mode = false;
$tr_sort_jobbatchmode = 0;
$jobMode = "undefiniert";
// *** Nur für's Logging
if ($toursubmit == "Senden"):
$jobMode = "Neu";
if ((isset($check_jb_permanent_flag) && $check_jb_permanent_flag == true)) $jobMode = "Fortsetzung Dauerauftrag"; // "*** DUPLICATION OF STANDING ORDER ***";
if ($getPriceOnly == 1) $jobMode = "Preisanfrage"; // "*** PRICE INQUIRY ***";
if ($afterwards == "1" && $getPriceOnly != 1) $jobMode = "Nacherfassung"; // "*** NEW FINISHED JOB ***";
if ($jb_id != "" && $getPriceOnly != 1) $jobMode = (getFieldValueFromId("job", "jb_id", "$jb_id", "jb_status") == 2 ? "Nachträglich" : "Laufend"); // "*** EDIT FINISHED JOB ***";
if ($jb_storno == 1 && $getPriceOnly != 1) $jobMode = "Storno kostenpflichtig"; // "*** CANCELLATION CREDIT NOTE WITH CANCELLATION COSTS ***";
if ($jb_storno == 2 && $getPriceOnly != 1) $jobMode = ($jb_status == 2 ? "Storno-Gutschrift für" : "Storno von") . " Auftrag Nr. $jb_id_copy"; // "*** CANCELLATION CREDIT NOTE WITHOUT CANCELLATION COSTS ***";
// if ($jobMode == "") $jobMode = ""; // "*** NEW JOB ***";
// writeLog("\n$jobMode\n" .
// "Variables: \$jb_storno='$jb_storno', \$hq_workmode='$hq_workmode', \$cs_id='$cs_id', \$hq_id='$hq_id'\n" .
// "HTTP Variables: \$csc_id_orderer='$csc_id_orderer', \$jb_id='$jb_id', \$toursubmit='$toursubmit',\n\$jobList='$jobListOri',\n\$cr_id_order='$cr_id_order',\$jb_waittime_hour='$jb_waittime_hour', " .
// "\$jb_waittime_minute='$jb_waittime_minute', \$jb_waitstorno='$jb_waitstorno', \$jb_weight='$jb_weight', \$vht_id='$vht_id',\n\$tag='$tag', \$monat='$monat', \$jahr='$jahr', " .
// "\$stunde='$stunde', \$minute='$minute', \$jb_permanent='$jb_permanent', \$jb_tourname='$jb_tourname',\n\$jb_fixprice='$jb_fixprice', \$afterwards='$afterwards', " .
// "\$statusMessage='$statusMessage', \$jb_cash_hidden='$jb_cash', \$getPriceOnly='$getPriceOnly', \$csc_id_payer='$csc_id_payer', \$comp_payer='$comp_payer', " .
// "\$jb_type='$jb_type', \$jb_globaljob='$jb_globaljob',\n\$jb_freetext_1='$jb_freetext_1',\n\$jb_costsplit_hidden='$jb_costsplit', \$jb_permanent2_hidden='$jb_permanent2', " .
// "\$jb_sales_tax_rate='$jb_sales_tax_rate', \$jb_sales_tax_rate_sign='$jb_sales_tax_rate_sign',\n\$endetag='$endetag', \$endemonat='$endemonat', \$endejahr='$endejahr', " .
// "\$jb_cr_filter='$jb_cr_filter', \$jb_cr_filter_opt='$jb_cr_filter_opt'\n");
// Bei der Änderung eines Auftrages soll festgehalten werden, was geändert wurde...
if ($jb_id != "" && $getPriceOnly != 1):
// gespeicherte Job-Daten holen
list($csc_id_old, $vht_id_old, $jb_weight_old, $jb_crvh_length_old, $jb_crvh_width_old, $jb_crvh_height_old, $jb_crvh_position_old, $jb_ordertime_old, $jb_reserv_old, $jb_permanent_old, $vht_id_old,
$cr_sid_old, $cr_id_order_old, $jb_waitstorno_old, $jb_waittime_old, $jb_fixprice_old, $jb_serviceprice_old, $csc_id_payer_old, $csc_id_payer_cash_old,
/*$jb_type,*/ $jb_globaljob_old, $jb_freetext_1_old, $jb_payment_old, $jb_permanent2_old,
$jb_sales_tax_rate_old, $jb_sales_tax_rate_sign_old, $jp_permenddat_old, $jb_cr_filter_old, $jb_cr_filter_opt_old,
$jb_status_old, $cr_id_permanent_old, $jb_incomplete_old, $jb_dispoinfo_old, $hq_id_exec_old, $jb_longhaul_old, $jb_commission_no_old) =
getFieldsValueFromId("job", "jb_id", $jb_id,
array("csc_id", "vht_id", "jb_weight", "jb_crvh_length", "jb_crvh_width", "jb_crvh_height", "jb_crvh_position", "jb_ordertime", "jb_reserv", "jb_permanent",
"vht_id", "cr_sid", "cr_id_order", "jb_waitstorno", "jb_waittime", "jb_fixprice", "jb_serviceprice", "csc_id_payer", "csc_id_payer_cash",
/*"jb_type",*/ "jb_globaljob", "jb_freetext_1", "jb_payment", "jb_permanent2",
"jb_sales_tax_rate", "jb_sales_tax_rate_sign", "jp_permenddat", "jb_cr_filter", "jb_cr_filter_opt",
"jb_status", "cr_id_permanent", "jb_incomplete", "jb_dispoinfo", "hq_id_exec", "jb_longhaul", "jb_commission_no"));
endif;
// gespeicherte Tour-Daten holen
$i = 1;
do {
if (existsEntry("tour", array("jb_id", $jb_id, "tr_sort", $i))):
$tourFound = 1;
list($csc_id_old_[$i], $tr_comp_old_[$i], $tr_person_old_[$i], $ad_street_old_[$i], $tr_hsno_old_[$i],
$ad_zipcode_old_[$i], $ad_city_old_[$i], $ad_country_old_[$i], $tr_remark_old_[$i], $tr_status_old_[$i], $tr_ware_from_to_old_[$i], $tr_commission_no_old_[$i], $tr_mediationarea_id_old_[$i],
$tr_status_old_[$i], $tr_sign_old_[$i], $tr_signname_old_[$i], $tr_finishtime_old_[$i]) =
getTourData($jb_id, $i, $dbh_tr);
else:
$tourFound = 0;
endif;
$i++;
} while ($tourFound == 1);
$i_tour_max_old = $i - 1;
endif;
// *** Nur für's Logging ENDE
if ($jb_storno > 0)
$jb_tourname = "";
$jb_fixprice_ori = $jb_fixprice;
$jb_fixprice = (float) str_replace(",", ".", $jb_fixprice);
$jb_serviceprice_ori = $jb_serviceprice;
$jb_serviceprice = (float) str_replace(",", ".", $jb_serviceprice);
$jb_cr_price_ori = $jb_cr_price;
$jb_cr_price = (float) str_replace(",", ".", $jb_cr_price);
if (MASK_CR_PRICE_MODE == "1") {
$jb_cr_serviceprice = (float) str_replace(",", ".", $jb_cr_serviceprice);
}
$addressValid = "ok";
$job_is_new = true;
// Preise werden immer ermittelt, auch wenn $getPriceOnly != 1 (ist halt einfacher)
$fullPrice = 0.00;
$jb_subtotal = 0;
$jb_totalprice = 0;
$discount_sign = "";
//$fullDiscount = 0.00;
$fullCrPrice = 0.00;
$jb_cr_subtotal = 0.00;
$jb_cr_price_total = 0.00;
if (!isset($self_service_discount)) {
$self_service_discount = 0.00;
} else {
$self_service_discount = (float) $self_service_discount;
};
$tmp_discount = 0;
$tmp_discount_rate = 0;
$is_EU = false;
$eu_countrycodes = explode(",", trim(getParameterValue("0", "EU_COUNTRYCODES", "0")));
$is_EU_only = true;
$is_foreign = false;
$gross_price = 0;
$distance = 0;
$fuel_cr_markup = 0;
$jb_price_km = 0;
if ($toursubmit == "Senden"):
// Wenn als Preis-Update aufgerufen, dann enthält die Joblist leider
// ein garstiges Zeichen (Â) welches zuerst herausgefiltert werden muss
// $jobListOri = str_replace("Â", "", $jobListOri);
// writeLog_("../log/job2_options_", var_export($jobListOri, true));
if (!(strpos ($jobListOri, "Â") === false)):
// "utf8_decode" auf dem mps1 macht "¹" und "²" kaputt...!
// $jobListOri = utf8_decode($jobListOri);
// $jobListOri = iconv("UTF-8", "ISO-8859-1", $jobListOri);
// http://php.net/manual/de/function.iconv.php
//Logic from http://twiki.org/cgi-bin/view/Codev/InternationalisationUTF8
$jobListOri = preg_replace("/([\xC2\xC3])([\x80-\xBF])/e", "chr(ord('\\1')<<6&0xC0|ord('\\2')&0x3F)", $jobListOri);
// writeLog_("../log/job2_options_", var_export($jobListOri, true));
endif;
// Jobliste in ein 2-dim. Array umwandeln
$jobList = $jobListOri;
$jobList = explode("¹", $jobList);
for ($i = 0; $i < count($jobList); $i++):
$jobList[$i] = explode("²", $jobList[$i]);
endfor;
endif;
$jsAddNewExternCostcenter = "";
$tr_tracking_flag = false;
$setMediation_area_idArr = array();
$assigned_cr_id = "";
$prev_jb_id = "";
// wenn Button "Senden" gedrückt, dann Auftrag speichern
// (wenn nicht, dann ist dies der erste Aufruf beim Anfordern der Seite)
if ($toursubmit == "Senden" && $getPriceOnly != 1):
// Transaktionsstart
TA("BEGIN");
// Auftragsdaten in Array speichern
if ($afterwards == "1"):
// Nacherfassung: Job ist bereits erledigt
$insertStmtArr = array("csc_id", $csc_id_orderer, "jb_status", "2");
// die einzelnen Touren sind auch erledigt
$tr_status = "1";
// der gewünschte Kurier ist dann der annehmende Kurier
// !!!!!!
array_push ($insertStmtArr, "cr_id",
getFieldValueFromId("couriervehicle", "crvh_sid", $cr_id_order, "cr_id"),
"cr_sid", $cr_id_order);
else:
// normaler Auftrag (keine Nacherfassung)
// ODER nachträgliche Änderung
if ($jb_id != ""):
// $jb_id gesetzt -> nachträgliche Änderung eines bestehenden Auftrags.
$job_is_new = false;
// status darf nicht geändert werden!
// Es sei denn, jb_status = "9" (Disponentenauftrag),
// -> muss dann auf 0 gesetzt werden wenn Kurier angegegeben
// ... ODER jb_globaljob = 1 und jb_status = 8 oder 9 (z.B. jb_globaljob vergessen und nachträglich hinzugefügt)
if ((getFieldValueFromId("job", "jb_id", "$jb_id", "jb_status") == "9" && $cr_id_order != "") ||
((getFieldValueFromId("job", "jb_id", "$jb_id", "jb_status") == "8" || getFieldValueFromId("job", "jb_id", "$jb_id", "jb_status") == "9") && $jb_globaljob == 1)):
$insertStmtArr = array("csc_id", $csc_id_orderer, "jb_status", "0");
else:
$insertStmtArr = array("csc_id", $csc_id_orderer);
endif;
// die einzelnen Touren sind noch NICHT erledigt
// TOBEDONE: Nachträgliche Änderungen von teilweise erledigten Aufträgen
$tr_status = "0";
else:
// neuer Auftrag: jb_status = 0
// (wenn Disposition gewünscht (hq.hq_workmode == "1"), dann jb_status = 9)
// Achtung: Bei Vorbestellung darf natürlich nicht jb_status = 9 gesetzt werden,
// wenn ein Kurier angegeben ist
// if ((!($tag == "" || $monat == "" || $jahr == "" || $stunde == "" || $minute == "") &&
// $cr_id_order != "") || $jb_globaljob == 1):
// Dauerauftrag oder Vorbestellung oder Frühauftrag
if ($cr_id_order != ""):
// Wenn mit Kurierangabe, dann dem Kurier sofort zuweisen,
// wenn workmode = 1, oder wenn workmode = 2, dann aber nur, wenn kein Dauerauftrag/Vorbestellung
if ((!($tag != "" && $monat != "" && $jahr != "" && $stunde != "" && $minute != "") || $jb_globaljob == 1)
|| $hq_workmode == "1"):
$insertStmtArr = array("csc_id", $csc_id_orderer, "jb_status", "0"); // Offener (anzunehmender) Auftrag
// Kurier-ID merken
$assigned_cr_id = getFieldValueFromId("couriervehicle", "crvh_sid", $cr_id_order, "cr_id");
// Wenn mit Kurierangabe, aber Dauerauftrag/Reservierung, dann ins Autoranking wenn workmode = 2
elseif ($hq_workmode == "2"):
// Autoranking bekommt jb_status = 8
$insertStmtArr = array("csc_id", $csc_id_orderer, "jb_status", "8");
endif;
// Wenn Kurier angegeben, dann auch die cr_sid setzen
if ($cr_id_order != ""):
array_push ($insertStmtArr,
"cr_id_order", getFieldValueFromId("couriervehicle", "crvh_sid", $cr_id_order, "cr_id"),
"cr_sid", $cr_id_order, "cr_id_permanent", $cr_id_order);
endif;
else:
// Ohne Kurierangabe
if ($hq_workmode == "1" && $jb_globaljob != 1):
// Adhoc-Auftrag: Disposition vornehmen (jb_status = 9) (nicht wenn an alle Kuriere!)
$insertStmtArr = array("csc_id", $csc_id_orderer, "jb_status", "9");
elseif ($hq_workmode == "2" && $jb_globaljob != 1):
// Autoranking bekommt jb_status = 8 (nicht wenn an alle Kuriere!)
$insertStmtArr = array("csc_id", $csc_id_orderer, "jb_status", "8");
else:
// Börsenmodus!!! oder an alle Kuriere
$insertStmtArr = array("csc_id", $csc_id_orderer, "jb_status", "0");
endif;
endif;
// die einzelnen Touren sind auch noch NICHT erledigt
$tr_status = "0";
endif;
if (isset($cs_invmode))
array_push ($insertStmtArr, "jb_invmode", $cs_invmode);
endif;
// wenn Annahmezeit gesetzt, dann übernehmen, sonst leer lassen
if (MASK_WAITTIME_ENABLED == "1"):
if ($jb_waittime_hour != "" && $jb_waittime_minute != ""):
$today = getdate();
$jb_waittime = $today['year'] . "-" . $today['mon'] . "-" . $today['mday'] . " "
. "$jb_waittime_hour:$jb_waittime_minute:00";
array_push ($insertStmtArr, "jb_waittime", $jb_waittime);
endif;
endif;
// if ($jb_waitstorno != "")
array_push ($insertStmtArr, "jb_waitstorno", $jb_waitstorno);
// if ($jb_weight != "" && $jb_weight != 0)
array_push ($insertStmtArr, "jb_weight", $jb_weight,
"jb_crvh_length", $jb_crvh_length, "jb_crvh_width", $jb_crvh_width,
"jb_crvh_height", $jb_crvh_height, "jb_crvh_position", $jb_crvh_position
);
if ($vht_id != "" && $vht_id != 0)
array_push ($insertStmtArr, "vht_id", $vht_id);
else
$vht_id = 2;
// if ($jb_globaljob != "")
array_push ($insertStmtArr, "jb_globaljob", $jb_globaljob);
// if ($jb_type != "")
// array_push ($insertStmtArr, "jb_type", $jb_type);
// if ($jb_freetext_1 != ""):
array_push ($insertStmtArr, "jb_freetext_1", my_str_check_http($jb_freetext_1));
// endif;
array_push ($insertStmtArr, "jb_dispoinfo", my_str_check_http($jb_dispoinfo));
// Warningtime
$jb_warningtime = "";
if (!($jb_warntag == "" || $jb_warnmonat == "" || $jb_warnjahr == "" || $jb_warnstunde == "" || $jb_warnminute == "")):
$jb_warningtime = "$jb_warnjahr-$jb_warnmonat-$jb_warntag $jb_warnstunde:$jb_warnminute:00";
endif;
array_push ($insertStmtArr, "jb_warningtime", $jb_warningtime);
// if ($jb_cr_filter != "") // Filer müssen auch löschbar sein!!!
$mandatory_filters = trim(getParameterValue("0", "MASK_MANDATORY_FILTERS", $hq_id));
//echo $jb_cr_filter . "|" . $mandatory_filters . "
\n";
if ($mandatory_filters != ''):
$mandatory_filtersArr = explode(",", $mandatory_filters);
for ($i = 0; $i < count($mandatory_filtersArr); $i++):
if (!in_array ($mandatory_filtersArr[$i], explode(",", $jb_cr_filter)))
$jb_cr_filter .= (trim($jb_cr_filter) == "" ? "" : ",") . $mandatory_filtersArr[$i];
endfor;
endif;
//echo $jb_cr_filter . "
\n"; die();
array_push ($insertStmtArr, "jb_cr_filter", $jb_cr_filter);
// if ($jb_cr_filter_opt != "")
array_push ($insertStmtArr, "jb_cr_filter_opt", $jb_cr_filter_opt);
// wenn Datum gesetzt, dann übernehmen, sonst aktuelle Zeit (nur wenn nicht Nachbearbeitung!!!)
$jb_ordertime = "";
if ($tag == "" || $monat == "" || $jahr == "" || $stunde == "" || $minute == ""):
if ($jb_id == ""):
$today = getdate();
$jb_ordertime = $today['year'] . "-" . $today['mon'] . "-" . $today['mday'] . " "
. $today['hours'] . ":" . $today['minutes'] . ":" . $today['seconds'];
else:
$jb_ordertime = $db->getOne("SELECT jb_ordertime FROM job WHERE jb_id = '$jb_id'");
endif;
else:
$jb_ordertime = "$jahr-$monat-$tag $stunde:$minute:00";
// Vorbestellung
$jb_reserv = 0;
if ($afterwards != "1"):
$jb_reserv = 1;
endif;
if ($jb_permanent != "" && $jb_permanent != 0):
$jb_reserv = 1;
// Dauerauftrag
array_push ($insertStmtArr, "jb_permanent", $jb_permanent);
array_push ($insertStmtArr, "jb_permanent2", $jb_permanent2);
if ($endetag != "" && $endemonat != "" && $endejahr != ""):
$jp_permenddat = "$endejahr-$endemonat-$endetag 00:00:00";
array_push ($insertStmtArr, "jp_permenddat", $jp_permenddat);
endif;
endif;
array_push ($insertStmtArr, "jb_reserv", $jb_reserv);
endif;
if ($jb_ordertime != "")
array_push ($insertStmtArr, "jb_ordertime", $jb_ordertime);
if ($afterwards == "1"):
// Nacherfassung: Job ist bereits erledigt
// 'finishtime' ist 'ordertime'
array_push ($insertStmtArr, "jb_finishtime", $jb_ordertime);
$today = getdate();
$jb_booktime = $today['year'] . "-" . $today['mon'] . "-" . $today['mday'] . " "
. $today['hours'] . ":" . $today['minutes'] . ":" . $today['seconds'];
array_push ($insertStmtArr, "jb_booktime", $jb_booktime);
endif;
// Festpreis?
// if ($jb_fixprice != "" && $jb_fixprice != 0) // Festpreis muss auch gelöscht werden können,
// wenn nachträglich geändert
if (isset($jb_storno) && $jb_storno > 0):
$jb_fixprice = $jb_fixprice * -1;
$jb_serviceprice = $jb_serviceprice * -1;
$jb_cr_price = $jb_cr_price * -1;
endif;
array_push ($insertStmtArr, "jb_fixprice", $jb_fixprice, "jb_serviceprice", $jb_serviceprice, "jb_cr_subprice", $jb_cr_price);
if ($jb_discount == 1)
$tmp_discount_rate = $jb_discount_rate;
$jb_totalprice = $jb_fixprice * (1 - ($tmp_discount_rate / 100));
$jb_sales_tax_rate_sign_new = $db->getOne("SELECT tx_sign FROM tax WHERE tx_id = '$jb_sales_tax_rate_sign'");
array_push ($insertStmtArr,
"jb_sales_tax_rate", $jb_sales_tax_rate, "jb_sales_tax_rate_sign", $jb_sales_tax_rate_sign_new);
//// wegen einer noch nicht geklärten Merkwürdigkeit in auth.inc.php kann es manchmal passieren, dass
//// $HTTP_SESSION_VARS['hq_id'] leer ist; dann wird hq_id einfach auf eins gesetzt
//// (wir werden voraussichtlich für jede Zentrale einen eigenen MySQL-Server laufen haben, also
//// ist hq_id sowieso immer 1)
//if ($hq_id == "" || $hq_id <= 0)
// $hq_id = 1;
// hq_id (Lizenznehmer) holen und speichern
array_push ($insertStmtArr, "hq_id", $hq_id);
// // emp_id (Erfasser des Auftrags) holen und speichern
// $emp_id = getFieldValueFromId("employee", "usr_id", $HTTP_SESSION_VARS['usr_id'], "emp_id");
// $usr_id speichern statt $emp_id, weil auch Zentrale kann Aufträge eingeben
// Auftragsdaten abspeichern und Auftrags-ID merken
if ($job_is_new)
// usr_id nur bei Ersterfassung speichern
array_push ($insertStmtArr, "emp_id", $usr_id);
//print_r ($insertStmtArr);
if (!$job_is_new && (!isset($jb_storno) || $jb_storno == 0))
{
// $wenn $jb_id gesetzt ist, dann handelt es sich um die nachträgliche Änderung
// eines bestehenden Auftrages!
//print_r ($insertStmtArr);
if ($getPriceOnly != 1) {
updateStmt("job", "jb_id", $jb_id, $insertStmtArr);
// zugehörige Einträge in tour und tourservice werden gelöscht,
// da sie unten wieder aufgebaut werden - NICHT MEHR: Unterschriften könnten gelöscht werden!!! -
// deleteStmt("tour", "jb_id = $jb_id");
// nur tourservices werden gelöscht, damit geänderte Preise berücksichtigt werden
deleteStmt("tourservice", "jb_id = $jb_id");
$statusMessageTxt = "Der Auftrag wurde geändert!";
$killAfterUpdate = true;
}
} else {
// neuer Auftrag, wie es sich gehört
if ($getPriceOnly != 1):
array_push ($insertStmtArr, "jb_createtime", date("Y-m-d H:i:s"));
if (!(isset($_copy_jobs_flag) && $_copy_jobs_flag == true) || (isset($_copy_jobs_flag_ori) && $_copy_jobs_flag_ori == true)
|| (isset($jb_storno) && $jb_storno > 0)):
// if (isset($jb_storno) && $jb_storno > 0):
// endif;
insertStmt("job", $insertStmtArr);
$jb_id = getLastInsertId();
// Wenn bereits ein Kurier zugewiesen wurde, dann muss dies hier berücksichtigt werden!
if ($assigned_cr_id != ""):
// Kurier muss auf occupied gesetzt werden, wenn angegeben und keine Reservierung/Dauerauftrag
$tmpArr = array("cr_occupied", 1);
updateStmt("courier", "cr_id", $assigned_cr_id, $tmpArr);
// Wenn automatische Vermittlung ($hq_workmode == "2"), dann muss hier auch autoranking berücksichtigt werden!
if ($hq_workmode == "2"):
// Set current assigning time for revoking a job if not taken by the courier
$currentTime = getDateTime("0");
if (existsEntry("autoranking",array("jb_id",$jb_id,"cr_id",$cr_id))) :
$tmpArr = array("ar_challenge", "0", " ar_lastassigntime", $currentTime);
updateStmt("autoranking", "jb_id", $jb_id, $tmpArr,"cr_id = '" . $cr_id . "'");
else :
$tmpArr = array("jb_id", $jb_id, "cr_id", $assigned_cr_id, "ar_challenge", "0", "ar_lastassigntime", $currentTime);
insertStmt("autoranking", $tmpArr);
endif;
endif;
endif;
if (isset($jb_storno) && $jb_storno > 0):
$jb_invtext = ($jb_status == 2 ? "Storno-Gutschrift für" : "Storno von");
$today = getdate();
$tmp_cr_sid = getFieldValueFromId("job", "jb_id", $jb_id_copy, "cr_sid");
$tmp_cr_id = getFieldValueFromId("couriervehicle", "crvh_sid", $tmp_cr_sid, "cr_id");
$tmpArr = array(
"jb_storno", ($jb_storno == 1 ? 3 : 4),
"jb_invtext", mkLineBreaks("$jb_invtext Auftrag Nr. $jb_id_copy", INV_MAXCOLS, 10, true),
"jb_status", 2,
"cr_id", $tmp_cr_id,
"cr_sid", $tmp_cr_sid,
"cr_id_order", getFieldValueFromId("job", "jb_id", $jb_id_copy, "cr_id_order"),
"jb_ordertime", getFieldValueFromId("job", "jb_id", $jb_id_copy, "jb_ordertime"),
"jb_taketime", getFieldValueFromId("job", "jb_id", $jb_id_copy, "jb_taketime"),
"jb_sales_tax_rate", getFieldValueFromId("job", "jb_id", $jb_id_copy, "jb_sales_tax_rate"),
"jb_sales_tax_rate_sign", getFieldValueFromId("job", "jb_id", $jb_id_copy, "jb_sales_tax_rate_sign"),
"jb_finishtime", $today['year'] . "-" . $today['mon'] . "-" . $today['mday'] . " "
. $today['hours'] . ":" . $today['minutes'] . ":" . $today['seconds'],
"jb_booktime", $today['year'] . "-" . $today['mon'] . "-" . $today['mday'] . " "
. $today['hours'] . ":" . $today['minutes'] . ":" . $today['seconds']);
updateStmt("job", "jb_id", $jb_id, $tmpArr);
// Originialauftrag updaten
// wenn ein Kurier zugewiesen war, dann miuss dieser Kurier auch in beiden Jobs als annehmender eingetragen
// werden, da sonst beim Export (jb_storno = 1 und jb_storno = 3, weil mit kosten) dieser
// Auftrag keinem Kurier zugewiesen werden kann!
// Aufträge ohne Kuriere dürfen _nicht kostenpflichtig_ storniert werden können!
updateStmt("job", "jb_id", $jb_id_copy, array("jb_id_copy", $jb_id, "cr_id", $tmp_cr_id));
// Job-Kopie wg. Storno-Gutschrift
// d.h. die alten tourservices müssen kopiert und mit negativen Werten versehen werden
// die Funktion "saveservicecosts" legt in diesem Fall keine neuen Kosten an
// jb_totalprice muss hier berücksichtigt werden!
$jb_subtotal_storno = (-1 * $db->getOne("SELECT jb_subtotalprice FROM job WHERE jb_id = '$jb_id_copy'"));
$jb_totalprice_storno = (-1 * $db->getOne("SELECT jb_totalprice FROM job WHERE jb_id = '$jb_id_copy'"));
$jb_cr_price_storno = (-1 * $db->getOne("SELECT jb_cr_price FROM job WHERE jb_id = '$jb_id_copy'"));
$sqlquery = "SELECT csc_id, tr_sort, srv_id, trs_srv_name, srvt_id, trs_srvt_name, trs_price, trs_discount FROM tourservice WHERE jb_id = '$jb_id_copy'";
$res = $db->query($sqlquery);
if (DB::isError($res)) reportDie ("$PHP_SELF: '$sqlquery': " . $res->getMessage());
$i = 0;
$csc_id_arr = array();
while ($row = $res->fetch_assoc()):
// Für jeden Posten des Storno-Jobs wird eine Gutschrift generiert
$tmpArr = array("jb_id", $jb_id, "tr_sort", $row['tr_sort'], "srv_id", $row['srv_id'], "trs_srv_name",
$row['trs_srv_name'], "srvt_id", $row['srvt_id'], "trs_srvt_name", $row['trs_srvt_name'],
"trs_price", (-1 * $row['trs_price']), "trs_discount", $row['trs_discount'], "csc_id", $row['csc_id']);
insertStmt("tourservice", $tmpArr);
// Zahler merken wg. Stornokosten
$csc_id_arr[$row['csc_id']] = "dummy";
$i++;
endwhile;
$res->free();
// Storno mit Kosten?
if ($jb_storno == 1):
$srvt_name = $db->getOne(
"SELECT mt_value FROM metatype WHERE mt_sort = '$vht_id' AND mt_type = 'vehicletype'");
$storno_price = getServiceValues(
$db->getOne("SELECT srv_id FROM service WHERE srv_name = 'Storno' AND hq_id = '$hq_id'"),
$db->getOne("SELECT srvt_id FROM servicetype WHERE srvt_name = '$srvt_name' AND hq_id = '$hq_id'"),
$cs_id, $hq_id, $jb_ordertime, 1);
$costsplit_divisor = count($csc_id_arr);
foreach($csc_id_arr as $key_csc_id => $val_dummy) {
$tmpArr = array(
"jb_id", $jb_id, "tr_sort", $i, "srv_id", 0, "trs_srv_name",
"Stornogebühr", "srvt_id", 0, "trs_srvt_name", "",
"trs_price", ($storno_price / $costsplit_divisor), "trs_discount", 0, "csc_id", $key_csc_id);
insertStmt("tourservice", $tmpArr);
}
endif;
endif;
else:
// Auftragsduplikation
// Duplikation der Originaldaten in eine neue Datenbank wg. Neuberechnung
// war am Angang nötig wg. Änderung der Kostenberechnung
array_push ($insertStmtArr, "jb_id", $jb_id_copy);
$jb_id = $jb_id_copy;
insertStmt("job", $insertStmtArr);
endif;
$statusMessageTxt = "Der Auftrag wurde gespeichert!\\nAuftragsnummer: $jb_id";
$prev_jb_id = $jb_id;
// wenn der Auftrag aus der Kundenbestandsliste generiert wurde,
// soll die Maske gleich wieder geschlossen werden
// if ($csc_id_orderer != "" && $csc_id_orderer != "0")
// $killAfterUpdate = true;
// else
$killAfterUpdate = false;
endif;
}
// Job WURDE GESCHRIEBEN
// Servicetype-Name (Fahrrad etc.)
$srvt_name = $db->getOne(
"SELECT mt_value FROM metatype WHERE mt_sort = '$vht_id' AND mt_type = 'vehicletype'");
// Ermittlung der Kostenübernahme
// wenn Fixpreis, dann keine Kostenerfassung in tourservice
// if (($jb_fixprice == "" || $jb_fixprice == 0) && $jb_fixprice != "0.00"):
$costsplit_count = 0;
// Kostenteilung? (wenn kein payer gesetzt)
for ($i = 0; $i < count($jobList); $i++):
if ($jobList[$i][JL_CSC_ID] == ""):
if ($jobList[$i][JL_TR_COMP] == "" ||
$jobList[$i][JL_AD_STREET] == "" ||
$jobList[$i][JL_TR_HSNO] == "" ||
$jobList[$i][JL_AD_ZIPCODE] == "" ||
$jobList[$i][JL_AD_CITY] == ""):
// Abbruchbedingung: csc_id leer und nicht genügend Angaben für eine
// neue Kostenstelle -> Auftrag vollständig durchlaufen
break;
endif;
else:
// csc_id gesetzt:
// wenn Kostenteilung, dann diese Kostenstelle mitzählen
$costsplit_count++;
if ($jobList[$i][JL_CSC_ID_PAYER] == "true"):
$csc_id_payer = $jobList[$i][JL_CSC_ID];
// Payer gefunden:
// Anzahl Payer auf 1 setzen
$costsplit_count = 1;
// Grundpreis des Auftrags (Anfahrtskosten) speichern
// wenn Kostensplit, wird er später anteilig bei jeder Etappenstelle einzeln gespeichert
// saveServiceCosts("Grundpreis", $srvt_name, $hq_id, $cs_id, $jb_id, 0, $jb_ordertime, 0, 1, $getPriceOnly, $jb_cash, (($jb_costsplit == "false" || MASK_CASH_PAYER_SELECT == "1") ? $tmpCsc_id_payer : ""), $jb_storno, false, false, false);
break;
endif;
endif;
endfor;
// endif;
// potentiellen Drittzahler berücksichtigen.
// Der wird direkt übergeben und ist in der job_list nicht vorhanden!!!
if ($csc_id_payer != "" && $csc_id_payer != "0")
$costsplit_count = 1;
// $csc_id_payer = "";
// Barzahlung berücksichtigen
if ($jb_cash == "true"):
// Achtung: wenn MASK_CASH_PAYER_SELECT gesetzt, dann ist auf jeden Fall ein Bezahler
// gesetzt, der natürlich auch erhalten bleiben muss!
if (MASK_CASH_PAYER_SELECT != "1"):
$csc_id_payer = "-1";
if (CSC_ID_PAYER_CASH != ""):
$csc_id_payer = CSC_ID_PAYER_CASH;
endif;
endif;
$costsplit_count = 1;
// Barzahlung
$jb_payment = 2;
else:
// Zahlungsmodus festhalten
if ($jb_costsplit == "true" && MASK_CASH_PAYER_SELECT != "1"): // Achtung: MASK_CASH_PAYER_SELECT entscheidet, ob 'jb_costsplit' Rechnungszahlung bedeutet!
// Rechnung mit Kostensplit
$jb_payment = 1;
else:
// Rechnung an den angegebenen Bezahler
$jb_payment = 0;
endif;
endif;
if ($csc_id_payer == 0 || $csc_id_payer == ""): // csc_id_payer == 0 ==> Kostensplit
$cs_invmode = getFieldValueFromId("headquarters", "hq_id", "$hq_id", "hq_invmode");
$cs_id = 0;
else:
$cs_id = getFieldValueFromId("costcenter", "csc_id", "$csc_id_payer", "cs_id");
// invmode ermitteln (ist abhängig von dem aktuellen Bezahler), kann neuerdings auch von der Ksotenstelle bestimmt werden
if (getParameterValue("0", "COSTCENTER_INV_MODE_" . $csc_id_payer, "0") != "") {
$cs_invmode = getParameterValue("0", "COSTCENTER_INV_MODE_" . $csc_id_payer, "0");
} else {
$cs_invmode = getFieldValueFromId("customer", "cs_id", "$cs_id", "cs_invmode");
}
endif;
if (MASK_CR_PRICE_MODE == "1") {
$vhtSrvt_name = $db->getOne("SELECT mt_value FROM metatype WHERE mt_sort = '$vht_id' AND mt_type = 'vehicletype'");
$fuel_cr_markup = getFuelMarkupCr($vhtSrvt_name, (trim($cs_id) != "" ? $cs_id : 0), $hq_id, $jb_ordertime);
//writeLog_("../log/job2_options_", "\$jb_id=|$jb_id|\$vhtSrvt_name=|$vhtSrvt_name|");
//writeLog_("../log/job2_options_", "\$jb_id=|$jb_id|\$fuel_cr_markup=|$fuel_cr_markup|");
}
// Der Bezahler steht jetzt erst fest; da es neuerdings einen Fall gibt, wo der Bezahler im Zusammenhang mit seinen Wunschkurieren
// den Status bestimmt, muss das hier jetzt abgefackelt werden (wenn mind. ein Wunschkurier vorhanden, dann kein autoranking)
// Darf natürlich kein Storno oder Dauerauftrag bzw. Reservierung sein!
$job_fav_crs = $db->getOne("SELECT COUNT(*) FROM customercourier WHERE cs_id = $cs_id AND cscr_relation = 1");
if ($job_fav_crs > 0 &&
MASK_FAVOURED_COURIER_MANUAL == "1" && $afterwards != "1" && $job_is_new && (!isset($jb_storno) || $jb_storno == 0)
&& (/*(($jb_permanent == "" || $jb_permanent == 0) && $jb_reserv != 1) && */$assigned_cr_id == "")):
$tmpArr = array("jb_status", "9", "jb_cr_fav", 1);
updateStmt("job", "jb_id", $jb_id, $tmpArr);
elseif (($job_fav_crs) > 0):
$tmpArr = array("jb_cr_fav", 1);
updateStmt("job", "jb_id", $jb_id, $tmpArr);
endif;
$jb_mediationarea_id = "";
$jb_mediationarea_name = "";
// Mediation-Area (PLZ-Bereiche oder Vermittlungsbereiche) für Auftragsliste festhalten
// jetzt MODE_INTERMEDIATION statt $hq_invmode (letzterer nur noch für Abrechnung, aber nicht mehr für Vermittlung)
if (MODE_INTERMEDIATION == 1):
$jb_mediationarea_id = $db->getOne(
"SELECT srvp_id FROM serviceplz WHERE srvp_plz = '" . $jobList[0][JL_AD_ZIPCODE] . "'");
$jb_mediationarea_name = $jobList[0][JL_AD_ZIPCODE];
elseif(MODE_INTERMEDIATION == 2 || MODE_INTERMEDIATION == 3):
$srvp_id = $db->getOne(
"SELECT srvp_id FROM serviceplz WHERE srvp_plz = '" . $jobList[0][JL_AD_ZIPCODE] . "'");
$jb_mediationarea_id = $db->getOne(
// "SELECT srvpa_id FROM serviceplzareamapping WHERE srvp_id = '" . $srvp_id . "'");
"SELECT srvpam.srvpa_id FROM serviceplzareamapping AS srvpam, serviceplzarea AS srvpa WHERE srvpam.srvp_id = '" . $srvp_id . "' AND srvpam.srvpa_id = srvpa.srvpa_id AND srvpa.hq_id = '$hq_id'");
$jb_mediationarea_name = $db->getOne(
"SELECT srvpa_name FROM serviceplzarea WHERE srvpa_id = '" . $jb_mediationarea_id . "'");
endif;
$hq_id_exec = $db->getOne("SELECT hq_id FROM serviceplz WHERE srvp_plz = '" . $jobList[0][JL_AD_ZIPCODE] . "'");
if ($hq_id_exec == "")
$hq_id_exec = $hq_id;
// Den noch fehlenden Rotz zum bestehenden Auftrag hinzuschreiben..
$tmpArr = array(
"jb_payment", $jb_payment,
"jb_mediationarea_id", $jb_mediationarea_id,
"jb_mediationarea_name", $jb_mediationarea_name,
"hq_id_exec", $hq_id_exec);
updateStmt("job", "jb_id", $jb_id, $tmpArr);
// ************************************************************************************************
// Ab hier werden Preise ermittelt und ggfs. gespeichert
// Treibstoffzuschlag in Prozent ermitteln
$jb_markup = getFuelMarkup($srvt_name, $cs_id, $hq_id, $jb_ordertime);
// Achtung: Beim Speichern in tourservice (bzw. Aufruf von saveservicecosts)
// Barzahlung mit ausgewähltem Bezahler berücksichtigen!
$tmpCsc_id_payer = $csc_id_payer;
if ($jb_payment == 2 && MASK_CASH_PAYER_SELECT == "1"):
if (CSC_ID_PAYER_CASH != ""):
$tmpCsc_id_payer = CSC_ID_PAYER_CASH;
else:
$tmpCsc_id_payer = "-1";
endif;
endif;
// Achtung: "Listenkunden" bekommen immer einen Fixpreis "0.00"
if (($db->getOne("SELECT cs_jobbatch from customer WHERE cs_id = $cs_id") == 1) /* && ($jb_fixprice == "" || $jb_fixprice == 0)*/ && $afterwards != "1"):
// Nicht Listenmodus wenn Nacherfassung!!!
$jb_fixprice = "0.00";
// Preis soll für den Eintrag ins Bemerkungsfeld ermittelt, aber nicht als offizieller Preis gespeichert werden
$jobbatch_mode = true;
endif;
//echo "$jb_fixprice
";
if (($jb_fixprice == "" || $jb_fixprice == 0 || $jobbatch_mode == true) /* && $jb_fixprice != "0.00"*/ && getFieldValueFromClause("parameter", "par_value", "par_key='MASK_CS_DONT_MAKE_STANDARD_PRICE_" . $cs_id . "'") != "1" && getParameterValue("0", "CUSTOMER_MASK_CALCULATOR_USAGE_ONLY_" . $cs_id, "0") != "1"):
//echo "Grundpreisberechnung
";
list ($fp, $fd, $fpm, $final_cr_price, $final_cr_discount, $final_cr_price_markup, $customer_specific, $special_address, $validfrom) =
saveServiceCosts("Grundpreis", $srvt_name, $hq_id, $cs_id, $jb_id, 0, $jb_ordertime, 0, $costsplit_count, (($getPriceOnly == 1 || $jobbatch_mode) ? 1 : 0), $jb_cash, (($jb_costsplit == "false" || MASK_CASH_PAYER_SELECT == "1") ? $tmpCsc_id_payer : ""), $jb_storno, false, false, false, $jb_markup, $fuel_cr_markup, $vht_id);
$gross_price += $fp;
$fullPrice += round($fp * ((100-$fd)/100), 2);
$jb_subtotal += round($fpm * ((100-$fd)/100), 2);
$discount_sign = ($special_address || $discount_sign == "**" ? "**"
: ($discount_sign = ($fd > 0 || $customer_specific || $discount_sign == "*" ? "*" : "")));
$jb_cr_subtotal += round($final_cr_price_markup * ((100-$fd-$self_service_discount)/100), 2);
$fullCrPrice += round($final_cr_price * ((100-$fd-$self_service_discount)/100), 2);
endif;
//echo "Fixpreis direkt
";
if (!($jb_fixprice == "" || $jb_fixprice == 0) || $jobbatch_mode == true /* && $jb_fixprice != "0.00"*/):
if ($jb_storno == 0):
// Km-Preis?
//echo ($km_price_params) . "
\n";
$km_price_paramsArrArr = array();
if (!(strpos($km_price_params, "|") === FALSE)) {
$km_price_paramsArr = explode("|", $km_price_params);
$jb_price_km = (float) str_replace(",", ".", explode(" ", $km_price_paramsArr[0])[0]);
if ($km_price_paramsArr[3] != "zone") {
$price_per_km = explode(" ", $km_price_paramsArr[1])[0];
$basic_price = explode(" ", trim(str_replace("+", "", $km_price_paramsArr[2])))[0];
$km_price_params = str_replace(",", ".", $jb_price_km . "|" . $price_per_km . "|" . $basic_price);
} else {
$km_price_paramsArr[1] = str_replace("[n]", "(n)", str_replace("(", "", str_replace(")", "", str_replace("(n)", "[n]", $km_price_paramsArr[1]))));
$km_price_paramsArrArr = explode("+", $km_price_paramsArr[1]);
if ($km_price_paramsArr[4] != "") {
if ($km_price_paramsArr[4][strlen($km_price_paramsArr[4]) - 1] == ",")
$km_price_paramsArr[4] = substr($km_price_paramsArr[4], 0, strlen($km_price_paramsArr[4]) - 1);
$ro_types = explode(";", $km_price_paramsArr[4]);
deleteStmt("phoenix_log.route", "jb_id = " . $jb_id);
$db_geo = get_db_geo();
if (is_null($db_geo)) {
$db_geo = getDbConnectionSpecial("172.16.0.111:3711", "address_geo", $dblogin, $dbpassword);
$res = $db_geo->query('SET NAMES latin1');
if (DB::isError($res)) reportDie ("$PHP_SELF: 'SET NAMES latin1' : " . $res->getMessage());
}
$sqlquery = "SELECT di_id, di_distance, di_duration, di_polyline, di_modify FROM address_geo.distance WHERE di_id IN (" . str_replace(";", ",", $km_price_paramsArr[4]) . ")";
writeLog_xServer("job2_options: [" . $sqlquery . "]");
$res = $db_geo->query($sqlquery);
if (DB::isError($res)) reportDie ("$PHP_SELF: '$sqlquery' : " . $res->getMessage());
$cnt = 0;
while ($row = ($phpVersion >= "8.0" ? $res->fetch_assoc() : $res->fetchRow())):
insertStmt("phoenix_log.route", array("jb_id", $jb_id, "di_id", $row["di_id"], "ro_distance", $row["di_distance"], "ro_duration", $row["di_duration"], "ro_polyline", $row["di_polyline"], "ro_num", ++$cnt,
"ro_type", (!(strpos($ro_types[1], $row["di_id"]) === false) ? 1 : 0), "ro_date", $row["di_modify"]));
endwhile;
$res->free();
}
$fixprice_min = $km_price_paramsArr[5];
}
}
// Fixpreis wird direkt (unter Berücksichtigung eines evtl. Discounts und des Treibstoffzuschlages) in der tourservice-Tabelle gespeichert
$tmpArr = array(
"jb_id", $jb_id, "tr_sort", 0, "srv_id", 0, "trs_srv_name",
"Fixpreis", "srvt_id", 0, "trs_srvt_name", (isset($km_price_paramsArr[3]) && $km_price_paramsArr[3] != "zone" ? $km_price_params : $fixprice_min),
"trs_price", round($jb_fixprice * (1 + ($jb_markup / 100)), 2) - round(round($jb_fixprice * (1 + ($jb_markup / 100)), 2) * $self_service_discount / 100, 2),
"trs_discount", $tmp_discount_rate, "csc_id",
(($jb_costsplit == "false" || MASK_CASH_PAYER_SELECT == "1") ? ($jb_cash == "true" ? CSC_ID_PAYER_CASH : $tmpCsc_id_payer) : ""));
insertStmt("tourservice", $tmpArr);
$tr_sort = 1;
foreach($km_price_paramsArrArr as $trs_srv_name) {
$tmpArr = array(
"jb_id", $jb_id, "tr_sort", $tr_sort++, "srv_id", 0, "trs_srv_name",
trim($trs_srv_name), "srvt_id", 0, "trs_srvt_name", "z",
"trs_price", 0, "trs_discount", 0, "csc_id",
(($jb_costsplit == "false" || MASK_CASH_PAYER_SELECT == "1") ? ($jb_cash == "true" ? $CSC_ID_PAYER_CASH_VAR : $tmpCsc_id_payer) : ""));
insertStmt("tourservice", $tmpArr);
}
endif;
endif;
if (!($jb_serviceprice == "" || $jb_serviceprice == 0)):
if ($jb_storno == 0):
// Servicepreis wird direkt in der tourservice-Tabelle gespeichert (ohne Treibstoffzuschlag)
$tmpArr = array(
"jb_id", $jb_id, "tr_sort", 0, "srv_id", 0, "trs_srv_name",
"Servicepreis", "srvt_id", 0, "trs_srvt_name", "",
"trs_price", $jb_serviceprice, "trs_discount", $tmp_discount_rate, "csc_id",
(($jb_costsplit == "false" || MASK_CASH_PAYER_SELECT == "1") ? ($jb_cash == "true" ? CSC_ID_PAYER_CASH : $tmpCsc_id_payer) : ""));
insertStmt("tourservice", $tmpArr);
endif;
endif;
$jsAddNewExternCostcenter = "";
$prev_ad_id = "";
$prev_tr_mediationarea_id = 0;
$jb_tourdata1 = "";
$jb_tourdata2 = "";
$jb_tourdata3 = "";
// die einzelnen Etappenstellen abspeichern
for ($i = 0; $i < count($jobList); $i++):
$csc_id = $jobList[$i][JL_CSC_ID];
// *** Externe Kostenstelle (Anfang) ***
if ($csc_id == ""):
// Wenn csc_id leer, dann muss eine neue externe Kostenstelle
// angelegt werden; das Sendeformular muss sicherstellen, dass
// alle notwendigen Informationen (Firma, Strasse, Nr., PLZ, Ort)
// vorhanden sind!
// Die neue externe Kostenstelle darf niemals Zahler sein!
//
if ($jobList[$i][JL_TR_COMP] == "" ||
$jobList[$i][JL_AD_STREET] == "" ||
$jobList[$i][JL_TR_HSNO] == "" ||
$jobList[$i][JL_AD_ZIPCODE] == "" ||
$jobList[$i][JL_AD_CITY] == "")
// Abbruchbedingung: csc_id leer und nicht genügend Angaben für eine
// neue Kostenstelle
break;
// die Adresse der neuen KSt speichern/überprüfen (wenn nicht gültig, dann Abbruch!)
// die neue Adresse wird in jedem Fall gespeichert, ob nur Preisanfrage oder
// neuer Auftrag
list($ad_id, $tr_hsno, $tr_comp, $tr_remark, $tr_person, $tr_phone) =
insertAddress($jobList[$i][JL_AD_STREET] . "|" . $jobList[$i][JL_TR_HSNO],
$jobList[$i][JL_AD_ZIPCODE], $jobList[$i][JL_AD_CITY], $csc_id, $jobList[$i][JL_AD_COUNTRY], ($accept_all_addresses == "1"));
if ($ad_id == "" && $accept_all_addresses != "1"):
// address invalid -> I must die...
// error-message is in tr_person, rest is empty
$statusMessageTxt = $tr_person;
$addressValid = "";
break;
endif;
if (MASK_CREATE_EXTERN_COSTCENTER != "1"):
$csc_id = CSC_ID_PAYER_EXTERN;
// $cs_id = getFieldValueFromId("costcenter", "csc_id", "$csc_id", "cs_id");
else:
// Da haben wir den Salat: Wenn Zentralenauftrag (cs_id = 0), dann neuer externer Kunde
// statt neue externe Kostenstelle
if ($cs_id != 0): // => nicht Zentralenauftrag
// Kundenauftrag -> neue externe Kostenstelle
// Prüfen, ob die Kostenstelle "Extern" vorhanden ist
if (!existsEntry("costcenter", array("cs_id", $cs_id, "csc_name", "Extern"))):
// Neue Kostenstelle "Extern" anlegen, die neue externe Kostenstellen aufnimmt
$csc_id_root = getFieldValueFromId("customer", "cs_id", "$cs_id", "csc_id");
$csc_name_root = getFieldValueFromId("costcenter", "csc_id", "$csc_id_root", "csc_name");
$tmpArr = array(
"cs_id", $cs_id, "csc_pre_id", $csc_id_root,
"csc_name", "Extern", "csc_path", "//" . my_str_check($csc_name_root) . "//", "csc_is_extern", 1);
insertStmt("costcenter", $tmpArr);
$csc_pre_id = getLastInsertId();
$csc_path = "//" . my_str_check($csc_name_root) . "//Extern//";
else:
// Kostenstelle "Extern" ist vorhanden; diese wird Parent der
// neuen externen Kostenstelle
$csc_pre_id = $db->getOne(
"SELECT csc_id FROM costcenter WHERE cs_id = '$cs_id' AND csc_name = 'Extern'");
$csc_path = my_str_check($db->getOne(
"SELECT csc_path FROM costcenter WHERE csc_id = '$csc_pre_id'") .
$db->getOne(
"SELECT csc_name FROM costcenter WHERE csc_id = '$csc_pre_id'")) . "//";
endif;
// Die Kostenstelle Extern (neu angelegt oder bestehend) ist Parent der neuen Kostenstelle
endif;
// *** Folgendes gilt für beide Fälle (Kunden- oder Zentralenauftrag) ***
$csc_name = $jobList[$i][JL_TR_COMP];
//
if ($cs_id != 0):
// Kundenauftrag: neue externe Kostenstelle
// eindeutigen Namen für die neue Kostenstelle finden
if ($getPriceOnly != 1): // nicht wenn nur Preisabfrage
$j = 0;
while (existsEntry("costcenter", array("cs_id", $cs_id, "csc_name", $csc_name))):
$csc_name = $jobList[$i][JL_TR_COMP] . "_" . ++$j;
endwhile;
// Neue externe Kostenstelle mit eindeutigem Namen unter "Extern" anlegen
$tmpArr = array("cs_id", $cs_id, "csc_pre_id", $csc_pre_id,
"csc_name", $csc_name, "csc_path", $csc_path, "csc_is_extern", 1);
insertStmt("costcenter", $tmpArr);
$csc_id = getLastInsertId();
endif;
else:
// Zentralenauftrag: Neuer Kunde nötig
// Neuen Kunden anlegen (nicht wenn nur Preisabfrage)
//
// Neue Kostenstelle für den neuen Kunden anlegen
if ($getPriceOnly != 1):
$tmpArr = array("csc_name", $csc_name, "csc_is_extern", 1);
insertStmt("costcenter", $tmpArr);
$csc_id = getLastInsertId();
// Insert company
$tmpArr = array("cmp_comp", $jobList[$i][JL_TR_COMP], "ad_id", $ad_id,
"cmp_hsno", $tr_hsno, "cmp_authenticated", "1");
insertStmt("company", $tmpArr);
$cmp_id_new = getLastInsertId();
// Insert customer
// ACHTUNG: cs_invmode HARTKODIERT NUR FÜR HANSETRANS! Sollte eigentlich aus DB geholt werden...
// MC: cs_invmode auf "2" setzen... (bzw. default in Abhängigkeit von Zentrale)
$tmpArr = array("cmp_id", $cmp_id_new, "hq_id", $hq_id, "csc_id", $csc_id, "cs_invmode", 2);
insertStmt("customer", $tmpArr);
$cs_id_new = getLastInsertId();
// Update new costcenter with new customer
$tmpArr = array("cs_id", $cs_id_new);
updateStmt("costcenter", "csc_id", $csc_id, $tmpArr);
// Update the costcenteraddresses (without type '4' which follows below)
$tmpArr =
array("csc_id", $csc_id, "cscad_comp", $jobList[$i][JL_TR_COMP], "ad_id", $ad_id, "adt_id", 1, "cscad_hsno", $tr_hsno, "cscad_remark", "", "cscad_person", "", "cscad_phone", "");
insertStmt("costcenteraddress", $tmpArr);
$tmpArr =
array("csc_id", $csc_id, "cscad_comp", $jobList[$i][JL_TR_COMP], "ad_id", $ad_id, "adt_id", 2, "cscad_hsno", $tr_hsno, "cscad_remark", "", "cscad_person", "", "cscad_phone", "");
insertStmt("costcenteraddress", $tmpArr);
$tmpArr =
array("csc_id", $csc_id, "cscad_comp", $jobList[$i][JL_TR_COMP], "ad_id", $ad_id, "adt_id", 3, "cscad_hsno", $tr_hsno, "cscad_remark", "", "cscad_person", "", "cscad_phone", "");
insertStmt("costcenteraddress", $tmpArr);
endif;
endif;
// *** Folgendes gilt wieder für beide Fälle (Kunden- oder Zentralenauftrag) ***
// Neue Costcenteraddress Typ "Lieferadresse" anlegen (nicht wenn nur Preisabfrage)
if ($getPriceOnly != 1):
$sqlStmt =
"INSERT INTO costcenteraddress (csc_id, cscad_comp, adt_id, ad_id, cscad_hsno, cscad_remark, cscad_person, cscad_phone) " .
"VALUES ($csc_id, '" . $jobList[$i][JL_TR_COMP] .
"', 4, $ad_id, '" . $jobList[$i][JL_TR_HSNO] . "', '" .
$jobList[$i][JL_TR_REMARK] . "', '" . $jobList[$i][JL_TR_PERSON] . "', '')";
$res = $db->query($sqlStmt);
if (DB::isError($res)) reportDie ("$PHP_SELF: '$sqlStmt': " . $res->getMessage());
if ($cs_id != 0):
// Kundenauftrag
// war noch für die alte Version mit den Drop-Down-Listen der csc_ids...
// $jsAddNewExternCostcenter .= "addOption(\"job_tour\", \"tourForm\", \"von_csc_id\", \"" . $csc_name. "\", false, false);\n"
// . "addOption(\"job_tour\", \"tourForm\", \"nach_csc_id\", \"" . $csc_name. "\", false, false);\n";
$jsAddNewExternCostcenter = "";
endif;
endif;
endif;
endif;
// *** Externe Kostenstelle (Ende) ***
// *** Kostenstelle liegt vor (Anfang) ***
// Ab hier liegt eine gültige csc_id vor (neu angelegt oder bestehend)
// (nicht bei nur Preisanfrage)
// *** Speichern der Etappenstelle in Tour ***
// zuerst Spiechern/Ermitteln ob Adresse gültig
list($ad_id, $tr_hsno, $tr_comp, $tr_remark, $tr_person, $tr_phone) =
insertAddress($jobList[$i][JL_AD_STREET] . "|" . $jobList[$i][JL_TR_HSNO],
$jobList[$i][JL_AD_ZIPCODE], $jobList[$i][JL_AD_CITY], $csc_id, $jobList[$i][JL_AD_COUNTRY], ($accept_all_addresses == "1"));
// PLZ und Ort werden für einfachere Übersicht in jb_tourdata zwischengespeichert
$jb_tourdata1 .= ($jb_tourdata1 == "" ? "" : ";") . $jobList[$i][JL_AD_ZIPCODE];
$jb_tourdata2 .= ($jb_tourdata2 == "" ? "" : ";") . $jobList[$i][JL_AD_CITY];
$jb_tourdata3 .= ($jb_tourdata3 == "" ? "" : ";") . (trim($jobList[$i][JL_AD_COUNTRY]) == "" ? "DE" : $jobList[$i][JL_AD_COUNTRY]);
// tr_phone ist neu für Hamburg
$tr_phone = $db->getOne("SELECT cscad_phone FROM costcenteraddress INNER JOIN costcenter ON costcenteraddress.csc_id = costcenter.csc_id" .
" WHERE costcenteraddress.csc_id = $csc_id AND costcenteraddress.adt_id = 4");
if ($ad_id == "" && $accept_all_addresses != "1"):
// address invalid -> I must die...
// error-message is in tr_person, rest is empty
// $statusMessageTxt = "Houston, we've got a problem...";
$statusMessageTxt = $tr_person;
$addressValid = "";
break;
endif;
// Ergänzen der fehlenden Angaben
// if ($jobList[$i][JL_TR_HSNO] != "")
$tr_hsno = my_str_check_mobile($jobList[$i][JL_TR_HSNO]);
// if ($jobList[$i][JL_TR_COMP] != "")
$tr_comp = my_str_check_mobile($jobList[$i][JL_TR_COMP]);
// if ($jobList[$i][JL_TR_PERSON] != "")
$tr_person = my_str_check_mobile($jobList[$i][JL_TR_PERSON]);
// $tr_remark = "";
if (/*$jobList[$i][JL_TR_REMARK] != "" && */ $jobList[$i][JL_HIDE_TR_REMARK] != "false")
$tr_remark = my_str_check_mobile($jobList[$i][JL_TR_REMARK]);
// Wenn Fuhrlohn angezeigt werden soll, erstmal den alten entfernen
if ((MASK_JB_CR_PRICE_2_TR_REMARK == "1" || MASK_JB_MEASURES_2_TR_REMARK == "1") && (!(strpos($tr_remark, "[[") === false) || !(strpos($tr_remark, "||") === false))):
if (!(strpos($tr_remark, "||") === false)) {
$jb_cr_priceStr = strstr($tr_remark, "||");
$jb_cr_priceStr = substr($jb_cr_priceStr, 0, strpos($jb_cr_priceStr, "||", 2) + 2);
} else {
$jb_cr_priceStr = strstr($tr_remark, "[[");
$jb_cr_priceStr = substr($jb_cr_priceStr, 0, strpos($jb_cr_priceStr, "]]", 2) + 2);
}
$tr_remark = str_replace("\n" . $jb_cr_priceStr, "", $tr_remark);
$tr_remark = str_replace($jb_cr_priceStr, "", $tr_remark);
endif;
$tr_remark = str_replace("\n*** ZAHLT BAR ***", "", $tr_remark);
$tr_remark = str_replace("*** ZAHLT BAR ***", "", $tr_remark);
// $tr_remark = preg_replace("/\n\*\*\* FESTPREIS \(LISTE\) EUR .* \*\*\*/", "", $tr_remark);
// $tr_remark = preg_replace("/\*\*\* FESTPREIS \(LISTE\) EUR .* \*\*\*/", "", $tr_remark);
$tr_remark_add = "";
if (MASK_JB_CR_PRICE_2_TR_REMARK == "1" && (($i + 1) == 1)):
$tr_remark_add = "{JB_CR_PRICE_TOTAL}";
if (trim($jb_toll) != "")
$tr_remark_add .= "Maut: " . str_replace(".", ",", $jb_toll) . " EUR\n";
endif;
// Maße und Gewichte
if (MASK_JB_MEASURES_2_TR_REMARK == "1" && (($i + 1) == 1)):
if ($jb_weight > 0) { $tr_remark_add .= "Maximalgewicht: " . $jb_weight . " kg\n";}
if ($jb_crvh_length > 0) { $tr_remark_add .= my_str_check_mobile("Länge: ") . $jb_crvh_length . " cm\n";}
if ($jb_crvh_width > 0) { $tr_remark_add .= "Breite: " . $jb_crvh_width . " cm\n";}
if ($jb_crvh_height > 0) { $tr_remark_add .= my_str_check_mobile("Höhe: ") . $jb_crvh_height . " cm\n";}
if ($jb_crvh_position > 0) { $tr_remark_add .= my_str_check_mobile("Plätze: ") . $jb_crvh_position . "\n";}
endif;
if ($tr_remark_add != "") {
$tr_remark .= "\n[[\n" . $tr_remark_add . "]]";
$tr_remark = str_replace("\n\n[[", "\n[[", $tr_remark);
}
if ($jb_cash == "true" && $jobList[$i][JL_CSC_ID_PAYER] == "true")
// Wenn Barzahlung und Bezahler angegeben, dann hier festhalten!
$tr_remark .= "\n*** ZAHLT BAR ***";
if ($jobbatch_mode == true && $jobList[$i][JL_CSC_ID_PAYER] == "true")
// Wenn Listenzahler und Bezahler angegeben, dann hier tournummer merken,
// damit zum Schluß hier der Preis gespeichert werden kann!
$tr_sort_jobbatchmode = ($i + 1);
$tr_ware_from_to = 0; // Weder Abholung noch Anlieferung
if ($jobList[$i][JL_TR_WARE_FROM] == "true")
$tr_ware_from_to = 2; // Nur Abholung
if ($jobList[$i][JL_TR_WARE_TO] == "true")
$tr_ware_from_to += 1; // Nur Anlieferung: 1; Abholung + Anlieferung: 3
$tr_photo = "";
if ($jobList[$i][JL_TR_PHOTO] == "true" ||
((getFieldValueFromClause("parameter", "par_value", "par_key='MASK_TR_PHOTO_CS_" . getFieldValueFromId("costcenter", "csc_id", "$csc_id_payer", "cs_id") . "'") == "2" ||
getFieldValueFromClause("parameter", "par_value", "par_key='MASK_TR_PHOTO_CS_" . getFieldValueFromId("costcenter", "csc_id", "$csc_id_payer", "cs_id") . "'") == "3")
&& $i > 0)):
$tr_photo = getFieldValueFromClause("parameter", "par_value", "par_key='MASK_MIN_MAX_TR_PHOTO_CS_" . getFieldValueFromId("costcenter", "csc_id", "$csc_id_payer", "cs_id") . "'");
//echo "MASK_MIN_MAX_TR_PHOTO_CS_" . getFieldValueFromId("costcenter", "csc_id", "$csc_id_payer", "cs_id") . ", " . $tr_photo; die();
if ($tr_photo == "")
$tr_photo = "1|1"; // Default: Mindestens ein Photo, höchstens eins (d.h. genau ein Foto)
endif;
// if ($jobList[$i][JL_TR_COMMISSION_NO] != "")
$tr_commission_no = my_str_check_mobile($jobList[$i][JL_TR_COMMISSION_NO]);
$tr_tracking = my_str_check_mobile($jobList[$i][JL_TR_TRACKING]);
$tr_mediationarea_id = $jobList[$i][JL_TR_MEDIATIONAREA_ID];
if ($tr_mediationarea_id == -1)
$tr_mediationarea_id = getMediationarea_id($hq_id, $jobList[$i][JL_AD_ZIPCODE], $jobList[$i][JL_AD_STREET], $tr_hsno);
if ($job_is_new): // Neuer Auftrag -> neue Tour
// Auftragsänderung mit neuer Tour
if ($getPriceOnly != 1):
$tmpArr = array( "jb_id", $jb_id, "ad_id", $ad_id, "tr_sort", ($i + 1),
"csc_id", $csc_id, "tr_comp", $tr_comp, "tr_person", $tr_person, "tr_phone", $tr_phone,
"tr_remark", $tr_remark, "tr_hsno", $tr_hsno, "tr_status", "0", "tr_ware_from_to", $tr_ware_from_to,
"tr_commission_no", $tr_commission_no, "tr_mediationarea_id", $tr_mediationarea_id);
insertStmt("tour", $tmpArr);
$tr_id = getLastInsertId();
if (trim($tr_photo) != "")
insertStmt("genericdatacontainer", array("gdc_obj_type", "tr", "gdc_obj_id", $tr_id, "gdc_gen_fieldname", "tr_photo", "gdc_content", $tr_photo, "gdc_context", $jb_id));
if (trim($tr_tracking) != "") {
insertStmt("genericdatacontainer", array("gdc_obj_type", "tr", "gdc_obj_id", $tr_id, "gdc_gen_fieldname", "tr_tracking", "gdc_content", $tr_tracking, "gdc_context", ""));
$tr_tracking_flag = true;
}
endif;
else:
// Testen, ob Eintrag schon vorhanden, falls geänderter Auftrag
$tr_id = $db->getOne(
"SELECT tr_id FROM tour WHERE jb_id = '$jb_id' AND tr_sort = '" . ($i + 1) . "'");
if ($tr_id != ""):
// Auftragsänderung -> ändern der bestehenden Tour wenn vorhanden
$tr_sign = $db->getOne(
"SELECT tr_status FROM tour WHERE jb_id = '$jb_id' AND tr_sort = '" . ($i + 1) . "'");
// if ($tr_sign != ""):
// if ($getPriceOnly != 1):
// $statusMessageTxt = "Etappenstelle Nr. " . ($i + 1) . " ist bereits unterschrieben und kann nicht mehr geändert werden!";
// $addressValid = "";
// endif;
// else:
// Status darf nicht gändert werden
if ($getPriceOnly != 1):
$tmpArr = array("ad_id", $ad_id,
"csc_id", $csc_id, "tr_comp", $tr_comp, "tr_person", $tr_person, "tr_phone", $tr_phone,
"tr_remark", $tr_remark, "tr_hsno", $tr_hsno, "tr_ware_from_to", $tr_ware_from_to,
"tr_commission_no", $tr_commission_no, "tr_mediationarea_id", $tr_mediationarea_id);
updateStmt("tour", "", "", $tmpArr, "jb_id = '$jb_id' AND tr_sort = '" . ($i + 1) . "'");
if (trim($tr_tracking) == "") {
deleteStmt("genericdatacontainer", "gdc_obj_type = 'tr' AND gdc_obj_id = " . $tr_id . " AND gdc_gen_fieldname = 'tr_tracking'");
} else {
$gdc_content = $db->getOne("SELECT gdc_content FROM genericdatacontainer WHERE gdc_obj_type = 'tr' AND gdc_gen_fieldname = 'tr_tracking' AND gdc_obj_id = " . $tr_id);
$gdc_content_arr = explode("|", $gdc_content);
if (count($gdc_content_arr) > 1) {
$gdc_content_add = "|" . $gdc_content_arr[1] . "|" . $gdc_content_arr[2];
}
if (trim($gdc_content) != "") {
updateStmt("genericdatacontainer", "gdc_obj_id", $tr_id, array("gdc_content", $tr_tracking . $gdc_content_add), "gdc_obj_type = 'tr' AND gdc_gen_fieldname = 'tr_tracking'");
} else {
insertStmt("genericdatacontainer", array("gdc_obj_type", "tr", "gdc_obj_id", $tr_id, "gdc_gen_fieldname", "tr_tracking", "gdc_content", $tr_tracking, "gdc_context", ""));
}
$tr_tracking_flag = true;
}
endif;
// endif;
else:
// Neue Tour im bestehenden Auftrag!
// -> Dies wird nur zugelassen wenn "Taximodus"
// (Erste Etappenstelle angegeben, zweite wird nachträglich angegeben)
$tour_cnt = $db->getOne("SELECT COUNT(*) FROM tour WHERE jb_id = '$jb_id'");
// if ($jb_status != 1): // - Beim nachträglichen Ändern einer Tour Sync-Problem wegen ‚jb_status' klären!
// Auftrag ist noch in der manuellen oder automatischen Vermittlung, oder der Kurier hat ihn noch ni
// genau eine Etappenstelle vorhanden => Taximodus
if ($getPriceOnly != 1):
$tmpArr = array( "jb_id", $jb_id, "ad_id", $ad_id, "tr_sort", ($i + 1),
"csc_id", $csc_id, "tr_comp", $tr_comp, "tr_person", $tr_person, "tr_phone", $tr_phone,
"tr_remark", $tr_remark, "tr_hsno", $tr_hsno, "tr_status", "0", "tr_ware_from_to", $tr_ware_from_to,
"tr_commission_no", $tr_commission_no, "tr_mediationarea_id", $tr_mediationarea_id);
insertStmt("tour", $tmpArr);
endif;
// else:
// // Auftrag ist bereits vermittelt oder fertig
// $statusMessageTxt = "Der Auftrag ist bereits vermittelt, es können keine Etappenstellen mehr hinzugefügt werden!";
// $addressValid = "";
// break;
// endif;
endif;
endif;
// Prüfen, ob aktuelle Etappenstelle der Bezahler des Auftrags ist
// es muss im Verlauf genau einen JL_CSC_ID_PAYER geben, der "true" ist
// ODER Kostenteilung!!!
if($jobList[$i][JL_CSC_ID_PAYER] == "true")
$csc_id_payer = $csc_id;
if ($jb_fixprice == "" || $jb_fixprice == 0 || $jobbatch_mode == true):
// - Grundpreis bei Kostensplit ab Etappenstelle 1
// if ($costsplit_count > 1)
// saveServiceCosts("Grundpreis", $srvt_name, $hq_id, $cs_id, $jb_id, ($i + 1), $jb_ordertime, 0, $costsplit_count, (($getPriceOnly == 1 || $jobbatch_mode) ? 1 : 0), $jb_cash, (($jb_costsplit == "false" || MASK_CASH_PAYER_SELECT == "1") ? $tmpCsc_id_payer : ""), $jb_storno, false, false);
if ($cs_invmode == 0):
// // - Preis für weitere Etappen ab Etappenstelle 3
// if (($i + 1) > 2):
// list ($fp, $fd, $fpm, $final_cr_price, $final_cr_discount, $final_cr_price_markup, $customer_specific, $special_address, $validfrom) =
// saveServiceCosts("Weitere
Adressen", $srvt_name, $hq_id, $cs_id, $jb_id, ($i + 1), $jb_ordertime, 0, $costsplit_count, (($getPriceOnly == 1 || $jobbatch_mode) ? 1 : 0), $jb_cash, (($jb_costsplit == "false" || MASK_CASH_PAYER_SELECT == "1") ? $tmpCsc_id_payer : ""), $jb_storno, false, false, false, $jb_markup, $fuel_cr_markup, $vht_id);
// $gross_price += $fp;
// $fullPrice += round($fp * ((100-$fd)/100), 2);
// $jb_subtotal += round($fpm * ((100-$fd)/100), 2);
// $discount_sign = ($special_address || $discount_sign == "**" ? "**"
// : ($discount_sign = ($fd > 0 || $customer_specific || $discount_sign == "*" ? "*" : "")));
// $jb_cr_subtotal += round($final_cr_price_markup * ((100-$fd-$self_service_discount)/100), 2);
// $fullCrPrice += round($final_cr_price * ((100-$fd-$self_service_discount)/100), 2);
// endif;
// // - Preis für Entfernungskilometer ab Etappenstelle 2
// if (($i + 1) > 1):
// $distance = ceil(getDistancePerID($ad_pre_id, $tr_pre_hsno, $ad_id, $tr_hsno));
// list ($fp, $fd, $fpm, $final_cr_price, $final_cr_discount, $final_cr_price_markup, $customer_specific, $special_address, $validfrom) =
// saveServiceCosts("km-Preis", $srvt_name, $hq_id, $cs_id, $jb_id, ($i + 1), $jb_ordertime, $distance, $costsplit_count, (($getPriceOnly == 1 || $jobbatch_mode) ? 1 : 0), $jb_cash, (($jb_costsplit == "false" || MASK_CASH_PAYER_SELECT == "1") ? $tmpCsc_id_payer : ""), $jb_storno, false, false, false, $jb_markup, $fuel_cr_markup, $vht_id);
// $gross_price += $fp;
// $fullPrice += round($fp * ((100-$fd)/100), 2);
// $jb_subtotal += round($fpm * ((100-$fd)/100), 2);
// $discount_sign = ($special_address || $discount_sign == "**" ? "**"
// : ($discount_sign = ($fd > 0 || $customer_specific || $discount_sign == "*" ? "*" : "")));
// $jb_cr_subtotal += round($final_cr_price_markup * ((100-$fd-$self_service_discount)/100), 2);
// $fullCrPrice += round($final_cr_price * ((100-$fd-$self_service_discount)/100), 2);
// endif;
elseif(getFieldValueFromClause("parameter", "par_value", "par_key='MASK_CS_DONT_MAKE_STANDARD_PRICE_" . $cs_id . "'") != "1" && getParameterValue("0", "CUSTOMER_MASK_CALCULATOR_USAGE_ONLY_" . $cs_id, "0") != "1"):
// Preisbestimmung aus PLZ-Matrix ab Etappenstelle 2
if (($i + 1) > 1):
// die Hamburger Fake-PLZs sind für Preisberechnung wichtig
$ad_id1 = $prev_ad_id . "³" . $tr_pre_hsno;
$zipcode1 = false;
if ($prev_tr_mediationarea_id != 0):
$ad_id1 = $prev_tr_mediationarea_id;
$zipcode1 = true;
endif;
$ad_id2 = $ad_id . "³" . $tr_hsno;
$zipcode2 = false;
if ($tr_mediationarea_id != 0):
$ad_id2 = $tr_mediationarea_id;
$zipcode2 = true;
endif;
//ab hier geht's normal weiter
list ($fp, $fd, $fpm, $final_cr_price, $final_cr_discount, $final_cr_price_markup, $customer_specific, $special_address, $validfrom) =
saveServiceCosts($ad_id1, $ad_id2, $hq_id, $cs_id, $jb_id, ($i + 1), $jb_ordertime, $distance, $costsplit_count, (($getPriceOnly == 1 || $jobbatch_mode) ? 1 : 0), $jb_cash, (($jb_costsplit == "false" || MASK_CASH_PAYER_SELECT == "1") ? $tmpCsc_id_payer : ""), $jb_storno, $zipcode1, $zipcode2, false, $jb_markup, $fuel_cr_markup, $vht_id);
$gross_price += $fp;
$fullPrice += round($fp * ((100-$fd)/100), 2);
$jb_subtotal += round($fpm * ((100-$fd)/100), 2);
$discount_sign = ($special_address || $discount_sign == "**" ? "**"
: ($discount_sign = ($fd > 0 || $customer_specific || $discount_sign == "*" ? "*" : "")));
$jb_cr_subtotal += round($final_cr_price_markup * ((100-$fd-$self_service_discount)/100), 2);
$fullCrPrice += round($final_cr_price * ((100-$fd-$self_service_discount)/100), 2);
endif;
$prev_ad_id = $ad_id;
$prev_tr_mediationarea_id = $tr_mediationarea_id;
endif;
$ad_pre_id = $ad_id;
$tr_pre_hsno = $tr_hsno;
endif;
// *** Kostenstelle liegt vor (Ende) ***
endfor;
// Wenn Etappenstellen gelöscht wurden, müssen sie auch in der Datenbank gelöscht werden!
deleteStmt("tour", "jb_id = $jb_id AND tr_sort >= '" . ($i + 1) . "'");
// Wenn nur eine Etappenstelle vorhanden, dann jb_incomplete für Nachbearbeitung setzen (Taximodus)
// if ($i == 1):
// $tmpArr = array("jb_incomplete", 1);
// else:
// $tmpArr = array("jb_incomplete", 0);
// endif;
// updateStmt("job", "jb_id", $jb_id, $tmpArr);
if ($addressValid == "ok"):
// Überprüfen, ob bei der Änderung eines Auftrages Etappenstellen gelöscht wurden
// MC: To test this get the next $i ...
// if (!$job_is_new): // geänderter Auftrag
// $ad_id_test = $db->getOne(
// "SELECT ad_id FROM tour WHERE jb_id = '$jb_id' AND tr_sort = '" . ($i + 1) . "'");
// if ($ad_id_test != ""):
// // Es existieren noch weitere Einträge -> mind. eine Etappenstelle gelöscht
// $statusMessageTxt = "Bei der Änderung eines Auftrages können keine Etappenstellen gelöscht werden!";
// $addressValid = "";
// endif;
// endif;
// der Bezahler des jobs wurde während des Speicherns der Touren ermittelt
// und wird jetzt gespeichert
if ($csc_id_payer != "")
if ($getPriceOnly != 1):
$tmpArr = array("csc_id_payer", $csc_id_payer);
if ($jb_payment == 2 && MASK_CASH_PAYER_SELECT == "1"):
if (CSC_ID_PAYER_CASH != ""):
$tmpArr = array("csc_id_payer", CSC_ID_PAYER_CASH, "csc_id_payer_cash", $csc_id_payer);
else:
$tmpArr = array("csc_id_payer", "-1", "csc_id_payer_cash", $csc_id_payer);
endif;
endif;
// 02.06.2023: Wenn der Auftrag mehr als ein Jahr in der Zukunft liegt, ist das vemutlich ein Irrtum, der
$jb_ordertime_vals = getValsFromDate($jb_ordertime);
if (!(isset($jb_storno) && $jb_storno > 0) && mktime(0, 0, 0, date("m"), date("d"), date("Y") + 1) <= mktime(0, 0, 0, $jb_ordertime_vals[1], $jb_ordertime_vals[2], $jb_ordertime_vals[0])):
include_once("../include/email/htmlMimeMail.php");
$mailObj = new htmlMimeMail();
$mailObj->setFrom("auto-mailer@assecutor.de");
$mailObj->setBcc("support@assecutor.de");
$mailObj->setSubject("Auftragsdatum von " . $jb_id . " liegt mehr als ein Jahr in der Zukunft.");
$mailObj->setText("Auftrag " . $jb_id . " ist vielleicht versehentlich mit dem Datum " . $jb_ordertime_vals[2] . "." . $jb_ordertime_vals[1] . "." . $jb_ordertime_vals[0] . " erfasst worden.\n ");
$mailResult = $mailObj->send(array(MAIL_SURVEY_ADDRESS_TO), 'smtp');
endif;
updateStmt("job", "jb_id", $jb_id, $tmpArr);
endif;
if (($jb_costsplit == "true" && MASK_CASH_PAYER_SELECT != "1") && !(isset($jb_storno) && $jb_storno > 0))
setCostsplit($jb_id);
// Wenn Tourname angegeben, prüfen, ob bereits existent;
// wenn ja, dann löschen
if ($jb_tourname != ""):
if ($getPriceOnly != 1)
if (existsEntry("job", array("jb_tourname", $jb_tourname, "csc_id_payer", $csc_id_payer)) ||
existsEntry("job", array("jb_tourname", $jb_tourname, "csc_id_payer_cash", $csc_id_payer))):
$tmpArr = array("jb_tourname", NULL);
updateStmt("job", "jb_tourname", $jb_tourname, $tmpArr, "(csc_id_payer = $csc_id_payer OR csc_id_payer_cash = $csc_id_payer)");
endif;
$tmpArr = array("jb_tourname", $jb_tourname);
// array_push ($insertStmtArr, "jb_tourname", $jb_tourname);
updateStmt("job", "jb_id", $jb_id, $tmpArr);
endif;
// Porto ermitteln und speichern; kompletten Preis speichern
if ($jb_fixprice == 0 && !(isset($jb_storno) && $jb_storno > 0)):
// wenn Fixpreis oder Storno, dann jb_subtotal bereits vorhanden
// sonst ermittelten Standardpreis nehmen
// $jb_subtotal bereits definiert
$jb_totalprice = $fullPrice;
if ($jb_cr_price == 0 && MASK_CR_PRICE_MODE == "1"):
$jb_cr_price_total = $fullCrPrice;
$jb_cr_price_rate = get_cr_price_rate($hq_id, $cs_id, $jb_ordertime, $vhtSrvt_name, $vht_id);
//writeLog_("../log/job2_options_", "\$jb_id=|$jb_id|\$jb_cr_price=|$jb_cr_price|");
endif;
else:
if (isset($jb_storno) && $jb_storno > 0):
$jb_totalprice = $jb_totalprice_storno;
$jb_subtotal = $jb_subtotal_storno;
$jb_cr_price_total = $jb_cr_price_storno;
else:
$jb_subtotal = round($jb_fixprice * (1 - ($tmp_discount_rate / 100)), 2);
$jb_totalprice = round($jb_subtotal * (1 + ($jb_markup / 100)), 2);
if (MASK_CR_PRICE_MODE == "1") {
if ($jb_cr_price == 0) {
list($jb_cr_subtotal, $jb_cr_price_rate) =
getCr_price_global($jb_subtotal, $hq_id, $cs_id, $jb_ordertime, $vhtSrvt_name, $vht_id);
writeLog_("../log/job2_options_", "\$jb_id=|$jb_id|\$jb_cr_subtotal=|$jb_cr_subtotal|\$jb_cr_price_rate=|$jb_cr_price_rate|");
} else {
$jb_cr_price = round($jb_cr_price * (1 - ($tmp_discount_rate / 100)), 2);
$jb_cr_subtotal = $jb_cr_price;
}
}
$gross_price = round($jb_fixprice * (1 + ($jb_markup / 100)), 2);
$jb_totalprice = round(($gross_price - round($gross_price * $self_service_discount / 100, 2)) * (1 - ($tmp_discount_rate / 100)), 2);
$jb_subtotal = round($jb_subtotal * ((100 - $self_service_discount) / 100), 2);
endif;
endif;
$jb_totalprice += round($jb_serviceprice * (1 - ($tmp_discount_rate / 100)), 2);
$jb_subtotal += round($jb_serviceprice * (1 - ($tmp_discount_rate / 100)), 2);
$jb_cr_serviceprice = round($jb_cr_serviceprice * (1 - ($tmp_discount_rate / 100)), 2);
// wenn Listenkunde, auch hier natürlich $jb_totalprice auf 0!!!
if ($jobbatch_mode == true):
$jb_subtotal = 0;
$jb_totalprice = 0;
$jb_cr_subtotal = 0;
endif;
if (MASK_CR_PRICE_MODE == "1") {
if ($jb_cr_serviceprice == 0)
list($jb_cr_serviceprice, $jb_cr_serviceprice_rate) =
getCr_price_global($jb_serviceprice, $hq_id, $cs_id, $jb_ordertime, $vhtSrvt_name, $vht_id);
//die($jb_serviceprice .", ". $jb_cr_serviceprice . ", " . $jb_cr_serviceprice_rate);
}
if (MASK_CR_PRICE_MODE == "1" && strtotime(MASK_CR_PRICE_MODE_DATE) <= strtotime($jb_ordertime) && (!isset($jb_storno) || $jb_storno == 0)) {
$jb_cr_subtotal = round($jb_cr_subtotal * (1 - ($self_service_discount / 100)), 2);
$jb_cr_price_total = round($jb_cr_subtotal * (1 + ($fuel_cr_markup / 100)), 2) + $jb_cr_serviceprice;
$jb_cr_subtotal += $jb_cr_serviceprice;
//writeLog_("../log/job2_options_", "\$jb_id=|$jb_id|\$jb_cr_price_total=|$jb_cr_price_total|");
}
list($usr_name, $usr_firstname) = getFieldsValueFromId("user", "usr_id", $usr_id, array("usr_name", "usr_firstname"));
$jb_commission_no = my_str_check($jb_commission_no);
$jb_commission_no_old = my_str_check($jb_commission_no_old);
updateStmt("job", "jb_id", $jb_id, array("jb_postage",
$db->getOne("SELECT cmp.cmp_postage"
. " FROM costcenter AS csc, customer AS cs, company AS cmp"
. " WHERE cmp.cmp_id = cs.cmp_id AND"
. " cs.cs_id = csc.cs_id AND"
. " csc.csc_id = '$csc_id_payer'"),
"jb_totalprice", $jb_totalprice, "jb_subtotalprice", $jb_subtotal, "jb_cr_price", $jb_cr_price_total, "jb_markup", $jb_markup, "jb_tourdata", $jb_tourdata1 . "|" . $jb_tourdata2 . "|" . $jb_tourdata3, "jb_origin", 4, "jb_orderer", $usr_firstname . " " . $usr_name, "jb_commission_no", $jb_commission_no));
//echo $jb_totalprice . "|
\n";die();
$db->query("DELETE FROM jobprice WHERE jb_id = " . $jb_id);
$insert_clause =
/*($jb_cr_markup > 0 ?*/ "(" . $jb_id . ", 1, " . $fuel_cr_markup . ",''), " /*: "")*/ .
($jb_cr_price > 0 ? "(" . $jb_id . ", 2, " . $jb_cr_price . ",''), " : "") .
// ($jb_cr_fixserviceprice > 0 ? "(" . $jb_id . ", 3, " . $jb_cr_fixserviceprice . ",''), " : "") .
// ($jb_cr_serviceprice > 0 ? "(" . $jb_id . ", 4, " . $jb_cr_serviceprice . ",''), " : "") .
($jb_cr_serviceprice > 0 ? "(" . $jb_id . ", 3, " . $jb_cr_serviceprice . ",''), " : "") .
($jb_cr_subtotal > 0 && isset($jb_cr_price_rate) && $jb_cr_price_rate > 0 ? "(" . $jb_id . ", 5, " . $jb_cr_price_rate . ",''), " : "") .
($jb_cr_serviceprice > 0 && $jb_cr_serviceprice_rate > 0 ? "(" . $jb_id . ", 6, " . $jb_cr_serviceprice_rate . ",''), " : "") .
// ($jb_cr_agio > 0 ? "(" . $jb_id . ", 7, " . $jb_cr_agio . ",''), " : "") .
($jb_cr_subtotal > 0 ? "(" . $jb_id . ", 10, " . $jb_cr_subtotal . ",''), " : "") .
($self_service_discount > 0 ? "(" . $jb_id . ", 13, " . $self_service_discount . ", '" . $gross_price . "'), " : "");
//echo "INSERT INTO jobprice (jb_id, mt_sort, jbprc_price, jbprc_remark) VALUES " . substr($insert_clause, 0, strlen($insert_clause) - 2); die();
$db->query("INSERT INTO jobprice (jb_id, mt_sort, jbprc_price, jbprc_remark) VALUES " . substr($insert_clause, 0, strlen($insert_clause) - 2));
if ($jb_price_km > 0) {
$db->query("INSERT INTO jobprice (jb_id, mt_sort, jbprc_price) VALUES (" . $jb_id . ", 15, " . $jb_price_km . ")");
}
// Rechnungstext erzeugen
if (!(isset($jb_storno) && $jb_storno > 0)):
mk_jb_invtext($jb_id, false);
endif;
// Job entsperren, falls gesperrt gewesen (Nachbearbeitung)
updateStmt("job", "jb_id", $jb_id, array("jb_locktime", NULL, "jb_lockuser", NULL));
// BWV_Auftrag?
$jb_longhaul = 0;
$tmpArr = array();
list($total_km, $total_km_osm) = get_job_distance($jb_id);
if ($total_km == -1)
$total_km = $db->getOne("SELECT jbprc_price FROM jobprice WHERE jb_id = " . $jb_id . " AND mt_sort = 11");
//echo $total_km . "|" . $tourCount . "|" . getParameterValue("0", "LONGHAUL_KM", "0");
if ($total_km > 0 && $tourCount > 1 && $total_km / ($tourCount - 1) >= getParameterValue("0", "LONGHAUL_KM", "0")) {
$jb_longhaul = 1;
$tmpArr = array("jb_status", 9);
}
array_push ($tmpArr, "jb_longhaul", $jb_longhaul);
updateStmt("job", "jb_id", $jb_id, $tmpArr);
if (MASK_CR_PRICE_MODE == "1") {
deleteStmt("genericdatacontainer", "gdc_obj_type = 'jb' AND gdc_obj_id = $jb_id AND gdc_gen_fieldname = 'jb_cr_serviceprice'");
// Service-Fuhrlohn wird extra gespeichert
//echo "|" . $jb_cr_serviceprice . "|";
if (trim($jb_cr_serviceprice) != "" && $jb_cr_serviceprice != 0)
insertStmt("genericdatacontainer", array("gdc_obj_type", "jb", "gdc_obj_id", $jb_id, "gdc_gen_fieldname", "jb_cr_serviceprice", "gdc_content", $jb_cr_serviceprice, "gdc_context", ""));
}
deleteStmt("genericdatacontainer", "gdc_obj_type = 'jb' AND gdc_obj_id = $jb_id AND gdc_gen_fieldname = 'jb_job_jam'");
if (trim($jb_jam_waittime) != "" && trim($jb_jam_waittime) != "undefined" && $jb_jam_waittime != 0):
$jb_jam_waittime *= 60;
if ($jb_reserv == 1)
$jb_jam_waittime = getParameterValue("0", "CS_JB_JAM_WAITTIME_RESERVATION_DEFAULT", "0") * -60; // (5 Min.); // Zeitzone beachten?
// was passiert wenn von den Zuzuweisenden ins Autoranking gkippt wird?
$jb_job_jam = date("Y-m-d H:i:s", strtotime($jb_ordertime) + $jb_jam_waittime);
insertStmt("genericdatacontainer", array("gdc_obj_type", "jb", "gdc_obj_id", $jb_id, "gdc_gen_fieldname", "jb_job_jam", "gdc_content", $jb_job_jam, "gdc_context", ""));
endif;
if (getParameterValue("0", "MASK_CUSTOMER_INCOMPLETE_" . $cs_id, "0") == "1") // 28.06.2021: Neuer Parameter für STH912809
$jb_incomplete = 1;
// Prüfen, ob jb_incomplete-Flag gesetzt werden muss
check_jb_incomplete($jb_id, $jb_incomplete);
// Prüfen, ob jb_serviceprice gesetzt werden muss
if ($job_is_new)
check_jb_serviceprice($jb_id, $hq_id, $jb_ordertime);
// manuelle Disposition gewünscht => overrult alles
if ($jb_status_manual == 1 && !(isset($jb_storno) && $jb_storno > 0)):
$tmpArr = array("jb_status", 9);
updateStmt("job", "jb_id", $jb_id, $tmpArr);
endif;
// Mitarbeiter speichern
// $tmpArr = array("jb_id", $jb_id, "usr_id", $usr_id, "jbemp_description", ($job_is_new == true ? "Erfassung" : "Änderung"));
// insertStmt("jobemployee", $tmpArr);
// $tmpArr = array("jb_id", $jb_id, "usr_id", $usr_id, "hq_id", $hq_id, "logo_id", ($job_is_new == true ? 1 : 2), "logo_description", $jobMode);
// insertStmt("phoenix_log.log", $tmpArr);
// Falls Listenkundenauftrag, der offiziell einen Nullpreis hat, den Preis im Bemerkungstextfeld speichern
// if ($jobbatch_mode == true):
// if ($tr_sort_jobbatchmode == 0)
// $tr_sort_jobbatchmode = 1;
// $tr_remark = $db->getOne("SELECT tr_remark FROM tour WHERE jb_id = $jb_id AND tr_sort = $tr_sort_jobbatchmode");
// $tr_remark .= "\n*** FESTPREIS (LISTE) EUR " . sprintf("%01.2f", $fullPrice) . " ***";
// $tmpArr = array("tr_remark", $tr_remark);
// updateStmt("tour", "jb_id", $jb_id, $tmpArr, "tr_sort = " . $tr_sort_jobbatchmode);
// endif;
deleteStmt("genericdatacontainer", "gdc_obj_type = 'jb' AND gdc_obj_id = " . $jb_id . " AND gdc_gen_fieldname = 'jb_blink'");
if (trim($jb_tourname_hidden_vht_id) != "" && $jb_tourname_hidden_vht_id != $vht_id && !($jb_fixprice == "" || $jb_fixprice == 0))
insertStmt("genericdatacontainer", array("gdc_obj_type", "jb", "gdc_obj_id", $jb_id, "gdc_gen_fieldname", "jb_blink", "gdc_content", "1", "gdc_context", ""));
if (MASK_CR_PRICE_MODE == "1"):
$tr_remark = $db->getOne("SELECT tr_remark FROM tour WHERE jb_id = $jb_id AND tr_sort = 1");
if ($jb_cr_price_total > 0):
$tr_remark = str_replace("{JB_CR_PRICE_TOTAL}", "Frachtverguetung: " . str_replace(".", ",", sprintf("%01.2f", $jb_cr_price_total)) . " EUR\n", $tr_remark);
else:
$tr_remark = str_replace("\n[[\n{JB_CR_PRICE_TOTAL}]]", "", $tr_remark);
$tr_remark = str_replace("{JB_CR_PRICE_TOTAL}", "", $tr_remark);
endif;
$filters_text = "";
if ($tr_tracking_flag)
$filters_text = "~~~\n" . "Bitte achten sie auf eine aktive GPS-Verbindung während dieses Auftrags, da der/die Empfänger über ihr voraussichtliches Eintreffen auf dem Laufenden gehalten wird.\n"
. str_replace("~~~\n", "", $filters_text) . "~~~\n";
$tmpArr = array("tr_remark", $filters_text . $tr_remark);
updateStmt("tour", "jb_id", $jb_id, $tmpArr, "tr_sort = 1");
endif;
$job_checkboxes = "";
if ($afterwards == 1) { $job_checkboxes .= ", `Nacherfassung´"; }
if ($jb_globaljob == 1) { $job_checkboxes .= ", `An alle Kuriere´"; }
if ($jb_status_manual == 1) { $job_checkboxes .= ", `Manuelle Disposition´"; }
if ($jb_incomplete == 1) { $job_checkboxes .= ", `Noch unvollständig´"; }
if (isset($jb_tourname_overwrite) && $jb_tourname_overwrite == 1) { $job_checkboxes .= ", `Gespeicherte Tour überschreiben´"; }
if (isset($jb_id_insurance) && $jb_id_insurance != 0) { $job_checkboxes .= ", `Höherversicherung (" . $jb_id_insurance . ")´"; }
if ($jb_tourname_hidden != "") { $job_checkboxes .= ", `Konserve \"" . $jb_tourname_hidden . "\"´"; }
if ($request_token != "") { // e.g. no request_token when storno
writeLog_("../log/job2_options_", "\$request_token = " . $request_token . ", \$sp_id_request = " . $sp_id_request . ", \$sp_context = " . $sp_context);
updateStmt("phoenix_log.semaphor", "sp_id", $sp_id_request, array("sp_context", (trim($sp_context) != "NOT_SENT" ? $sp_context . "," : "") . $jb_id));
}
if (trim($jb_id_org) == "") {
$changes_text = "";
$changes_str = "";
if (!$job_is_new):
// Analyse der Änderungen vornehmen, falls es eine Änderung war
if ($vht_id_old != $vht_id) { $changes_text .= ", Fahrzeugtyp"; $changes_str .= "|\$vht_id_old=$vht_id_old|\$vht_id=$vht_id"; }
// $csc_id !=
if ($jb_weight_old != $jb_weight) { $changes_text .= ", Maximalgewicht"; $changes_str .= "|\$jb_weight_old=$jb_weight_old|\$jb_weight=$jb_weight"; }
if ($jb_crvh_length_old != $jb_crvh_length) { $changes_text .= ", Länge"; $changes_str .= "|\$jb_crvh_length_old=$jb_crvh_length_old|\$jb_crvh_length=$jb_crvh_length"; }
if ($jb_crvh_width_old != $jb_crvh_width) { $changes_text .= ", Breite"; $changes_str .= "|\$jb_crvh_width_old=$jb_crvh_width_old|\$jb_crvh_width=$jb_crvh_width"; }
if ($jb_crvh_height_old != $jb_crvh_height) { $changes_text .= ", Höhe"; $changes_str .= "|\$jb_crvh_height_old=$jb_crvh_height_old|\$jb_crvh_height=$jb_crvh_height"; }
if ($jb_crvh_position_old != $jb_crvh_position) { $changes_text .= ", Stellplätze"; $changes_str .= "|\$jb_crvh_position_old=$jb_crvh_position_old|\$jb_crvh_position=$jb_crvh_position"; }
// if ($jb_ordertime_old != $jb_ordertime) { $changes_text .= ", Datum und/oder Uhrzeit"; $changes_str .= "|\$jb_ordertime_old=$jb_ordertime_old|\$jb_ordertime=$jb_ordertime"; }
// if ($jb_reserv_old != $jb_reserv) { $changes_text .= ", "; $changes_str .= "|\$jb_reserv_old = $jb_reserv_old|\$jb_reserv = $jb_reserv"; }
if ($jb_permanent_old != $jb_permanent) { $changes_text .= ", Dauerauftragsrhythmus"; $changes_str .= "|\$jb_permanent_old=$jb_permanent_old|\$jb_permanent=$jb_permanent"; }
// if ($cr_sid_old != $cr_sid) { $changes_text .= ", "; $changes_str .= "|\$cr_sid=$cr_sid"; }
// if ($cr_id_order_old != $cr_id_order) { $changes_text .= ", "; $changes_str .= "|\$cr_id_order=$cr_id_order"; }
if ($jb_waitstorno_old != $jb_waitstorno_old) { $changes_text .= ", Storno bei Nichtverfügbarkeit"; $changes_str .= "|\$jb_waitstorno_old=$jb_waitstorn_old|\$jb_waitstorno=$jb_waitstorno"; }
// if ($jb_waittime_old != $jb_waittime) { $changes_text .= ", "; $changes_str .= "|\$jb_waittime_old=$jb_waittime_old|\$jb_waittime=$jb_waittime"; }
$jb_fixprice_compare = ($jb_fixprice == "" ? "0.00" : $jb_fixprice);
if ($jb_fixprice_old != $jb_fixprice_compare) { $changes_text .= ", Festpreis"; $changes_str .= "|\$jb_fixprice_old=$jb_fixprice_old|\$jb_fixprice=$jb_fixprice_compare"; }
$jb_serviceprice_compare = ($jb_serviceprice == "" ? "0.00" : $jb_serviceprice);
if ($jb_serviceprice_old != $jb_serviceprice_compare) { $changes_text .= ", Servicepreis"; $changes_str .= "|\$jb_serviceprice_old=$jb_serviceprice_old|\$jb_serviceprice=$jb_serviceprice_compare"; }
if ($csc_id_payer_old != $csc_id_payer || ($csc_id_payer_cash_old != $csc_id_payer_cash && $csc_id_payer_cash != "")) { $changes_text .= ", Zahler oder Zahlungsmodus"; $changes_str .= "|\$csc_id_payer_old=$csc_id_payer_old|\$csc_id_payer=$csc_id_payer|\$csc_id_payer_cash_old=$csc_id_payer_cash_old|\$csc_id_payer_cash=$csc_id_payer_cash"; }
// if ($jb_globaljob_old != $jb_globaljob && $jb_globaljob != "") { $changes_text .= ", `An alle Kuriere´ an oder aus"; $changes_str .= "|\$jb_globaljob_old=$jb_globaljob_old|\$jb_globaljob=$jb_globaljob"; }
if (my_str_check($jb_freetext_1_old) != my_str_check_http($jb_freetext_1)) { $changes_text .= ", Rechnungstext"; $changes_str .= "|\$jb_freetext_1_old=" . my_str_check($jb_freetext_1_old) . "|\$jb_freetext_1=" . my_str_check_http($jb_freetext_1); }
// if ($jb_payment_old != $jb_payment) { $changes_text .= ", Fahrzeuganforderung"; $changes_str .= "|\$jb_payment_old=$jb_payment_old|\$jb_payment=$jb_payment"; }
if ($jb_permanent2_old != $jb_permanent2) { $changes_text .= ", Dauerauftragsrhythmus-Tage"; $changes_str .= "|\$jb_permanent2_old=$jb_permanent2_old|\$jb_permanent2=$jb_permanent2"; }
if ($jb_sales_tax_rate_old != $jb_sales_tax_rate) { $changes_text .= ", MwSt-Satz"; $changes_str .= "|\$jb_sales_tax_rate_old=$jb_sales_tax_rate_old|\$jb_sales_tax_rate=$jb_sales_tax_rate"; }
if ($jb_sales_tax_rate_sign_old != $jb_sales_tax_rate_sign_new) { $changes_text .= ", MwSt-Kennzeichen"; $changes_str .= "|\$jb_sales_tax_rate_sign_old=$jb_sales_tax_rate_sign_old|\$jb_sales_tax_rate_sign=$jb_sales_tax_rate_sign"; }
if ($jp_permenddat_old != $jp_permenddat) { $changes_text .= ", Dauerauftragsenddatum"; $changes_str .= "|\$jp_permenddat_old=$jp_permenddat_old|\$jp_permenddat=$jp_permenddat"; }
if ($jb_cr_filter_old != $jb_cr_filter) { $changes_text .= ", Kurierfilter"; $changes_str .= "|\$jb_cr_filter_old=$jb_cr_filter_old|\$jb_cr_filter=$jb_cr_filter"; }
if ($jb_cr_filter_opt_old != $jb_cr_filter_opt) { $changes_text .= ", optionale Kurierfilter"; $changes_str .= "|\$jb_cr_filter_opt_old=$jb_cr_filter_opt_old|\$jb_cr_filter_opt=$jb_cr_filter_opt"; }
if ($jb_dispoinfo_old != $jb_dispoinfo) { $changes_text .= ", Dispo-Info"; $changes_str .= "|\$jb_dispoinfo_old=$jb_dispoinfo_old|\$jb_dispoinfo=$jb_dispoinfo"; }
// if ($jb_status_old != $jb_status) { $changes_text .= ", Auftragsstatus"; $changes_str .= "|\$jb_status_old=$jb_status_old|\$jb_status=$jb_status"; }
// if ($cr_id_permanent_old != $cr_id_permanent) { $changes_text .= ", "; $changes_str .= "|\$cr_id_permanent_old=$cr_id_permanent_old|\$cr_id_permanent=$cr_id_permanent"; }
// if ($jb_incomplete_old == 1 && $jb_incomplete == "" || $jb_incomplete_old == 0 && $jb_incomplete == "1") { $changes_text .= ", `Noch unvollständig´ an oder aus"; $changes_str .= "|\$jb_incomplete_old=$jb_incomplete_old|\$jb_incomplete=$jb_incomplete"; }
if ($hq_id_exec_old != $hq_id_exec) { $changes_text .= ", Ausführende NL:"; $changes_str .= "|\$hq_id_exec_old=$hq_id_exec_old|\$hq_id_exec=$hq_id_exec"; }
if ($jb_longhaul_old != $jb_longhaul) { $changes_text .= ", BWV-Auftrag"; $changes_str .= "|\$jb_longhaul_old=$jb_longhaul_old|\$jb_longhaul=$jb_longhaul"; }
if ($jb_commission_no_old != $jb_commission_no) { $changes_text .= ", Rechnungskommission"; $changes_str .= "|\$jb_commission_no_old=$jb_commission_no_old|\$jb_commission_no=$jb_commission_no"; }
$tr_add_str = "";
$tr_del_str = "";
$i = 1;
do {
if (existsEntry("tour", array("jb_id", $jb_id, "tr_sort", $i))){
$tourFound = 1;
if ($i < $i_tour_max_old) {
list($csc_id, $tr_comp, $tr_person, $ad_street, $tr_hsno,
$ad_zipcode, $ad_city, $ad_country, $tr_remark, $tr_status, $tr_ware_from_to, $tr_commission_no, $tr_mediationarea_id, $tr_status, $tr_sign, $tr_signname, $tr_finishtime) =
getTourData($jb_id, $i, $dbh_tr);
} else {
$tr_add_str .= "$i, ";
$changes_text .= ", $i. Etappe hinzugefügt";
}
} else {
$tourFound = 0;
if ($i < $i_tour_max_old):
$csc_id = $tr_comp = $tr_person = $ad_street = $tr_hsno =
$ad_zipcode = $ad_city = $ad_country = $tr_remark = $tr_status = $tr_ware_from_to = $tr_commission_no = $tr_mediationarea_id = $tr_status = $tr_sign = $tr_signname = $tr_finishtime = "";
$tr_del_str .= "$i, ";
endif;
}
if ($i < $i_tour_max_old) {
if ($csc_id != $csc_id_old_[$i]) { $changes_text .= ", $i. Kostenstelle"; $changes_str .= "|\$csc_id_$i=".$csc_id."|\$csc_id_old_$i=".$csc_id_old_[$i]; }
if ($tr_comp != $tr_comp_old_[$i]) { $changes_text .= ", $i. Firma"; $changes_str .= "|\$tr_comp_$i=".$tr_comp."|\$tr_comp_old_$i=".$tr_comp_old_[$i]; }
if ($tr_person != $tr_person_old_[$i]) { $changes_text .= ", $i. Person"; $changes_str .= "|\$tr_person_$i=".$tr_person."|\$tr_person_old_$i=".$tr_person_old_[$i]; }
if ($ad_street != $ad_street_old_[$i]) { $changes_text .= ", $i. Straße"; $changes_str .= "|\$ad_street_$i=".$ad_street."|\$ad_street_old_$i=".$ad_street_old_[$i]; }
if ($tr_hsno != $tr_hsno_old_[$i]) { $changes_text .= ", $i. Hausnummer"; $changes_str .= "|\$tr_hsno_$i=".$tr_hsno."|\$tr_hsno_old_$i=".$tr_hsno_old_[$i]; }
if ($ad_zipcode != $ad_zipcode_old_[$i]) { $changes_text .= ", $i. PLZ"; $changes_str .= "|\$ad_zipcode_$i=".$ad_zipcode."|\$ad_zipcode_old_$i=".$ad_zipcode_old_[$i]; }
if ($ad_city != $ad_city_old_[$i]) { $changes_text .= ", $i. Ort"; $changes_str .= "|\$ad_city_$i=".$ad_city."|\$ad_city_old_$i=".$ad_city_old_[$i]; }
if ($ad_country != $ad_country_old_[$i]) { $changes_text .= ", $i. Ort"; $changes_str .= "|\$ad_country_$i=".$ad_country."|\$ad_country_old_$i=".$ad_country_old_[$i]; }
if ($tr_remark != $tr_remark_old_[$i]) { $changes_text .= ", $i. Bemerkung"; $changes_str .= "|\$tr_remark_$i=".$tr_remark."|\$tr_remark_old_$i=".$tr_remark_old_[$i]; }
// if ($tr_status != $tr_status_old_[$i]) { $changes_text .= ", $i. Status"; $changes_str .= "|\$tr_status_$i=".$tr_status."|\$tr_status_old_$i=".$tr_status_old_[$i]; }
if ($tr_ware_from_to != $tr_ware_from_to_old_[$i]) { $changes_text .= ", $i. An/Ab"; $changes_str .= "|\$tr_ware_from_to_$i=".$tr_ware_from_to."|\$tr_ware_from_to_old_$i=".$tr_ware_from_to_old_[$i]; }
if ($tr_commission_no != $tr_commission_no_old_[$i]) { $changes_text .= ", $i. Kommissionsnummer"; $changes_str .= "|\$tr_commission_no_$i=".$tr_commission_no."|\$tr_commission_no_old_$i=".$tr_commission_no_old_[$i]; }
if ($tr_mediation_area_id != $tr_mediation_area_id_old_[$i]) { $changes_text .= ", $i. Bereich"; $changes_str .= "|\$tr_mediation_area_id_$i=".$tr_mediation_area_id."|\$tr_mediation_area_id_old_$i=".$tr_mediation_area_id_old_[$i]; }
}
$i++;
} while ($tourFound == 1 || $i < $i_tour_max_old);
if ($tr_add_str != "") {
$changes_str .= "|\$tr_add=" . substr($tr_add_str, 0, -2);
}
if ($tr_del_str != "") {
$changes_str .= "|\$tr_del=" . substr($tr_del_str, 0, -2);
if ($jb_status != 2 && $tr_status_all == 1) {
if ($jb_finishtime_new == "0000-00-00 00:00:00")
$jb_finishtime_new = date("Y-m-d H:i:s");
updateStmt("job", "jb_id", $jb_id, array("jb_status", 2, "jb_finishtime", $jb_finishtime_new));
}
}
if ($jb_id_permanent_pre != "") { $changes_str .= "|\$jb_id_permanent_pre=$jb_id_permanent_pre"; }
if ($changes_text == ""):
$changes_text = ", keine Änderung der Auftragsdaten";
else:
// Versionszähler bei jeder echten Änderung hochzählen
$tmpArr = array("jb_version", $db->getOne("SELECT jb_version FROM job WHERE jb_id = '$jb_id'") + 1);
updateStmt("job", "jb_id", $jb_id, $tmpArr);
endif;
endif;
$changes_text .= $job_checkboxes;
if ($changes_text != "")
$changes_text = " (" . substr($changes_text, 2) . ")";
writeToLogDB(($job_is_new == true ? 162 : 163), $hq_id, $jb_id, $usr_id, "", "", "", $jobMode . $changes_text . $changes_str . ($hq_id_exec != $hq_id ? "|HQ_ID_EXEC=$hq_id_exec" : "") . ($jb_longhaul == 1 ? "|JB_LONGHAUL=$jb_longhaul" : ""));
}
else
{
if ($job_checkboxes != "")
$job_checkboxes = " (" . substr($job_checkboxes, 2) . ")";
if ($jobMode == "Neu") // neuer Job, hier aus Kopie; $jobMode kann hier auch noch Nacherfassung sein
$jobMode = "Erfassung aus Kopie";
// $jobMode = "Erfassung aus Kopie von Nr. $jb_id_org";
writeToLogDB(25, $hq_id, $jb_id, $usr_id, "", "", "", $jobMode . $job_checkboxes . "|JB_ID_ORG=$jb_id_org" . ($hq_id_exec != $hq_id ? "|HQ_ID_EXEC=$hq_id_exec" : ""));
}
// HIER PDA-COMMAND EINFÜHREN!!!
//insertPDACommand
// $currentTime = getDateTime("0");
//
//insertPDACommand($hq_id, $crId, "4", "1", $jb_id_storno, $currentTime, "");
//writeLog_("../log/job2_options_", trace_execution_time_stop() . " '../jobs/job_options.php' job saved, '$jobMode': \$jb_id=$jb_id_log , \$usr_id=$usr_id, \$job_is_new=$job_is_new, \$getPriceOnly=$getPriceOnly"); // Transaktion abschliessen
//trace_execution_time_start();
TA("COMMIT");
if ($sp_id_block > 0) {
updateStmt("phoenix_log.semaphor", "sp_id", $sp_id_block, array("sp_obj_id", 0));
}
if (!existsEntry("job", array("jb_id", $jb_id))):
if ($sp_id > 0) {
$db->query("UPDATE phoenix_log.semaphor SET sp_obj_id = " . $jb_id . ", sp_content = CONCAT(sp_content, '-FAIL (" . $usr_id . ", " . date("Y-m-d H:i:s") . ")') WHERE sp_id = " . $sp_id);
}
$post_vars = "";
foreach($HTTP_POST_VARS as $key => $value) {
$post_vars .= "\n";
}
include_once("../include/email/htmlMimeMail.php");
$mailObj = new htmlMimeMail();
// $mailObj->setFrom("auto-mailer@assecutor.de");
$mailObj->setFrom("support@assecutor.de");
$mailObj->setSubject("Auftrag " . $jb_id . " wurde nicht geschrieben!");
$mailObj->setText($post_vars);
$mailResult = $mailObj->send(array("ca@assecutor.de"), 'smtp');
// $mailResult = $mailObj->send(array("support@assecutor.de"), 'smtp');
else:
if ($sp_id > 0) {
$db->query("UPDATE phoenix_log.semaphor SET sp_obj_id = " . $jb_id . ", sp_content = CONCAT(sp_content, '-OK (" . $usr_id . ", " . date("Y-m-d H:i:s") . ")') WHERE sp_id = " . $sp_id);
}
endif;
$jb_id_log = $jb_id;
else:
// Transaktion abbrechen
TA("ROLLBACK");
if ($sp_id_block > 0) {
updateStmt("phoenix_log.semaphor", "sp_id", $sp_id_block, array("sp_obj_id", 0));
}
if ($sp_id > 0) {
$db->query("UPDATE phoenix_log.semaphor SET sp_obj_id = " . $jb_id . ", sp_content = CONCAT(sp_content, '-RB (" . $usr_id . ", " . date("Y-m-d H:i:s") . "), \$addressValid = \"" . $addressValid . "\"') WHERE sp_id = " . $sp_id);
}
// Fenster nach Meldung nicht schliessen
$killAfterUpdate = false;
// Hier liegt der Hase im Pfeffer wg. der fehlerhaften neuen Jobs nach Adressänderungen in einem bestehenden Auftrag
if ($job_is_new)
$jb_id = "";
endif;
TA("END");
$statusMessage = $statusMessageTxt;
//writeLog_("../log/job2_options_", trace_execution_time_stop() . " '../jobs/job_options.php' job saved, '$jobMode': \$jb_id=$jb_id_log , \$usr_id=$usr_id, \$job_is_new=$job_is_new, \$getPriceOnly=$getPriceOnly");
//trace_execution_time_start();
elseif ($toursubmit == "Senden" && $getPriceOnly == 1):
// Nur Preisermittlung
// Auch hier muss der payer bekannt sein, da cs_inv_mode von ihm abhängt
// Servicetype-Name (Fahrrad etc.)
$srvt_name = $db->getOne(
"SELECT mt_value FROM metatype WHERE mt_sort = '$vht_id' AND mt_type = 'vehicletype'");
// Ermittlung der Kostenübernahme
// wenn Fixpreis, dann keine Kosterfassung in tourservice
$costsplit_count = 0;
for ($i = 0; $i < count($jobList); $i++):
if ($jobList[$i][JL_CSC_ID] == ""):
if ($jobList[$i][JL_TR_COMP] == "" ||
$jobList[$i][JL_AD_STREET] == "" ||
$jobList[$i][JL_TR_HSNO] == "" ||
$jobList[$i][JL_AD_ZIPCODE] == "" ||
$jobList[$i][JL_AD_CITY] == ""):
// Abbruchbedingung: csc_id leer und nicht genügend Angaben für eine
// neue Kostenstelle -> Auftrag vollständig durchlaufen
break;
endif;
else:
// csc_id gesetzt:
// wenn Kostenteilung, dann diese Kostenstelle mitzählen
$costsplit_count++;
if ($jobList[$i][JL_CSC_ID_PAYER] == "true"):
$csc_id_payer = $jobList[$i][JL_CSC_ID];
// Payer gefunden:
// Anzahl Payer auf 1 setzen
$costsplit_count = 1;
// Grundpreis des Auftrags (Anfahrtskosten) speichern
// wenn Kostensplit, wird er später anteilig bei jeder Etappenstelle einzeln gespeichert
// saveServiceCosts("Grundpreis", $srvt_name, $hq_id, $cs_id, $jb_id, 0, $jb_ordertime, 0, 1, (($getPriceOnly == 1 || $jobbatch_mode) ? 1 : 0), $jb_cash, (($jb_costsplit == "false" || MASK_CASH_PAYER_SELECT == "1") ? $csc_id_payer : ""), $jb_storno, false, false, false);
break;
endif;
endif;
endfor;
// potentiellen Drittzahler berücksichtigen.
// Der wird direkt übergeben und ist in der job_list nicht vorhanden!!!
if ($csc_id_payer != "" && $csc_id_payer != "0")
$costsplit_count = 1;
// $csc_id_payer = "";
// Barzahlung berücksichtigen
if ($jb_cash == "true"):
// Achtung: wenn MASK_CASH_PAYER_SELECT gesetzt, dann ist auf jeden Fall ein Bezahler
// gesetzt, der natürlich auch erhalten bleiben muss!
if (MASK_CASH_PAYER_SELECT != "1"):
$csc_id_payer = "-1";
if (CSC_ID_PAYER_CASH != ""):
$csc_id_payer = CSC_ID_PAYER_CASH;
endif;
endif;
$costsplit_count = 1;
endif;
// invmode ermitteln (ist abhängig von dem aktuellen Bezahler)
$cs_id = getFieldValueFromId("costcenter", "csc_id", "$csc_id_payer", "cs_id");
$cs_invmode = getFieldValueFromId("customer", "cs_id", "$cs_id", "cs_invmode");
// Preise sollen auch ermittelt werden können, wenn nur Adresse
// vorhanden (sogar wenn falsch!) -> nur im PLZ zu PLZ-Modus möglich
$jb_ordertime = "";
if ($tag == "" || $monat == "" || $jahr == "" || $stunde == "" || $minute == ""):
if ($jb_id == ""):
$today = getdate();
$jb_ordertime = $today['year'] . "-" . $today['mon'] . "-" . $today['mday'] . " "
. $today['hours'] . ":" . $today['minutes'] . ":" . $today['seconds'];
else:
$jb_ordertime = $db->getOne("SELECT jb_ordertime FROM job WHERE jb_id = '$jb_id'");
endif;
else:
$jb_ordertime = "$jahr-$monat-$tag $stunde:$minute:00";
endif;
// Grundpreis
// Servicetype-Name (Fahrrad etc.)
$srvt_name = $db->getOne(
"SELECT mt_value FROM metatype WHERE mt_sort = '$vht_id' AND mt_type = 'vehicletype'");
// Auch Treibstoffzuschlag in Prozent ermitteln
$jb_markup = getFuelMarkup($srvt_name, (trim($cs_id) != "" ? $cs_id : 0), $hq_id, $jb_ordertime);
list ($fp, $fd, $fpm, $final_cr_price, $final_cr_discount, $final_cr_price_markup, $customer_specific, $special_address, $validfrom) =
saveServiceCosts("Grundpreis", $srvt_name, $hq_id, $cs_id, $jb_id, 0, $jb_ordertime, 0, $costsplit_count, (($getPriceOnly == 1 || $jobbatch_mode) ? 1 : 0), $jb_cash, (($jb_costsplit == "false" || MASK_CASH_PAYER_SELECT == "1") ? $csc_id_payer : ""), $jb_storno, false, false, false, $jb_markup, $fuel_cr_markup, $vht_id);
$fullPrice += round($fp * ((100-$fd)/100), 2);
$discount_sign = ($special_address || $discount_sign == "**" ? "**"
: ($discount_sign = ($fd > 0 || $customer_specific || $discount_sign == "*" ? "*" : "")));
$jb_cr_subtotal += round($final_cr_price_markup * ((100-$fd-$self_service_discount)/100), 2);
$fullCrPrice += round($final_cr_price * ((100-$fd-$self_service_discount)/100), 2);
// PLZ-Preis
//print_r($jobList);
// Anzahl Kostenstellen für Preisberechnung ermitteln
$maxTour = count($jobList);
for ($i = 0; $i < count($jobList); $i++):
if ($jobList[$i][JL_CSC_ID] == ""):
if ($jobList[$i][JL_TR_COMP] == "" ||
$jobList[$i][JL_AD_STREET] == "" ||
$jobList[$i][JL_TR_HSNO] == "" ||
$jobList[$i][JL_AD_ZIPCODE] == "" ||
$jobList[$i][JL_AD_CITY] == ""):
// Abbruchbedingung: csc_id leer und nicht genügend Angaben für eine
// neue Kostenstelle -> Auftrag vollständig durchlaufen
$maxTour = $i - 1;
break;
endif;
endif;
endfor;
for ($i = 0; $i < $maxTour; $i++):
//reportDie ($jobList[$i][JL_AD_ZIPCODE] . ", " . $jobList[$i+1][JL_AD_ZIPCODE]);
// die Hamburger Fake-PLZs sind für Preisberechnung wichtig ...
//print_r($jobList);
//reportDie ("'" . $jobList[$i][JL_TR_MEDIATIONAREA_ID] . "'");
// ... und Berlin hat noch eine andere Extra-Wurst:
// Bestimmte wohldefinierte Adressen sind bestimmten Bereichen zugeordnet ...
// ... somit muss die vollständige Adresse übergeben werden!
$ad_id1 = $jobList[$i][JL_AD_ZIPCODE] . "³" . $jobList[$i][JL_AD_STREET] . "³" . $jobList[$i][JL_TR_HSNO];
$zipcode1 = false;
if ($jobList[$i][JL_TR_MEDIATIONAREA_ID] != 0):
$ad_id1 = $jobList[$i][JL_TR_MEDIATIONAREA_ID];
if ($ad_id1 == -1):
$ad_id1 = getMediationarea_id($hq_id, $jobList[$i][JL_AD_ZIPCODE], $jobList[$i][JL_AD_STREET], $jobList[$i][JL_TR_HSNO]);
array_push ($setMediation_area_idArr, $i, $ad_id1);
endif;
$zipcode1 = true;
endif;
$ad_id2 = $jobList[$i+1][JL_AD_ZIPCODE] . "³" . $jobList[$i+1][JL_AD_STREET] . "³" . $jobList[$i+1][JL_TR_HSNO];
$zipcode2 = false;
if ($jobList[$i+1][JL_TR_MEDIATIONAREA_ID] != 0):
$ad_id2 = $jobList[$i+1][JL_TR_MEDIATIONAREA_ID];
if ($ad_id2 == -1):
$ad_id2 = getMediationarea_id($hq_id, $jobList[$i+1][JL_AD_ZIPCODE], $jobList[$i+1][JL_AD_STREET], $jobList[$i+1][JL_TR_HSNO]);
array_push ($setMediation_area_idArr, $i+1, $ad_id2);
endif;
$zipcode2 = true;
endif;
//ab hier geht's normal weiter
//reportDie ("saveServiceCosts($ad_id1, $ad_id2, $hq_id, $cs_id, $jb_id, ($i + 1), $jb_ordertime, $distance, $costsplit_count, $getPriceOnly, $jb_cash, " . (($jb_costsplit == "false" || MASK_CASH_PAYER_SELECT == "1") ? $csc_id_payer : "") . ", $jb_storno, $zipcode1, $zipcode2);");
list ($fp, $fd, $fpm, $final_cr_price, $final_cr_discount, $final_cr_price_markup, $customer_specific, $special_address, $validfrom) =
saveServiceCosts($ad_id1, $ad_id2, $hq_id, $cs_id, $jb_id, ($i + 1), $jb_ordertime, $distance, $costsplit_count, $getPriceOnly, $jb_cash, (($jb_costsplit == "false" || MASK_CASH_PAYER_SELECT == "1") ? $csc_id_payer : ""), $jb_storno, $zipcode1, $zipcode2, true, $jb_markup, $fuel_cr_markup, $vht_id);
$fullPrice += round($fp * ((100-$fd)/100), 2);
$discount_sign = ($special_address || $discount_sign == "**" ? "**"
: ($discount_sign = ($fd > 0 || $customer_specific || $discount_sign == "*" ? "*" : "")));
$jb_cr_subtotal += round($final_cr_price_markup * ((100-$fd-$self_service_discount)/100), 2);
$fullCrPrice += round($final_cr_price * ((100-$fd-$self_service_discount)/100), 2);
endfor;
endif;
/* ********************************************************************** */
// Inhalt des Frames aufbauen und ausgeben
//
// nur wenn if $getPriceOnly != 1 UND WENN NICHT von "check_jb_permanent.php" aufgerufen
if ($getPriceOnly != 1 &&
!(isset($check_jb_permanent_flag) && $check_jb_permanent_flag == true)):
// Wartezeiten für die Annahme durch den gewünschten Kurier
//$jb_waittime_options = addOptionsFromTable(
// "metatype", "mt_sort", "mt_value", "mt_sort", "mt_type = 'waittime'");
// Fahrzeugtypen
$mask_exclude_vht_ids_cs = getParameterValue("0", "MASK_EXCLUDE_VHT_IDS_CS", $hq_id);
if ($mask_exclude_vht_ids_cs != "")
$mask_exclude_vht_ids_cs = " AND NOT mt_sort IN (" . $mask_exclude_vht_ids_cs . ")";
$vht_id_options = addOptionsFromTable(
"metatype", "mt_sort", "mt_value", "mt_sort", "mt_type = 'vehicletype' AND mt_sort > 0" . $mask_exclude_vht_ids_cs,
getFieldValueFromId("headquarters", "hq_id", "$hq_id", "hq_vht_default"));
// gespeicherte Touren
$savedTour_options = addOptionsFromTable(
"job", "jb_id", "jb_tourname", "jb_tourname", "csc_id_payer = '$csc_id_orderer' AND LENGTH(jb_tourname) > 0");
// gespeicherte Touren darf nicht mehr disabled sein, da durch die Auswahl der Referesh ausgelöst wird!
// $savedTour_disabled = ($savedTour_options == "") ? "disabled" : "";
$savedTour_disabled = "";
// Dauerauftrags-Rhythmen
$jb_permanent_options = addOptionsFromTable(
"metatype", "mt_sort", "mt_value", "mt_sort", "mt_type = 'permanent'");
$jb_sales_tax_rate_sign_options = addOptionsFromTable(
"tax", "tx_id", "tx_sign", "tx_sign", "", "4");
// Default-Steuersatz
$sales_tax_rate_value = $db->getOne("SELECT tx_value FROM tax WHERE tx_id = 4");
// Die externen Kostenstellen werden in ein Javascript-Array geschrieben,
// damit später überprüft werden kann, ob eine gewählte Etappenstelle
// Bezahler sein kann
if ($cs_id != 0):
// Kundenauftrag -> nur externe Kostenstelle des Kunden übernehmen
$sqlquery = "SELECT costcenter.csc_id, costcenter.csc_path, costcenter.csc_is_extern" .
" FROM costcenter, costcenteraddress " .
" WHERE costcenter.csc_id = costcenteraddress.csc_id" .
" AND costcenter.cs_id = '$cs_id' AND costcenteraddress.adt_id = '4'";
$res = $db->query($sqlquery);
if (DB::isError($res)) reportDie ("$PHP_SELF: '$sqlquery': " . $res->getMessage());
// $csc_id_extern_list = "var csc_id_extern_list = new Array();\n";
// Erkennungsmerkmal ist csc_path, welcher hier erst einmal ermittelt
// werden muss
$csc_id_root = getFieldValueFromId("customer", "cs_id", "$cs_id", "csc_id");
$csc_name_root = getFieldValueFromId("costcenter", "csc_id", "$csc_id_root", "csc_name");
$csc_path_start = "//" . my_str_check($csc_name_root) . "//Extern//";
// externe Kostenstellen in Array schreiben
// $i = 0;
// while ($row = $res->fetch_assoc()):
// if (substr($row["csc_path"], 0, strlen($csc_path_start)) == $csc_path_start)
// $csc_id_extern_list .= "csc_id_extern_list[" . $i++ . "] = \"" . $row["csc_id"] . "\";\n";
// endwhile;
// $res->free();
else:
// // Zentralenauftrag -> nur externe Kostenstelle des Zentrale übernehmen
// $res = $db->query("SELECT costcenter.csc_id " .
// " FROM costcenter, customer " .
// " WHERE costcenter.cs_id = customer.cs_id" .
// " AND customer.hq_id = '$hq_id' AND costcenter.csc_is_extern = '1'");
// if (DB::isError($res))
// reportDie ("$PHP_SELF: 'SELECT costcenter.csc_id, costcenter.csc_path ...': " . $res->getMessage());
// $csc_id_extern_list = "var csc_id_extern_list = new Array();\n";
// $i = 0;
// while ($row = $res->fetch_assoc()):
// $csc_id_extern_list .= "csc_id_extern_list[" . $i++ . "] = \"" . $row["csc_id"] . "\";\n";
// endwhile;
// $res->free();
endif;
// jb_id must be modified according to current action
if ($toursubmit == "Senden"):
if ($addressValid != ""): // Auftrag ok
if ($killAfterUpdate):
$jb_id = "killMe"; // Aufrag wurde geändert, Auftragserfassung beenden
else:
$jb_id = ""; // Neuer Auftrag wurde gespeichert, nächster Auftrag kann eingegeben werden
endif;
else:
$jb_id = $jb_id; // Änderung war nicht ok, jb_id muss erhalten bleiben
endif;
else:
$jb_id = $jb_id; // Erster Aufruf: wenn jb_id gesetzt, dann Änderung, sonst erste Neuerfassung
endif;
// if ($phpVersion >= "7.0"):
// $tpl = new HTML_Template_IT();
// else:
// $tpl = new IntegratedTemplate();
// endif;
// $tpl->loadTemplatefile("job_options.tpl.htm", true, true);
$output = file_get_contents("job_options.tpl.htm");
// $tpl->setCurrentBlock("javascript");
$output = str_replace("{_csc_id_extern_list_}", /* $csc_id_extern_list . */ $jsAddNewExternCostcenter, $output);
// $tpl->setVariable("_ph_", getPublicHolidays(getDateTime("year"), "1", "1"));
$output = str_replace("{_hq_id_}", $hq_id, $output);
$output = str_replace("{_cs_id_}", $cs_id, $output);
$output = str_replace("{_cs_id_ec_}", ec($cs_id), $output);
$output = str_replace("{_csc_id_orderer_}", $csc_id_orderer, $output);
$output = str_replace("{_csc_id_orderer_ec_}", $csc_id_orderer_ec, $output);
$output = str_replace("{_csc_id_orderer_root_ec_}", ec(getFieldValueFromId("employee", "usr_id", "$usr_id", "csc_id")), $output);
$output = str_replace("{_jb_id_}", $jb_id, $output);
$output = str_replace("{_jb_copy_}", $jb_copy, $output);
$output = str_replace("{_dbhistory_}", $dbhistory, $output);
$output = str_replace("{_self_service_discount_}", $self_service_discount, $output);
/*
=> Funktion "getParameterValue" in dbglobal, also erreichbar
=> Parameter "$emp_id" ist schon immer in der Session definiert und existiert
=> $empModeCopyJob holt den Parameter für Auftragskopie
0 = Default = Dispo-Modus = wie jetzt
1 = Buchhaltungs-Modus = Kopie mit Datum, Fahrzeugtyp und Fahrer
$empModeLaterJob holt den Parameter für das Nacherfassungs-Flag
0 = Default = Dispo-Modus = wie jetzt = Flag nicht gesetzt
1 = Buchhaltungs-Modus = Flag automatisch gesetzt
*/
$output = str_replace("{_empModeCopyJob_}", getParameterValue($emp_id, "MODE_COPY_JOB"), $output);
$output = str_replace("{_empModeLaterJob_}", getParameterValue($emp_id, "MODE_LATER_JOB"), $output);
$output = str_replace("{_prev_jb_id_}", $prev_jb_id, $output);
$output = str_replace("{_cr_id_order_list_}", "var MASK_COURIER_SORT_BY_OCCUPIED = \"0\";\n" . (isset($cr_id_order_list) ? $cr_id_order_list : "") . (isset($customercourier_list) ? $customercourier_list : ""), $output);
$output = str_replace("{_when_}", "var when = \"" . date("H:i") . "\";", $output);
$output = str_replace("{_hq_id_}", $hq_id, $output);
$output = str_replace("{_cs_jbedit_cr_}", getFieldValueFromId("customer", "cs_id", "$cs_id", "cs_jbedit_cr"), $output);
if (getFieldValueFromId("customer", "cs_id", "$cs_id", "cs_jbedit_cr") == "1"):
$output = str_replace("{_cs_jbedit_cr_list_}", getCustomerCouriers($db, $cs_id), $output);
else:
$output = str_replace("{_cs_jbedit_cr_list_}", "", $output);
endif;
if (trim($db->getOne("SELECT cs_filter_jbedit FROM customer WHERE cs_id = $cs_id")) != ""):
$output = str_replace("{_cs_jbedit_cs_filter_}", "1", $output);
else:
$output = str_replace("{_cs_jbedit_cs_filter_}", "", $output);
endif;
$output = str_replace("{_cs_jbedit_filter_list_}", getCustomerFilters($db, $cs_id), $output);
$output = str_replace("{_csc_id_payer_cash_}", CSC_ID_PAYER_CASH, $output);
$output = str_replace("{_cash_payer_select_}", MASK_CASH_PAYER_SELECT, $output);
$output = str_replace("{_auto_refresh_}", MASK_AUTO_REFRESH, $output);
$output = str_replace("{_commission_no_on_}", MASK_COMMISSION_NO, $output);
$output = str_replace("{_ask_defaultpayer_change_}", MASK_ASK_DEFAULTPAYER_CHANGE, $output);
$output = str_replace("{_manual_disposition_}", MASK_MANUAL_DISPOSITION, $output);
$output = str_replace("{_mask_cr_price_mode_}", MASK_CR_PRICE_MODE, $output);
$output = str_replace("{_mask_maxtour_}", MASK_MAXTOUR, $output);
$output = str_replace("{_hq_workmode_}", $hq_workmode, $output);
$output = str_replace("{statusMessage}", $statusMessage, $output);
if ($addressValid != "ok"):
// restore values submitted in the form
// ONLY job_options!!! (the other forms do still exist)
$javascript = "var addressValid = false;\n";
// Kurierfilter berücksichtigen
$jb_cr_filter_list = array_merge(explode(",", $jb_cr_filter), explode(",", $jb_cr_filter_opt));
// Erst alle Kurierfilter zurücksetzen
$javascript .=
"for (var i = 0; i < parent.job_options.cfl.length; i++)\n" .
" parent.job_options.cfl[i][3] == 0;\n";
// Alle Kurierfilter neu setzen
for ($i = 0; $i <= count($jb_cr_filter_list); $i++)
{
$javascript .=
"for (var i = 0; i < parent.job_options.cfl.length; i++)\n" .
"{\n" .
" if (parent.job_options.cfl[i][0] == \"" . trim($jb_cr_filter_list[$i]) . "\")\n" .
" {\n" .
" parent.job_options.cfl[i][3] = 1;\n" .
" break;\n" .
" }\n" .
"}\n";
}
// if ($jb_cr_filter . $jb_cr_filter_opt != "")
// $javascript .=
// "parent.job_options.document.tourOptions.jb_cr_filterButton.value = \"Filter*\";";
$javascript .=
setJavascriptOpenerFormVals("job_options", "tourOptions",
array("cr_id_order" => $cr_id_order, "vht_id" => $vht_id, "jb_weight" => $jb_weight,
"jb_crvh_length" => $jb_crvh_length, "jb_crvh_width" => $jb_crvh_width,
"jb_crvh_height" => $jb_crvh_height, "jb_crvh_position" => $jb_crvh_position,
"jb_permanent" => $jb_permanent,
"jahr" => $jahr, "monat" => $monat, "tag" => $tag, "stunde" => $stunde,
"minute" => $minute, "endejahr" => $endejahr, "endemonat" => $endemonat, "endetag" => $endetag,
"savedTour" => "", "jb_fixprice" => $jb_fixprice_ori, "jb_serviceprice" => $jb_serviceprice_ori,
"jb_cr_price" => $jb_cr_price_ori,
"jb_freetext_1" => my_str_check_http($jb_freetext_1),
"jb_dispoinfo" => my_str_check_http($jb_dispoinfo),
"jb_warnjahr" => $jb_warnjahr, "jb_warnmonat" => $jb_warnmonat, "jb_warntag" => $jb_warntag, "jb_warnstunde" => $jb_warnstunde,
"jb_warnminute" => $jb_warnminute,
"jb_cr_filter" => $jb_cr_filter,
"jb_cash_hidden" => $jb_cash, "jb_costsplit_hidden" => $jb_costsplit,
"jb_cr_filter_opt" => $jb_cr_filter_opt, "jb_permanent2_hidden" => $jb_permanent2,
"jb_sales_tax_rate" => $jb_sales_tax_rate, "jb_sales_tax_rate_sign" => $jb_sales_tax_rate_sign,
"jb_tourname" => $jb_tourname, "jobList" => my_str_check_http($jobListOri)), ""
);
if (MASK_CR_PRICE_MODE == "1") {
$javascript .=
setJavascriptOpenerFormVals("job_options", "tourOptions",
array("jb_cr_serviceprice" => $jb_cr_serviceprice), "");
}
if (MASK_WAITTIME_ENABLED == "1"):
$javascript .=
setJavascriptOpenerFormVals("job_options", "tourOptions",
array("jb_waittime_hour" => $jb_waittime_hour, "jb_waittime_minute" => $jb_waittime_minute), ""
);
endif;
$javascript .=
setJavascriptOpenerChecked("job_options", "tourOptions", "jb_waitstorno",
(($jb_waitstorno != "1") ? "false" : "true"), "") .
setJavascriptOpenerChecked("job_options", "tourOptions", "afterwards",
(($afterwards != "1") ? "false" : "true"), "") .
setJavascriptOpenerChecked("job_options", "tourOptions", "jb_status_manual",
(($jb_status_manual != "1") ? "false" : "true"), "") .
setJavascriptOpenerChecked("job_options", "tourOptions", "jb_incomplete",
(($jb_incomplete != "1") ? "false" : "true"), "") .
setJavascriptOpenerChecked("job_options", "tourOptions", "jb_globaljob",
(($jb_globaljob != "1") ? "false" : "true"), "") .
setJavascriptOpenerDisabled("job_options", "tourOptions", "jb_permanent",
(($jb_reserv == 1 || $jb_permanent != "") ? "false" : "true"), "") .
"checkJb_permanent();\n" .
setJavascriptOpenerChecked("job_options", "tourOptions", "jb_permanent2_0",
((substr($jb_permanent2, 0, 1) != "1") ? "false" : "true"), "") .
setJavascriptOpenerChecked("job_options", "tourOptions", "jb_permanent2_1",
((substr($jb_permanent2, 1, 1) != "1") ? "false" : "true"), "") .
setJavascriptOpenerChecked("job_options", "tourOptions", "jb_permanent2_2",
((substr($jb_permanent2, 2, 1) != "1") ? "false" : "true"), "") .
setJavascriptOpenerChecked("job_options", "tourOptions", "jb_permanent2_3",
((substr($jb_permanent2, 3, 1) != "1") ? "false" : "true"), "") .
setJavascriptOpenerChecked("job_options", "tourOptions", "jb_permanent2_4",
((substr($jb_permanent2, 4, 1) != "1") ? "false" : "true"), "") .
setJavascriptOpenerChecked("job_options", "tourOptions", "jb_permanent2_5",
((substr($jb_permanent2, 5, 1) != "1") ? "false" : "true"), "") .
setJavascriptOpenerChecked("job_options", "tourOptions", "jb_permanent2_6",
((substr($jb_permanent2, 6, 1) != "1") ? "false" : "true"), "") .
"checkJb_permanent2();\n" .
($comp_payer != "" ? "setCsc_id_payer('$csc_id_payer', '$comp_payer');\n" : "");
// cs_eid_list wiederherstellen, sonst haut es mit dem Bezahler nicht hin...
$payer_found = false;
for ($i = 0; $i < count($jobList); $i++):
$csc_id = $jobList[$i][JL_CSC_ID];
$javascript .= javascriptAdd_cs_eid($csc_id, "");
if ($csc_id == $csc_id_payer):
$payer_found = true;
endif;
endfor;
// Wenn Drittzahler, dann auch dessen Daten wiederherstellen
if (!$payer_found):
$javascript .= javascriptAdd_cs_eid($csc_id_payer, "");
endif;
// Wenn der Originalaufrag einen Festpreis hatte und ein Discount berücksichtigt wurde,
// dann muss die entsprechende Checkbox gesetzt sein!
if ($jb_fixprice != "" || $jb_serviceprice != ""):
$javascript .=
setJavascriptOpenerChecked("job_options", "tourOptions", "jb_discount",
(($jb_discount > 0) ? "true" : "false"), "");
endif;
$javascript .=
"checkSendTour();\n";
else:
$javascript = "var addressValid = true;\n";
endif;
$output = str_replace("{_javascript_}", $javascript, $output);
if ($csc_id_orderer != '0'):
// Kundenauftrag: Immer Rechnungszahler, immer der Kunde selbst!
// d.h. er wird in der Maske als Drittzahler eingestellt
$comp_payer = $db->getOne(
"SELECT cmp.cmp_comp FROM company AS cmp, customer AS cs, costcenter AS csc" .
" WHERE cmp.cmp_id = cs.cmp_id AND cs.cs_id = csc.cs_id AND csc.csc_id = '$csc_id_orderer'");
$comp_payer = my_str_check_js($comp_payer);
$javascript =
"setCsc_id_payer('$csc_id_orderer', '$comp_payer');\n";
// "curCsc_id_payer=$csc_id_orderer;\n";
$javascript .= javascriptAdd_cs_eid($csc_id_orderer, "");
$output = str_replace("{_csc_id_start_code_js_}", $javascript, $output);
if (!defined("MASK_WAITTIME_ENABLED"))
define ("MASK_WAITTIME_ENABLED", "0");
if (!defined("MASK_DATESELECTFIELDS_ENABLED"))
define ("MASK_DATESELECTFIELDS_ENABLED", "0");
if (!defined("MASK_CHECK_DISCOUNT"))
define ("MASK_CHECK_DISCOUNT", "1");
if (!defined("MASK_SERVICE_PRICE"))
define ("MASK_SERVICE_PRICE", "1");
define ("CUSTOMER_JOB", "1");
else:
$output = str_replace("{_csc_id_start_code_js_}", mkCsc_id_start($csc_id_start), $output);
define ("CUSTOMER_JOB", "0");
endif;
// $tpl->parseCurrentBlock("javascript");
// $tpl->setCurrentBlock("touroptions");
$output = str_replace("{_csc_id_orderer_}", ec($csc_id_orderer), $output);
$_request_token_ = date("YmdHis") . str_pad(gettimeofday()["usec"], 6, '0') . (isset($usr_id) ? $usr_id : "000000");
insertStmt("phoenix_log.semaphor", array("sp_obj_type", "usr", "sp_obj_id", (isset($usr_id) ? $usr_id : "000000"), "sp_fieldname", "request_token", "sp_content", $_request_token_, "sp_context", "NOT_SENT", "sp_createtime", date("Y-m-d H:i:s")));
$output = str_replace("{_request_token_}", $_request_token_, $output);
$output = str_replace("{_ec_jb_id_}", ec($jb_id), $output);
if (MASK_WAITTIME_ENABLED != "1"):
$output = str_replace("{WAITTIME_DISABLED_START}", "", $output);
else:
$output = str_replace("{WAITTIME_DISABLED_START}", "", $output);
$output = str_replace("{WAITTIME_DISABLED_END}", "", $output);
endif;
if (MASK_DATESELECTFIELDS_ENABLED != "1"):
$output = str_replace("{DATESELECTFIELDS_DISABLED_START}", "", $output);
$output = str_replace("{DATEINPUTFIELDS_DISABLED_START}", "", $output);
$output = str_replace("{DATEINPUTFIELDS_DISABLED_END}", "", $output);
$output = str_replace("{TIMESELECTFIELDS_DISABLED_START}", "", $output);
$output = str_replace("{TIMEINPUTFIELDS_DISABLED_START}", "", $output);
$output = str_replace("{TIMEINPUTFIELDS_DISABLED_END}", "", $output);
else:
$output = str_replace("{DATESELECTFIELDS_DISABLED_START}", "", $output);
$output = str_replace("{DATESELECTFIELDS_DISABLED_END}", "", $output);
$output = str_replace("{DATEINPUTFIELDS_DISABLED_START}", "", $output);
$output = str_replace("{TIMESELECTFIELDS_DISABLED_START}", "", $output);
$output = str_replace("{TIMESELECTFIELDS_DISABLED_END}", "", $output);
$output = str_replace("{TIMEINPUTFIELDS_DISABLED_START}", "", $output);
endif;
if (MASK_CHECK_DISCOUNT != "1"):
$output = str_replace("{DISCOUNT_DISABLED_START}", "", $output);
else:
$output = str_replace("{DISCOUNT_DISABLED_START}", "", $output);
$output = str_replace("{DISCOUNT_DISABLED_END}", "", $output);
endif;
if (MASK_SERVICE_PRICE != "1"):
$output = str_replace("{SERVICEPRICE_DISABLED_START}", "", $output);
else:
$output = str_replace("{SERVICEPRICE_DISABLED_START}", "", $output);
$output = str_replace("{SERVICEPRICE_DISABLED_END}", "", $output);
endif;
if (CUSTOMER_JOB == "1"):
$output = str_replace("{CUSTOMER_DISABLED_START}", "", $output);
// Steuern hartcodiert auf 16% für Kundenaufträge
$output = str_replace("{CUSTOMER_JB_SALES_TAX_RATE}",
"" .
"", $output
);
if (getFieldValueFromId("customer", "cs_id", "$cs_id", "cs_jbedit_cr") != "1"):
$output = str_replace("{CUSTOMER_COURIER_DISABLED_START}", "", $output);
else:
$output = str_replace("{CUSTOMER_COURIER_DISABLED_START}", "", $output);
$output = str_replace("{CUSTOMER_COURIER_DISABLED_END}", "", $output);
endif;
if (trim($db->getOne("SELECT cs_filter_jbedit FROM customer WHERE cs_id = $cs_id")) == ""):
$output = str_replace("{CUSTOMER_FILTER_DISABLED_START}", "", $output);
else:
$output = str_replace("{CUSTOMER_FILTER_DISABLED_START}", "", $output);
$output = str_replace("{CUSTOMER_FILTER_DISABLED_END}", "", $output);
endif;
$output = str_replace("{RANKING_JB2CRVH_MEASURE_DISABLED_START}", "", $output);
$RANKING_JB2CRVH_MEASURE_CS_IDS = $db->getOne("SELECT par_text FROM parameter WHERE hq_id = " . $hq_id . " AND par_key = 'RANKING_JB2CRVH_MEASURE_CS_IDS'");
if (!in_array ($cs_id, explode(",", $RANKING_JB2CRVH_MEASURE_CS_IDS))):
$output = str_replace("{RANKING_JB2CRVH_MEASURE_ENABLED_START}", "", $output);
else:
$output = str_replace("{RANKING_JB2CRVH_MEASURE_ENABLED_START}", "", $output);
$output = str_replace("{RANKING_JB2CRVH_MEASURE_ENABLED_END}", "", $output);
endif;
// if (getParameterValue("0", "CUSTOMER_MANUAL_DISPO_" . $cs_id, "0") != "1"):
$output = str_replace("{CUSTOMER_MANUAL_DISPO_START}", "", $output);
// else:
// $output = str_replace("{CUSTOMER_MANUAL_DISPO_START}", "", $output);
// $output = str_replace("{CUSTOMER_MANUAL_DISPO_END}", "", $output);
// endif;
else:
if (RANKING_JB2CRVH_MEASURE == "1"):
$output = str_replace("{RANKING_JB2CRVH_MEASURE_ENABLED_START}", "", $output);
$output = str_replace("{RANKING_JB2CRVH_MEASURE_ENABLED_END}", "", $output);
else:
$output = str_replace("{RANKING_JB2CRVH_MEASURE_DISABLED_START}", "", $output);
endif;
endif;
$output = str_replace("{_cr_id_options_}", (isset($cr_id_options) ? $cr_id_options : ""), $output);
//$output = str_replace("{_jb_waittime_options_}", $jb_waittime_options, $output);
$output = str_replace("{_vht_id_options_}", $vht_id_options, $output);
$output = str_replace("{_savedTour_disabled_}", $savedTour_disabled, $output);
$output = str_replace("{_savedTour_options_}", $savedTour_options, $output);
$output = str_replace("{_jb_permanent_options_}", $jb_permanent_options, $output);
$output = str_replace("{_jb_sales_tax_rate_sign_options_}", $jb_sales_tax_rate_sign_options, $output);
$output = str_replace("{_sales_tax_rate_value_}", $sales_tax_rate_value, $output);
// *** TABINDICES und ACCESSKEYS ***
$ti = 0;
$output = str_replace("{_cr_id_order_tabindex_}", ++$ti, $output);
$output = str_replace("{_crSidList_tabindex_}", ++$ti, $output);
$output = str_replace("{_crSidList_accesskey_}", _CRSIDLIST_ACCESSKEY_, $output);
$output = str_replace("{_jb_cr_filter_tabindex_}", ++$ti, $output);
$output = str_replace("{_jb_cr_filter_accesskey_}", _JB_CR_FILTER_ACCESSKEY_, $output);
$output = str_replace("{_jb_waitstorno_tabindex_}", ++$ti, $output);
if (MASK_WAITTIME_ENABLED == "1"):
$output = str_replace("{_jb_waittime_hour_tabindex_}", ++$ti, $output);
$output = str_replace("{_jb_waittime_minute_tabindex_}", ++$ti, $output);
endif;
$output = str_replace("{_vht_id_tabindex_}", ++$ti, $output);
$output = str_replace("{_jb_weight_tabindex_}", ++$ti, $output);
$output = str_replace("{_jb_crvh_length_tabindex_}", ++$ti, $output);
$output = str_replace("{_jb_crvh_width_tabindex_}", ++$ti, $output);
$output = str_replace("{_jb_crvh_height_tabindex_}", ++$ti, $output);
$output = str_replace("{_jb_crvh_position_tabindex_}", ++$ti, $output);
$output = str_replace("{_tag_tabindex_}", ++$ti, $output);
$output = str_replace("{_monat_tabindex_}", ++$ti, $output);
$output = str_replace("{_jahr_tabindex_}", ++$ti, $output);
$output = str_replace("{_stunde_tabindex_}", ++$ti, $output);
$output = str_replace("{_minute_tabindex_}", ++$ti, $output);
// $output = str_replace("{_jb_type_tabindex_}", ++$ti, $output);
// $output = str_replace("{_jb_type_accesskey_}", _JB_TYPE_ACCESSKEY_, $output);
$output = str_replace("{_endetag_tabindex_}", ++$ti, $output);
$output = str_replace("{_endemonat_tabindex_}", ++$ti, $output);
$output = str_replace("{_endejahr_tabindex_}", ++$ti, $output);
$output = str_replace("{_jb_permanent_tabindex_}", ++$ti, $output);
$output = str_replace("{_jb_permanent2_0_tabindex_}", ++$ti, $output);
$output = str_replace("{_jb_permanent2_1_tabindex_}", ++$ti, $output);
$output = str_replace("{_jb_permanent2_2_tabindex_}", ++$ti, $output);
$output = str_replace("{_jb_permanent2_3_tabindex_}", ++$ti, $output);
$output = str_replace("{_jb_permanent2_4_tabindex_}", ++$ti, $output);
$output = str_replace("{_jb_permanent2_5_tabindex_}", ++$ti, $output);
$output = str_replace("{_jb_permanent2_6_tabindex_}", ++$ti, $output);
$output = str_replace("{_savedTour_tabindex_}", ++$ti, $output);
$output = str_replace("{_jb_tourname_tabindex_}", ++$ti, $output);
$output = str_replace("{_jb_tourname_}", "", $output);
$output = str_replace("{_jb_tourname_overwrite_tabindex_}", ++$ti, $output);
$output = str_replace("{_jb_fixprice_tabindex_}", ++$ti, $output);
$output = str_replace("{_jb_serviceprice_tabindex_}", ++$ti, $output);
$output = str_replace("{_jb_discount_tabindex_}", ++$ti, $output);
$output = str_replace("{_jb_sales_tax_rate_tabindex_}", ++$ti, $output);
$output = str_replace("{_jb_sales_tax_rate_sign_tabindex_}", ++$ti, $output);
$output = str_replace("{_afterwards_tabindex_}", ++$ti, $output);
$output = str_replace("{_afterwards_accesskey_}", _AFTERWARDS_ACCESSKEY_, $output);
$output = str_replace("{_jb_globaljob_tabindex_}", ++$ti, $output);
// $output = str_replace("{_jb_globaljob_accesskey_}", _JB_GLOBALJOB_ACCESSKEY_, $output);
$output = str_replace("{_jb_status_manual_tabindex_}", ++$ti, $output);
$output = str_replace("{_jb_status_manual_accesskey_}", _JB_STATUS_MANUAL_ACCESSKEY_, $output);
$output = str_replace("{_jb_incomplete_tabindex_}", ++$ti, $output);
$output = str_replace("{_jb_incomplete_accesskey_}", _JB_INCOMPLETE_ACCESSKEY_, $output);
$output = str_replace("{_toursubmit_tabindex_}", ++$ti, $output);
$output = str_replace("{_toursubmit_accesskey_}", _TOURSUBMIT_ACCESSKEY_, $output);
// *** ***
// $tpl->parseCurrentBlock("touroptions");
// include("../jobs/shrink.inc.php");
// $html_code = $tpl->get();
// echo htmlShrink($html_code, true);
// $tpl->show();
echo $output;
elseif (!(isset($check_jb_permanent_flag) && $check_jb_permanent_flag == true)):
$jb_subtotal = round($jb_fixprice * ((100-$self_service_discount)/100), 2);
$jb_subtotal = round($jb_subtotal * (1 - ($tmp_discount_rate / 100)), 2);
$jb_totalprice = round($jb_subtotal * (1 + ($jb_markup / 100)) + $jb_serviceprice * (1 - ($tmp_discount_rate / 100)), 2);
$jb_markup_text = "";
if ($jb_markup > 0)
$jb_markup_text = " (" . str_replace(".", ",", sprintf("%01.2f", $jb_markup)) . "% Tz.)";
$javascript = "";
// falls mediation_areas ermittelt wurden, diese setzen
for ($ma = 0; $ma < count($setMediation_area_idArr); $ma += 2)
$javascript .= "parent.job_options.setJobList(" . $setMediation_area_idArr[$ma] . ", " . JL_TR_MEDIATIONAREA_ID . ", " . $setMediation_area_idArr[$ma+1] . ");\n";
if ($self_service_discount > 0) $discount_sign .= " (-" . $self_service_discount . "%)";
$javascript .=
"parent.job_options.document.tourOptions.jb_markup.value = $jb_markup;\n" .
(MASK_CALCULATOR_SRV_SRC == "1" ? getCustomerServices($db, $cs_id) : "") .
"parent.job_tour.document.tourForm.currentPrice.value = " .
"\"" . /*"Standard Preis: " .*/ str_replace(".", ",", sprintf("%01.2f", $fullPrice)) . " EUR" . $discount_sign . $jb_markup_text . "\";\n" .
"if (parent.job_options.document.tourOptions.jb_fixprice.value != \"\") {" .
// " parent.job_tour.document.tourForm.currentPrice.value = parent.job_options.formatPrice(String(parseFloat(parent.job_options.document.tourOptions.jb_fixprice.value.replace(/,/,\".\")))) + \" EUR\"};\n";
" parent.job_tour.document.tourForm.currentPrice.value = '" . str_replace(".", ",", sprintf("%01.2f", $jb_totalprice)) . "' + \" EUR" . ($self_service_discount > 0 ? " (-" . $self_service_discount . "%)" : "") . $jb_markup_text . "\"};\n";
// if ($discount_sign == "*" && ($jb_fixprice == "" || $jb_fixprice = 0))
// $javascript .=
// "parent.job_options.document.tourOptions.jb_fixprice.value = '" . str_replace(".", ",", sprintf("%01.2f", $fullPrice)) . "';";
$javascript .=
"self.setTimeout('parent.job_options.writeJob()', 1)\n";
// $javascript =
// "opener.parent.frames[" . JOB_TOUR . "].document.forms[" . TOURFORM ."].elements[\"currentPrice\"].value = " .
// "\"" . str_replace(".", ",", ("$fp - $fd")) . " EUR\";\n";
// $javascript .= javascriptOpenerRefreshAndClose(1);
// Inhalt des temporären Fensters erzeugen und ausgeben
// if ($phpVersion >= "7.0"):
// $tpl = new HTML_Template_IT();
// else:
// $tpl = new IntegratedTemplate();
// endif;
$output = file_get_contents(GETDATAHTMLTPL);
$output = str_replace("{_javascript_}", $javascript, $output);
// include("../jobs/shrink.inc.php");
// $html_code = $tpl->get();
// echo htmlShrink($html_code, true);
echo $output;
endif;
if (!isset($jb_id_log)) $jb_id_log = "undefined";
writeLog_("../log/job2_options_", trace_execution_time_stop() . " '../jobs2/job_options.php' executed, '$jobMode': \$jb_id=$jb_id_log , \$usr_id=$usr_id, \$job_is_new=$job_is_new, \$getPriceOnly=$getPriceOnly, \$csc_id_payer=$csc_id_payer");
?>