jobinfo.index.1.js 23 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648
  1. $(function() {
  2. // init date tables
  3. var jobTable = $("#job_list").dataTable({
  4. "deferRender": true,
  5. "processing" : true,
  6. "serverSide": true,
  7. "ajax": {
  8. url: base_url + "/jobinfo/pageList",
  9. type:"post",
  10. data : function ( d ) {
  11. var obj = {};
  12. obj.jobGroup = $('#jobGroup').val();
  13. obj.triggerStatus = $('#triggerStatus').val();
  14. obj.jobDesc = $('#jobDesc').val();
  15. obj.executorHandler = $('#executorHandler').val();
  16. obj.author = $('#author').val();
  17. obj.start = d.start;
  18. obj.length = d.length;
  19. return obj;
  20. }
  21. },
  22. "searching": false,
  23. "ordering": false,
  24. //"scrollX": true, // scroll x,close self-adaption
  25. "columns": [
  26. {
  27. "data": 'id',
  28. "bSortable": false,
  29. "visible" : true,
  30. "width":'7%'
  31. },
  32. {
  33. "data": 'jobGroup',
  34. "visible" : false,
  35. "render": function ( data, type, row ) {
  36. var groupMenu = $("#jobGroup").find("option");
  37. for ( var index in $("#jobGroup").find("option")) {
  38. if ($(groupMenu[index]).attr('value') == data) {
  39. return $(groupMenu[index]).html();
  40. }
  41. }
  42. return data;
  43. }
  44. },
  45. {
  46. "data": 'jobDesc',
  47. "visible" : true,
  48. "width":'25%'
  49. },
  50. {
  51. "data": 'glueType',
  52. "width":'25%',
  53. "visible" : true,
  54. "render": function ( data, type, row ) {
  55. var glueTypeTitle = findGlueTypeTitle(row.glueType);
  56. if (row.executorHandler) {
  57. return glueTypeTitle +":" + row.executorHandler;
  58. } else {
  59. return glueTypeTitle;
  60. }
  61. }
  62. },
  63. { "data": 'executorParam', "visible" : false},
  64. {
  65. "data": 'jobCron',
  66. "visible" : true,
  67. "width":'13%'
  68. },
  69. {
  70. "data": 'addTime',
  71. "visible" : false,
  72. "render": function ( data, type, row ) {
  73. return data?moment(new Date(data)).format("YYYY-MM-DD HH:mm:ss"):"";
  74. }
  75. },
  76. {
  77. "data": 'updateTime',
  78. "visible" : false,
  79. "render": function ( data, type, row ) {
  80. return data?moment(new Date(data)).format("YYYY-MM-DD HH:mm:ss"):"";
  81. }
  82. },
  83. { "data": 'author', "visible" : true, "width":'10%'},
  84. { "data": 'alarmEmail', "visible" : false},
  85. {
  86. "data": 'triggerStatus',
  87. "width":'10%',
  88. "visible" : true,
  89. "render": function ( data, type, row ) {
  90. // status
  91. if (1 == data) {
  92. return '<small class="label label-success" >RUNNING</small>';
  93. } else {
  94. return '<small class="label label-default" >STOP</small>';
  95. }
  96. return data;
  97. }
  98. },
  99. {
  100. "data": I18n.system_opt ,
  101. "width":'10%',
  102. "render": function ( data, type, row ) {
  103. return function(){
  104. // status
  105. var start_stop_div = "";
  106. if (1 == row.triggerStatus ) {
  107. start_stop_div = '<li><a href="javascript:void(0);" class="job_operate" _type="job_pause" >'+ I18n.jobinfo_opt_stop +'</a></li>\n';
  108. } else {
  109. start_stop_div = '<li><a href="javascript:void(0);" class="job_operate" _type="job_resume" >'+ I18n.jobinfo_opt_start +'</a></li>\n';
  110. }
  111. // log url
  112. var logHref = base_url +'/joblog?jobId='+ row.id;
  113. // log url
  114. var codeBtn = "";
  115. if ('BEAN' != row.glueType) {
  116. var codeUrl = base_url +'/jobcode?jobId='+ row.id;
  117. codeBtn = '<li><a href="'+ codeUrl +'" target="_blank" >GLUE IDE</a></li>\n';
  118. codeBtn += '<li class="divider"></li>\n';
  119. }
  120. // data
  121. tableData['key'+row.id] = row;
  122. // opt
  123. var html = '<div class="btn-group">\n' +
  124. ' <button type="button" class="btn btn-primary btn-sm">'+ I18n.system_opt +'</button>\n' +
  125. ' <button type="button" class="btn btn-primary btn-sm dropdown-toggle" data-toggle="dropdown">\n' +
  126. ' <span class="caret"></span>\n' +
  127. ' <span class="sr-only">Toggle Dropdown</span>\n' +
  128. ' </button>\n' +
  129. ' <ul class="dropdown-menu" role="menu" _id="'+ row.id +'" >\n' +
  130. ' <li><a href="javascript:void(0);" class="job_trigger" >'+ I18n.jobinfo_opt_run +'</a></li>\n' +
  131. ' <li><a href="'+ logHref +'">'+ I18n.jobinfo_opt_log +'</a></li>\n' +
  132. ' <li><a href="javascript:void(0);" class="job_registryinfo" >' + I18n.jobinfo_opt_registryinfo + '</a></li>\n' +
  133. ' <li><a href="javascript:void(0);" class="job_next_time" >' + I18n.jobinfo_opt_next_time + '</a></li>\n' +
  134. ' <li class="divider"></li>\n' +
  135. codeBtn +
  136. start_stop_div +
  137. ' <li><a href="javascript:void(0);" class="update" >'+ I18n.system_opt_edit +'</a></li>\n' +
  138. ' <li><a href="javascript:void(0);" class="job_operate" _type="job_del" >'+ I18n.system_opt_del +'</a></li>\n' +
  139. ' </ul>\n' +
  140. ' </div>';
  141. return html;
  142. };
  143. }
  144. }
  145. ],
  146. "language" : {
  147. "sProcessing" : I18n.dataTable_sProcessing ,
  148. "sLengthMenu" : I18n.dataTable_sLengthMenu ,
  149. "sZeroRecords" : I18n.dataTable_sZeroRecords ,
  150. "sInfo" : I18n.dataTable_sInfo ,
  151. "sInfoEmpty" : I18n.dataTable_sInfoEmpty ,
  152. "sInfoFiltered" : I18n.dataTable_sInfoFiltered ,
  153. "sInfoPostFix" : "",
  154. "sSearch" : I18n.dataTable_sSearch ,
  155. "sUrl" : "",
  156. "sEmptyTable" : I18n.dataTable_sEmptyTable ,
  157. "sLoadingRecords" : I18n.dataTable_sLoadingRecords ,
  158. "sInfoThousands" : ",",
  159. "oPaginate" : {
  160. "sFirst" : I18n.dataTable_sFirst ,
  161. "sPrevious" : I18n.dataTable_sPrevious ,
  162. "sNext" : I18n.dataTable_sNext ,
  163. "sLast" : I18n.dataTable_sLast
  164. },
  165. "oAria" : {
  166. "sSortAscending" : I18n.dataTable_sSortAscending ,
  167. "sSortDescending" : I18n.dataTable_sSortDescending
  168. }
  169. }
  170. });
  171. // table data
  172. var tableData = {};
  173. // search btn
  174. $('#searchBtn').on('click', function(){
  175. jobTable.fnDraw();
  176. });
  177. // jobGroup change
  178. $('#jobGroup').on('change', function(){
  179. //reload
  180. var jobGroup = $('#jobGroup').val();
  181. window.location.href = base_url + "/jobinfo?jobGroup=" + jobGroup;
  182. });
  183. // job operate
  184. $("#job_list").on('click', '.job_operate',function() {
  185. var typeName;
  186. var url;
  187. var needFresh = false;
  188. var type = $(this).attr("_type");
  189. if ("job_pause" == type) {
  190. typeName = I18n.jobinfo_opt_stop ;
  191. url = base_url + "/jobinfo/stop";
  192. needFresh = true;
  193. } else if ("job_resume" == type) {
  194. typeName = I18n.jobinfo_opt_start ;
  195. url = base_url + "/jobinfo/start";
  196. needFresh = true;
  197. } else if ("job_del" == type) {
  198. typeName = I18n.system_opt_del ;
  199. url = base_url + "/jobinfo/remove";
  200. needFresh = true;
  201. } else {
  202. return;
  203. }
  204. var id = $(this).parents('ul').attr("_id");
  205. layer.confirm( I18n.system_ok + typeName + '?', {
  206. icon: 3,
  207. title: I18n.system_tips ,
  208. btn: [ I18n.system_ok, I18n.system_cancel ]
  209. }, function(index){
  210. layer.close(index);
  211. $.ajax({
  212. type : 'POST',
  213. url : url,
  214. data : {
  215. "id" : id
  216. },
  217. dataType : "json",
  218. success : function(data){
  219. if (data.code == 200) {
  220. layer.msg( typeName + I18n.system_success );
  221. if (needFresh) {
  222. //window.location.reload();
  223. jobTable.fnDraw(false);
  224. }
  225. } else {
  226. layer.msg( data.msg || typeName + I18n.system_fail );
  227. }
  228. }
  229. });
  230. });
  231. });
  232. // job trigger
  233. $("#job_list").on('click', '.job_trigger',function() {
  234. var id = $(this).parents('ul').attr("_id");
  235. var row = tableData['key'+id];
  236. $("#jobTriggerModal .form input[name='id']").val( row.id );
  237. $("#jobTriggerModal .form textarea[name='executorParam']").val( row.executorParam );
  238. $('#jobTriggerModal').modal({backdrop: false, keyboard: false}).modal('show');
  239. });
  240. $("#jobTriggerModal .ok").on('click',function() {
  241. $.ajax({
  242. type : 'POST',
  243. url : base_url + "/jobinfo/trigger",
  244. data : {
  245. "id" : $("#jobTriggerModal .form input[name='id']").val(),
  246. "executorParam" : $("#jobTriggerModal .textarea[name='executorParam']").val()
  247. },
  248. dataType : "json",
  249. success : function(data){
  250. if (data.code == 200) {
  251. $('#jobTriggerModal').modal('hide');
  252. layer.msg( I18n.jobinfo_opt_run + I18n.system_success );
  253. } else {
  254. layer.msg( data.msg || I18n.jobinfo_opt_run + I18n.system_fail );
  255. }
  256. }
  257. });
  258. });
  259. $("#jobTriggerModal").on('hide.bs.modal', function () {
  260. $("#jobTriggerModal .form")[0].reset();
  261. });
  262. // job registryinfo
  263. $("#job_list").on('click', '.job_registryinfo',function() {
  264. var id = $(this).parents('ul').attr("_id");
  265. var row = tableData['key'+id];
  266. var jobGroup = row.jobGroup;
  267. $.ajax({
  268. type : 'POST',
  269. url : base_url + "/jobgroup/loadById",
  270. data : {
  271. "id" : jobGroup
  272. },
  273. dataType : "json",
  274. success : function(data){
  275. var html = '<center>';
  276. if (data.code == 200 && data.content.registryList) {
  277. for (var index in data.content.registryList) {
  278. html += '<span class="badge bg-green" >' + data.content.registryList[index] + '</span><br>';
  279. }
  280. }
  281. html += '</center>';
  282. layer.open({
  283. title: I18n.jobinfo_opt_registryinfo ,
  284. btn: [ I18n.system_ok ],
  285. content: html
  286. });
  287. }
  288. });
  289. });
  290. // job_next_time
  291. $("#job_list").on('click', '.job_next_time',function() {
  292. var id = $(this).parents('ul').attr("_id");
  293. var row = tableData['key'+id];
  294. var jobCron = row.jobCron;
  295. $.ajax({
  296. type : 'POST',
  297. url : base_url + "/jobinfo/nextTriggerTime",
  298. data : {
  299. "cron" : jobCron
  300. },
  301. dataType : "json",
  302. success : function(data){
  303. if (data.code != 200) {
  304. layer.open({
  305. title: I18n.jobinfo_opt_next_time ,
  306. btn: [ I18n.system_ok ],
  307. content: data.msg
  308. });
  309. } else {
  310. var html = '<center>';
  311. if (data.code == 200 && data.content) {
  312. for (var index in data.content) {
  313. html += '<span>' + data.content[index] + '</span><br>';
  314. }
  315. }
  316. html += '</center>';
  317. layer.open({
  318. title: I18n.jobinfo_opt_next_time ,
  319. btn: [ I18n.system_ok ],
  320. content: html
  321. });
  322. }
  323. }
  324. });
  325. });
  326. // add
  327. $(".add").click(function(){
  328. // init-cronGen
  329. $("#addModal .form input[name='jobCron']").show().siblings().remove();
  330. $("#addModal .form input[name='jobCron']").cronGen({});
  331. $('#addModal').modal({backdrop: false, keyboard: false}).modal('show');
  332. });
  333. var addModalValidate = $("#addModal .form").validate({
  334. errorElement : 'span',
  335. errorClass : 'help-block',
  336. focusInvalid : true,
  337. rules : {
  338. jobDesc : {
  339. required : true,
  340. maxlength: 50
  341. },
  342. jobCron : {
  343. required : true
  344. },
  345. author : {
  346. required : true
  347. },
  348. executorTimeout : {
  349. digits:true
  350. },
  351. executorFailRetryCount : {
  352. digits:true
  353. }
  354. },
  355. messages : {
  356. jobDesc : {
  357. required : I18n.system_please_input + I18n.jobinfo_field_jobdesc
  358. },
  359. jobCron : {
  360. required : I18n.system_please_input + "Cron"
  361. },
  362. author : {
  363. required : I18n.system_please_input + I18n.jobinfo_field_author
  364. },
  365. executorTimeout : {
  366. digits: I18n.system_please_input + I18n.system_digits
  367. },
  368. executorFailRetryCount : {
  369. digits: I18n.system_please_input + I18n.system_digits
  370. }
  371. },
  372. highlight : function(element) {
  373. $(element).closest('.form-group').addClass('has-error');
  374. },
  375. success : function(label) {
  376. label.closest('.form-group').removeClass('has-error');
  377. label.remove();
  378. },
  379. errorPlacement : function(error, element) {
  380. element.parent('div').append(error);
  381. },
  382. submitHandler : function(form) {
  383. // process
  384. var executorTimeout = $("#addModal .form input[name='executorTimeout']").val();
  385. if(!/^\d+$/.test(executorTimeout)) {
  386. executorTimeout = 0;
  387. }
  388. $("#addModal .form input[name='executorTimeout']").val(executorTimeout);
  389. var executorFailRetryCount = $("#addModal .form input[name='executorFailRetryCount']").val();
  390. if(!/^\d+$/.test(executorFailRetryCount)) {
  391. executorFailRetryCount = 0;
  392. }
  393. $("#addModal .form input[name='executorFailRetryCount']").val(executorFailRetryCount);
  394. // process-cronGen
  395. $("#addModal .form input[name='jobCron']").val( $("#addModal .form input[name='cronGen_display']").val() );
  396. $.post(base_url + "/jobinfo/add", $("#addModal .form").serialize(), function(data, status) {
  397. if (data.code == "200") {
  398. $('#addModal').modal('hide');
  399. layer.open({
  400. title: I18n.system_tips ,
  401. btn: [ I18n.system_ok ],
  402. content: I18n.system_add_suc ,
  403. icon: '1',
  404. end: function(layero, index){
  405. jobTable.fnDraw();
  406. //window.location.reload();
  407. }
  408. });
  409. } else {
  410. layer.open({
  411. title: I18n.system_tips ,
  412. btn: [ I18n.system_ok ],
  413. content: (data.msg || I18n.system_add_fail),
  414. icon: '2'
  415. });
  416. }
  417. });
  418. }
  419. });
  420. $("#addModal").on('hide.bs.modal', function () {
  421. addModalValidate.resetForm();
  422. $("#addModal .form")[0].reset();
  423. $("#addModal .form .form-group").removeClass("has-error");
  424. $(".remote_panel").show(); // remote
  425. $("#addModal .form input[name='executorHandler']").removeAttr("readonly");
  426. });
  427. // glueType change
  428. $(".glueType").change(function(){
  429. // executorHandler
  430. var $executorHandler = $(this).parents("form").find("input[name='executorHandler']");
  431. var glueType = $(this).val();
  432. if ('BEAN' != glueType) {
  433. $executorHandler.val("");
  434. $executorHandler.attr("readonly","readonly");
  435. } else {
  436. $executorHandler.removeAttr("readonly");
  437. }
  438. });
  439. $("#addModal .glueType").change(function(){
  440. // glueSource
  441. var glueType = $(this).val();
  442. if ('GLUE_GROOVY'==glueType){
  443. $("#addModal .form textarea[name='glueSource']").val( $("#addModal .form .glueSource_java").val() );
  444. } else if ('GLUE_SHELL'==glueType){
  445. $("#addModal .form textarea[name='glueSource']").val( $("#addModal .form .glueSource_shell").val() );
  446. } else if ('GLUE_PYTHON'==glueType){
  447. $("#addModal .form textarea[name='glueSource']").val( $("#addModal .form .glueSource_python").val() );
  448. } else if ('GLUE_PHP'==glueType){
  449. $("#addModal .form textarea[name='glueSource']").val( $("#addModal .form .glueSource_php").val() );
  450. } else if ('GLUE_NODEJS'==glueType){
  451. $("#addModal .form textarea[name='glueSource']").val( $("#addModal .form .glueSource_nodejs").val() );
  452. } else if ('GLUE_POWERSHELL'==glueType){
  453. $("#addModal .form textarea[name='glueSource']").val( $("#addModal .form .glueSource_powershell").val() );
  454. } else {
  455. $("#addModal .form textarea[name='glueSource']").val("");
  456. }
  457. });
  458. // update
  459. $("#job_list").on('click', '.update',function() {
  460. var id = $(this).parents('ul').attr("_id");
  461. var row = tableData['key'+id];
  462. // base data
  463. $("#updateModal .form input[name='id']").val( row.id );
  464. $('#updateModal .form select[name=jobGroup] option[value='+ row.jobGroup +']').prop('selected', true);
  465. $("#updateModal .form input[name='jobDesc']").val( row.jobDesc );
  466. $("#updateModal .form input[name='jobCron']").val( row.jobCron );
  467. $("#updateModal .form input[name='author']").val( row.author );
  468. $("#updateModal .form input[name='alarmEmail']").val( row.alarmEmail );
  469. $("#updateModal .form input[name='executorTimeout']").val( row.executorTimeout );
  470. $("#updateModal .form input[name='executorFailRetryCount']").val( row.executorFailRetryCount );
  471. $('#updateModal .form select[name=executorRouteStrategy] option[value='+ row.executorRouteStrategy +']').prop('selected', true);
  472. $("#updateModal .form input[name='executorHandler']").val( row.executorHandler );
  473. $("#updateModal .form textarea[name='executorParam']").val( row.executorParam );
  474. $("#updateModal .form input[name='childJobId']").val( row.childJobId );
  475. $('#updateModal .form select[name=executorBlockStrategy] option[value='+ row.executorBlockStrategy +']').prop('selected', true);
  476. $('#updateModal .form select[name=glueType] option[value='+ row.glueType +']').prop('selected', true);
  477. $("#updateModal .form select[name=glueType]").change();
  478. // init-cronGen
  479. $("#updateModal .form input[name='jobCron']").show().siblings().remove();
  480. $("#updateModal .form input[name='jobCron']").cronGen({});
  481. // show
  482. $('#updateModal').modal({backdrop: false, keyboard: false}).modal('show');
  483. });
  484. var updateModalValidate = $("#updateModal .form").validate({
  485. errorElement : 'span',
  486. errorClass : 'help-block',
  487. focusInvalid : true,
  488. rules : {
  489. jobDesc : {
  490. required : true,
  491. maxlength: 50
  492. },
  493. jobCron : {
  494. required : true
  495. },
  496. author : {
  497. required : true
  498. },
  499. executorTimeout : {
  500. digits:true
  501. },
  502. executorFailRetryCount : {
  503. digits:true
  504. }
  505. },
  506. messages : {
  507. jobDesc : {
  508. required : I18n.system_please_input + I18n.jobinfo_field_jobdesc
  509. },
  510. jobCron : {
  511. required : I18n.system_please_input + "Cron"
  512. },
  513. author : {
  514. required : I18n.system_please_input + I18n.jobinfo_field_author
  515. },
  516. executorTimeout : {
  517. digits: I18n.system_please_input + I18n.system_digits
  518. },
  519. executorFailRetryCount : {
  520. digits: I18n.system_please_input + I18n.system_digits
  521. }
  522. },
  523. highlight : function(element) {
  524. $(element).closest('.form-group').addClass('has-error');
  525. },
  526. success : function(label) {
  527. label.closest('.form-group').removeClass('has-error');
  528. label.remove();
  529. },
  530. errorPlacement : function(error, element) {
  531. element.parent('div').append(error);
  532. },
  533. submitHandler : function(form) {
  534. // process
  535. var executorTimeout = $("#updateModal .form input[name='executorTimeout']").val();
  536. if(!/^\d+$/.test(executorTimeout)) {
  537. executorTimeout = 0;
  538. }
  539. $("#updateModal .form input[name='executorTimeout']").val(executorTimeout);
  540. var executorFailRetryCount = $("#updateModal .form input[name='executorFailRetryCount']").val();
  541. if(!/^\d+$/.test(executorFailRetryCount)) {
  542. executorFailRetryCount = 0;
  543. }
  544. $("#updateModal .form input[name='executorFailRetryCount']").val(executorFailRetryCount);
  545. // process-cronGen
  546. $("#updateModal .form input[name='jobCron']").val( $("#updateModal .form input[name='cronGen_display']").val() );
  547. // post
  548. $.post(base_url + "/jobinfo/update", $("#updateModal .form").serialize(), function(data, status) {
  549. if (data.code == "200") {
  550. $('#updateModal').modal('hide');
  551. layer.open({
  552. title: I18n.system_tips ,
  553. btn: [ I18n.system_ok ],
  554. content: I18n.system_update_suc ,
  555. icon: '1',
  556. end: function(layero, index){
  557. //window.location.reload();
  558. jobTable.fnDraw();
  559. }
  560. });
  561. } else {
  562. layer.open({
  563. title: I18n.system_tips ,
  564. btn: [ I18n.system_ok ],
  565. content: (data.msg || I18n.system_update_fail ),
  566. icon: '2'
  567. });
  568. }
  569. });
  570. }
  571. });
  572. $("#updateModal").on('hide.bs.modal', function () {
  573. updateModalValidate.resetForm();
  574. $("#updateModal .form")[0].reset();
  575. $("#updateModal .form .form-group").removeClass("has-error");
  576. });
  577. /**
  578. * find title by name, GlueType
  579. */
  580. function findGlueTypeTitle(glueType) {
  581. var glueTypeTitle;
  582. $("#addModal .form select[name=glueType] option").each(function () {
  583. var name = $(this).val();
  584. var title = $(this).text();
  585. if (glueType == name) {
  586. glueTypeTitle = title;
  587. return false
  588. }
  589. });
  590. return glueTypeTitle;
  591. }
  592. });