zhuguifei
2026-03-10 58402bd5e762361363a0f7d7907153c77dbb819f
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
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
/**
* jQuery EasyUI 1.3.6
* Copyright (c) 2009-2014 www.jeasyui.com. All rights reserved.
*
* Licensed under the GPL or commercial licenses
* To use it on other terms please contact author: info@jeasyui.com
* http://www.gnu.org/licenses/gpl.txt
* http://www.jeasyui.com/license_commercial.php
*
* jQuery EasyUI layout Extensions 1.0 beta
* jQuery EasyUI layout 组件扩展
* jeasyui.extensions.layout.js
* 二次开发 流云
* 最近更新:2014-06-17
*
* 依赖项:
*   1、jquery.jdirk.js v1.0 beta late
*   2、jeasyui.extensions.js v1.0 beta late
*
* Copyright (c) 2013-2014 ChenJianwei personal All rights reserved.
* http://www.chenjianwei.org
*/
(function ($, undefined) {
 
    $.fn.layout.extensions = { resizeDelay: 500 };
 
 
 
    function getPanels(target, withCenter) {
        var l = $(target),
            flag = (withCenter == null || withCenter == undefined) ? true : withCenter,
            regions = flag ? ["north", "west", "east", "center", "south"] : ["north", "west", "east", "south"];
        return $.array.reduce(regions, function (prev, val, index) {
            var p = l.layout("panel", val);
            if (p && p.length) {
                prev.push({ region: val, panel: p });
                prev[val] = p;
            }
            return prev;
        }, []);
    };
 
    function collapseRegion(l, region) {
        var p = l.layout("panel", region);
        if (p && p.length) {
            var opts = p.panel("options");
            if (!opts.collapsed) { l.layout("collapse", region); }
        }
    };
 
    function collapseAll(target) {
        var l = $(target), panels = l.layout("panels", false);
        $.each(panels, function (index, item) {
            var opts = item.panel.panel("options");
            if (!opts.collapsed) { l.layout("collapse", item.region); }
        });
        $.util.exec(function () { l.layout("resize"); }, $.fn.layout.extensions.resizeDelay);
    };
 
    function expandRegion(l, region) {
        var p = l.layout("panel", region);
        if (p && p.length) {
            var opts = p.panel("options");
            if (opts.collapsed) { l.layout("expand", region); }
        }
    };
 
    function expandAll(target) {
        var l = $(target), panels = l.layout("panels", false);
        $.each(panels, function (index, item) {
            var opts = item.panel.panel("options");
            if (opts.collapsed) { l.layout("expand", item.region); }
        });
        $.util.exec(function () { l.layout("resize"); }, $.fn.layout.extensions.resizeDelay);
    };
 
 
    function toggle(target, region) {
        if (!$.array.contains(["north", "west", "east", "center", "south"], region)) { return; }
        var l = $(target), p = l.layout("panel", region);
        if (p && p.length) {
            var opts = p.panel("options");
            if (opts.collapsed) { l.layout("expand", region); } else { l.layout("collapse", region); }
        }
    };
 
    function toggleAll(target, type) {
        if (!$.array.contains(["collapse", "expand", "toggle"], type)) { type = "toggle"; }
        var l = $(target), regions = ["north", "west", "east", "south"],
            hasCollapsed = $.array.some(regions, function (region) {
                var p = l.layout("panel", region);
                if (p && p.length) { var opts = p.panel("options"); return opts.collapsed ? true : false; } else { return false; }
            }),
            hasExpanded = $.array.some(regions, function (region) {
                var p = l.layout("panel", region);
                if (p && p.length) { var opts = p.panel("options"); return !opts.collapsed ? true : false; } else { return false; }
            });
        switch (type) {
            case "collapse":
                l.layout(hasExpanded ? "collapseAll" : "expandAll");
                break;
            case "expand":
                l.layout(hasCollapsed ? "expandAll" : "collapseAll");
                break;
            case "toggle":
                toggleRegions();
                break;
            default:
                toggleRegions();
                break;
        }
        function toggleRegions() {
            $.each(regions, function (i, region) {
                l.layout("toggle", region);
            });
            $.util.exec(function () { l.layout("resize"); }, $.fn.layout.extensions.resizeDelay);
        };
    };
 
 
 
 
    var defaults = $.fn.layout.extensions.defaults = {};
 
    var methods = $.fn.layout.extensions.methods = {
 
        // 扩展 easyui-layout 组件的自定义方法;获取 easyui-layout 组件的所有 panel 面板;
        // 该方法的参数 withCenter 是一个 boolean 类型值,默认为 true;表示返回的数组中是否包含 center panel。
        // 返回值:该方法返回一个 Array 数组对象;数组中的每个元素都是一个包含如下属性定义的 JSON-Object:
        //      region  : String 类型值,表示该面板所在的位置,可能的值为 "north"、"west"、"east"、"center"、"south";
        //      panel   : jQuery 对象,表示 easyui-panel 面板对象;
        panels: function (jq, withCenter) { return getPanels(jq[0], withCenter); },
 
        //  扩展 easyui-layout 组件的自定义方法;用于折叠 easyui-layout 组件除 center 位置外的所有 panel 面板;
        //  返回值:返回表示当前 easyui-combo layout jQuery 链式对象。
        collapseAll: function (jq) { return jq.each(function () { collapseAll(this); }); },
 
        //  扩展 easyui-layout 组件的自定义方法;用于展开 easyui-layout 组件除 center 位置外的所有 panel 面板;
        //  返回值:返回表示当前 easyui-combo layout jQuery 链式对象。
        expandAll: function (jq) { return jq.each(function () { expandAll(this); }); },
 
        //  扩展 easyui-layout 组件的自定义方法;用于切换 panel 面板的 折叠/展开 状态;该方法定义如下参数:
        //      region: String 类型值,表示要切换 折叠/展开 状态的面板的位置;
        //  返回值:返回表示当前 easyui-combo layout jQuery 链式对象。
        toggle: function (jq, region) { return jq.each(function () { toggle(this, region); }); },
 
        //  扩展 easyui-layout 组件的自定义方法;用于切换所有 panel 面板的 折叠/展开 状态;该方法定义如下参数:
        //      type:   String 类型值,表示在进行 折叠/展开 操作时的操作方式;该参数传入的值限定在以下范围内:
        //          "collapse": 当既有展开的面板也有折叠的面板时,对所有面板执行折叠操作;
        //          "expand"  : 当既有展开的面板也有折叠的面板时,对所有面板执行展开操作;
        //          "toggle"  : 当既有展开的面板也有折叠的面板时,对所有面板执行切换 折叠/展开 状态操作;默认值。
        //  返回值:返回表示当前 easyui-combo layout jQuery 链式对象。
        toggleAll: function (jq, type) { return jq.each(function () { toggleAll(this, type); }); }
    };
 
 
    $.extend($.fn.layout.defaults, defaults);
    $.extend($.fn.layout.methods, methods);
 
})(jQuery);