crontab.js 5.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104
  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. fixedColumns: true,
  21. fixedRightNumber: 1,
  22. columns: [
  23. [
  24. {field: 'state', checkbox: true,},
  25. {field: 'id', title: 'ID'},
  26. {field: 'type', title: __('Type'), searchList: Config.typeList, formatter: Table.api.formatter.label, custom: {sql: 'warning', url: 'info', shell: 'success'}},
  27. {field: 'title', title: __('Title')},
  28. {field: 'maximums', title: __('Maximums'), formatter: Controller.api.formatter.maximums},
  29. {field: 'executes', title: __('Executes')},
  30. {field: 'begintime', title: __('Begin time'), formatter: Table.api.formatter.datetime, operate: 'RANGE', addclass: 'datetimerange'},
  31. {field: 'endtime', title: __('End time'), formatter: Table.api.formatter.datetime, operate: 'RANGE', addclass: 'datetimerange'},
  32. {field: 'nexttime', title: __('Next execute time'), formatter: Controller.api.formatter.nexttime, operate: false, addclass: 'datetimerange', sortable: true},
  33. {field: 'executetime', title: __('Execute time'), formatter: Table.api.formatter.datetime, operate: 'RANGE', addclass: 'datetimerange', sortable: true},
  34. {field: 'weigh', title: __('Weigh')},
  35. {field: 'status', title: __('Status'), searchList: {"normal": __('Normal'), "hidden": __('Hidden'), "expired": __('Expired'), "completed": __('Completed')}, formatter: Table.api.formatter.status},
  36. {
  37. field: 'operate', title: __('Operate'), table: table, events: Table.api.events.operate, formatter: Table.api.formatter.operate,
  38. buttons: [
  39. {
  40. name: "detail",
  41. icon: "fa fa-list",
  42. title: function (row, index) {
  43. return __('Logs') + "[" + row['title'] + "]";
  44. },
  45. text: __('Logs'),
  46. classname: "btn btn-xs btn-info btn-dialog",
  47. url: "general/crontab_log/index?crontab_id={ids}",
  48. }
  49. ]
  50. }
  51. ]
  52. ]
  53. });
  54. // 为表格绑定事件
  55. Table.api.bindevent(table);
  56. },
  57. add: function () {
  58. Controller.api.bindevent();
  59. },
  60. edit: function () {
  61. Controller.api.bindevent();
  62. },
  63. api: {
  64. bindevent: function () {
  65. $('#schedule').on('valid.field', function (e, result) {
  66. $("#pickdays").trigger("change");
  67. });
  68. Form.api.bindevent($("form[role=form]"));
  69. $(document).on("change", "#pickdays", function () {
  70. Fast.api.ajax({url: "general/crontab/get_schedule_future", data: {schedule: $("#schedule").val(), days: $(this).val()}}, function (data, ret) {
  71. if (typeof data.futuretime !== 'undefined' && $.isArray(data.futuretime)) {
  72. var result = [];
  73. $.each(data.futuretime, function (i, j) {
  74. result.push("<li class='list-group-item'>" + j + "<span class='badge'>" + (i + 1) + "</span></li>");
  75. });
  76. $("#scheduleresult").html(result.join(""));
  77. } else {
  78. $("#scheduleresult").html("");
  79. }
  80. return false;
  81. });
  82. });
  83. $("#pickdays").trigger("change");
  84. },
  85. formatter: {
  86. nexttime: function (value, row, index) {
  87. if (isNaN(value)) {
  88. return value;
  89. } else {
  90. return Table.api.formatter.datetime.call(this, value, row, index);
  91. }
  92. },
  93. maximums: function (value, row, index) {
  94. return value === 0 ? __('No limit') : value;
  95. }
  96. }
  97. }
  98. };
  99. return Controller;
  100. });