diff options
author | Dave Lerner <dave.lerner@windriver.com> | 2014-03-12 16:54:09 -0500 |
---|---|---|
committer | Richard Purdie <richard.purdie@linuxfoundation.org> | 2014-03-21 14:47:53 +0000 |
commit | 4cdd56fff3471669ff2372f0d8bf15f9a287374a (patch) | |
tree | 76b81b2cb87e3b3df9751d8487351b5dfb2c59a3 /bitbake/lib/toaster/toastergui/templates/target.html | |
parent | e94f0b4e8c2cbea92688975b1a45a061af48911e (diff) | |
download | poky-4cdd56fff3471669ff2372f0d8bf15f9a287374a.tar.gz |
bitbake: toaster: image information views
[YOCTO # 4346]
When a target image is selected, this commit adds to the toaster
project a two-tabbed page that shows
1) 'packages included' a table of packages included in the image
(see target.html), and
2) 'directory structure', the target image's file system directory
and detailed information showing the source of each file in the
directory table (see dirinfo.html).
The directory structure tab relies on the open source jQuery plugin
jtreetable which provides hierarchical table expansions and contractions
of the directory entry tables as the user drills down into directories.
A file of jtreetable styles that are compatible with other toaster styles
is provided included as css/jquery.treetable.theme.toaster.css. The
complete unaltered jtreetable plugin is added via a separate commit.
This work was developed base on the bugzilla specification number 4346
and the document "Design 1.1 Image information" attached to that report.
Whitespace and typo fixes from Alex Damian.
(Bitbake rev: 1ba9f310a8b4fd0952a95be86ab43ae27fe6d983)
Signed-off-by: Dave Lerner <dave.lerner@windriver.com>
Signed-off-by: Alexandru DAMIAN <alexandru.damian@intel.com>
Signed-off-by: Richard Purdie <richard.purdie@linuxfoundation.org>
Diffstat (limited to 'bitbake/lib/toaster/toastergui/templates/target.html')
-rw-r--r-- | bitbake/lib/toaster/toastergui/templates/target.html | 153 |
1 files changed, 149 insertions, 4 deletions
diff --git a/bitbake/lib/toaster/toastergui/templates/target.html b/bitbake/lib/toaster/toastergui/templates/target.html index f2d0ad461b..45128986e1 100644 --- a/bitbake/lib/toaster/toastergui/templates/target.html +++ b/bitbake/lib/toaster/toastergui/templates/target.html | |||
@@ -1,8 +1,153 @@ | |||
1 | {% extends "basebuildpage.html" %} | 1 | {% extends "basebuildpage.html" %} |
2 | |||
3 | {% block localbreadcrumb %} | 2 | {% block localbreadcrumb %} |
4 | <li>Target</li> | 3 | <li>{{target.target}}</li> |
5 | {% endblock %} | 4 | {% endblock localbreadcrumb%} |
5 | |||
6 | {% load projecttags %} | ||
6 | 7 | ||
7 | {% block buildinfomain %} | 8 | {% block buildinfomain %} |
8 | {% endblock %} | 9 | |
10 | <div class="row-fluid span10"> | ||
11 | <div class="page-header"> | ||
12 | <h1> | ||
13 | {% if request.GET.search and objects.paginator.count > 0 %} | ||
14 | {{objects.paginator.count}} package{{objects.paginator.count|pluralize}} found | ||
15 | {% elif request.GET.search and objects.paginator.count == 0 %} | ||
16 | No packages found | ||
17 | {% else %} | ||
18 | {{target.target}} | ||
19 | {% endif %} | ||
20 | </h1> | ||
21 | </div> | ||
22 | </div> | ||
23 | |||
24 | <div class="row-fluid pull-right span10" id="navTab"> | ||
25 | <ul class="nav nav-pills"> | ||
26 | <li class="active"> | ||
27 | <a href="#target"> | ||
28 | <i class="icon-question-sign get-help" data-toggle="tooltip" title="Of all the packages built, the subset installed in the root file system of this image"></i> | ||
29 | Packages included ({{target.package_count}} - {{packages_sum|filtered_filesizeformat}}) | ||
30 | </a> | ||
31 | </li> | ||
32 | <li> | ||
33 | <a href="{% url 'dirinfo' build.id target.id %}"> | ||
34 | <i class="icon-question-sign get-help" data-toggle="tooltip" title="The directories and files in the root file system of this image"></i> | ||
35 | Directory structure | ||
36 | </a> | ||
37 | </li> | ||
38 | </ul> | ||
39 | |||
40 | <div id="image-packages" class="tab-pane"> | ||
41 | |||
42 | {% if objects.paginator.count == 0 %} | ||
43 | <div class="row-fluid"> | ||
44 | <div class="alert"> | ||
45 | <form class="no-results input-append" id="searchform"> | ||
46 | <input id="search" name="search" class="input-xxlarge" type="text" value="{{request.GET.search}}"/>{% if request.GET.search %}<a href="javascript:$('#search').val('');searchform.submit()" class="add-on btn" tabindex="-1"><i class="icon-remove"></i></a>{% endif %} | ||
47 | <button class="btn" type="submit" value="Search">Search</button> | ||
48 | <button class="btn btn-link" onclick="javascript:$('#search').val('');searchform.submit()">Show all packages</button> | ||
49 | </form> | ||
50 | </div> | ||
51 | </div> | ||
52 | |||
53 | |||
54 | {% else %} | ||
55 | {% include "basetable_top.html" %} | ||
56 | {% for package in objects %} | ||
57 | <tr> | ||
58 | <td class="package_name"> | ||
59 | <a href="{% url 'package_included_detail' build.id target.id package.id %}"> | ||
60 | {{package.name}} | ||
61 | </a> | ||
62 | {% if package.installed_name and package.name != package.installed_name %} | ||
63 | <span class="muted"> as {{package.installed_name}}</span> | ||
64 | <i class="icon-question-sign get-help hover-help" title='{{package.name|add:" was renamed at packaging time and was installed in your image as "|add:package.installed_name}}'></i> | ||
65 | {% endif %} | ||
66 | </td> | ||
67 | <td class="package_version"> | ||
68 | <a href="{% url 'package_included_detail' build.id target.id package.id %}"> | ||
69 | {{package.version|filtered_packageversion:package.revision}} | ||
70 | </a> | ||
71 | </td> | ||
72 | <td class="package_size"> | ||
73 | {{package.size|filtered_installedsize:package.installed_size|filtered_filesizeformat}} | ||
74 | </td> | ||
75 | <td class="size_over_total"> | ||
76 | {{package|filter_sizeovertotal:packages_sum}} | ||
77 | </td> | ||
78 | <td class="license"> | ||
79 | {{package.license}} | ||
80 | </td> | ||
81 | <td class="depends"> | ||
82 | {% with deps=package|runtime_dependencies:target.id %} | ||
83 | {% with deps_count=deps|length %} | ||
84 | {% if deps_count > 0 %} | ||
85 | <a class="btn" | ||
86 | title="<a href='{% url "package_included_dependencies" build.id target.id package.id %}'>{{package.name}}</a> depends on" | ||
87 | data-content="<ul class='unstyled'> | ||
88 | {% for i in deps|dictsort:'depends_on.name' %} | ||
89 | <li><a href='{% url "package_included_dependencies" build.pk target.id i.depends_on.pk %}'>{{i.depends_on.name}}</a></li> | ||
90 | {% endfor %} | ||
91 | </ul>"> | ||
92 | {{deps_count}} | ||
93 | </a> | ||
94 | {% endif %} | ||
95 | {% endwith %} | ||
96 | {% endwith %} | ||
97 | </td> | ||
98 | <td class="brought_in_by"> | ||
99 | {% with rdeps=package|reverse_runtime_dependencies:target.id %} | ||
100 | {% with rdeps_count=rdeps|length %} | ||
101 | {% if rdeps_count > 0 %} | ||
102 | <a class="btn" | ||
103 | title="<a href='{% url "package_included_reverse_dependencies" build.id target.id package.id %}'>{{package.name}}</a> is brought in by" | ||
104 | data-content="<ul class='unstyled'> | ||
105 | {% for i in rdeps|dictsort:'package.name' %} | ||
106 | <li><a href='{% url "package_included_dependencies" build.id target.id i.package.id %}'>{{i.package.name}}</a></li> | ||
107 | {% endfor %} | ||
108 | </ul>"> | ||
109 | {{rdeps_count}} | ||
110 | </a> | ||
111 | {% endif %} | ||
112 | {% endwith %} | ||
113 | {% endwith %} | ||
114 | </td> | ||
115 | <td class="recipe_name"> | ||
116 | {% if package.recipe.version %} | ||
117 | <a href="{% url 'recipe' build.id package.recipe_id %}"> | ||
118 | {{ package.recipe.name }} | ||
119 | </a> | ||
120 | {% endif %} | ||
121 | </td> | ||
122 | <td class="recipe_version"> | ||
123 | {% if package.recipe.version %} | ||
124 | <a href="{% url 'recipe' build.id package.recipe_id %}"> | ||
125 | {{ package.recipe.version }} | ||
126 | </a> | ||
127 | {% endif %} | ||
128 | </td> | ||
129 | <td class="layer_name"> | ||
130 | {{ package.recipe.layer_version.layer.name }} | ||
131 | </td> | ||
132 | <td class="layer_branch"> | ||
133 | {{ package.recipe.layer_version.branch}} | ||
134 | </td> | ||
135 | <td class="layer_commit"> | ||
136 | <a class="btn" | ||
137 | data-content="<ul class='unstyled'> | ||
138 | <li>{{package.recipe.layer_version.commit}}</li> | ||
139 | </ul>"> | ||
140 | {{package.recipe.layer_version.commit|truncatechars:13}} | ||
141 | </a> | ||
142 | </td> | ||
143 | <td class="layer_directory"> | ||
144 | {{ package.recipe.layer_version.layer.local_path }} | ||
145 | </td> | ||
146 | </tr> | ||
147 | {% endfor %} | ||
148 | |||
149 | {% include "basetable_bottom.html" %} | ||
150 | {% endif %} | ||
151 | </div> <!-- tabpane --> | ||
152 | </div> <!--span 10--> | ||
153 | {% endblock buildinfomain %} | ||