jobinfo.index.1.js 16 KB

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