crontab.js 5.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102
  1. define(['jquery', 'bootstrap', 'backend', 'table', 'form'], function ($, undefined, Backend, Table, Form) {
  2. var Controller = {
  3. index: function () {
  4. // 初始化表格参数配置
  5. Table.api.init({
  6. extend: {
  7. index_url: 'general/crontab/index',
  8. add_url: 'general/crontab/add',
  9. edit_url: 'general/crontab/edit',
  10. del_url: 'general/crontab/del',
  11. multi_url: 'general/crontab/multi',
  12. table: 'crontab'
  13. }
  14. });
  15. var table = $("#table");
  16. // 初始化表格
  17. table.bootstrapTable({
  18. url: $.fn.bootstrapTable.defaults.extend.index_url,
  19. sortName: 'weigh',
  20. columns: [
  21. [
  22. {field: 'state', checkbox: true,},
  23. {field: 'id', title: 'ID'},
  24. {field: 'type', title: __('Type'), searchList: Config.typeList, formatter: Table.api.formatter.label, custom: {sql: 'warning', url: 'info', shell: 'success'}},
  25. {field: 'title', title: __('Title')},
  26. {field: 'maximums', title: __('Maximums'), formatter: Controller.api.formatter.maximums},
  27. {field: 'executes', title: __('Executes')},
  28. {field: 'begintime', title: __('Begin time'), formatter: Table.api.formatter.datetime, operate: 'RANGE', addclass: 'datetimerange'},
  29. {field: 'endtime', title: __('End time'), formatter: Table.api.formatter.datetime, operate: 'RANGE', addclass: 'datetimerange'},
  30. {field: 'nexttime', title: __('Next execute time'), formatter: Controller.api.formatter.nexttime, operate: false, addclass: 'datetimerange', sortable: true},
  31. {field: 'executetime', title: __('Execute time'), formatter: Table.api.formatter.datetime, operate: 'RANGE', addclass: 'datetimerange', sortable: true},
  32. {field: 'weigh', title: __('Weigh')},
  33. {field: 'status', title: __('Status'), formatter: Table.api.formatter.status},
  34. {
  35. field: 'operate', title: __('Operate'), table: table, events: Table.api.events.operate, formatter: Table.api.formatter.operate,
  36. buttons: [
  37. {
  38. name: "detail",
  39. icon: "fa fa-list",
  40. title: function (row, index) {
  41. return __('Logs') + "[" + row['title'] + "]";
  42. },
  43. text: __('Logs'),
  44. classname: "btn btn-xs btn-info btn-dialog",
  45. url: "general/crontab_log/index?crontab_id={ids}",
  46. }
  47. ]
  48. }
  49. ]
  50. ]
  51. });
  52. // 为表格绑定事件
  53. Table.api.bindevent(table);
  54. },
  55. add: function () {
  56. Controller.api.bindevent();
  57. },
  58. edit: function () {
  59. Controller.api.bindevent();
  60. },
  61. api: {
  62. bindevent: function () {
  63. $('#schedule').on('valid.field', function (e, result) {
  64. $("#pickdays").trigger("change");
  65. });
  66. Form.api.bindevent($("form[role=form]"));
  67. $(document).on("change", "#pickdays", function () {
  68. Fast.api.ajax({url: "general/crontab/get_schedule_future", data: {schedule: $("#schedule").val(), days: $(this).val()}}, function (data, ret) {
  69. if (typeof data.futuretime !== 'undefined' && $.isArray(data.futuretime)) {
  70. var result = [];
  71. $.each(data.futuretime, function (i, j) {
  72. result.push("<li class='list-group-item'>" + j + "<span class='badge'>" + (i + 1) + "</span></li>");
  73. });
  74. $("#scheduleresult").html(result.join(""));
  75. } else {
  76. $("#scheduleresult").html("");
  77. }
  78. return false;
  79. });
  80. });
  81. $("#pickdays").trigger("change");
  82. },
  83. formatter: {
  84. nexttime: function (value, row, index) {
  85. if (isNaN(value)) {
  86. return value;
  87. } else {
  88. return Table.api.formatter.datetime.call(this, value, row, index);
  89. }
  90. },
  91. maximums: function (value, row, index) {
  92. return value === 0 ? __('No limit') : value;
  93. }
  94. }
  95. }
  96. };
  97. return Controller;
  98. });