| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464 |
- $(function() {
- // init date tables
- var jobTable = $("#job_list").dataTable({
- "deferRender": true,
- "processing" : true,
- "serverSide": true,
- "ajax": {
- url: base_url + "/jobinfo/pageList",
- data : function ( d ) {
- d.jobGroup = $('#jobGroup').val();
- d.jobName = $('#jobName').val();
- }
- },
- "searching": false,
- "ordering": false,
- //"scrollX": true, // X轴滚动条,取消自适应
- "columns": [
- { "data": 'id', "bSortable": false, "visible" : false},
- {
- "data": 'jobGroup',
- "visible" : false,
- "render": function ( data, type, row ) {
- var groupMenu = $("#jobGroup").find("option");
- for ( var index in $("#jobGroup").find("option")) {
- if ($(groupMenu[index]).attr('value') == data) {
- return $(groupMenu[index]).html();
- }
- }
- return data;
- }
- },
- { "data": 'jobName'},
- { "data": 'jobDesc', "visible" : true},
- { "data": 'jobCron', "visible" : true},
- { "data": 'jobClass', "visible" : false},
- {
- "data": 'jobData',
- "visible" : true,
- "render": function ( data, type, row ) {
- var _jobData = eval('(' + data + ')'); // row.jobData
- var html = "<p title='" + data + "'>执行器:" + _jobData.handler_name +
- "<br>执行参数:" + _jobData.handler_params +
- "<br>执行机器:" + _jobData.handler_address + "</p>";
- return html;
- }
- },
- {
- "data": 'addTime',
- "visible" : false,
- "render": function ( data, type, row ) {
- return data?moment(new Date(data)).format("YYYY-MM-DD HH:mm:ss"):"";
- }
- },
- {
- "data": 'updateTime',
- "visible" : false,
- "render": function ( data, type, row ) {
- return data?moment(new Date(data)).format("YYYY-MM-DD HH:mm:ss"):"";
- }
- },
- { "data": 'author', "visible" : true},
- { "data": 'alarmEmail', "visible" : false},
- { "data": 'alarmThreshold', "visible" : false},
- {
- "data": 'jobStatus',
- "visible" : true,
- "render": function ( data, type, row ) {
- if ('NORMAL' == data) {
- return '<small class="label label-success" ><i class="fa fa-clock-o"></i>'+ data +'</small>';
- } else if ('PAUSED' == data){
- return '<small class="label label-default" title="暂停" ><i class="fa fa-clock-o"></i>'+ data +'</small>';
- } else if ('BLOCKED' == data){
- return '<small class="label label-default" title="阻塞[串行]" ><i class="fa fa-clock-o"></i>'+ data +'</small>';
- }
- return data;
- }
- },
- { "data": '操作' ,
- "render": function ( data, type, row ) {
- return function(){
- // status
- var pause_resume = "";
- if ('NORMAL' == row.jobStatus) {
- pause_resume = '<button class="btn btn-info btn-xs job_operate" type="job_pause" type="button">暂停</button> ';
- } else if ('PAUSED' == row.jobStatus){
- pause_resume = '<button class="btn btn-info btn-xs job_operate" type="job_resume" type="button">恢复</button> ';
- }
- // log url
- var logUrl = base_url +'/joblog?jobGroup='+ row.jobGroup +'&jobName='+ row.jobName;
-
- // job data
- var jobDataMap = eval('(' + row.jobData + ')');
-
- var html = '<p id="'+ row.id +'" '+
- ' jobGroup="'+ row.jobGroup +'" '+
- ' jobName="'+ row.jobName +'" '+
- ' jobCron="'+ row.jobCron +'" '+
- ' jobDesc="'+ row.jobDesc +'" '+
- ' jobClass="'+ row.jobClass +'" '+
- ' jobData="'+ row.jobData +'" '+
- ' author="'+ row.author +'" '+
- ' alarmEmail="'+ row.alarmEmail +'" '+
- ' alarmThreshold="'+ row.alarmThreshold +'" '+
- ' handler_params="'+jobDataMap.handler_params +'" '+
- ' handler_address="'+ jobDataMap.handler_address +'" '+
- ' handler_name="'+ jobDataMap.handler_name +'" '+
- '>'+
- pause_resume +
- '<button class="btn btn-info btn-xs job_operate" type="job_trigger" type="button">执行</button>'+
- '<button class="btn btn-warning btn-xs update" type="button">编辑</button><br>'+
- '<button class="btn btn-warning btn-xs" type="job_del" type="button" '+
- 'onclick="javascript:window.open(\'' + logUrl + '\')" >查看日志</button> '+
- '<button class="btn btn-danger btn-xs job_operate" type="job_del" type="button">删除</button> '+
- '</p>';
-
-
- return html;
- };
- }
- }
- ],
- "language" : {
- "sProcessing" : "处理中...",
- "sLengthMenu" : "每页 _MENU_ 条记录",
- "sZeroRecords" : "没有匹配结果",
- "sInfo" : "第 _PAGE_ 页 ( 总共 _PAGES_ 页 )",
- "sInfoEmpty" : "无记录",
- "sInfoFiltered" : "(由 _MAX_ 项结果过滤)",
- "sInfoPostFix" : "",
- "sSearch" : "搜索:",
- "sUrl" : "",
- "sEmptyTable" : "表中数据为空",
- "sLoadingRecords" : "载入中...",
- "sInfoThousands" : ",",
- "oPaginate" : {
- "sFirst" : "首页",
- "sPrevious" : "上页",
- "sNext" : "下页",
- "sLast" : "末页"
- },
- "oAria" : {
- "sSortAscending" : ": 以升序排列此列",
- "sSortDescending" : ": 以降序排列此列"
- }
- }
- });
-
- // 搜索按钮
- $('#searchBtn').on('click', function(){
- jobTable.fnDraw();
- });
-
- // job operate
- $("#job_list").on('click', '.job_operate',function() {
- var typeName;
- var url;
- var type = $(this).attr("type");
- if ("job_pause" == type) {
- typeName = "暂停";
- url = base_url + "/jobinfo/pause";
- } else if ("job_resume" == type) {
- typeName = "恢复";
- url = base_url + "/jobinfo/resume";
- } else if ("job_del" == type) {
- typeName = "删除";
- url = base_url + "/jobinfo/remove";
- } else if ("job_trigger" == type) {
- typeName = "执行";
- url = base_url + "/jobinfo/trigger";
- } else {
- return;
- }
-
- var jobGroup = $(this).parent('p').attr("jobGroup");
- var jobName = $(this).parent('p').attr("jobName");
-
- ComConfirm.show("确认" + typeName + "?", function(){
- $.ajax({
- type : 'POST',
- url : url,
- data : {
- "jobGroup" : jobGroup,
- "jobName" : jobName
- },
- dataType : "json",
- success : function(data){
- if (data.code == 200) {
- ComAlert.show(1, typeName + "成功", function(){
- //window.location.reload();
- jobTable.fnDraw();
- });
- } else {
- ComAlert.show(1, typeName + "失败");
- }
- },
- });
- });
- });
-
- // jquery.validate 自定义校验 “英文字母开头,只含有英文字母、数字和下划线”
- jQuery.validator.addMethod("myValid01", function(value, element) {
- var length = value.length;
- var valid = /^[a-zA-Z][a-zA-Z0-9_]*$/;
- return this.optional(element) || valid.test(value);
- }, "只支持英文字母开头,只含有英文字母、数字和下划线");
-
- // 新增
- $(".add").click(function(){
- $('#addModal').modal({backdrop: false, keyboard: false}).modal('show');
- });
- var addModalValidate = $("#addModal .form").validate({
- errorElement : 'span',
- errorClass : 'help-block',
- focusInvalid : true,
- rules : {
- jobName : {
- required : true ,
- minlength: 4,
- maxlength: 100,
- myValid01:true
- },
- jobCron : {
- required : true ,
- maxlength: 100
- },
- jobDesc : {
- required : true ,
- maxlength: 200
- },
- handler_address : {
- required : true ,
- maxlength: 200
- },
- handler_name : {
- required : true ,
- maxlength: 200
- },
- author : {
- required : true ,
- maxlength: 200
- },
- alarmEmail : {
- required : true ,
- maxlength: 200
- },
- alarmThreshold : {
- required : true ,
- digits:true
- }
- },
- messages : {
- jobName : {
- required :"请输入“任务名”" ,
- minlength:"“任务名”长度不应低于4位",
- maxlength:"“任务名”长度不应超过100位"
- },
- jobCron : {
- required :"请输入“Corn”." ,
- maxlength:"“Corn”长度不应超过100位"
- },
- jobDesc : {
- required :"请输入“任务描述”." ,
- maxlength:"“任务描述”长度不应超过200位"
- },
- handler_address : {
- required :"请输入“远程-机器地址”." ,
- maxlength:"“远程-机器地址”长度不应超过200位"
- },
- handler_name : {
- required : "请输入“远程-执行器”." ,
- maxlength: "“远程-执行器”长度不应超过200位"
- },
- author : {
- required : "请输入“负责人”." ,
- maxlength: "“负责人”长度不应超过50位"
- },
- alarmEmail : {
- required : "请输入“报警邮件”." ,
- maxlength: "“报警邮件”长度不应超过200位"
- },
- alarmThreshold : {
- required : "请输入“报警阈值”." ,
- digits:"阀值应该为整数."
- }
- },
- highlight : function(element) {
- $(element).closest('.form-group').addClass('has-error');
- },
- success : function(label) {
- label.closest('.form-group').removeClass('has-error');
- label.remove();
- },
- errorPlacement : function(error, element) {
- element.parent('div').append(error);
- },
- submitHandler : function(form) {
- $.post(base_url + "/jobinfo/add", $("#addModal .form").serialize(), function(data, status) {
- if (data.code == "200") {
- ComAlert.show(1, "新增任务成功", function(){
- window.location.reload();
- });
- } else {
- if (data.msg) {
- ComAlert.show(2, data.msg);
- } else {
- ComAlert.show(2, "新增失败");
- }
- }
- });
- }
- });
- $("#addModal").on('hide.bs.modal', function () {
- $("#addModal .form")[0].reset();
- addModalValidate.resetForm();
- $("#addModal .form .form-group").removeClass("has-error");
- $(".remote_panel").show(); // remote
- });
-
- // 远程任务/本地任务,切换
- $("#addModal select[name='jobClass']").change(function() {
- //console.log( $(this).val().indexOf('RemoteHttpJobBean') );
-
- if($(this).val().indexOf('RemoteHttpJobBean') > -1){
- $(".remote_panel").show(); // remote
- } else if($(this).val().indexOf('RemoteHttpJobBean') == -1){
- $(".remote_panel").hide(); // local
- }
- });
-
- // 更新
- $("#job_list").on('click', '.update',function() {
- $("#updateModal .form input[name='jobGroup']").val($(this).parent('p').attr("jobGroup"));
- $("#updateModal .form input[name='jobName']").val($(this).parent('p').attr("jobName"));
- $("#updateModal .form input[name='jobCron']").val($(this).parent('p').attr("jobCron"));
- $("#updateModal .form input[name='jobDesc']").val($(this).parent('p').attr("jobDesc"));
- $("#updateModal .form input[name='jobClass']").val($(this).parent('p').attr("jobClass"));
- $("#updateModal .form input[name='handler_params']").val($(this).parent('p').attr("handler_params"));
- $("#updateModal .form input[name='handler_address']").val($(this).parent('p').attr("handler_address"));
- $("#updateModal .form input[name='handler_name']").val($(this).parent('p').attr("handler_name"));
- $("#updateModal .form input[name='author']").val($(this).parent('p').attr("author"));
- $("#updateModal .form input[name='alarmEmail']").val($(this).parent('p').attr("alarmEmail"));
- $("#updateModal .form input[name='alarmThreshold']").val($(this).parent('p').attr("alarmThreshold"));
-
- var _jobClass = $(this).parent('p').attr("jobClass");
- if(_jobClass.indexOf('RemoteHttpJobBean') > -1){
- $(".remote_panel").show(); // remote
- } else if($(this).val().indexOf('RemoteHttpJobBean') == -1){
- $(".remote_panel").hide(); // local
- }
-
- $('#updateModal').modal({backdrop: false, keyboard: false}).modal('show');
- });
- var updateModalValidate = $("#updateModal .form").validate({
- errorElement : 'span',
- errorClass : 'help-block',
- focusInvalid : true,
- rules : {
- jobCron : {
- required : true ,
- maxlength: 100
- },
- jobDesc : {
- required : true ,
- maxlength: 200
- },
- handler_address : {
- required : true ,
- maxlength: 200
- },
- handler_name : {
- required : true ,
- maxlength: 200
- },
- author : {
- required : true ,
- maxlength: 200
- },
- alarmEmail : {
- required : true ,
- maxlength: 200
- },
- alarmThreshold : {
- required : true ,
- digits:true
- }
- },
- messages : {
- jobCron : {
- required :"请输入“Corn”." ,
- maxlength:"“Corn”长度不应超过100位"
- },
- jobDesc : {
- required :"请输入“任务描述”." ,
- maxlength:"“任务描述”长度不应超过200位"
- },
- handler_address : {
- required :"请输入“远程-机器地址”." ,
- maxlength:"“远程-机器地址”长度不应超过200位"
- },
- handler_name : {
- required : "请输入“远程-执行器”." ,
- maxlength: "“远程-执行器”长度不应超过200位"
- },
- author : {
- required : "请输入“负责人”." ,
- maxlength: "“负责人”长度不应超过50位"
- },
- alarmEmail : {
- required : "请输入“报警邮件”." ,
- maxlength: "“报警邮件”长度不应超过200位"
- },
- alarmThreshold : {
- required : "请输入“报警阈值”." ,
- digits:"阀值应该为整数."
- }
- },
- highlight : function(element) {
- $(element).closest('.form-group').addClass('has-error');
- },
- success : function(label) {
- label.closest('.form-group').removeClass('has-error');
- label.remove();
- },
- errorPlacement : function(error, element) {
- element.parent('div').append(error);
- },
- submitHandler : function(form) {
- $.post(base_url + "/jobinfo/reschedule", $("#updateModal .form").serialize(), function(data, status) {
- if (data.code == "200") {
- ComAlert.show(1, "更新成功", function(){
- window.location.reload();
- });
- } else {
- if (data.msg) {
- ComAlert.show(2, data.msg);
- } else {
- ComAlert.show(2, "更新失败");
- }
- }
- });
- }
- });
- $("#updateModal").on('hide.bs.modal', function () {
- $("#updateModal .form")[0].reset()
- });
-
-
- /*
- // 新增-添加参数
- $("#addModal .addParam").on('click', function () {
- var html = '<div class="form-group newParam">'+
- '<label for="lastname" class="col-sm-2 control-label">参数 <button class="btn btn-danger btn-xs removeParam" type="button">移除</button></label>'+
- '<div class="col-sm-4"><input type="text" class="form-control" name="key" placeholder="请输入参数key[将会强转为String]" maxlength="200" /></div>'+
- '<div class="col-sm-6"><input type="text" class="form-control" name="value" placeholder="请输入参数value[将会强转为String]" maxlength="200" /></div>'+
- '</div>';
- $(this).parents('.form-group').parent().append(html);
-
- $("#addModal .removeParam").on('click', function () {
- $(this).parents('.form-group').remove();
- });
- });
- */
- });
|