datalist.html 3.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104
  1. {extend name="../../base/view/common/base" /}
  2. <!-- 主体 -->
  3. {block name="body"}
  4. <div class="p-page">
  5. <form class="layui-form gg-form-bar border-t border-x" lay-filter="barsearchform">
  6. {gt name="$is_auth" value="0"}
  7. <div class="layui-input-inline user-name" style="width:100px;">
  8. <input type="text" name="username" placeholder="选择跟进人" class="layui-input picker-admin" readonly />
  9. <input type="text" name="uid" value="" style="display:none" />
  10. </div>
  11. {/gt}
  12. <div class="layui-input-inline" style="width:175px;">
  13. <input type="text" class="layui-input" id="follow_time" placeholder="下次跟进日期" readonly name="follow_time">
  14. </div>
  15. <div class="layui-input-inline" style="width:300px">
  16. <input type="text" name="keywords" placeholder="关键字,沟通内容/销售机会/客户名称" class="layui-input" autocomplete="off" />
  17. </div>
  18. <div class="layui-input-inline" style="width:150px">
  19. <button class="layui-btn layui-btn-normal" lay-submit="" lay-filter="table-search"><i class="layui-icon layui-icon-search mr-1"></i>搜索</button>
  20. <button type="reset" class="layui-btn layui-btn-reset" lay-filter="table-reset">清空</button>
  21. </div>
  22. </form>
  23. <table class="layui-hide" id="table_customer_trace" lay-filter="table_customer_trace"></table>
  24. </div>
  25. <script type="text/html" id="toolbarDemo">
  26. <div>
  27. <h3>跟进记录</h3>
  28. </div>
  29. </script>
  30. {/block}
  31. <!-- /主体 -->
  32. <!-- 脚本 -->
  33. {block name="script"}
  34. <script>
  35. const moduleInit = ['tool','oaPicker','laydatePlus','tablePlus'];
  36. function gouguInit() {
  37. var table = layui.tablePlus, tool = layui.tool, form = layui.form,laydatePlus=layui.laydatePlus;
  38. var follow_time = new laydatePlus({'target':'follow_time'});
  39. layui.traceTable = table.render({
  40. elem: "#table_customer_trace"
  41. , toolbar: "#toolbarDemo"
  42. ,url: "/customer/trace/datalist"
  43. ,page: true
  44. ,limit: 20
  45. ,cellMinWidth: 80
  46. ,is_excel: true
  47. ,height: 'full-114'
  48. ,cols: [[
  49. {field:'id',width:80, title: 'ID号', align:'center'}
  50. ,{field:'stage_name',title: '当前阶段',width:100,align:'center'}
  51. ,{field:'content',title: '沟通内容',minWidth:300}
  52. ,{field:'chance',title: '销售机会',width:200}
  53. ,{field:'type_name',title: '跟进方式',width:80,align:'center'}
  54. ,{field:'admin_name',title: '跟进人',width:80,align:'center'}
  55. ,{field:'follow_time', title: '跟进日期',width:150,align:'center'}
  56. ,{field:'next_time', title: '下次跟进日期',width:150,align:'center',style:'color:#16b777'}
  57. ,{field:'customer',title: '关联客户',width: 300}
  58. ,{width:120,fixed:'right',title: '操作', align:'center',ignoreExport:true,templet: function(d){
  59. var html='';
  60. var btn1='<a class="layui-btn layui-btn-normal layui-btn-xs" lay-event="view">详细</a>';
  61. var btn2='<a class="layui-btn layui-btn-xs" lay-event="edit">编辑</a>';
  62. var btn3='<a class="layui-btn layui-btn-danger layui-btn-xs" lay-event="del">删除</a>';
  63. if(d.admin_id == login_admin){
  64. return '<div class="layui-btn-group">'+btn1+btn2+btn3+'</div>';
  65. }
  66. else{
  67. return '<div class="layui-btn-group">'+btn1+'</div>';
  68. }
  69. }}
  70. ]]
  71. });
  72. table.on('tool(table_customer_trace)',function (obj) {
  73. var checkStatus = table.checkStatus(obj.config.id); //获取选中行状态
  74. var data = obj.data;
  75. if (obj.event === 'view') {
  76. tool.side("/customer/trace/view?id="+data.id);
  77. return;
  78. }
  79. if (obj.event === 'edit') {
  80. tool.side("/customer/trace/add?id="+data.id);
  81. return;
  82. }
  83. if (obj.event === 'del') {
  84. layer.confirm('确定要删除该线索机会吗?', { icon: 3, title: '提示' }, function (index) {
  85. let callback = function (e) {
  86. layer.msg(e.msg);
  87. if (e.code == 0) {
  88. obj.del();
  89. }
  90. }
  91. tool.delete("/customer/trace/del", { id: data.id }, callback);
  92. layer.close(index);
  93. });
  94. return;
  95. }
  96. });
  97. }
  98. </script>
  99. {/block}
  100. <!-- /脚本 -->