= "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/job_options_", var_export($_POST, 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"));
list ($disp) = getHttpVars(array("disp"));
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_tourname_overwrite, $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_hiddenFreetext_1, $jb_costsplit, $jb_permanent2, $jb_multi, $jb_multi_factor,
$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_id_parent, $tmp_add_jb_ids, $tmp_add_sids, $tmp_add_prices,
$tmp_add_srvs, $tmp_add_srvts, $tmp_add_mult, $tmp_add_mult_price, $jb_dispoinfo, $jb_warntag, $jb_warnmonat, $jb_warnjahr, $jb_warnstunde, $jb_warnminute, $jb_jam_waittime, $jb_offer, $jb_markup,
$jb_cr_markup, $cr_id_order_hidden, $cr_id_orders, $ask_mailrecipients, $sendmail, $jb_toll, $jb_id_permanent_pre, $jb_cashpayer_mail, $do_delete_suborder, $cr_price_threshold_override,
$cr_price_block_override, $hq_id, $km_price_params, $jb_km, $jb_id_insurance, $jb_value_of_goods, $special_case, $special_case_ori, $jb_insurance_rate, $self_service_discount, $jb_tourname_hidden,
$cs_invmail, $jb_origin, $jb_origin_other, $request_token, $jb_orderer, $jb_commission_no, $jb_bwv, $jb_offer_mail) =
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_tourname_overwrite", "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_hiddenFreetext_1", "jb_costsplit_hidden", "jb_permanent2_hidden", "jb_multi", "jb_multi_factor",
"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_id_parent",
"tmp_add_jb_ids", "tmp_add_sids", "tmp_add_prices", "tmp_add_srvs", "tmp_add_srvts", "tmp_add_mult", "tmp_add_mult_price", "jb_dispoinfo",
"jb_warntag", "jb_warnmonat", "jb_warnjahr", "jb_warnstunde", "jb_warnminute", "jb_jam_waittime",
"jb_offer", "jb_markup", "jb_cr_markup", "cr_id_order_hidden", "cr_id_orders", "ask_mailrecipients", "sendmail", "jb_toll", "jb_id_permanent_pre", "jb_cashpayer_mail_hidden", "do_delete_suborder",
"cr_price_threshold_override", "cr_price_block_override", "hq_id", "km_price_params", "jb_km", "jb_id_insurance", "jb_value_of_goods", "special_case", "special_case_ori", "jb_insurance_rate",
"self_service_discount", "jb_tourname_hidden", "cs_invmail_hidden", "jb_origin_hidden", "jb_origin_other_hidden", "request_token", "jb_orderer_hidden", "jb_commission_no_hidden", "jb_bwv",
"jb_offer_mail_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/job_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/job_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" : "NEW") . ((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 (!isset($jb_id_org) || 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;
$cs_invmode = 0;
if ($csc_id_orderer != '0'):
// Kundenaufrag
$cs_id = getFieldValueFromId("costcenter", "csc_id", "$csc_id_orderer", "cs_id");
$hq_id = getFieldValueFromId("customer", "cs_id", "$cs_id", "hq_id");
// wenn Kundenauftrag, dann entscheidet der zentralenabhängige Modus darüber, ob manuell oder automatisch
if (MASK_MANUAL_DISPOSITION == '1' || getParameterValue("0", "MASK_MANUAL_DISPO_MANDATORY_" . $cs_id, "0") == "1"):
$jb_status_manual = 1;
endif;
// cs_invmode ist vom Bezahler abhängig!!!
// $cs_invmode = getFieldValueFromId("customer", "cs_id", "$cs_id", "cs_invmode");
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))
if ($hq_id == "")
$hq_id = $HTTP_SESSION_VARS['hq_id'];
if ($hq_id_job != "")
$hq_id = $hq_id_job;
// *** 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;
$CSC_ID_PAYER_CASH_VAR = getParameterValue("0", "CSC_ID_PAYER_CASH", $hq_id);
// // 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");
$hq_invmode = getFieldValueFromId("headquarters", "hq_id", "$hq_id", "hq_invmode");
$jobbatch_mode = false;
$tr_sort_jobbatchmode = 0;
$tr_sort_cashpayer = 0;
$is_EU = false;
$eu_countrycodes = explode(",", trim(getParameterValue("0", "EU_COUNTRYCODES", "0")));
$is_EU_only = true;
$is_foreign = false;
$is_globaljob = false;
$gross_price = 0;
$distance = 0;
$jb_tourname_old = "";
// *** Nur für's Logging
if ($toursubmit == "Senden"):
$jobMode = "";
if ((isset($check_jb_permanent_flag) && $check_jb_permanent_flag == true)) $jobMode =
(isset($jb_id_ori) ? "\$jb_id_ori=$jb_id_ori" : "") .
(isset($jb_id_ori_copy) ? "\$jb_id_ori_copy=$jb_id_ori_copy" : "") .
(isset($jb_id_permanent_pre1) ? "|\$jb_id_permanent_pre1=$jb_id_permanent_pre1" : ""); // "*** DUPLICATION OF STANDING ORDER ***";
if ($getPriceOnly == 1) $jobMode = "Preisanfrage"; // "*** PRICE INQUIRY ***";
if (isset($afterwards) && $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...
$jb_offer_old = 0;
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, $jb_cr_price_old, $csc_id_payer_old, $csc_id_payer_cash_old,
$jb_type_old, $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_id_parent_old, $jb_dispoinfo_old, $jb_offer_old, $jb_warningtime_old, $jb_markup_old, $hq_id_dispo_old, $jb_longhaul_old, $jb_origin_old, $jb_orderer_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", "jb_cr_price", "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_id_parent", "jb_dispoinfo", "jb_offer", "jb_warningtime", "jb_markup", "hq_id_dispo", "jb_longhaul", "jb_origin", "jb_orderer", "jb_commission_no"));
if (MASK_CR_PRICE_MODE == "1") {
$jb_cr_serviceprice_old = $db->getOne("SELECT gdc_content FROM genericdatacontainer WHERE gdc_obj_type = 'jb' AND gdc_obj_id = " . $jb_id . " AND gdc_gen_fieldname = 'jb_cr_serviceprice'");
// $jb_cr_markup_old = $db->getOne("SELECT gdc_content FROM genericdatacontainer WHERE gdc_obj_type = 'jb' AND gdc_obj_id = " . $jb_id . " AND gdc_gen_fieldname = 'jb_cr_markup'");
$jb_cr_markup_old = $db->getOne("SELECT jbprc_price FROM jobprice WHERE jb_id = " . $jb_id . " AND mt_sort IN (" . JB_CR_MARKUP . ", " . JB_CR_MARKUP_MAN . ")");
}
$jb_km_old = $db->getOne("SELECT jbprc_price FROM jobprice WHERE jb_id = " . $jb_id . " AND mt_sort = 11");
$jb_hiddenFreetext_1_old = $db->getOne("SELECT gdc_content FROM genericdatacontainer WHERE gdc_obj_type = 'jb' AND gdc_obj_id = " . $jb_id . " AND gdc_gen_fieldname = 'jb_hiddenFreetext_1'");
$jb_cashpayer_mail_old = $db->getOne("SELECT gdc_content FROM genericdatacontainer WHERE gdc_obj_type = 'jb' AND gdc_obj_id = " . $jb_id . " AND gdc_gen_fieldname = 'jb_cashpayer_mail'");
$jb_offer_mail_old = $db->getOne("SELECT gdc_content FROM genericdatacontainer WHERE gdc_obj_type = 'jb' AND gdc_obj_id = " . $jb_id . " AND gdc_gen_fieldname = 'jb_offer_mail'");
$jb_toll_old = $db->getOne("SELECT gdc_content FROM genericdatacontainer WHERE gdc_obj_type = 'jb' AND gdc_obj_id = " . $jb_id . " AND gdc_gen_fieldname = 'jb_toll'");
$jb_origin_other_old = $db->getOne("SELECT gdc_content FROM genericdatacontainer WHERE gdc_obj_type = 'jb' AND gdc_obj_id = " . $jb_id . " AND gdc_gen_fieldname = 'jb_origin_other'");
endif;
// $jb_tourname muss immer geholt werden, denn wenn eine Konserve geändert wird, dann muss das immer der aktuelle Preis sein!
$i = 1;
if (trim($jb_id) != ""):
$jb_tourname_old = $db->getOne("SELECT jb_tourname FROM job WHERE jb_id = " . $jb_id);
// gespeicherte Tour-Daten holen
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, "tour");
$tr_id_old_[$i] = $db->getOne("SELECT tr_id FROM tour WHERE jb_id = " . $jb_id . " AND tr_sort = " . $i);
$tr_photo_old_[$i] = $db->getOne("SELECT gdc_content FROM genericdatacontainer WHERE gdc_obj_type = 'tr' AND gdc_obj_id = " . $tr_id_old_[$i] . " AND gdc_gen_fieldname = 'tr_photo'");
else:
$tourFound = 0;
endif;
$i++;
} while ($tourFound == 1);
endif;
$i_tour_max_old = $i - 1;
endif;
// *** Nur für's Logging ENDE
writeLog_("../log/job_options_", "\$jb_tourname_old = " . $jb_tourname_old);
if ($jb_storno > 0)
$jb_tourname = "";
$jb_fixprice_ori = $jb_fixprice;
$jb_fixprice = (float) str_replace(",", ".", $jb_fixprice);
$jb_markup_ori = isset($jb_markup) ? $jb_markup : "";
$jb_markup = (float) str_replace(",", ".", isset($jb_markup) ? $jb_markup : "0");
$jb_cr_markup_ori = isset($jb_cr_markup) ? $jb_cr_markup : "";
$jb_cr_markup = (float) str_replace(",", ".", isset($jb_cr_markup) ? $jb_cr_markup : "0");
$jb_toll_ori = $jb_toll;
if (trim($jb_toll != ""))
$jb_toll = (float) str_replace(",", ".", $jb_toll);
$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_ori = $jb_cr_serviceprice;
$jb_cr_serviceprice = (float) str_replace(",", ".", $jb_cr_serviceprice);
}
$jb_cr_fixserviceprice = 0.0;
$jb_km_ori = $jb_km;
$jb_km = (float) str_replace(",", ".", $jb_km);
if (trim($jb_value_of_goods) != "")
$jb_value_of_goods = (float) str_replace(",", ".", $jb_value_of_goods);
$addressValid = "ok";
$job_is_new = true;
$tmp_discount = 0;
$tmp_discount_rate = 0;
if ($jb_discount == 1)
$tmp_discount_rate = $jb_discount_rate;
// Preise werden immer ermittelt, auch wenn $getPriceOnly != 1 (ist halt einfacher)
$fullPrice = 0.00;
$jb_subtotal = 0.00;
$jb_totalprice = 0.00;
$discount_sign = "";
$discount_sign_cr = "";
//$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;
};
$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/job_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/job_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 (isset($afterwards) && $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", "99");
$is_globaljob = true;
else:
$insertStmtArr = array("csc_id", $csc_id_orderer);
endif;
// Sonderfall: Wenn Auftragsänderung, kann normalerweise der Fahrer nicht mehr geändert werden.
// Ausnahme: wenn über den Calculator das jeweilige 750-Fahrzeug eingetragen wird. Dann ist der Auftrag
// erledigt (sonst geht Calc. nicht), und deshalb muss wie bei einer Nacherfassung auch der
// annehmende Kurier angepasst werden!
// if ($cr_id_order_hidden != "" && (substr($cr_id_order_hidden, -3) == "751" || substr($cr_id_order_hidden, -3) == "750")):
if ($cr_id_order_hidden != "" && (substr($cr_id_order_hidden, -3) == substr(MASK_INVOICE_SIDS_SID, -3, 2) . "6" || substr($cr_id_order_hidden, -3) == substr(MASK_INVOICE_SIDS_SID, -3, 2) . "5")):
array_push ($insertStmtArr, "cr_id",
getFieldValueFromId("couriervehicle", "crvh_sid", $cr_id_order_hidden, "cr_id"),
"cr_sid", $cr_id_order_hidden);
endif;
// Unerauftrag wurde gelöscht und der Fahrer muss daher neu gespeichert werden
if ($do_delete_suborder == "1"):
array_push ($insertStmtArr, "cr_id",
getFieldValueFromId("couriervehicle", "crvh_sid", $cr_id_order, "cr_id"),
"cr_sid", $cr_id_order);
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
//writeLog_("../log/job_options_", "\$jb_id = " . $jb_id . ", MASK_COURIER_IMMEDIATE = " . MASK_COURIER_IMMEDIATE . ", MASK_COURIER_IMMEDIATE = " . getParameterValue("0", "MASK_COURIER_IMMEDIATE", $hq_id) . ", \$check_jb_permanent_flag = " . $check_jb_permanent_flag);
if ((!($tag != "" && $monat != "" && $jahr != "" && $stunde != "" && $minute != "") || $jb_globaljob == 1)
|| $hq_workmode == "1" || (getParameterValue("0", "MASK_COURIER_IMMEDIATE", $hq_id) == "1" && !(isset($check_jb_permanent_flag) && $check_jb_permanent_flag == true))):
$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", "99");
$is_globaljob = true;
endif;
endif;
// die einzelnen Touren sind auch noch NICHT erledigt
$tr_status = "0";
endif;
array_push ($insertStmtArr, "jb_invmode", isset($cs_invmode) ? $cs_invmode : 0);
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);
// if ($jb_globaljob != "")
array_push ($insertStmtArr, "jb_globaljob", $jb_globaljob);
// if ($jb_type != "")
array_push ($insertStmtArr, "jb_type", $jb_type);
array_push ($insertStmtArr, "jb_id_parent", $jb_id_parent);
// if ($jb_freetext_1 != ""):
array_push ($insertStmtArr, "jb_freetext_1", my_str_check_http($jb_freetext_1));
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);
array_push ($insertStmtArr, "jb_offer", $jb_offer);
// endif;
// 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);
$filters_text = "";
$filters_sql = $jb_cr_filter . (trim($jb_cr_filter) == "" || trim($jb_cr_filter_opt) == "" ? "" : ",") . $jb_cr_filter_opt;
$filters_sql = str_replace(",", "','", $filters_sql);
if ($filters_sql != "") {
$sqlquery = "SELECT crf_longtext FROM courierfilter WHERE crf_short IN ('" . $filters_sql . "')";
$res = $db->query($sqlquery);
if (DB::isError($res)) reportDie ("$PHP_SELF: '$sqlquery': " . $res->getMessage());
while ($row = $res->fetch_assoc()):
if (trim($row['crf_longtext']) != "")
$filters_text .= $row['crf_longtext'] . "\n";
endwhile;
$res->free();
}
if ($filters_text != "")
$filters_text = "~~~\n". $filters_text . "~~~\n";
// wenn Datum gesetzt, dann übernehmen, sonst aktuelle Zeit (nur wenn nicht Nachbearbeitung!!!)
$jb_ordertime = "";
if ($tag == "" || $monat == "" || $jahr == "" || $stunde == "" || $minute == ""):
if ($jb_id == "" || $db->getOne("SELECT jb_reserv FROM job WHERE jb_id = '$jb_id'") == 1 || ($jb_offer == 0 && $jb_offer_old == 1)):
$today = getdate();
$jb_ordertime = $today['year'] . "-" . $today['mon'] . "-" . $today['mday'] . " "
. $today['hours'] . ":" . $today['minutes'] . ":" . $today['seconds'];
array_push ($insertStmtArr, "jb_reserv", 0);
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 (isset($afterwards) && $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 23:59:59";
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 (isset($afterwards) && $afterwards == "1"):
// Nacherfassung: Job ist bereits erledigt
// 'finishtime' und 'taketime' ist 'ordertime'
array_push ($insertStmtArr, "jb_finishtime", $jb_ordertime);
array_push ($insertStmtArr, "jb_taketime", $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;
if (trim($jb_toll != ""))
$jb_toll = sprintf("%01.2f", $jb_toll * -1);
endif;
array_push ($insertStmtArr, "jb_fixprice", $jb_fixprice, "jb_serviceprice", $jb_serviceprice, "jb_cr_subprice", $jb_cr_price);
$jb_sales_tax_rate_sign_new = $db->getOne("SELECT tx_sign FROM tax WHERE tx_id = '$jb_sales_tax_rate_sign'");
$jb_sales_tax_rate = $db->getOne("SELECT tx_value FROM tax WHERE tx_id = '$jb_sales_tax_rate_sign'");
$jb_ordertime_vals = getValsFromDate($jb_ordertime);
if (($hq_id == 2 || $hq_id == 3 || $hq_id == 5) && $jb_markup > 0 && mktime(0, 0, 0, 11, 16, 2021) > mktime(0, 0, 0, $jb_ordertime_vals[1], $jb_ordertime_vals[2], $jb_ordertime_vals[0])):
$jb_markup_ori = 0;
$jb_markup = 0;
endif;
if ($jb_sales_tax_rate > 0 && mktime(0, 0, 0, 7, 1, 2020) > mktime(0, 0, 0, $jb_ordertime_vals[1], $jb_ordertime_vals[2], $jb_ordertime_vals[0])):
$jb_sales_tax_rate = 19;
endif;
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;
// // 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", isset($usr_id) ? $usr_id : 0);
// bei einem zu ändernden Job darf die originale hq_id nicht geändert werden (insbesondere im Falle der Ferntour)
array_push ($insertStmtArr, "hq_id", $hq_id);
endif;
//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) {
// Wenn eine ursprüngliche Nacherfassung geändert wird, dann muss auch die Finishtime angepasst werden, wenn die Ordertime geändert wurde! Ganz wichtig!!!
$was_afterwards = job_was_afterwards($jb_id);
if ($was_afterwards) {
if ($jb_ordertime != "") {
// 'finishtime' und 'taketime' ist 'ordertime'
array_push ($insertStmtArr, "jb_finishtime", $jb_ordertime);
array_push ($insertStmtArr, "jb_taketime", $jb_ordertime);
}
}
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!" . $statusMessageTxt;
$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"):
// ar_cr_order muss im Falle einer Reservierung und Anforderung eines Fahrers auf 1 gesetzt werden, damit das Autoranking weiß, dass
// der Kurier für die Reservierung explizt angefordert wurde, womit der Auftrag bei nicht-Vorhandesein des angeforderten Fahrers
// wieder in die Vermittlung (in die zuzuweisenden) zurückgeht, ansonsten würde er weiteren Fahrern angeboten werden
$ar_cr_order = 0;
if ($jb_reserv == 1)
$ar_cr_order = 1;
// 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, "ar_cr_order", $ar_cr_order);
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, "ar_cr_order", $ar_cr_order);
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;
// zu guter Letzt: evtl. bestehende Unteraufträge löschen!
deleteJobChildren($jb_id_copy);
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_tourname_old == "" ? $jb_ordertime : date("Y-m-d H:i:s")), 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 (isset($jb_cash) && $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_VAR != ""):
$csc_id_payer = $CSC_ID_PAYER_CASH_VAR;
endif;
endif;
$costsplit_count = 1;
// Barzahlung
$jb_payment = 2;
else:
// Zahlungsmodus festhalten
if (isset($jb_costsplit) && $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;
$hq_id_sales = $hq_id;
if ($csc_id_payer == 0 || $csc_id_payer == ""): // csc_id_payer == 0 ==> Kostensplit
$cs_invmode = $hq_invmode;
$cs_id = 0;
else:
$cs_id = getFieldValueFromId("costcenter", "csc_id", "$csc_id_payer", "cs_id");
$hq_id_sales = getFieldValueFromId("customer", "cs_id", $cs_id, "hq_id");
// Noch was Neues: Wenn beim Kunden hinterlegt ist, dass bei der Abholung bei diesem Kunden dessen Konditionen (cs_jbcond = 1) gelten soll,
// dann gelten für die Preisermittlung nicht die Konditionen des Zahlers!
$cs_id_cond = getFieldValueFromId("costcenter", "csc_id", $jobList[0][JL_CSC_ID], "cs_id");
$cs_jbcond = getFieldValueFromId("customer", "cs_id", $cs_id_cond, "cs_jbcond");
if ($cs_jbcond == 1)
$cs_id = $cs_id_cond;
// invmode ermitteln (ist abhängig von dem aktuellen Bezahler), kann neuerdings auch von der Kostenstelle 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");
}
$cmp_postage_old = $db->getOne("SELECT cmp_postage FROM customer AS cs, company AS cmp WHERE cmp.cmp_id = cs.cmp_id AND cs_id = " . $cs_id);
$cmp_postage = $cmp_postage_old;
endif;
if (trim($jb_markup_ori) == "") {
$jb_markup = getFuelMarkup($srvt_name, (trim($cs_id) != "" ? $cs_id : 0), $hq_id, $jb_ordertime);
}
if (MASK_CR_PRICE_MODE == "1") {
if (trim($jb_cr_markup_ori) == "") {
$vhtSrvt_name = $db->getOne("SELECT mt_value FROM metatype WHERE mt_sort = '$vht_id' AND mt_type = 'vehicletype'");
$jb_cr_markup = getFuelMarkupCr($vhtSrvt_name, (trim($cs_id) != "" ? $cs_id : 0), $hq_id, $jb_ordertime);
}
}
// 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 &&
getParameterValue("0", "MASK_FAVOURED_COURIER_MANUAL", $hq_id) == "1" && isset($afterwards) && $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_dispo = $db->getOne("SELECT hq_id FROM serviceplz WHERE srvp_plz = '" . $jobList[0][JL_AD_ZIPCODE] . "'");
if ($hq_id_dispo == "")
$hq_id_dispo = $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_dispo", $hq_id_dispo,
"hq_id_sales", $hq_id_sales);
updateStmt("job", "jb_id", $jb_id, $tmpArr);
// ************************************************************************************************
// Ab hier werden Preise ermittelt und ggfs. gespeichert
// Achtung: Beim Speichern in tourservice (bzw. Aufruf von saveservicecosts)
// Barzahlung mit ausgewähltem Bezahler berücksichtigen!
$tmpCsc_id_payer = $csc_id_payer;
// $tmpCsc_id_payer zum Ermitteln und Speichern des tatsächlichen Zahlers. Der übergebene csc_id_payer soll für das Logging erhaslten bleiben.
// Wichtig für Barzahlung: $tmpCsc_id_payer ist hier immer der System-Barzahler, während in csc_id_payer festgehalten wird, wer der in der Realität zahlende Barzahler ist.
if ($jb_payment == 2):
// 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"):
$tmpCsc_id_payer = "-1";
if ($CSC_ID_PAYER_CASH_VAR != ""):
$tmpCsc_id_payer = $CSC_ID_PAYER_CASH_VAR;
endif;
endif;
endif;
// aus bisher nicht geklärten Gründen ist $tmpCsc_id_payer manchmal 0;
// kann nur im Barzahlungsfall auftreten, deshlab hier sicherstellen, dass dann auch die Barzahler-ID hier drin steht
if ($tmpCsc_id_payer == 0 || $tmpCsc_id_payer == "")
$tmpCsc_id_payer = getParameterValue("0", "CSC_ID_PAYER_CASH", $hq_id);
// 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"*/):
//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_tourname_old == "" ? $jb_ordertime : date("Y-m-d H:i:s")), 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, $jb_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
";
$di_ids = array();
if (!($jb_fixprice == "" || $jb_fixprice == 0) || $jobbatch_mode == true /* && $jb_fixprice != "0.00"*/):
if ($jb_storno == 0):
// Km-Preis?
$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("job_options: [" . $sqlquery . "]");
writeLog_xServer("job_options: [" . "\$db_geo ist " . (is_null($db_geo) ? "" : "nicht ") . "null" . "]");
if (!is_null($db_geo)) {
$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())):
// writeLog_xServer("job_options: [" . var_export(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[2], $row["di_id"]) === false) ? 2 : (!(strpos($ro_types[1], $row["di_id"]) === false) ? 1 : 0)), "ro_date", $row["di_modify"]), true) . "]");
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[2], $row["di_id"]) === false) ? 2 : (!(strpos($ro_types[1], $row["di_id"]) === false) ? 1 : 0)), "ro_date", $row["di_modify"]));
endwhile;
$res->free();
} else {
$di_ids = explode(",", str_replace(";", ",", $km_price_paramsArr[4]));
foreach($di_ids as $di_id) {
insertStmt("phoenix_log.route", array("jb_id", $jb_id, "di_id", $di_id, "ro_distance", 0, "ro_duration", 0, "ro_polyline", 0, "ro_num", ++$cnt));
}
}
}
$fixprice_min = $km_price_paramsArr[5];
}
}
//echo ($km_price_params) . "
\n";
//print_r ($km_price_paramsArrArr) . "
\n";die();
// 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_VAR : $tmpCsc_id_payer) : ""));
//die();
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 und ggfs. ohne Rabatt)
$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",
((getParameterValue("0", "INV_SERVICEPRICE_DISCOUNT", $hq_id) == "1") ? $tmp_discount_rate : 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;
$prev_ad_id = "";
$prev_tr_mediationarea_id = 0;
$jb_tourdata1 = "";
$jb_tourdata2 = "";
$jb_tourdata3 = "";
$insertedOrUpdatedTr_ids = "";
// 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
//echo "insertAddress($jobList[$i][JL_AD_STREET], $jobList[$i][JL_AD_ZIPCODE], $jobList[$i][JL_AD_CITY], $csc_id, $jobList[$i][JL_AD_COUNTRY], ($accept_all_addresses == \"1\"))";
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" && !(isset($jb_storno) && $jb_storno > 0)):
// address invalid -> I must die...
// error-message is in tr_person, rest is empty
$statusMessageTxt = $tr_person;
$addressValid = "";
break;
endif;
if ($is_EU_only) {
//echo $jobList[$i][JL_AD_COUNTRY] . "
\n";
$is_EU_only = in_array($jobList[$i][JL_AD_COUNTRY], $eu_countrycodes);
//echo "is_EU_only = " . $is_EU_only . "
\n";
}
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
//echo "\n
insertAddress(".$jobList[$i][JL_AD_STREET].",". $jobList[$i][JL_AD_ZIPCODE].",". $jobList[$i][JL_AD_CITY].",". $csc_id.",". $jobList[$i][JL_AD_COUNTRY]."," . ($accept_all_addresses == "1") .")";
if (!$is_foreign)
$is_foreign = $jobList[$i][JL_AD_COUNTRY] != "DE";
$jb_tourdata2_add = "";
$tmp_accept_all_addresses = isset($accept_all_addresses) ? $accept_all_addresses : false;
$insertAddressDistrictCity = getParameterValue("0", "MASK_INSERTADDRESS_DISTRICT_" . getFieldValueFromId("costcenter", "csc_id", "$csc_id_payer", "cs_id"), "0");
if ($insertAddressDistrictCity != "" && !(strpos($jobList[$i][JL_AD_CITY], $insertAddressDistrictCity) === false)):
$addresses = checkCityZipcode($jobList[$i][JL_AD_ZIPCODE], $jobList[$i][JL_AD_CITY], $jobList[$i][JL_AD_STREET], "2");
//print_r($addresses);
for($matchedCount = 1; $matchedCount <= count($addresses); $matchedCount++):
if (trim($addresses["st_district"][$matchedCount]) != "" && strpos($jobList[$i][JL_AD_CITY], $addresses["st_district"][$matchedCount]) === false):
// $jobList[$i][JL_AD_CITY] .= "-" . $addresses["st_district"][$matchedCount];
// $tmp_accept_all_addresses = "1";
$jb_tourdata2_add = "-" . $addresses["st_district"][$matchedCount];
break;
endif;
endfor;
endif;
//echo $jobList[$i][JL_AD_CITY]; die();
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], ($tmp_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_tourdata2_add;
$jb_tourdata3 .= ($jb_tourdata3 == "" ? "" : ";") . (trim($jobList[$i][JL_AD_COUNTRY]) == "" ? "DE" : $jobList[$i][JL_AD_COUNTRY]);
if ($is_EU_only)
$is_EU_only = in_array($jobList[$i][JL_AD_COUNTRY], $eu_countrycodes);
// if (!$is_EU)
// $is_EU = (trim($jobList[$i][JL_AD_COUNTRY]) == "DE" || trim($jobList[$i][JL_AD_COUNTRY]) == "") ? false : true;
// 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" && !(isset($jb_storno) && $jb_storno > 0)):
// 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);
}
//echo str_replace("\n", "<br>
", "|" . $jb_cr_priceStr . "|") . "
";
//echo str_replace("\n", "<br>
", $tr_remark) . "
";
$tr_remark = str_replace("\r\n\r\n" . $jb_cr_priceStr, "", $tr_remark);
$tr_remark = str_replace("\r\n" . $jb_cr_priceStr, "", $tr_remark);
$tr_remark = str_replace("\n". $jb_cr_priceStr, "", $tr_remark);
$tr_remark = str_replace($jb_cr_priceStr, "", $tr_remark);
//echo str_replace("\n", "<br>
", $tr_remark) . "
";die();
endif;
// Wenn Barzahlung vorhanden, hier erstmal entfernen
$tr_remark = str_replace("\n*** ZAHLT BAR ***", "", $tr_remark);
$tr_remark = str_replace("*** ZAHLT BAR ***", "", $tr_remark);
$tr_remark = str_replace("\n*** LIEFERSCHEIN ZUR ZENTRALE STADTBOTE ***", "", $tr_remark);
$tr_remark = str_replace("*** LIEFERSCHEIN ZUR ZENTRALE STADTBOTE ***", "", $tr_remark);
// $tr_remark = preg_replace("/\n\*\*\* FESTPREIS \(LISTE\) EUR .* \*\*\*/", "", $tr_remark);
// $tr_remark = preg_replace("/\*\*\* FESTPREIS \(LISTE\) EUR .* \*\*\*/", "", $tr_remark);
if (MASK_CR_PRICE_MODE == "1" && !(strpos($tr_remark, "*** Bitte im Auftrag STADTBOTE Bar") === false)):
$barStr = strstr($tr_remark, "*** Bitte im Auftrag STADTBOTE Bar");
$barStr = substr($barStr, 0, strpos($barStr, "kassieren und quittieren. ***") + strlen("kassieren und quittieren. ***"));
$tr_remark = str_replace("\n" . $barStr, "", $tr_remark);
$tr_remark = str_replace($barStr, "", $tr_remark);
endif;
//echo str_replace("\n", "<br>
", $tr_remark) . "
";die();
// Wenn Fuhrlohn angezeigt werden soll, hier hinzufügen
$tr_remark_add = "";
if (MASK_JB_CR_PRICE_2_TR_REMARK == "1" && (($i + 1) == 1) && MASK_CR_PRICE_MODE == "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 (isset($jb_cash) && $jb_cash == "true" && $jobList[$i][JL_CSC_ID_PAYER] == "true"):
// Wenn Barzahlung und Bezahler angegeben, dann hier festhalten!
// $tr_remark .= "\n*** ZAHLT BAR ***";
//$honk=substr($tr_remark, strlen($tr_remark)-1, strlen($tr_remark));
//echo str_replace("\n", "<br>
", $tr_remark) . "
";
$tr_remark .= "\n*** ZAHLT BAR ***";
if (MASK_CR_PRICE_MODE == "1"):
$tr_sort_cashpayer = ($i + 1);
endif;
//echo str_replace("\n", "<br>
", "|" . $honk . "|" . $tr_remark) . "
";die();
endif;
//echo str_replace("\n", "<br>
", $tr_remark) . "
";
if (in_array ("LZ", explode(",", $jb_cr_filter_opt)) && ($i + 1) == 1)
$tr_remark .= "\n*** LIEFERSCHEIN ZUR ZENTRALE STADTBOTE ***";
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") . "'") == "1" ||
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") . "'");
if ($tr_photo == ""):
$tr_photo = "1|1"; // Default: Mindestens ein Photo, höchstens eins (d.h. genau ein Foto)
endif;
elseif (getFieldValueFromClause("parameter", "par_value", "par_key='MASK_MIN_MAX_TR_PHOTO_CS_" . getFieldValueFromId("costcenter", "csc_id", "$csc_id_payer", "cs_id") . "'") == "0|0"):
$tr_photo = "0|0"; // Foto verhindern
endif;
// 08.09.2021: Zum Testen soll jede Station mir einer Foto-Möglichkeit versehen werden, wenn keines extra angefordert ist
$gdc_context_add = "";
if ($tr_photo == "" && getParameterValue("0", "MASK_TR_PHOTO_FORCE", "0") == "1" &&
getFieldValueFromClause("parameter", "par_value", "par_key='MASK_TR_PHOTO_CS_" . getFieldValueFromId("costcenter", "csc_id", "$csc_id_payer", "cs_id") . "'") != "1") {
$tr_photo = getParameterValue("0", "MASK_MIN_MAX_TR_PHOTO_FORCE", "0");
$gdc_context_add = "|forced";
}
// 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 = isset($jobList[$i][JL_TR_MEDIATIONAREA_ID]) ? $jobList[$i][JL_TR_MEDIATIONAREA_ID] : 0;
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, "tr_mediationarea_name", (isset($di_ids[$i]) ? $di_ids[$i] : ""));
"tr_commission_no", $tr_commission_no, "tr_mediationarea_id", $tr_mediationarea_id);
insertStmt("tour", $tmpArr);
$tr_id = getLastInsertId();
// if ($tr_id == $jb_id || $tr_id == 0)
writeLog_("../log/tours_missing_", "INSERT INTO tour (jb_id, ad_id, tr_sort, csc_id, tr_comp, tr_person, tr_phone, tr_remark, tr_hsno, tr_status, tr_ware_from_to, tr_commission_no, tr_mediationarea_id)" .
"VALUES ('" . $jb_id . "', '" . $ad_id . "', '" . ($i + 1) . "', '" . $csc_id . "', '" . my_str_check($tr_comp) . "', '" . my_str_check($tr_person) . "', '" . $tr_phone . "', '" . my_str_check($tr_remark) . "', '" . my_str_check($tr_hsno) . "', '0', '" . $tr_ware_from_to . "', '" . $tr_commission_no . "', '" . my_str_check($tr_mediationarea_id) . "');");
$insertedOrUpdatedTr_ids .= "," . $tr_id;
writeLog_("../log/job_options_", "\$jb_id = " . $jb_id . ", \$tr_sort = " . ($i + 1) . ", \$insertedOrUpdatedTr_ids = " . $insertedOrUpdatedTr_ids);
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 . $gdc_context_add));
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
// TOBEDONE: Vertauschen ist nicht berücksichtigt!!! 28.04.2016: Ab jetzt schon
// $ad_id_test = $db->getOne(
// "SELECT ad_id FROM tour WHERE jb_id = '$jb_id' AND tr_sort = '" . ($i + 1) . "'");
// if ($ad_id_test != ""):
$tr_id = trim($jobList[$i][JL_TR_ID]);
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_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, "tr_sort", ($i + 1), "tr_mediationarea_name", (isset($di_ids[$i]) ? $di_ids[$i] : ""));
"tr_commission_no", $tr_commission_no, "tr_mediationarea_id", $tr_mediationarea_id, "tr_sort", ($i + 1));
// Bei b2b-Importen darf importierte Rufnummer nicht überschreiben
if ($db->getOne("SELECT jb_id FROM phoenix_log.log WHERE jb_id = '$jb_id' AND logo_id = 102") != $jb_id)
array_push ($tmpArr, "tr_phone", my_str_check($tr_phone));
// updateStmt("tour", "", "", $tmpArr, "jb_id = '$jb_id' AND tr_sort = '" . ($i + 1) . "'");
updateStmt("tour", "", "", $tmpArr, "jb_id = '$jb_id' AND tr_id = " . $tr_id);
$insertedOrUpdatedTr_ids .= "," . $tr_id;
writeLog_("../log/job_options_", "\$jb_id = " . $jb_id . ", \$tr_sort = " . ($i + 1) . ", \$insertedOrUpdatedTr_ids = " . $insertedOrUpdatedTr_ids);
deleteStmt("genericdatacontainer", "gdc_obj_type = 'tr' AND gdc_obj_id = " . $tr_id . " AND gdc_gen_fieldname = 'tr_photo'");
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 . $gdc_context_add));
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);
// "tr_commission_no", $tr_commission_no, "tr_mediationarea_id", $tr_mediationarea_id, "tr_mediationarea_name", (isset($di_ids[$i]) ? $di_ids[$i] : ""));
insertStmt("tour", $tmpArr);
$tr_id = getLastInsertId();
// if ($tr_id == $jb_id || $tr_id == 0)
writeLog_("../log/tours_missing_", "INSERT INTO tour (jb_id, ad_id, tr_sort, csc_id, tr_comp, tr_person, tr_phone, tr_remark, tr_hsno, tr_status, tr_ware_from_to, tr_commission_no, tr_mediationarea_id)" .
"VALUES ('" . $jb_id . "', '" . $ad_id . "', '" . ($i + 1) . "', '" . $csc_id . "', '" . my_str_check($tr_comp) . "', '" . my_str_check($tr_person) . "', '" . $tr_phone . "', '" . my_str_check($tr_remark) . "', '" . my_str_check($tr_hsno) . "', '0', '" . $tr_ware_from_to . "', '" . $tr_commission_no . "', '" . my_str_check($tr_mediationarea_id) . "') ;");
$insertedOrUpdatedTr_ids .= "," . $tr_id;
writeLog_("../log/job_options_", "\$jb_id = " . $jb_id . ", \$tr_sort = " . ($i + 1) . ", \$insertedOrUpdatedTr_ids = " . $insertedOrUpdatedTr_ids);
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 . $gdc_context_add));
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_tourname_old == "" ? $jb_ordertime : date("Y-m-d H:i:s")), 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_tourname_old == "" ? $jb_ordertime : date("Y-m-d H:i:s")), 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, $jb_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_tourname_old == "" ? $jb_ordertime : date("Y-m-d H:i:s")), $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, $jb_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;
else:
// 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_tourname_old == "" ? $jb_ordertime : date("Y-m-d H:i:s")), $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, $jb_cr_markup, $vht_id);
//echo "'$prev_tr_mediationarea_id, $ad_id1; $tr_mediationarea_id, $ad_id2'
\n";
//reportDie ("saveServiceCosts($ad_id1, $ad_id2, $hq_id, $cs_id, $jb_id, ($i + 1), ($jb_tourname_old == "" ? $jb_ordertime : date("Y-m-d H:i:s")), $distance, $costsplit_count, $getPriceOnly, $jb_cash, " . (($jb_costsplit == "false" || MASK_CASH_PAYER_SELECT == "1") ? $tmpCsc_id_payer : "") . ", $jb_storno, $zipcode1, $zipcode2, ". false .");");
$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 == "*" ? "*" : "")));
if ($fd > 0) $discount_sign = " (-" . $fd . "%)";
$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);
$discount_sign_cr = "";
if ($fd+$self_service_discount > 0) $discount_sign_cr = " (-" . ($fd+$self_service_discount) . "%)";
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;
// Anzahl der Touren bestimmt neben dem Preis, ob die Tour eine Ferntour ist
$tourCount = $i;
// 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;
// Zu löschende tr_ids merken für nachfolgende Löschung in der genericdatacontainer)
$sqlquery = "SELECT tr_id FROM tour WHERE jb_id = " . $jb_id .
($insertedOrUpdatedTr_ids != "" ? " AND tr_id NOT IN (" . substr($insertedOrUpdatedTr_ids, 1) . ")" : "");
writeLog_("../log/job_options_", $sqlquery);
$res = $db->query($sqlquery);
$tr_ids_to_be_deleted = "";
if (DB::isError($res)) reportDie ("$PHP_SELF: '$sqlquery': " . $res->getMessage());
while ($row = $res->fetch_assoc()):
$tr_ids_to_be_deleted .= "," . $row["tr_id"];
endwhile;
$res->free();
// Wenn Etappenstellen gelöscht wurden, müssen sie auch in der Datenbank gelöscht werden!
// TOBEDONE: Unterschriften dürfen nicht gelöscht werden!!!
// deleteStmt("tour", "jb_id = $jb_id AND tr_sort >= '" . ($i + 1) . "'");
deleteStmt("tour", "jb_id = $jb_id " .
($insertedOrUpdatedTr_ids != "" ? " AND tr_id NOT IN (" . substr($insertedOrUpdatedTr_ids, 1) . ")" : ""));
// echo $tr_ids_to_be_deleted;die();
if ($tr_ids_to_be_deleted != "")
deleteStmt("genericdatacontainer", "gdc_obj_type = 'tr' AND gdc_obj_id IN (" . substr($tr_ids_to_be_deleted, 1) . ") AND gdc_gen_fieldname = 'tr_photo'");
// 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, "csc_id_payer_cash", 0);
$cs_invmail_old = "";
if (isset($cs_invmail) && trim($cs_invmail) != "") {
$cs_invmail_old = $db->getOne("SELECT usr_inv_email from customer, employee, user WHERE cs_id = " . $cs_id . " AND customer.cs_admin = employee.emp_id AND employee.usr_id = user.usr_id");
// $db->query("UPDATE customer AS cs, employee AS emp, user AS usr SET usr.usr_inv_email = '" . $cs_invmail . "' WHERE cs.cs_id = " . $cs_id . " AND cs.cs_admin = emp.emp_id AND emp.usr_id = usr.usr_id");
$retArr = userSetFieldAndExportFlag($db->getOne("SELECT usr.usr_id FROM customer AS cs, employee AS emp, user AS usr WHERE cs.cs_id = " . $cs_id . " AND cs.cs_admin = emp.emp_id AND emp.usr_id = usr.usr_id"), "usr", "usr_inv_email", $cs_invmail);
writeLog_("../log/job_options_", "\$cs_id = " . $cs_id . ", \$cs_invmail = " . $cs_invmail . ", \$retArr = " . json_encode($retArr));
$db->query("UPDATE customer AS cs, company AS cmp SET cmp_postage = 0 WHERE cmp.cmp_id = cs.cmp_id AND cs_id = " . $cs_id);
$cmp_postage = 0;
}
// Bei einem Dispo24-Mitarbeiter entscheidet die hq_id des zahlenden Kunden über die Niederlassung
// $empHqList = getParameterValue("0", "HEADQUARTERS_MULTIPLE_ACCESS_EMPLOYEES", "0") . "|300001";
// if (isset($emp_id) && isInParameterString($emp_id, $empHqList)) {
// array_push ($tmpArr, "hq_id", getFieldValueFromId("customer", "cs_id", $cs_id, "hq_id"));
// }
if ($jb_payment == 2 && MASK_CASH_PAYER_SELECT == "1"):
if ($CSC_ID_PAYER_CASH_VAR != ""):
$tmpArr = array("csc_id_payer", $CSC_ID_PAYER_CASH_VAR, "csc_id_payer_cash", $csc_id_payer);
else:
$tmpArr = array("csc_id_payer", "-1", "csc_id_payer_cash", $csc_id_payer);
endif;
endif;
// 25.03.2022: Wenn aufgrund eines Problems in der DB die tour-Tabelle nicht geschrieben wurde, dann Alarm-Mail senden
$tr_sorts = "";
for($j = 1; $j <= $tourCount; $j++):
if (!existsEntry("tour", array("jb_id", $jb_id, "tr_sort", $j))):
if ($tr_sorts != "")
$tr_sorts .= ", ";
$tr_sorts .= $j;
endif;
endfor;
if ($tr_sorts != ""):
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 komplett geschrieben!");
$mailObj->setText("In Auftrag " . $jb_id . " (hq_id = " . $hq_id . ") wurde(n) folgende Station(en) nicht in die tour-Tabelle geschrieben: " . $tr_sorts . ".\nDetails zu den betreffenden Stationen siehe tours_missing_" . date("Ym") . ".log.");
$mailResult = $mailObj->send(array("ca@assecutor.de"), 'smtp');
// $mailResult = $mailObj->send(array("support@assecutor.de"), 'smtp');
endif;
// 14.02.2020: 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;
// 07.08.2018: Aufrund eines fälschlichen nicht reproduzierbaren externen Zahlers in Auftrag 17719291 soll hier eine Warnmail erfolgen, wenn das nochmal passiert
if ($jb_payment != 2 && $csc_id_payer == CSC_ID_PAYER_EXTERN):
include_once("../include/email/htmlMimeMail.php");
$mailObj = new htmlMimeMail();
// $mailObj->setFrom("auto-mailer@assecutor.de");
$mailObj->setFrom("support@assecutor.de");
$mailObj->setSubject("Externer Zahler in Auftrag $jb_id");
$mailObj->setText("Externer Zahler $csc_id_payer in Auftrag $jb_id\n");
$mailResult = $mailObj->send(array("ca@assecutor.de"), 'smtp');
endif;
// 22.01.2010:
$ad_country_payer = $db->getOne("SELECT ad_country FROM costcenteraddress, address WHERE costcenteraddress.ad_id = address.ad_id AND costcenteraddress.csc_id = $csc_id_payer AND costcenteraddress.adt_id = 2");
if ($ad_country_payer != "DE" && $ad_country_payer != "" && $ad_country_payer != "LI" && $ad_country_payer != "NO" && $ad_country_payer != "IS" &&
$ad_country_payer != "HR" && $ad_country_payer != "MC" && $ad_country_payer != "AL" && $ad_country_payer != "MK" && $ad_country_payer != "CH"):
$is_EU = true;
array_push ($tmpArr, "jb_sales_tax_rate", 0.00, "jb_sales_tax_rate_sign", "0");
// Nur für's Logging
$jb_sales_tax_rate = 0.00;
$jb_sales_tax_rate_sign_new = "0";
endif;
updateStmt("job", "jb_id", $jb_id, $tmpArr);
endif;
// if ($is_EU)
// 20.05.2025: Lt. Task #1042 soll Filter "EU" immer gesetzt sein, wenn eine Station _nicht_ in Deutschland ist
if ($is_foreign)
if ($getPriceOnly != 1):
$jb_cr_filter_new = $jb_cr_filter;
if (!in_array ("EU", explode(",", $jb_cr_filter)))
$jb_cr_filter_new .= (trim($jb_cr_filter) == "" ? "" : ",") . "EU";
if (!in_array ("AL", explode(",", $jb_cr_filter)) && strtotime(getParameterValue("0", "MASK_FILTER_AL_DATE", "0")) <= strtotime($jb_ordertime))
$jb_cr_filter_new .= (trim($jb_cr_filter) == "" ? "" : ",") . "AL";
if ($jb_cr_filter != $jb_cr_filter_new)
updateStmt("job", "jb_id", $jb_id, array("jb_cr_filter", $jb_cr_filter_new));
endif;
if ((isset($jb_costsplit) && $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 (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:
if ($jb_fixprice == 0):
// wenn Fixpreis, dann jb_subtotal bereits vorhanden
// sonst ermittelten Standardpreis nehmen
// $jb_subtotal bereits ermittelt
$jb_totalprice = $fullPrice;
if ($jb_cr_price == 0 && MASK_CR_PRICE_MODE == "1"):
// $jb_cr_price = $jb_cr_subtotal; // resultierender Endpreis wäre falsch, wenn Grundpreis TSZ-frei sit (wie derzeit noch in Hamburg)
$jb_cr_price_total = $fullCrPrice;
$jb_cr_price_rate = get_cr_price_rate($hq_id, $cs_id, $jb_ordertime, $vhtSrvt_name, $vht_id);
endif;
else:
$jb_subtotal = round($jb_fixprice * (1 - ($tmp_discount_rate / 100)), 2);
if (MASK_CR_PRICE_MODE == "1") {
if ($jb_cr_price == 0) {
list($jb_cr_price, $jb_cr_price_rate) =
getCr_price_global($jb_subtotal, $hq_id, $cs_id, ($jb_tourname_old == "" ? $jb_ordertime : date("Y-m-d H:i:s")), $vhtSrvt_name, $vht_id);
} else {
$jb_cr_price = round($jb_cr_price * (1 - ($tmp_discount_rate / 100)), 2);
}
}
$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;
if (getParameterValue("0", "INV_SERVICEPRICE_DISCOUNT", $hq_id) == "1"):
$jb_subtotal += round($jb_serviceprice * (1 - ($tmp_discount_rate / 100)), 2);
$jb_totalprice += round($jb_serviceprice * (1 - ($tmp_discount_rate / 100)), 2);
$jb_cr_serviceprice = round($jb_cr_serviceprice * (1 - ($tmp_discount_rate / 100)), 2);
else:
$jb_subtotal += $jb_serviceprice;
$jb_totalprice += $jb_serviceprice;
endif;
// wenn Listenkunde, auch hier natürlich $jb_totalprice auf 0!!!
if ($jobbatch_mode == true):
$jb_subtotal = 0;
$jb_totalprice = 0;
$jb_cr_price = 0;
endif;
if (MASK_CR_PRICE_MODE == "1") {
if ($jb_cr_serviceprice == 0 && !($jb_serviceprice == "" || $jb_serviceprice == 0))
list($jb_cr_serviceprice, $jb_cr_serviceprice_rate) =
getCr_price_global($jb_serviceprice, $hq_id, $cs_id, ($jb_tourname_old == "" ? $jb_ordertime : date("Y-m-d H:i:s")), $vhtSrvt_name, $vht_id);
}
if (MASK_CR_PRICE_MODE == "1" && strtotime(MASK_CR_PRICE_MODE_DATE) <= strtotime($jb_ordertime)) {
// wenn $jb_cr_price_total schon definiert, dann steht der Endpreis für den Fuhrlohn bereits fest (z. B. PLZ-Preis)
if ($jb_cr_price_total == 0) {
$jb_cr_subtotal = round($jb_cr_price * (1 - ($self_service_discount / 100)), 2);
$jb_cr_price_total = round($jb_cr_subtotal * (1 + ($jb_cr_markup / 100)), 2);
}
$jb_cr_subtotal += $jb_cr_serviceprice;
$jb_cr_price_total += $jb_cr_serviceprice;
}
endif;
// $jb_hq_id_exec_price_rate = (float) getParameterValue("0", "MASK_HQ_ID_EXEC_PRICE_RATE", $hq_id);
// Sollte eigentlich nicht sein, aber der Fehler ist nicht zu finden
if ($jb_origin == "") {
writeLog_("../log/job_options_", "\$jb_origin_old = " . $jb_origin_old . ", \$jb_origin = " . $jb_origin);
$jb_origin = $jb_origin_old;
}
$jb_orderer = my_str_check($jb_orderer);
$jb_orderer_old = my_str_check($jb_orderer_old);
$jb_commission_no = my_str_check($jb_commission_no);
$jb_commission_no_old = my_str_check($jb_commission_no_old);
// Treibstoffzuschlag auch auf Fuhrlohn
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_hq_id_exec_price", (round(($jb_totalprice - $jb_cr_price_total) * $jb_hq_id_exec_price_rate, 2) + $jb_cr_price_total), */ "jb_markup", $jb_markup, "jb_tourdata", $jb_tourdata1 . "|" . $jb_tourdata2 . "|" . $jb_tourdata3, "jb_origin", $jb_origin, "jb_orderer", $jb_orderer, "jb_commission_no", $jb_commission_no));
if ($self_service_discount > 0)
$db->query("UPDATE jobprice SET jbprc_remark = '" . $gross_price . "' WHERE jb_id = " . $jb_id . " AND mt_sort = 13");
// Rechnungstext erzeugen
if (!(isset($jb_storno) && $jb_storno > 0)):
mk_jb_invtext($jb_id, false, $tmp_add_srvs, $tmp_add_srvts, $tmp_add_mult, $tmp_add_mult_price, $tmp_add_sids, $tmp_add_prices);
endif;
// Job entsperren, falls gesperrt gewesen (Nachbearbeitung)
updateStmt("job", "jb_id", $jb_id, array("jb_locktime", NULL, "jb_lockuser", NULL));
// manuelle Disposition gewünscht => overrult alles
// oder die Tour ist eine Ferntour (aber nicht bei Nacherfassungen!!!)
// oder Auftrag ist nur Angebot
if (!(isset($jb_storno) && $jb_storno > 0)):
if ($jb_offer == 1 || $jb_status_manual == 1 || ($jb_totalprice >= 150.0 && $tourCount == 2 && $job_is_new && getParameterValue("0", "LONGHAUL_ACTIVE", 0) == "1" && $afterwards != "1")):
$tmpArr = array("jb_status", 9);
// wenn Ferntour, dann muss zusätzlich Flag "jb_longhaul" gesetzt werden
if (($jb_totalprice >= 150.0 && $tourCount = 2) && (getParameterValue("0", "LONGHAUL_ACTIVE", 0) == "1")):
array_push ($tmpArr, "jb_longhaul", 1);
endif;
updateStmt("job", "jb_id", $jb_id, $tmpArr);
endif;
endif;
// BWV_Auftrag?
$jb_longhaul = 0;
$tmpArr = array();
$check_bwv = true;
list($total_km, $total_km_osm) = get_job_distance($jb_id);
$check_bwv = false;
if ($total_km == -1)
$total_km = $db->getOne("SELECT jbprc_price FROM jobprice WHERE jb_id = " . $jb_id . " AND mt_sort = 11");
if ($total_km > 0 && $tourCount > 1 && $total_km / ($tourCount - 1) >= getParameterValue("0", "LONGHAUL_KM", "0")) {
$jb_longhaul = 1;
if ($job_is_new && $afterwards != "1")
$tmpArr = array("jb_status", 9);
if (!in_array ("BWV", explode(",", $jb_cr_filter_opt)))
array_push($tmpArr, "jb_cr_filter_opt", $jb_cr_filter_opt . (trim($jb_cr_filter_opt) == "" ? "" : ",") . "BWV");
}
writeLog_("../log/job_options_", "\$jb_longhaul = " . $jb_longhaul . " (\$total_km = " . $total_km . ", \$tourCount = " . $tourCount . ", LONGHAUL_KM = " . getParameterValue("0", "LONGHAUL_KM", "0") . ", \$total_km / (\$tourCount - 1) = " . $total_km / ($tourCount - 1) . ")");
array_push ($tmpArr, "jb_longhaul", $jb_longhaul);
$logstr_foreign = "";
// Auslands-Auftrag?
if ($jobList[0][JL_AD_COUNTRY] != "DE" && $jobList[0][JL_AD_COUNTRY] != "D" && $jobList[0][JL_AD_COUNTRY] != "") {
$coords_start = get_coords($jobList[0][JL_AD_COUNTRY], $jobList[0][JL_AD_ZIPCODE], $jobList[0][JL_AD_CITY], $jobList[0][JL_AD_STREET], $jobList[$i][JL_TR_HSNO]);
$coords_end = get_coords($jobList[$tourCount-1][JL_AD_COUNTRY], $jobList[$tourCount-1][JL_AD_ZIPCODE], $jobList[$tourCount-1][JL_AD_CITY], $jobList[$tourCount-1][JL_AD_STREET], $jobList[$tourCount-1][JL_TR_HSNO]);
$sqlquery = // "SELECT hq_id, hq_mnemonic, hq_gps_long, hq_gps_lat FROM headquarters WHERE hq_gps_long > 0 AND hq_gps_lat > 0";
"(SELECT hq_id, hq_mnemonic, hq_gps_long, hq_gps_lat" .
" FROM headquarters WHERE hq_gps_long > 0 AND hq_gps_lat > 0 ORDER BY (SQRT(POW(ABS(hq_gps_lat - " . $coords_start[0] . "),2) + POW(ABS(hq_gps_long - " . $coords_start[1] . "),2)) * 111) LIMIT 3)" .
" UNION " .
"(SELECT hq_id, hq_mnemonic, hq_gps_long, hq_gps_lat" .
" FROM headquarters WHERE hq_gps_long > 0 AND hq_gps_lat > 0 ORDER BY (SQRT(POW(ABS(hq_gps_lat - " . $coords_end[0] . "),2) + POW(ABS(hq_gps_long - " . $coords_end[1] . "),2)) * 111) LIMIT 3)";
$res = $db->query($sqlquery);
if (DB::isError($res)) reportDie ("$PHP_SELF: '$sqlquery': " . $res->getMessage());
$round_kms_min = 0;
$hq_id_min = 0;
while ($row = $res->fetch_assoc()):
$round_kms = get_job_distance($jb_id, "km", $tr_sort = 0, $row["hq_gps_lat"], $row["hq_gps_long"], $row["hq_gps_lat"], $row["hq_gps_long"]);
if ($round_kms_min == 0 || $round_kms[0] < $round_kms_min) {
$round_kms_min = $round_kms[0];
$hq_id_min = $row["hq_id"];
}
$logstr_foreign .= ($logstr_foreign != "" ? ";" : "") . $row["hq_mnemonic"] . ":" . $round_kms[0];
endwhile;
$res->free();
array_push ($tmpArr, "hq_id_dispo", $hq_id_min);
}
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
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_toll'");
// Maut wird extra gespeichert
if (trim($jb_toll) != "")
insertStmt("genericdatacontainer", array("gdc_obj_type", "jb", "gdc_obj_id", $jb_id, "gdc_gen_fieldname", "jb_toll", "gdc_content", $jb_toll, "gdc_context", (isset($jb_toll_context) ? $jb_toll_context : "")));
deleteStmt("genericdatacontainer", "gdc_obj_type = 'jb' AND gdc_obj_id = " . $jb_id . " AND gdc_gen_fieldname = 'jb_hiddenFreetext_1'");
// Für die Fahrer nicht sichtbarer Rechnungtext wird extra gespeichert
if (trim($jb_hiddenFreetext_1) != "")
insertStmt("genericdatacontainer", array("gdc_obj_type", "jb", "gdc_obj_id", $jb_id, "gdc_gen_fieldname", "jb_hiddenFreetext_1", "gdc_content", $jb_hiddenFreetext_1, "gdc_context", ""));
deleteStmt("genericdatacontainer", "gdc_obj_type = 'jb' AND gdc_obj_id = $jb_id AND gdc_gen_fieldname = 'jb_id_permanent_pre'");
if (isset($jb_id_permanent_pre) && $jb_id_permanent_pre != "")
insertStmt("genericdatacontainer", array("gdc_obj_type", "jb", "gdc_obj_id", $jb_id, "gdc_gen_fieldname", "jb_id_permanent_pre", "gdc_content", $jb_id_permanent_pre, "gdc_context", date("Y-m-d H:i:s")));
// deleteStmt("genericdatacontainer", "gdc_obj_type = 'jb' AND gdc_obj_id = $jb_id AND gdc_gen_fieldname = 'jb_multi'");
// if ($jb_multi != "")
// insertStmt("genericdatacontainer", array("gdc_obj_type", "jb", "gdc_obj_id", $jb_id, "gdc_gen_fieldname", "jb_multi", "gdc_content", $jb_multi_factor, "gdc_context", date("Y-m-d H:i:s")));
// deleteStmt("genericdatacontainer", "gdc_obj_type = 'jb' AND gdc_obj_id = $jb_id AND gdc_gen_fieldname = 'jb_cashpayer_mail' AND gdc_context = ''");
// if (trim($jb_cashpayer_mail) != "")
// insertStmt("genericdatacontainer", array("gdc_obj_type", "jb", "gdc_obj_id", $jb_id, "gdc_gen_fieldname", "jb_cashpayer_mail", "gdc_content", $jb_cashpayer_mail, "gdc_context", ""));
if (existsEntry("genericdatacontainer", array("gdc_obj_type", "jb", "gdc_obj_id", $jb_id, "gdc_gen_fieldname", "jb_cashpayer_mail"))) {
updateStmt("genericdatacontainer", "gdc_obj_id", $jb_id, array("gdc_content", $jb_cashpayer_mail), "gdc_obj_type = 'jb' AND gdc_gen_fieldname = 'jb_cashpayer_mail'");
} else {
if (trim($jb_cashpayer_mail) != "")
insertStmt("genericdatacontainer", array("gdc_obj_type", "jb", "gdc_obj_id", $jb_id, "gdc_gen_fieldname", "jb_cashpayer_mail", "gdc_content", $jb_cashpayer_mail, "gdc_context", ""));
}
if (existsEntry("genericdatacontainer", array("gdc_obj_type", "jb", "gdc_obj_id", $jb_id, "gdc_gen_fieldname", "jb_offer_mail"))) {
updateStmt("genericdatacontainer", "gdc_obj_id", $jb_id, array("gdc_content", $jb_offer_mail), "gdc_obj_type = 'jb' AND gdc_gen_fieldname = 'jb_offer_mail'");
} else {
if (trim($jb_offer_mail) != "")
insertStmt("genericdatacontainer", array("gdc_obj_type", "jb", "gdc_obj_id", $jb_id, "gdc_gen_fieldname", "jb_offer_mail", "gdc_content", $jb_offer_mail, "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) != "" && $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;
deleteStmt("genericdatacontainer", "gdc_obj_type = 'jb' AND gdc_obj_id = $jb_id AND gdc_gen_fieldname = 'jb_origin_other' AND gdc_context = ''");
if (trim($jb_origin_other) != "")
insertStmt("genericdatacontainer", array("gdc_obj_type", "jb", "gdc_obj_id", $jb_id, "gdc_gen_fieldname", "jb_origin_other", "gdc_content", $jb_origin_other, "gdc_context", ""));
deleteStmt("genericdatacontainer", "gdc_obj_type = 'jb' AND gdc_obj_id = $jb_id AND gdc_gen_fieldname = 'jb_bwv' AND gdc_context = ''");
if ($jb_bwv == "1")
insertStmt("genericdatacontainer", array("gdc_obj_type", "jb", "gdc_obj_id", $jb_id, "gdc_gen_fieldname", "jb_bwv", "gdc_content", $jb_bwv, "gdc_context", ""));
// Kinderaufträge bearbeiten
// ... falls im Calculator
if (getParameterValue("0", "MASK_CHILDREN_TAX_HARDCODED", 0) == "1"):
saveJobChildren($jb_id,
array("hq_id", $hq_id, "vht_id", $vht_id, "jb_payment", $jb_payment,
"jb_status", "2", "jb_autoranking", "0", "jb_type", $jb_type, "emp_id", $usr_id,
"jb_postage", 0, "jb_invmode", $jb_invmode, "jb_freetext_1", "",
"jb_sales_tax_rate", 0, "jb_sales_tax_rate_sign", '4'),
$tmp_add_jb_ids, $tmp_add_sids, $tmp_add_prices, $jb_markup, $tmp_discount_rate, $jb_serviceprice);
else:
saveJobChildren($jb_id,
array("hq_id", $hq_id, "vht_id", $vht_id, "jb_payment", $jb_payment,
"jb_status", "2", "jb_autoranking", "0", "jb_type", $jb_type, "emp_id", (isset($usr_id) ? $usr_id : 0),
"jb_postage", 0, "jb_invmode", (isset($jb_invmode) ? $jb_invmode : 0), "jb_freetext_1", "",
"jb_sales_tax_rate", $jb_sales_tax_rate, "jb_sales_tax_rate_sign", $jb_sales_tax_rate_sign_new),
$tmp_add_jb_ids, $tmp_add_sids, $tmp_add_prices, $jb_markup, $tmp_discount_rate, $jb_serviceprice);
endif;
$jb_third_country_old = $db->getOne("SELECT gdc_content FROM genericdatacontainer WHERE gdc_obj_type = 'jb' AND gdc_obj_id = " . $jb_id . " AND gdc_gen_fieldname = 'jb_third_country'");
//echo "is_EU_only = " . $is_EU_only . "
\n";
//echo "jb_third_country_old = " . $jb_third_country_old . "
\n";
if (!$is_EU_only) {
if ($jb_third_country_old != "1") {
insertStmt("genericdatacontainer", array("gdc_obj_type", "jb", "gdc_obj_id", $jb_id, "gdc_gen_fieldname", "jb_third_country", "gdc_content", "1", "gdc_context", ""));
// Log-Eintrag "Anforderung des Versenderstatus bestätigt durch #Name" wird am Ende eingetragen, damit das nicht der erste Log-Eintrag ist
// writeToLogDB(151, $hq_id, $jb_id, $usr_id, "", "", "", "");
if ($job_is_new) {
$jb_incomplete = "1";
}
// } else {
////echo "jb_incomplete_old = " . $jb_incomplete_old . "
\n";
////echo "jb_incomplete = " . $jb_incomplete . "
\n";
// if ($jb_incomplete == "" && $jb_incomplete_old == "1")
// // Log-Eintrag "Umsatzsteuerrechtlich korrekte Abrechnung bestätigt durch #Name"
// writeToLogDB(152, $hq_id, $jb_id, $usr_id, "", "", "", "");
}
} else {
deleteStmt("genericdatacontainer", "gdc_obj_type = 'jb' AND gdc_obj_id = " . $jb_id . " AND gdc_gen_fieldname = 'jb_third_country'");
}
// TOBEDONE: - Eintrag in genericdatacontainer für Export wenn !is_eu_only
// - Neue log_operation für Bestätigungen (Abfrage bei Erfassung und dann Hinweis bei späterem Entfernen von jb_incomplete)
// Prüfen, ob jb_incomplete-Flag gesetzt werden muss
check_jb_incomplete($jb_id, $jb_incomplete); //nach saveJobChildren, damit evtl. Unteraufträge auch mit verarztet werden
// Prüfen, ob jb_serviceprice gesetzt werden muss
if ($job_is_new)
check_jb_serviceprice($jb_id, $hq_id, $jb_ordertime);
// Fuhrlohn berechnen (auch bei einem geänderten Auftrag evtl. nötig, daher immer aufrufen)
// setCr_price($jb_id);
$db->query("DELETE FROM jobprice WHERE jb_id = " . $jb_id . " AND (mt_sort < 11 OR mt_sort = 15)");
$insert_clause =
/*($jb_cr_markup > 0 ?*/ "(" . $jb_id . ", " . (trim($jb_cr_markup_ori) == "" ? 1 : 9) . ", " . $jb_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 . "), " : "") .
(isset($jb_cr_price_rate) && $jb_cr_price_rate > 0 ? "(" . $jb_id . ", 5, " . $jb_cr_price_rate . "), " : "") .
(isset($jb_cr_serviceprice_rate) && $jb_cr_serviceprice_rate > 0 ? "(" . $jb_id . ", 6, " . $jb_cr_serviceprice_rate . "), " : "") .
// ($jb_cr_agio > 0 ? "(" . $jb_id . ", 7, " . $jb_cr_agio . "), " : "") .
(trim($jb_markup_ori != "") ? "(" . $jb_id . ", 8, " . $jb_markup . "), " : "") .
($jb_cr_subtotal > 0 || $jb_cr_subtotal < 0 ? "(" . $jb_id . ", 10, " . $jb_cr_subtotal . "), " : "");
$db->query("INSERT INTO jobprice (jb_id, mt_sort, jbprc_price) VALUES " . substr($insert_clause, 0, strlen($insert_clause) - 2));
if ((!isset($jb_km_old) || $jb_km_old != $jb_km) && trim($jb_km_ori != "")) {
$db->query("DELETE FROM jobprice WHERE jb_id = " . $jb_id . " AND mt_sort IN (11, 12)");
$db->query("INSERT INTO jobprice (jb_id, mt_sort, jbprc_price, jbprc_remark) VALUES (" . $jb_id . ", 11, " . $jb_km . ", 'm')");
}
if ($jb_price_km > 0) {
$db->query("INSERT INTO jobprice (jb_id, mt_sort, jbprc_price) VALUES (" . $jb_id . ", 15, " . $jb_price_km . ")");
}
// UPDATE jobprice SET mt_sort = 10 WHERE mt_sort = 8
// 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 = my_str_check_mobile($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;
updateStmt("genericdatacontainer", "gdc_obj_id", $jb_id, array("gdc_content", "0", "gdc_context", date("Y-m-d H:i:s")), "gdc_obj_type = 'jb' AND gdc_gen_fieldname = 'jb_blink' AND gdc_content = '1'");
if (MASK_CR_PRICE_MODE == "1"):
$tr_remark = my_str_check_mobile($db->getOne("SELECT tr_remark FROM tour WHERE jb_id = " . $jb_id . " AND tr_sort = 1"));
//echo str_replace("\n", "<br>
", $tr_remark) . "
";die();
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;
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);
//echo str_replace("\n", "<br>
", $tr_remark) . "
";die();
updateStmt("tour", "jb_id", $jb_id, $tmpArr, "tr_sort = 1");
if ($tr_sort_cashpayer > 0):
if ($tr_sort_cashpayer != 1)
$tr_remark = my_str_check_mobile($db->getOne("SELECT tr_remark FROM tour WHERE jb_id = " . $jb_id . " AND tr_sort = " . $tr_sort_cashpayer));
$jb_totalprice_tax = round(($jb_totalprice + (float) $jb_toll) * ($jb_sales_tax_rate / 100), 2);
//echo str_replace("\n", "<br>
", $tr_remark);
$tr_remark = str_replace("*** ZAHLT BAR ***", "*** Bitte im Auftrag STADTBOTE Bar " . str_replace(".", ",", sprintf("%01.2f", $jb_totalprice + (float) $jb_toll)) . " EUR zzgl. " .
str_replace(".", ",", sprintf("%01.2f", $jb_totalprice_tax)) . " EUR MwSt (Gesamt " . str_replace(".", ",", sprintf("%01.2f", $jb_totalprice + (float) $jb_toll + $jb_totalprice_tax)) .
" EUR) kassieren und quittieren. ***", $tr_remark);
//echo str_replace("\n", "<br>
", $tr_remark);
$tmpArr = array("tr_remark", $tr_remark);
updateStmt("tour", "jb_id", $jb_id, $tmpArr, "tr_sort = " . $tr_sort_cashpayer);
endif;
endif;
if ($jb_id_insurance != "" && ($special_case_ori == 0 || $special_case == 0)) {
deleteStmt("genericdatacontainer", "gdc_obj_type = 'jb' AND gdc_obj_id = " . $jb_id . " AND gdc_gen_fieldname = 'jb_id_insurance'");
deleteStmt("job", "jb_id = " . $jb_id_insurance);
deleteStmt("tour", "jb_id = " . $jb_id_insurance);
deleteStmt("tourservice", "jb_id = " . $jb_id_insurance);
}
if ($jb_value_of_goods != "" && ($special_case_ori == 0 || $special_case == 0)) {
$jb_id_insurance = saveJobInsurance($jb_id, $csc_id_payer, $vht_id, $jb_ordertime, $jb_value_of_goods, $jb_insurance_rate, $special_case);
insertStmt("genericdatacontainer", array("gdc_obj_type", "jb", "gdc_obj_id", $jb_id, "gdc_gen_fieldname", "jb_id_insurance", "gdc_content", $jb_id_insurance, "gdc_context", $jb_value_of_goods . "|" . $jb_insurance_rate . "|" . $special_case));
updateStmt("job", "jb_id", $jb_id_insurance, array("jb_origin", 8, "jb_orderer", $jb_orderer));
// insertStmt("genericdatacontainer", array("gdc_obj_type", "jb", "gdc_obj_id", $jb_id, "gdc_gen_fieldname", "jb_origin_other", "gdc_content", "Höherversicherung", "gdc_context", ""));
} else {
$jb_id_insurance = 0;
}
$job_checkboxes = "";
if ($job_is_new) {
$jb_origin_text = "Auftragsherkunft ";
switch ($jb_origin) {
case 0:
$jb_origin_text .= "ohne Angabe";
break;
case 1:
$jb_origin_text .= "Telefon";
break;
case 2:
$jb_origin_text .= "Mail";
break;
case 3:
$jb_origin_text .= "Schnittstelle";
break;
case 4:
$jb_origin_text .= "KAE";
break;
case 5:
$jb_origin_text .= "Dauerauftrag";
break;
case 6:
$jb_origin_text .= "Sonstiges (". $jb_origin_other . ")";
break;
default:
$jb_origin_text .= "unbekannt";
}
$job_checkboxes = ", `" . $jb_origin_text . "´";
}
if (isset($afterwards) && $afterwards == 1) { $job_checkboxes .= ", `Nacherfassung´"; }
if ($jb_globaljob == 1) { $job_checkboxes .= ", `An alle Kuriere´"; }
if (isset($jb_status_manual) && $jb_status_manual == 1) { $job_checkboxes .= ", `Manuelle Disposition´"; }
if ($jb_incomplete == 1) { $job_checkboxes .= ", `Noch unvollständig´"; }
if ($jb_offer == 1) { $job_checkboxes .= ", `Angebot´"; }
if (isset($jb_tourname_overwrite) && $jb_tourname_overwrite == 1) { $job_checkboxes .= ", `Gespeicherte Tour überschreiben´"; }
if ($jb_id_insurance != 0) { $job_checkboxes .= ", `Höherversicherung (" . $jb_id_insurance . ")´"; }
if ($special_case == 1) { $job_checkboxes .= ", `Sonderfall´"; }
if (isset($jb_tourname_hidden) && $jb_tourname_hidden != "") { $job_checkboxes .= ", `Konserve \"" . $jb_tourname_hidden . "\"´"; }
$jb_multi_str = "";
if ((isset($jb_multi_factor) && $jb_multi_factor > 1)) { $jb_multi_str .= "|\$jb_multi_factor=$jb_multi_factor"; }
if ((isset($jb_multi_factor_ori) && $jb_multi_factor_ori > 1 && !isset($i_multi))) { $jb_multi_str .= "|\$jb_multi_factor=$jb_multi_factor_ori"; }
if (isset($i_multi)) {
$jb_multi_str .= "|\$i_multi=$i_multi";
$usr_id = $db->getOne("SELECT usr_id FROM phoenix_log.log WHERE jb_id = " . $jb_id_ori_copy . " AND logo_id IN (1,25)");
}
$changes_text_add = "";
$changes_str_add = "";
if ($job_is_new) {
if ($hq_id_dispo != $hq_id) { $changes_str_add .= "|hq_id_dispo=$hq_id_dispo"; }
if ($logstr_foreign != "") { $changes_str_add .= "|ROUND_KMS=" . $logstr_foreign; }
if ($jb_longhaul == 1) { $changes_str_add .= "|JB_LONGHAUL=$jb_longhaul"; }
}
if (isset($cs_invmail) && $cs_invmail_old != $cs_invmail) { $changes_text_add .= ", Rechnungs-Email"; $changes_str_add .= "|\$cs_invmail_old=$cs_invmail_old|\$cs_invmail=$cs_invmail"; }
if ($cmp_postage_old != $cmp_postage) { $changes_text_add .= ", Porto"; $changes_str_add .= "|\$cmp_postage_old=$cmp_postage_old|\$cmp_postage=$cmp_postage"; }
if ($request_token != "") { // e.g. no request_token when storno
writeLog_("../log/job_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 = "";
$pda_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"; $pda_changes_text .= "#$jb_id, Maximalgewicht"; }
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"; $pda_changes_text .= "#$jb_id, Länge"; }
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"; $pda_changes_text .= "#$jb_id, Breite"; }
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"; $pda_changes_text .= "#$jb_id, Höhe"; }
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"; $pda_changes_text .= "#$jb_id, Stellplätze"; }
if ($jb_ordertime_old != $jb_ordertime) { $changes_text .= ", Datum und/oder Uhrzeit"; $changes_str .= "|\$jb_ordertime_old=$jb_ordertime_old|\$jb_ordertime=$jb_ordertime"; $pda_changes_text .= "#$jb_id, Datum bzw. Uhrzeit"; }
// if ($jb_reserv == 1 && ($jb_ordertime_old != $jb_ordertime)) { $changes_text .= ", Datum und/oder Uhrzeit"; $changes_str .= "|\$jb_ordertime_old=$jb_ordertime_old|\$jb_ordertime=$jb_ordertime"; $pda_changes_text .= "#$jb_id, Datum bzw. Uhrzeit"; }
if ($jb_reserv_old != $jb_reserv && $jb_reserv != "") { $changes_text .= ", Vorbestellung"; $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 (MASK_CR_PRICE_MODE == "1") {
$jb_cr_serviceprice_compare = ($jb_cr_serviceprice == "0" ? "" : $jb_cr_serviceprice);
if ($jb_cr_serviceprice_old != $jb_cr_serviceprice_compare) { $changes_text .= ", Servicevergütung"; $changes_str .= "|\$jb_cr_serviceprice_old=$jb_cr_serviceprice_old|\$jb_cr_serviceprice=$jb_cr_serviceprice"; $pda_changes_text .= "#$jb_id, Servicevergütung\n"; }
if ($jb_cr_price_old != $jb_cr_price_total && $jb_cr_price_total != "") { $changes_text .= ", Frachtvergütung"; $changes_str .= "|\$jb_cr_price_old=$jb_cr_price_old|\$jb_cr_price=$jb_cr_price_total"; $pda_changes_text .= "#$jb_id, Frachtvergütung\n"; }
}
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"; $pda_changes_text .= "#$jb_id, Zahler oder Zahlungsmodus\n"; }
// 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 (my_str_check($jb_hiddenFreetext_1_old) != my_str_check_http($jb_hiddenFreetext_1)) { $changes_text .= ", verborgener Rechnungstext"; $changes_str .= "|\$jb_hiddenFreetext_1_old=" . my_str_check($jb_hiddenFreetext_1_old) . "|\$jb_hiddenFreetext_1=" . my_str_check_http($jb_hiddenFreetext_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_warningtime_old == "0000-00-00 00:00:00")
$jb_warningtime_old = "";
if ($jb_warningtime_old != $jb_warningtime) { $changes_text .= ", Enddatum/-uhrzeit der Dispo-Info"; $changes_str .= "|\$jb_warningtime_old=$jb_warningtime_old|\$jb_warningtime=$jb_warningtime";}
// 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 ($jb_cashpayer_mail_old != $jb_cashpayer_mail) { $changes_text .= ", Barzahler-Erledigungsmail"; $changes_str .= "|\$jb_cashpayer_mail_old=$jb_cashpayer_mail_old|\$jb_cashpayer_mail=$jb_cashpayer_mail"; }
if ($jb_offer_mail_old != $jb_offer_mail) { $changes_text .= ", Angebots-Mail"; $changes_str .= "|\$jb_offer_mail_old=$jb_offer_mail_old|\$jb_offer_mail=$jb_offer_mail"; }
if ($jb_markup_old != $jb_markup) { $changes_text .= ", Treibstoffzuschlag"; $changes_str .= "|\$jb_markup_old=$jb_markup_old|\$jb_markup=$jb_markup"; }
if (MASK_CR_PRICE_MODE == "1") {
if ($jb_cr_markup_old != $jb_cr_markup) { $changes_text .= ", Treibstoffzuschlag"; $changes_str .= "|\$jb_cr_markup_old=$jb_cr_markup_old|\$jb_cr_markup=$jb_cr_markup"; $pda_changes_text .= "#$jb_id, Treibstoffzuschlag\n"; }
}
if ($jb_toll_old != $jb_toll) { $changes_text .= ", Maut"; $changes_str .= "|\$jb_toll_old=$jb_toll_old|\$jb_toll=$jb_toll"; $pda_changes_text .= "#$jb_id, Maut\n"; }
if ($jb_km_old != $jb_km && trim($jb_km != "")) { $changes_text .= ", Kilometer"; $changes_str .= "|\$jb_km_old=$jb_km_old|\$jb_km=$jb_km"; }
if ($hq_id_dispo_old != $hq_id_dispo) { $changes_text .= ", Ausführende NL:"; $changes_str .= "|\$hq_id_dispo_old=$hq_id_dispo_old|\$hq_id_dispo=$hq_id_dispo"; }
if ($jb_longhaul_old != $jb_longhaul) { $changes_text .= ", BWV-Auftrag"; $changes_str .= "|\$jb_longhaul_old=$jb_longhaul_old|\$jb_longhaul=$jb_longhaul"; }
if ($jb_origin_old != $jb_origin) { $changes_text .= ", Auftragseingang"; $changes_str .= "|\$jb_origin_old=$jb_origin_old|\$jb_origin=$jb_origin"; }
if ($jb_origin_other_old != $jb_origin_other) { $changes_text .= ", Auftragseingang-Sonstiges"; $changes_str .= "|\$jb_origin_other_old=$jb_origin_other_old|\$jb_origin_other=$jb_origin_other"; }
if ($jb_orderer_old != $jb_orderer) { $changes_text .= ", Besteller"; $changes_str .= "|\$jb_orderer_old=$jb_orderer_old|\$jb_orderer=$jb_orderer"; }
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;
$tr_status_all = 1;
$jb_finishtime_new = "0000-00-00 00:00:00";
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, $tr_id) =
getTourData($jb_id, $i, "tour");
$tr_photo = $db->getOne("SELECT gdc_content FROM genericdatacontainer WHERE gdc_obj_type = 'tr' AND gdc_obj_id = " . $tr_id . " AND gdc_gen_fieldname = 'tr_photo' AND NOT (gdc_context LIKE '%|forced')");
//echo "
$i" . $tr_photo;
} else {
$tr_add_str .= "$i, ";
$changes_text .= ", Station $i hinzugefügt";
$pda_changes_text .= "#$jb_id/$i, hinzugefügt\n";
}
} 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, ";
$changes_text .= ", Station $i gelöscht";
$pda_changes_text .= "#$jb_id/$i, gelöscht\n";
endif;
}
if ($i < $i_tour_max_old && $tourFound == 1) {
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]; $pda_changes_text .= "#$jb_id/$i, Firma\n"; }
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]; $pda_changes_text .= "#$jb_id/$i, Person\n"; }
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]; $pda_changes_text .= "#$jb_id/$i, Straße\n"; }
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]; $pda_changes_text .= "#$jb_id/$i, Hausnummer\n"; }
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]; $pda_changes_text .= "#$jb_id/$i, PLZ\n"; }
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]; $pda_changes_text .= "#$jb_id/$i, Ort\n"; }
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]; $pda_changes_text .= "#$jb_id/$i, Land\n"; }
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]; $pda_changes_text .= "#$jb_id/$i, Bemerkung\n"; }
// 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]; $pda_changes_text .= "#$jb_id/$i, Status"; }
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]; $pda_changes_text .= "#$jb_id/$i, An/Ab\n"; }
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]; $pda_changes_text .= "#$jb_id/$i, Kommissionsnummer\n"; }
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]; }
if ($tr_photo != $tr_photo_old_[$i]) { $changes_text .= ", $i. Foto"; $changes_str .= "|\$tr_photo_$i=".str_replace("|", "/", $tr_photo)."|\$tr_photo_old_$i=".str_replace("|", "/", $tr_photo_old_[$i]); $pda_changes_text .= "#$jb_id/$i, Foto\n"; }
// 28.05.2021: After deleting a station it has to be checked, whether this causes a job to be finished now
if ($jb_status != 2 && $tr_status_all == 1 && $tourFound == 1) {
if ($tr_status == "1") {
if ($tr_finishtime != "" && $tr_finishtime != "0000-00-00 00:00:00" && strtotime($jb_finishtime_new) < strtotime($tr_finishtime))
$jb_finishtime_new = $tr_finishtime;
} else {
$tr_status_all = 0;
}
}
}
$i++;
} while ($tourFound == 1 || $i < $i_tour_max_old);
if ($tr_add_str != "") {
$changes_str .= "|\$tr_add=" . substr($tr_add_str, 0, -2);
// 29.04.2021: After adding a station the automail has to be sent another time
if ($jb_status_manual == 1) {
updateStmt("job", "jb_id", $jb_id, array("jb_automailsent", "0"));
deleteStmt("phoenix_log.semaphor", "sp_obj_type = 'jb' AND sp_obj_id = " . $jb_id . " AND sp_fieldname = 'automailer' AND sp_context = 'LOCKED'");
}
}
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);
// Bei einem laufenden PDA-Auftrag (jb_status = 1) PDA-Kommando absetzen, damit der Fahrer informiert ist...
if (getFieldValueFromId("job", "jb_id", "$jb_id", "jb_status") == 1 && $pda_changes_text != ""):
$crId = getFieldValueFromId("job", "jb_id", "$jb_id", "cr_id");
if ($crId != ""):
// Execution Time: 20 Sekunden von jetzt an; damit soll sichergestellt werden, dass die geänderten Daten bereits auf dem PDA vorliegen,
// _bevor_ die Änderungsmitteilung den Fahrer aus dem Schlaf weckt...
$pdaCommandExecTime = getdate(mktime(date("H"), date("i"), date("s") + 20, date("m"), date("d"), date("Y")));
$pdaCommandExecTimeMySQL = $pdaCommandExecTime['year'] . "-" . sprintf("%02d", $pdaCommandExecTime['mon']) . "-" . sprintf("%02d", $pdaCommandExecTime['mday']) .
" " . sprintf("%02d", $pdaCommandExecTime['hours']) . ":" . sprintf("%02d", $pdaCommandExecTime['minutes']) . ":" . sprintf("%02d", $pdaCommandExecTime['seconds']);
// Expiration Time: 36 Stunden von Auftragszeit oder von jetzt an (je nachdem was später ist);
// die Nachricht soll nicht noch Tage später den Fahrer erschrecken, wenn der Auftrag schon lange vorbei ist
// und er schon gar nicht mehr weiß, was das überhaupt für ein Auftrag gewesen ist...
$pdaCommandExpireTimeFromNow = getdate(mktime(date("H") + 36, date("i"), date("s"), date("m"), date("d"), date("Y")));
$jb_ordertime_vals = getValsFromDate(getFieldValueFromId("job", "jb_id", $jb_id, "jb_ordertime"));
$pdaCommandExpireTimeFromOrdertime = getdate(mktime($jb_ordertime_vals[3] + 36, $jb_ordertime_vals[4], $jb_ordertime_vals[5],
$jb_ordertime_vals[1], $jb_ordertime_vals[2], $jb_ordertime_vals[0]));
//echo "
\$pdaCommandExpireTimeFromNow:
";
//print_r ($pdaCommandExpireTimeFromNow);
//echo "
\$pdaCommandExpireTimeFromOrdertime:
";
//print_r ($pdaCommandExpireTimeFromOrdertime);
if ($pdaCommandExpireTimeFromNow > $pdaCommandExpireTimeFromOrdertime):
$pdaCommandExpireTime = $pdaCommandExpireTimeFromNow;
else:
$pdaCommandExpireTime = $pdaCommandExpireTimeFromOrdertime;
endif;
//echo "
\$pdaCommandExpireTime:
";
//print_r ($pdaCommandExpireTime);
$pdaCommandExpireTimeMySQL = $pdaCommandExpireTime['year'] . "-" . sprintf("%02d", $pdaCommandExpireTime['mon']) . "-" . sprintf("%02d", $pdaCommandExpireTime['mday']) .
" " . sprintf("%02d", $pdaCommandExpireTime['hours']) . ":" . sprintf("%02d", $pdaCommandExpireTime['minutes']) . ":" . sprintf("%02d", $pdaCommandExpireTime['seconds']);
//echo "
\$pdaCommandExpireTimeMySQL:
";
//echo $pdaCommandExpireTimeMySQL;
insertPDACommand($hq_id, $crId, "7", "1", $pda_changes_text, $pdaCommandExecTimeMySQL, $pdaCommandExpireTimeMySQL);
endif;
endif;
endif;
endif;
$changes_text .= $job_checkboxes;
if ($changes_text != "")
$changes_text = " (" . substr($changes_text, 2) . ")";
writeToLogDB(($job_is_new == true ? (!(isset($check_jb_permanent_flag) && $check_jb_permanent_flag == true) ? 1 : 161) : 2), $hq_id, $jb_id, (isset($usr_id) ? $usr_id : 0), "", "", "", $jobMode . $changes_text . $changes_text_add . $jb_multi_str . $changes_str . $changes_str_add);
}
else
{
if ($job_checkboxes != "")
$job_checkboxes = " (" . substr($job_checkboxes, 2) . ")";
if ($jobMode == "") // 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 . $changes_text_add . $job_checkboxes . "|JB_ID_ORG=$jb_id_org" . $jb_multi_str . $changes_str_add);
}
if (isset($tr_del_str) && $tr_del_str != "" && $jb_status != 2 && $tr_status_all == 1) {
writeToLogDB(4, $hq_id, $jb_id, $usr_id, "", "", "", "finished due to deleting station(s) by " . $jb_finishtime_new);
$crId = getFieldValueFromId("job", "jb_id", "$jb_id", "cr_id");
$today = getdate();
$now = $today['year'] . "-" . sprintf("%02d", $today['mon']) . "-" . sprintf("%02d", $today['mday']) . " " .
sprintf("%02d", $today['hours']) . ":" . sprintf("%02d", $today['minutes']) . ":" . sprintf("%02d", $today['seconds']);
$cmd_exec_limit = date("Y-m-d H:i:s", mktime(date("H"), date("i"), date("s"), date("m"), date("d"), date("Y") + 1));
// 20.08.2025: cmd_command changed from 3 to 5
insertPDACommand($hq_id, $crId, "5", "1", $jb_id, $now, $cmd_exec_limit);
}
if (!$is_EU_only && $jb_third_country_old != "1")
// Log-Eintrag "Anforderung des Versenderstatus bestätigt durch #Name"
writeToLogDB(151, $hq_id, $jb_id, $usr_id, "", "", "", "");
// Erst hier Log-Eintrag wenn jb_incomplete immer noch incomplete
if (!$is_EU_only && $jb_third_country_old == "1" && $db->getOne("SELECT jb_incomplete FROM job WHERE jb_id = " . $jb_id) == 0 && $jb_incomplete_old == "1") {
// Log-Eintrag "Umsatzsteuerrechtlich korrekte Abrechnung bestätigt durch #Name"
writeToLogDB(152, $hq_id, $jb_id, $usr_id, "", "", "", "");
}
if (isset($cr_price_threshold_override) && trim($cr_price_threshold_override) != "") {
// Log-Eintrag "Überschreiten der Fuhrlohnschwelle bestätigt #Name"
writeToLogDB(153, $hq_id, $jb_id, $usr_id, "", "", "", $cr_price_threshold_override);
}
if (isset($cr_price_block_override) && trim($cr_price_block_override) != "") {
// Log-Eintrag "Überschreiten der Fuhrlohnsperre bestätigt #Name"
writeToLogDB(154, $hq_id, $jb_id, $usr_id, "", "", "", $cr_price_block_override);
}
//writeLog_("../log/job_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));
}
// deleteStmt("phoenix_log.semaphor","sp_obj_type = 'jb' AND sp_obj_id = 0 AND sp_fieldname = 'job_options'");
// 11.07.2024: falls das COMMIT nicht geklappt hat, eine Alarm-Mail senden
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_block . ", " . date("Y-m-d H:i:s") . ")') WHERE sp_id = " . $sp_id);
}
/*
$params = "";
foreach($HTTP_POST_VARS as $key=>$value) { $params .= $key.'='.$value.'&'; }
rtrim($fields_string, '&');
// $options = array(
// 'http' => array(
// 'header' => "Content-type: text/html; charset=iso-8859-1\r\n",
// 'method' => 'POST',
// 'content' => $params
// )
// );
$result = file_get_contents("https://ext01.sb-test.assecutor.de/jobs/job_options.php?" . $params);
print_r($params);
die($result);
*/
$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_block . ", " . date("Y-m-d H:i:s") . ")') WHERE sp_id = " . $sp_id);
}
endif;
//echo "\$is_globaljob = " . $is_globaljob;
if ($is_globaljob):
$cmd = "php ../service/service_aaa_multi_check.php acapella7890 " . $jb_id . " >> " . "../log/service_aaa_multi_check_" . date("Ym") . ".log" . " 2>&1 &";
exec($cmd);
endif;
$dummy = file ("http://www.assecutor.de/stadtbote/tools/check_address_caller.php?jb_id=$jb_id&hq_id=$hq_id&inst=" . getParameterValue("0", "GLOBAL_UNIQUE_DB_INSTANCE_NO", "0"));
// $cmd = "php ../sysadmin/check_special_chars.php " . $jb_id . " >> ../log/check_special_chars.stdout+err 2>&1 &";
// exec($cmd);
// check whether there is something to do with jb_cr_price
if (getFieldValueFromId("job", "jb_id", "$jb_id", "jb_status") == 2)
check_cr_agio($jb_id);
photosToBeMadeForLastStation($jb_id);
if ($job_is_new)
initJobSemaphors($jb_id);
if (!isset($jb_multi) || $jb_multi == "")
$jb_multi = "0";
if (!isset($jb_multi_factor) || $jb_multi_factor == "")
$jb_multi_factor = "1";
//echo "job_options: php ../jobs/check_jb_permanent.php " . $jb_id . " " . $jb_multi . " " . $jb_multi_factor . " >> " . "../log/check_jb_permanent_multi_" . date("Ym") . ".log" . " 2>&1 &";
if ($jb_multi == "1" || $jb_multi_factor != "1") {
$cmd = "php ../jobs/check_jb_permanent.php " . $jb_id . " " . $jb_multi . " " . $jb_multi_factor . " " . $cr_id_orders . " >> " . "../log/check_jb_permanent_multi_" . date("Ym") . ".log" . " 2>&1 &";
exec($cmd);
}
$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_block . ", " . 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");
if ((isset($sendmail) && $sendmail == "1") || ($job_is_new && $jb_offer == 1 && trim($jb_offer_mail) != "")):
$job_id = $jb_id;
$f_email = str_replace(" ", "", $ask_mailrecipients);
$currentHqId = $hq_id;
$job_crSid = "undefined";
// Define constants
$constMailSenderAddress = getParameterValue("0", "MAIL_SENDER_ADDRESS", $currentHqId);
// Set action parameters
$f_act = "mailsend";
$mailResult = FALSE;
// Standalone process
$automailer = "1";
$mailTextJobStatus = "CHANGE";
if ($jb_offer == 1) {
$f_email = str_replace(" ", "", $jb_offer_mail);
if ($job_is_new)
$mailTextJobStatus = "OFFER";
else
$mailTextJobStatus = "OFFER_CHANGE";
}
include_once ('../include/email/htmlMimeMail.php');
include_once ("../admin/jb_detail.php");
// Get current mail status
if ($mailResult) :
$statusSent = "OK";
$statusMessageTxt .= "\\nEine Mail wurde versandt an \\\"" . $f_email . "\\\".";
else:
$statusSent = "NOT OK";
$statusMessageTxt .= "\\nDie Mail an " . $f_email . " konnte nicht versandt werden.";
endif;
// Write logdata into log file
$logFile = substr(getParameterValue("0", "AUTOMAILER_LOGFILE", $currentHqId), 0, -4) . "." . strtolower($mailTextJobStatus) . ".log";
writeToFile($logFile, "[Job: " . $job_id . "] [Time: " . getDateTime("0") . "] [From: " . $constMailSenderAddress . "] [To: " . $f_email . "] [SID: " . $job_crSid . "] [" . $mailTextJobStatus . "] [Status: " . $statusSent . "]");
endif;
$statusMessage = $statusMessageTxt;
//writeLog_("../log/job_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_tourname_old == "" ? $jb_ordertime : date("Y-m-d H:i:s")), 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_VAR != ""):
$csc_id_payer = $CSC_ID_PAYER_CASH_VAR;
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");
// Noch was Neues: Wenn beim Kunden hinterlegt ist, dass bei der Abholung bei diesem Kunden dessen Konditionen (cs_jbcond = 1) gelten soll,
// dann gelten für die Preisermittlung nicht die Konditionen des Zahlers!
$cs_id_cond = getFieldValueFromId("costcenter", "csc_id", $jobList[0][JL_CSC_ID], "cs_id");
$cs_jbcond = getFieldValueFromId("customer", "cs_id", $cs_id_cond, "cs_jbcond");
if ($cs_jbcond == 1)
$cs_id = $cs_id_cond;
$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;
$vhtSrvt_name = $db->getOne("SELECT mt_value FROM metatype WHERE mt_sort = '$vht_id' AND mt_type = 'vehicletype'");
if (trim($jb_markup_ori) == "") {
$jb_markup = getFuelMarkup($vhtSrvt_name, (trim($cs_id) != "" ? $cs_id : 0), $hq_id, $jb_ordertime);
}
if (MASK_CR_PRICE_MODE == "1") {
if (trim($jb_cr_markup_ori) == "") {
$jb_cr_markup = getFuelMarkupCr($vhtSrvt_name, (trim($cs_id) != "" ? $cs_id : 0), $hq_id, $jb_ordertime);
}
}
// Grundpreis
// Servicetype-Name (Fahrrad etc.)
$srvt_name = $db->getOne(
"SELECT mt_value FROM metatype WHERE mt_sort = '$vht_id' AND mt_type = 'vehicletype'");
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_tourname_old == "" ? $jb_ordertime : date("Y-m-d H:i:s")), 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, $jb_cr_markup, $vht_id);
// $gross_price += $fullPrice;
$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] == "")
$jobList[$i][JL_TR_MEDIATIONAREA_ID] = 0;
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] == "")
$jobList[$i+1][JL_TR_MEDIATIONAREA_ID] = 0;
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
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_tourname_old == "" ? $jb_ordertime : date("Y-m-d H:i:s")), $distance, $costsplit_count, $getPriceOnly, $jb_cash, (($jb_costsplit == "false" || MASK_CASH_PAYER_SELECT == "1") ? $csc_id_payer : ""), $jb_storno, $zipcode1, $zipcode2, true, $jb_markup, $jb_cr_markup, $vht_id);
//echo "'".$jobList[$i][JL_TR_HSNO].",$ad_id1;".$jobList[$i+1][JL_TR_HSNO].",$ad_id2'
\n";
//reportDie ("saveServiceCosts($ad_id1, $ad_id2, $hq_id, $cs_id, $jb_id, ($i + 1), ($jb_tourname_old == "" ? $jb_ordertime : date("Y-m-d H:i:s")), $distance, $costsplit_count, $getPriceOnly, $jb_cash, " . (($jb_costsplit == "false" || MASK_CASH_PAYER_SELECT == "1") ? $csc_id_payer : "") . ", $jb_storno, $zipcode1, $zipcode2, ". true .");");
$fullPrice += round($fp * ((100-$fd)/100), 2);
$discount_sign = ($special_address || $discount_sign == "**" ? "**"
: ($discount_sign = ($fd > 0 || $customer_specific || $discount_sign == "*" ? "*" : "")));
if ($fd > 0)
$discount_sign = " (-" . $fd . "%";
if ($self_service_discount > 0)
$discount_sign .= " KAE";
if ($fd > 0)
$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);
$discount_sign_cr = "";
if ($fd+$self_service_discount > 0) $discount_sign_cr = " (-" . ($fd+$self_service_discount) . "%)";
endfor;
endif;
/* ********************************************************************** */
// Inhalt des Frames aufbauen und ausgeben
//
// nur wenn if $getPriceOnly != 1 UND WENN NICHT von "check_jb_permanent.php" aufgerufen
if (isset($recalc_price_flag) && $recalc_price_flag == true)
return;
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 = getParameterValue("0", "MASK_EXCLUDE_VHT_IDS", $hq_id);
if ($mask_exclude_vht_ids != "")
$mask_exclude_vht_ids = " AND NOT mt_sort IN (" . $mask_exclude_vht_ids . ")";
$vht_id_options = addOptionsFromTable(
"metatype", "mt_sort", "mt_value", "mt_sort", "mt_type = 'vehicletype' AND mt_sort > 0" . $mask_exclude_vht_ids,
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_permanent_options =
"" .
"" .
"" .
"" .
"" .
"" .
"" .
"" .
"" .
"" .
"";
$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;
$_csc_id_extern_list_ = /* $csc_id_extern_list . */ $jsAddNewExternCostcenter;
// $_ph_", getPublicHolidays(getDateTime("year"), "1", "1"));
$_hq_id_ = $hq_id;
$_md_id_ = $md_id;
$_cs_id_ = $cs_id;
$_csc_id_orderer_ = $csc_id_orderer;
$_csc_id_orderer_ec_ = $csc_id_orderer_ec;
$_jb_id_ = $jb_id;
$_jb_copy_ = $jb_copy;
$_dbhistory_ = $dbhistory;
/*
=> 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
*/
if ($disp != "true") {
$_empModeCopyJob_ = getParameterValue($emp_id, "MODE_COPY_JOB");
$_empModeLaterJob_ = getParameterValue($emp_id, "MODE_LATER_JOB");
$_empModeLaterJobWithNormal_ = MODE_LATER_JOB_WITH_NORMAL;
}
$_prev_jb_id_ = $prev_jb_id;
$_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 : "");
$_when_ = "var when = \"" . date("H:i") . "\";";
$_cs_jbedit_cr_ = getFieldValueFromId("customer", "cs_id", "$cs_id", "cs_jbedit_cr");
if (getFieldValueFromId("customer", "cs_id", "$cs_id", "cs_jbedit_cr") == "1"):
$_cs_jbedit_cr_list_ = getCustomerCouriers($db, $cs_id);
endif;
if (trim($db->getOne("SELECT cs_filter_jbedit FROM customer WHERE cs_id = $cs_id")) != ""):
$_cs_jbedit_cs_filter_ = "1";
endif;
$_cs_jbedit_filter_list_ = getCustomerFilters($db, $cs_id);
$_cur_jb_status_ = getFieldValueFromId("job", "jb_id", "$jb_id", "jb_status");
$_is_b2b_ = ($jb_id != "" && is_numeric($jb_id) ? ($db->getOne("SELECT jb_id FROM phoenix_log.log WHERE logo_id = 102 AND jb_id = " . $jb_id) == $jb_id ? "1" : "0") : "0");
$_csc_id_payer_cash_ = $CSC_ID_PAYER_CASH_VAR;
$_cash_payer_select_ = MASK_CASH_PAYER_SELECT;
$_auto_refresh_ = MASK_AUTO_REFRESH;
$_commission_no_on_ = MASK_COMMISSION_NO;
$_ask_defaultpayer_change_ = MASK_ASK_DEFAULTPAYER_CHANGE;
$_manual_disposition_ = MASK_MANUAL_DISPOSITION;
$_MASK_CALCULATOR_TYPE_ = MASK_CALCULATOR_TYPE;
$_MASK_CALCULATOR_SRV_ = MASK_CALCULATOR_SRV;
$_MASK_CALC_CR_PRICE_ = MASK_CALC_CR_PRICE;
$_MASK_CR_PRICE_MODE_ = MASK_CR_PRICE_MODE;
$_MASK_CALC_SIDS_ = MASK_CALC_SIDS;
$_CSC_ID_PAYER_EXTERN_ = CSC_ID_PAYER_EXTERN;
$_MASK_MAXTOUR_ = MASK_MAXTOUR;
$_MASK_MAX_TR_REMARK_ = MASK_MAX_TR_REMARK;
$_MASK_CS_PROV_DEFAULT_ = (MASK_CS_PROV_DEFAULT == "" ? 0 : MASK_CS_PROV_DEFAULT);
$_MASK_INVOICE_SHOW_SIDS_ = MASK_INVOICE_SHOW_SIDS;
$_MASK_INVOICE_SIDS_SID_ = MASK_INVOICE_SIDS_SID;
$_MASK_INVOICE_SIDS_SID0_ = getParameterValue("0", "MASK_INVOICE_SIDS_SID0", "0");
$_MASK_INVOICE_SIDS_SID1_ = getParameterValue("0", "MASK_INVOICE_SIDS_SID1", "0");
$_EMAIL_CRVHSID_NO_MAIL_Arr = explode(",", getParameterValue("0", "EMAIL_CRVHSID_NO_MAIL", $hq_id));
$_EMAIL_CRVHSID_NO_MAIL_ = "";
foreach($_EMAIL_CRVHSID_NO_MAIL_Arr as $val)
$_EMAIL_CRVHSID_NO_MAIL_ .= "'" . $val . "',";
if ($_EMAIL_CRVHSID_NO_MAIL_ != "")
$_EMAIL_CRVHSID_NO_MAIL_ = substr($_EMAIL_CRVHSID_NO_MAIL_, 0, -1);
$_MASK_JB_REPORT_BUTTON_ENABLED_PERMANENT_ = getParameterValue("0", "MASK_JB_REPORT_BUTTON_ENABLED_PERMANENT", $hq_id);
$_MASK_HIDDEN_FREETEXT_ = getParameterValue("0", "MASK_HIDDEN_FREETEXT", $hq_id);
$_MASK_BIKE_FILTER_ = MASK_BIKE_FILTER;
$_MASK_COMMISSION_NO_MANDATORY = MASK_COMMISSION_NO_MANDATORY;
$_MASK_HIDE_STANDARD_PRICE_IF_KM_PRICE = getParameterValue("0", "MASK_HIDE_STANDARD_PRICE_IF_KM_PRICE", $hq_id);
$_EU_COUNTRYCODES_Arr = explode(",", getParameterValue("0", "EU_COUNTRYCODES", "0"));
$_EU_COUNTRYCODES_ = "";
foreach($_EU_COUNTRYCODES_Arr as $val)
$_EU_COUNTRYCODES_ .= "'" . $val . "',";
if ($_EU_COUNTRYCODES_ != "")
$_EU_COUNTRYCODES_ = substr($_EU_COUNTRYCODES_, 0, -1);
$_cs_srv_list_ = (MASK_CALCULATOR_SRV_SRC == "1" ? "var cs_srv_list = [];\nvar cs_srvt_list = [];\nvar cs_price_list = [];\n" : "");
$_hq_workmode_ = $hq_workmode;
$statusMessage = $statusMessage;
// Externe Kostenstelle vordefinieren
$javascript = javascriptAdd_cs_eid(CSC_ID_PAYER_EXTERN, "");
$empHqList = getParameterValue("0", "HEADQUARTERS_MULTIPLE_ACCESS_EMPLOYEES", "0") . "|300001";
if ($userType == "1" && $empHqList != ""):
$empHqListGlobaljobs = getParameterValue("0", "HEADQUARTERS_MULTIPLE_ACCESS_EMPLOYEES_GLOBALJOBS", "0");
//echo "'$emp_id', '$empHqListGlobaljobs'" . ", '$hq_id', |" . isInParameterString($hq_id, $empHqListGlobaljobs) . "|, |" . isInParameterString($emp_id, $empHqList) . "|";
if ($empHqListGlobaljobs != "" && isInParameterString($emp_id, $empHqList) && !isInParameterString($hq_id, $empHqListGlobaljobs)) :
$javascript .= "parent.job_options.document.tourOptions.jb_globaljob.disabled=true;\n";
endif;
endif;
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_hiddenFreetext_1" => my_str_check_http($jb_hiddenFreetext_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_jam_waittime" => $jb_jam_waittime,
"jb_cr_filter" => $jb_cr_filter, "jb_markup" => $jb_markup_ori, "jb_cr_markup" => $jb_cr_markup_ori, "jb_toll" => $jb_toll_ori,
"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_id_parent" => $jb_id_parent, "jb_type" => $jb_type,
"jb_tourname" => $jb_tourname, "jb_km" => $jb_km_ori, "jobList" => my_str_check_http($jobListOri)), ""
);
if (MASK_CR_PRICE_MODE == "1") {
$javascript .=
setJavascriptOpenerFormVals("job_options", "tourOptions",
array("jb_cr_serviceprice" => $jb_cr_serviceprice_ori), "");
}
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"), "") .
setJavascriptOpenerChecked("job_options", "tourOptions", "jb_offer",
(($jb_offer != "1") ? "false" : "true"), "") .
setJavascriptOpenerDisabled("job_options", "tourOptions", "jb_permanent",
(($jb_reserv == 1 || $jb_permanent != "") ? "false" : "true"), "") .
"checkJb_permanent(0);\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;
$_javascript_ = $javascript;
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";
$javascript .= javascriptAdd_cs_eid($csc_id_orderer, "");
$_csc_id_start_code_js_ = $javascript;
define ("MASK_WAITTIME_ENABLED", "0");
define ("MASK_DATESELECTFIELDS_ENABLED", "0");
define ("MASK_CHECK_DISCOUNT", "1");
define ("MASK_SERVICE_PRICE", "1");
define ("CUSTOMER_JOB", "1");
else:
$_csc_id_start_code_js_ = mkCsc_id_start($csc_id_start);
define ("CUSTOMER_JOB", "0");
endif;
// $_csc_id_orderer_ = ec($csc_id_orderer);
$_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")));
$_ec_jb_id_ = ec($jb_id);
if (MASK_WAITTIME_ENABLED != "1"):
$WAITTIME_DISABLED_START = "";
endif;
$DATESELECTFIELDS_DISABLED_START = "";
$DATESELECTFIELDS_DISABLED_END = "";
$TIMESELECTFIELDS_DISABLED_START = "";
$TIMESELECTFIELDS_DISABLED_END = "";
$DATEINPUTFIELDS_DISABLED_START = "";
$DATEINPUTFIELDS_DISABLED_END = "";
$TIMEINPUTFIELDS_DISABLED_START = "";
$TIMEINPUTFIELDS_DISABLED_END = "";
if (MASK_DATESELECTFIELDS_ENABLED != "1"):
$DATESELECTFIELDS_DISABLED_START = "";
$TIMESELECTFIELDS_DISABLED_START = "";
else:
$DATEINPUTFIELDS_DISABLED_START = "";
$TIMEINPUTFIELDS_DISABLED_START = "";
endif;
$DISCOUNT_DISABLED_START = "";
$DISCOUNT_DISABLED_END = "";
if (MASK_CHECK_DISCOUNT != "1"):
$DISCOUNT_DISABLED_START = "";
endif;
$SERVICEPRICE_DISABLED_START = "";
$SERVICEPRICE_DISABLED_END = "";
if (MASK_SERVICE_PRICE != "1" || MASK_MARKUP_MODE == "2"):
$SERVICEPRICE_DISABLED_START = "";
endif;
$CUSTOMER_DISABLED_START = "";
$CUSTOMER_DISABLED_END = "";
$CUSTOMER_COURIER_DISABLED_START = "";
$CUSTOMER_COURIER_DISABLED_END = "";
$CUSTOMER_FILTER_DISABLED_START = "";
$CUSTOMER_FILTER_DISABLED_END = "";
$CUSTOMER_JB_SALES_TAX_RATE = "";
if (CUSTOMER_JOB == "1"):
$CUSTOMER_DISABLED_START = "";
// Steuern hartcodiert auf 16% für Kundenaufträge
$CUSTOMER_JB_SALES_TAX_RATE =
"" .
"";
if (getFieldValueFromId("customer", "cs_id", "$cs_id", "cs_jbedit_cr") != "1"):
$CUSTOMER_COURIER_DISABLED_START = "";
endif;
if (trim($db->getOne("SELECT cs_filter_jbedit FROM customer WHERE cs_id = $cs_id")) == ""):
$CUSTOMER_FILTER_DISABLED_START = "";
endif;
endif;
$CALCULATOR_DISABLED_START = "";
$CALCULATOR_DISABLED_END = "";
if (MASK_CALCULATOR != "1"):
$CALCULATOR_DISABLED_START = "";
endif;
$RANKING_JB2CRVH_MEASURE_DISABLED_START = "";
$RANKING_JB2CRVH_MEASURE_DISABLED_END = "";
$RANKING_JB2CRVH_MEASURE_ENABLED_START = "";
$RANKING_JB2CRVH_MEASURE_ENABLED_END = "";
if (RANKING_JB2CRVH_MEASURE == "1"):
$RANKING_JB2CRVH_MEASURE_DISABLED_START = "";
else:
$RANKING_JB2CRVH_MEASURE_ENABLED_START = "";
endif;
$_cr_id_options_ = (isset($cr_id_options) ? $cr_id_options : "");
//$_jb_waittime_options_ = $jb_waittime_options;
$_vht_id_options_ = $vht_id_options;
$_savedTour_disabled_ = $savedTour_disabled;
$_savedTour_options_ = $savedTour_options;
$_jb_permanent_options_ = $jb_permanent_options;
$_jb_sales_tax_rate_sign_options_ = $jb_sales_tax_rate_sign_options;
$_sales_tax_rate_value_ = $sales_tax_rate_value;
$_jb_type_ = MASK_JB_TYPE_DEFAULT;
if ($hq_id == 1):
define ("BUNDESLAND", "HB");
elseif ($hq_id == 2):
define ("BUNDESLAND", "HH");
elseif ($hq_id == 3):
define ("BUNDESLAND", "BE");
elseif ($hq_id == 4):
define ("BUNDESLAND", "NI");
elseif ($hq_id == 5):
define ("BUNDESLAND", "HE");
elseif ($hq_id == 6):
define ("BUNDESLAND", "SN");
elseif ($hq_id == 7):
define ("BUNDESLAND", "NW");
elseif ($hq_id == 8):
define ("BUNDESLAND", "SN");
elseif ($hq_id == 9):
define ("BUNDESLAND", "BY");
elseif ($hq_id == 10):
define ("BUNDESLAND", "BY");
elseif ($hq_id == 11):
define ("BUNDESLAND", "BW");
elseif ($hq_id == 90):
define ("BUNDESLAND", "HB");
endif;
if (MASK_CR_PRICE_MODE == "1") {
// Fuhrlohn = "38"
// Fuhrlohn GFL = "39"
$cr_price_readonly = "";
if (!authCheckEmployeeRights($emp_id, "38")) : $cr_price_readonly = " readonly"; endif;
$_cr_price_threshold_ = getParameterValue("0", "JB_CR_PRICE_THRESHOLD", "0");
$_cr_price_block_ = getParameterValue("0", "JB_CR_PRICE_BLOCK", "0");
$_cr_price_block_override_ = "0";
if (authCheckEmployeeRights($emp_id, "39")) : $_cr_price_block_override_ = "1"; endif;
}
// *** TABINDICES und ACCESSKEYS ***
$ti = 0;
$_cr_id_order_tabindex_ = ++$ti;
$_crSidList_tabindex_ = ++$ti;
$_crSidList_accesskey_ = _CRSIDLIST_ACCESSKEY_;
$_jb_cr_filter_tabindex_ = ++$ti;
$_jb_cr_filter_accesskey_ = _JB_CR_FILTER_ACCESSKEY_;
$_jb_waitstorno_tabindex_ = ++$ti;
if (MASK_WAITTIME_ENABLED == "1"):
$_jb_waittime_hour_tabindex_ = ++$ti;
$_jb_waittime_minute_tabindex_ = ++$ti;
endif;
$_vht_id_tabindex_ = ++$ti;
$_jb_markup_tabindex_ = ++$ti;
$_jb_cr_markup_tabindex_ = ++$ti;
$_jb_toll_tabindex_ = ++$ti;
$_jb_weight_tabindex_ = ++$ti;
$_jb_crvh_length_tabindex_ = ++$ti;
$_jb_crvh_width_tabindex_ = ++$ti;
$_jb_crvh_height_tabindex_ = ++$ti;
$_jb_crvh_position_tabindex_ = ++$ti;
$_tag_tabindex_ = ++$ti;
$_monat_tabindex_ = ++$ti;
$_jahr_tabindex_ = ++$ti;
$_stunde_tabindex_ = ++$ti;
$_minute_tabindex_ = ++$ti;
// $_jb_type_tabindex_ = ++$ti;
// $_jb_type_accesskey_ = _JB_TYPE_ACCESSKEY_;
$_endetag_tabindex_ = ++$ti;
$_endemonat_tabindex_ = ++$ti;
$_endejahr_tabindex_ = ++$ti;
$_jb_permanent_tabindex_ = ++$ti;
$_jb_permanent2_0_tabindex_ = ++$ti;
$_jb_permanent2_1_tabindex_ = ++$ti;
$_jb_permanent2_2_tabindex_ = ++$ti;
$_jb_permanent2_3_tabindex_ = ++$ti;
$_jb_permanent2_4_tabindex_ = ++$ti;
$_jb_permanent2_5_tabindex_ = ++$ti;
$_jb_permanent2_6_tabindex_ = ++$ti;
$_jb_multi_tabindex_ = ++$ti;
$_jb_multi_factor_tabindex_ = ++$ti;
$_savedTour_tabindex_ = ++$ti;
$_jb_tourname_tabindex_ = ++$ti;
$_jb_tourname_overwrite_tabindex_ = ++$ti;
$_jb_fixprice_tabindex_ = ++$ti;
$_jb_serviceprice_tabindex_ = ++$ti;
if (MASK_CR_PRICE_MODE == "1") {
$_jb_cr_price_tabindex_ = ++$ti;
$_jb_cr_serviceprice_tabindex_ = ++$ti;
}
$_jb_discount_tabindex_ = ++$ti;
$_jb_sales_tax_rate_tabindex_ = ++$ti;
$_jb_sales_tax_rate_sign_tabindex_ = ++$ti;
$_jb_insurance_tabindex_ = ++$ti;
$_jb_value_of_goods_tabindex_ = ++$ti;
$_special_case_tabindex_ = ++$ti;
$_jb_insurance_rate_tabindex_ = ++$ti;
$_afterwards_tabindex_ = ++$ti;
$_afterwards_accesskey_ = _AFTERWARDS_ACCESSKEY_;
$_jb_globaljob_tabindex_ = ++$ti;
// $_jb_globaljob_accesskey_ = _JB_GLOBALJOB_ACCESSKEY_;
$_jb_status_manual_tabindex_ = ++$ti;
$_jb_status_manual_accesskey_ = _JB_STATUS_MANUAL_ACCESSKEY_;
$_jb_incomplete_tabindex_ = ++$ti;
$_jb_offer_tabindex_ = ++$ti;
$_jb_bwv_tabindex_ = ++$ti;
$_jb_incomplete_accesskey_ = _JB_INCOMPLETE_ACCESSKEY_;
$_jb_km_tabindex_ = ++$ti;
$_toursubmit_tabindex_ = ++$ti;
$_toursubmit_accesskey_ = _TOURSUBMIT_ACCESSKEY_;
// *** ***
// include("../jobs/shrink.inc.php");
// $html_code = $tpl->get();
// echo htmlShrink($html_code, true);
elseif (!(isset($check_jb_permanent_flag) && $check_jb_permanent_flag == true)):
$jb_markup_text = "";
if ($jb_markup > 0)
$jb_markup_text = " (" . str_replace(".", ",", sprintf("%01.2f", $jb_markup)) . "% Tz.)";
if (MASK_CR_PRICE_MODE == "1") {
if ($jb_cr_markup > 0)
$jb_cr_markup_text = " (" . str_replace(".", ",", sprintf("%01.2f", $jb_cr_markup)) . "% Tz.)";
}
// Auch Treibstoffzuschlag in Prozent ermitteln
$fuel_markup = getFuelMarkup($srvt_name, (trim($cs_id) != "" ? $cs_id : 0), $hq_id, $jb_ordertime);
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);
}
$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";
$cur_price = "nicht anwendbar";
$cur_cr_price = "nicht anwendbar";
if ($vht_id < 7 || getParameterValue("0", "MASK_SHOW_STANDARD_PRICE_FOR_TRUCKS", $hq_id) == "1") {
$cur_price = str_replace(".", ",", sprintf("%01.2f", $fullPrice)) . " EUR" . $discount_sign . $jb_markup_text;
$cur_cr_price = str_replace(".", ",", sprintf("%01.2f", $fullCrPrice)) . " EUR" . $discount_sign_cr . $jb_cr_markup_text;
// if ($jb_cr_serviceprice > 0)
// $cur_cr_price = $cur_cr_price . " inkl. " . str_replace(".", ",", sprintf("%01.2f", $jb_cr_serviceprice)) . " EUR Service-Fuhrlohn";
}
$javascript .=
// jb_markup nur neu setzen, wenn neuer Job
// "if (parent.job_options.jb_markup_overwrite == 1) {" .
// " parent.job_options.document.tourOptions.jb_markup.value = \"" . str_replace(".", ",", sprintf("%01.2f", $fuel_markup)) . "\";\n" .
" parent.job_options.document.tourOptions.currentTSZ.value = \"" . str_replace(".", ",", sprintf("%01.2f", $fuel_markup)) . " %\";\n" .
" if (parent.job_options.document.tourOptions.jb_fixprice.value != \"\") parent.job_options.checkFixprice(1);" .
// "}\n" .
(MASK_CR_PRICE_MODE == "1" ?
// "if (parent.job_options.jb_cr_markup_overwrite == 1) {" .
// " parent.job_options.document.tourOptions.jb_cr_markup.value = \"" . str_replace(".", ",", sprintf("%01.2f", $fuel_cr_markup)) . "\";\n" .
" parent.job_options.document.tourOptions.currentCrTSZ.value = \"" . str_replace(".", ",", sprintf("%01.2f", $fuel_cr_markup)) . " %\";\n" .
" if (parent.job_options.document.tourOptions.jb_cr_price.value != \"\") parent.job_options.checkCrPrice();"
// . "}\n"
: "") .
(MASK_CALCULATOR_SRV_SRC == "1" ? getCustomerServices($db, $cs_id) : "") .
"parent.job_tour.document.tourForm.currentPrice.value = " .
"\"" . /*"Standard Preis: " .*/ $cur_price . "\";\n" .
(MASK_CR_PRICE_MODE == "1" ?
"parent.job_tour.document.tourForm.currentCrPrice.value = " .
"\"" . $cur_cr_price . "\";\n"
: "");
if (MASK_CR_PRICE_MODE == "1") {
$javascript .=
"parent.job_tour.document.tourForm.currentCrPrice.value = " . "\"" . "\";\n";
$javascript .=
"parent.job_options.document.tourOptions.cr_price_text.value = " . "\"" . "\";\n";
if (strtotime(MASK_CR_PRICE_MODE_DATE) <= strtotime($jb_ordertime)) {
$javascript .=
"parent.job_tour.document.tourForm.currentCrPrice.value = " .
"\"" . $cur_cr_price . "\";\n";
if ((($jb_fixprice != 0 && $jb_cr_price == 0) || ($jb_cr_price != 0 && $jb_markup != 0))) {
$jb_subtotal = round((float)$jb_fixprice * (1 - ($tmp_discount_rate / 100)) * ((100-$self_service_discount)/100), 2);
if ($jb_cr_price == 0 || $jb_cr_price == "") {
list($cr_price, $cr_price_rate) =
getCr_price_global($jb_subtotal, $hq_id, $cs_id, ($jb_tourname_old == "" ? $jb_ordertime : date("Y-m-d H:i:s")), $vhtSrvt_name, $vht_id);
$cr_price_rate_text = " (./. " . str_replace(".", ",", sprintf("%01.2f", $cr_price_rate)) . "%)";
} else {
$cr_price = round((float)$jb_cr_price * (1 - ($tmp_discount_rate / 100)) * ((100-$self_service_discount)/100), 2);
$cr_price_rate_text = " (BSG " . str_replace(".", ",", sprintf("%01.2f", ($jb_subtotal - $cr_price) / ($jb_subtotal != 0 ? $jb_subtotal : 1) * 100)) . "%)";
}
$cr_price = round($cr_price * (1 + ($jb_cr_markup / 100)), 2);
$jb_cr_markup_text = "";
if ($jb_cr_markup > 0)
$jb_cr_markup_text = " mit " . str_replace(".", ",", sprintf("%01.2f", $jb_cr_markup)) . "% TSZ";
// $javascript .= "alert('|".$jb_cr_price."|');" .
$javascript .=
"parent.job_options.document.tourOptions.cr_price_text.value = " .
"\"Frachtverg" . $jb_cr_markup_text . ": " . str_replace(".", ",", sprintf("%01.2f", $cr_price)) . " " . chr(128) . $cr_price_rate_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 .= "alert('".MASK_MARK_OLD_PRICE . "|" . $validfrom ."');";
if (MASK_MARK_OLD_PRICE != ""):
// $javascript .= "alert('".strtotime($validfrom) . "|" . strtotime(MASK_MARK_OLD_PRICE) ."');";
if (strtotime($validfrom) < strtotime(MASK_MARK_OLD_PRICE) && $fullPrice > 0):
$javascript .= "parent.job_tour.document.tourForm.currentPrice.style.backgroundColor = \"#000000\";";
else:
$javascript .= "parent.job_tour.document.tourForm.currentPrice.style.backgroundColor = \"" . $constBackground . "\";";
endif;
endif;
$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;
exit();
else:
return; // exit() an dieser Stelle würde dazu führen, dass Stornieren z. B. aus der Auftragsliste nicht mehr funktioniert
endif;
if (!isset($jobMode)) $jobMode = "undefined";
if (!isset($jb_id_log)) $jb_id_log = "undefined";
writeLog_("../log/job_options_", trace_execution_time_stop() . " '../jobs/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");
?>
AUFTRAGSERFASSUNG - SUBMITFRAME