joblog.detail.1.js 2.7 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889
  1. $(function() {
  2. // trigger fail, end
  3. if ( !(triggerCode == 200 || handleCode != 0) ) {
  4. $('#logConsoleRunning').hide();
  5. $('#logConsole').append('<span style="color: red;">'+ I18n.joblog_rolling_log_triggerfail +'</span>');
  6. return;
  7. }
  8. // pull log
  9. var fromLineNum = 1; // [from, to], start as 1
  10. var pullFailCount = 0;
  11. function pullLog() {
  12. // pullFailCount, max=20
  13. if (pullFailCount++ > 20) {
  14. logRunStop('<span style="color: red;">'+ I18n.joblog_rolling_log_failoften +'</span>');
  15. return;
  16. }
  17. // load
  18. console.log("pullLog, fromLineNum:" + fromLineNum);
  19. $.ajax({
  20. type : 'POST',
  21. async: false, // sync, make log ordered
  22. url : base_url + '/joblog/logDetailCat',
  23. data : {
  24. "logId":logId,
  25. "fromLineNum":fromLineNum
  26. },
  27. dataType : "json",
  28. success : function(data){
  29. if (data.code == 200) {
  30. if (!data.content) {
  31. console.log('pullLog fail');
  32. return;
  33. }
  34. if (fromLineNum != data.content.fromLineNum) {
  35. console.log('pullLog fromLineNum not match');
  36. return;
  37. }
  38. if (fromLineNum > data.content.toLineNum ) {
  39. console.log('pullLog already line-end');
  40. // valid end
  41. if (data.content.end) {
  42. logRunStop('<br><span style="color: green;">[Rolling Log Finish]</span>');
  43. return;
  44. }
  45. return;
  46. }
  47. // append content
  48. fromLineNum = data.content.toLineNum + 1;
  49. $('#logConsole').append(data.content.logContent);
  50. pullFailCount = 0;
  51. // scroll to bottom
  52. scrollTo(0, document.body.scrollHeight); // $('#logConsolePre').scrollTop( document.body.scrollHeight + 300 );
  53. } else {
  54. console.log('pullLog fail:'+data.msg);
  55. }
  56. }
  57. });
  58. }
  59. // pull first page
  60. pullLog();
  61. // handler already callback, end
  62. if (handleCode > 0) {
  63. logRunStop('<br><span style="color: green;">[Load Log Finish]</span>');
  64. return;
  65. }
  66. // round until end
  67. var logRun = setInterval(function () {
  68. pullLog()
  69. }, 3000);
  70. function logRunStop(content){
  71. $('#logConsoleRunning').hide();
  72. logRun = window.clearInterval(logRun);
  73. $('#logConsole').append(content);
  74. }
  75. });