sysKnowledgePerGet.jsp 7.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290
  1. <%--
  2. time:2015-07-28 10:23:07
  3. desc:edit the 权限
  4. --%>
  5. <%@page language="java" pageEncoding="UTF-8"%>
  6. <%@include file="/commons/include/html_doctype.html"%>
  7. <html>
  8. <head>
  9. <title>权限明细</title>
  10. <%@include file="/commons/include/form.jsp"%>
  11. <script type="text/javascript" src="${ctx}/js/hotent/CustomValid.js"></script>
  12. <script type="text/javascript" src="${ctx}/js/hotent/platform/system/SysDialog.js"></script>
  13. <script type="text/javascript">
  14. var expandDepth = 10;
  15. var temdType = "";
  16. $(function() {
  17. initOwerData();
  18. initPerData();
  19. //人员查看详情事件
  20. $("a.moreinfo").live('click',function(){
  21. var me = $(this),
  22. hrefStr = me.attr('hrefstr');
  23. if(!hrefStr)return;
  24. openDetailWin({url:hrefStr,hasClose:true});
  25. });
  26. });
  27. function initPerData(){
  28. var perObjList = '${perObjList}'
  29. if(perObjList == "")return;
  30. var perObj = JSON.parse(perObjList);
  31. var html = "";
  32. var html = "";
  33. $.each(perObj,function(i,permission){
  34. var permissionJson = permission.permissionJson;
  35. if(permissionJson==""){
  36. return true;
  37. }
  38. var perArray = permissionJson.split(",");
  39. html += '<tr><th width="20%">'+permission.typeName+':</th>';
  40. html +='<td style="width:80%" class="formInput">';
  41. for(var j = 0 ; j < perArray.length ; j++){
  42. var perName = ""
  43. if(perArray[j] == "readDir"){
  44. perName = "分类可读取";
  45. }else if(perArray[j] == "del"){
  46. perName = "文章可删除";
  47. }else if(perArray[j] == "edit"){
  48. perName = "文章可编辑";
  49. }else if(perArray[j] == "add"){
  50. perName = "可添加文章";
  51. }else if(perArray[j] == "read"){
  52. perName = "文章可读";
  53. }
  54. html += '<span class="owner-span">'+perName+'</span>';
  55. }
  56. html += '</td></tr>';
  57. });
  58. $("#detailTr").after(html);
  59. }
  60. function initOwerData(){//编辑的是初始化用户数据org..user
  61. var perObjList = '${perObjList}'
  62. if(perObjList == "")return;
  63. var perObj = JSON.parse(perObjList);
  64. var objArray = [];
  65. var objJson = {
  66. all:"N",
  67. user:"",
  68. org:""
  69. }
  70. for(var i=0 ; i<perObj.length ; i++){
  71. var permissionType = perObj[i].permissionType;
  72. var ownerId = perObj[i].ownerId;
  73. var owner = perObj[i].owner;
  74. if(permissionType=='all'){
  75. objJson.al l= "Y";
  76. }else if(permissionType =="user"){
  77. var array = [];
  78. var u = {
  79. ownerId:ownerId,
  80. ownerName:owner
  81. }
  82. array.push(u);
  83. objJson.user = array;
  84. }else if(permissionType =="org"){
  85. var array = [];
  86. var o = {
  87. ownerId:ownerId,
  88. ownerName:owner
  89. }
  90. array.push(o);
  91. objJson.org = array;
  92. }
  93. }
  94. initOwner(objJson);
  95. }
  96. //授权用户数据
  97. function initOwner(objJson){
  98. var jsonStr = JSON2.stringify(objJson);
  99. temdType = jsonStr;
  100. var emptyMark = true;
  101. var ownerObj = [];
  102. $("textarea[name='ownerName']",$("#ownerName_div")).each(function(){
  103. var me = $(this),
  104. tr = me.closest("tr"),
  105. owner = $("textarea[name='ownerName']",tr);
  106. rightType = $("input[name='rightType']",tr).val();
  107. if(rightType=='all'){
  108. owner.val(objJson.all);
  109. if(objJson.all=="Y"){
  110. tr.show();
  111. emptyMark = false;
  112. }else{
  113. tr.hide();
  114. }
  115. }else if(rightType=='user'){
  116. if(objectIsEmptyByRep(objJson.user,'')){
  117. tr.hide();
  118. }else{
  119. tr.show();
  120. var href = __ctx+"/platform/system/sysUser/get.ht?openType=detail&userId=";
  121. setVal(me,objJson.user,href);
  122. emptyMark = false;
  123. }
  124. }else if(rightType=='org'){
  125. if(objectIsEmptyByRep(objJson.org,'')){
  126. tr.hide();
  127. }else{
  128. tr.show();
  129. setVal(me,objJson.org);
  130. emptyMark = false;
  131. }
  132. }
  133. });
  134. //是否没有授权对象内容
  135. if(emptyMark){
  136. $("tr.empty-div",$("#ownerName_div")).show();
  137. }else{
  138. $("tr.empty-div",$("#ownerName_div")).hide();
  139. }
  140. }
  141. //是否为空
  142. function objectIsEmpty(obj){
  143. // 内容是是否为空
  144. if(typeof(obj)==undefined||obj==null||obj==''){
  145. return true;
  146. }else{
  147. return false;
  148. }
  149. };
  150. //并且不能等str的内容,是否为空
  151. function objectIsEmptyByRep(obj,str){
  152. // 内容是是否为空
  153. if(typeof(obj)==undefined||obj==null||obj==''||obj==str){
  154. return true;
  155. }else{
  156. return false;
  157. }
  158. };
  159. //设置值
  160. function setVal(obj,json,href){
  161. var tr=$(obj).closest("tr"),
  162. owner = $("textarea[name='ownerName']",tr);
  163. if(json=='textarea'){
  164. json = owner.val();
  165. json = $.parseJSON(json);
  166. }else{
  167. var jsonStr = JSON2.stringify(json);
  168. owner.val(jsonStr);
  169. }
  170. setOwnerSpan(tr,json,href);
  171. };
  172. function setOwnerSpan(tr,json,href){
  173. var div = $("div.owner-div",tr);
  174. if(!div||div.length==0)return;
  175. div.empty();
  176. if(!json||json.length==0)return;
  177. for(var i=0,c;c=json[i++];){
  178. if(c.ownerId == "")
  179. continue;
  180. var a = $('<a class="moreinfo"></a>').html(c.ownerName).attr("ownerId",c.ownerId);
  181. if(href){
  182. a.attr("hrefstr",href+c.ownerId);
  183. a.attr("href","#");
  184. }
  185. var span = $('<span class="owner-span"></span>').html(a);
  186. div.append(span);
  187. }
  188. var html = div.html();
  189. };
  190. //显示用户详情
  191. function openDetailWin(conf){
  192. var dialogWidth=650;
  193. var dialogHeight=550;
  194. conf=$.extend({},{dialogWidth:dialogWidth ,dialogHeight:dialogHeight ,help:0,status:0,scroll:0,center:1},conf);
  195. var winArgs="dialogWidth="+conf.dialogWidth+"px;dialogHeight="+conf.dialogHeight
  196. +"px;help=" + conf.help +";status=" + conf.status +";scroll=" + conf.scroll +";center=" +conf.center;
  197. var url = conf.url + '&hasClose=' +conf.hasClose;
  198. DialogUtil.open({
  199. height:conf.dialogHeight,
  200. width: conf.dialogWidth,
  201. title : '用户选择器',
  202. url: url,
  203. isResize: true,
  204. });
  205. }
  206. //全选删除..编辑
  207. function allSelect(obj){
  208. var o = $(obj);
  209. var name = o.attr("name");
  210. var check = o.attr("checked");
  211. if(check=="checked"){
  212. $("input[name='"+name+"']").attr("checked", true);
  213. }else{
  214. $("input[name='"+name+"']").attr("checked", false);
  215. }
  216. }
  217. </script>
  218. <style type="text/css">
  219. .td1{width: 400px}
  220. .td2{width: 180px}
  221. .ztree li a{width: 100%}
  222. .ztree li ul{left;margin: 0 0 0 0;padding:0 0 0 0;}
  223. </style>
  224. </head>
  225. <body>
  226. <div class="panel">
  227. <div class="panel-top">
  228. <div class="tbar-title">
  229. </div>
  230. <div class="panel-toolbar">
  231. <div class="toolBar">
  232. <div class="l-bar-separator"></div>
  233. <div class="group">
  234. <a class="link back"
  235. href="list.ht"><span></span>返回</a>
  236. </div>
  237. </div>
  238. </div>
  239. </div>
  240. <div class="panel-body">
  241. <form>
  242. <table class="table-detail" cellpadding="0" cellspacing="0"
  243. border="0" type="main">
  244. <tr>
  245. <th width="20%">名称</th>
  246. <td>${sysKnowPerRef.name}</td>
  247. </tr>
  248. <tr id = "detailTr">
  249. <th width="20%">人员组织</th>
  250. <td>
  251. <div id="ownerName_div">
  252. <table class="table-detail" style="border: hidden !important;" >
  253. <tr class="hidden">
  254. <td>
  255. <div class="owner-div"></div> <textarea class="hidden"
  256. name="ownerName"></textarea> <input type="hidden"
  257. name="rightType" value="user">
  258. </td>
  259. </tr>
  260. <tr class="hidden">
  261. <td>
  262. <div class="owner-div"></div> <textarea class="hidden"
  263. name="ownerName"></textarea> <input type="hidden"
  264. name="rightType" value="org">
  265. </td>
  266. </tr>
  267. <tr class="hidden">
  268. <td>
  269. <div class="owner-div">
  270. <label style="float: left" for="selectAll">允许所有人访问</label>
  271. </div> <textarea rightType="0" class="hidden" name="ownerName"></textarea>
  272. <input type="hidden" name="rightType" value="all">
  273. </td>
  274. </tr>
  275. </table>
  276. </div>
  277. </td>
  278. </tr>
  279. </table>
  280. </form>
  281. </div>
  282. </div>
  283. </body>
  284. </html>