diff options
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 @@ | |||
1 | table.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 | |||
22 | table.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 @@ | |||
1 | table.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 | |||
10 | table.treetable caption { | ||
11 | font-size: .9em; | ||
12 | font-weight: bold; | ||
13 | margin-bottom: .2em; | ||
14 | } | ||
15 | |||
16 | table.treetable tbody tr td { | ||
17 | cursor: default; | ||
18 | padding: .3em 1em; | ||
19 | } | ||
20 | |||
21 | table.treetable span { | ||
22 | background-position: center left; | ||
23 | background-repeat: no-repeat; | ||
24 | padding: .2em 0 .2em 1.5em; | ||
25 | } | ||
26 | |||
27 | table.treetable span.file { | ||
28 | background-image: url(); | ||
29 | } | ||
30 | |||
31 | table.treetable span.folder { | ||
32 | background-image: url(); | ||
33 | } | ||
34 | |||
35 | table.treetable tr.collapsed span.indenter a { | ||
36 | background-image: url(); | ||
37 | } | ||
38 | |||
39 | table.treetable tr.expanded span.indenter a { | ||
40 | background-image: url(); | ||
41 | } | ||
42 | |||
43 | |||
44 | |||
45 | table.treetable tr.collapsed.selected span.indenter a { | ||
46 | background-image: url(); | ||
47 | } | ||
48 | |||
49 | table.treetable tr.expanded.selected span.indenter a { | ||
50 | background-image: url(); | ||
51 | } | ||
52 | |||
53 | table.treetable tr.accept { | ||
54 | background-color: #a3bce4; | ||
55 | color: #fff | ||
56 | } | ||
57 | |||
58 | table.treetable tr.collapsed.accept td span.indenter a { | ||
59 | background-image: url(); | ||
60 | } | ||
61 | |||
62 | table.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 @@ | |||
1 | body { | ||
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 | |||
19 | pre.listing { | ||
20 | background: #eee; | ||
21 | border: 1px solid #ccc; | ||
22 | margin: .6em 0 .3em 0; | ||
23 | padding: .1em .3em; | ||
24 | } | ||
25 | |||
26 | pre.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 | ||
12 | freedom to share and change it. By contrast, the GNU General Public | ||
13 | License is intended to guarantee your freedom to share and change free | ||
14 | software--to make sure the software is free for all its users. This | ||
15 | General Public License applies to most of the Free Software | ||
16 | Foundation's software and to any other program whose authors commit to | ||
17 | using it. (Some other Free Software Foundation software is covered by | ||
18 | the GNU Lesser General Public License instead.) You can apply it to | ||
19 | your programs, too. | ||
20 | |||
21 | When we speak of free software, we are referring to freedom, not | ||
22 | price. Our General Public Licenses are designed to make sure that you | ||
23 | have the freedom to distribute copies of free software (and charge for | ||
24 | this service if you wish), that you receive source code or can get it | ||
25 | if you want it, that you can change the software or use pieces of it | ||
26 | in 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 | ||
29 | anyone to deny you these rights or to ask you to surrender the rights. | ||
30 | These restrictions translate to certain responsibilities for you if you | ||
31 | distribute copies of the software, or if you modify it. | ||
32 | |||
33 | For example, if you distribute copies of such a program, whether | ||
34 | gratis or for a fee, you must give the recipients all the rights that | ||
35 | you have. You must make sure that they, too, receive or can get the | ||
36 | source code. And you must show them these terms so they know their | ||
37 | rights. | ||
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, | ||
41 | distribute and/or modify the software. | ||
42 | |||
43 | Also, for each author's protection and ours, we want to make certain | ||
44 | that everyone understands that there is no warranty for this free | ||
45 | software. If the software is modified by someone else and passed on, we | ||
46 | want its recipients to know that what they have is not the original, so | ||
47 | that any problems introduced by others will not reflect on the original | ||
48 | authors' reputations. | ||
49 | |||
50 | Finally, any free program is threatened constantly by software | ||
51 | patents. We wish to avoid the danger that redistributors of a free | ||
52 | program will individually obtain patent licenses, in effect making the | ||
53 | program proprietary. To prevent this, we have made it clear that any | ||
54 | patent must be licensed for everyone's free use or not licensed at all. | ||
55 | |||
56 | The precise terms and conditions for copying, distribution and | ||
57 | modification 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 | ||
63 | a notice placed by the copyright holder saying it may be distributed | ||
64 | under the terms of this General Public License. The "Program", below, | ||
65 | refers to any such program or work, and a "work based on the Program" | ||
66 | means either the Program or any derivative work under copyright law: | ||
67 | that is to say, a work containing the Program or a portion of it, | ||
68 | either verbatim or with modifications and/or translated into another | ||
69 | language. (Hereinafter, translation is included without limitation in | ||
70 | the term "modification".) Each licensee is addressed as "you". | ||
71 | |||
72 | Activities other than copying, distribution and modification are not | ||
73 | covered by this License; they are outside its scope. The act of | ||
74 | running the Program is not restricted, and the output from the Program | ||
75 | is covered only if its contents constitute a work based on the | ||
76 | Program (independent of having been made by running the Program). | ||
77 | Whether that is true depends on what the Program does. | ||
78 | |||
79 | 1. You may copy and distribute verbatim copies of the Program's | ||
80 | source code as you receive it, in any medium, provided that you | ||
81 | conspicuously and appropriately publish on each copy an appropriate | ||
82 | copyright notice and disclaimer of warranty; keep intact all the | ||
83 | notices that refer to this License and to the absence of any warranty; | ||
84 | and give any other recipients of the Program a copy of this License | ||
85 | along with the Program. | ||
86 | |||
87 | You may charge a fee for the physical act of transferring a copy, and | ||
88 | you 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 | ||
91 | of it, thus forming a work based on the Program, and copy and | ||
92 | distribute such modifications or work under the terms of Section 1 | ||
93 | above, 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 | |||
114 | These requirements apply to the modified work as a whole. If | ||
115 | identifiable sections of that work are not derived from the Program, | ||
116 | and can be reasonably considered independent and separate works in | ||
117 | themselves, then this License, and its terms, do not apply to those | ||
118 | sections when you distribute them as separate works. But when you | ||
119 | distribute the same sections as part of a whole which is a work based | ||
120 | on the Program, the distribution of the whole must be on the terms of | ||
121 | this License, whose permissions for other licensees extend to the | ||
122 | entire whole, and thus to each and every part regardless of who wrote it. | ||
123 | |||
124 | Thus, it is not the intent of this section to claim rights or contest | ||
125 | your rights to work written entirely by you; rather, the intent is to | ||
126 | exercise the right to control the distribution of derivative or | ||
127 | collective works based on the Program. | ||
128 | |||
129 | In addition, mere aggregation of another work not based on the Program | ||
130 | with the Program (or with a work based on the Program) on a volume of | ||
131 | a storage or distribution medium does not bring the other work under | ||
132 | the scope of this License. | ||
133 | |||
134 | 3. You may copy and distribute the Program (or a work based on it, | ||
135 | under Section 2) in object code or executable form under the terms of | ||
136 | Sections 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 | |||
155 | The source code for a work means the preferred form of the work for | ||
156 | making modifications to it. For an executable work, complete source | ||
157 | code means all the source code for all modules it contains, plus any | ||
158 | associated interface definition files, plus the scripts used to | ||
159 | control compilation and installation of the executable. However, as a | ||
160 | special exception, the source code distributed need not include | ||
161 | anything that is normally distributed (in either source or binary | ||
162 | form) with the major components (compiler, kernel, and so on) of the | ||
163 | operating system on which the executable runs, unless that component | ||
164 | itself accompanies the executable. | ||
165 | |||
166 | If distribution of executable or object code is made by offering | ||
167 | access to copy from a designated place, then offering equivalent | ||
168 | access to copy the source code from the same place counts as | ||
169 | distribution of the source code, even though third parties are not | ||
170 | compelled to copy the source along with the object code. | ||
171 | |||
172 | 4. You may not copy, modify, sublicense, or distribute the Program | ||
173 | except as expressly provided under this License. Any attempt | ||
174 | otherwise to copy, modify, sublicense or distribute the Program is | ||
175 | void, and will automatically terminate your rights under this License. | ||
176 | However, parties who have received copies, or rights, from you under | ||
177 | this License will not have their licenses terminated so long as such | ||
178 | parties remain in full compliance. | ||
179 | |||
180 | 5. You are not required to accept this License, since you have not | ||
181 | signed it. However, nothing else grants you permission to modify or | ||
182 | distribute the Program or its derivative works. These actions are | ||
183 | prohibited by law if you do not accept this License. Therefore, by | ||
184 | modifying or distributing the Program (or any work based on the | ||
185 | Program), you indicate your acceptance of this License to do so, and | ||
186 | all its terms and conditions for copying, distributing or modifying | ||
187 | the Program or works based on it. | ||
188 | |||
189 | 6. Each time you redistribute the Program (or any work based on the | ||
190 | Program), the recipient automatically receives a license from the | ||
191 | original licensor to copy, distribute or modify the Program subject to | ||
192 | these terms and conditions. You may not impose any further | ||
193 | restrictions on the recipients' exercise of the rights granted herein. | ||
194 | You are not responsible for enforcing compliance by third parties to | ||
195 | this License. | ||
196 | |||
197 | 7. If, as a consequence of a court judgment or allegation of patent | ||
198 | infringement or for any other reason (not limited to patent issues), | ||
199 | conditions are imposed on you (whether by court order, agreement or | ||
200 | otherwise) that contradict the conditions of this License, they do not | ||
201 | excuse you from the conditions of this License. If you cannot | ||
202 | distribute so as to satisfy simultaneously your obligations under this | ||
203 | License and any other pertinent obligations, then as a consequence you | ||
204 | may not distribute the Program at all. For example, if a patent | ||
205 | license would not permit royalty-free redistribution of the Program by | ||
206 | all those who receive copies directly or indirectly through you, then | ||
207 | the only way you could satisfy both it and this License would be to | ||
208 | refrain entirely from distribution of the Program. | ||
209 | |||
210 | If any portion of this section is held invalid or unenforceable under | ||
211 | any particular circumstance, the balance of the section is intended to | ||
212 | apply and the section as a whole is intended to apply in other | ||
213 | circumstances. | ||
214 | |||
215 | It is not the purpose of this section to induce you to infringe any | ||
216 | patents or other property right claims or to contest validity of any | ||
217 | such claims; this section has the sole purpose of protecting the | ||
218 | integrity of the free software distribution system, which is | ||
219 | implemented by public license practices. Many people have made | ||
220 | generous contributions to the wide range of software distributed | ||
221 | through that system in reliance on consistent application of that | ||
222 | system; it is up to the author/donor to decide if he or she is willing | ||
223 | to distribute software through any other system and a licensee cannot | ||
224 | impose that choice. | ||
225 | |||
226 | This section is intended to make thoroughly clear what is believed to | ||
227 | be a consequence of the rest of this License. | ||
228 | |||
229 | 8. If the distribution and/or use of the Program is restricted in | ||
230 | certain countries either by patents or by copyrighted interfaces, the | ||
231 | original copyright holder who places the Program under this License | ||
232 | may add an explicit geographical distribution limitation excluding | ||
233 | those countries, so that distribution is permitted only in or among | ||
234 | countries not thus excluded. In such case, this License incorporates | ||
235 | the limitation as if written in the body of this License. | ||
236 | |||
237 | 9. The Free Software Foundation may publish revised and/or new versions | ||
238 | of the General Public License from time to time. Such new versions will | ||
239 | be similar in spirit to the present version, but may differ in detail to | ||
240 | address new problems or concerns. | ||
241 | |||
242 | Each version is given a distinguishing version number. If the Program | ||
243 | specifies a version number of this License which applies to it and "any | ||
244 | later version", you have the option of following the terms and conditions | ||
245 | either of that version or of any later version published by the Free | ||
246 | Software Foundation. If the Program does not specify a version number of | ||
247 | this License, you may choose any version ever published by the Free Software | ||
248 | Foundation. | ||
249 | |||
250 | 10. If you wish to incorporate parts of the Program into other free | ||
251 | programs whose distribution conditions are different, write to the author | ||
252 | to ask for permission. For software which is copyrighted by the Free | ||
253 | Software Foundation, write to the Free Software Foundation; we sometimes | ||
254 | make exceptions for this. Our decision will be guided by the two goals | ||
255 | of preserving the free status of all derivatives of our free software and | ||
256 | of 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 | ||
261 | FOR THE PROGRAM, TO THE EXTENT PERMITTED BY APPLICABLE LAW. EXCEPT WHEN | ||
262 | OTHERWISE STATED IN WRITING THE COPYRIGHT HOLDERS AND/OR OTHER PARTIES | ||
263 | PROVIDE THE PROGRAM "AS IS" WITHOUT WARRANTY OF ANY KIND, EITHER EXPRESSED | ||
264 | OR IMPLIED, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF | ||
265 | MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE. THE ENTIRE RISK AS | ||
266 | TO THE QUALITY AND PERFORMANCE OF THE PROGRAM IS WITH YOU. SHOULD THE | ||
267 | PROGRAM PROVE DEFECTIVE, YOU ASSUME THE COST OF ALL NECESSARY SERVICING, | ||
268 | REPAIR OR CORRECTION. | ||
269 | |||
270 | 12. IN NO EVENT UNLESS REQUIRED BY APPLICABLE LAW OR AGREED TO IN WRITING | ||
271 | WILL ANY COPYRIGHT HOLDER, OR ANY OTHER PARTY WHO MAY MODIFY AND/OR | ||
272 | REDISTRIBUTE THE PROGRAM AS PERMITTED ABOVE, BE LIABLE TO YOU FOR DAMAGES, | ||
273 | INCLUDING ANY GENERAL, SPECIAL, INCIDENTAL OR CONSEQUENTIAL DAMAGES ARISING | ||
274 | OUT OF THE USE OR INABILITY TO USE THE PROGRAM (INCLUDING BUT NOT LIMITED | ||
275 | TO LOSS OF DATA OR DATA BEING RENDERED INACCURATE OR LOSSES SUSTAINED BY | ||
276 | YOU OR THIRD PARTIES OR A FAILURE OF THE PROGRAM TO OPERATE WITH ANY OTHER | ||
277 | PROGRAMS), EVEN IF SUCH HOLDER OR OTHER PARTY HAS BEEN ADVISED OF THE | ||
278 | POSSIBILITY 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 @@ | |||
1 | Copyright (c) 2013 Ludo van den Boom, http://ludovandenboom.com | ||
2 | |||
3 | Permission is hereby granted, free of charge, to any person obtaining | ||
4 | a copy of this software and associated documentation files (the | ||
5 | "Software"), to deal in the Software without restriction, including | ||
6 | without limitation the rights to use, copy, modify, merge, publish, | ||
7 | distribute, sublicense, and/or sell copies of the Software, and to | ||
8 | permit persons to whom the Software is furnished to do so, subject to | ||
9 | the following conditions: | ||
10 | |||
11 | The above copyright notice and this permission notice shall be | ||
12 | included in all copies or substantial portions of the Software. | ||
13 | |||
14 | THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, | ||
15 | EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF | ||
16 | MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND | ||
17 | NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE | ||
18 | LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION | ||
19 | OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION | ||
20 | WITH 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 | |||
3 | jQuery treetable is a plugin for jQuery, the 'Write Less, Do More, JavaScript | ||
4 | Library'. With this plugin you can display a tree in an HTML table, e.g. a | ||
5 | directory structure or a nested list. Why not use a list, you say? Because lists | ||
6 | are great for displaying a tree, and tables are not. Oh wait, but this plugin | ||
7 | uses tables, doesn't it? Yes. Why do I use a table to display a list? Because I | ||
8 | need multiple columns to display additional data besides the tree. | ||
9 | |||
10 | Download the latest release from the jQuery Plugin Registry or grab the source | ||
11 | code from Github. Please report issues through Github issues. This plugin is | ||
12 | released under both the MIT and the GPLv2 license by Ludo van den Boom. | ||
13 | |||
14 | ## Documentation and Examples | ||
15 | |||
16 | See index.html for technical documentation and examples. The most recent version | ||
17 | of this document is also available online at | ||
18 | http://ludo.cubicphuse.nl/jquery-treetable. An AJAX enabled example built with | ||
19 | Ruby on Rails can be found at | ||
20 | https://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='#'> </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); | ||