jobinfo.index.1.js 14 KB

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