jobinfo.index.1.js 15 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443
  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.executorHandler = $('#executorHandler').val();
  14. obj.start = d.start;
  15. obj.length = d.length;
  16. return obj;
  17. }
  18. },
  19. "searching": false,
  20. "ordering": false,
  21. //"scrollX": true, // X轴滚动条,取消自适应
  22. "columns": [
  23. { "data": 'id', "bSortable": false, "visible" : false},
  24. {
  25. "data": 'jobGroup',
  26. "visible" : false,
  27. "render": function ( data, type, row ) {
  28. var groupMenu = $("#jobGroup").find("option");
  29. for ( var index in $("#jobGroup").find("option")) {
  30. if ($(groupMenu[index]).attr('value') == data) {
  31. return $(groupMenu[index]).html();
  32. }
  33. }
  34. return data;
  35. }
  36. },
  37. {
  38. "data": 'childJobKey',
  39. "visible" : true,
  40. "render": function ( data, type, row ) {
  41. var jobKey = row.jobGroup + "_" + row.id;
  42. return jobKey;
  43. }
  44. },
  45. { "data": 'jobDesc', "visible" : true},
  46. { "data": 'jobCron', "visible" : true},
  47. {
  48. "data": 'executorHandler',
  49. "visible" : true,
  50. "render": function ( data, type, row ) {
  51. return (row.glueSwitch > 0)? "GLUE模式" : data;
  52. }
  53. },
  54. { "data": 'executorParam', "visible" : false},
  55. {
  56. "data": 'addTime',
  57. "visible" : false,
  58. "render": function ( data, type, row ) {
  59. return data?moment(new Date(data)).format("YYYY-MM-DD HH:mm:ss"):"";
  60. }
  61. },
  62. {
  63. "data": 'updateTime',
  64. "visible" : false,
  65. "render": function ( data, type, row ) {
  66. return data?moment(new Date(data)).format("YYYY-MM-DD HH:mm:ss"):"";
  67. }
  68. },
  69. { "data": 'author', "visible" : true},
  70. { "data": 'alarmEmail', "visible" : false},
  71. { "data": 'glueSwitch', "visible" : false},
  72. {
  73. "data": 'jobStatus',
  74. "visible" : true,
  75. "render": function ( data, type, row ) {
  76. if ('NORMAL' == data) {
  77. return '<small class="label label-success" ><i class="fa fa-clock-o"></i>'+ data +'</small>';
  78. } else if ('PAUSED' == data || 'NONE' == data){
  79. return '<small class="label label-default" title="暂停" ><i class="fa fa-clock-o"></i>'+ data +'</small>';
  80. } else if ('BLOCKED' == data){
  81. return '<small class="label label-default" title="阻塞[串行]" ><i class="fa fa-clock-o"></i>'+ data +'</small>';
  82. }
  83. return data;
  84. }
  85. },
  86. { "data": '操作' ,
  87. "render": function ( data, type, row ) {
  88. return function(){
  89. // status
  90. var pause_resume = "";
  91. if ('NORMAL' == row.jobStatus) {
  92. pause_resume = '<button class="btn btn-primary btn-xs job_operate" type="job_pause" type="button">暂停</button> ';
  93. } else if ('PAUSED' == row.jobStatus || 'NONE' == row.jobStatus){
  94. pause_resume = '<button class="btn btn-primary btn-xs job_operate" type="job_resume" type="button">恢复</button> ';
  95. }
  96. // log url
  97. var logUrl = base_url +'/joblog?jobId='+ row.id;
  98. // log url
  99. var codeBtn = "";
  100. if(row.glueSwitch > 0){
  101. var codeUrl = base_url +'/jobcode?jobId='+ row.id;
  102. codeBtn = '<button class="btn btn-warning btn-xs" type="button" onclick="javascript:window.open(\'' + codeUrl + '\')" >GLUE</button> '
  103. }
  104. // html
  105. var html = '<p id="'+ row.id +'" '+
  106. ' jobGroup="'+ row.jobGroup +'" '+
  107. ' jobCron="'+ row.jobCron +'" '+
  108. ' jobDesc="'+ row.jobDesc +'" '+
  109. ' author="'+ row.author +'" '+
  110. ' alarmEmail="'+ row.alarmEmail +'" '+
  111. ' executorRouteStrategy="'+row.executorRouteStrategy +'" '+
  112. ' executorHandler="'+row.executorHandler +'" '+
  113. ' executorParam="'+ row.executorParam +'" '+
  114. ' glueSwitch="'+ row.glueSwitch +'" '+
  115. ' childJobKey="'+ row.childJobKey +'" '+
  116. '>'+
  117. '<button class="btn btn-primary btn-xs job_operate" type="job_trigger" type="button">执行</button> '+
  118. pause_resume +
  119. '<button class="btn btn-primary btn-xs" type="job_del" type="button" onclick="javascript:window.open(\'' + logUrl + '\')" >日志</button><br> '+
  120. '<button class="btn btn-warning btn-xs update" type="button">编辑</button> '+
  121. codeBtn +
  122. '<button class="btn btn-danger btn-xs job_operate" type="job_del" type="button">删除</button> '+
  123. '</p>';
  124. return html;
  125. };
  126. }
  127. }
  128. ],
  129. "language" : {
  130. "sProcessing" : "处理中...",
  131. "sLengthMenu" : "每页 _MENU_ 条记录",
  132. "sZeroRecords" : "没有匹配结果",
  133. "sInfo" : "第 _PAGE_ 页 ( 总共 _PAGES_ 页 )",
  134. "sInfoEmpty" : "无记录",
  135. "sInfoFiltered" : "(由 _MAX_ 项结果过滤)",
  136. "sInfoPostFix" : "",
  137. "sSearch" : "搜索:",
  138. "sUrl" : "",
  139. "sEmptyTable" : "表中数据为空",
  140. "sLoadingRecords" : "载入中...",
  141. "sInfoThousands" : ",",
  142. "oPaginate" : {
  143. "sFirst" : "首页",
  144. "sPrevious" : "上页",
  145. "sNext" : "下页",
  146. "sLast" : "末页"
  147. },
  148. "oAria" : {
  149. "sSortAscending" : ": 以升序排列此列",
  150. "sSortDescending" : ": 以降序排列此列"
  151. }
  152. }
  153. });
  154. // 搜索按钮
  155. $('#searchBtn').on('click', function(){
  156. jobTable.fnDraw();
  157. });
  158. // job operate
  159. $("#job_list").on('click', '.job_operate',function() {
  160. var typeName;
  161. var url;
  162. var needFresh = false;
  163. var type = $(this).attr("type");
  164. if ("job_pause" == type) {
  165. typeName = "暂停";
  166. url = base_url + "/jobinfo/pause";
  167. needFresh = true;
  168. } else if ("job_resume" == type) {
  169. typeName = "恢复";
  170. url = base_url + "/jobinfo/resume";
  171. needFresh = true;
  172. } else if ("job_del" == type) {
  173. typeName = "删除";
  174. url = base_url + "/jobinfo/remove";
  175. needFresh = true;
  176. } else if ("job_trigger" == type) {
  177. typeName = "执行";
  178. url = base_url + "/jobinfo/trigger";
  179. } else {
  180. return;
  181. }
  182. var id = $(this).parent('p').attr("id");
  183. ComConfirm.show("确认" + typeName + "?", function(){
  184. $.ajax({
  185. type : 'POST',
  186. url : url,
  187. data : {
  188. "id" : id
  189. },
  190. dataType : "json",
  191. success : function(data){
  192. if (data.code == 200) {
  193. ComAlert.show(1, typeName + "成功", function(){
  194. if (needFresh) {
  195. //window.location.reload();
  196. jobTable.fnDraw();
  197. }
  198. });
  199. } else {
  200. ComAlert.show(1, typeName + "失败");
  201. }
  202. },
  203. });
  204. });
  205. });
  206. // jquery.validate 自定义校验 “英文字母开头,只含有英文字母、数字和下划线”
  207. jQuery.validator.addMethod("myValid01", function(value, element) {
  208. var length = value.length;
  209. var valid = /^[a-zA-Z][a-zA-Z0-9_]*$/;
  210. return this.optional(element) || valid.test(value);
  211. }, "只支持英文字母开头,只含有英文字母、数字和下划线");
  212. // 新增
  213. $(".add").click(function(){
  214. $('#addModal').modal({backdrop: false, keyboard: false}).modal('show');
  215. });
  216. var addModalValidate = $("#addModal .form").validate({
  217. errorElement : 'span',
  218. errorClass : 'help-block',
  219. focusInvalid : true,
  220. rules : {
  221. jobDesc : {
  222. required : true,
  223. maxlength: 50
  224. },
  225. jobCron : {
  226. required : true
  227. },
  228. executorHandler : {
  229. required : false
  230. },
  231. alarmEmail : {
  232. required : true
  233. },
  234. author : {
  235. required : true
  236. }
  237. },
  238. messages : {
  239. jobDesc : {
  240. required :"请输入“描述”."
  241. },
  242. jobCron : {
  243. required :"请输入“Cron”."
  244. },
  245. executorHandler : {
  246. required : "请输入“jobHandler”."
  247. },
  248. alarmEmail : {
  249. required : "请输入“报警邮件”."
  250. },
  251. author : {
  252. required : "请输入“负责人”."
  253. }
  254. },
  255. highlight : function(element) {
  256. $(element).closest('.form-group').addClass('has-error');
  257. },
  258. success : function(label) {
  259. label.closest('.form-group').removeClass('has-error');
  260. label.remove();
  261. },
  262. errorPlacement : function(error, element) {
  263. element.parent('div').append(error);
  264. },
  265. submitHandler : function(form) {
  266. $.post(base_url + "/jobinfo/add", $("#addModal .form").serialize(), function(data, status) {
  267. if (data.code == "200") {
  268. $('#addModal').modal('hide');
  269. setTimeout(function () {
  270. ComAlert.show(1, "新增任务成功", function(){
  271. jobTable.fnDraw();
  272. //window.location.reload();
  273. });
  274. }, 315);
  275. } else {
  276. if (data.msg) {
  277. ComAlert.show(2, data.msg);
  278. } else {
  279. ComAlert.show(2, "新增失败");
  280. }
  281. }
  282. });
  283. }
  284. });
  285. $("#addModal").on('hide.bs.modal', function () {
  286. $("#addModal .form")[0].reset();
  287. addModalValidate.resetForm();
  288. $("#addModal .form .form-group").removeClass("has-error");
  289. $(".remote_panel").show(); // remote
  290. $("#addModal .form input[name='executorHandler']").removeAttr("readonly");
  291. });
  292. // GLUE模式开启
  293. $(".ifGLUE").click(function(){
  294. var ifGLUE = $(this).is(':checked');
  295. var $executorHandler = $(this).parents("form").find("input[name='executorHandler']");
  296. var $glueSwitch = $(this).parents("form").find("input[name='glueSwitch']");
  297. if (ifGLUE) {
  298. $executorHandler.val("");
  299. $executorHandler.attr("readonly","readonly");
  300. $glueSwitch.val(1);
  301. } else {
  302. $executorHandler.removeAttr("readonly");
  303. $glueSwitch.val(0);
  304. }
  305. });
  306. // 更新
  307. $("#job_list").on('click', '.update',function() {
  308. // base data
  309. $("#updateModal .form input[name='id']").val($(this).parent('p').attr("id"));
  310. $('#updateModal .form select[name=jobGroup] option[value='+ $(this).parent('p').attr("jobGroup") +']').prop('selected', true);
  311. $("#updateModal .form input[name='jobDesc']").val($(this).parent('p').attr("jobDesc"));
  312. $("#updateModal .form input[name='jobCron']").val($(this).parent('p').attr("jobCron"));
  313. $("#updateModal .form input[name='author']").val($(this).parent('p').attr("author"));
  314. $("#updateModal .form input[name='alarmEmail']").val($(this).parent('p').attr("alarmEmail"));
  315. $('#updateModal .form select[name=executorRouteStrategy] option[value='+ $(this).parent('p').attr("executorRouteStrategy") +']').prop('selected', true);
  316. $("#updateModal .form input[name='executorHandler']").val($(this).parent('p').attr("executorHandler"));
  317. $("#updateModal .form input[name='executorParam']").val($(this).parent('p').attr("executorParam"));
  318. $("#updateModal .form input[name='childJobKey']").val($(this).parent('p').attr("childJobKey"));
  319. // glueSwitch
  320. var glueSwitch = $(this).parent('p').attr("glueSwitch");
  321. $("#updateModal .form input[name='glueSwitch']").val(glueSwitch);
  322. var $ifGLUE = $("#updateModal .form .ifGLUE");
  323. var $executorHandler = $("#updateModal .form input[name='executorHandler']");
  324. if (glueSwitch == 1) {
  325. $ifGLUE.attr("checked", true);
  326. $executorHandler.val("");
  327. $executorHandler.attr("readonly","readonly");
  328. } else {
  329. $ifGLUE.attr("checked", false);
  330. $executorHandler.removeAttr("readonly");
  331. }
  332. // show
  333. $('#updateModal').modal({backdrop: false, keyboard: false}).modal('show');
  334. });
  335. var updateModalValidate = $("#updateModal .form").validate({
  336. errorElement : 'span',
  337. errorClass : 'help-block',
  338. focusInvalid : true,
  339. rules : {
  340. jobDesc : {
  341. required : true,
  342. maxlength: 50
  343. },
  344. jobCron : {
  345. required : true
  346. },
  347. executorHandler : {
  348. required : false
  349. },
  350. alarmEmail : {
  351. required : true
  352. },
  353. author : {
  354. required : true
  355. }
  356. },
  357. messages : {
  358. jobDesc : {
  359. required :"请输入“描述”."
  360. },
  361. jobCron : {
  362. required :"请输入“Cron”."
  363. },
  364. executorHandler : {
  365. required : "请输入“jobHandler”."
  366. },
  367. alarmEmail : {
  368. required : "请输入“报警邮件”."
  369. },
  370. author : {
  371. required : "请输入“负责人”."
  372. }
  373. },
  374. highlight : function(element) {
  375. $(element).closest('.form-group').addClass('has-error');
  376. },
  377. success : function(label) {
  378. label.closest('.form-group').removeClass('has-error');
  379. label.remove();
  380. },
  381. errorPlacement : function(error, element) {
  382. element.parent('div').append(error);
  383. },
  384. submitHandler : function(form) {
  385. // post
  386. $.post(base_url + "/jobinfo/reschedule", $("#updateModal .form").serialize(), function(data, status) {
  387. if (data.code == "200") {
  388. $('#updateModal').modal('hide');
  389. setTimeout(function () {
  390. ComAlert.show(1, "更新成功", function(){
  391. //window.location.reload();
  392. jobTable.fnDraw();
  393. });
  394. }, 315);
  395. } else {
  396. if (data.msg) {
  397. ComAlert.show(2, data.msg);
  398. } else {
  399. ComAlert.show(2, "更新失败");
  400. }
  401. }
  402. });
  403. }
  404. });
  405. $("#updateModal").on('hide.bs.modal', function () {
  406. $("#updateModal .form")[0].reset()
  407. });
  408. /*
  409. // 新增-添加参数
  410. $("#addModal .addParam").on('click', function () {
  411. var html = '<div class="form-group newParam">'+
  412. '<label for="lastname" class="col-sm-2 control-label">参数&nbsp;<button class="btn btn-danger btn-xs removeParam" type="button">移除</button></label>'+
  413. '<div class="col-sm-4"><input type="text" class="form-control" name="key" placeholder="请输入参数key[将会强转为String]" maxlength="200" /></div>'+
  414. '<div class="col-sm-6"><input type="text" class="form-control" name="value" placeholder="请输入参数value[将会强转为String]" maxlength="200" /></div>'+
  415. '</div>';
  416. $(this).parents('.form-group').parent().append(html);
  417. $("#addModal .removeParam").on('click', function () {
  418. $(this).parents('.form-group').remove();
  419. });
  420. });
  421. */
  422. });