define(['jquery', 'bootstrap', 'backend', 'table', 'form'], function ($, undefined, Backend, Table, Form) { var Controller = { index : function () { // 初始化表格参数配置 Table.api.init(); //绑定事件 $('a[data-toggle="tab"]').on('shown.bs.tab', function (e) { var panel = $($(this).attr("href")); if (panel.length > 0) { Controller.table[panel.attr("id")].call(this); $(this).on('click', function (e) { $($(this).attr("href")).find(".btn-refresh").trigger("click"); }); } //移除绑定的事件 $(this).unbind('shown.bs.tab'); }); //必须默认触发shown.bs.tab事件 $('ul.nav-tabs li.active a[data-toggle="tab"]').trigger("shown.bs.tab"); $(document).on('click', '.show-detail', function (data) { var area = [$(window).width() > 1200 ? '1200px' : '95%', $(window).height() > 800 ? '800px' : '95%']; var options = { shadeClose : false, shade : [0.3, '#393D49'], area : area, callback : function (value) { //在回调函数里可以调用你的业务代码实现前端的各种逻辑和效果 console.log(value); } }; Fast.api.open($.fn.bootstrapTable.defaults.extend.detail_url + "?ids=" + $(this).data('id'), '联系人详情', options); }).on('click', '.show-customer', function (data) { var area = [$(window).width() > 1200 ? '1200px' : '95%', $(window).height() > 800 ? '800px' : '95%']; var options = { shadeClose : false, shade : [0.3, '#393D49'], area : area, callback : function (value) { //在回调函数里可以调用你的业务代码实现前端的各种逻辑和效果 console.log(value); } }; Fast.api.open($.fn.bootstrapTable.defaults.extend.customer_url + "?ids=" + $(this).data('id'), '客户详情', options); }).on('click','.btn-send-email',function () { var tab_id=$('.active.in').attr('id'); var table; switch (tab_id){ case 'first'://全部 table=$('#table'); break; case 'second'://我负责的 table=$('#table1'); break; case 'third'://下属负责的 table=$('#table2'); break; case 'four'://今日待跟进 table=$('#table3'); break; case 'five'://今日已跟进 table=$('#table4'); break; case 'six'://从未跟进的 table=$('#table5'); break; } //在templateView的模式下不能调用table.bootstrapTable('getSelections')来获取选中的ID,只能通过下面的Table.api.selectedids来获取 if(Table.api.selectedids(table).length == 0){ layer.alert('请选择要选中的客户!'); return false; } var $this=$(this); var ids=JSON.stringify(Table.api.selectedids(table)); var url=$this.data('url'),title=$this.data('title'),types=$this.data('types'); Fast.api.open(url+"?ids="+ids+"&type="+types, title,{ shadeClose: false, shade: false, maxmin: false, moveOut: false, scrollbars:false, 'area':[ $(window).width() > 800 ? '600px' : '400px', $(window).height() > 600 ? '500px' : '400px' ], callback:function(value){ Form.events.plupload("#plupload-local"); // 在这里可以接收弹出层中使用`Fast.api.close(data)`进行回传数据 }, }); }).on('click','.btn-send-sms',function () { var tab_id=$('.active.in').attr('id'); var table; switch (tab_id){ case 'first'://全部 table=$('#table'); break; case 'second'://我负责的 table=$('#table1'); break; case 'third'://下属负责的 table=$('#table2'); break; case 'four'://今日待跟进 table=$('#table3'); break; case 'five'://今日已跟进 table=$('#table4'); break; case 'six'://从未跟进的 table=$('#table5'); break; } //在templateView的模式下不能调用table.bootstrapTable('getSelections')来获取选中的ID,只能通过下面的Table.api.selectedids来获取 if(Table.api.selectedids(table).length == 0){ layer.alert('请选择要选中的客户!'); return false; } var $this=$(this); var ids=JSON.stringify(Table.api.selectedids(table)); var url=$this.data('url'),title=$this.data('title'),types=$this.data('types'); Fast.api.open(url+"?ids="+ids+"&type="+types, title,{ shadeClose: false, shade: false, maxmin: false, moveOut: false, scrollbars:false, 'area':[ $(window).width() > 800 ? '600px' : '400px', $(window).height() > 600 ? '500px' : '400px' ], callback:function(value){ Form.events.plupload("#plupload-local"); // 在这里可以接收弹出层中使用`Fast.api.close(data)`进行回传数据 }, }); }).on("click", ".btn-export", function () { var tab_id=$('.active.in').attr('id'); var table,type; switch (tab_id){ case 'first'://全部 table=$('#table'); type=0; break; case 'second'://我负责的 table=$('#table1'); type=1; break; case 'third'://下属负责的 table=$('#table2'); type=2; break; case 'four'://今日待跟进 table=$('#table3'); type=3; break; case 'five'://今日已跟进 table=$('#table4'); type=4; break; case 'six'://从未跟进的 table=$('#table5'); type=5; break; } var ids = Table.api.selectedids(table); var page = table.bootstrapTable('getData'); var options = table.bootstrapTable('getOptions'); var params=options.queryParams({}); var all = options.totalRows; var sort = options.sortName+' '+options.sortOrder; var filter = params.filter; var op = params.op; Layer.confirm("请选择导出的选项", { title : '导出数据', btn : ["选中项(" + ids.length + "条)", "本页(" + page.length + "条)", "全部(" + all + "条)"], success : function (layero, index) { $(".layui-layer-btn a", layero).addClass("layui-layer-btn0"); }, yes : function (index, layero) { if (ids.length == 0) { Layer.alert('数据为空'); return true; } $.post('qingdong/customer/contacts/export', {sort:sort,ids : ids.join(","), isall : 1}, function (res) { if(res.code == 1){ Layer.alert(res.msg); window.location.href = res.data.filePath; Layer.close(index); table.bootstrapTable('refresh'); }else{ Layer.alert(res.msg); } }, 'json'); return false; }, btn2 : function (index, layero) { if (page.length == 0) { Layer.alert('数据为空'); return true; } var ids = []; $.each(page, function (i, j) { ids.push(j.id); }); $.post('qingdong/customer/contacts/export', {sort:sort,ids : ids.join(","), isall : 2}, function (res) { if(res.code == 1){ Layer.alert(res.msg); window.location.href = res.data.filePath; Layer.close(index); table.bootstrapTable('refresh'); }else{ Layer.alert(res.msg); } }, 'json'); return false; }, btn3 : function (index, layero) { if (page.length == 0) { Layer.alert('数据为空'); return true; } $.post('qingdong/customer/contacts/export?filter='+filter+'&op='+op, {sort:sort,ids : ids.join(","), isall : 3,type:type}, function (res) { if(res.code == 1){ Layer.alert(res.msg); window.location.href = res.data.filePath; Layer.close(index); table.bootstrapTable('refresh'); }else{ Layer.alert(res.msg); } }, 'json'); return false; } }) }).on('click','.btn-imports',function () { Fast.api.open("qingdong/customer/contacts/import", "联系人导入",{ shadeClose: false, shade: false, maxmin: false, moveOut: false, scrollbars:false, 'area':[ $(window).width() > 800 ? '600px' : '400px', $(window).height() > 600 ? '500px' : '400px' ], callback:function(value){ Form.events.plupload("#plupload-local"); // 在这里可以接收弹出层中使用`Fast.api.close(data)`进行回传数据 }, }); }); }, tableinfo:{ url : '', toolbar: '#toolbar', pk : 'id', sortName : 'id', fixedColumns : true, fixedNumber : 2, fixedRightNumber : 1, search:false, searchFormVisible:true, columns : [ [ {checkbox : true}, { field : 'name', title : '姓名', fixedColumns : true, formatter : function (value, row, index) { if(value ==''){ value = '无'; } return "" + value + ""; } }, { field : 'customer', title : '所属客户', fixedColumns : true, formatter : function (value, row, index) { if(row.customer){ return "" + row.customer.name + ""; }else{ return row.customer_id; } },operate:false }, {field : 'customer_id', title : '客户名称', visible: false, addClass: "selectpage", extend: "data-source='qingdong/customer/customer/index' data-field='name'"}, {field : 'subname', title : '尊称',operate:'like'}, {field : 'mobile', title : '手机',operate:'like'}, {field : 'email', title : '邮箱',operate:'like'}, {field : 'role', title : '角色',operate:false}, {field : 'post', title : '职务',operate:false}, {field : 'address', title : '地址',operate:false}, {field : 'next_time', title : '下次联系时间',operate:false}, {field : 'remarks', title : '备注信息',operate:false}, {field : 'owner_staff.name', title : '归属人',operate:false}, {field : 'createtime', title : '创建时间',formatter: Table.api.formatter.datetime,operate:false}, {field : 'updatetime', title : '更新时间',formatter: Table.api.formatter.datetime,operate:false}, { field: 'operate2', title: __('Operate'), events: { 'click .btn-chooseone': function (e, value, row, index) { Fast.api.close({id: row.id, name: row.name}); }, }, formatter: function () { return ' ' + __('Choose') + ''; } }, {field: 'operate', title: __('Operate'), events: Table.api.events.operate, formatter: Table.api.formatter.buttons, buttons: [ { name: 'detail', text: __('跟进'), title: __('跟进'), extend:'data-area=["80%","80%"]', classname: 'records btn-dialog', url: 'qingdong/customer/record/add/relation_type/2', visible: function (row) { //返回true时按钮显示,返回false隐藏 return true; } }, ] }, ] ], onLoadSuccess:function(){ // 这里就是数据渲染结束后的回调函数 $(".btn-add").data("area",["80%","80%"]); $(".btn-edit").data("area",["80%","80%"]); } }, table: { first: function () { // 初始化表格参数配置 Table.api.init({ extend : { add_url : 'qingdong/customer/contacts/add', detail_url : 'qingdong/customer/contacts/detail', customer_url : 'qingdong/customer/customer/detail', table : 'contacts', } }); if(Config.fields !='[]'){ if (Config.fields && Object.keys(Config.fields).length > 0) { var fields = JSON.parse(Config.fields); var start = Controller.tableinfo.columns[0].length-2; for (var i = 0; i < fields.length; i++) { if (fields[i].hasOwnProperty('formatter')) fields[i].formatter = eval(fields[i].formatter); if (fields[i].hasOwnProperty('events')) fields[i].events = eval(fields[i].events); if (fields[i].hasOwnProperty('searchList')) fields[i].searchList = JSON.parse(fields[i].searchList); Controller.tableinfo.columns[0].splice(start + i, 0, fields[i]); } } } const q = {}; location.search.replace(/([^?&=]+)=([^&]+)/g,function(_,k,v){q[k]=v}); var table = $("#table"); Controller.tableinfo.url=location.href+'&type=0'; Controller.tableinfo.toolbar='#toolbar'; Controller.tableinfo.columns[0][Controller.tableinfo.columns[0].length-1].table=table; if (q.isselect == 1) { Controller.tableinfo.columns[0][Controller.tableinfo.columns[0].length - 1].visible = false; } else { Controller.tableinfo.columns[0][Controller.tableinfo.columns[0].length - 2].visible = false; } // 初始化表格 table.bootstrapTable(Controller.tableinfo); // 为表格绑定事件 Table.api.bindevent(table); }, second: function () { // 初始化表格参数配置 Table.api.init({ extend : { add_url : 'qingdong/customer/contacts/add', detail_url : 'qingdong/customer/contacts/detail', customer_url : 'qingdong/customer/customer/detail', table : 'contacts', } }); var table = $("#table1"); Controller.tableinfo.url=location.href+'&type=1'; Controller.tableinfo.toolbar='#toolbar1'; Controller.tableinfo.columns[0][Controller.tableinfo.columns[0].length-1].table=table; // 初始化表格 table.bootstrapTable(Controller.tableinfo); // 为表格绑定事件 Table.api.bindevent(table); }, third: function () { // 初始化表格参数配置 Table.api.init({ extend : { add_url : 'qingdong/customer/contacts/add', detail_url : 'qingdong/customer/contacts/detail', customer_url : 'qingdong/customer/customer/detail', table : 'contacts', } }); var table = $("#table2"); Controller.tableinfo.url=location.href+'&type=2'; Controller.tableinfo.toolbar='#toolbar2'; Controller.tableinfo.columns[0][Controller.tableinfo.columns[0].length-1].table=table; // 初始化表格 table.bootstrapTable(Controller.tableinfo); // 为表格绑定事件 Table.api.bindevent(table); }, four: function () { // 初始化表格参数配置 Table.api.init({ extend : { add_url : 'qingdong/customer/contacts/add', detail_url : 'qingdong/customer/contacts/detail', customer_url : 'qingdong/customer/customer/detail', table : 'contacts', } }); var table = $("#table3"); Controller.tableinfo.url=location.href+'&type=3'; Controller.tableinfo.toolbar='#toolbar3'; Controller.tableinfo.columns[0][Controller.tableinfo.columns[0].length-1].table=table; // 初始化表格 table.bootstrapTable(Controller.tableinfo); // 为表格绑定事件 Table.api.bindevent(table); }, five: function () { // 初始化表格参数配置 Table.api.init({ extend : { add_url : 'qingdong/customer/contacts/add', detail_url : 'qingdong/customer/contacts/detail', customer_url : 'qingdong/customer/customer/detail', table : 'contacts', } }); var table = $("#table4"); Controller.tableinfo.url=location.href+'&type=4'; Controller.tableinfo.toolbar='#toolbar4'; Controller.tableinfo.columns[0][Controller.tableinfo.columns[0].length-1].table=table; // 初始化表格 table.bootstrapTable(Controller.tableinfo); // 为表格绑定事件 Table.api.bindevent(table); }, six: function () { // 初始化表格参数配置 Table.api.init({ extend : { add_url : 'qingdong/customer/contacts/add', detail_url : 'qingdong/customer/contacts/detail', customer_url : 'qingdong/customer/customer/detail', table : 'contacts', } }); var table = $("#table5"); Controller.tableinfo.url=location.href+'&type=5'; Controller.tableinfo.toolbar='#toolbar5'; Controller.tableinfo.columns[0][Controller.tableinfo.columns[0].length-1].table=table; // 初始化表格 table.bootstrapTable(Controller.tableinfo); // 为表格绑定事件 Table.api.bindevent(table); }, }, add : function () { Controller.api.bindevent(); }, edit : function () { Form.api.bindevent($("form"), function(data, ret){ //这里是表单提交处理成功后的回调函数,接收来自php的返回数据 Fast.api.close(data);//这里是重点 }, function(data, ret){ }); Controller.api.bindevent(); }, import : function () { Form.api.bindevent($("form[role=form]"), function (data, ret) { //这里是表单提交处理成功后的回调函数,接收来自php的返回数据 Fast.api.close(data);//这里是重点 }, function (data, ret) { Toastr.error(ret.msg); return false; }); }, detail : function () { // 初始化表格参数配置 Table.api.init({}); //跟进记录 var table1 = $("#records"); // 初始化表格 table1.bootstrapTable({ url : 'qingdong/customer/record/index?contacts_id='+Config.idinfo.id, pk : 'id', sortName : 'id', operate : false, commonSearch : false, search : false, visible : false, showColumns : false, showExport : false, showToggle : false, columns : [ [ {field: 'follow_type', title: __('跟进类型')}, {field: 'follow_time', title: __('跟进时间')}, {field: 'follow', title: __('跟进状态')}, {field: 'content', title: __('跟进内容'),cellStyle:function (value,row,index,field) { return { css: { "min-width": "150px", "white-space": "nowrap", "text-overflow": "ellipsis", "overflow": "hidden", "max-width":"300px", 'cursor':"pointer" } }; },formatter:function (value,row,index,field) { var span=document.createElement('span'); span.setAttribute('title',value); span.innerHTML = value; return span.outerHTML; } }, {field: 'next_time', title: __('下次跟进时间')}, { field : 'operate', title : __('Operate'), table : table1, events : Table.api.events.operate, formatter : Table.api.formatter.operate, buttons : [ { name : '详情', text : __('详情'), classname : 'records btn-dialog', url : 'qingdong/customer/record/detail', callback: function (data) { $('.btn-success').trigger('click'); }, }, { name : '评论', text : __('评论'), classname : 'records btn-dialog', url : 'qingdong/customer/comment/add', callback: function (data) { $('.btn-success').trigger('click'); }, } ] } ] ] }); //操作日志 var table2 = $("#operation_log"); // 初始化表格 table2.bootstrapTable({ url : 'qingdong/customer/log/index?contacts_id='+Config.idinfo.id, pk : 'id', sortName : 'id', operate : false, commonSearch : false, search : false, visible : false, showColumns : false, showExport : false, showToggle : false, columns : [ [ {field: 'staff.name', title: __('员工')}, {field: 'content', title: __('内容'),cellStyle:function (value,row,index,field) { return { css: { "min-width": "150px", "white-space": "nowrap", "text-overflow": "ellipsis", "overflow": "hidden", "max-width":"300px", 'cursor':"pointer" } }; },formatter:function (value,row,index,field) { var span=document.createElement('span'); span.setAttribute('title',value); span.innerHTML = value; return span.outerHTML; } }, {field: 'createtime', title: __('Createtime'), operate:'RANGE', addclass:'datetimerange', formatter: Table.api.formatter.datetime}, ] ] }); //附件 $('#files').bootstrapTable({ url : 'qingdong/customer/contacts/get_file'+ location.search, pk : 'id', sortName : 'id', operate : false, commonSearch : false, search : false, visible : false, showColumns : false, showExport : false, showToggle : false, columns : [ [ {field : 'name', title : '附件名称'}, {field : 'size', title : '附件大小'}, {field : 'staff.name', title : '上传人'}, {field : 'createtime', title : '上传时间',formatter: Table.api.formatter.datetime}, { field : 'operate', title : '操作', formatter : function (value, row, index) { return "" + '预览' + ""; } }, ] ] }); //编辑 $(document).on('click','.btn-edit',function () { var id=$('#ids').val(); Fast.api.open("qingdong/customer/contacts/edit?ids="+id, "客户编辑",{ shadeClose: false, shade: false, maxmin: false, moveOut: false, scrollbars:false, callback:function () { location.reload() } }); }).on('click',".btn-del",function(){//删除 var id=$('#ids').val(); Layer.confirm('确定删除当前客户吗?', { btn: ['确定','取消'], title: '提示', },function(index, layero){ Fast.api.ajax("qingdong/customer/contacts/del?ids="+id,function(data,ret){ if(ret.code == 1){ Layer.close(index); parent.location.reload(); } },function(data,ret){ }); }); }).on('click','.btn-send-email',function () { //在templateView的模式下不能调用table.bootstrapTable('getSelections')来获取选中的ID,只能通过下面的Table.api.selectedids来获取 var $this=$(this); var ids=$('#ids').val(); var url=$this.data('url'),title=$this.data('title'),types=$this.data('types'); Fast.api.open(url+"?ids="+ids+"&type="+types, title,{ shadeClose: false, shade: false, maxmin: false, moveOut: false, scrollbars:false, 'area':[ $(window).width() > 800 ? '600px' : '400px', $(window).height() > 600 ? '500px' : '400px' ], callback:function(value){ Form.events.plupload("#plupload-local"); // 在这里可以接收弹出层中使用`Fast.api.close(data)`进行回传数据 }, }); }).on('click','.btn-send-sms',function () { //在templateView的模式下不能调用table.bootstrapTable('getSelections')来获取选中的ID,只能通过下面的Table.api.selectedids来获取 var $this=$(this); var ids=$('#ids').val(); var url=$this.data('url'),title=$this.data('title'),types=$this.data('types'); Fast.api.open(url+"?ids="+ids+"&type="+types, title,{ shadeClose: false, shade: false, maxmin: false, moveOut: false, scrollbars:false, 'area':[ $(window).width() > 800 ? '600px' : '400px', $(window).height() > 600 ? '500px' : '400px' ], callback:function(value){ Form.events.plupload("#plupload-local"); // 在这里可以接收弹出层中使用`Fast.api.close(data)`进行回传数据 }, }); }); Controller.api.bindevent(); }, api : { bindevent : function () { $(document).on("click", ".select-customer", function () { var $this = $(this); parent.Backend.api.open($(this).data("url"), __('Select'), { callback: function (data) { $this.html(data.name); $('[name="' + $this.data('name') + '"]').val(data.id); } }); }); Form.api.bindevent($("form[role=form]"), function(data, ret){ //这里是表单提交处理成功后的回调函数,接收来自php的返回数据 Fast.api.close(data);//这里是重点 }); } } }; return Controller; });