Brak opisu

associatWorkOrder.html 23KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595
  1. <!DOCTYPE html>
  2. <html>
  3. <head>
  4. <meta charset="UTF-8">
  5. <script src="../Script/Common/huayi.load.js"></script>
  6. <script src="../Script/Common/huayi.config.js"></script>
  7. <link href="../css/layer/need/layer.css" />
  8. <link rel="stylesheet" href="../css/init.css" />
  9. <link rel="stylesheet" href="../js/zTree/zTreeStyle.css" />
  10. <link rel="stylesheet" href="../css/WorkOrder/WorkOrderList.css">
  11. <link rel="stylesheet" href="../js/layui/css/layui.css">
  12. <title>关联工单</title>
  13. <style>
  14. .Common {
  15. z-index: 999;
  16. overflow-y: visible;
  17. }
  18. .box_content {
  19. border: 0;
  20. }
  21. .btn_box {
  22. text-align: center;
  23. }
  24. .inps,
  25. .inpsReactionCategory {
  26. border: 1px solid rgb(229, 230, 231)
  27. }
  28. </style>
  29. </head>
  30. <body>
  31. <div class="">
  32. <div class="Common">
  33. <div class="box_content">
  34. <table id="sqzx" style="width: 100%" border="0" cellspacing="0" cellpadding="0">
  35. <tr>
  36. <th>事项编号:</th>
  37. <td>
  38. <input type="text" placeholder="输入工单号" id="wids" class="form-control" />
  39. </td>
  40. <th>录入时间:</th>
  41. <td colspan="3">
  42. <input id="starttime" class="photo x-color laydate-icon" type="text" autocomplete="off"
  43. style="height: 35px;" />-<input id="endtime" class="photo x-color laydate-icon"
  44. type="text" autocomplete="off" style="height: 35px;" />
  45. </td>
  46. </tr>
  47. <tr>
  48. <th>来电号码:</th>
  49. <td>
  50. <input type="text" id="tel" class="form-control" placeholder="请输入来电号码" />
  51. </td>
  52. <th>来电人:</th>
  53. <td>
  54. <input type="text" id="name" class="form-control" autocomplete="off" />
  55. </td>
  56. <th>工单标题:</th>
  57. <td>
  58. <input type="text" id="workOrderTitle" class="form-control" placeholder="输入工单标题" />
  59. </td>
  60. </tr>
  61. <tr>
  62. <th>来电内容:</th>
  63. <td>
  64. <input type="text" id="workOrderContent" class="form-control" placeholder="输入来电内容" />
  65. </td>
  66. <th>事发区域:</th>
  67. <td>
  68. <select id="sourceAreas" class="form-control"></select>
  69. </td>
  70. <th>反映类别:</th>
  71. <td style="position: relative;">
  72. <div class="inpBox">
  73. <input type="text" class="inpsReactionCategory" />
  74. <input type="hidden" id="keyid" />
  75. <i class="CleansReactionCategory fa fa-close"></i>
  76. <i class="xlReactionCategory xl_one"></i>
  77. <div class="addTreeReactionCategory xlAddReactionCategory">
  78. <ul id="addTreeDemoReactionCategory" class="ztree"></ul>
  79. </div>
  80. </div>
  81. </td>
  82. </tr>
  83. <tr>
  84. <th>承办单位:</th>
  85. <td style="position: relative">
  86. <div class="inpBox">
  87. <input type="text" class="inps" />
  88. <i class="Cleans fa fa-close"></i>
  89. <i class="xl xl_one"></i>
  90. <div class="addTree xlAdd">
  91. <ul id="addTreeDemo" class="ztree"></ul>
  92. </div>
  93. </div>
  94. <div class="selDpart1">
  95. <ul id="sponsor"></ul>
  96. </div>
  97. </td>
  98. <td colspan="7" style="text-align: center">
  99. <botton class="btns Seach">搜索</botton>
  100. </td>
  101. </tr>
  102. <input type="hidden" id="PID" />
  103. <input type="hidden" id="Dpment" />
  104. </table>
  105. </div>
  106. </div>
  107. <div style="width: 100%; padding: 10px; z-index: 1">
  108. <table id="orderlist" data-row-style="rowStyle" data-query-params="queryParams" data-pagination="true">
  109. <thead>
  110. <tr>
  111. <th data-field="state" data-checkbox="true"></th>
  112. <th data-formatter="serialNumber" data-align="center">
  113. 序号
  114. </th>
  115. <th data-field="F_WorkOrderId" data-formatter="View" data-align="center">
  116. 工单单号
  117. </th>
  118. <th data-field="F_ComTitle" data-formatter="GetCont" data-align="center">
  119. 诉求标题
  120. </th>
  121. <th data-field="DeptName" data-align="center">
  122. 承办单位
  123. </th>
  124. <th data-field="UserName" data-align="center">
  125. 受理人
  126. </th>
  127. <th data-field="F_WorkState" data-align="center" data-formatter="States">
  128. 办理状态
  129. </th>
  130. <th data-field="F_IsRelease" data-align="center" data-formatter="isReleaseFormatter">
  131. 关联工单类型
  132. </th>
  133. <!-- <th data-field="OverState" data-formatter="OverTime" data-align="center">
  134. 时限
  135. </th>
  136. <th data-field="LimitTime" data-formatter="BanTime" data-align="center">
  137. 办理时限
  138. </th> -->
  139. </tr>
  140. </thead>
  141. <tbody class="list"></tbody>
  142. </table>
  143. </div>
  144. <div class="btn_box">
  145. <button class="btns associatedBtn">关联</button>
  146. </div>
  147. </div>
  148. <script src="../js/layui/layui.js"></script>
  149. <script src="../js/adjustHeight.js"></script>
  150. <script src="../js/bootstrap-select.js"></script>
  151. <script src="../css/laydate/laydate.js"></script>
  152. <!-- <script src="../My97DatePicker/WdatePicker.js"></script> -->
  153. <script src="../js/zTree/jquery.ztree.core.js"></script>
  154. <script src="../js/search/screen.js"></script>
  155. <script src="../js/WorkOrder/WorkOrderList.js"></script>
  156. <script>
  157. var wid = helper.request.queryString("wid");
  158. var tab = helper.request.queryString("tab");
  159. var roleCode = $.cookie("code")
  160. var comprehensive;
  161. var jianhang;
  162. var phoneType;
  163. $(document).ready(function () {
  164. $(".associatedBtn").click(function () {
  165. submit(1)
  166. })
  167. laydate.skin('blue');
  168. laydate({
  169. elem: '#starttime',
  170. event: 'focus',
  171. istime: true,
  172. format: 'YYYY-MM-DD hh:mm:ss'
  173. });
  174. laydate({
  175. elem: '#endtime',
  176. event: 'focus',
  177. istime: true,
  178. format: 'YYYY-MM-DD hh:mm:ss'
  179. });
  180. if (roleCode === "MTDD") {
  181. comprehensive = ""
  182. jianhang = 1;
  183. phoneType = "";
  184. } else if (roleCode === "ZXLD") {
  185. comprehensive = ""
  186. jianhang = 0;
  187. phoneType = 2;
  188. } else {
  189. comprehensive = 1;
  190. jianhang = "";
  191. phoneType = "";
  192. }
  193. load()
  194. });
  195. // 提交
  196. function submit(state) {
  197. var ids = $.map($('#orderlist').bootstrapTable('getSelections'),
  198. function (row) {
  199. return row.F_WorkOrderId;
  200. });
  201. var workorderid = wid;
  202. var subworkorderid = ids.join(",")
  203. layer.confirm(
  204. "确定要关联工单吗?", {
  205. btn: ["是", "否"], //按钮
  206. },
  207. function () {
  208. /*发送请求*/
  209. $.post(huayi.config.callcenter_url + "WorkOrder/RelationWorkOrder", {
  210. workorderid: workorderid,
  211. subworkorderid: subworkorderid,
  212. token: $.cookie("token")
  213. }, function (result) {
  214. result = JSON.parse(result);
  215. if (result.state.toLowerCase() == "success") {
  216. var index = parent.layer.getFrameIndex(window
  217. .name); //先得到当前iframe层的索引
  218. parent.layer.close(index); //再执行关闭
  219. parent.$("#orderlist").bootstrapTable("refresh");
  220. parent.layer.msg("操作成功");
  221. parent.closePage();
  222. }
  223. })
  224. }
  225. );
  226. }
  227. function load() {
  228. //坐席
  229. var usercodeID = "";
  230. var usercode_ = $("#ZX").val(); //坐席
  231. if (usercode_ != null) {
  232. $(usercode_).each(function (i, n) {
  233. var obj1 = "";
  234. obj1 = n + ",";
  235. usercodeID += obj1;
  236. });
  237. } else {
  238. usercodeID = "";
  239. }
  240. // 调度员
  241. var ddusercodeID = "";
  242. var ddusercode_ = $("#yardman").val(); //坐席
  243. if (ddusercode_ != null) {
  244. $(ddusercode_).each(function (i, n) {
  245. var obj2 = "";
  246. obj2 = n + ",";
  247. ddusercodeID += obj2;
  248. });
  249. } else {
  250. ddusercodeID = "";
  251. }
  252. //先销毁表格
  253. $("#orderlist").bootstrapTable("destroy");
  254. //初始化表格,动态从服务器加载数据
  255. $("#orderlist").bootstrapTable({
  256. method: "get", //使用get请求到服务器获取数据
  257. url: huayi.config.callcenter_url + "WorkOrder/GetLDDealList", //获取数据的Servlet地址
  258. contentType: "application/x-www-form-urlencoded",
  259. striped: true, //表格显示条纹
  260. pagination: true, //启动分页
  261. pageSize: 10, //每页显示的记录数
  262. pageNumber: 1, //当前第几页
  263. pageList: [10, 20, 50, 100], //记录数可选列表
  264. search: false, //是否启用查询
  265. showColumns: false, //显示下拉框勾选要显示的列
  266. showRefresh: false, //显示刷新按钮
  267. sidePagination: "server", //表示服务端请求
  268. //设置为undefined可以获取pageNumber,pageSize,searchText,sortName,sortOrder
  269. //设置为limit可以获取limit, offset, search, sort, order
  270. queryParamsType: "undefined",
  271. queryParams: function queryParams(params) {
  272. //设置查询参数
  273. //alert(params.pageNumber)
  274. var param = {
  275. page: params.pageNumber,
  276. pagesize: params.pageSize,
  277. workid: $("#wids").val().replace(/\s+/g, ""),
  278. state: $("#state").val(), //=工单状态
  279. type: $("#type").val(), //=工单类型
  280. //bigtype: $("#bigtype").val(), //=大类别
  281. //smalltype: $("#smalltype").val(), //=小类别
  282. key: $("#key").val(), //=关键字
  283. tel: $("#tel").val().replace(/\s+/g, ""), //=客户电话
  284. name: $("#name").val().replace(/\s+/g, ""), //=客户名称
  285. usercode: usercodeID, //=坐席工号
  286. ddusercode: ddusercodeID,
  287. keyid: $("#keyid").val(), //=关键词id
  288. source: $("#source").val(), //=来源&
  289. starttime: $("#starttime").val(), //=开始时间
  290. endtime: $("#endtime").val(), //=结束时间
  291. deptid: $("#PID").val(),
  292. type: $("#type").val(),
  293. dealtype: $("#dealtype").val(),
  294. sourcearea: $("#sourceAreas").val(), // 区域
  295. ComTitle: $("#workOrderTitle").val().replace(/\s+/g, ""), // 工单标题
  296. ComContent: $("#workOrderContent").val().replace(/\s+/g, ""), // 工单内容
  297. // Result: $("#workOrderProcessingResult").val().replace(/\s+/g, ""), // 办理结果
  298. dealstarttime: $("#dealstarttime").val(), //办理开始时间
  299. dealstrendtime: $("#dealstrendtime").val(), //办理结束时间
  300. isopen: $("#isopen").val(),
  301. comprehensive: comprehensive, // 综合查询
  302. jianhang: jianhang,
  303. tab: 0, //待处理
  304. sourcearea: $("#sourceAreas").val(), //区域
  305. phoneType: 2, // 12345来电
  306. token: $.cookie("token"),
  307. };
  308. return param;
  309. },
  310. onLoadSuccess: function (data) {
  311. //加载成功时执行
  312. // layer.msg("加载成功");
  313. //console.log(data);
  314. },
  315. onLoadError: function () {
  316. //加载失败时执行
  317. //layer.msg("加载数据失败", { time: 1500, icon: 2 });
  318. },
  319. });
  320. }
  321. //状态
  322. function States(val, row) {
  323. var html = "";
  324. switch (val + "") {
  325. case "0":
  326. html = "新工单";
  327. if (row.F_IsReturn == 1) {
  328. html = "新工单(回退)";
  329. }
  330. break;
  331. case "1":
  332. html = "待交办";
  333. break;
  334. case "2":
  335. html = '<span style="color:#FF0000;">待查收</span>';
  336. break;
  337. case "3":
  338. html = "退回审核中";
  339. break;
  340. case "4":
  341. html = "办理中";
  342. break;
  343. case "5":
  344. html = "延时审核";
  345. break;
  346. case "6":
  347. if (row.F_IsProtect === 2 || row.F_IsProtect === 3) {
  348. html = "已办未果"
  349. } else {
  350. html = "已办理";
  351. }
  352. break;
  353. case "7":
  354. html = "已回访";
  355. break;
  356. case "8":
  357. html = "重办中";
  358. break;
  359. case "9":
  360. html = "已结案";
  361. break;
  362. case "10":
  363. html = "待审核";
  364. break;
  365. case "11":
  366. html = "重办待交办";
  367. break;
  368. // case '12':
  369. // html = '待审核';
  370. // break;
  371. case "13":
  372. html = "重办驳回";
  373. break;
  374. }
  375. return html;
  376. }
  377. //编号
  378. function serialNumber(val, row, index) {
  379. return index + 1;
  380. }
  381. // 关联工单类型
  382. function isReleaseFormatter(val, row) {
  383. if (String(val) === "2") {
  384. return "<span style='color: #e02433'>主工单</span>"
  385. } else if (String(val) === "3") {
  386. return "<span style='color: #e02433'>子工单</span>"
  387. }
  388. }
  389. function GetCont(val) {
  390. if (val) {
  391. var str = "<div ";
  392. if (val.length > 10) {
  393. str = str + ' title="' + val + '" ';
  394. val = val.substr(0, 10) + "...";
  395. }
  396. return str + ">" + val + "</div>";
  397. } else {
  398. return "";
  399. }
  400. }
  401. //时限
  402. function OverTime(val, row) {
  403. if (val == 1) {
  404. return (
  405. '<div class="" style="cursor: pointer;">' +
  406. '<span class="Greens">' +
  407. row.GapTime +
  408. "</span>" +
  409. "</div>"
  410. );
  411. } else if (val == 2) {
  412. return (
  413. '<div class="" style="cursor: pointer;">' +
  414. '<span class="Yellows">' +
  415. row.GapTime +
  416. "</span>" +
  417. "</div>"
  418. );
  419. } else if (val == 3) {
  420. return (
  421. '<div class="" style="cursor: pointer;">' +
  422. '<span class="Reds">' +
  423. row.GapTime +
  424. "</span>" +
  425. "</div>"
  426. );
  427. }
  428. }
  429. //办理时限
  430. function BanTime(val) {
  431. if (val) {
  432. var time = val.substring(0, val.indexOf(" "));
  433. return (
  434. '<div class="" style="cursor: pointer;">' +
  435. "<span>" +
  436. time +
  437. "</span>" +
  438. "</div>"
  439. );
  440. }
  441. }
  442. //来源
  443. function LY(obj) {
  444. obj.empty();
  445. obj.append(
  446. '<option selected="selected" value="">请选择</option>'
  447. );
  448. $.getJSON(
  449. huayi.config.callcenter_url +
  450. "Dictionary/GetDicValueListById", {
  451. token: $.cookie("token"),
  452. id: 1,
  453. },
  454. function (data) {
  455. if (data.state.toLowerCase() == "success") {
  456. var content = data.data;
  457. $(content).each(function (i, n) {
  458. $(
  459. "<option value='" +
  460. n.F_ValueId +
  461. "'>" +
  462. n.F_Value +
  463. "</option>"
  464. ).appendTo(obj);
  465. });
  466. }
  467. }
  468. );
  469. }
  470. //类别
  471. function LB(obj) {
  472. obj.empty();
  473. obj.append(
  474. '<option selected="selected" value="">请选择</option>'
  475. );
  476. $.getJSON(
  477. huayi.config.callcenter_url +
  478. "Dictionary/GetDicValueListById", {
  479. token: $.cookie("token"),
  480. id: 2,
  481. },
  482. function (data) {
  483. if (data.state.toLowerCase() == "success") {
  484. var content = data.data;
  485. $(content).each(function (i, n) {
  486. $(
  487. "<option value='" +
  488. n.F_ValueId +
  489. "'>" +
  490. n.F_Value +
  491. "</option>"
  492. ).appendTo(obj);
  493. });
  494. }
  495. }
  496. );
  497. }
  498. // 主题
  499. function ZT(obj) {
  500. obj.empty();
  501. obj.append(
  502. '<option selected="selected" value="">请选择</option>'
  503. );
  504. $.getJSON(
  505. huayi.config.callcenter_url +
  506. "Dictionary/GetDicValueListById", {
  507. token: $.cookie("token"),
  508. id: 3,
  509. },
  510. function (data) {
  511. if (data.state.toLowerCase() == "success") {
  512. var content = data.data;
  513. $(content).each(function (i, n) {
  514. $(
  515. "<option value='" +
  516. n.F_ValueId +
  517. "'>" +
  518. n.F_Value +
  519. "</option>"
  520. ).appendTo(obj);
  521. });
  522. }
  523. }
  524. );
  525. }
  526. function tree() {
  527. $.get(
  528. huayi.config.callcenter_url + "Department/GetDeptList", {
  529. token: $.cookie("token"),
  530. // "pid": pid
  531. },
  532. function (result) {
  533. result = $.parseJSON(result);
  534. $.fn.zTree.init(
  535. $("#addTreeDemo"),
  536. setting1,
  537. result.data
  538. ); //实例化树形图
  539. }
  540. );
  541. }
  542. var setting1 = {
  543. data: {
  544. key: {
  545. name: "F_DeptName",
  546. },
  547. simpleData: {
  548. enable: true,
  549. idKey: "F_DeptId",
  550. pIdKey: "F_PartentId",
  551. rootPId: 0,
  552. },
  553. },
  554. callback: {
  555. onClick: zTreeOnClick,
  556. },
  557. };
  558. function zTreeOnClick(event, treeId, treeNode) {
  559. $(".inps").val(treeNode.F_DeptName);
  560. $("#PID").val(treeNode.F_DeptId);
  561. $("#Dpment").val(treeNode.F_DeptId);
  562. $(".Cleans").show();
  563. }
  564. function Close() {
  565. $(".lyxz").removeClass("cx");
  566. if ($("audio").length > 0) {
  567. $("audio")[0].pause();
  568. }
  569. }
  570. </script>
  571. </body>
  572. </html>