liuxiaolong
2019-05-09 0d1d88cdb668e75ea8609417ac18ae19947e9525
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
<%@ tag language="java" pageEncoding="UTF-8"%>
<%@ include file="/webpage/include/taglib.jsp"%>
<%@ attribute name="id" type="java.lang.String" required="true" description="编号"%>
<%@ attribute name="name" type="java.lang.String" required="true" description="隐藏域名称(ID)"%>
<%@ attribute name="value" type="java.lang.String" required="true" description="隐藏域值(ID)"%>
<%@ attribute name="labelName" type="java.lang.String" required="true" description="输入框名称(Name)"%>
<%@ attribute name="labelValue" type="java.lang.String" required="true" description="输入框值(Name)"%>
<%@ attribute name="title" type="java.lang.String" required="true" description="选择框标题"%>
<%@ attribute name="url" type="java.lang.String" required="true" description="树结构数据地址"%>
<%@ attribute name="checked" type="java.lang.Boolean" required="false" description="是否显示复选框,如果不需要返回父节点,请设置notAllowSelectParent为true"%>
<%@ attribute name="extId" type="java.lang.String" required="false" description="排除掉的编号(不能选择的编号)"%>
<%@ attribute name="isAll" type="java.lang.Boolean" required="false" description="是否列出全部数据,设置true则不进行数据权限过滤(目前仅对Office有效)"%>
<%@ attribute name="notAllowSelectRoot" type="java.lang.Boolean" required="false" description="不允许选择根节点"%>
<%@ attribute name="notAllowSelectParent" type="java.lang.Boolean" required="false" description="不允许选择父节点"%>
<%@ attribute name="module" type="java.lang.String" required="false" description="过滤栏目模型(只显示指定模型,仅针对CMS的Category树)"%>
<%@ attribute name="selectScopeModule" type="java.lang.Boolean" required="false" description="选择范围内的模型(控制不能选择公共模型,不能选择本栏目外的模型)(仅针对CMS的Category树)"%>
<%@ attribute name="allowClear" type="java.lang.Boolean" required="false" description="是否允许清除"%>
<%@ attribute name="allowInput" type="java.lang.Boolean" required="false" description="文本框可填写"%>
<%@ attribute name="cssClass" type="java.lang.String" required="false" description="css样式"%>
<%@ attribute name="cssStyle" type="java.lang.String" required="false" description="css样式"%>
<%@ attribute name="smallBtn" type="java.lang.Boolean" required="false" description="缩小按钮显示"%>
<%@ attribute name="hideBtn" type="java.lang.Boolean" required="false" description="是否显示按钮"%>
<%@ attribute name="disabled" type="java.lang.String" required="false" description="是否限制选择,如果限制,设置为disabled"%>
<%@ attribute name="dataMsgRequired" type="java.lang.String" required="false" description=""%>
    <input id="${id}Id" name="${name}" class="${cssClass}" type="hidden" value="${value}"/>
    <div class="input-group">
        <input id="${id}Name" name="${labelName}" ${allowInput?'':'readonly="readonly"'}  type="text" value="${labelValue}" data-msg-required="${dataMsgRequired}"
        class="${cssClass}" style="${cssStyle}"/>
                <span class="input-group-btn">
                    <button type="button"  id="${id}Button" class="btn <c:if test="${fn:contains(cssClass, 'input-sm')}"> btn-sm </c:if><c:if test="${fn:contains(cssClass, 'input-lg')}"> btn-lg </c:if>  btn-primary ${disabled} ${hideBtn ? 'hide' : ''}"><i class="fa fa-search"></i>
                 </button> 
                </span>
               
    </div>
     <label id="${id}Name-error" class="error" for="${id}Name" style="display:none"></label>
<script type="text/javascript">
    $("#${id}Button, #${id}Name").click(function(){
        // 是否限制选择,如果限制,设置为disabled
        if ($("#${id}Button").hasClass("disabled")){
            return true;
        }
        // 正常打开    
        top.layer.open({
            type: 2, 
            area: ['300px', '420px'],
            title:"选择${title}",
            ajaxData:{selectIds: $("#${id}Id").val()},
            content: "${ctx}/tag/treeselect?url="+encodeURIComponent("${url}")+"&module=${module}&checked=${checked}&extId=${extId}&isAll=${isAll}" ,
            btn: ['确定', '关闭']
               ,yes: function(index, layero){ //或者使用btn1
                        var tree = layero.find("iframe")[0].contentWindow.tree;//h.find("iframe").contents();
                        var ids = [], names = [], nodes = [];
                        if ("${checked}" == "true"){
                            nodes = tree.getCheckedNodes(true);
                        }else{
                            nodes = tree.getSelectedNodes();
                        }
                        for(var i=0; i<nodes.length; i++) {//<c:if test="${checked && notAllowSelectParent}">
                            if (nodes[i].isParent){
                                continue; // 如果为复选框选择,则过滤掉父节点
                            }//</c:if><c:if test="${notAllowSelectRoot}">
                            if (nodes[i].level == 0){
                                //top.$.jBox.tip("不能选择根节点("+nodes[i].name+")请重新选择。");
                                top.layer.msg("不能选择根节点("+nodes[i].name+")请重新选择。", {icon: 0});
                                return false;
                            }//</c:if><c:if test="${notAllowSelectParent}">
                            if (nodes[i].isParent){
                                //top.$.jBox.tip("不能选择父节点("+nodes[i].name+")请重新选择。");
                                //layer.msg('有表情地提示');
                                top.layer.msg("不能选择父节点("+nodes[i].name+")请重新选择。", {icon: 0});
                                return false;
                            }//</c:if><c:if test="${not empty module && selectScopeModule}">
                            if (nodes[i].module == ""){
                                //top.$.jBox.tip("不能选择公共模型("+nodes[i].name+")请重新选择。");
                                top.layer.msg("不能选择公共模型("+nodes[i].name+")请重新选择。", {icon: 0});
                                return false;
                            }else if (nodes[i].module != "${module}"){
                                //top.$.jBox.tip("不能选择当前栏目以外的栏目模型,请重新选择。");
                                top.layer.msg("不能选择当前栏目以外的栏目模型,请重新选择。", {icon: 0});
                                return false;
                            }//</c:if>
                            ids.push(nodes[i].id);
                            names.push(nodes[i].name);//<c:if test="${!checked}">
                            break; // 如果为非复选框选择,则返回第一个选择  </c:if>
                        }
                        $("#${id}Id").val(ids.join(",").replace(/u_/ig,""));
                        $("#${id}Name").val(names.join(","));
                        $("#${id}Name").focus();
                        top.layer.close(index);
                               },
        cancel: function(index){ //或者使用btn2
                   //按钮【按钮二】的回调
               }
        }); 
    
    });
</script>