intention.js 9.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204
  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: 'intention/index',
  8. add_url: 'intention/add',
  9. edit_url: 'intention/edit',
  10. del_url: 'intention/del',
  11. follow_url: 'intention/follow',
  12. multi_url: 'intention/multi',
  13. table: 'intention',
  14. }
  15. });
  16. var table = $("#table");
  17. // 初始化表格
  18. table.bootstrapTable({
  19. url: $.fn.bootstrapTable.defaults.extend.index_url,
  20. pk: 'id',
  21. sortName: 'id',
  22. showToggle: false,
  23. showColumns: false,
  24. columns: [
  25. [
  26. {field: 'unit_name', title: '公司名称'},
  27. {field: 'unit_type', title: __('Unit_type'), searchable: false},
  28. {field: 'usr_nickname', title: '操作人'},
  29. {field: 'depart_id', title: '操作人部门',searchable: false,searchList: $.getJSON('auth/group/departList'),formatter:function (value, row) {
  30. return row.usr_depart;
  31. }},
  32. {field: 'created_at', title: '创建时间', operate:'RANGE', addclass:'datetimerange', searchable: false},
  33. {field: 'operate', title: __('Operate'),searchable: false,
  34. table: table,
  35. events: Controller.api.events.operate,
  36. formatter: Controller.api.formatter.operate
  37. }
  38. ]
  39. ]
  40. });
  41. // 为表格绑定事件
  42. Table.api.bindevent(table);
  43. },
  44. add: function () {
  45. $.ajax({
  46. url: 'intention/unitTypeList',
  47. type: 'post',
  48. dataType: 'json',
  49. success: function success(res) {
  50. var data = res.rows;
  51. $('#c-unit_type').selectPage({
  52. data : data,
  53. });
  54. console.log(data);
  55. }
  56. });
  57. Controller.api.bindevent();
  58. },
  59. edit: function () {
  60. Controller.api.bindevent();
  61. },
  62. follow: function () {
  63. Controller.api.bindevent();
  64. },
  65. api: {
  66. bindevent: function () {
  67. Form.api.bindevent($("form[role=form]"));
  68. },
  69. formatter:{
  70. operate: function (value, row, index) {
  71. var table = this.table;
  72. // 操作配置
  73. var options = table ? table.bootstrapTable('getOptions') : {};
  74. // 默认按钮组
  75. var buttons = $.extend([], this.buttons || []);
  76. switch (row.status){
  77. case 0: //保护中
  78. buttons.push({text: '放弃', classname: 'btn btn-xs btn-danger btn-giveup'});
  79. buttons.push({text:'跟进', classname: 'btn btn-xs btn-info btn-follow'});
  80. buttons.push({text:'修改', classname: 'btn btn-xs btn-primary btn-editone'});
  81. buttons.push({text:'详情', classname: 'btn btn-xs btn-warning btn-detail'});
  82. buttons.push({
  83. name: 'del',
  84. icon: 'fa fa-trash',
  85. title: __('Del'),
  86. extend: 'data-toggle="tooltip"',
  87. classname: 'btn btn-xs btn-danger btn-delone'
  88. });
  89. break;
  90. case 1:
  91. buttons.push({text:'详情', classname: 'btn btn-xs btn-warning btn-detail'});
  92. break;
  93. case 2:
  94. buttons.push({text:'修改', classname: 'btn btn-xs btn-primary btn-editone'});
  95. buttons.push({text:'详情', classname: 'btn btn-xs btn-warning btn-detail'});
  96. break;
  97. case 4:
  98. buttons.push({text:'详情', classname: 'btn btn-xs btn-warning btn-detail'});
  99. break;
  100. }
  101. return Table.api.buttonlink(this, buttons, value, row, index, 'operate');
  102. },
  103. },
  104. events:{
  105. operate: {
  106. // 放弃
  107. 'click .btn-giveup': function(e, value, row) {
  108. Layer.confirm('您确定放弃吗?',function (index) {
  109. var id = row.id;
  110. $.ajax({
  111. url: 'intention/giveup',
  112. type: 'post',
  113. data: { id:id },
  114. dataType: 'json',
  115. success: function success(res) {
  116. Layer.close(index);
  117. if(res.code == 1){
  118. Toastr.success(res.msg);
  119. $('.btn-refresh').click();
  120. } else {
  121. Toastr.error(res.msg);
  122. }
  123. }
  124. });
  125. });
  126. },
  127. // 跟进
  128. 'click .btn-follow': function (e, value, row) {
  129. e.stopPropagation();
  130. e.preventDefault();
  131. var options = $(this).closest('table').bootstrapTable('getOptions');
  132. var open = Fast.api.open(options.extend.follow_url + (options.extend.follow_url.match(/(\?|&)+/) ? "&ids=" : "/ids/") + row[options.pk], __('Follow'), {
  133. title: '跟进',
  134. maxmin: false
  135. });
  136. },
  137. // 修改
  138. 'click .btn-editone': function clickBtnEditone(e, value, row, index) {
  139. e.stopPropagation();
  140. e.preventDefault();
  141. var options = $(this).closest('table').bootstrapTable('getOptions');
  142. var open = Fast.api.open(options.extend.edit_url + (options.extend.edit_url.match(/(\?|&)+/) ? "&ids=" : "/ids/") + row[options.pk], __('Edit'), {
  143. title: '修改',
  144. maxmin: false
  145. });
  146. },
  147. 'click .btn-detail': function clickBtnEditone(e, value, row, index) {
  148. var html = '<table class="table table-striped table-bordered table-hover">';
  149. html += '<tr><td>公司名称</td><td>'+ row.unit_name +'</td></tr>';
  150. html += '<tr><td>联系人</td><td>'+ row.contacts +'</td></tr>';
  151. html += '<tr><td>手机</td><td>'+ row.phone +'</td></tr>';
  152. html += '<tr><td>固定电话</td><td>'+ row.fixed_phone +'</td></tr>';
  153. html += '<tr><td>地址</td><td>'+ row.address +'</td></tr>';
  154. html += '<tr><td>联系人职位</td><td>'+ row.con_position +'</td></tr>';
  155. html += '<tr><td>单位性质</td><td>'+ row.unit_type +'</td></tr>';
  156. html += '<tr><td>人数</td><td>'+ row.number +'</td></tr>';
  157. html += '<tr><td>单价</td><td>'+ row.price +'</td></tr>';
  158. html += '<tr><td>备注</td><td>'+ row.remark +'</td></tr>';
  159. html += '<tr><td>操作人</td><td>'+ row.usr_nickname +'</td></tr>';
  160. html += '<tr><td>操作人部门</td><td>'+ row.usr_depart +'</td></tr>';
  161. html += '</table>';
  162. Layer.open({
  163. content : html,
  164. area : ['500px'],
  165. })
  166. },
  167. 'click .btn-delone': function (e, value, row, index) {
  168. e.stopPropagation();
  169. e.preventDefault();
  170. var that = this;
  171. var top = $(that).offset().top - $(window).scrollTop();
  172. var left = $(that).offset().left - $(window).scrollLeft() - 260;
  173. if (top + 154 > $(window).height()) {
  174. top = top - 154;
  175. }
  176. if ($(window).width() < 480) {
  177. top = left = undefined;
  178. }
  179. Layer.confirm(
  180. __('Are you sure you want to delete this item?'),
  181. {icon: 3, title: __('Warning'), offset: [top, left], shadeClose: true},
  182. function (index) {
  183. var table = $(that).closest('table');
  184. var options = table.bootstrapTable('getOptions');
  185. Table.api.multi("del", row[options.pk], table, that);
  186. Layer.close(index);
  187. }
  188. );
  189. }
  190. }
  191. }
  192. }
  193. };
  194. return Controller;
  195. });