user.js 3.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384
  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: 'user/user/index',
  8. add_url: 'user/user/add',
  9. edit_url: 'user/user/edit',
  10. del_url: 'user/user/del',
  11. multi_url: 'user/user/multi',
  12. table: 'user',
  13. }
  14. });
  15. var table = $("#table");
  16. // 初始化表格
  17. table.bootstrapTable({
  18. url: $.fn.bootstrapTable.defaults.extend.index_url,
  19. pk: 'id',
  20. sortName: 'user.id',
  21. columns: [
  22. [
  23. {checkbox: true},
  24. {field: 'id', title: __('Id'), sortable: true},
  25. {field: 'type', title: __('Type'), sortable: true},
  26. {field: 'workplace', title: __('Workplace')},
  27. {field: 'job_type', title: __('Job Type')},
  28. {field: 'title', title: __('Title')},
  29. {field: 'first_name', title: __('First Name')},
  30. {field: 'middle_name', title: __('Middle Name')},
  31. {field: 'last_name', title: __('Last Name')},
  32. {field: 'facebook', title: __('Facebook')},
  33. {field: 'twitter', title: __('Twitter')},
  34. {field: 'email', title: __('Email'), operate: 'LIKE'},
  35. // {field: 'username', title: __('Username'), operate: 'LIKE'},
  36. // {field: 'nickname', title: __('Nickname'), operate: 'LIKE'},
  37. // {field: 'mobile', title: __('Mobile'), operate: 'LIKE'},
  38. {field: 'avatar', title: __('Avatar'), events: Table.api.events.image, formatter: Table.api.formatter.image, operate: false},
  39. {field: 'status', title: __('Status'), formatter: Table.api.formatter.status, searchList: {normal: __('Normal'), hidden: __('Hidden')}},
  40. {field: 'operate', title: __('Operate'), table: table, events: Table.api.events.operate, formatter: Table.api.formatter.operate}
  41. ]
  42. ]
  43. });
  44. // 为表格绑定事件
  45. Table.api.bindevent(table);
  46. var cloneQueryParams = null;
  47. //绑定tab事件
  48. $('a[data-toggle="tab"]').on('show.bs.tab',function(event){
  49. let type =$(this).attr("data-value");
  50. let options = table.bootstrapTable('getOptions');
  51. $('.nav-tabs li').attr('class','');
  52. $(this).parent().attr("class",'active');
  53. options.pageNumber =1;
  54. if (cloneQueryParams == null) {
  55. cloneQueryParams = options.queryParams;
  56. }
  57. options.queryParams =function(params){
  58. params.type = type;
  59. return cloneQueryParams(params);
  60. };
  61. table.bootstrapTable('refresh',{});
  62. return false;
  63. });
  64. },
  65. add: function () {
  66. Controller.api.bindevent();
  67. },
  68. edit: function () {
  69. Controller.api.bindevent();
  70. },
  71. api: {
  72. bindevent: function () {
  73. Form.api.bindevent($("form[role=form]"));
  74. }
  75. }
  76. };
  77. return Controller;
  78. });