main_new_version.php 45 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840
  1. <?php
  2. $max_ec = ini_get('max_execution_time'); //set max_excution_time
  3. ini_set('max_execution_time', '600');
  4. $memory_limit = "";
  5. $action = "";
  6. if (isset($_GET['action']))
  7. $action = strtolower($_GET['action']);
  8. if (isset($_POST['action']))
  9. $action = strtolower($_POST['action']);
  10. include "include.ini.php";
  11. include 'service/ocean_booking.class.php';
  12. include 'service/ocean_order.class.php';
  13. include 'service/operation_log.class.php';
  14. include 'service/search.class.php';
  15. include 'service/column.class.php';
  16. include 'service/ajax.class.php';
  17. include 'service/login.class.php';
  18. include 'service/tools.class.php';
  19. //为了调用,临时做一个登录动作 如果是正式版 要注释掉菜单System Settings
  20. //$_POST['uname'] = "ra.admin";
  21. //$_POST['psw'] = common::excuteOneSql("select ra_password from public.ra_online_user where user_login = 'ra.admin'");
  22. // $name =strpos(common::ip(), "192.168.0.158") !== false || strpos(common::ip(), "192.168.0.161s") !== false ? "dddde" : 'ra.admin';
  23. // $_POST['uname'] = $name;
  24. // $_POST['psw'] = common::excuteOneSql("select ra_password from public.ra_online_user where user_login = '".$name."'");
  25. // login::getInstance()->do_login_auto();
  26. //验证路由权限
  27. common::securityCheckHandNew($action);
  28. if (_is_only_vgm()) {
  29. Header("Location:main.php?action=main");
  30. }
  31. error_log("--------------前端请求post参数---------------");
  32. error_log(utils::jsonFiltration("null", "\"\"", json_encode($_POST)));
  33. error_log("--------------前端请求get参数---------------");
  34. error_log(utils::jsonFiltration("null", "\"\"", json_encode($_GET)));
  35. //Operation log 日志记录
  36. utils::operation_log_records();
  37. switch ($action) {
  38. case 'ocean_booking':
  39. ocean_booking::getInstance()->ocean_booking();
  40. break;
  41. case 'ocean_order':
  42. include ONLINE_ROOT . 'libs' . DS . 'ams_config.ini.php';
  43. ocean_order::getInstance()->ocean_order();
  44. break;
  45. case 'ajax':
  46. echo ajax::getInstance()->run();
  47. break;
  48. case 'opreation_log':
  49. echo operation_log::getInstance()->operation_log();
  50. break;
  51. case 'main':
  52. //如果在没有登录前,没有登录信息,指定用户
  53. if(!isset($_SESSION['ONLINE_USER'])){
  54. $menuList = array();
  55. $menuList[] = array("index"=>'1',"label"=>"Dashboard","icon"=>"icon_data_fill_b","path"=>"/dashboard");
  56. $menuList[] = array("index"=>'2',"label"=>"Booking","icon"=>"icon_booking__fill_b","path"=>"/booking");
  57. $menuList[] = array("index"=>'3',"label"=>"Tracking","icon"=>"icon_tracking__fill_b","path"=>"/tracking");
  58. } else {
  59. //d登录后,根据配置的权限,是否显示
  60. if (_isAdmin())
  61. $sql = "select f_column, min(menu_id) as menu_id, max(menu_icon_font) as menu_icon_font from public.ra_online_permission where has_new_version=true group by f_column order by min(order_by)";
  62. elseif (_isNewUser())
  63. $sql = "select f_column, min(menu_id) as menu_id, max(menu_icon_font) as menu_icon_font from public.ra_online_permission where has_new_version=true and customer_check = true group by f_column ORDER BY min(order_by)";
  64. else
  65. $sql = "select p.f_column, min(menu_id) as menu_id, max(menu_icon_font) as menu_icon_font from public.ra_online_user_permission up left join public.ra_online_permission p on up.p_id = p.id where has_new_version=true and lower(user_name) = '" . common::check_input(strtolower(_getLoginName())) . "' group by p.f_column ORDER BY min(p.order_by)";
  66. $rs = common::excuteListSql($sql);
  67. if (empty($rs) && _isApexLogin()) {
  68. $sql = "select f_column, min(menu_id) as menu_id, max(menu_icon_font) as menu_icon_font from public.ra_online_permission where has_new_version=true and default_check = true group by f_column ORDER BY min(order_by)";
  69. $rs = common::excuteListSql($sql);
  70. }
  71. $menuSetting = array("Ocean Booking" => array("label"=>"Booking","path"=>"/booking","icon"=>"icon_booking__fill_b"),
  72. "Ocean B/L Info." => array("label"=>"Tracking","path"=>"/tracking","icon"=>"icon_tracking__fill_b"));
  73. $menuList = array();
  74. $menuList[] = array("index"=>'1',"label"=>"Dashboard","icon"=>"icon_data_fill_b","path"=>"/dashboard");
  75. $index = 2;
  76. foreach ($rs as $value) {
  77. if ($value['f_column'] == "Shipment Info."){
  78. if (_isAdmin())
  79. $ll = common::excuteListSql("select s_column, url_action, sub_menu_id from public.ra_online_permission where has_new_version=true and f_column = '" . common::check_input($value['f_column']) . "' ORDER BY order_by");
  80. elseif (_isNewUser())
  81. $ll = common::excuteListSql("select s_column, url_action, sub_menu_id from public.ra_online_permission where has_new_version=true and customer_check = true and f_column = '" . common::check_input($value['f_column']) . "' ORDER BY order_by");
  82. else
  83. $ll = common::excuteListSql("select s_column, url_action, sub_menu_id from public.ra_online_permission p left join public.ra_online_user_permission gp on gp.p_id = p.id where has_new_version=true and f_column = '" . common::check_input($value['f_column']) . "' and lower(gp.user_name) = '" . common::check_input(strtolower(_getLoginName())) . "' ORDER BY p.order_by");
  84. if (empty($ll) && _isApexLogin()) {
  85. $ll = common::excuteListSql("select s_column, url_action, sub_menu_id from public.ra_online_permission where has_new_version=true and f_column = '" . common::check_input($value['f_column']) . "' and default_check = true ORDER BY order_by");
  86. }
  87. //单独拼接URL
  88. foreach ($ll as $v) {
  89. if($v['s_column'] =="Ocean Booking" || $v['s_column'] =="Ocean B/L Info."){
  90. $urlData = $menuSetting[$v['s_column']];
  91. $menuList[] = array("index"=>"$index","label"=>$urlData['label'],"icon"=>$urlData['icon'],"path"=>$urlData['path']);
  92. $index = $index + 1;
  93. }
  94. }
  95. }
  96. }
  97. // $menuList[] = array("index"=>$index,"label"=>"System Management","icon"=>"icon_system__management_fill_b","type"=>"list",
  98. // "children"=>array(array("index" =>$index.'-1',"label" =>"Operation Log","path"=>"/Operationlog")));
  99. $systemManagement = array("index"=>"$index","label"=>"System Management","icon"=>"icon_system__management_fill_b","type"=>"list");
  100. $children = array();
  101. $children[] = array("index" =>$index.'-1',"label" =>"System Message","path"=>"/system-message");
  102. $children[] = array("index" =>$index.'-2',"label" =>"System Settings","path"=>"/SystemSettings");
  103. //只有chud的账户可以看日志记录
  104. if(_getLoginName() == "chud" || _getLoginName() == "IT.Andywu" || _getLoginName() == "ra.admin"){
  105. $children[] = array("index" =>$index.'-3',"label" =>"Operation Log","path"=>"/Operationlog");
  106. }
  107. $systemManagement["children"] = $children;
  108. if (!empty($children)){
  109. $menuList[] = $systemManagement;
  110. }
  111. }
  112. common::echo_json_encode(200, $menuList);
  113. exit();
  114. break;
  115. case 'main_filter':
  116. $data = common::getManagement();
  117. common::echo_json_encode(200, $data['dashboard_filter']);
  118. exit();
  119. break;
  120. case 'main_report':
  121. //这里只剩下r3,r4的查询
  122. $type = $_REQUEST["r_type"];
  123. $sqlWhere = ' and ' . common::searchExtendHand_KLN("ocean", $_SESSION["ONLINE_USER"]);
  124. $sqlWhere = " " . $sqlWhere;
  125. $sqlWhere .= common::getDashboardTransportationSqlWhere();
  126. $sqlWhere = common::check_input($sqlWhere);
  127. $list = common::excuteListSql("select * from public.online_order_status_date_kln_pending('$type'::text, '$sqlWhere'::text) "
  128. . "r (c bigint, e integer, b integer, d text)");
  129. $key = "[";
  130. $value = "[";
  131. $totalValue = 0;
  132. foreach ($list as $vv) {
  133. if ($key != "[") {
  134. $key .= ",";
  135. $value .= ",";
  136. }
  137. if ($type == "r2" || $type == "r3" || $type == "r3_1" || $type == "r4" || $type == "r4_1") {
  138. $key .= '"' . $vv["d"] . '"';
  139. $value .= '{"value":"' . $vv["c"] . '","name":"' . $vv["d"] . '" }';
  140. $totalValue = $totalValue + $vv["c"];
  141. } else {
  142. if ($vv["e"] == -1) {
  143. $key .= '"Over 80 Days"';
  144. $value .= '{"value":"' . $vv["c"] . '","name":"Over 80 Days"}';
  145. } else {
  146. $key .= '"' . $vv["b"] . '-' . $vv["e"] . ' Days"';
  147. $value .= '{"value":"' . $vv["c"] . '","name":"' . $vv["b"] . '-' . $vv["e"] . ' Days"}';
  148. }
  149. $totalValue = $totalValue + $vv["c"];
  150. }
  151. }
  152. $key .= "]";
  153. $value .= "]";
  154. //处理返回原表数据格式
  155. $data = common::mian_repot_do($value,$type,$totalValue);
  156. common::echo_json_encode(200, $data);
  157. exit();
  158. break;
  159. case 'main_report_etd':
  160. //这里只有r1查询
  161. $type = "r1";
  162. $container_type = "";
  163. $date_type = strtolower($_REQUEST["date_type"]);
  164. if (empty($_REQUEST["date_start"])) {
  165. $bdate = "null";
  166. } else {
  167. $bdate = $_REQUEST["date_start"];
  168. $bdate = "'$bdate'";
  169. }
  170. if (empty($_REQUEST["date_end"])) {
  171. $edate = "null";
  172. } else {
  173. $edate = $_REQUEST["date_end"];
  174. $edate = "'$edate'";
  175. }
  176. $sqlWhere = ' and ' . common::searchExtendHand_KLN("ocean", $_SESSION["ONLINE_USER"]);
  177. $sqlWhere = " " . $sqlWhere;
  178. $sqlWhere = $sqlWhere . common::getDashboardTransportationSqlWhere();
  179. $sqlWhere = common::check_input($sqlWhere);
  180. $list = common::excuteListSql("select * from public.online_order_status_date_kln_r1_r2('$type'::text, 'eta'::text, 'etd'::text, $bdate, $edate, '$sqlWhere'::text, '$container_type'::text,'$date_type'::text) "
  181. . "r (c bigint, e integer, b integer, d text)");
  182. $key = "[";
  183. $value = "[";
  184. $totalValue = 0;
  185. foreach ($list as $vv) {
  186. if ($key != "[") {
  187. $key .= ",";
  188. $value .= ",";
  189. }
  190. if ($type == "r2" || $type == "r3" || $type == "r3_1" || $type == "r4" || $type == "r4_1") {
  191. $key .= '"' . $vv["d"] . '"';
  192. $value .= '{"value":"' . $vv["c"] . '","name":"' . $vv["d"] . '" }';
  193. $totalValue = $totalValue + $vv["c"];
  194. } else {
  195. if ($vv["e"] == -1) {
  196. $key .= '"Over 80 Days"';
  197. $value .= '{"value":"' . $vv["c"] . '","name":"Over 80 Days"}';
  198. } else {
  199. $key .= '"' . $vv["b"] . '-' . $vv["e"] . ' Days"';
  200. $value .= '{"value":"' . $vv["c"] . '","name":"' . $vv["b"] . '-' . $vv["e"] . ' Days"}';
  201. }
  202. $totalValue = $totalValue + $vv["c"];
  203. }
  204. }
  205. $key .= "]";
  206. $value .= "]";
  207. //处理返回原表数据格式
  208. $data = common::mian_repot_do($value,$type,$totalValue);
  209. common::echo_json_encode(200, $data);
  210. exit();
  211. break;
  212. case 'main_report_kpi':
  213. $type = $_REQUEST["r_type"];
  214. $sqlWhere = ' and ' . common::searchExtendHand_KLN("ocean", $_SESSION["ONLINE_USER"]);
  215. $sqlWhere = " " . $sqlWhere;
  216. $sqlWhere = $sqlWhere . common::getDashboardTransportationSqlWhere();
  217. $sqlWhere = common::check_input($sqlWhere);
  218. $date_type = strtolower($_REQUEST["date_type"]);
  219. if (isset($_REQUEST['date_start']) && !empty($_REQUEST['date_start']))
  220. $sqlWhere .= " and $date_type >= ''" . common::usDate2sqlDate($_REQUEST['date_start']) . " 00:00:00''";
  221. if (isset($_REQUEST['date_end']) && !empty($_REQUEST['date_end']))
  222. $sqlWhere .= " and $date_type <= ''" . common::usDate2sqlDate($_REQUEST['date_end']) . " 23:59:59''";
  223. $list = common::excuteListSql("select * from public.online_order_status_date_kln_kpi('$type'::text,'$sqlWhere'::text) "
  224. . "r (c bigint, d text)");
  225. $key = "[";
  226. $value = "[";
  227. $totalValue = 0;
  228. foreach ($list as $vv) {
  229. if ($key != "[") {
  230. $key .= ",";
  231. $value .= ",";
  232. }
  233. if ($type == "ata_r3" || $type == "atd_r4" ) {
  234. $key .= '"' . $vv["d"] .'"';
  235. $value .= '{"value":"' . $vv["c"] . '","name":"' . $vv["d"] .'"}';
  236. $totalValue = $totalValue + $vv["c"];
  237. }
  238. }
  239. $key .= "]";
  240. $value .= "]";
  241. //处理返回原表数据格式
  242. $ETDList = array();
  243. $value_arr = json_decode($value,true);
  244. foreach($value_arr as $arr){
  245. $color = common::getItemStyle($type,$arr['name']);
  246. if($arr['name'] == "0 Day"){
  247. $arr['name'] = "≤1 Day";
  248. }
  249. if($arr['name'] == "7 Days"){
  250. $arr['name'] = "≥7 Days";
  251. }
  252. $ETDList[] = array("value" =>intval($arr['value']),"name" =>$arr['name'],"itemStyle" =>array("color" =>$color));
  253. }
  254. if($type == 'atd_r4'){
  255. $data = array("ETDList" =>$ETDList,"ETD_Radius"=>array('30%','50%'),"title1" =>"Departure","title2" =>"(ATD-ETD)","download_name" => "KPI Departure");
  256. }
  257. if($type == 'ata_r3'){
  258. $data = array("ETDList" =>$ETDList,"ETD_Radius"=>array('30%','50%'),"title1" =>"Arrival","title2" =>"(ATA-ETA)","download_name" => "KPI Arrival");
  259. }
  260. common::echo_json_encode(200, $data);
  261. exit();
  262. break;
  263. case 'main_report_container_bar':
  264. //新UI 要ALL 20 40 45 四份数据同时查询,且是柱状图,所以与r3 r4查询分开
  265. $container_type_arr = array("20","40","45");
  266. $container_type_param = "all";
  267. $ContainerCounSeries = array();
  268. foreach($container_type_arr as $_container_type){
  269. $container_type = $_container_type;
  270. $date_type = strtolower($_REQUEST["date_type"]);
  271. $type = $_REQUEST["r_type"];
  272. if (empty($_REQUEST["date_start"])) {
  273. $bdate = "null";
  274. } else {
  275. $bdate = $_REQUEST["date_start"];
  276. $bdate = "'$bdate'";
  277. }
  278. if (empty($_REQUEST["date_end"])) {
  279. $edate = "null";
  280. } else {
  281. $edate = $_REQUEST["date_end"];
  282. $edate = "'$edate'";
  283. }
  284. $list= array();
  285. //all 查询所有
  286. $sqlWhere = ' and ' . common::searchExtendHandNew("ocean", $_SESSION["ONLINE_USER"]);
  287. $sqlWhere = common::check_input($sqlWhere);
  288. $sqlWhere = " " . $sqlWhere;
  289. //如果页面查询的是ALL 这个20 40 45都查询出来。否则值查询都对应的size,其他的不查询
  290. if(strtolower($container_type_param) == "all"){
  291. $list = common::excuteListSql("select * from public.online_order_status_date_new_r1_r2('$type'::text, 'eta'::text, 'etd'::text, $bdate, $edate, '$sqlWhere'::text, '$container_type'::text, '$date_type'::text) "
  292. . "r (c bigint, e integer, b integer, d text)");
  293. }else{
  294. if($container_type_param == $_container_type){
  295. $list = common::excuteListSql("select * from public.online_order_status_date_new_r1_r2('$type'::text, 'eta'::text, 'etd'::text, $bdate, $edate, '$sqlWhere'::text, '$container_type'::text, '$date_type'::text) "
  296. . "r (c bigint, e integer, b integer, d text)");
  297. }
  298. }
  299. $key = "[";
  300. $value = "[";
  301. $totalValue = 0;
  302. foreach ($list as $vv) {
  303. if ($key != "[") {
  304. $key .= ",";
  305. $value .= ",";
  306. }
  307. if ($type == "r2" || $type == "r3" || $type == "r3_1" || $type == "r4" || $type == "r4_1") {
  308. $key .= '"' . $vv["d"] . '"';
  309. $value .= '{"value":"' . $vv["c"] . '","name":"' . $vv["d"] . '" }';
  310. $totalValue = $totalValue + $vv["c"];
  311. } else {
  312. if ($vv["e"] == -1) {
  313. $key .= '"Over 80 Days"';
  314. $value .= '{"value":"' . $vv["c"] . '","name":"Over 80 Days"}';
  315. } else {
  316. $key .= '"' . $vv["b"] . '-' . $vv["e"] . ' Days"';
  317. $value .= '{"value":"' . $vv["c"] . '","name":"' . $vv["b"] . '-' . $vv["e"] . ' Days"}';
  318. }
  319. $totalValue = $totalValue + $vv["c"];
  320. }
  321. }
  322. $key .= "]";
  323. $value .= "]";
  324. $key_arr = json_decode($key,true);
  325. $value_arr = json_decode($value,true);
  326. $data = array();
  327. //每一个size 的所有月份总计
  328. $total = 0;
  329. //每一个size 对应的最大值
  330. $max = 0;
  331. foreach($value_arr as $arr){
  332. $data[] = intval($arr['value']);
  333. $total = $total + intval($arr['value']);
  334. $max = $max < intval($arr['value']) ? intval($arr['value']) : $max;
  335. }
  336. $ContainerCounSeries[$container_type] = array("data"=>$data,"total"=>$total,"max"=>$max);
  337. }
  338. //处理返回时数据格式
  339. $ContainerCounSeries_return = array();
  340. //横坐标栏位
  341. $ContainerCount_Title = $key_arr;
  342. //所查的所有模式计算总和
  343. $total = 0;
  344. //所有size下的最大值,方便标注计算最长的Y坐标
  345. $max_all = 0;
  346. foreach($ContainerCounSeries as $k =>$v){
  347. //这个type 是页面传过来的。这个固定r2
  348. $color = common::getItemStyle($type,$k);
  349. $total = $total + $v['total'];
  350. $ContainerCounSeries_return[] = array("name"=>strval($k),"type"=>"bar","emphasis" => array("focus" =>"none"),
  351. "stack" =>"总计","data" =>$v['data'],"itemStyle" =>array("color" =>$color));
  352. $max_all = $max_all + $v['max'];
  353. }
  354. //计算Y坐标的间隔
  355. $interval = utils::calculateTicks(0,$max_all,5);
  356. if($interval == 0){
  357. //处理返回默认值
  358. $interval = 2;
  359. }
  360. $returnData = array("ContainerCount_Title"=>"Total: $total","ContainerCountList" =>$ContainerCount_Title,"ContainerCounSeries" =>$ContainerCounSeries_return,
  361. "min" => 0,"Max" =>$interval*5,"interval" =>$interval,"download_name" => "Container Count");
  362. //demo
  363. // $json = '{"code":200,"data":{"ContainerCount_Title":"Total: 463518","ContainerCountList":["OCT,23","NOV,23","DEC,23","JAN,24","FEB,24","MAR,24","APR,24","MAY,24","JUN,24","JUL,24","AUG,24","SEP,24","OCT,24"],"ContainerCounSeries":[{"name":"20","type":"bar","emphasis":{"focus":"none"},"stack":"\u603b\u8ba1","data":[4400,8600,8804,9271,8961,8793,8534,9476,9530,10277,10081,8997,5784],"itemStyle":{"color":"#FF7500"}},{"name":"40","type":"bar","emphasis":{"focus":"none"},"stack":"\u603b\u8ba1","data":[13652,28021,30422,30136,26320,27035,23979,26494,28406,33318,32318,30962,16369],"itemStyle":{"color":"#FFAC66"}},{"name":"45","type":"bar","emphasis":{"focus":"none"},"stack":"\u603b\u8ba1","data":[189,337,415,437,439,321,250,320,324,603,328,415,200],"itemStyle":{"color":"#FFE3CC"}}],"min":0,"Max":45000,"interval":9000}}';
  364. // $returnData = json_decode($json,true);
  365. // echo json_encode($returnData);
  366. // exit();
  367. common::echo_json_encode(200, $returnData);
  368. exit();
  369. break;
  370. case 'main_report_co2e_bar':
  371. $returnData = common::getCo2eBar();
  372. common::echo_json_encode(200, $returnData);
  373. exit();
  374. break;
  375. case 'main_report_top10_bar':
  376. $returnData = common::getTopBar();
  377. common::echo_json_encode(200, $returnData);
  378. exit();
  379. break;
  380. case 'main_report_revenue':
  381. $returnData = common::getRevenue();
  382. common::echo_json_encode(200, $returnData);
  383. exit();
  384. break;
  385. case 'main_map':
  386. $uncode = $_POST["uncode"];
  387. $serial_no = $_POST["serial_no"];
  388. $unall = explode("|", $uncode);
  389. $sql = "";
  390. if (!empty($unall[0]) && $unall[0] != "''") {
  391. $sql .= "select lon as lng, lat as lat, uncode, 'Place of receipt: '||name1 as location_namewo, 'por' as type from vessel.vt_unlocode where "
  392. . "lon<>0 and lat<>0 and lon is not null and lat is not null and uncode in "
  393. . "($unall[0])";
  394. }
  395. if (!empty($unall[1]) && $unall[1] != "''") {
  396. if (!empty($sql)) {
  397. $sql .= " union ";
  398. }
  399. $sql .= "select lon as lng, lat as lat, uncode, 'POL: '||name1 as location_namewo, 'pol' as type from vessel.vt_unlocode where "
  400. . "lon<>0 and lat<>0 and lon is not null and lat is not null and uncode in "
  401. . "($unall[1])";
  402. }
  403. if (!empty($unall[2]) && $unall[2] != "''") {
  404. if (!empty($sql)) {
  405. $sql .= " union ";
  406. }
  407. $sql .= "select lon as lng, lat as lat, uncode, 'POD: '||name1 as location_namewo, 'pod' as type from vessel.vt_unlocode where "
  408. . "lon<>0 and lat<>0 and lon is not null and lat is not null and uncode in "
  409. . "($unall[2])";
  410. }
  411. if (!empty($unall[3]) && $unall[3] != "''") {
  412. if (!empty($sql)) {
  413. $sql .= " union ";
  414. }
  415. $sql .= "select lon as lng, lat as lat, uncode, 'Place of delivery: '||name1 as location_namewo, 'poe' as type from vessel.vt_unlocode where "
  416. . "lon<>0 and lat<>0 and lon is not null and lat is not null and uncode in "
  417. . "($unall[3])";
  418. }
  419. $tkStatus = common::excuteListSql("select tl.by_pickup, g.consignee_exp, g.pickup_from_exp, c.ctnr, g.deliveryto_exp, g.serial_no, tl.location, tl.type, tl.id,
  420. to_char(tl.upload_time, 'MM/DD/YYYY HH24:MI:SS') as utime
  421. from public.tk_general g, public.tk_commodity c left join public.tk_location tl on c.serial_no=tl.serial_no
  422. where g.serial_no=c.serial_no and g.bol=(select m_bol from public.ocean where serial_no='$serial_no') order by tl.order_id");
  423. foreach ($tkStatus as $vv) {
  424. $ll = explode(",", $vv["location"]);
  425. if ($vv["by_pickup"] == "t") {
  426. $pf = explode("\r\n", $vv["pickup_from_exp"]);
  427. $pf = common::check_input($pf[0]) . "(" . $vv["ctnr"] . ")";
  428. $dt = explode("\r\n", $vv["consignee_exp"]);
  429. $dt = common::check_input($dt[0]) . "(" . $vv["ctnr"] . ")";
  430. } else {
  431. $pf = explode("\r\n", $vv["consignee_exp"]);
  432. $pf = common::check_input($pf[0]) . "(" . $vv["ctnr"] . ")";
  433. $dt = explode("\r\n", $vv["deliveryto_exp"]);
  434. $dt = common::check_input($dt[0]) . "(" . $vv["ctnr"] . ")";
  435. }
  436. if ($vv["type"] == "26" && !empty($ll[1])) {
  437. if (!empty($sql)) {
  438. $sql .= " union ";
  439. }
  440. $sql .= "select '" . $ll[1] . "' as lng, '" . $ll[0] . "' as lat, '" . $vv["ctnr"] . "' as uncode, 'Pick up: " . $vv["utime"] . "<br>'||'" . $pf . "' as location_namewo, 'pickup' as type";
  441. } elseif ($vv["type"] == "25" && !empty($ll[1])) {
  442. if (!empty($sql)) {
  443. $sql .= " union ";
  444. }
  445. $sql .= "select '" . $ll[1] . "' as lng, '" . $ll[0] . "' as lat, '" . $vv["ctnr"] . "' as uncode, 'Delivery: " . $vv["utime"] . "<br>'||'" . $dt . "' as location_namewo, 'delivery' as type";
  446. }
  447. }
  448. if (!empty($sql)) {
  449. $gps = common::excuteListSql($sql . "");
  450. }
  451. if (!empty($serial_no)) {
  452. $all = explode(",", $serial_no);
  453. foreach ($all as $a) {
  454. $rs = common::excuteOneSql("select public.get_vessel_position('$a'::text)");
  455. if (!empty($rs)) {
  456. $rss = explode("|", $rs);
  457. $lng_lat = explode(",", $rss[1]);
  458. $gps[] = array("lng" => $lng_lat[0], "lat" => $lng_lat[1], "uncode" => "", "location_namewo" => "", "type" => "vessel", "vessel_name" => $rss[2], "m_shipname" => "", "mmsi" => "", "imo" => "", "m_shipstate" => "", "m_shiptype" => "", "m_dest" => "", "m_newshiparrive" => "", "m_newlasttime" => "", "lasttime" => "", "sub" => "");
  459. }
  460. }
  461. }
  462. $data = array("gps" => $gps);
  463. common::echo_json_encode("200", $data);
  464. exit();
  465. break;
  466. case 'main_map_new':
  467. include ONLINE_ROOT . 'libs' . DS . 'map_config.ini.php';
  468. //修改添加port_of_transshipment 和port_of_transshipment_name的坐标获取(有为空的可能)
  469. $serial_no = $_REQUEST["serial_no"];
  470. $_schemas = $_REQUEST['_schemas'];
  471. if(empty($_schemas)){
  472. $_schemas ="public";
  473. }
  474. //$serial_no = "F41E6016-1A97-4C93-8198-53D8B3B26220";
  475. $transport_mode = common::excuteOneSql("SELECT transport_mode FROM public.kln_ocean ko
  476. WHERE ko.serial_no = '$serial_no' and order_from = '$_schemas'");
  477. if($transport_mode == "sea"){
  478. $sql = "with ss as (select '$serial_no' as sn)
  479. , aa as (
  480. select place_of_receipt_un, place_of_delivery_un, fport_of_loading_un, mport_of_discharge_un, port_of_loading, port_of_discharge, place_of_delivery_exp, place_of_receipt_exp,dd.*
  481. from public.kln_ocean oo
  482. left join LATERAL (
  483. select (select uncode from ports where code = o.port_of_transshipment) as port_of_transshipment_un,
  484. port_of_transshipment_name
  485. from $_schemas.ocean o where o.serial_no=oo.serial_no order by id desc limit 1
  486. ) dd on true
  487. where serial_no=(select sn from ss) limit 1
  488. )
  489. , rr as (
  490. select lon as lng, lat as lat, 'Origin' as label, port_of_loading as infor, 1 as sort, null::timestamp without time zone as stime, 'pol'::text as ptype
  491. from vessel.vt_unlocode, aa where (lat<=90 and lat>=-90) and (lon<=180 and lon>=-180) and lon is not null and lat is not null and uncode=fport_of_loading_un
  492. union all
  493. select lon as lng, lat as lat, 'Destination' as label, port_of_discharge as infor, 2 as sort, null::timestamp without time zone as stime, 'pod'::text as ptype
  494. from vessel.vt_unlocode, aa where (lat<=90 and lat>=-90) and (lon<=180 and lon>=-180) and lon is not null and lat is not null and uncode=mport_of_discharge_un
  495. union all
  496. select lon as lng, lat as lat, 'Transfer' as label, port_of_transshipment_name as infor, 3 as sort, null::timestamp without time zone as stime, 'poe'::text as ptype
  497. from vessel.vt_unlocode, aa where (lat<=90 and lat>=-90) and (lon<=180 and lon>=-180) and lon is not null and lat is not null and uncode=port_of_transshipment_un
  498. )
  499. select * from rr order by sort, stime";
  500. } elseif ($transport_mode == "air"){
  501. $sql = "with ss as (select '$serial_no' as sn)
  502. , aa as (
  503. select place_of_receipt_un, place_of_delivery_un, fport_of_loading_un, mport_of_discharge_un, port_of_loading, port_of_discharge, place_of_delivery_exp, place_of_receipt_exp
  504. from public.kln_ocean oo
  505. where serial_no=(select sn from ss) limit 1
  506. )
  507. , rr as (
  508. select lon as lng, lat as lat, 'Origin' as label, port_of_loading as infor, 1 as sort, null::timestamp without time zone as stime, 'pol'::text as ptype
  509. from vessel.vt_unlocode, aa where (lat<=90 and lat>=-90) and (lon<=180 and lon>=-180) and lon is not null and lat is not null and uncode=fport_of_loading_un
  510. union all
  511. select lon as lng, lat as lat, 'Destination' as label, port_of_discharge as infor, 2 as sort, null::timestamp without time zone as stime, 'pod'::text as ptype
  512. from vessel.vt_unlocode, aa where (lat<=90 and lat>=-90) and (lon<=180 and lon>=-180) and lon is not null and lat is not null and uncode=mport_of_discharge_un
  513. )
  514. select * from rr order by sort, stime";
  515. }
  516. $rss = common::excuteListSql($sql);
  517. //$rss = $mapdb->GetAll($sql);
  518. //先固定死
  519. // $json = '[{"lng":"100.78594000","lat":"13.68521000","label":"Origin","infor":"LAT KRABANG, THAILAND","sort":"0","stime":null,"ptype":"por"},
  520. // {"lng":"100.88333333","lat":"13.08333333","label":"Destination","infor":"LAEM CHABANG PORT,THAILAND","sort":"1","stime":null,"ptype":"pol"},
  521. // {"lng":"-122.28640000","lat":"37.79784000","label":"Transfer","infor":"OAKLAND, CA, USA","sort":"2","stime":null,"ptype":"pod"}]';
  522. //$rss = json_decode($json,true);
  523. global $mapdb;
  524. //查询线(包含所有的线) 空运不查询航线
  525. if ($transport_mode == "air"){
  526. $Line =array();
  527. }else{
  528. error_log("select * from get_track_data('$serial_no',true)");
  529. $map_sql = "select * from get_track_data('$serial_no',true)";
  530. $Line = $mapdb->GetAll($map_sql) or ( (!$mapdb->ErrorMsg()) or error_log(common::dbLog($mapdb, $map_sql), 0));
  531. }
  532. $solidLine = array();
  533. $dottedLine = array();
  534. $rangePoint = array();
  535. foreach($Line as $line){
  536. if($line['tp'] == "1"){
  537. $solidLine[] = $line;
  538. }elseif($line['tp'] == "0"){
  539. $dottedLine[] = $line;
  540. }else{
  541. $rangePoint[] = $line;
  542. }
  543. }
  544. //如果没有虚线,这这个范围点也是异常的,不需要显示
  545. if(empty($dottedLine)){
  546. $rangePoint = array();
  547. }
  548. $data = array("point"=>$rss,"solidLine"=>$solidLine,"dottedLine"=>$dottedLine,"rangePoint"=>$rangePoint);
  549. common::echo_json_encode(200, $data);
  550. //common::echo_json_encode(200, $rss);
  551. exit();
  552. break;
  553. case 'main_welcome':
  554. $cp = common::check_input($_POST ['cp']); //current_page
  555. $ps = common::check_input($_POST ['ps']); //ps
  556. if (empty($ps))
  557. $ps = 10;
  558. $sqlWhere = ' where ' . common::searchExtendHand_KLN("ocean", $_SESSION["ONLINE_USER"]);
  559. $sqlWhere .= common::getDashboardTransportationSqlWhere();
  560. // test dome
  561. // $_POST['is_default'] = "no";
  562. // $_POST['date_start'] =null;
  563. // $_POST['date_end'] = null;
  564. //默认初始条件:ALL& ETD& Current Month 当前月的1号到最后一天 这个默认条件已经废除,前端不会这样传参数
  565. if (isset($_POST['is_default']) && strtolower($_POST['is_default']) == "yes" && false){
  566. $sqlWhere .= "and etd>='" . date("Y-m") . "-01' and etd<='" . date("Y-m") . "-01'::date + interval '1 month'";
  567. } else {
  568. $date_type = strtolower(common::check_input($_POST ['date_type']));
  569. if (isset($_POST['date_start']) && !empty($_POST['date_start']))
  570. $sqlWhere .= " and $date_type >= '" . common::usDate2sqlDate($_POST['date_start']) . " 00:00:00'";
  571. if (isset($_POST['date_end']) && !empty($_POST['date_end']))
  572. $sqlWhere .= " and $date_type <= '" . common::usDate2sqlDate($_POST['date_end']) . " 23:59:59'";
  573. }
  574. if (isset($_POST['customer']) && !empty($_POST['customer'])){
  575. $sqlWhere .= " and (shipper ilike '%".common::check_input($_POST['customer'])."%' or shipper_id ilike '%".common::check_input($_POST['customer'])."%'
  576. or consignee ilike '%".common::check_input($_POST['customer'])."%' or consignee_id ilike '%".common::check_input($_POST['customer'])."%')";
  577. }
  578. $rc = $_POST ['rc'];
  579. if ($rc == - 1) {
  580. $sql = "SELECT count(1) from public.kln_ocean" . $sqlWhere;
  581. $rc = common::excuteOneSql($sql);
  582. }
  583. $tp = ceil($rc / $ps);
  584. if ($rc > 0) {
  585. $sql = "SELECT order_from as _schemas,serial_no, consignee, shipper, h_bol,final_desination_uncode, transport_mode,
  586. to_char(etd, 'MM/DD/YYYY'::text) as etd,
  587. to_char(eta, 'MM/DD/YYYY'::text) AS eta,
  588. fport_of_loading_un, mport_of_discharge_un, place_of_receipt_un, place_of_delivery_un, booking_no,
  589. f_vessel,f_voyage,origin,
  590. CASE
  591. WHEN ((m_iffbcf is not null or m_iffbcf is null) and m_iffcpu is null and m_iffrec is null and m_iffdep is null and m_iffarr is null and m_iffdel is null) THEN 'Created'::text
  592. WHEN ((m_iffcpu is not null or m_iffrec is not null) and m_iffdep is null and m_iffarr is null and m_iffdel is null) THEN 'Cargo Received'::text
  593. WHEN (m_iffdep is not null and m_iffarr is null and m_iffdel is null) THEN 'Departure'::text
  594. WHEN (m_iffarr is not null and m_iffdel is null) THEN 'Arrived'::text
  595. WHEN (m_iffdel is not null) THEN 'Completed'::text
  596. ELSE 'Created'::text
  597. END AS new_status
  598. FROM public.kln_ocean $sqlWhere";
  599. //$sqlWhere and last_status_315_update_time is not null";
  600. $sql .= " ORDER BY eta,id desc DESC limit " . $ps . " offset " . ($cp - 1) * $ps;
  601. //$sql .= " ORDER BY last_status_315_update_time DESC limit " . $ps . " offset " . ($cp - 1) * $ps;
  602. $rss = common::excuteListSql($sql);
  603. //RecentStatusList
  604. $RecentStatusList = array();
  605. foreach ($rss as $key => $value) {
  606. $serial_no = $value["serial_no"];
  607. $_schemas_bk = $value['_schemas'];
  608. $_schemas = $value['_schemas'];
  609. if($_schemas == "public"){
  610. $_schemas = "ocean";
  611. }
  612. //单独取查询milestone信息
  613. if ($value['transport_mode'] == "sea"){
  614. $milestone_sql = "select a.act_date,a.act_time,sn.description,a.timezone,
  615. a.code as dd_code
  616. from public.ocean_milestone a
  617. inner join public.customer_service_milestone_sno sn on sn.code=a.code and sn.type = 'sea'
  618. where a.serial_no='$serial_no'
  619. and a.code in (select regexp_split_to_table('IFFBCF,IFFCPU,IFFREC,IFFDEP,IFFARR,IFFDEL', ','))
  620. and a.act_date is not null
  621. order by sn.sno desc limit 1";
  622. } elseif ($value['transport_mode'] == "air"){
  623. //air milestone 的Departed实际描述要替换: IFFDEP =》 IFFONB
  624. $milestone_sql = "select a.act_date,a.act_time,sn.description,a.timezone,
  625. case when a.code = 'IFFONB' then 'IFFDEP'
  626. else a.code
  627. end as dd_code
  628. from $_schemas_bk.air_milestone a
  629. inner join public.customer_service_milestone_sno sn on sn.code=a.code and sn.type = 'air'
  630. where a.serial_no='$serial_no'
  631. and a.code in (select regexp_split_to_table('IFFBCF,IFFCPU,IFFREC,IFFONB,IFFARR,IFFDEL', ','))
  632. and a.act_date is not null
  633. order by sn.sno desc limit 1";
  634. }
  635. $milestone = common::excuteObjectSql($milestone_sql);
  636. $value["act_date"] = $milestone["act_date"];
  637. $value["act_time"] = $milestone["act_time"];
  638. $value["description"] = $milestone["description"];
  639. $value["timezone"] = $milestone["timezone"];
  640. $value["dd_code"] = $milestone["dd_code"];
  641. $timezone = "";
  642. //按照最新execl Timezone From 来自于origin
  643. if($value['dd_code'] == "IFFBCF" || $value['dd_code'] == "IFFCPU"){
  644. $sql = "SELECT (select time_zone from public.city_timezone where uncode = LEFT(c.country, 2) || COALESCE(c.city_code,'')) as timezone
  645. FROM $_schemas.contacts c WHERE c.contact_id = '".$value['origin']."'";
  646. $timezone = common::excuteOneSql($sql);
  647. }
  648. //按照最新execl Timezone From 来自于final_destination
  649. if($value['dd_code'] == "IFFDEL"){
  650. $sql = "select time_zone from public.city_timezone where uncode = '".$value['final_desination_uncode']."'";
  651. $timezone = common::excuteOneSql($sql);
  652. }
  653. if($value['dd_code'] == "IFFREC" || $value['dd_code'] == "IFFDEP" || $value['dd_code'] == "IFFARR"){
  654. $EDI315Time = array();
  655. if ($value['transport_mode'] == "sea"){
  656. //Timezone From 来自于EDI315
  657. $EDI315Time = common::getEDI315Time($serial_no,$value['_schemas']);
  658. }
  659. if($value['dd_code'] == "IFFREC" || $value['dd_code'] == "IFFDEP"){
  660. //先以EDI315 时区为准,如果没有这代表数据是手动输入,或者没有同步情况
  661. $timezone = $EDI315Time[$value['dd_code']]['timezone'];
  662. if(empty($timezone)){
  663. if($value['dd_code'] == "IFFREC"){
  664. $sql = "select time_zone from public.city_timezone where uncode = '".$value['place_of_receipt_un']."'";
  665. }else{
  666. $sql = "select time_zone from public.city_timezone where uncode = '".$value['fport_of_loading_un']."'";
  667. }
  668. $timezone = common::excuteOneSql($sql);
  669. }
  670. }
  671. if($value['dd_code'] == "IFFARR"){
  672. $timezone = $EDI315Time[$value['dd_code']]['timezone'];
  673. if(empty($timezone)){
  674. $sql = "select time_zone from public.city_timezone where uncode = '".$value['mport_of_discharge_un']."'";
  675. $timezone = common::excuteOneSql($sql);
  676. }
  677. }
  678. // 根据IFFDEL这个milestone来判断是否转变为completed
  679. // if($value['dd_code'] == "IFFAFD"){
  680. // $timezone = $EDI315Time[$value['dd_code']]['timezone'];
  681. // if(empty($timezone)){
  682. // $sql = "select time_zone from public.city_timezone where uncode = '".$value['place_of_delivery_un']."'";
  683. // $timezone = common::excuteOneSql($sql);
  684. // }
  685. // }
  686. }
  687. $Arrived = $value['description'];
  688. $startStation=$value['fport_of_loading_un'];
  689. $endStation=$value['mport_of_discharge_un'];
  690. if ($value['transport_mode'] == "sea"){
  691. $startStation=$value['place_of_receipt_un'];
  692. $endStation=$value['place_of_delivery_un'];
  693. }
  694. if ($value['transport_mode'] == "air"){
  695. $startStation=!empty($ocean['place_of_receipt_un'])? $ocean['place_of_receipt_un'] : $ocean['fport_of_loading_un'];
  696. $endStation=!empty($ocean['place_of_delivery_un']) ? $ocean['place_of_delivery_un'] : $ocean['mport_of_discharge_un'];
  697. }
  698. $RecentStatusList[] = array("Title"=>$value['h_bol'],
  699. "name"=>utils::outDisplayForMerge($value['f_vessel'],$value['f_voyage']),
  700. "bookingNumber" =>$value['booking_no'],
  701. "IsSubscribe" =>false,
  702. "shipperName"=>$value['shipper'],
  703. "consigneeName" =>$value['consignee'],
  704. "startStation"=>$startStation,
  705. "endStation"=>$endStation,
  706. "ETD"=>$value['etd'],
  707. "ETA"=>$value['eta'],
  708. "type"=>$value['new_status'],
  709. "Arrived"=>$Arrived,
  710. "Time"=>$value["act_date"],
  711. "act_time" =>$value["act_time"],
  712. "timezone"=>$timezone,
  713. "_schemas"=>$value["_schemas"],
  714. "transport_mode"=>$value["transport_mode"],
  715. 'is_subscribe' =>common::checkedSubscribe($value['serial_no']),
  716. "a" =>common::deCode($value['serial_no'], 'E'));
  717. }
  718. $data = common::getManagement();
  719. $arrTmp = array('searchData' => $RecentStatusList,
  720. 'Management' => $data['Management'],
  721. 'dashboard_filter' => $data['dashboard_filter'],
  722. 'is_customer' =>_isCustomerLogin(),
  723. 'rc' => $rc,
  724. 'ps' => $ps,
  725. 'cp' => $cp,
  726. 'tp' => $tp);
  727. } else {
  728. $data = common::getManagement();
  729. $arrTmp = array('searchData' => array(),
  730. 'Management' => $data['Management'],
  731. 'dashboard_filter' => $data['dashboard_filter']);
  732. }
  733. common::echo_json_encode(200,$arrTmp);
  734. exit();
  735. break;
  736. case 'save_layout':
  737. $management = json_encode($_POST["management"]);
  738. $dashboard_filter = json_encode($_POST["dashboardObj"]);
  739. $_param = "";
  740. if(!empty($_POST["management"])){
  741. $_param .= " management = '$management' ";
  742. }
  743. if(isset($_POST["dashboardObj"]) && !empty($dashboard_filter)){
  744. $_param .= ",dashboard_filter = '$dashboard_filter' ";
  745. }
  746. if(!empty($_param)){
  747. common::excuteUpdateSql("update public.ra_online_user set $_param where lower(user_login) = '" . strtolower(_getLoginName()) . "'");
  748. }
  749. $returnData = array("msg" => "success");
  750. common::echo_json_encode(200, $returnData);
  751. exit();
  752. break;
  753. case 'password':
  754. tools::getInstance()->updatePassword();
  755. break;
  756. case 'tools':
  757. tools::getInstance()->markSystem();
  758. break;
  759. case 'system_setting':
  760. tools::getInstance()->user_system_setting();
  761. break;
  762. case 'monitoring_setting':
  763. tools::getInstance()->user_monitoring_setting();
  764. break;
  765. case 'notifications_rules':
  766. tools::getInstance()->notifications_rules();
  767. break;
  768. case 'user_guide':
  769. $rootPath = realpath(dirname(__FILE__)) . DS;
  770. //common::download_file($rootPath."images\ACE-M1_ISF_ACI_User_Guide\ACE-M1_ISF_ACI_User_Guide.pdf", "ACE-M1_ISF_ACI_User_Guide_V2.0.pdf");
  771. // PDF文件在服务器上的位置
  772. $filename = $rootPath."userFile". DS."KLN_Online_User_Guide_24.11.26.pdf";
  773. $display_name = "KLN_Online_User_Guide_24_11_26.pdf";
  774. // Header content type
  775. header("Content-type: application/pdf");
  776. header("Content-Length: " . filesize($filename));
  777. header("Content-Disposition:attachment;filename=\"" . $display_name . "\"");
  778. // 将文件发送到浏览器。
  779. readfile($filename);
  780. break;
  781. case 'feature_update':
  782. $id = $_REQUEST["id"];
  783. $rootPath = realpath(dirname(__FILE__)) . DS;
  784. //common::download_file($rootPath."images\ACE-M1_ISF_ACI_User_Guide\ACE-M1_ISF_ACI_User_Guide.pdf", "ACE-M1_ISF_ACI_User_Guide_V2.0.pdf");
  785. // PDF文件在服务器上的位置
  786. $filename = $rootPath."upload". DS."feature_update_".$id.".pdf";
  787. $display_name = "feature_update.pdf";
  788. // Header content type
  789. header("Content-type: application/pdf");
  790. header("Content-Length: " . filesize($filename));
  791. header("Content-Disposition:inline;filename=\"" . $display_name . "\"");
  792. // 将文件发送到浏览器。
  793. readfile($filename);
  794. break;
  795. default:
  796. $data = array(
  797. 'msg' => 'Page not found',
  798. );
  799. common::echo_json_encode(500, $data);
  800. }
  801. $db->Close();
  802. $db = null;
  803. if ($max_ec > 0)
  804. ini_set('max_execution_time', $max_ec); //recover old value
  805. if (!empty($memory_limit))
  806. ini_set('memory_limit', $memory_limit);
  807. ?>