destination_delivery.class.php 82 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394959697989910010110210310410510610710810911011111211311411511611711811912012112212312412512612712812913013113213313413513613713813914014114214314414514614714814915015115215315415515615715815916016116216316416516616716816917017117217317417517617717817918018118218318418518618718818919019119219319419519619719819920020120220320420520620720820921021121221321421521621721821922022122222322422522622722822923023123223323423523623723823924024124224324424524624724824925025125225325425525625725825926026126226326426526626726826927027127227327427527627727827928028128228328428528628728828929029129229329429529629729829930030130230330430530630730830931031131231331431531631731831932032132232332432532632732832933033133233333433533633733833934034134234334434534634734834935035135235335435535635735835936036136236336436536636736836937037137237337437537637737837938038138238338438538638738838939039139239339439539639739839940040140240340440540640740840941041141241341441541641741841942042142242342442542642742842943043143243343443543643743843944044144244344444544644744844945045145245345445545645745845946046146246346446546646746846947047147247347447547647747847948048148248348448548648748848949049149249349449549649749849950050150250350450550650750850951051151251351451551651751851952052152252352452552652752852953053153253353453553653753853954054154254354454554654754854955055155255355455555655755855956056156256356456556656756856957057157257357457557657757857958058158258358458558658758858959059159259359459559659759859960060160260360460560660760860961061161261361461561661761861962062162262362462562662762862963063163263363463563663763863964064164264364464564664764864965065165265365465565665765865966066166266366466566666766866967067167267367467567667767867968068168268368468568668768868969069169269369469569669769869970070170270370470570670770870971071171271371471571671771871972072172272372472572672772872973073173273373473573673773873974074174274374474574674774874975075175275375475575675775875976076176276376476576676776876977077177277377477577677777877978078178278378478578678778878979079179279379479579679779879980080180280380480580680780880981081181281381481581681781881982082182282382482582682782882983083183283383483583683783883984084184284384484584684784884985085185285385485585685785885986086186286386486586686786886987087187287387487587687787887988088188288388488588688788888989089189289389489589689789889990090190290390490590690790890991091191291391491591691791891992092192292392492592692792892993093193293393493593693793893994094194294394494594694794894995095195295395495595695795895996096196296396496596696796896997097197297397497597697797897998098198298398498598698798898999099199299399499599699799899910001001100210031004100510061007100810091010101110121013101410151016101710181019102010211022102310241025102610271028102910301031103210331034103510361037103810391040104110421043104410451046104710481049105010511052105310541055105610571058105910601061106210631064106510661067106810691070107110721073107410751076107710781079108010811082108310841085108610871088108910901091109210931094109510961097109810991100110111021103110411051106110711081109111011111112111311141115111611171118111911201121112211231124112511261127112811291130113111321133113411351136113711381139114011411142114311441145114611471148114911501151115211531154115511561157115811591160116111621163116411651166116711681169117011711172117311741175117611771178117911801181118211831184118511861187118811891190119111921193119411951196119711981199120012011202120312041205120612071208120912101211121212131214121512161217121812191220122112221223122412251226122712281229123012311232123312341235123612371238123912401241124212431244124512461247124812491250125112521253125412551256125712581259126012611262126312641265126612671268126912701271127212731274127512761277127812791280128112821283128412851286128712881289129012911292129312941295129612971298129913001301130213031304130513061307130813091310131113121313131413151316131713181319132013211322132313241325132613271328132913301331133213331334133513361337133813391340134113421343134413451346134713481349135013511352135313541355135613571358135913601361136213631364136513661367136813691370137113721373137413751376137713781379138013811382138313841385138613871388138913901391139213931394139513961397139813991400140114021403140414051406140714081409141014111412141314141415141614171418141914201421142214231424142514261427142814291430143114321433143414351436143714381439144014411442144314441445144614471448144914501451145214531454145514561457145814591460146114621463146414651466146714681469147014711472147314741475147614771478147914801481148214831484148514861487148814891490149114921493149414951496149714981499150015011502150315041505150615071508150915101511151215131514151515161517151815191520152115221523152415251526152715281529153015311532153315341535153615371538153915401541154215431544154515461547154815491550155115521553155415551556155715581559156015611562156315641565156615671568156915701571157215731574157515761577157815791580158115821583158415851586158715881589159015911592159315941595159615971598159916001601160216031604160516061607160816091610161116121613161416151616161716181619162016211622162316241625162616271628162916301631163216331634163516361637163816391640164116421643164416451646164716481649165016511652165316541655165616571658165916601661166216631664166516661667166816691670167116721673167416751676167716781679168016811682168316841685168616871688168916901691169216931694169516961697169816991700170117021703170417051706170717081709171017111712171317141715171617171718
  1. <?php
  2. if (!defined('IN_ONLINE')) {
  3. exit('Access Denied');
  4. }
  5. /**
  6. * Description of operation_log
  7. *
  8. * @author Administrator
  9. */
  10. class destination_delivery {
  11. private static $_destination_delivery;
  12. public static function getInstance() {
  13. if (!self::$_destination_delivery) {
  14. $c = __CLASS__;
  15. self::$_destination_delivery = new $c;
  16. }
  17. return self::$_destination_delivery;
  18. }
  19. /**
  20. * 关于destination_delivery 页面的所有的静态加载数据查询
  21. */
  22. public function destination_delivery_load(){
  23. $operate = utils::_get('operate');
  24. $operate = strtolower($operate);
  25. /**
  26. * select country
  27. */
  28. if ($operate == "country") {
  29. $term = $_POST['term'];
  30. $term = trim($term);
  31. $sql = "select DISTINCT category AS country_code from public.kerry_system_code
  32. where description='COUNTRY-STATION'
  33. and category ilike '" . common::check_input($term) . "%'";
  34. $sql .= " order by category";
  35. $rs = common::excuteListSql($sql);
  36. //前端要加上id 从1开始
  37. $retData = array();
  38. foreach($rs as $key => $val){
  39. if(!empty($val['country_code'])){
  40. $retData[] = array("value" =>$val['country_code'] ,"label"=>$val['country_code']);
  41. }
  42. }
  43. common::echo_json_encode(200,$retData);
  44. exit();
  45. }
  46. /**
  47. * select station 选择国家后再展示 station list数据
  48. */
  49. if ($operate == "station") {
  50. $country = common::check_input($_REQUEST['country']);
  51. $sql = "select code from public.kerry_system_code
  52. where description='COUNTRY-STATION'
  53. and category = '".$country."'
  54. and code NOT LIKE 'Online_%' order by code";
  55. $rs = common::excuteListSql($sql);
  56. foreach($rs as $key => $val){
  57. if(!empty($val['code'])){
  58. $retData[] = array("value" =>$val['code'] ,"label"=>$val['code']);
  59. }
  60. }
  61. common::echo_json_encode(200,$retData);
  62. exit();
  63. }
  64. /**
  65. * select KLN PIC 下拉可供选择的employee帐号,且帐号权限站点包括选中的station ?
  66. */
  67. if ($operate == "employee_account") {
  68. $term = $_POST['term'];
  69. $term = trim($term);
  70. $station = $_REQUEST['station'];
  71. $sqlwhere = '';
  72. if(!empty($station)){
  73. $more_param = common::getInNotInSqlForSearch(utils::implode(';',$station));
  74. $sqlwhere = " and lower(e.contact_id) in ($more_param) ";
  75. }
  76. $sql = "select e.email from public.ra_online_user r, employee e
  77. where r.employee_id=e.employee_id
  78. and r.online_active = true
  79. and r.user_type = 'Employee'
  80. and e.active = true
  81. ".$sqlwhere."
  82. and coalesce(e.email,'') <>''
  83. and e.email ilike '" . common::check_input($term) . "%' order by e.email limit 50";
  84. $rs = common::excuteListSql($sql);
  85. $retData = array();
  86. foreach($rs as $key => $val){
  87. if(!empty($val['email'])){
  88. $retData[] = array("value" =>$val['email'] ,"label"=>$val['email']);
  89. }
  90. }
  91. common::echo_json_encode(200,$retData);
  92. exit();
  93. }
  94. /**
  95. * 下拉可供选择的ports
  96. */
  97. if ($operate == "ports") {
  98. $mode = $_POST['mode'];
  99. $term = $_POST['term'];
  100. $term = trim($term);
  101. if ($mode == 'sea'){
  102. $sql = "select DISTINCT uncode from public.ports
  103. where coalesce(uncode,'')<> '' and uncode ilike '" . common::check_input($term) . "%'";
  104. } else {
  105. $sql = "select DISTINCT coalesce(airport.country_abb,'')||airport.airport_code as uncode from sfs.airport
  106. where coalesce(country_abb,'')<>''
  107. and coalesce(airport.country_abb,'')||airport.airport_code ilike '" . common::check_input($term) . "%'";
  108. }
  109. $sql .= " order by uncode limit 50";
  110. $rs = common::excuteListSql($sql);
  111. //前端要加上id 从1开始
  112. $retData = array();
  113. foreach($rs as $key => $val){
  114. if(!empty($val['uncode'])){
  115. $retData[] = array("value" =>$val['uncode'] ,"label"=>$val['uncode'],"checked"=>false);
  116. }
  117. }
  118. common::echo_json_encode(200,$retData);
  119. exit();
  120. }
  121. /**
  122. * 下拉可供选择的carrier
  123. */
  124. if ($operate == "carrier") {
  125. $term = $_POST['term'];
  126. $term = trim($term);
  127. $sql = "select DISTINCT scac from public.vessel_company
  128. where coalesce(scac,'')<> '' and scac ilike '" . common::check_input($term) . "%'";
  129. $sql .= " order by scac limit 50";
  130. $rs = common::excuteListSql($sql);
  131. //前端要加上id 从1开始
  132. $retData = array();
  133. foreach($rs as $key => $val){
  134. if(!empty($val['scac'])){
  135. $retData[] = array("value" =>$val['scac'] ,"label"=>$val['scac'],"checked"=>false);
  136. }
  137. }
  138. common::echo_json_encode(200,$retData);
  139. exit();
  140. }
  141. /**
  142. * Manage Address load
  143. */
  144. if ($operate == "manage_address"){
  145. $consignee = $_REQUEST['consignee_id'];
  146. //$consignee =array('COMGEN38002','FGB050132','ATOZTI35005','WILSON80001');
  147. $more_param = common::getInNotInSqlForSearch(utils::implode(';',$consignee));
  148. $country = $_REQUEST['country'];
  149. //$country =array('GB','DE','US');
  150. $more_param_country = common::getInNotInSqlForSearch(utils::implode(';',$country));
  151. $delivery_serial_no = common::deCode($_REQUEST['delivery_serial_no'], 'D');
  152. //contact_person,contact_number, 现在系统还没有把这两个字段接入
  153. if(!empty($delivery_serial_no)){
  154. $sql = "SELECT addr1,addr2,addr3,addr4,
  155. ctry_code,city_code,postal_code,
  156. '' as contact_person,'' as contact_number,
  157. create_user,contact_id,sync_key,
  158. from_station,
  159. 'from Ksmart' as op_action
  160. FROM public.contacts_address ca
  161. WHERE addr_type = 'D'
  162. and lower(ca.contact_id) in (".$more_param.")
  163. and ca.from_station in (select code from public.kerry_system_code where lower(category) in (".$more_param_country."))
  164. and ca.sync_key not in (select sync_key from public.contacts_address_online where delivery_serial_no = '".$delivery_serial_no."')
  165. union all
  166. SELECT addr1,addr2,addr3,addr4,
  167. ctry_code,city_code,postal_code,
  168. contact_person,contact_number,
  169. create_user,contact_id,sync_key,
  170. from_station,
  171. action as op_action
  172. FROM public.contacts_address_online
  173. where delivery_serial_no = '$delivery_serial_no'";
  174. }else{
  175. $sql = "SELECT addr1,addr2,addr3,addr4,
  176. ctry_code,city_code,postal_code,
  177. '' as contact_person,'' as contact_number,
  178. create_user,contact_id,sync_key,
  179. from_station,
  180. 'from Ksmart' as op_action
  181. FROM public.contacts_address ca
  182. WHERE addr_type = 'D'
  183. and lower(ca.contact_id) in (".$more_param.")
  184. and ca.from_station in (select code from public.kerry_system_code where lower(category) in (".$more_param_country."))";
  185. }
  186. $data = common::excuteListSql($sql);
  187. error_log($sql);
  188. $manageAddressList = array();
  189. //Online_D_Address
  190. foreach($data as $d){
  191. if ($d['op_action'] == "from Ksmart" && $d['create_user'] <> "Online_D_Address"){
  192. $address_remark = "read-only";
  193. } elseif ($d['op_action'] == "from Ksmart" && $d['create_user'] == "Online_D_Address"){
  194. $address_remark = "reviewed";
  195. } elseif ($d['op_action'] == "Add" && $d['create_user'] == "Online_D_Address"){
  196. $address_remark = "unreviewed";
  197. } elseif ($d['op_action'] == "Modify" && $d['create_user'] == "Online_D_Address"){
  198. $address_remark = "unreviewed";
  199. } else {
  200. $address_remark = "deletion";
  201. }
  202. $manageAddressList[] = array(
  203. "address_1"=>$d['addr1'],
  204. "address_2"=>$d['addr2'],
  205. "address_3"=>$d['addr3'],
  206. "address_4"=>$d['addr4'],
  207. "country"=>$d['ctry_code'],
  208. "city"=>$d['city_code'],
  209. "postal_code"=>$d['postal_code'],
  210. "contact_person"=>$d['contact_person'] === null ? '' : $d['contact_person'],
  211. "contact_number" =>$d['contact_number'] === null ? '' : $d['contact_number'],
  212. "create_user" => $d['create_user'], //create_user = Online_D_Address 时,代表對客戶賬號類型自己創建的D類地址
  213. "contact_id" => $d['contact_id'],
  214. "sync_key" => $d['sync_key'], //唯一key
  215. "from_station" => $d['from_station'], //只有是客户新键的才会特殊处理station Online_GE. 好判断是那个国家的
  216. "contact_type" => "Unedit", //这个前端控制的
  217. "op_action" => $d['op_action'],
  218. "address_remark" => $address_remark
  219. );
  220. }
  221. common::echo_json_encode(200,$manageAddressList);
  222. exit();
  223. }
  224. /**
  225. * country and city load
  226. */
  227. if ($operate == "country_city_load") {
  228. $term_type = $_POST['term_type'];
  229. $limit = $_POST['limit'];
  230. $term = $_POST['term'];
  231. $term = trim($term);
  232. $extend_sql_where = "";
  233. if ($term_type == "country" && !empty($limit)){
  234. $extend_sql_where = " and location_code = '$limit'";
  235. }
  236. if ($term_type == "city" && !empty($limit)){
  237. $extend_sql_where = " and country_code = '$limit'";
  238. }
  239. if ($term_type == "country"){
  240. $sql = "select DISTINCT country_code AS code from public.unlocode
  241. where country_code ilike '" . common::check_input($term) . "%'".$extend_sql_where;
  242. $sql .= " order by country_code limit 50";
  243. }
  244. if ($term_type == "city"){
  245. $sql = "select DISTINCT location_code AS code from public.unlocode
  246. where location_code ilike '" . common::check_input($term) . "%'".$extend_sql_where;
  247. $sql .= " order by location_code limit 50";
  248. }
  249. $rs = common::excuteListSql($sql);
  250. //前端要加上id 从1开始
  251. $retData = array();
  252. foreach($rs as $key => $val){
  253. if(!empty($val['code'])){
  254. $retData[] = array("value" =>$val['code'] ,"label"=>$val['code']);
  255. }
  256. }
  257. common::echo_json_encode(200,$retData);
  258. exit();
  259. }
  260. }
  261. /**
  262. * destination_delivery 配置
  263. */
  264. public function destination_delivery_config(){
  265. $operate = utils::_get('operate');
  266. $operate = strtolower($operate);
  267. /**
  268. * 这个是嵌套在destination_delivery的配置查询,
  269. */
  270. if ($operate == "search"){
  271. $cp = common::check_input($_POST ['cp']); //current_page
  272. $ps = common::check_input($_POST ['ps']); //ps
  273. if (empty($ps))
  274. $ps = 100;
  275. if (empty($cp))
  276. $cp = 1;
  277. $rc = $_POST ['rc'];
  278. if ($rc == - 1) {
  279. $sql = "select count(*) from public.kln_destination_delivery_config";
  280. $rc = common::excuteOneSql($sql);
  281. }
  282. $tp = ceil($rc / $ps);
  283. if ($rc > 0) {
  284. $sql = "select * from public.kln_destination_delivery_config";
  285. $sql .= " order by id desc limit " . $ps . " offset " . ($cp - 1) * $ps;
  286. $rs = common::excuteListSql($sql);
  287. foreach($rs as $key => $val){
  288. $rs[$key]["_serial_no"] = common::deCode($val['serial_no'], 'E');
  289. }
  290. $arrTmp = array('searchData' => $rs,
  291. 'rc' => intval($rc),
  292. 'ps' => intval($ps),
  293. 'cp' => intval($cp),
  294. 'tp' => intval($tp));
  295. common::echo_json_encode(200,$arrTmp);
  296. exit();
  297. }else{
  298. $arrTmp = array('searchData' => array());
  299. common::echo_json_encode(200, $arrTmp);
  300. exit();
  301. }
  302. }
  303. if ($operate == "add"){
  304. $serial_no = common::deCode($_REQUEST['a'], 'D');
  305. $data = array();
  306. $rule = array();
  307. if (!empty($serial_no)){
  308. $sql = "select * from public.kln_destination_delivery_config where serial_no = '$serial_no'";
  309. $data = common::excuteObjectSql($sql);
  310. if ($data['recommended_delivery'] == 'Delivery_ETA_ATA') {
  311. $sql = "select * from public.kln_destination_delivery_rule where recommended_delivery_serial_no = '$serial_no'";
  312. $rule = common::excuteListSql($sql);
  313. }
  314. } else{
  315. //代表新加,页面初始
  316. $data['booking_window'] = "No_Restrictions";
  317. $data['booking_window_date_start'] ="";
  318. $data['booking_window_date_end'] ="";
  319. $data['recommended_delivery'] ="No_Recommended";
  320. }
  321. //处理组装返回格式
  322. //RcommendDeliveryDate
  323. $RecommendCheckedAirList = array();
  324. $RecommendCheckedSeaList = array();
  325. $RecommendCheckedList = array();
  326. foreach($rule as $item){
  327. if ($item['mode_type'] == 'sea'){
  328. $RecommendCheckedSeaList[] = array("priority"=>$item['priority'],"rule_type"=>$item['rule_type'],
  329. "ports"=>explode(",", $item['ports']),
  330. "carrier"=>explode(",", $item['carrier']),
  331. "recommended_delivery_from"=>$item['recommended_delivery_from'],
  332. "recommended_delivery_to"=>$item['recommended_delivery_to'],
  333. "mode_type"=>$item['mode_type']);
  334. }
  335. if ($item['mode_type'] == 'air'){
  336. $RecommendCheckedAirList[] = array("priority"=>$item['priority'],"rule_type"=>$item['rule_type'],
  337. "ports"=>explode(",", $item['ports']),
  338. "carrier"=>explode(",", $item['carrier']),
  339. "recommended_delivery_from"=>$item['recommended_delivery_from'],
  340. "recommended_delivery_to"=>$item['recommended_delivery_to'],
  341. "mode_type"=>$item['mode_type']);
  342. }
  343. if (!utils::in_array(ucfirst($item['mode_type']), $RecommendCheckedList)) {
  344. $RecommendCheckedList[] = ucfirst($item['mode_type']);
  345. }
  346. }
  347. $returnData = $data;
  348. $returnData["SetBookingWindow"] = array("windowradio" =>common::destination_delivery_window_radio($data['booking_window']),
  349. "windowBeforeDays"=>$data['booking_window_date_start'],
  350. "windowAfterDays"=>$data['booking_window_date_end']);
  351. $returnData["RcommendDeliveryDate"] = array("Recommendradio" =>common::destination_delivery_recommended($data['recommended_delivery']),
  352. "RecommendCheckedList"=>$RecommendCheckedList,
  353. "RecommendCheckedAirList"=>$RecommendCheckedAirList,
  354. "RecommendCheckedSeaList"=>$RecommendCheckedSeaList);
  355. $returnData["KLNPLCvalue"] = empty($data['kln_pic']) ? array() : explode(";", $data['kln_pic']);
  356. $CountryCheckedList = array();
  357. $sql = "select code from public.kerry_system_code
  358. where description='COUNTRY-STATION'
  359. and category = '".$data['country']."'
  360. and code NOT LIKE 'Online_%'";
  361. $rs = common::excuteListSql($sql);
  362. foreach($rs as $key => $val){
  363. if(!empty($val['code'])){
  364. $CountryCheckedList[] = array("value" =>$val['code'] ,"label"=>$val['code']);
  365. }
  366. }
  367. $returnData["CountryCheckedList"] = $CountryCheckedList;
  368. $returnData["station"] = explode(",", $returnData["station"]);
  369. $data = array('returnData' =>$returnData);
  370. common::echo_json_encode(200,$data);
  371. exit();
  372. }
  373. if ($operate == "save"){
  374. $serial_no = common::deCode($_POST['serial_no'], 'D');
  375. $country = common::check_input($_POST['country']);
  376. $station = empty($_POST['station']) ? "" : utils::implode(",",$_POST['station']);
  377. $booking_window = common::check_input($_POST['booking_window']);
  378. $booking_window_date_start = common::check_input($_POST['booking_window_date_start']);
  379. $booking_window_date_end = common::check_input($_POST['booking_window_date_end']);
  380. $recommended_delivery = common::check_input($_POST['recommended_delivery']);
  381. $kln_pic = $_POST['kln_pic'];
  382. $kln_pic = utils::implode(";",$kln_pic);
  383. $booking_window_desc = common::check_input($_POST['booking_window_desc']);
  384. $recommended_delivery_date_desc = common::check_input($_POST['recommended_delivery_date_desc']);
  385. //rule
  386. $_mode_type = $_POST['mode_type'];
  387. $_priority = $_POST['priority'];
  388. $_rule_type = $_POST['rule_type'];
  389. $_ports = $_POST['ports'];
  390. $_carrier = $_POST['carrier'];
  391. $_recommended_delivery_from = $_POST['recommended_delivery_from'];
  392. $_recommended_delivery_to = $_POST['recommended_delivery_to'];
  393. $sql = "";
  394. if (!empty($serial_no)){
  395. $updateSqlSet = " modify_by = '"._getLoginName()."',update_time = now()";
  396. if (!empty($country)) {
  397. $updateSqlSet.= ", country = '$country' ";
  398. }
  399. if (!empty($station)) {
  400. $updateSqlSet.= ", station = '$station' ";
  401. }
  402. if (!empty($booking_window)) {
  403. $updateSqlSet.= ", booking_window = '$booking_window' ";
  404. }
  405. if (!empty($booking_window_date_start)) {
  406. $updateSqlSet.= ", booking_window_date_start = '$booking_window_date_start' ";
  407. }
  408. if (!empty($booking_window_date_end)) {
  409. $updateSqlSet.= ", booking_window_date_end = '$booking_window_date_end' ";
  410. }
  411. if (!empty($recommended_delivery)) {
  412. $updateSqlSet.= ", recommended_delivery = '$recommended_delivery' ";
  413. }
  414. if (!empty($kln_pic)) {
  415. $updateSqlSet.= ", kln_pic = '$kln_pic' ";
  416. }
  417. if (!empty($booking_window_desc)) {
  418. $updateSqlSet.= ", booking_window_desc = '$booking_window_desc' ";
  419. }
  420. if (!empty($recommended_delivery_date_desc)) {
  421. $updateSqlSet.= ", recommended_delivery_date_desc = '$recommended_delivery_date_desc' ";
  422. }
  423. //代表update
  424. $sql .= "update public.kln_destination_delivery_config set ".$updateSqlSet."
  425. where serial_no = '$serial_no';";
  426. } else {
  427. //检查配置的站点是否于以前的配置的,是否重合
  428. $exist = common::excuteListSql("select country,station from public.kln_destination_delivery_config WHERE string_to_array('$station', ',') && string_to_array(station, ',')");
  429. if(!empty($exist)){
  430. $data = array("msg" =>"The station has been reconfigured. Please check ".$exist[0]['country'] ." - " .$exist[0]['station']);
  431. common::echo_json_encode(200,$data);
  432. exit();
  433. }
  434. //代表更新
  435. $serial_no = common::uuid();
  436. $sql .="INSERT INTO public.kln_destination_delivery_config(
  437. serial_no, country, station, booking_window, booking_window_date_start,
  438. booking_window_date_end, recommended_delivery, kln_pic, booking_window_desc,recommended_delivery_date_desc,
  439. create_by, created_time, modify_by, update_time)
  440. VALUES ('$serial_no', '$country', '$station', '$booking_window', '$booking_window_date_start',
  441. '$booking_window_date_end', '$recommended_delivery', '$kln_pic','$booking_window_desc','$recommended_delivery_date_desc',
  442. '"._getLoginName()."', now(), '"._getLoginName()."', now());";
  443. }
  444. $errmsg = "";
  445. //柜子是先删除,后添加
  446. $sql .= "delete from public.kln_destination_delivery_rule where recommended_delivery_serial_no = '$serial_no';";
  447. if ($recommended_delivery == "Delivery_ETA_ATA"){
  448. // 用于统计每种类型是否存在,以及是否满足 rule_type = 'all'
  449. $typeExists = ['air' => false, 'sea' => false];
  450. $typeHasAllRule = ['air' => false, 'sea' => false];
  451. //检查判断规则不能重合
  452. $seaRule = [];
  453. $airRule = [];
  454. foreach($_mode_type as $key => $v){
  455. $mode_type = $v;
  456. $priority = $_priority[$key];
  457. $rule_type = $_rule_type[$key];
  458. $ports = $_ports[$key];
  459. $carrier = $_carrier[$key];
  460. if( $mode_type == 'sea'){
  461. $seaRule[] = explode(",",$_ports[$key]);
  462. ///$sea_carrier_index += 1;
  463. } else {
  464. $airRule[] = explode(",",$_ports[$key]);
  465. }
  466. $recommended_delivery_from = $_recommended_delivery_from[$key];
  467. $recommended_delivery_to = $_recommended_delivery_to[$key];
  468. $sql .= "INSERT INTO public.kln_destination_delivery_rule(
  469. recommended_delivery_serial_no, mode_type, priority,
  470. rule_type, ports, carrier, recommended_delivery_from, recommended_delivery_to,
  471. create_by, created_time, modify_by, update_time)
  472. VALUES ('$serial_no', '$mode_type', '$priority',
  473. '$rule_type', '$ports', '$carrier', '$recommended_delivery_from', '$recommended_delivery_to',
  474. '"._getLoginName()."', now(), '"._getLoginName()."', now());";
  475. $typeExists[$mode_type] = true;
  476. if ($rule_type == '*Default Rule') {
  477. $typeHasAllRule[$mode_type] = true;
  478. }
  479. }
  480. // 检查缺失的 rule_type = 'all'
  481. $missingTypes = [];
  482. foreach (['air', 'sea'] as $type) {
  483. if ($typeExists[$type] && !$typeHasAllRule[$type]) {
  484. $missingTypes[] = $type;
  485. }
  486. }
  487. if (!empty($missingTypes)) {
  488. $errmsg = "The Default Rule must exist.";
  489. }
  490. //检查规则不能重复
  491. $errmsg .= common::checkOverlap($seaRule,"Sea Rule");
  492. $errmsg .= common::checkOverlap($airRule,"Air Rule");
  493. }
  494. if (empty($errmsg) && !empty($sql)){
  495. common::excuteUpdateSql($sql);
  496. $data = array("msg" =>"success");
  497. } else {
  498. $data = array("msg" =>$errmsg);
  499. }
  500. common::echo_json_encode(200,$data);
  501. exit();
  502. }
  503. if ($operate == "delete"){
  504. $serial_no = common::deCode($_POST['a'], 'D');
  505. $sql = "delete from public.kln_destination_delivery_config where serial_no = '$serial_no';";
  506. $sql .= "delete from public.kln_destination_delivery_rule where recommended_delivery_serial_no = '$serial_no';";
  507. error_log($sql);
  508. common::excuteUpdateSql($sql);
  509. $data = array("msg" =>"success");
  510. common::echo_json_encode(200,$data);
  511. exit();
  512. }
  513. }
  514. /**
  515. * booking
  516. */
  517. public function destination_delivery_booking(){
  518. $operate = utils::_get('operate');
  519. $operate = strtolower($operate);
  520. if ($operate == "destination_delivery_search") {
  521. //search
  522. //栏位信息
  523. $column = column::getInstance()->getDisplayColumn('Destination_Delivery_Search');
  524. $BookingTableColumns = column::getInstance()->tableColumns('Destination_Delivery_Search',$column);
  525. $data['TrackingTableColumns'] = $BookingTableColumns;
  526. common::echo_json_encode(200,$data);
  527. exit();
  528. }
  529. if ($operate == "destination_delivery_shipment_search") {
  530. //search
  531. //栏位信息
  532. $column = column::getInstance()->getDisplayColumn('destination_delivery_shipment_search');
  533. $BookingTableColumns = column::getInstance()->tableColumns('destination_delivery_shipment_search',$column);
  534. $data['TrackingTableColumns'] = $BookingTableColumns;
  535. common::echo_json_encode(200,$data);
  536. exit();
  537. }
  538. /**
  539. * select shipment,
  540. * Pending Approval Approve Reject Cancel Modify Submit
  541. */
  542. if ($operate == "search"){
  543. $cp = common::check_input($_POST ['cp']); //current_page
  544. $ps = common::check_input($_POST ['ps']); //ps
  545. if (empty($ps))
  546. $ps = 100;
  547. if (empty($cp))
  548. $cp = 1;
  549. $sqlWhere = ' where ' . common::searchExtendHand_KLN("ocean", $_SESSION["ONLINE_USER"]);
  550. //兜底规则
  551. $sqlWhere .= " and eta >= now() - INTERVAL '6 months' and eta <= now() + INTERVAL '6 months'";
  552. //代表employee
  553. $sqlDeliveryWhere = " 1=1";
  554. if(_isApexLogin()){
  555. //$sqlDeliveryWhere .= " and '".strtolower("CATHY.LEE@APEXSHIPPING.COM")."' = ANY(regexp_split_to_array(LOWER(kd.kln_pic), ','))";
  556. //$sqlDeliveryWhere .= " and '".strtolower(_getLoginEmployeeEamil())."' = ANY(regexp_split_to_array(LOWER(kd.kln_pic), ','))";
  557. }
  558. //条件带入
  559. $text_search = $_REQUEST['text_search'];
  560. if (!empty($text_search)){
  561. $sqlDeliveryWhere .= " and (lower(booking_no) like '%".strtolower($text_search)."%'
  562. or lower(h_bol) like '%".strtolower($text_search)."%'
  563. or lower(m_bol) like '%".strtolower($text_search)."%'
  564. or lower(ctnr) like '%".strtolower($text_search)."%'
  565. or lower(consignee) like '%".strtolower($text_search)."%')";
  566. }
  567. if (isset($_REQUEST['delivery_date_start']) && !empty($_REQUEST['delivery_date_start']))
  568. $sqlDeliveryWhere .= " and kd.delivery_date >= '" . common::usDate2sqlDate($_REQUEST['delivery_date_start']) . " 00:00:00'";
  569. if (isset($_REQUEST['delivery_date_end']) && !empty($_REQUEST['delivery_date_end']))
  570. $sqlDeliveryWhere .= " and kd.delivery_date <= '" . common::usDate2sqlDate($_REQUEST['delivery_date_end']) . " 23:59:59'";
  571. if(!empty($_POST['delivery_mode'])){
  572. $sqlDeliveryWhere .= " and kd.delivery_mode ='". common::check_input($_REQUEST['delivery_mode'])."'";
  573. }
  574. if (isset($_REQUEST['created_time_start']) && !empty($_REQUEST['created_time_start']))
  575. $sqlDeliveryWhere .= " and kd.created_time >= '" . common::usDate2sqlDate($_REQUEST['created_time_start']) . " 00:00:00'";
  576. if (isset($_REQUEST['created_time_end']) && !empty($_REQUEST['created_time_end']))
  577. $sqlDeliveryWhere .= " and kd.created_time <= '" . common::usDate2sqlDate($_REQUEST['created_time_end']) . " 23:59:59'";
  578. //移除filterTag
  579. //$sqlWhere_befrom_filterTag = $sqlWhere;
  580. $filterTag_param = "";
  581. if (!empty($_POST["filterTag"])) {
  582. if (utils::count($_POST['filterTag']) == 1){
  583. $filterTag = $_POST['filterTag'][0];
  584. }else{
  585. $filterTag = utils::implode(",", $_POST['filterTag']);
  586. }
  587. $filterTag_param = "1<>1";
  588. if(strtolower($filterTag) == "all"){
  589. $filterTag_param = "1=1";
  590. }
  591. if (stripos($filterTag, "Pending Approval") !== FALSE) {
  592. $filterTag_param .= " or (kd.status = 'Pending Approval')";
  593. }
  594. if (stripos($filterTag, "Approve") !== FALSE) {
  595. $filterTag_param .= " or (kd.status = 'Approve')";
  596. }
  597. if (stripos($filterTag, "Reject") !== FALSE) {
  598. $filterTag_param .= " or (kd.status = 'Reject')";
  599. }
  600. if (stripos($filterTag, "Cancel") !== FALSE) {
  601. $filterTag_param .= " or (kd.status = 'Cancel')";
  602. }
  603. if(strtolower($filterTag) <> "all" && !empty($filterTag)){
  604. $filterTag_param = " ($filterTag_param)";
  605. }
  606. }
  607. if(empty($filterTag_param)){
  608. $filterTag_param = "1=1";
  609. }
  610. $tag_and_mode_param = $filterTag_param;
  611. $rc = $_POST ['rc'];
  612. if ($rc == - 1 || true) {
  613. $sql = "select count(1) as rc,
  614. sum(case when $tag_and_mode_param then 1 else 0 end) as seach_rc,
  615. sum(case when kd.status ='Pending Approval' then 1 else 0 end) as pending_approval_rc,
  616. sum(case when kd.status ='Approve' then 1 else 0 end) as approved_rc,
  617. sum(case when kd.status ='Reject' then 1 else 0 end) as rejected_rc,
  618. sum(case when kd.status ='Cancel' then 1 else 0 end) as cancelled_rc
  619. from public.kln_destination_delivery kd
  620. where ".$sqlDeliveryWhere."
  621. and exists(select 1 from public.kln_ocean oo ". $sqlWhere." and oo.serial_no = any(kd.h_serial_no) limit 1)";
  622. error_log("kln_destination_delivery_count:".$sql);
  623. $statusRc = common::excuteObjectSql($sql);
  624. $rc = $statusRc['rc'];
  625. $search_rc = $statusRc['seach_rc'];
  626. $pending_approval_rc = $statusRc['pending_approval_rc'];
  627. $approved_rc = $statusRc['approved_rc'];
  628. $rejected_rc = $statusRc['rejected_rc'];
  629. $cancelled_rc = $statusRc['cancelled_rc'];
  630. }
  631. $tp = ceil($rc / $ps);
  632. if ($rc > 0) {
  633. $sql = "select *,to_char((recommended_delivery_window_date_from)::date, 'YYYY-MM-DD')
  634. || ';' ||
  635. to_char((recommended_delivery_window_date_to)::date, 'YYYY-MM-DD') AS date_range
  636. from public.kln_destination_delivery kd
  637. where ".$tag_and_mode_param."
  638. and ".$sqlDeliveryWhere."
  639. and exists(select 1 from public.kln_ocean oo ". $sqlWhere." and oo.serial_no = any(h_serial_no) limit 1)";
  640. $sql .= " order by id desc limit " . $ps . " offset " . ($cp - 1) * $ps;
  641. error_log("kln_destination_delivery_search:".$sql);
  642. $rs = common::excuteListSql($sql);
  643. foreach($rs as $key => $val){
  644. $rs[$key]["_serial_no"] = common::deCode($val['serial_no'], 'E');
  645. $rs[$key]["status"] = common::deliveryStatusConvert($val['status']);
  646. $rs[$key]["h_bol"] = json_decode($val['h_bol_multiple_link']);
  647. $rs[$key]["kln_pic"] = empty($val['kln_pic']) ? array() : explode(";", $val['kln_pic']);
  648. }
  649. $arrTmp = array('searchData' => $rs,
  650. 'is_employee' => _isApexLogin(),
  651. 'All' =>$rc,
  652. 'pending_approval_rc' =>$pending_approval_rc,
  653. 'approved_rc' =>$approved_rc,
  654. 'rejected_rc' =>$rejected_rc,
  655. 'cancelled_rc' =>$cancelled_rc,
  656. 'rc' => $search_rc,
  657. 'ps' => $ps,
  658. 'cp' => $cp,
  659. 'tp' => $tp);
  660. common::echo_json_encode(200,$arrTmp);
  661. exit();
  662. }else{
  663. $arrTmp = array('searchData' => array(),
  664. 'is_employee' => _isApexLogin(),
  665. 'All' =>$rc,
  666. 'pending_approval_rc' =>$pending_approval_rc,
  667. 'approved_rc' =>$approved_rc,
  668. 'rejected_rc' =>$rejected_rc,
  669. 'cancelled_rc' =>$cancelled_rc,
  670. 'rc' => $search_rc,
  671. 'ps' => $ps,
  672. 'cp' => $cp,
  673. 'tp' => $tp);
  674. common::echo_json_encode(200,$arrTmp);
  675. exit();
  676. }
  677. }
  678. if ($operate == "search_shipment"){
  679. $data = $this->search_shipment();
  680. if(!empty($data['msg'])){
  681. $arrTmp = array("msg" =>$data['msg']);
  682. }else{
  683. $arrTmp = array("msg" =>"success","data"=>$data['data']);
  684. }
  685. common::echo_json_encode(200, $arrTmp);
  686. exit();
  687. }
  688. if ($operate == "add"){
  689. $serial_no = common::deCode($_POST['serial_no'], 'D');
  690. //前端按钮 后台权限拦截
  691. if(!empty($serial_no)){
  692. common::checkedActionLegal($serial_no,$operate);
  693. }else{
  694. if(_isApexLogin()){
  695. $data = array("msg" =>"Employees cannot create booking");
  696. common::echo_json_encode(200,$data);
  697. exit();
  698. }
  699. }
  700. $booking_data = array();
  701. if(!empty($serial_no)){
  702. //to_char(delivery_date, 'MM/DD/YYYY') AS _delivery_date,
  703. $sql = "select *,
  704. to_char(delivery_date, 'HH24:MI') AS _delivery_time
  705. from public.kln_destination_delivery where serial_no = '$serial_no'";
  706. $booking_data = common::excuteObjectSql($sql);
  707. $booking_data["delivery_time"] = $booking_data["_delivery_time"];
  708. $booking_data["delivery_address_detail"] = json_decode($booking_data["delivery_address_detail"],true);
  709. $shipments = $this->search_shipment_with_booking($booking_data['serial_no'],$booking_data['h_serial_no'],$booking_data['ctnr']);
  710. } else {
  711. $shipments = $this->search_shipment();
  712. }
  713. if(!empty($shipments['msg'])){
  714. $data = array("msg" =>$shipments['msg']);
  715. common::echo_json_encode(200,$data);
  716. exit();
  717. }
  718. $booking_data['tableData'] = $shipments['data'];
  719. $data = array("msg" =>"success","data"=>$booking_data);
  720. common::echo_json_encode(200,$data);
  721. exit();
  722. }
  723. if ($operate == "save"){
  724. $serial_no = common::deCode($_POST['serial_no'], 'D');
  725. $booking_no = $_POST['booking_no'];
  726. $manifest_type = $_POST['manifest_type'];
  727. $h_bol = $_POST['h_bol'];
  728. $h_serial_no = $_POST['serial_no'];
  729. $order_from = $_POST['order_from'];
  730. $m_bol = $_POST['m_bol'];
  731. $ctnr = $_POST['ctnr'];
  732. $kln_pic = $_POST['dc_kln_pic'];
  733. $consignee = $_POST['consignee'];
  734. $consignee_id = $_POST['consignee_id'];
  735. $dc_country = $_POST['dc_country'];
  736. $recommended_delivery_window_date_from = $_POST['recommended_delivery_from_date'];
  737. $recommended_delivery_window_date_to = $_POST['recommended_delivery_to_date'];
  738. $recommended_delivery_from = $_POST['recommended_delivery_from'];
  739. $recommended_delivery_to = $_POST['recommended_delivery_to'];
  740. $modify_reason = common::check_input($_POST['modify_reason']);
  741. $delivery_date = $_POST['delivery_date'];
  742. $delivery_time = $_POST['delivery_time'];
  743. $delivery_mode = common::check_input($_POST['delivery_mode']);
  744. //这status 编辑只有两种情况,新加,和在拒绝后 用户重新编辑 状态都是Pending Approval
  745. $status = "Pending Approval";
  746. $is_new = false;
  747. if(empty($serial_no)){
  748. $is_new = true;
  749. }
  750. $delivery_address = common::check_input($_POST['delivery_address']);
  751. $special_requirements = common::check_input($_POST['special_requirements']);
  752. $delivery_reference = common::check_input($_POST['delivery_reference']);
  753. //检查不能重复添加booking 这里空运没问题,但是会遇到相同hbol 不同的柜子情况,本质上来说就是一条
  754. //$sqlWhere = ' where ' . common::searchExtendHand_KLN("ocean", $_SESSION["ONLINE_USER"]);
  755. //兜底规则
  756. //$sqlWhere .= " and eta >= now() - INTERVAL '6 months' and eta <= now() + INTERVAL '6 months'";
  757. //and exists(select 1 from public.kln_ocean oo ". $sqlWhere." and oo.serial_no = any(kde.h_serial_no) limit 1)
  758. $ckeckedSql = "with save_table as (
  759. select regexp_split_to_table('".utils::implode(',',$h_serial_no)."', ',') as serial_no
  760. ),
  761. save_table_ctnr as (
  762. select regexp_split_to_table('".utils::implode(',',$ctnr)."', ',') as ctnr
  763. )
  764. select h_bol,ctnr from public.kln_destination_delivery kde
  765. where status not in ('Cancel','Reject')
  766. and exists(select 1 from save_table where save_table.serial_no = any(kde.h_serial_no))
  767. and (exists(select 1 from save_table_ctnr where save_table_ctnr.ctnr = ANY(regexp_split_to_array(kde.ctnr, ','))
  768. or COALESCE(kde.ctnr,'') = ''))";
  769. //代表编辑
  770. if(!empty($serial_no)){
  771. $ckeckedSql .=" and kde.serial_no <> '$serial_no'";
  772. }
  773. $checkeData = common::excuteObjectSql($ckeckedSql);
  774. if(!empty($checkeData['h_bol'])){
  775. $data = array("msg" =>"The HBOL NO: ".$checkeData['h_bol'] .", Destination Delivery cannot be created repeatedly.");
  776. common::echo_json_encode(200,$data);
  777. exit();
  778. }
  779. $sql = "";
  780. //代表修改
  781. if(!empty($serial_no)){
  782. $updateSqlSet = " modify_by = '"._getLoginName()."',update_time = now()";
  783. if (!empty($status)) {
  784. $updateSqlSet.= ", status = '$status' ";
  785. }
  786. if (!empty($delivery_address)) {
  787. $delivery_address_detail = common::check_input(json_encode(common::returnDAddress(),JSON_UNESCAPED_UNICODE));
  788. $updateSqlSet.= ", delivery_address = '$delivery_address' ";
  789. $updateSqlSet.= ", delivery_address_detail = '$delivery_address_detail' ";
  790. }
  791. if (!empty($special_requirements)) {
  792. $updateSqlSet.= ", special_requirements = '$special_requirements' ";
  793. }
  794. if (!empty($delivery_reference)) {
  795. $updateSqlSet.= ", delivery_reference = '$delivery_reference' ";
  796. }
  797. if (!empty($modify_reason)) {
  798. $updateSqlSet.= ", modify_reason = '$modify_reason' ";
  799. }
  800. if (!empty($delivery_date)) {
  801. $delivery_date = empty($_POST['delivery_date']) ? "null": "'".common::usDate2sqlDate($_POST['delivery_date'])." ".$delivery_time."'";
  802. $updateSqlSet.= ", delivery_date = $delivery_date";
  803. }
  804. //修改记录临时表
  805. common::saveDAddressTempTable($serial_no,$consignee_id);
  806. //代表update
  807. $sql .= "update public.kln_destination_delivery set ".$updateSqlSet."
  808. where serial_no = '$serial_no';";
  809. //记录log
  810. $sql .="INSERT INTO public.kln_destination_delivery_operation_log(
  811. serial_no, action,notes, create_by, created_time, created_zone)
  812. VALUES ('$serial_no', 'Submit','".$modify_reason."', '"._getLoginName()."', now(), ''); ";
  813. } else {
  814. $saveData = $this->groupShipments($booking_no,$manifest_type,$h_bol,$h_serial_no,$order_from,$m_bol,$ctnr,$kln_pic,$consignee,$consignee_id,
  815. $recommended_delivery_window_date_from, $recommended_delivery_window_date_to,
  816. $recommended_delivery_from,$recommended_delivery_to,$dc_country);
  817. foreach($saveData as $sData){
  818. $serial_no = common::uuid();
  819. // 使用 PostgreSQL 的 ARRAY 语法
  820. $tags_sql = "ARRAY['" . implode("','", array_map('pg_escape_string', $sData['h_serial_no'])) . "']";
  821. // 使用 PostgreSQL 的 ARRAY 语法
  822. $country_sql = "ARRAY['" . implode("','", array_map('pg_escape_string', $sData['dc_country'])) . "']";
  823. $recommended_delivery_window_date_from = "";
  824. if(empty($sData['recommended_delivery_window_date_from'])){
  825. $recommended_delivery_window_date_from = "null";
  826. } else {
  827. $recommended_delivery_window_date_from = "'".$sData['recommended_delivery_window_date_from']."'";
  828. }
  829. $recommended_delivery_window_date_to = "";
  830. if(empty($sData['recommended_delivery_window_date_to'])){
  831. $recommended_delivery_window_date_to = "null";
  832. } else {
  833. $recommended_delivery_window_date_to = "'".$sData['recommended_delivery_window_date_to']."'";
  834. }
  835. $delivery_date = empty($_POST['delivery_date']) ? "null": "'".common::usDate2sqlDate($_POST['delivery_date'])." ".$delivery_time."'";
  836. //修改记录临时表,有值代表选择的add
  837. $_sync_key_add = common::saveDAddressTempTable($serial_no,$sData['consignee_id']);
  838. $delivery_address_detail = common::check_input(json_encode(common::returnDAddress($_sync_key_add),JSON_UNESCAPED_UNICODE));
  839. $sql .= "INSERT INTO public.kln_destination_delivery(
  840. serial_no, h_serial_no,address_country,
  841. booking_no, h_bol,h_bol_multiple_link,
  842. m_bol, ctnr,
  843. consignee, delivery_date, delivery_mode, status, delivery_address,delivery_address_detail, special_requirements,delivery_reference,
  844. recommended_delivery_window_date_from, recommended_delivery_window_date_to, d_address_change_log,
  845. recommended_delivery_from, recommended_delivery_to,kln_pic,
  846. create_by, created_time, modify_by, update_time)
  847. VALUES ('$serial_no', ".$tags_sql.",".$country_sql.",
  848. '".$sData['booking_no']."', '".utils::implode(',',$sData['h_bol'])."','".common::check_input(json_encode($sData['h_bol_multiple_link']))."',
  849. '".utils::implode(',',$sData['m_bol'])."', '".utils::implode(',',$sData['ctnr'])."',
  850. '".$sData['consignee']."', $delivery_date,'$delivery_mode','$status', '$delivery_address','$delivery_address_detail', '$special_requirements','$delivery_reference',
  851. $recommended_delivery_window_date_from, $recommended_delivery_window_date_to,'',
  852. '".$sData['recommended_delivery_from']."', '".$sData['recommended_delivery_to']."','".$sData['kln_pic']."',
  853. '"._getLoginName()."', now(), '"._getLoginName()."', now());";
  854. //记录log
  855. $sql .="INSERT INTO public.kln_destination_delivery_operation_log(
  856. serial_no, action,notes, create_by, created_time, created_zone)
  857. VALUES ('$serial_no', 'Submit','', '"._getLoginName()."', now(), ''); ";
  858. }
  859. }
  860. if(!empty($sql)){
  861. $rs = common::excuteUpdateSql($sql);
  862. if ($rs === FALSE){
  863. $data = array("msg" =>"error");
  864. common::echo_json_encode(200,$data);
  865. exit();
  866. }
  867. }
  868. if(!$is_new){
  869. //状态变更时,发送邮件提醒
  870. $status = "Modify";
  871. $data = common::excuteObjectSql("select *, TO_CHAR(delivery_date, 'Mon-DD-YYYY') as _delivery_date,
  872. TO_CHAR(created_time, 'Mon-DD-YYYY') as _created_time,
  873. TO_CHAR(update_time, 'Mon-DD-YYYY') as _update_time
  874. from public.kln_destination_delivery where serial_no = '$serial_no'");
  875. $shipmentsData = $this->search_shipment_with_booking($data['serial_no'],$data['h_serial_no'],$data['ctnr']);
  876. $email_sql = common::sendDestinationDeliveryReminder($data,$shipmentsData,$status);
  877. if(!empty($email_sql)){
  878. common::excuteUpdateSql($email_sql);
  879. }
  880. } else {
  881. $status = "Submit";
  882. $data = common::excuteObjectSql("select *, TO_CHAR(delivery_date, 'Mon-DD-YYYY') as _delivery_date,
  883. TO_CHAR(created_time, 'Mon-DD-YYYY') as _created_time,
  884. TO_CHAR(update_time, 'Mon-DD-YYYY') as _update_time
  885. from public.kln_destination_delivery where serial_no = '$serial_no'");
  886. $shipmentsData = $this->search_shipment_with_booking($data['serial_no'],$data['h_serial_no'],$data['ctnr']);
  887. $email_sql = common::sendDestinationDeliveryReminder($data,$shipmentsData,$status);
  888. if(!empty($email_sql)){
  889. common::excuteUpdateSql($email_sql);
  890. }
  891. }
  892. $data = array("msg" =>"success");
  893. common::echo_json_encode(200,$data);
  894. exit();
  895. }
  896. /**
  897. * 审核 Approve or Reject Cancel Pending Approval
  898. */
  899. if ($operate == "review"){
  900. $serial_no = common::deCode($_POST['serial_no'], 'D');
  901. $status = common::check_input($_POST['status']);
  902. $notes = common::check_input($_POST['notes']);
  903. $action_user = _getLoginName();
  904. //前端按钮 后台权限拦截
  905. common::checkedActionLegal($serial_no,$operate);
  906. global $db;
  907. $db->StartTrans();
  908. try {
  909. $sql = "";
  910. //审核通过时,才取下放当时应用修改的地址
  911. if ($status == "Approve") {
  912. $delivery_booking = common::excuteObjectSql("select *,array_to_json(address_country) as address_country,
  913. array_to_json(h_serial_no) as h_serial_no_json,
  914. TO_CHAR( delivery_date, 'HH24:MI') AS _delivery_time,
  915. delivery_date::date AS _delivery_date
  916. from public.kln_destination_delivery where serial_no = '$serial_no'");
  917. $onine_address = common::excuteListSql("select * from public.contacts_address_online where delivery_serial_no = '$serial_no'");
  918. $sql .= "delete from public.contacts_address_online where delivery_serial_no = '$serial_no';";
  919. $sql .=common::returnDAddressRecord($delivery_booking["address_country"],$onine_address);
  920. //Booking自動同步到Ksmart WO 的逻辑 保存在do_header和do_details表里
  921. common::saveWorkOrder($delivery_booking);
  922. }
  923. if ($status == "Reject" || $status == "Cancel") {
  924. //这种情况,清除当前用户对这一票的修改和添加的信息
  925. $sql .= "delete from public.contacts_address_online where delivery_serial_no = '$serial_no';";
  926. }
  927. $sql .= "update public.kln_destination_delivery set status = '$status', modify_by = '"._getLoginName()."',update_time = now() where serial_no = '$serial_no';";
  928. $sql .= "INSERT INTO public.kln_destination_delivery_operation_log(
  929. serial_no, action,notes, create_by, created_time, created_zone)
  930. VALUES ('$serial_no', '$status','$notes', '$action_user', now(), ''); ";
  931. $db->Execute($sql) or ((!$db->ErrorMsg()) or error_log(common::dbLog($db, $sql), 0));
  932. $rs = $db->CompleteTrans();
  933. } catch (Exception $e) {
  934. $db->RollbackTrans();
  935. }
  936. if ($rs === FALSE){
  937. $data = array("msg" => "Update Error");
  938. common::echo_json_encode(200,$data);
  939. } else{
  940. //状态变更时,发送邮件提醒
  941. $data = common::excuteObjectSql("select *,
  942. TO_CHAR(delivery_date, 'Mon-DD-YYYY') as _delivery_date,
  943. TO_CHAR(created_time, 'Mon-DD-YYYY') as _created_time,
  944. TO_CHAR(update_time, 'Mon-DD-YYYY') as _update_time
  945. from public.kln_destination_delivery where serial_no = '$serial_no'");
  946. $shipmentsData = $this->search_shipment_with_booking($data['serial_no'],$data['h_serial_no'],$data['ctnr']);
  947. $email_sql = common::sendDestinationDeliveryReminder($data,$shipmentsData,$status);
  948. if(!empty($email_sql)){
  949. common::excuteUpdateSql($email_sql);
  950. }
  951. $data = array("msg" =>"success");
  952. common::echo_json_encode(200,$data);
  953. }
  954. }
  955. /**
  956. * 邮件留言初始
  957. */
  958. if ($operate == "email_message_init"){
  959. try {
  960. $email_uuid = common::deCode($_POST['serial_no'], 'D');
  961. $emailRecords = $this->getCommunicationNew($email_uuid);
  962. common::echo_json_encode(200,array("msg" => "Sent Successfully", "emailRecords" => $emailRecords));
  963. exit();
  964. } catch (Exception $e) {
  965. common::echo_json_encode(500,array("msg" => "Sent Error."));
  966. exit();
  967. }
  968. }
  969. /**
  970. * 邮件留言
  971. */
  972. if ($operate == "email_message_board"){
  973. //前端按钮 后台权限拦截
  974. $email_uuid = common::deCode($_POST['serial_no'], 'D');
  975. common::checkedActionLegal($email_uuid,$operate);
  976. try {
  977. $content = $_POST["content"];
  978. $content = common::check_input($content);
  979. $content = urldecode($content);
  980. $text = $_POST["text"];
  981. $web_content = urldecode($text);
  982. $serial_no = common::uuid();
  983. $email_uuid = common::deCode($_POST['serial_no'], 'D');
  984. $add_by = _getLoginName();
  985. $refer_id = 0;
  986. $from_email = "US.KApex.Online@kerryapex.com";
  987. $to_email = $_POST["kln_pic"];
  988. $cc_email = "";
  989. $communication_cc = $_POST["communication_cc"];
  990. $communication_cc = trim($communication_cc);
  991. if (!empty($communication_cc)) {
  992. $communication_cc = common::check_input($communication_cc);
  993. $cc_email = $communication_cc;
  994. }
  995. $user_from = _getLoginName();
  996. $h_bol_str = array();
  997. foreach($_POST["h_bol"] as $obj){
  998. $h_bol_str[] = $obj['key'];
  999. }
  1000. //邮件发送
  1001. $title = "Destination Delivery from " . _getLoginName() . ", Shipment No: " . utils::implode(',',$h_bol_str);
  1002. $emailContent = $content;
  1003. common::excuteUpdateSql("insert into public.email_record (type,title,from_email,to_email,cc_email,content,insert_date)values('Delivery_Comm','$title','$from_email','$to_email','$cc_email','$emailContent',now());");
  1004. $rs = common::excuteUpdateSql("INSERT INTO public.online_ocean_communication(serial_no, email_uuid, content,web_content,user_from, user_to, user_cc, refer_id, add_by, add_time, cc_email)
  1005. VALUES ('$serial_no', '$email_uuid', '$emailContent','$web_content', '$user_from', '$to_email', '$cc_email', $refer_id, '$add_by', now(), '$communication_cc');");
  1006. $emailRecords = $this->getCommunicationNew($email_uuid);
  1007. common::echo_json_encode(200,array("msg" => "Sent Successfully", "emailRecords" => $emailRecords));
  1008. exit();
  1009. } catch (Exception $e) {
  1010. common::echo_json_encode(500,array("msg" => "Sent Error."));
  1011. exit();
  1012. }
  1013. }
  1014. /**
  1015. * view detail and log
  1016. */
  1017. if ($operate == "view_detail"){
  1018. $serial_no = common::deCode($_POST['serial_no'], 'D');
  1019. //前端按钮 后台权限拦截
  1020. common::checkedActionLegal($serial_no,$operate);
  1021. $data = common::excuteObjectSql("select * from public.kln_destination_delivery where serial_no = '$serial_no'");
  1022. $_shipmentsData = array();
  1023. $shipmentsData = $this->search_shipment_with_booking($data['serial_no'],$data['h_serial_no'],$data['ctnr']);
  1024. foreach($shipmentsData["data"] as $shipment){
  1025. $_shipmentsData[] = array("HBOL No." => $shipment['h_bol'],"Container No." => $shipment['ctnr'],
  1026. "Service Type" => $shipment['service'],"ETA" => $shipment['eta'],
  1027. "Recommended Delivery Date" => $shipment['date_range']);
  1028. }
  1029. $_operation_log = array();
  1030. $operation_log = common::excuteListSql("select * from public.kln_destination_delivery_operation_log where serial_no = '$serial_no' order by id desc");
  1031. foreach($operation_log as $log){
  1032. $action = $log['action'] == "Pending Approval" ? "Submit" : $log['action'];
  1033. $_operation_log[] = array("time" => $log['created_time'],"timezone" => $log['created_zone'],
  1034. "label" => $action,"createdBy" => $log['create_by'],
  1035. "tips" => $log['notes']);
  1036. }
  1037. $retData = $data;
  1038. $retData["status"] = common::deliveryStatusConvert($retData["status"]);
  1039. $retData['shipmentsData'] = $_shipmentsData;
  1040. $retData['operation_log'] = $_operation_log;
  1041. $data = array("msg" =>"success","data"=>$retData);
  1042. common::echo_json_encode(200,$data);
  1043. exit();
  1044. }
  1045. /**
  1046. * Delivery date
  1047. */
  1048. if ($operate == "delivery_date_load"){
  1049. $sqlWhere = ' where ' . common::searchExtendHand_KLN("ocean", $_SESSION["ONLINE_USER"]);
  1050. //兜底规则
  1051. $sqlWhere .= " and eta >= now() - INTERVAL '6 months' and eta <= now() + INTERVAL '6 months'";
  1052. $sqlDeliveryWhere = " 1=1";
  1053. //$sqlWhere_befrom_filterTag = $sqlWhere;
  1054. $sql = "select delivery_date::date as delivery_date,
  1055. sum(case when status ='Pending Approval' then 1 else 0 end) as pending_approval_rc,
  1056. sum(case when status ='Approve' then 1 else 0 end) as approved_rc
  1057. from public.kln_destination_delivery kd
  1058. where ".$sqlDeliveryWhere."
  1059. and exists(select 1 from public.kln_ocean oo ". $sqlWhere." and oo.serial_no = any(h_serial_no) limit 1)
  1060. group by delivery_date::date order by delivery_date::date desc";
  1061. $rs = common::excuteListSql($sql);
  1062. error_log("delivery_date_load:".$sql);
  1063. $dateArr = new stdClass();
  1064. foreach($rs as $val){
  1065. //$dateArr[] = array($val['delivery_date'] => array("pending"=>$val['pending_approval_rc'],"approved"=>$val['approved_rc']));
  1066. $dateArr->{$val['delivery_date']} = new stdClass();
  1067. $dateArr->{$val['delivery_date']}->pending = $val['pending_approval_rc'];
  1068. $dateArr->{$val['delivery_date']}->approved = $val['approved_rc'];
  1069. }
  1070. $data = array("msg" =>"success","data"=>$dateArr);
  1071. common::echo_json_encode(200,$data);
  1072. }
  1073. }
  1074. private function getCommunicationNew($serial_no) {
  1075. $list = common::excuteListSql("select to_char(add_time, 'MM/dd/yyyy hh24:MI:ss') as add_times, * from public.online_ocean_communication where email_uuid='$serial_no' and refer_id = 0 order by id");
  1076. $emialRecords =array();
  1077. foreach ($list as $k => $v) {
  1078. $msg =array();
  1079. $msg["name"] = $v["add_by"];
  1080. $msg["creatTime"] = $v["add_times"];
  1081. $msg["content"] = urldecode($v["web_content"]);
  1082. $emialRecords[] = $msg;
  1083. }
  1084. return $emialRecords;
  1085. }
  1086. function search_shipment(){
  1087. $sqlWhere_common = ' where ' . common::searchExtendHand_KLN("ocean", $_SESSION["ONLINE_USER"]);
  1088. //根據用戶的賬號權限所能看到的全部shipment數據的目的地站點,去匹配是否有開通destination delivery的服務,如果未開通,則展示此提示頁面
  1089. //兜底规则
  1090. $sqlWhere = $sqlWhere_common;
  1091. $sqlWhere .= " and eta >= now() - INTERVAL '6 months' and eta <= now() + INTERVAL '6 months'";
  1092. $checkOpenSql = "select station from public.kln_destination_delivery_config dc
  1093. where exists(select 1 from
  1094. public.kln_ocean oo ". $sqlWhere."
  1095. and oo.agent in (select regexp_split_to_table(dc.station, E',')) limit 1
  1096. )";
  1097. $config = common::excuteListSql($checkOpenSql);
  1098. if(empty($config)){
  1099. return array("msg"=>"Destination Delivery Service Not Available","data"=>"");
  1100. }
  1101. //根據用戶的賬號權限所能看到的全部shipment數據的目的地站點,去匹配是否有開通destination delivery的服務,如果有開通,但沒有符合條件的shipment,則展示此提示頁面
  1102. $sqlWhere = $sqlWhere_common;
  1103. $sqlWhere .= " and eta >= now() - INTERVAL '6 months' and eta <= now() + INTERVAL '6 months'";
  1104. $text_search = $_REQUEST['text_search'];
  1105. if (!empty($text_search)){
  1106. $sqlWhere .= " and (lower(oo.h_bol) like '%".strtolower($text_search)."%'
  1107. or lower(oo.po_no) like '%".strtolower($text_search)."%'
  1108. or lower(oo.ctnrs) like '%".strtolower($text_search)."%')";
  1109. }
  1110. //vessel name
  1111. $vessel = $_REQUEST['vessel'];
  1112. if (!empty($vessel)){
  1113. $sqlWhere .= " and lower(vessel) like '%".strtolower($vessel)."%'";
  1114. }
  1115. $consignee = $_REQUEST['consignee'];
  1116. if (!empty($consignee)){
  1117. $sqlWhere .= " and lower(consignee) like '%".strtolower($consignee)."%'";
  1118. }
  1119. $shipper = $_REQUEST['shipper'];
  1120. if (!empty($shipper)){
  1121. $sqlWhere .= " and lower(shipper) like '%".strtolower($shipper)."%'";
  1122. }
  1123. if (isset($_REQUEST['eta_start']) && !empty($_REQUEST['eta_start']))
  1124. $sqlWhere .= " and eta >= '" . common::usDate2sqlDate($_REQUEST['eta_start']) . " 00:00:00'";
  1125. if (isset($_REQUEST['eta_end']) && !empty($_REQUEST['eta_end']))
  1126. $sqlWhere .= " and eta <= '" . common::usDate2sqlDate($_REQUEST['eta_end']) . " 23:59:59'";
  1127. if (isset($_REQUEST['ata_start']) && !empty($_REQUEST['ata_start']))
  1128. $sqlWhere .= " and ata >= '" . common::usDate2sqlDate($_REQUEST['ata_start']) . " 00:00:00'";
  1129. if (isset($_REQUEST['ata_end']) && !empty($_REQUEST['ata_end']))
  1130. $sqlWhere .= " and ata <= '" . common::usDate2sqlDate($_REQUEST['ata_end']) . " 23:59:59'";
  1131. $sql = "with oo as(
  1132. select oo.serial_no,
  1133. oo.h_bol,
  1134. oo.m_bol,
  1135. oo.service,
  1136. oo.po_no,
  1137. oo.transport_mode,
  1138. oo.qty,
  1139. oo.qty_uom,
  1140. oo.piece_count,
  1141. oo.cbm,
  1142. oo.vessel,
  1143. oo.voyage,
  1144. oo.carrier,
  1145. oo.fport_of_loading_un,
  1146. oo.mport_of_discharge_un,
  1147. oo.eta,
  1148. oo.ata,
  1149. oo.etd,
  1150. oo.atd,
  1151. oo.shipper,
  1152. oo.consignee_id,
  1153. oo.consignee,
  1154. oo.booking_no,
  1155. oo.agent,
  1156. oo.order_from
  1157. from public.kln_ocean oo ". $sqlWhere ."
  1158. ),
  1159. -- 2. 预解析station字段
  1160. station_list AS (
  1161. SELECT
  1162. serial_no,
  1163. country,
  1164. kln_pic,
  1165. booking_window,
  1166. booking_window_date_start,
  1167. booking_window_date_end,
  1168. unnest(string_to_array(station, ',')) as station_code
  1169. FROM public.kln_destination_delivery_config
  1170. ),
  1171. ooc as (
  1172. select oo.*,
  1173. dc.serial_no as dc_serial_no,
  1174. dc.country as dc_country,
  1175. dc.kln_pic as dc_kln_pic
  1176. from station_list dc
  1177. Inner Join oo
  1178. on oo.agent = dc.station_code
  1179. where 1=1 and
  1180. case when dc.booking_window = 'Restrictions_ETD_ATD' and COALESCE(dc.booking_window_date_start,'')<>'' and COALESCE(dc.booking_window_date_end,'')<>''
  1181. then COALESCE(atd, etd) >= (NOW() - (dc.booking_window_date_start ||' days')::INTERVAL)::date and COALESCE(atd, etd) <= (NOW() + (dc.booking_window_date_end ||' days')::INTERVAL)::date
  1182. when dc.booking_window = 'Restrictions_ETA_ATA' and COALESCE(dc.booking_window_date_start,'')<>'' and COALESCE(dc.booking_window_date_end,'')<>''
  1183. then COALESCE(ata, eta) >= (NOW() - (dc.booking_window_date_start ||' days')::INTERVAL)::date and COALESCE(ata, eta) <= (NOW() + (dc.booking_window_date_end ||' days')::INTERVAL)::date
  1184. else 1=1 end
  1185. ),
  1186. matched_data as (
  1187. select
  1188. ooc.serial_no,
  1189. ooc.h_bol,
  1190. ooc.m_bol,
  1191. oc.ctnr,
  1192. ooc.service,
  1193. ooc.po_no,
  1194. (select reference_no from public.ocean o where o.serial_no = ooc.serial_no limit 1) as reference_no,
  1195. ooc.transport_mode,
  1196. oc.qty::text as pakages,
  1197. oc.unit as package_type ,
  1198. oc.grs_kgs::text as kgw,
  1199. oc.cbm as volume,
  1200. ooc.vessel,
  1201. ooc.voyage,
  1202. ooc.carrier,
  1203. ooc.fport_of_loading_un,
  1204. ooc.mport_of_discharge_un,
  1205. ooc.eta,
  1206. ooc.ata,
  1207. ooc.shipper,
  1208. ooc.consignee_id,
  1209. ooc.consignee,
  1210. (select customer_name from public.ocean_extend ex where ex.serial_no = ooc.serial_no limit 1) as controlling_customer,
  1211. ooc.booking_no,
  1212. (select manifest_type from public.ocean o where o.serial_no = ooc.serial_no limit 1) as manifest_type,
  1213. dc_serial_no,
  1214. dc_country,
  1215. dc_kln_pic,
  1216. ooc.agent,
  1217. ooc.order_from
  1218. from ooc
  1219. LEFT JOIN public.oc_container oc ON oc.serial_no::text = ooc.serial_no::text
  1220. where ooc.order_from = 'public' and transport_mode = 'sea'
  1221. union all
  1222. select
  1223. ooc.serial_no,
  1224. ooc.h_bol,
  1225. ooc.m_bol,
  1226. oc.ctnr,
  1227. ooc.service,
  1228. ooc.po_no,
  1229. (select reference_no from sfs.ocean o where o.serial_no = ooc.serial_no limit 1) as reference_no,
  1230. ooc.transport_mode,
  1231. oc.qty::text as pakages,
  1232. oc.unit as package_type ,
  1233. oc.grs_kgs::text as kgw,
  1234. oc.cbm as volume,
  1235. ooc.vessel,
  1236. ooc.voyage,
  1237. ooc.carrier,
  1238. ooc.fport_of_loading_un,
  1239. ooc.mport_of_discharge_un,
  1240. ooc.eta,
  1241. ooc.ata,
  1242. ooc.shipper,
  1243. ooc.consignee_id,
  1244. ooc.consignee,
  1245. (select customer_name from ocean_extend ex where ex.serial_no = ooc.serial_no limit 1) as controlling_customer,
  1246. ooc.booking_no,
  1247. (select manifest_type from sfs.ocean o where o.serial_no = ooc.serial_no limit 1) as manifest_type,
  1248. dc_serial_no,
  1249. dc_country,
  1250. dc_kln_pic,
  1251. ooc.agent,
  1252. ooc.order_from
  1253. from ooc
  1254. LEFT JOIN sfs.oc_container oc ON oc.serial_no::text = ooc.serial_no::text
  1255. where ooc.order_from = 'sfs' and transport_mode = 'sea'
  1256. union all
  1257. select
  1258. ooc.serial_no,
  1259. ooc.h_bol,
  1260. ooc.m_bol,
  1261. '' as ctnr,
  1262. ooc.service,
  1263. ooc.po_no,
  1264. '' as reference_no,
  1265. ooc.transport_mode,
  1266. ooc.qty as pakages,
  1267. ooc.qty_uom as package_type ,
  1268. ooc.piece_count as kgw,
  1269. ooc.cbm as volume,
  1270. ooc.vessel,
  1271. ooc.voyage,
  1272. ooc.carrier,
  1273. ooc.fport_of_loading_un,
  1274. ooc.mport_of_discharge_un,
  1275. ooc.eta,
  1276. ooc.ata,
  1277. ooc.shipper,
  1278. ooc.consignee_id,
  1279. ooc.consignee,
  1280. '' as controlling_customer,
  1281. ooc.booking_no,
  1282. '' as manifest_type,
  1283. dc_serial_no,
  1284. dc_country,
  1285. dc_kln_pic,
  1286. ooc.agent,
  1287. ooc.order_from
  1288. from ooc
  1289. where ooc.transport_mode = 'air'
  1290. )
  1291. select md.*,
  1292. CASE
  1293. WHEN r.recommended_delivery_from IS NOT NULL AND r.recommended_delivery_to IS NOT NULL THEN
  1294. to_char((COALESCE(ata, eta) + (r.recommended_delivery_from ||' days')::INTERVAL)::date, 'YYYY.MM.DD')
  1295. || '-' ||
  1296. to_char((COALESCE(ata, eta) + (r.recommended_delivery_to ||' days')::INTERVAL)::date, 'YYYY.MM.DD')
  1297. WHEN r.recommended_delivery_from IS NULL AND r.recommended_delivery_to IS NOT NULL THEN
  1298. '-' ||
  1299. to_char((COALESCE(ata, eta) + (r.recommended_delivery_to || ' days')::INTERVAL)::date, 'YYYY.MM.DD')
  1300. WHEN r.recommended_delivery_from IS NOT NULL AND r.recommended_delivery_to IS NULL THEN
  1301. to_char((COALESCE(ata, eta) + (r.recommended_delivery_from || ' days')::INTERVAL)::date, 'YYYY.MM.DD')
  1302. || '-'
  1303. ELSE '' END
  1304. AS date_range,
  1305. r.recommended_delivery_from,
  1306. r.recommended_delivery_to,
  1307. CASE
  1308. WHEN r.recommended_delivery_from IS NOT NULL THEN
  1309. (COALESCE(ata, eta) + (r.recommended_delivery_from ||' days')::INTERVAL)::date
  1310. ELSE null END
  1311. AS recommended_delivery_from_date,
  1312. CASE
  1313. WHEN r.recommended_delivery_to IS NOT NULL THEN
  1314. (COALESCE(ata, eta) + (r.recommended_delivery_to ||' days')::INTERVAL)::date
  1315. ELSE null END
  1316. AS recommended_delivery_to_date
  1317. from matched_data md
  1318. LEFT JOIN LATERAL (
  1319. SELECT
  1320. r.*
  1321. FROM public.kln_destination_delivery_rule r
  1322. WHERE md.transport_mode = r.mode_type
  1323. and r.recommended_delivery_serial_no = md.dc_serial_no
  1324. AND ((md.transport_mode = 'sea' AND (
  1325. (r.ports ilike '%'|| md.mport_of_discharge_un ||'%' AND r.carrier ilike '%'|| md.carrier ||'%')
  1326. OR (r.ports ilike '%'|| md.mport_of_discharge_un ||'%' AND r.carrier = 'ALL')
  1327. OR (r.ports = 'ALL' AND r.carrier ilike '%'|| md.carrier ||'%')
  1328. OR (r.ports = 'ALL' AND r.carrier = 'ALL'))
  1329. )
  1330. OR (md.transport_mode = 'air' AND (
  1331. r.ports ilike '%'|| md.mport_of_discharge_un ||'%'
  1332. OR r.ports = 'ALL')
  1333. )
  1334. )
  1335. ORDER BY priority asc
  1336. LIMIT 1
  1337. ) r ON true
  1338. order by md.eta desc";
  1339. $rs = common::excuteListSql($sql);
  1340. error_log($sql);
  1341. if(empty($rs)){
  1342. return array("msg"=>"No Eligible Shipments for Booking","data"=>"");
  1343. }
  1344. return array("msg"=>"","data"=>$rs);
  1345. }
  1346. /**
  1347. * 不依赖配置的规则查询,如果规则已经移除或者修改不在查询范围内,開通期間創建的booking數據正常保留和展示
  1348. */
  1349. function search_shipment_with_booking($serial_no,$h_serial_no,$ctnr){
  1350. $sqlCtnr = "";
  1351. if(!empty($ctnr)){
  1352. $sqlCtnr = "and oc.ctnr in (select regexp_split_to_table('".$ctnr."', ','))";
  1353. }
  1354. $sqlWhere = "where oo.serial_no = ANY('".$h_serial_no."'::TEXT[])";
  1355. $sql = "with ooc as(
  1356. select * from public.kln_ocean oo ". $sqlWhere ."
  1357. ),
  1358. matched_data as (
  1359. select
  1360. ooc.serial_no,
  1361. ooc.h_bol,
  1362. ooc.m_bol,
  1363. oc.ctnr,
  1364. ooc.service,
  1365. ooc.po_no,
  1366. (select reference_no from public.ocean o where o.serial_no = ooc.serial_no limit 1) as reference_no,
  1367. ooc.transport_mode,
  1368. oc.qty::text as pakages,
  1369. oc.unit as package_type ,
  1370. oc.grs_kgs::text as kgw,
  1371. oc.cbm as volume,
  1372. ooc.vessel,
  1373. ooc.voyage,
  1374. ooc.carrier,
  1375. ooc.fport_of_loading_un,
  1376. ooc.mport_of_discharge_un,
  1377. ooc.eta,
  1378. ooc.ata,
  1379. ooc.shipper,
  1380. ooc.consignee_id,
  1381. ooc.consignee,
  1382. (select customer_name from public.ocean_extend ex where ex.serial_no = ooc.serial_no limit 1) as controlling_customer,
  1383. ooc.booking_no,
  1384. (select manifest_type from public.ocean o where o.serial_no = ooc.serial_no limit 1) as manifest_type,
  1385. ooc.agent,
  1386. ooc.order_from
  1387. from ooc
  1388. LEFT JOIN public.oc_container oc ON oc.serial_no::text = ooc.serial_no::text
  1389. where ooc.order_from = 'public' and transport_mode = 'sea' ".$sqlCtnr."
  1390. union all
  1391. select
  1392. ooc.serial_no,
  1393. ooc.h_bol,
  1394. ooc.m_bol,
  1395. oc.ctnr,
  1396. ooc.service,
  1397. ooc.po_no,
  1398. (select reference_no from sfs.ocean o where o.serial_no = ooc.serial_no limit 1) as reference_no,
  1399. ooc.transport_mode,
  1400. oc.qty::text as pakages,
  1401. oc.unit as package_type ,
  1402. oc.grs_kgs::text as kgw,
  1403. oc.cbm as volume,
  1404. ooc.vessel,
  1405. ooc.voyage,
  1406. ooc.carrier,
  1407. ooc.fport_of_loading_un,
  1408. ooc.mport_of_discharge_un,
  1409. ooc.eta,
  1410. ooc.ata,
  1411. ooc.shipper,
  1412. ooc.consignee_id,
  1413. ooc.consignee,
  1414. (select customer_name from ocean_extend ex where ex.serial_no = ooc.serial_no limit 1) as controlling_customer,
  1415. ooc.booking_no,
  1416. (select manifest_type from sfs.ocean o where o.serial_no = ooc.serial_no limit 1) as manifest_type,
  1417. ooc.agent,
  1418. ooc.order_from
  1419. from ooc
  1420. LEFT JOIN sfs.oc_container oc ON oc.serial_no::text = ooc.serial_no::text
  1421. where ooc.order_from = 'sfs' and transport_mode = 'sea' ".$sqlCtnr."
  1422. union all
  1423. select
  1424. ooc.serial_no,
  1425. ooc.h_bol,
  1426. ooc.m_bol,
  1427. '' as ctnr,
  1428. ooc.service,
  1429. ooc.po_no,
  1430. '' as reference_no,
  1431. ooc.transport_mode,
  1432. ooc.qty as pakages,
  1433. ooc.qty_uom as package_type ,
  1434. ooc.piece_count as kgw,
  1435. ooc.cbm as volume,
  1436. ooc.vessel,
  1437. ooc.voyage,
  1438. ooc.carrier,
  1439. ooc.fport_of_loading_un,
  1440. ooc.mport_of_discharge_un,
  1441. ooc.eta,
  1442. ooc.ata,
  1443. ooc.shipper,
  1444. ooc.consignee_id,
  1445. ooc.consignee,
  1446. '' as controlling_customer,
  1447. ooc.booking_no,
  1448. '' as manifest_type,
  1449. ooc.agent,
  1450. ooc.order_from
  1451. from ooc
  1452. where ooc.transport_mode = 'air'
  1453. )
  1454. select md.*,
  1455. CASE
  1456. WHEN kd.recommended_delivery_window_date_from IS NOT NULL AND kd.recommended_delivery_window_date_to IS NOT NULL THEN
  1457. to_char((recommended_delivery_window_date_from)::date, 'YYYY-MM-DD')
  1458. || ';' ||
  1459. to_char((recommended_delivery_window_date_to)::date, 'YYYY-MM-DD')
  1460. WHEN kd.recommended_delivery_window_date_from IS NULL AND kd.recommended_delivery_window_date_to IS NOT NULL THEN
  1461. ';' ||
  1462. to_char((recommended_delivery_window_date_to)::date, 'YYYY-MM-DD')
  1463. WHEN kd.recommended_delivery_window_date_from IS NOT NULL AND kd.recommended_delivery_window_date_to IS NULL THEN
  1464. to_char((recommended_delivery_window_date_from)::date, 'YYYY-MM-DD')
  1465. || ';'
  1466. ELSE ''
  1467. END AS date_range,
  1468. kd.recommended_delivery_from,
  1469. kd.recommended_delivery_to,
  1470. kd.recommended_delivery_window_date_from as recommended_delivery_from_date,
  1471. kd.recommended_delivery_window_date_to as recommended_delivery_to_date,
  1472. (select dc.country from public.kln_destination_delivery_config dc where md.agent in (select regexp_split_to_table(dc.station, ','))) as dc_country
  1473. from matched_data md
  1474. LEFT join public.kln_destination_delivery kd on kd.serial_no = '$serial_no'
  1475. order by md.eta desc";
  1476. //error_log($sql);
  1477. $rs = common::excuteListSql($sql);
  1478. return array("msg"=>"","data"=>$rs);
  1479. }
  1480. function groupShipments($booking_no, $manifest_type, $h_bol,$h_serial_no, $order_from,$m_bol, $ctnr,$kln_pic,$consignee,$consignee_id,
  1481. $recommended_delivery_window_date_from, $recommended_delivery_window_date_to,
  1482. $recommended_delivery_from,$recommended_delivery_to,$dc_country){
  1483. // Combine the data into an array of shipments
  1484. $shipments = [];
  1485. foreach ($h_bol as $index => $_h_bol) {
  1486. $shipments[] = [
  1487. 'booking_no' =>$booking_no[$index],
  1488. 'manifest_type' => $manifest_type[$index],
  1489. 'h_bol' => $h_bol[$index],
  1490. 'h_serial_no' => $h_serial_no[$index],
  1491. 'order_from' => $order_from[$index],
  1492. 'm_bol' => $m_bol[$index],
  1493. 'ctnr' => $ctnr[$index],
  1494. 'kln_pic' => $kln_pic[$index],
  1495. 'consignee' => $consignee[$index],
  1496. 'consignee_id' => $consignee_id[$index],
  1497. 'dc_country' => $dc_country[$index],
  1498. 'recommended_delivery_window_date_from' => $recommended_delivery_window_date_from[$index],
  1499. 'recommended_delivery_window_date_to' => $recommended_delivery_window_date_to[$index],
  1500. 'recommended_delivery_from' => $recommended_delivery_from[$index],
  1501. 'recommended_delivery_to' => $recommended_delivery_to[$index]
  1502. ];
  1503. }
  1504. // 按 MBOL 分组
  1505. $groupedByMbol = [];
  1506. // 按 ShipmentID 分组
  1507. $groupedByShipmentId = [];
  1508. foreach ($shipments as $item) {
  1509. $m_bol = $item['m_bol'];
  1510. $h_serial_no = $item['h_serial_no'];
  1511. $h_bol = $item['h_bol'];
  1512. $order_from = $item['order_from'];
  1513. $ctnr = $item['ctnr'];
  1514. $dc_country = $item['dc_country'];
  1515. $consignee_id = $item['consignee_id'];
  1516. if($item['manifest_type'] == 'BCN'){
  1517. if (!isset($groupedByMbol[$m_bol])) {
  1518. $item['h_bol'] = array();
  1519. $item['h_bol_multiple_link'] = array();
  1520. $item['h_serial_no'] = array();
  1521. $item['ctnr'] = array();
  1522. $item['dc_country'] = array();
  1523. $item['consignee_id'] = array();
  1524. $item['m_bol'] = array($item['m_bol']);
  1525. $groupedByMbol[$m_bol] = $item;
  1526. }
  1527. if (!in_array($h_serial_no, $groupedByMbol[$m_bol]['h_serial_no'])) {
  1528. $groupedByMbol[$m_bol]['h_bol'][] = $h_bol;
  1529. $groupedByMbol[$m_bol]['h_bol_multiple_link'][] = array("key"=>$h_bol,"value" =>$h_serial_no,"order_from"=>$order_from);
  1530. $groupedByMbol[$m_bol]['h_serial_no'][] = $h_serial_no;
  1531. $groupedByMbol[$m_bol]['dc_country'][] = $dc_country;
  1532. $groupedByMbol[$m_bol]['consignee_id'][] = $consignee_id;
  1533. }
  1534. if (!in_array($ctnr, $groupedByMbol[$m_bol]['ctnr'])) {
  1535. $groupedByMbol[$m_bol]['ctnr'][] = $ctnr;
  1536. }
  1537. } else {
  1538. if (!isset($groupedByShipmentId[$h_serial_no])) {
  1539. $item['m_bol'] = array();
  1540. $item['ctnr'] = array();
  1541. $item['dc_country'] = array($item['dc_country']);
  1542. $item['consignee_id'] = array($item['consignee_id']);
  1543. $item['h_serial_no'] = array($item['h_serial_no']);
  1544. $item['h_bol'] = array($item['h_bol']);
  1545. $item['h_bol_multiple_link'] = array(array("key"=>$h_bol,"value" =>$h_serial_no,"order_from"=>$order_from));
  1546. $groupedByShipmentId[$h_serial_no] = $item;
  1547. }
  1548. if (!in_array($m_bol, $groupedByShipmentId[$h_serial_no]['m_bol'])) {
  1549. $groupedByShipmentId[$h_serial_no]['m_bol'][] = $m_bol;
  1550. }
  1551. if (!in_array($ctnr, $groupedByShipmentId[$h_serial_no]['ctnr'])) {
  1552. $groupedByShipmentId[$h_serial_no]['ctnr'][] = $ctnr;
  1553. }
  1554. }
  1555. }
  1556. $result = array();
  1557. foreach($groupedByMbol as $mb){
  1558. $result[] = $mb;
  1559. }
  1560. foreach($groupedByShipmentId as $hb){
  1561. $result[] = $hb;
  1562. }
  1563. return $result;
  1564. }
  1565. }
  1566. ?>