jobinfo.index.1.js 18 KB

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