user.js 5.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118
  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: 'username', title: __('Username'), operate: 'LIKE'},
  26. {field: 'nickname', title: __('Nickname'), operate: 'LIKE'},
  27. {field: 'total_traffic', title: '总流量',formatter:function(val,row){
  28. var kb = 1024;
  29. var Mb = 1024 * kb;
  30. var Gb = 1024 * Mb;
  31. var Tb = 1024 * Gb;
  32. if(val < Mb){
  33. return (val/kb).toFixed(2) +' Kb';
  34. }else if(val < Gb){
  35. return (val/Mb).toFixed(2) +' Mb';
  36. }else if(val < Tb){
  37. return (val/Gb).toFixed(2) +' Gb';
  38. }
  39. return val + ' b'
  40. }},
  41. {field: 'traffic', title: '已使用流量',formatter:function(val,row){
  42. var kb = 1024;
  43. var Mb = 1024 * kb;
  44. var Gb = 1024 * Mb;
  45. var Tb = 1024 * Gb;
  46. if(val < Mb){
  47. return (val/kb).toFixed(2) +' Kb';
  48. }else if(val < Gb){
  49. return (val/Mb).toFixed(2) +' Mb';
  50. }else if(val < Tb){
  51. return (val/Gb).toFixed(2) +' Gb';
  52. }
  53. return val + ' b';
  54. }},
  55. {field: 'traffic', title: '剩余流量',formatter:function(val,row){
  56. val = row.total_traffic - row.traffic;
  57. if(val < 1 ){return '已用完';}
  58. var kb = 1024;
  59. var Mb = 1024 * kb;
  60. var Gb = 1024 * Mb;
  61. var Tb = 1024 * Gb;
  62. if(val < Mb){
  63. return (val/kb).toFixed(2) +' Kb';
  64. }else if(val < Gb){
  65. return (val/Mb).toFixed(2) +' Mb';
  66. }else if(val < Tb){
  67. return (val/Gb).toFixed(2) +' Gb';
  68. }
  69. return val + ' b';
  70. }},
  71. {field: 'email', title: __('Email'), operate: 'LIKE'},
  72. {field: 'mobile', title: __('Mobile'), operate: 'LIKE'},
  73. {field: 'avatar', title: __('Avatar'), events: Table.api.events.image, formatter: Table.api.formatter.image, operate: false},
  74. // {field: 'level', title: __('Level'), operate: 'BETWEEN', sortable: true},
  75. // {field: 'gender', title: __('Gender'), visible: false, searchList: {1: __('Male'), 0: __('Female')}},
  76. // {field: 'score', title: __('Score'), operate: 'BETWEEN', sortable: true},
  77. {field: 'successions', title: __('Successions'), visible: false, operate: 'BETWEEN', sortable: true},
  78. {field: 'maxsuccessions', title: __('Maxsuccessions'), visible: false, operate: 'BETWEEN', sortable: true},
  79. {field: 'logintime', title: __('Logintime'), formatter: Table.api.formatter.datetime, operate: 'RANGE', addclass: 'datetimerange', sortable: true},
  80. {field: 'loginip', title: __('Loginip'), formatter: Table.api.formatter.search},
  81. {field: 'jointime', title: __('Jointime'), formatter: Table.api.formatter.datetime, operate: 'RANGE', addclass: 'datetimerange', sortable: true},
  82. {field: 'joinip', title: __('Joinip'), formatter: Table.api.formatter.search},
  83. {field: 'status', title: __('Status'), formatter: Table.api.formatter.status, searchList: {normal: __('Normal'), hidden: __('Hidden')}},
  84. {field: 'operate', title: __('Operate'), table: table, events: Table.api.events.operate, formatter: Table.api.formatter.operate}
  85. ]
  86. ]
  87. });
  88. // 为表格绑定事件
  89. Table.api.bindevent(table);
  90. },
  91. add: function () {
  92. Controller.api.bindevent();
  93. },
  94. edit: function () {
  95. Controller.api.bindevent();
  96. },
  97. api: {
  98. bindevent: function () {
  99. Form.api.bindevent($("form[role=form]"));
  100. }
  101. }
  102. };
  103. return Controller;
  104. });