summaryrefslogtreecommitdiffstats
path: root/bitbake
diff options
context:
space:
mode:
authorDave Lerner <dave.lerner@windriver.com>2014-03-04 15:02:58 -0600
committerRichard Purdie <richard.purdie@linuxfoundation.org>2014-03-21 14:47:53 +0000
commite94f0b4e8c2cbea92688975b1a45a061af48911e (patch)
treeb3a9968645affa9ec7f89819eebb2ca39dbd76f6 /bitbake
parent6f5e196d0f28be421f90b14bb0f2909cc9b6b275 (diff)
downloadpoky-e94f0b4e8c2cbea92688975b1a45a061af48911e.tar.gz
bitbake: toaster: add jquery treetable plugin
This commit includes the critical javascript and css files downloaded from http://plugins.jquery.com/treetable version 3.1.0. The following is from the author's README.md included with the license files in the directory static/jquery-treetable-license. "jQuery treetable is a plugin for jQuery, the 'Write Less, Do More, JavaScript Library'. With this plugin you can display a tree in an HTML table, e.g. a directory structure or a nested list... Download the latest release from the jQuery Plugin Registry or grab the source code from Github. Please report issues through Github issues. This plugin is released under both the MIT and the GPLv2 license by Ludo van den Boom... See index.html for technical documentation and examples. The most recent version of this document is also available online at http://ludo.cubicphuse.nl/jquery-treetable. An AJAX enabled example built with Ruby on Rails can be found at https://github.com/ludo/jquery-treetable-ajax-example." Author: Ludo van den Boom The relevant files were moved to the static/js and static/css directories to match the existing javascript and css toaster deployment model. The applicable licenses and the README are in static/jquery-treetable-license. (Bitbake rev: 9a260d8b08053e3dcc2fe5960e060b2da1109790) Signed-off-by: Dave Lerner <dave.lerner@windriver.com> Signed-off-by: Richard Purdie <richard.purdie@linuxfoundation.org>
Diffstat (limited to 'bitbake')
-rw-r--r--bitbake/lib/toaster/toastergui/static/css/jquery.treetable.css28
-rw-r--r--bitbake/lib/toaster/toastergui/static/css/jquery.treetable.theme.default.css64
-rw-r--r--bitbake/lib/toaster/toastergui/static/css/screen.css28
-rw-r--r--bitbake/lib/toaster/toastergui/static/jquery-treetable-license/GPL-LICENSE.txt278
-rw-r--r--bitbake/lib/toaster/toastergui/static/jquery-treetable-license/MIT-LICENSE.txt20
-rw-r--r--bitbake/lib/toaster/toastergui/static/jquery-treetable-license/README.md20
-rw-r--r--bitbake/lib/toaster/toastergui/static/js/jquery.treetable.js620
7 files changed, 1058 insertions, 0 deletions
diff --git a/bitbake/lib/toaster/toastergui/static/css/jquery.treetable.css b/bitbake/lib/toaster/toastergui/static/css/jquery.treetable.css
new file mode 100644
index 0000000000..4e95bfd3a8
--- /dev/null
+++ b/bitbake/lib/toaster/toastergui/static/css/jquery.treetable.css
@@ -0,0 +1,28 @@
1table.treetable span.indenter {
2 display: inline-block;
3 margin: 0;
4 padding: 0;
5 text-align: right;
6
7 /* Disable text selection of nodes (for better D&D UX) */
8 user-select: none;
9 -khtml-user-select: none;
10 -moz-user-select: none;
11 -o-user-select: none;
12 -webkit-user-select: none;
13
14 /* Force content-box box model for indenter (Bootstrap compatibility) */
15 -webkit-box-sizing: content-box;
16 -moz-box-sizing: content-box;
17 box-sizing: content-box;
18
19 width: 19px;
20}
21
22table.treetable span.indenter a {
23 background-position: left center;
24 background-repeat: no-repeat;
25 display: inline-block;
26 text-decoration: none;
27 width: 19px;
28}
diff --git a/bitbake/lib/toaster/toastergui/static/css/jquery.treetable.theme.default.css b/bitbake/lib/toaster/toastergui/static/css/jquery.treetable.theme.default.css
new file mode 100644
index 0000000000..48289baad1
--- /dev/null
+++ b/bitbake/lib/toaster/toastergui/static/css/jquery.treetable.theme.default.css
@@ -0,0 +1,64 @@
1table.treetable {
2 border: 1px solid #888;
3 border-collapse: collapse;
4 font-size: .8em;
5 line-height: 1;
6 margin: .6em 0 1.8em 0;
7 width: 100%;
8}
9
10table.treetable caption {
11 font-size: .9em;
12 font-weight: bold;
13 margin-bottom: .2em;
14}
15
16table.treetable tbody tr td {
17 cursor: default;
18 padding: .3em 1em;
19}
20
21table.treetable span {
22 background-position: center left;
23 background-repeat: no-repeat;
24 padding: .2em 0 .2em 1.5em;
25}
26
27table.treetable span.file {
28 background-image: url();
29}
30
31table.treetable span.folder {
32 background-image: url();
33}
34
35table.treetable tr.collapsed span.indenter a {
36 background-image: url();
37}
38
39table.treetable tr.expanded span.indenter a {
40 background-image: url();
41}
42
43
44
45table.treetable tr.collapsed.selected span.indenter a {
46 background-image: url();
47}
48
49table.treetable tr.expanded.selected span.indenter a {
50 background-image: url();
51}
52
53table.treetable tr.accept {
54 background-color: #a3bce4;
55 color: #fff
56}
57
58table.treetable tr.collapsed.accept td span.indenter a {
59 background-image: url();
60}
61
62table.treetable tr.expanded.accept td span.indenter a {
63 background-image: url();
64}
diff --git a/bitbake/lib/toaster/toastergui/static/css/screen.css b/bitbake/lib/toaster/toastergui/static/css/screen.css
new file mode 100644
index 0000000000..e233ef6ae2
--- /dev/null
+++ b/bitbake/lib/toaster/toastergui/static/css/screen.css
@@ -0,0 +1,28 @@
1body {
2 background: #ddd;
3 color: #000;
4 font-family: Helvetica, Arial, sans-serif;
5 line-height: 1.5;
6 margin: 0;
7 padding: 0;
8}
9
10#main {
11 background: #fff;
12 border-left: 20px solid #eee;
13 border-right: 20px solid #eee;
14 margin: 0 auto;
15 max-width: 800px;
16 padding: 20px;
17}
18
19pre.listing {
20 background: #eee;
21 border: 1px solid #ccc;
22 margin: .6em 0 .3em 0;
23 padding: .1em .3em;
24}
25
26pre.listing b {
27 color: #f00;
28}
diff --git a/bitbake/lib/toaster/toastergui/static/jquery-treetable-license/GPL-LICENSE.txt b/bitbake/lib/toaster/toastergui/static/jquery-treetable-license/GPL-LICENSE.txt
new file mode 100644
index 0000000000..76927f581c
--- /dev/null
+++ b/bitbake/lib/toaster/toastergui/static/jquery-treetable-license/GPL-LICENSE.txt
@@ -0,0 +1,278 @@
1 GNU GENERAL PUBLIC LICENSE
2 Version 2, June 1991
3
4 Copyright (C) 1989, 1991 Free Software Foundation, Inc.
5 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
6 Everyone is permitted to copy and distribute verbatim copies
7 of this license document, but changing it is not allowed.
8
9 Preamble
10
11 The licenses for most software are designed to take away your
12freedom to share and change it. By contrast, the GNU General Public
13License is intended to guarantee your freedom to share and change free
14software--to make sure the software is free for all its users. This
15General Public License applies to most of the Free Software
16Foundation's software and to any other program whose authors commit to
17using it. (Some other Free Software Foundation software is covered by
18the GNU Lesser General Public License instead.) You can apply it to
19your programs, too.
20
21 When we speak of free software, we are referring to freedom, not
22price. Our General Public Licenses are designed to make sure that you
23have the freedom to distribute copies of free software (and charge for
24this service if you wish), that you receive source code or can get it
25if you want it, that you can change the software or use pieces of it
26in new free programs; and that you know you can do these things.
27
28 To protect your rights, we need to make restrictions that forbid
29anyone to deny you these rights or to ask you to surrender the rights.
30These restrictions translate to certain responsibilities for you if you
31distribute copies of the software, or if you modify it.
32
33 For example, if you distribute copies of such a program, whether
34gratis or for a fee, you must give the recipients all the rights that
35you have. You must make sure that they, too, receive or can get the
36source code. And you must show them these terms so they know their
37rights.
38
39 We protect your rights with two steps: (1) copyright the software, and
40(2) offer you this license which gives you legal permission to copy,
41distribute and/or modify the software.
42
43 Also, for each author's protection and ours, we want to make certain
44that everyone understands that there is no warranty for this free
45software. If the software is modified by someone else and passed on, we
46want its recipients to know that what they have is not the original, so
47that any problems introduced by others will not reflect on the original
48authors' reputations.
49
50 Finally, any free program is threatened constantly by software
51patents. We wish to avoid the danger that redistributors of a free
52program will individually obtain patent licenses, in effect making the
53program proprietary. To prevent this, we have made it clear that any
54patent must be licensed for everyone's free use or not licensed at all.
55
56 The precise terms and conditions for copying, distribution and
57modification follow.
58
59 GNU GENERAL PUBLIC LICENSE
60 TERMS AND CONDITIONS FOR COPYING, DISTRIBUTION AND MODIFICATION
61
62 0. This License applies to any program or other work which contains
63a notice placed by the copyright holder saying it may be distributed
64under the terms of this General Public License. The "Program", below,
65refers to any such program or work, and a "work based on the Program"
66means either the Program or any derivative work under copyright law:
67that is to say, a work containing the Program or a portion of it,
68either verbatim or with modifications and/or translated into another
69language. (Hereinafter, translation is included without limitation in
70the term "modification".) Each licensee is addressed as "you".
71
72Activities other than copying, distribution and modification are not
73covered by this License; they are outside its scope. The act of
74running the Program is not restricted, and the output from the Program
75is covered only if its contents constitute a work based on the
76Program (independent of having been made by running the Program).
77Whether that is true depends on what the Program does.
78
79 1. You may copy and distribute verbatim copies of the Program's
80source code as you receive it, in any medium, provided that you
81conspicuously and appropriately publish on each copy an appropriate
82copyright notice and disclaimer of warranty; keep intact all the
83notices that refer to this License and to the absence of any warranty;
84and give any other recipients of the Program a copy of this License
85along with the Program.
86
87You may charge a fee for the physical act of transferring a copy, and
88you may at your option offer warranty protection in exchange for a fee.
89
90 2. You may modify your copy or copies of the Program or any portion
91of it, thus forming a work based on the Program, and copy and
92distribute such modifications or work under the terms of Section 1
93above, provided that you also meet all of these conditions:
94
95 a) You must cause the modified files to carry prominent notices
96 stating that you changed the files and the date of any change.
97
98 b) You must cause any work that you distribute or publish, that in
99 whole or in part contains or is derived from the Program or any
100 part thereof, to be licensed as a whole at no charge to all third
101 parties under the terms of this License.
102
103 c) If the modified program normally reads commands interactively
104 when run, you must cause it, when started running for such
105 interactive use in the most ordinary way, to print or display an
106 announcement including an appropriate copyright notice and a
107 notice that there is no warranty (or else, saying that you provide
108 a warranty) and that users may redistribute the program under
109 these conditions, and telling the user how to view a copy of this
110 License. (Exception: if the Program itself is interactive but
111 does not normally print such an announcement, your work based on
112 the Program is not required to print an announcement.)
113
114These requirements apply to the modified work as a whole. If
115identifiable sections of that work are not derived from the Program,
116and can be reasonably considered independent and separate works in
117themselves, then this License, and its terms, do not apply to those
118sections when you distribute them as separate works. But when you
119distribute the same sections as part of a whole which is a work based
120on the Program, the distribution of the whole must be on the terms of
121this License, whose permissions for other licensees extend to the
122entire whole, and thus to each and every part regardless of who wrote it.
123
124Thus, it is not the intent of this section to claim rights or contest
125your rights to work written entirely by you; rather, the intent is to
126exercise the right to control the distribution of derivative or
127collective works based on the Program.
128
129In addition, mere aggregation of another work not based on the Program
130with the Program (or with a work based on the Program) on a volume of
131a storage or distribution medium does not bring the other work under
132the scope of this License.
133
134 3. You may copy and distribute the Program (or a work based on it,
135under Section 2) in object code or executable form under the terms of
136Sections 1 and 2 above provided that you also do one of the following:
137
138 a) Accompany it with the complete corresponding machine-readable
139 source code, which must be distributed under the terms of Sections
140 1 and 2 above on a medium customarily used for software interchange; or,
141
142 b) Accompany it with a written offer, valid for at least three
143 years, to give any third party, for a charge no more than your
144 cost of physically performing source distribution, a complete
145 machine-readable copy of the corresponding source code, to be
146 distributed under the terms of Sections 1 and 2 above on a medium
147 customarily used for software interchange; or,
148
149 c) Accompany it with the information you received as to the offer
150 to distribute corresponding source code. (This alternative is
151 allowed only for noncommercial distribution and only if you
152 received the program in object code or executable form with such
153 an offer, in accord with Subsection b above.)
154
155The source code for a work means the preferred form of the work for
156making modifications to it. For an executable work, complete source
157code means all the source code for all modules it contains, plus any
158associated interface definition files, plus the scripts used to
159control compilation and installation of the executable. However, as a
160special exception, the source code distributed need not include
161anything that is normally distributed (in either source or binary
162form) with the major components (compiler, kernel, and so on) of the
163operating system on which the executable runs, unless that component
164itself accompanies the executable.
165
166If distribution of executable or object code is made by offering
167access to copy from a designated place, then offering equivalent
168access to copy the source code from the same place counts as
169distribution of the source code, even though third parties are not
170compelled to copy the source along with the object code.
171
172 4. You may not copy, modify, sublicense, or distribute the Program
173except as expressly provided under this License. Any attempt
174otherwise to copy, modify, sublicense or distribute the Program is
175void, and will automatically terminate your rights under this License.
176However, parties who have received copies, or rights, from you under
177this License will not have their licenses terminated so long as such
178parties remain in full compliance.
179
180 5. You are not required to accept this License, since you have not
181signed it. However, nothing else grants you permission to modify or
182distribute the Program or its derivative works. These actions are
183prohibited by law if you do not accept this License. Therefore, by
184modifying or distributing the Program (or any work based on the
185Program), you indicate your acceptance of this License to do so, and
186all its terms and conditions for copying, distributing or modifying
187the Program or works based on it.
188
189 6. Each time you redistribute the Program (or any work based on the
190Program), the recipient automatically receives a license from the
191original licensor to copy, distribute or modify the Program subject to
192these terms and conditions. You may not impose any further
193restrictions on the recipients' exercise of the rights granted herein.
194You are not responsible for enforcing compliance by third parties to
195this License.
196
197 7. If, as a consequence of a court judgment or allegation of patent
198infringement or for any other reason (not limited to patent issues),
199conditions are imposed on you (whether by court order, agreement or
200otherwise) that contradict the conditions of this License, they do not
201excuse you from the conditions of this License. If you cannot
202distribute so as to satisfy simultaneously your obligations under this
203License and any other pertinent obligations, then as a consequence you
204may not distribute the Program at all. For example, if a patent
205license would not permit royalty-free redistribution of the Program by
206all those who receive copies directly or indirectly through you, then
207the only way you could satisfy both it and this License would be to
208refrain entirely from distribution of the Program.
209
210If any portion of this section is held invalid or unenforceable under
211any particular circumstance, the balance of the section is intended to
212apply and the section as a whole is intended to apply in other
213circumstances.
214
215It is not the purpose of this section to induce you to infringe any
216patents or other property right claims or to contest validity of any
217such claims; this section has the sole purpose of protecting the
218integrity of the free software distribution system, which is
219implemented by public license practices. Many people have made
220generous contributions to the wide range of software distributed
221through that system in reliance on consistent application of that
222system; it is up to the author/donor to decide if he or she is willing
223to distribute software through any other system and a licensee cannot
224impose that choice.
225
226This section is intended to make thoroughly clear what is believed to
227be a consequence of the rest of this License.
228
229 8. If the distribution and/or use of the Program is restricted in
230certain countries either by patents or by copyrighted interfaces, the
231original copyright holder who places the Program under this License
232may add an explicit geographical distribution limitation excluding
233those countries, so that distribution is permitted only in or among
234countries not thus excluded. In such case, this License incorporates
235the limitation as if written in the body of this License.
236
237 9. The Free Software Foundation may publish revised and/or new versions
238of the General Public License from time to time. Such new versions will
239be similar in spirit to the present version, but may differ in detail to
240address new problems or concerns.
241
242Each version is given a distinguishing version number. If the Program
243specifies a version number of this License which applies to it and "any
244later version", you have the option of following the terms and conditions
245either of that version or of any later version published by the Free
246Software Foundation. If the Program does not specify a version number of
247this License, you may choose any version ever published by the Free Software
248Foundation.
249
250 10. If you wish to incorporate parts of the Program into other free
251programs whose distribution conditions are different, write to the author
252to ask for permission. For software which is copyrighted by the Free
253Software Foundation, write to the Free Software Foundation; we sometimes
254make exceptions for this. Our decision will be guided by the two goals
255of preserving the free status of all derivatives of our free software and
256of promoting the sharing and reuse of software generally.
257
258 NO WARRANTY
259
260 11. BECAUSE THE PROGRAM IS LICENSED FREE OF CHARGE, THERE IS NO WARRANTY
261FOR THE PROGRAM, TO THE EXTENT PERMITTED BY APPLICABLE LAW. EXCEPT WHEN
262OTHERWISE STATED IN WRITING THE COPYRIGHT HOLDERS AND/OR OTHER PARTIES
263PROVIDE THE PROGRAM "AS IS" WITHOUT WARRANTY OF ANY KIND, EITHER EXPRESSED
264OR IMPLIED, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF
265MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE. THE ENTIRE RISK AS
266TO THE QUALITY AND PERFORMANCE OF THE PROGRAM IS WITH YOU. SHOULD THE
267PROGRAM PROVE DEFECTIVE, YOU ASSUME THE COST OF ALL NECESSARY SERVICING,
268REPAIR OR CORRECTION.
269
270 12. IN NO EVENT UNLESS REQUIRED BY APPLICABLE LAW OR AGREED TO IN WRITING
271WILL ANY COPYRIGHT HOLDER, OR ANY OTHER PARTY WHO MAY MODIFY AND/OR
272REDISTRIBUTE THE PROGRAM AS PERMITTED ABOVE, BE LIABLE TO YOU FOR DAMAGES,
273INCLUDING ANY GENERAL, SPECIAL, INCIDENTAL OR CONSEQUENTIAL DAMAGES ARISING
274OUT OF THE USE OR INABILITY TO USE THE PROGRAM (INCLUDING BUT NOT LIMITED
275TO LOSS OF DATA OR DATA BEING RENDERED INACCURATE OR LOSSES SUSTAINED BY
276YOU OR THIRD PARTIES OR A FAILURE OF THE PROGRAM TO OPERATE WITH ANY OTHER
277PROGRAMS), EVEN IF SUCH HOLDER OR OTHER PARTY HAS BEEN ADVISED OF THE
278POSSIBILITY OF SUCH DAMAGES. \ No newline at end of file
diff --git a/bitbake/lib/toaster/toastergui/static/jquery-treetable-license/MIT-LICENSE.txt b/bitbake/lib/toaster/toastergui/static/jquery-treetable-license/MIT-LICENSE.txt
new file mode 100644
index 0000000000..c2e824fb08
--- /dev/null
+++ b/bitbake/lib/toaster/toastergui/static/jquery-treetable-license/MIT-LICENSE.txt
@@ -0,0 +1,20 @@
1Copyright (c) 2013 Ludo van den Boom, http://ludovandenboom.com
2
3Permission is hereby granted, free of charge, to any person obtaining
4a copy of this software and associated documentation files (the
5"Software"), to deal in the Software without restriction, including
6without limitation the rights to use, copy, modify, merge, publish,
7distribute, sublicense, and/or sell copies of the Software, and to
8permit persons to whom the Software is furnished to do so, subject to
9the following conditions:
10
11The above copyright notice and this permission notice shall be
12included in all copies or substantial portions of the Software.
13
14THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
15EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
16MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
17NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE
18LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION
19OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION
20WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
diff --git a/bitbake/lib/toaster/toastergui/static/jquery-treetable-license/README.md b/bitbake/lib/toaster/toastergui/static/jquery-treetable-license/README.md
new file mode 100644
index 0000000000..ece7afb58c
--- /dev/null
+++ b/bitbake/lib/toaster/toastergui/static/jquery-treetable-license/README.md
@@ -0,0 +1,20 @@
1# jQuery treetable
2
3jQuery treetable is a plugin for jQuery, the 'Write Less, Do More, JavaScript
4Library'. With this plugin you can display a tree in an HTML table, e.g. a
5directory structure or a nested list. Why not use a list, you say? Because lists
6are great for displaying a tree, and tables are not. Oh wait, but this plugin
7uses tables, doesn't it? Yes. Why do I use a table to display a list? Because I
8need multiple columns to display additional data besides the tree.
9
10Download the latest release from the jQuery Plugin Registry or grab the source
11code from Github. Please report issues through Github issues. This plugin is
12released under both the MIT and the GPLv2 license by Ludo van den Boom.
13
14## Documentation and Examples
15
16See index.html for technical documentation and examples. The most recent version
17of this document is also available online at
18http://ludo.cubicphuse.nl/jquery-treetable. An AJAX enabled example built with
19Ruby on Rails can be found at
20https://github.com/ludo/jquery-treetable-ajax-example.
diff --git a/bitbake/lib/toaster/toastergui/static/js/jquery.treetable.js b/bitbake/lib/toaster/toastergui/static/js/jquery.treetable.js
new file mode 100644
index 0000000000..42e7427cc0
--- /dev/null
+++ b/bitbake/lib/toaster/toastergui/static/js/jquery.treetable.js
@@ -0,0 +1,620 @@
1/*
2 * jQuery treetable Plugin 3.1.0
3 * http://ludo.cubicphuse.nl/jquery-treetable
4 *
5 * Copyright 2013, Ludo van den Boom
6 * Dual licensed under the MIT or GPL Version 2 licenses.
7 */
8(function() {
9 var $, Node, Tree, methods;
10
11 $ = jQuery;
12
13 Node = (function() {
14 function Node(row, tree, settings) {
15 var parentId;
16
17 this.row = row;
18 this.tree = tree;
19 this.settings = settings;
20
21 // TODO Ensure id/parentId is always a string (not int)
22 this.id = this.row.data(this.settings.nodeIdAttr);
23
24 // TODO Move this to a setParentId function?
25 parentId = this.row.data(this.settings.parentIdAttr);
26 if (parentId != null && parentId !== "") {
27 this.parentId = parentId;
28 }
29
30 this.treeCell = $(this.row.children(this.settings.columnElType)[this.settings.column]);
31 this.expander = $(this.settings.expanderTemplate);
32 this.indenter = $(this.settings.indenterTemplate);
33 this.children = [];
34 this.initialized = false;
35 this.treeCell.prepend(this.indenter);
36 }
37
38 Node.prototype.addChild = function(child) {
39 return this.children.push(child);
40 };
41
42 Node.prototype.ancestors = function() {
43 var ancestors, node;
44 node = this;
45 ancestors = [];
46 while (node = node.parentNode()) {
47 ancestors.push(node);
48 }
49 return ancestors;
50 };
51
52 Node.prototype.collapse = function() {
53 if (this.collapsed()) {
54 return this;
55 }
56
57 this.row.removeClass("expanded").addClass("collapsed");
58
59 this._hideChildren();
60 this.expander.attr("title", this.settings.stringExpand);
61
62 if (this.initialized && this.settings.onNodeCollapse != null) {
63 this.settings.onNodeCollapse.apply(this);
64 }
65
66 return this;
67 };
68
69 Node.prototype.collapsed = function() {
70 return this.row.hasClass("collapsed");
71 };
72
73 // TODO destroy: remove event handlers, expander, indenter, etc.
74
75 Node.prototype.expand = function() {
76 if (this.expanded()) {
77 return this;
78 }
79
80 this.row.removeClass("collapsed").addClass("expanded");
81
82 if (this.initialized && this.settings.onNodeExpand != null) {
83 this.settings.onNodeExpand.apply(this);
84 }
85
86 if ($(this.row).is(":visible")) {
87 this._showChildren();
88 }
89
90 this.expander.attr("title", this.settings.stringCollapse);
91
92 return this;
93 };
94
95 Node.prototype.expanded = function() {
96 return this.row.hasClass("expanded");
97 };
98
99 Node.prototype.hide = function() {
100 this._hideChildren();
101 this.row.hide();
102 return this;
103 };
104
105 Node.prototype.isBranchNode = function() {
106 if(this.children.length > 0 || this.row.data(this.settings.branchAttr) === true) {
107 return true;
108 } else {
109 return false;
110 }
111 };
112
113 Node.prototype.updateBranchLeafClass = function(){
114 this.row.removeClass('branch');
115 this.row.removeClass('leaf');
116 this.row.addClass(this.isBranchNode() ? 'branch' : 'leaf');
117 };
118
119 Node.prototype.level = function() {
120 return this.ancestors().length;
121 };
122
123 Node.prototype.parentNode = function() {
124 if (this.parentId != null) {
125 return this.tree[this.parentId];
126 } else {
127 return null;
128 }
129 };
130
131 Node.prototype.removeChild = function(child) {
132 var i = $.inArray(child, this.children);
133 return this.children.splice(i, 1)
134 };
135
136 Node.prototype.render = function() {
137 var handler,
138 settings = this.settings,
139 target;
140
141 if (settings.expandable === true && this.isBranchNode()) {
142 handler = function(e) {
143 $(this).parents("table").treetable("node", $(this).parents("tr").data(settings.nodeIdAttr)).toggle();
144 return e.preventDefault();
145 };
146
147 this.indenter.html(this.expander);
148 target = settings.clickableNodeNames === true ? this.treeCell : this.expander;
149
150 target.off("click.treetable").on("click.treetable", handler);
151 target.off("keydown.treetable").on("keydown.treetable", function(e) {
152 if (e.keyCode == 13) {
153 handler.apply(this, [e]);
154 }
155 });
156 }
157
158 this.indenter[0].style.paddingLeft = "" + (this.level() * settings.indent) + "px";
159
160 return this;
161 };
162
163 Node.prototype.reveal = function() {
164 if (this.parentId != null) {
165 this.parentNode().reveal();
166 }
167 return this.expand();
168 };
169
170 Node.prototype.setParent = function(node) {
171 if (this.parentId != null) {
172 this.tree[this.parentId].removeChild(this);
173 }
174 this.parentId = node.id;
175 this.row.data(this.settings.parentIdAttr, node.id);
176 return node.addChild(this);
177 };
178
179 Node.prototype.show = function() {
180 if (!this.initialized) {
181 this._initialize();
182 }
183 this.row.show();
184 if (this.expanded()) {
185 this._showChildren();
186 }
187 return this;
188 };
189
190 Node.prototype.toggle = function() {
191 if (this.expanded()) {
192 this.collapse();
193 } else {
194 this.expand();
195 }
196 return this;
197 };
198
199 Node.prototype._hideChildren = function() {
200 var child, _i, _len, _ref, _results;
201 _ref = this.children;
202 _results = [];
203 for (_i = 0, _len = _ref.length; _i < _len; _i++) {
204 child = _ref[_i];
205 _results.push(child.hide());
206 }
207 return _results;
208 };
209
210 Node.prototype._initialize = function() {
211 var settings = this.settings;
212
213 this.render();
214
215 if (settings.expandable === true && settings.initialState === "collapsed") {
216 this.collapse();
217 } else {
218 this.expand();
219 }
220
221 if (settings.onNodeInitialized != null) {
222 settings.onNodeInitialized.apply(this);
223 }
224
225 return this.initialized = true;
226 };
227
228 Node.prototype._showChildren = function() {
229 var child, _i, _len, _ref, _results;
230 _ref = this.children;
231 _results = [];
232 for (_i = 0, _len = _ref.length; _i < _len; _i++) {
233 child = _ref[_i];
234 _results.push(child.show());
235 }
236 return _results;
237 };
238
239 return Node;
240 })();
241
242 Tree = (function() {
243 function Tree(table, settings) {
244 this.table = table;
245 this.settings = settings;
246 this.tree = {};
247
248 // Cache the nodes and roots in simple arrays for quick access/iteration
249 this.nodes = [];
250 this.roots = [];
251 }
252
253 Tree.prototype.collapseAll = function() {
254 var node, _i, _len, _ref, _results;
255 _ref = this.nodes;
256 _results = [];
257 for (_i = 0, _len = _ref.length; _i < _len; _i++) {
258 node = _ref[_i];
259 _results.push(node.collapse());
260 }
261 return _results;
262 };
263
264 Tree.prototype.expandAll = function() {
265 var node, _i, _len, _ref, _results;
266 _ref = this.nodes;
267 _results = [];
268 for (_i = 0, _len = _ref.length; _i < _len; _i++) {
269 node = _ref[_i];
270 _results.push(node.expand());
271 }
272 return _results;
273 };
274
275 Tree.prototype.findLastNode = function (node) {
276 if (node.children.length > 0) {
277 return this.findLastNode(node.children[node.children.length - 1]);
278 } else {
279 return node;
280 }
281 };
282
283 Tree.prototype.loadRows = function(rows) {
284 var node, row, i;
285
286 if (rows != null) {
287 for (i = 0; i < rows.length; i++) {
288 row = $(rows[i]);
289
290 if (row.data(this.settings.nodeIdAttr) != null) {
291 node = new Node(row, this.tree, this.settings);
292 this.nodes.push(node);
293 this.tree[node.id] = node;
294
295 if (node.parentId != null) {
296 this.tree[node.parentId].addChild(node);
297 } else {
298 this.roots.push(node);
299 }
300 }
301 }
302 }
303
304 for (i = 0; i < this.nodes.length; i++) {
305 node = this.nodes[i].updateBranchLeafClass();
306 }
307
308 return this;
309 };
310
311 Tree.prototype.move = function(node, destination) {
312 // Conditions:
313 // 1: +node+ should not be inserted as a child of +node+ itself.
314 // 2: +destination+ should not be the same as +node+'s current parent (this
315 // prevents +node+ from being moved to the same location where it already
316 // is).
317 // 3: +node+ should not be inserted in a location in a branch if this would
318 // result in +node+ being an ancestor of itself.
319 var nodeParent = node.parentNode();
320 if (node !== destination && destination.id !== node.parentId && $.inArray(node, destination.ancestors()) === -1) {
321 node.setParent(destination);
322 this._moveRows(node, destination);
323
324 // Re-render parentNode if this is its first child node, and therefore
325 // doesn't have the expander yet.
326 if (node.parentNode().children.length === 1) {
327 node.parentNode().render();
328 }
329 }
330
331 if(nodeParent){
332 nodeParent.updateBranchLeafClass();
333 }
334 if(node.parentNode()){
335 node.parentNode().updateBranchLeafClass();
336 }
337 node.updateBranchLeafClass();
338 return this;
339 };
340
341 Tree.prototype.removeNode = function(node) {
342 // Recursively remove all descendants of +node+
343 this.unloadBranch(node);
344
345 // Remove node from DOM (<tr>)
346 node.row.remove();
347
348 // Clean up Tree object (so Node objects are GC-ed)
349 delete this.tree[node.id];
350 this.nodes.splice($.inArray(node, this.nodes), 1);
351 }
352
353 Tree.prototype.render = function() {
354 var root, _i, _len, _ref;
355 _ref = this.roots;
356 for (_i = 0, _len = _ref.length; _i < _len; _i++) {
357 root = _ref[_i];
358
359 // Naming is confusing (show/render). I do not call render on node from
360 // here.
361 root.show();
362 }
363 return this;
364 };
365
366 Tree.prototype.sortBranch = function(node, sortFun) {
367 // First sort internal array of children
368 node.children.sort(sortFun);
369
370 // Next render rows in correct order on page
371 this._sortChildRows(node);
372
373 return this;
374 };
375
376 Tree.prototype.unloadBranch = function(node) {
377 var children, i;
378
379 for (i = 0; i < node.children.length; i++) {
380 this.removeNode(node.children[i]);
381 }
382
383 // Reset node's collection of children
384 node.children = [];
385
386 node.updateBranchLeafClass();
387
388 return this;
389 };
390
391 Tree.prototype._moveRows = function(node, destination) {
392 var children = node.children, i;
393
394 node.row.insertAfter(destination.row);
395 node.render();
396
397 // Loop backwards through children to have them end up on UI in correct
398 // order (see #112)
399 for (i = children.length - 1; i >= 0; i--) {
400 this._moveRows(children[i], node);
401 }
402 };
403
404 // Special _moveRows case, move children to itself to force sorting
405 Tree.prototype._sortChildRows = function(parentNode) {
406 return this._moveRows(parentNode, parentNode);
407 };
408
409 return Tree;
410 })();
411
412 // jQuery Plugin
413 methods = {
414 init: function(options, force) {
415 var settings;
416
417 settings = $.extend({
418 branchAttr: "ttBranch",
419 clickableNodeNames: false,
420 column: 0,
421 columnElType: "td", // i.e. 'td', 'th' or 'td,th'
422 expandable: false,
423 expanderTemplate: "<a href='#'>&nbsp;</a>",
424 indent: 19,
425 indenterTemplate: "<span class='indenter'></span>",
426 initialState: "collapsed",
427 nodeIdAttr: "ttId", // maps to data-tt-id
428 parentIdAttr: "ttParentId", // maps to data-tt-parent-id
429 stringExpand: "Expand",
430 stringCollapse: "Collapse",
431
432 // Events
433 onInitialized: null,
434 onNodeCollapse: null,
435 onNodeExpand: null,
436 onNodeInitialized: null
437 }, options);
438
439 return this.each(function() {
440 var el = $(this), tree;
441
442 if (force || el.data("treetable") === undefined) {
443 tree = new Tree(this, settings);
444 tree.loadRows(this.rows).render();
445
446 el.addClass("treetable").data("treetable", tree);
447
448 if (settings.onInitialized != null) {
449 settings.onInitialized.apply(tree);
450 }
451 }
452
453 return el;
454 });
455 },
456
457 destroy: function() {
458 return this.each(function() {
459 return $(this).removeData("treetable").removeClass("treetable");
460 });
461 },
462
463 collapseAll: function() {
464 this.data("treetable").collapseAll();
465 return this;
466 },
467
468 collapseNode: function(id) {
469 var node = this.data("treetable").tree[id];
470
471 if (node) {
472 node.collapse();
473 } else {
474 throw new Error("Unknown node '" + id + "'");
475 }
476
477 return this;
478 },
479
480 expandAll: function() {
481 this.data("treetable").expandAll();
482 return this;
483 },
484
485 expandNode: function(id) {
486 var node = this.data("treetable").tree[id];
487
488 if (node) {
489 if (!node.initialized) {
490 node._initialize();
491 }
492
493 node.expand();
494 } else {
495 throw new Error("Unknown node '" + id + "'");
496 }
497
498 return this;
499 },
500
501 loadBranch: function(node, rows) {
502 var settings = this.data("treetable").settings,
503 tree = this.data("treetable").tree;
504
505 // TODO Switch to $.parseHTML
506 rows = $(rows);
507
508 if (node == null) { // Inserting new root nodes
509 this.append(rows);
510 } else {
511 var lastNode = this.data("treetable").findLastNode(node);
512 rows.insertAfter(lastNode.row);
513 }
514
515 this.data("treetable").loadRows(rows);
516
517 // Make sure nodes are properly initialized
518 rows.filter("tr").each(function() {
519 tree[$(this).data(settings.nodeIdAttr)].show();
520 });
521
522 if (node != null) {
523 // Re-render parent to ensure expander icon is shown (#79)
524 node.render().expand();
525 }
526
527 return this;
528 },
529
530 move: function(nodeId, destinationId) {
531 var destination, node;
532
533 node = this.data("treetable").tree[nodeId];
534 destination = this.data("treetable").tree[destinationId];
535 this.data("treetable").move(node, destination);
536
537 return this;
538 },
539
540 node: function(id) {
541 return this.data("treetable").tree[id];
542 },
543
544 removeNode: function(id) {
545 var node = this.data("treetable").tree[id];
546
547 if (node) {
548 this.data("treetable").removeNode(node);
549 } else {
550 throw new Error("Unknown node '" + id + "'");
551 }
552
553 return this;
554 },
555
556 reveal: function(id) {
557 var node = this.data("treetable").tree[id];
558
559 if (node) {
560 node.reveal();
561 } else {
562 throw new Error("Unknown node '" + id + "'");
563 }
564
565 return this;
566 },
567
568 sortBranch: function(node, columnOrFunction) {
569 var settings = this.data("treetable").settings,
570 prepValue,
571 sortFun;
572
573 columnOrFunction = columnOrFunction || settings.column;
574 sortFun = columnOrFunction;
575
576 if ($.isNumeric(columnOrFunction)) {
577 sortFun = function(a, b) {
578 var extractValue, valA, valB;
579
580 extractValue = function(node) {
581 var val = node.row.find("td:eq(" + columnOrFunction + ")").text();
582 // Ignore trailing/leading whitespace and use uppercase values for
583 // case insensitive ordering
584 return $.trim(val).toUpperCase();
585 }
586
587 valA = extractValue(a);
588 valB = extractValue(b);
589
590 if (valA < valB) return -1;
591 if (valA > valB) return 1;
592 return 0;
593 };
594 }
595
596 this.data("treetable").sortBranch(node, sortFun);
597 return this;
598 },
599
600 unloadBranch: function(node) {
601 this.data("treetable").unloadBranch(node);
602 return this;
603 }
604 };
605
606 $.fn.treetable = function(method) {
607 if (methods[method]) {
608 return methods[method].apply(this, Array.prototype.slice.call(arguments, 1));
609 } else if (typeof method === 'object' || !method) {
610 return methods.init.apply(this, arguments);
611 } else {
612 return $.error("Method " + method + " does not exist on jQuery.treetable");
613 }
614 };
615
616 // Expose classes to world
617 this.TreeTable || (this.TreeTable = {});
618 this.TreeTable.Node = Node;
619 this.TreeTable.Tree = Tree;
620}).call(this);