selEach.jsp_用到再改 18 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466
  1. <%-- 来自 ws_ff。Lin --%>
  2. <html>
  3. <head>
  4. <meta charset="UTF-8">
  5. <title></title>
  6. <css.ss file="/ss/treeTable/jquery.treetable.css"/>
  7. <css.ss file="/ss/treeTable/jquery.treetable.theme.default.css"/>
  8. <js.ss file="/ss/drag_.js"/> <%-- 原为 "/wd/js/drag.js",因与 Drag.js 重名,故改名为 drag_.js。Lin --%>
  9. <style type="text/css">
  10. .bac {
  11. width: 41px;
  12. height: 41px;
  13. background-image: url("/ss/window/theme/dhx_blue/image/close.png");
  14. position: absolute;
  15. top: 0;
  16. right: 0;
  17. }
  18. .bac:hover {
  19. background-position: 41px 0;
  20. }
  21. /*.box {
  22. width: 400px;
  23. height: 250px;
  24. background-color: white;
  25. margin: -374px 166px;
  26. position: absolute;
  27. z-index: 10;
  28. display: none;
  29. border: #008B8B 1px solid;
  30. }*/
  31. .bottom-div {
  32. position: absolute;
  33. }
  34. #ryOption .radioItem {
  35. display: none;
  36. }
  37. .nbFrame {
  38. height: 115px;
  39. overflow: auto;
  40. }
  41. [id^="wrapper"] {
  42. display: flex;
  43. align-items: center;
  44. background: transparent !important;
  45. }
  46. .ys_cl {
  47. display: inline-block;
  48. max-width: 56%;
  49. overflow: hidden;
  50. text-overflow: ellipsis;
  51. }
  52. .box2 .ys_cl {
  53. max-width: 95%;
  54. }
  55. </style>
  56. </head>
  57. <body style="padding-top:12px;padding-left:8px;">
  58. <script src="ws_dwff/specific.js"></script>
  59. <form id="myForm" method="post" style="padding-right: 4px">
  60. <input type="hidden" name="ryidList" id="ryidList" value=""/>
  61. <div class="longCardList-div" style="width: calc(100% - 4px);box-sizing: border-box;">
  62. <table wdFitHeight="max:100px,min:99px">
  63. <tbody style="width: 100%;padding: 0px 4px 0px 11px;box-sizing: border-box;" id="wdTbody0">
  64. <tr>
  65. <td class="hLine-highlight">
  66. <div onclick='@service{name:"ws_ck",dest:"env_play",show:"wdDialog",param:{wsid:"${wsid}"}}@' class="longCardList-info" style="font-size: 0px;display: inline-block;float: left;">
  67. <span class="longCardList-highlight" style="margin-bottom: 3px;overflow: hidden;text-overflow: ellipsis;display: -webkit-box;-webkit-line-clamp:1;-webkit-box-orient: vertical;">
  68. <a>${ws.bt}</a>
  69. </span>
  70. <div id="cardList-abstract" class="longCardList-dim" style="overflow:hidden;text-overflow:ellipsis;white-space:nowrap;width:850px;">
  71. <wd:write value="${ws.zy}" />
  72. </div>
  73. <div id="cardList-category" class="longCardList growHeightDiv">
  74. <span>文书类型:来文</span>
  75. <%-- <span>文书范围:<wd:translate name="wsfw" value='${ws.wsfwm}'/></span> --%>
  76. <span>文书类别:<wd:translate name="wslb" value='${ws.wslbm}'/></span>
  77. <span>收文日期:<wd:write value='${ws.swsj}' format="yyyy-MM-dd HH:mm"/></span>
  78. </div>
  79. </div>
  80. </td>
  81. </tr>
  82. </tbody>
  83. </table>
  84. </div>
  85. <div class="content-div" wdFitHeight="max:520px,min:480px,top:1" style="height:480px;">
  86. <table class='form' style="table-layout:fixed;">
  87. <tbody>
  88. <tr>
  89. <th width="150px">拟办</th>
  90. <td style="padding-right: 0px;">
  91. <div class="nbFrame scrollbar">
  92. <div id="nbSelected" wdSelectedClass="list-checkedIcon" class="scrollbar">
  93. <wd:iterate name="nbList" id="item">
  94. <div wdObjectId='${item.shid}' <wd:equal leftValue="${index == 0}" rightValue="true">isSq="true"</wd:equal> class='list-background nb-Div' style='overflow:hidden;max-width:780px;'
  95. onClick='if($(window.event.srcElement).is("a,img"))return;@service{dest:"sh_content_player",show:"wdDialog",param:{sm:"${item.sm}",fjid:"${item.fjid}",ynrid:"${item.ynrid}"}}@'>
  96. <span class='nbName list-dim' style='display: inline-block;float: left;width: 85px;white-space: nowrap;overflow: hidden;text-overflow: ellipsis;height:41px;line-height:41px;'>
  97. ${item.xm}
  98. </span>
  99. <span class='nbBt list-dim' style='float: left;display:inline-flex;height:41px;line-height:41px;width:calc(100% - 265px);'>
  100. <span style="overflow:hidden;text-overflow:ellipsis;" title="${item.sm}">
  101. ${item.sm}
  102. </span>
  103. <wd:equal leftValue="${empty item.fjid}" rightValue="false">
  104. <span>
  105. <input type="button" class="underlineIcon-attachment" style="margin-left: 5px;" />
  106. </span>
  107. </wd:equal>
  108. <%--
  109. <wd:equal leftValue="${empty item.ynrid}" rightValue="false">
  110. <span>
  111. <input type="button" class="underlineIcon-media" style="margin-left: 5px;" />
  112. </span>
  113. </wd:equal>
  114. --%>
  115. </span>
  116. <div class='sj list-smallDim' style='float: right;margin-right: 10px;font-size: 0px;padding-top:12px;width:80px;'>${item.time} </div>
  117. </div>
  118. </wd:iterate>
  119. </div>
  120. </div>
  121. </td>
  122. </tr>
  123. <%-- </form> 放错位置了,移到后面。Lin
  124. </form> --%>
  125. <tr id="ys">
  126. <th>阅示/处理人员</th>
  127. <td style="padding: 0;padding-top: 5px;">
  128. <input name="clfs" type="hidden" value="2"/> <%-- 增加了 闭标签 "/"。Lin --%>
  129. <div style="float: right;margin-right: 8px;margin-bottom: 3px;">
  130. <input class="radioItem" type="button" value="领导" wdValue="1" name="choice"/>
  131. <wd:equal leftValue="${ws.wsfwm==25}" rightValue="false">
  132. <input class="radioItem" type="button" value="部门" wdValue="2" name="choice"/>
  133. </wd:equal>
  134. <wd:equal leftValue="${ws.wsfwm==25}" rightValue="true">
  135. <input class="radioItem" type="button" value="成员" wdValue="2" name="choice"/>
  136. </wd:equal>
  137. <%-- <input class="radioItem" type="button" value="群组" wdValue="3" name="choice"/> --%>
  138. <wd:write type="radio" name="choice" value="1" onClass="content-onButton" offClass="content-offButton" nullable="false" />
  139. </div>
  140. <div class="dragList-div" id="container" style="width: 100%;margin-bottom:10px;">
  141. <div class="box">
  142. <p class="label">已选<span id="ryDropAll" class="icon-allRight"></span></p>
  143. <div class="list-body" style="overflow-x: hidden;width: 100%;height: 240px;">
  144. <div id="rySelected" wdSelectedClass="list-checkedIcon" class="scrollbar" style="height:100%">
  145. </div>
  146. </div>
  147. </div>
  148. <div class="box box2">
  149. <p class="label">可选<span id="ryPickAll" class="icon-allLeft"></span></p>
  150. <div class="list-body" style="overflow-x: hidden;width: 100%;height: 240px;">
  151. <div id="ryOption" wdSelectedClass="list-checkedIcon" class="scrollbar" style="height:100%">
  152. <wd:iterate name="leaderList" id="item">
  153. <div wdObjectId="${item.ryid}" wdValue="${item.ryid}" val="1" class="leader list-background" style="min-height: 41px;line-height: 41px;width: 100%;box-sizing: border-box;overflow: hidden;text-overflow: ellipsis;white-space: nowrap;">
  154. <sapn class="ys_cl">${item.xm}</sapn>
  155. <%-- <input class="radioItem" type="button" value="处理" wdValue="${item.ryid}" name="clfs" lx="1"/> --%>
  156. <span style="margin-left:10px;">
  157. <input class="radioItem" type="button" value="阅示" wdValue="2" name="clfs_${item.ryid}" lx="1" ysBtn/>
  158. <input class="radioItem" type="button" value="处理" wdValue="${item.ryid}" name="clfs_${item.ryid}" lx="1" onclick="handleCl('${item.ryid}')" clBtn/>
  159. <wd:write type="radio" name="clfs_${item.ryid}" value="2" onClass="content-onButton" offClass="content-offButton" nullable="false" />
  160. </span>
  161. </div>
  162. </wd:iterate>
  163. <wd:equal leftValue="${ws.wsfwm==25}" rightValue="false">
  164. <wd:iterate name="bmList" id="item">
  165. <div wdObjectId="${item.bmid}" wdValue="${item.bmid}" val="2" class="bmList list-background" style="min-height: 41px;line-height: 41px;width: 100%;box-sizing: border-box;overflow: hidden;text-overflow: ellipsis;white-space: nowrap;">
  166. <sapn class="ys_cl">${item.mc}</sapn>
  167. <%-- <input class="radioItem" type="button" value="处理" wdValue="${item.bmid}" name="clfs" lx="2"/> --%>
  168. <span style="margin-left:10px;">
  169. <input class="radioItem" type="button" value="阅示" wdValue="2" name="clfs_${item.bmid}" lx="2" ysBtn/>
  170. <input class="radioItem" type="button" value="处理" wdValue="${item.bmid}" name="clfs_${item.bmid}" lx="2" onclick="handleCl('${item.bmid}')" clBtn/>
  171. <wd:write type="radio" name="clfs_${item.bmid}" value="2" onClass="content-onButton" offClass="content-offButton" nullable="false" />
  172. </span>
  173. </div>
  174. </wd:iterate>
  175. </wd:equal>
  176. <wd:equal leftValue="${ws.wsfwm==25}" rightValue="true">
  177. <wd:iterate name="topRyList" id="item">
  178. <div wdObjectId="${item.ryid}" wdValue="${item.ryid}" val="2" class="bmList list-background" style="min-height: 41px;line-height: 41px;width: 100%;box-sizing: border-box;overflow: hidden;text-overflow: ellipsis;white-space: nowrap;">
  179. <sapn class="ys_cl">${item.xm}</sapn>
  180. <%-- <input class="radioItem" type="button" value="处理" wdValue="${item.ryid}" name="clfs" lx="1"/> --%>
  181. <span style="margin-left:10px;">
  182. <input class="radioItem" type="button" value="阅示" wdValue="2" name="clfs_${item.ryid}" lx="1" ysBtn/>
  183. <input class="radioItem" type="button" value="处理" wdValue="${item.ryid}" name="clfs_${item.ryid}" lx="1" onclick="handleCl('${item.ryid}')" clBtn/>
  184. <wd:write type="radio" name="clfs_${item.ryid}" value="2" onClass="content-onButton" offClass="content-offButton" nullable="false" />
  185. </span>
  186. </div>
  187. </wd:iterate>
  188. </wd:equal>
  189. <wd:iterate name="qzList" id="item">
  190. <div wdObjectId="${item.qzid}" wdValue="${item.qzid}" val="3" class="qzList list-background" style="min-height: 41px;line-height: 41px;width: 100%;box-sizing: border-box;overflow: hidden;text-overflow: ellipsis;white-space: nowrap;">
  191. <sapn class="ys_cl">${item.mc}</sapn>
  192. <span style="margin-left:10px;">
  193. <input class="radioItem" type="button" value="阅示" wdValue="2" name="clfs_${item.qzid}" lx="1" ysBtn/>
  194. <wd:write type="radio" name="clfs_${item.qzid}" value="2" onClass="content-onButton" offClass="content-offButton" nullable="false"/>
  195. </span>
  196. </div>
  197. </wd:iterate>
  198. <wd:write type="radio" name="clfs" value="2" onClass="content-onButton" offClass="content-offButton" nullable="true"/>
  199. </div>
  200. </div>
  201. </div>
  202. </div>
  203. <wd:equal leftValue="${ws.wsfwm==25}" rightValue="false">
  204. <%--
  205. <div class="select-items select-others" style="top:0;margin: 5px 0px 0px 6px;">
  206. <input name="under" type="button" value="及其下人员" style="margin-bottom: 10px;margin-right: 8px;" />
  207. <wd:write type="checkbox" name="under" value="0" onClass="content-onButton" offClass="content-offButton"/>
  208. </div>
  209. --%>
  210. </wd:equal>
  211. </td>
  212. </tr>
  213. </tbody>
  214. </table>
  215. </div>
  216. <div class='bottom-div'>
  217. <div class="bottom-down-div border-top">
  218. <input type="button" id="test" value="确认" class="bottom-button"/>
  219. <input type="button" value="关闭" class="bottom-button" onclick="wd.display.closeDialog();"/>
  220. </div>
  221. </div>
  222. </form> <%-- 从上面移到这。Lin --%>
  223. <input type="hidden" id="getNbListUrl" value="@service{name:'ws_ff_nb_cx'}@"/>
  224. <%--脚本查询拟办列表--%>
  225. <input type="hidden" id="updateShlbmUrl" value="@service{name:'ws_ff_nbshlbm_bc'}@"/>
  226. <%-- 脚本修改拟办类别为改稿类别 --%>
  227. <input type="hidden" id="XyshiftRyidsUrl" value="@service{name:'ws_ff_xyxgry_cx'}@"/>
  228. <%-- 学员查询 --%>
  229. <input type="hidden" id="toRyidUrl" value="@service{name:'ws_ff_bm2ry'}@"/>
  230. <input type="hidden" id="qzToRyidUrl" value="@service{name:'ws_ff_qz2ry'}@"/>
  231. <input type="hidden" id="lyUrl" value='@service{dest:"ws_ly",show:"wdDialog",param:{"id":"wdVal{id}"}}@'/>
  232. <%-- wsfwm大于51的用到 --%>
  233. <input type="hidden" id="queryRyUrl" value="@service{name:'ws_ff_xyxg_cx'}@"/>
  234. <wd:write type="drag" name="nb" group="true" function="editOrder"/>
  235. <wd:write type="drag" name="ry" group="true" function="editOrder"/>
  236. <script type="text/javascript" src="jquery.treetable.js"></script>
  237. <script type="text/javascript" src="/wd/js/title.js"></script>
  238. <script>
  239. window.onload = function() {
  240. $('.list-background').addClass('list');
  241. }
  242. </script>
  243. <script>
  244. //页面初始化的方法
  245. function handleDispense(){
  246. var val = $('input[name="choice"][type="hidden"]').val();
  247. $("#ryOption>div").hide();
  248. $("#ryOption>div[val='"+val+"']").show();
  249. }
  250. (function() {
  251. handleDispense();
  252. $('input[name="choice"][type="button"]').click(handleDispense);
  253. })();
  254. // 阅示人员校验
  255. $("#test").click(function() {
  256. if ($('div.nb-Div').length > 0) {
  257. var _length = $("#nbSelected").find("div.list-checkedIcon").length;
  258. if (_length == 0) {
  259. wd.display.alert("您尚未选拟办记录");
  260. return;
  261. }
  262. }
  263. var len = $('#rySelected > div').size();
  264. if (len > 0) {
  265. agree();
  266. } else {
  267. wd.display.alert("至少选择一个人员或部门");
  268. }
  269. });
  270. function bmidToRyid(bms,prefix){
  271. var ryids=[];
  272. if(bms&&bms.length>0){
  273. }else{
  274. return ryids;
  275. }
  276. prefix=prefix||"";
  277. var under = $('input[name="under"][type="button"]').attr('class') == 'content-onButton';
  278. var url = document.getElementById("toRyidUrl").value;
  279. $.ajax({
  280. type: "post",
  281. url: url,
  282. async: false,
  283. data: {
  284. "bms": bms,
  285. "under": under
  286. },
  287. dataType: "json",
  288. traditional: true,
  289. success: function(data) {
  290. //console.log(data);
  291. if (data.result) {
  292. $.each(data.data, function(i, element) {
  293. ryids.push(prefix+element);
  294. });
  295. }
  296. }
  297. });
  298. return ryids;
  299. }
  300. //工作流成功
  301. function agree() {
  302. //var val = $('input[name="clfs"][type="hidden"]').val();
  303. var ryids = new Array();//存动态分支并行的ryid或者blryid(blryid存入ws的jbryid);
  304. var bms = new Array();//用来转换为ryids,同样最后也是放进ryids里面
  305. //var bms2 = new Array();
  306. //存放拟办 勾选的为拟办
  307. var shidNb = new Array();
  308. //存放改稿 没有勾选的为改稿
  309. var shidGg=new Array();
  310. var sqid = "";
  311. var allDiv = $('div[id="nbSelected"]>div');
  312. for (var i = 0; i < allDiv.length; i++) {
  313. var id = $(allDiv[i]).attr("wdobjectid");
  314. var isSq = $(allDiv[i]).attr("isSq");
  315. if ($(allDiv[i]).hasClass("list-checkedIcon") > 0) {
  316. //勾选 拟办
  317. if (isSq == "true") {
  318. sqid = id;
  319. }else{
  320. shidNb.push(id);
  321. }
  322. } else {
  323. //没有勾选 改稿
  324. if (!isSq) {
  325. shidGg.push(id);
  326. }
  327. }
  328. }
  329. //领导选项卡
  330. $("#rySelected").find("div.leader").each(function(i, element) {
  331. //if (element.getAttribute("wdobjectid") == $('.dragList-div .content-onButton').attr('wdvalue')) {
  332. if (element.getAttribute("wdobjectid") == $(element).find("[name^='clfs_']").eq(0).val()) {
  333. ryids.push("blryid" + element.getAttribute("wdobjectid"));
  334. } else {
  335. ryids.push(element.getAttribute("wdobjectid"));
  336. }
  337. });
  338. //部门选项卡
  339. $("#rySelected").find("div.bmList").each(function(i, element) {
  340. <%-- 不是部门内 --%>
  341. <wd:equal leftValue = "${ws.wsfwm==25}" rightValue = "false" >
  342. //if (element.getAttribute("wdobjectid") == $('.dragList-div .content-onButton').attr('wdvalue')) {
  343. if (element.getAttribute("wdobjectid") == $(element).find("[name^='clfs_']").eq(0).val()) {
  344. //ryids.push("blbmid"+element.getAttribute("wdobjectid"));
  345. ryids=ryids.concat(bmidToRyid([element.getAttribute("wdobjectid")],"blryid"));
  346. } else {
  347. bms.push(element.getAttribute("wdobjectid"));
  348. }
  349. </wd:equal>
  350. <%-- 是部门内 因为部门内是直接选部门内的成员所以直接存入ryids中就行了 --%>
  351. <wd:equal leftValue="${ws.wsfwm==25}" rightValue="true">
  352. ryids.push(element.getAttribute("wdobjectid"));
  353. </wd:equal>
  354. });
  355. if (bms.length > 0) {
  356. var under = $('input[name="under"][type="button"]').attr('class') == 'content-onButton';
  357. var url = document.getElementById("toRyidUrl").value;
  358. $.ajax({
  359. type: "post",
  360. url: url,
  361. async: false,
  362. data: {
  363. "bms": bms,
  364. "under": under
  365. },
  366. dataType: "json",
  367. traditional: true,
  368. success: function(data) {
  369. console.log(data);
  370. if (data.result) {
  371. $.each(data.data, function(i, element) {
  372. ryids.push(element);
  373. });
  374. }
  375. }
  376. });
  377. }
  378. //群组选项卡
  379. var qzids=[];
  380. $("#rySelected").find("div.qzList").each(function(i, element) {
  381. qzids.push(element.getAttribute("wdobjectid"));
  382. });
  383. if (qzids.length > 0) {
  384. var url = document.getElementById("qzToRyidUrl").value;
  385. $.ajax({
  386. type: "post",
  387. url: url,
  388. async: false,
  389. data: {
  390. "qzids": qzids.join(",")
  391. },
  392. dataType: "json",
  393. traditional: true,
  394. success: function(result) {
  395. if (result) {
  396. $.each(result, function(i, item) {
  397. ryids.push(item.ryid);
  398. });
  399. }
  400. }
  401. });
  402. }
  403. // 处理人员
  404. /*var clrys = [];
  405. $('[name^="clfs_"]').each(function() {
  406. var _this = $(this)[0]
  407. if(_this.className == "" && _this.value != 2) {
  408. clrys.push(_this.value)
  409. }
  410. })
  411. $('[name="clfs"]').val(clrys.toString().replace(/\,/g, "|"))*/
  412. var ryidList = ryids.toString().replace(/\,/g, "|");
  413. if (ryidList == "") {
  414. wd.display.alert("所选择的区域无适当人选");
  415. } else {
  416. var ryidArr = ryidList.split(",");
  417. var f = document.getElementById("myForm");
  418. var formUrl = "@service{name:'ws_ff_dw_tj',dest:'sys_info',param:{sqid:'wdVal{sqid}',shidNb:'wdVal{shidNb}',shidGg:'wdVal{shidGg}',shid:'${shid}',sfty:1,sm:'单位分发处理'}}@";
  419. f.action = wd.display.replaceDynamicParam(formUrl, {
  420. "shidNb": shidNb,
  421. "shidGg": shidGg,
  422. "sqid": sqid
  423. });
  424. $('#ryidList').val(ryidList);
  425. f.submit();
  426. }
  427. }
  428. //工作流失败
  429. function reject() {
  430. var f = document.getElementById('myForm');
  431. f.action = "@service{name:'check',dest:'sys_info',param:{shid:'${shid}',sfty:0}}@";
  432. f.submit();
  433. }
  434. function handleCl(id) {
  435. //$("[name='clfs_' + id]").val(2)
  436. $('[name^="clfs_"][type="hidden"]').each(function() {
  437. $(this).val(2)
  438. })
  439. //$('[name^="clfs_"][wdvalue="2"]').each(function() {
  440. $('[ysBtn]').each(function() {
  441. $(this).removeClass("content-offButton").addClass("content-onButton")
  442. })
  443. $('[clBtn]').each(function() {
  444. $(this).removeClass("content-onButton").addClass("content-offButton")
  445. })
  446. }
  447. </script>
  448. <script type="text/javascript">
  449. var data1 = '${nbList}';
  450. </script>
  451. </body>
  452. </html>