jobinfo.index.1.js 15 KB

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