comment.js 8.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161
  1. define(['jquery', 'bootstrap', 'backend', 'table', 'form'], function ($, undefined, Backend, Table, Form) {
  2. //设置弹窗宽高
  3. Fast.config.openArea = ['80%', '80%'];
  4. var Controller = {
  5. index: function () {
  6. // 初始化表格参数配置
  7. Table.api.init({
  8. extend: {
  9. index_url: 'cms/comment/index',
  10. add_url: 'cms/comment/add',
  11. edit_url: 'cms/comment/edit',
  12. del_url: 'cms/comment/del',
  13. multi_url: 'cms/comment/multi',
  14. table: 'cms_comment',
  15. }
  16. });
  17. var table = $("#table");
  18. // 初始化表格
  19. table.bootstrapTable({
  20. url: $.fn.bootstrapTable.defaults.extend.index_url,
  21. pk: 'id',
  22. sortName: 'id',
  23. fixedColumns: true,
  24. fixedRightNumber: 1,
  25. exportTypes: ['excel'],
  26. columns: [
  27. [
  28. {checkbox: true},
  29. {field: 'id', sortable: true, title: __('Id')},
  30. {field: 'type', title: __('Type'), formatter: Table.api.formatter.flag, custom: {archives: 'success', page: 'info'}, searchList: Config.typeList},
  31. {field: 'aid', sortable: true, title: __('Aid'), formatter: Table.api.formatter.search},
  32. {field: 'pid', sortable: true, title: __('Pid'), formatter: Table.api.formatter.search, visible: false},
  33. {field: 'user_id', sortable: true, title: __('User_id'), formatter: Table.api.formatter.search},
  34. {field: 'user.nickname', operate: false, title: __('Nickname')},
  35. {
  36. field: 'title', title: __('Title'), operate: false, formatter: function (value, row, index) {
  37. var title = row.spage && row.spage.id ? row.spage.title : (row.archives && row.archives.id ? row.archives.title : __('None'));
  38. return Table.api.formatter.content.call(this, title, row, index);
  39. }
  40. },
  41. {
  42. field: 'source.url', title: __('Url'), operate: false, formatter: function (value, row, index) {
  43. return '<a href="' + value + '" target="_blank" class="btn btn-default btn-xs"><i class="fa fa-link"></i></a>';
  44. }
  45. },
  46. {
  47. field: 'content', operate: 'like', sortable: false, title: __('Content'), formatter: Table.api.formatter.content
  48. },
  49. {field: 'comments', sortable: true, title: __('Comments'), operate: 'BETWEEN', visible: false},
  50. {field: 'ip', title: __('Ip'), formatter: Table.api.formatter.search},
  51. {field: 'useragent', title: __('Useragent'), visible: false},
  52. {field: 'subscribe', sortable: true, title: __('Subscribe'), visible: false, searchList: {"1": __('Yes'), "0": __('No')},},
  53. {field: 'createtime', sortable: true, title: __('Createtime'), operate: 'RANGE', addclass: 'datetimerange', formatter: Table.api.formatter.datetime},
  54. {field: 'updatetime', sortable: true, visible: false, title: __('Updatetime'), operate: 'RANGE', addclass: 'datetimerange', formatter: Table.api.formatter.datetime, visible: false},
  55. {field: 'status', title: __('Status'), searchList: {"normal": __('normal'), "hidden": __('hidden')}, formatter: Table.api.formatter.status},
  56. {field: 'operate', title: __('Operate'), clickToSelect: false, table: table, events: Table.api.events.operate, formatter: Table.api.formatter.operate}
  57. ]
  58. ]
  59. });
  60. // 为表格绑定事件
  61. Table.api.bindevent(table);
  62. },
  63. recyclebin: function () {
  64. // 初始化表格参数配置
  65. Table.api.init({
  66. extend: {
  67. 'dragsort_url': ''
  68. }
  69. });
  70. var table = $("#table");
  71. // 初始化表格
  72. table.bootstrapTable({
  73. url: 'cms/comment/recyclebin',
  74. pk: 'id',
  75. sortName: 'id',
  76. columns: [
  77. [
  78. {checkbox: true},
  79. {field: 'id', title: __('Id')},
  80. {field: 'type', title: __('Type'), formatter: Table.api.formatter.flag, custom: {archives: 'success', page: 'info'}, searchList: Config.typeList},
  81. {field: 'aid', sortable: true, title: __('Aid'), formatter: Table.api.formatter.search},
  82. {field: 'pid', sortable: true, title: __('Pid'), formatter: Table.api.formatter.search, visible: false},
  83. {field: 'user_id', sortable: true, title: __('User_id'), formatter: Table.api.formatter.search},
  84. {field: 'user.nickname', operate: false, title: __('Nickname')},
  85. {
  86. field: 'title', title: __('Title'), operate: false, formatter: function (value, row, index) {
  87. return row.spage && row.spage.id ? row.spage.title : (row.archives && row.archives.id ? row.archives.title : __('None'));
  88. }
  89. },
  90. {
  91. field: 'url', title: __('Url'), formatter: function (value, row, index) {
  92. return '<a href="' + value + '" target="_blank" class="btn btn-default btn-xs"><i class="fa fa-link"></i></a>';
  93. }
  94. },
  95. {
  96. field: 'content', sortable: false, title: __('Content'), formatter: function (value, row, index) {
  97. var width = this.width != undefined ? this.width : 250;
  98. return "<div style='white-space: nowrap; text-overflow:ellipsis; overflow: hidden; max-width:" + width + "px;'>" + value + "</div>";
  99. }
  100. },
  101. {
  102. field: 'deletetime',
  103. title: __('Deletetime'),
  104. operate: 'RANGE',
  105. addclass: 'datetimerange',
  106. formatter: Table.api.formatter.datetime
  107. },
  108. {
  109. field: 'operate',
  110. width: '130px',
  111. title: __('Operate'),
  112. table: table,
  113. events: Table.api.events.operate,
  114. buttons: [
  115. {
  116. name: 'Restore',
  117. text: __('Restore'),
  118. classname: 'btn btn-xs btn-info btn-ajax btn-restoreit',
  119. icon: 'fa fa-rotate-left',
  120. url: 'cms/comment/restore',
  121. refresh: true
  122. },
  123. {
  124. name: 'Destroy',
  125. text: __('Destroy'),
  126. classname: 'btn btn-xs btn-danger btn-ajax btn-destroyit',
  127. icon: 'fa fa-times',
  128. url: 'cms/comment/destroy',
  129. refresh: true
  130. }
  131. ],
  132. formatter: Table.api.formatter.operate
  133. }
  134. ]
  135. ]
  136. });
  137. // 为表格绑定事件
  138. Table.api.bindevent(table);
  139. },
  140. add: function () {
  141. Controller.api.bindevent();
  142. },
  143. edit: function () {
  144. Controller.api.bindevent();
  145. },
  146. api: {
  147. bindevent: function () {
  148. Form.api.bindevent($("form[role=form]"));
  149. }
  150. }
  151. };
  152. return Controller;
  153. });