title.js 5.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131
  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: 'manage/title/index',
  8. add_url: 'manage/title/add',
  9. edit_url: 'manage/title/edit',
  10. del_url: 'manage/title/del',
  11. multi_url: 'manage/title/multi',
  12. table: 'manage_title',
  13. }
  14. });
  15. var table = $("#table");
  16. // 初始化表格
  17. table.bootstrapTable({
  18. url: $.fn.bootstrapTable.defaults.extend.index_url,
  19. pk: 'id',
  20. sortName: 'id',
  21. search: false,
  22. showToggle: false,
  23. showColumns: false,
  24. showExport: false,
  25. commonSearch: false,
  26. columns: [
  27. [
  28. {checkbox: true},
  29. {field: 'id', title: 'ID'},
  30. {field: 'sex', title: __('Sex'),formatter: Controller.api.formatter.sex_text, searchList: {"1":__('Sex 1'),"2":__('Sex 2'),"3":__('Sex 3')}},
  31. {field: 'title', title: '标题'},
  32. {field: 'status', title: '状态', formatter: Table.api.formatter.status},
  33. {field: 'createtime', title: '创建时间', formatter: Table.api.formatter.datetime},
  34. {field: 'updatetime', title: '更新时间', formatter: Table.api.formatter.datetime},
  35. {field: 'operate', title: '操作', table: table, events: Table.api.events.operate, formatter: Table.api.formatter.operate}
  36. ]
  37. ]
  38. });
  39. $(document).on('click','.btn-batchaddtitle',function () {
  40. Fast.api.open($(this).attr('href'), '批量添加标题', {});
  41. return false;
  42. });
  43. // 为表格绑定事件
  44. Table.api.bindevent(table);
  45. },
  46. select: function () {
  47. // 初始化表格参数配置
  48. Table.api.init({
  49. extend: {
  50. index_url: 'manage/title/select',
  51. }
  52. });
  53. var table = $("#table");
  54. // 初始化表格
  55. table.bootstrapTable({
  56. url: $.fn.bootstrapTable.defaults.extend.index_url,
  57. sortName: 'id',
  58. searchFormVisible: true,
  59. columns: [
  60. [
  61. {field: 'state', checkbox: true, },
  62. {field: 'id', title: __('Id')},
  63. {field: 'sex', title: __('Sex'),formatter: Controller.api.formatter.sex_text, searchList: {"1":__('Sex 1'),"2":__('Sex 2'),"3":__('Sex 3')}},
  64. {field: 'title', title: __('Title')},
  65. {field: 'updatetime', title: '更新时间', formatter: Table.api.formatter.datetime},
  66. {field: 'operate', title: __('Operate'), events: {
  67. 'click .btn-chooseone': function (e, value, row, index) {
  68. Fast.api.close(row);
  69. }
  70. }, formatter: function () {
  71. return '<a href="javascript:;" class="btn btn-danger btn-chooseone btn-xs"><i class="fa fa-check"></i> ' + __('Choose') + '</a>';
  72. }}
  73. ]
  74. ]
  75. });
  76. // 为表格绑定事件
  77. Table.api.bindevent(table);
  78. },
  79. add: function () {
  80. Controller.api.bindevent();
  81. },
  82. edit: function () {
  83. Controller.api.bindevent();
  84. },
  85. batchaddtitle: function () {
  86. var state = false;
  87. $('#batchaddtitle-form').data('validator-options', {
  88. 'beforeSubmit': function () {
  89. if (!$('#titles').val() || !$('#titles').val().trim()) {
  90. Toastr.error("标题不可为空");
  91. return false;
  92. }
  93. var max = 100;
  94. if ($('#titles').val().trim().split("\n").length > max) {
  95. Toastr.error("标题超出最大编辑最大数量:" + max);
  96. return false;
  97. }
  98. layer.confirm('确定要添加书籍标题吗?', {
  99. btn: ['确认', '取消'] //按钮
  100. }, function () {
  101. state = true;
  102. $('#batchaddtitle-form').submit();
  103. }, function(){
  104. state = false;
  105. });
  106. return state;
  107. }
  108. });
  109. Form.api.bindevent($("form[role=form]"));
  110. },
  111. api: {
  112. bindevent: function () {
  113. Form.api.bindevent($("form[role=form]"));
  114. },
  115. formatter:{
  116. sex_text: function(value,row,index){return row.sex_text;},
  117. }
  118. }
  119. };
  120. return Controller;
  121. });