question.js 2.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869
  1. define(['jquery', 'bootstrap', 'backend', 'table', 'form','selectpage'], function ($, undefined, Backend, Table, Form,SelectPage) {
  2. var Controller = {
  3. index: function () {
  4. // 初始化表格参数配置
  5. Table.api.init({
  6. extend: {
  7. index_url: 'questionnaire/question/index' + location.search,
  8. add_url: 'questionnaire/question/add',
  9. edit_url: 'questionnaire/question/edit',
  10. del_url: 'questionnaire/question/del',
  11. multi_url: 'questionnaire/question/multi',
  12. table: 'questionnaire_question',
  13. }
  14. });
  15. var table = $("#table");
  16. // 初始化表格
  17. table.bootstrapTable({
  18. url: $.fn.bootstrapTable.defaults.extend.index_url,
  19. pk: 'id',
  20. sortName: 'weight',
  21. sortOrder:'asc',
  22. columns: [
  23. [
  24. {field: 'question', title: __('Question')},
  25. {field: 'questionnaire', title: __('所属问卷'),searchable:false},
  26. {field: 'createrdAt', title: __('Createrdat'), operate:'RANGE', addclass:'datetimerange'},
  27. {field: 'weight', title: __('Weight')},
  28. {field: 'operate', title: __('Operate'), table: table, events: Table.api.events.operate, formatter: Table.api.formatter.operate}
  29. ]
  30. ]
  31. });
  32. // 为表格绑定事件
  33. Table.api.bindevent(table);
  34. },
  35. add: function () {
  36. questionnaireList();
  37. Controller.api.bindevent();
  38. },
  39. edit: function () {
  40. questionnaireList();
  41. Controller.api.bindevent();
  42. },
  43. api: {
  44. bindevent: function () {
  45. Form.api.bindevent($("form[role=form]"));
  46. }
  47. }
  48. };
  49. let questionnaireList = function ()
  50. {
  51. $.ajax({
  52. url: 'questionnaire/questionnaire/index',
  53. type: 'post',
  54. dataType: 'json',
  55. success: function success(res) {
  56. var data = res.rows;
  57. $('#c-questionnaire_id').selectPage({
  58. data : data,
  59. orderBy: 'index'
  60. });
  61. }
  62. });
  63. }
  64. return Controller;
  65. });