| | |
| | | background-color: #fff; |
| | | box-shadow: 0 -1px 2px 0 rgba(0, 0, 0, .05); |
| | | } |
| | | .cool-divider { |
| | | float: left; |
| | | margin: 4px 18px; |
| | | display: inline-block; |
| | | height: 32px; |
| | | width: 1px; |
| | | vertical-align: middle; |
| | | position: relative; |
| | | top: -.06em; |
| | | box-sizing: border-box; |
| | | -webkit-tap-highlight-color: transparent; |
| | | margin-top: 5px !important; |
| | | margin-bottom: 5px !important; |
| | | background: #c8d1dabd; |
| | | } |
| | | |
| | | .card-body-item { |
| | | display: inline-block; |
| | | border-right: 1px solid #e0e0e0; |
| | | width: 250px; |
| | | padding: 0 30px 0 10px; |
| | | } |
| | | .header-desc { |
| | | overflow:hidden; |
| | | white-space: nowrap; |
| | | text-overflow: ellipsis; |
| | | -o-text-overflow:ellipsis; |
| | | } |
| | | |
| | | </style> |
| | |
| | | <div class="layui-fluid" style="padding-bottom: 75px;"> |
| | | <!-- 标题 --> |
| | | <div class="layui-card"> |
| | | <div class="layui-card-header"> |
| | | <div class="layui-card-header" style="padding-top: 5px; padding-bottom: 5px"> |
| | | <div> |
| | | <i class="layui-icon" style="font-size: 20px;color: #1890ff;font-weight: bold"></i> |
| | | <span id="form-name" style="margin: 0 6px;font-size: 18px;font-weight: bold;letter-spacing: 1px"></span> |
| | | <span style="opacity: .5;font-size: small;margin-left: 5px">甲方单位</span> |
| | | </div> |
| | | </div> |
| | | <div class="layui-card-body"> |
| | | <div class="card-body-item"> |
| | | <div class="header-sub"> |
| | | 电话 |
| | | 客户电话 |
| | | </div> |
| | | <div class="header-desc" id="form-tel"> |
| | | 15067665399 |
| | | |
| | | </div> |
| | | </div> |
| | | |
| | | <div class="card-body-item"> |
| | | <div class="card-body-item" style="width: 400px"> |
| | | <div class="header-sub"> |
| | | 详细地址 |
| | | 客户详细地址 |
| | | </div> |
| | | <div class="header-desc" id="form-addr"> |
| | | 河北省邯郸市君邦乳业有限公司 |
| | | |
| | | </div> |
| | | </div> |
| | | |
| | |
| | | 负责人 |
| | | </div> |
| | | <div class="header-desc" id="form-director" style="color: #006fdb;"> |
| | | 陆晓涛 |
| | | |
| | | </div> |
| | | </div> |
| | | </div> |
| | | </div> |
| | | <!-- 基本信息 --> |
| | | <div class="layui-row"> |
| | | <div class="layui-col-md9"> |
| | | <!-- 基本信息 --> |
| | | <div class="layui-col-md12"> |
| | | <div class="layui-card"> |
| | | <div class="layui-card-header"> |
| | | 基本信息 |
| | |
| | | <input name="cstmrType$" class="layui-input" disabled /> |
| | | </div> |
| | | </div> |
| | | <div class="layui-inline layui-col-md6"> |
| | | <label class="layui-form-label">客户关系:</label> |
| | | <div class="layui-input-block"> |
| | | <input name="rela" class="layui-input" disabled/> |
| | | </div> |
| | | </div> |
| | | <!-- <div class="layui-inline layui-col-md6">--> |
| | | <!-- <label class="layui-form-label">客户关系:</label>--> |
| | | <!-- <div class="layui-input-block">--> |
| | | <!-- <input name="rela" class="layui-input" disabled/>--> |
| | | <!-- </div>--> |
| | | <!-- </div>--> |
| | | <div class="layui-inline layui-col-md6"> |
| | | <label class="layui-form-label">省市区:</label> |
| | | <div class="layui-input-block"> |
| | |
| | | <input name="type$" class="layui-input" disabled /> |
| | | </div> |
| | | </div> |
| | | <div class="layui-inline layui-col-md6"> |
| | | <div class="layui-inline layui-col-md12"> |
| | | <label class="layui-form-label">备注:</label> |
| | | <div class="layui-input-block"> |
| | | <input name="remarks" class="layui-input" disabled /> |
| | |
| | | </div> |
| | | </div> |
| | | </div> |
| | | <div class="layui-col-md3" style="width: 24%;margin-left: 1%"> |
| | | <div class="layui-card"> |
| | | <div class="layui-card-header"> |
| | | <span>跟进人</span> |
| | | <span style="float: right;cursor: pointer;"> |
| | | <i class="layui-icon" style="font-size: 20px;color: #1890ff;"></i> |
| | | </span> |
| | | </div> |
| | | <div class="layui-card-body"> |
| | | <table id="originTable" lay-filter="originTable"></table> |
| | | </div> |
| | | </div> |
| | | </div> |
| | | <!-- <!– 跟进人 –>--> |
| | | <!-- <div class="layui-col-md3" style="width: 24%;margin-left: 1%">--> |
| | | <!-- <div class="layui-card">--> |
| | | <!-- <div class="layui-card-header">--> |
| | | <!-- <span>跟进人</span>--> |
| | | <!-- <span lay-filter="followerAdd" lay-submit style="float: right;cursor: pointer;">--> |
| | | <!-- <i class="layui-icon" style="font-size: 20px;color: #1890ff;"></i>--> |
| | | <!-- </span>--> |
| | | <!-- </div>--> |
| | | <!-- <div class="layui-card-body">--> |
| | | <!-- <table id="followersTable" lay-filter="followersTable"></table>--> |
| | | <!-- </div>--> |
| | | <!-- </div>--> |
| | | <!-- </div>--> |
| | | </div> |
| | | </div> |
| | | |
| | | <div class="form-group-bottom text-right"> |
| | | <button class="layui-btn" lay-filter="refresh" lay-submit><i class="layui-icon"></i> 刷新 </button> |
| | | <button class="layui-btn layui-btn-normal" lay-filter="save" lay-submit><i class="layui-icon"></i> 保存 </button> |
| | | </div> |
| | | |
| | | </form> |
| | | |
| | | <script type="text/html" id="followerTabOperate"> |
| | | <a class="layui-btn layui-btn-primary layui-btn-xs btn-edit" lay-event="del">删除</a> |
| | | </script> |
| | | |
| | | <!-- 跟进人 --> |
| | | <script type="text/html" id="followerEditDialog"> |
| | | <form id="followerEditForm" lay-filter="followerEditForm" class="layui-form model-form"> |
| | | <input name="experimentId" type="hidden"/> |
| | | <div class="layui-form-item" style="float: left;clear: none;margin-right: 20px"> |
| | | <label class="layui-form-label">选择成员</label> |
| | | <div class="layui-input-block"> |
| | | <div id="followersBox" name="followersBox"> |
| | | </div> |
| | | </div> |
| | | </div> |
| | | <div class="layui-form-item text-right" style="float: left;clear: none"> |
| | | <button class="layui-btn layui-btn-primary" type="button" ew-event="closeDialog">取消</button> |
| | | <button class="layui-btn" lay-filter="followerSubmit" lay-submit>保存</button> |
| | | </div> |
| | | </form> |
| | | </script> |
| | | |
| | | <script> |
| | | var cstmrId = top.cstmrByMore; |
| | | $('.layui-layer-close').hide(); |
| | |
| | | base: baseUrl + "/static/layui/lay/modules/" |
| | | }).extend({ |
| | | notice: 'notice/notice', |
| | | }).use(['form', 'table', 'laydate', 'notice'], function () { |
| | | }).use(['form', 'table', 'laydate', 'notice', 'xmSelect'], function () { |
| | | var $ = layui.jquery; |
| | | var form = layui.form; |
| | | var table = layui.table; |
| | | var laydate = layui.laydate; |
| | | var notice = layui.notice; |
| | | var xmSelect = layui.xmSelect; |
| | | |
| | | form.render('select'); |
| | | |
| | |
| | | let cstmr = res.data; |
| | | top.cstmrByMore = null; |
| | | $("#form-name").html(cstmr.name); |
| | | $("#form-tel").html(cstmr.tel); |
| | | $("#form-addr").html(cstmr.addr); |
| | | $("#form-director").html(cstmr.director$); |
| | | if (cstmr.tel) {$("#form-tel").html(cstmr.tel);} |
| | | if (cstmr.addr) {$("#form-addr").html(cstmr.addr);$("#form-addr").attr("title", cstmr.addr);} |
| | | if (cstmr.director$) {$("#form-director").html(cstmr.director$);} |
| | | // 设备明细 |
| | | form.val('formAdvForm', cstmr); |
| | | // 跟进人 |
| | | initFollowers(cstmr.id); |
| | | layDateRender(); |
| | | } else if (res.code === 403) { |
| | | top.location.href = baseUrl + "/"; |
| | |
| | | elem: '#endTime', |
| | | type: 'datetime' |
| | | }); |
| | | |
| | | laydate.render({ |
| | | elem: '#lastTime', |
| | | type: 'datetime' |
| | | }); |
| | | } |
| | | layDateRender(); |
| | | |
| | | // 渲染跟进人模块 |
| | | function initFollowers(cstmrId) { |
| | | if (!cstmrId) { |
| | | return; |
| | | } |
| | | $.ajax({ |
| | | url: baseUrl+"/cstmr/followers/table/auth", |
| | | headers: {'token': localStorage.getItem('token')}, |
| | | data: { |
| | | cstmrId: cstmrId |
| | | }, |
| | | method: 'GET', |
| | | success: function (res) { |
| | | if (res.code === 200){ |
| | | var follTab = table.render({ |
| | | elem: '#followersTable', |
| | | data: res.data, |
| | | limit: 999, |
| | | height: 'full-408', |
| | | cols: [[ |
| | | {field: 'userName', title: '工作人员'}, |
| | | {fixed: 'right', title:'', align: 'center', toolbar: '#followerTabOperate', width: 70} |
| | | ]], |
| | | done: function (res, curr, count) { |
| | | $('#dictTable+.layui-table-view .layui-table-body tbody>tr:first').trigger('click'); |
| | | } |
| | | }); |
| | | // 监听行工具事件 |
| | | table.on('tool(followersTable)', function(obj){ |
| | | let data = obj.data; |
| | | switch (obj.event) { |
| | | case "del": |
| | | let loadIndex = layer.load(2); |
| | | $.ajax({ |
| | | url: baseUrl+"/cstmr/followers/remove/auth", |
| | | headers: {'token': localStorage.getItem('token')}, |
| | | data: { |
| | | cstmrId: cstmrId, |
| | | userId: data.userId |
| | | }, |
| | | method: 'POST', |
| | | success: function (res) { |
| | | layer.close(loadIndex); |
| | | if (res.code === 200){ |
| | | initFollowers(cstmrId); |
| | | } else if (res.code === 403){ |
| | | top.location.href = baseUrl+"/"; |
| | | } else { |
| | | layer.msg(res.msg, {icon: 2}); |
| | | } |
| | | } |
| | | }) |
| | | break; |
| | | } |
| | | }); |
| | | } else if (res.code === 403){ |
| | | top.location.href = baseUrl+"/"; |
| | | }else { |
| | | layer.msg(res.msg, {icon: 2}) |
| | | } |
| | | } |
| | | }) |
| | | } |
| | | |
| | | // 添加跟进人 |
| | | var followerLayer; |
| | | form.on('submit(followerAdd)', function (data) { |
| | | if (followerLayer) {return;} |
| | | followerLayer = admin.open({ |
| | | type: 1, |
| | | offset: '150px', |
| | | area: '600px', |
| | | title: '添加跟进人', |
| | | content: $('#followerEditDialog').html(), |
| | | success: function (layero, dIndex) { |
| | | // 表单提交事件 |
| | | form.on('submit(followerSubmit)', function (data) { |
| | | let selectList = xmSelectIdx.getValue(); |
| | | if (selectList.length === 0) { |
| | | layer.msg("请选择至少一条数据", {icon: 3}); |
| | | return false; |
| | | } |
| | | let loadIndex = layer.load(2); |
| | | $.ajax({ |
| | | url: baseUrl+"/cstmr/followers/add/auth", |
| | | headers: {'token': localStorage.getItem('token')}, |
| | | data: { |
| | | cstmrId: cstmrId, |
| | | followerIds: selectList.map(function (d) { |
| | | return d.value; |
| | | }) |
| | | }, |
| | | method: 'POST', |
| | | success: function (res) { |
| | | if (res.code === 200){ |
| | | layer.close(loadIndex); |
| | | initFollowers(cstmrId); |
| | | } else if (res.code === 403){ |
| | | top.location.href = baseUrl+"/"; |
| | | }else { |
| | | layer.msg(res.msg, {icon: 2}) |
| | | } |
| | | } |
| | | }) |
| | | layer.close(dIndex); |
| | | return false; |
| | | }); |
| | | let xmSelectIdx = xmSelect.render({ |
| | | el: '#followersBox', |
| | | style: { |
| | | width: '280px', |
| | | }, |
| | | autoRow: true, |
| | | toolbar: { show: true }, |
| | | filterable: true, |
| | | remoteSearch: true, |
| | | remoteMethod: function(val, cb, show){ |
| | | $.ajax({ |
| | | url: baseUrl+"/user/all/get/kv", |
| | | headers: {'token': localStorage.getItem('token')}, |
| | | data: { |
| | | condition: val |
| | | }, |
| | | method: 'POST', |
| | | success: function (res) { |
| | | if (res.code === 200){ |
| | | cb(res.data) |
| | | } else { |
| | | cb([]); |
| | | layer.msg(res.msg, {icon: 2}); |
| | | } |
| | | } |
| | | }); |
| | | } |
| | | }) |
| | | // 弹窗不出现滚动条 |
| | | $(layero).children('.layui-layer-content').css('overflow', 'visible'); |
| | | layui.form.render('select'); |
| | | }, |
| | | end: function () { |
| | | followerLayer = null; |
| | | } |
| | | }) |
| | | }); |
| | | |
| | | /* 监听表单提交 */ |
| | | form.on('submit(refresh)', function (data) { |
| | | init(); |
| | | return false; |
| | | }); |
| | | form.on('submit(save)', function (elem) { |
| | | let data = elem.field; |
| | | notice.msg('正在拼命修改数据......', {icon: 4, position: "topRight"}); |
| | | $.ajax({ |
| | | url: baseUrl + "/issue/process/auth", |
| | | headers: {'token': localStorage.getItem('token')}, |
| | | contentType: 'application/json;charset=UTF-8', |
| | | method: 'POST', |
| | | data: JSON.stringify({ |
| | | id: Number(data.id), |
| | | uuid: data.uuid, |
| | | dealer: data.dealer, |
| | | settle: Number(data.settle), |
| | | endTime: top.strToDate(data.endTime$), |
| | | // lastTime: data.lastTime, |
| | | reason: data.reason, |
| | | deal: data.deal, |
| | | }), |
| | | success: function (res) { |
| | | notice.destroy(); |
| | | if (res.code === 200) { |
| | | notice.success({title: '消息通知', message: res.msg}); |
| | | $('.layui-layer-close').click(); |
| | | } else if (res.code === 403) { |
| | | top.location.href = baseUrl + "/"; |
| | | } else { |
| | | notice.error({title: '消息通知', message: res.msg}); |
| | | } |
| | | } |
| | | }) |
| | | return false; |
| | | }); |
| | | |
| | | }); |
| | | }) |
| | | </script> |