summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorFarrell Wymore <farrell.wymore@windriver.com>2014-05-21 15:15:08 +0100
committerRichard Purdie <richard.purdie@linuxfoundation.org>2014-05-21 16:47:01 +0100
commitdefe2271350c36605704129f4a6b9332446a1319 (patch)
tree36fc9a72b47733f542ed90e47f80a0b692bc44ab
parent8a8d7176fc830ec48248929e2ab79501dd2a2422 (diff)
downloadpoky-defe2271350c36605704129f4a6b9332446a1319.tar.gz
bitbake: toaster: sort columns properly after edit columns
If a sorted column is made invisible through the edit columns function, resort the table the its default order. [YOCTO 5919] (Bitbake rev: 64618f7489eb9eb13a97d03cd2d353384f5faa70) Signed-off-by: Farrell Wymore <farrell.wymore@windriver.com> Signed-off-by: Richard Purdie <richard.purdie@linuxfoundation.org>
-rw-r--r--bitbake/lib/toaster/toastergui/templates/basetable_top.html172
-rw-r--r--bitbake/lib/toaster/toastergui/views.py46
2 files changed, 204 insertions, 14 deletions
diff --git a/bitbake/lib/toaster/toastergui/templates/basetable_top.html b/bitbake/lib/toaster/toastergui/templates/basetable_top.html
index 22c389799a..1231e1f924 100644
--- a/bitbake/lib/toaster/toastergui/templates/basetable_top.html
+++ b/bitbake/lib/toaster/toastergui/templates/basetable_top.html
@@ -1,17 +1,42 @@
1{% load projecttags %} 1{% load projecttags %}
2<!-- component to display a generic table --> 2<!-- component to display a generic table -->
3 <script> 3 <script>
4 function showhideTableColumn(clname, sh) {
5 if (sh) $('.' + clname).show(100);
6 else $('.' + clname).hide(100);
7 4
8 // save cookie for all checkboxes 5 //
9 save = ''; 6 // most of the following javascript is for managing the 'Edit Columns'
10 $('.chbxtoggle').each(function() { if ($(this).attr('id') != undefined) { save += ';' + $(this).attr('id') +':'+ $(this).is(':checked')} }) 7 // pop-up dialog and actions. the idea is that there are 2 types
11 $.cookie('_displaycols_{{objectname}}', save); 8 // of actions: immediate - performed while the dialog is still
12 save = ''; 9 // visible - hide/show columns, and delayed - performed when the
13 } 10 // dialog becomes invisible - any resorting if necessary.
11 //
12 // When the dialog is open, an interval timer is set up to
13 // determine if the dialog is still visible. when the dialog
14 // closes - goes invisible, the delayed actions are performed.
15 //
16 // the interval timer and interrupt handler is a way of simulating
17 // an onclose event. there is probably a simpler way to do this
18 // however the pop-up window id was elusive.
19 //
20
21 var editColTimer;
22 var editColAction;
14 23
24 //
25 // this is the target function of the interval timeout.
26 // check to see if the dialog is visible. if the dialog
27 // has gone invisible since the last check, take any delayed
28 // actions indicated in the action list and clear the timer.
29 //
30
31 function checkVisible( ) {
32 editcol = document.getElementById( 'editcol' );
33 if ( editcol.offsetWidth <= 0 ) {
34 clearInterval( editColTimer );
35 editColTimer = false;
36 hideshowColumns( );
37 editColAction = [ ];
38 }
39 }
15 40
16 function filterTableRows(test) { 41 function filterTableRows(test) {
17 if (test.length > 0) { 42 if (test.length > 0) {
@@ -24,6 +49,113 @@
24 $('tr.data').show(); 49 $('tr.data').show();
25 } 50 }
26 } 51 }
52
53 //
54 // determine the value of the indicated url arg.
55 // this is needed to determine whether a resort
56 // is necessary. it looks like a lot of gorp stuff
57 // but its actually pretty simple.
58 //
59
60 function getURLParameter( name ) {
61 return decodeURIComponent((new RegExp('[?|&]' + name + '=' +
62 '([^&;]+?)(&|#|;|$)').exec(location.search)||[,""])[1].replace(/\+/g,
63 '%20'))||null
64 }
65
66 //
67 // when the dialog box goes invisible
68 // this function is called to interpret
69 // the action list and take any delayed actions necessary.
70 // the editColAction list is a hash table with
71 // the column name as the hash key, the hash value
72 // is a 2 element list. the first element is a flag
73 // indicating whether the column is on or off. the
74 // 2nd element is the sort order indicator for the column.
75 //
76
77 function hideshowColumns( ) {
78 for( var k in editColAction ) {
79 showhideDelayedTableAction( k, editColAction[ k ][ 0 ], editColAction[ k ][ 1 ]);
80 }
81 }
82
83 //
84 // this function actually performs the delayed table actions
85 // namely any resorting if necessary
86 //
87
88 function showhideDelayedTableAction( clname, sh, orderkey ) {
89 if ( !sh ) {
90 p = getURLParameter( "orderby" ).split( ":" )[ 0 ];
91 if ( p == orderkey ) {
92 reload_params({ 'orderby' : '{{default_orderby}}'});
93 }
94 }
95 }
96
97 //
98 // this function actually performs the immediate table actions
99 // namely any colums that need to be hidden/shown
100 //
101
102 function showhideImmediateTableAction( clname, sh, orderkey ) {
103 if ( sh ) {
104 $( '.' + clname ).show( 100 );
105 }
106 else {
107 $( '.' + clname ).hide( 100 );
108 }
109
110 // save cookie for all checkboxes
111 save = '';
112 $( '.chbxtoggle' ).each(function( ) {
113 if ( $( this ).attr( 'id' ) != undefined ) {
114 save += ';' + $( this ).attr( 'id' ) +':'+ $( this ).is( ':checked' )
115 }
116 });
117 $.cookie( '_displaycols_{{objectname}}', save );
118 save = '';
119 }
120
121 //
122 // this is the onclick handler for all of the check box
123 // items in edit columns dialog
124 //
125
126 function showhideTableColumn( clname, sh, orderkey ) {
127 editcol = document.getElementById( 'editcol' );
128 if ( editcol.offsetWidth <= 0 ) {
129
130 //
131 // this path is taken when the page is first
132 // getting initialized - no dialog visible,
133 // perform both the immediate and delayed actions
134 //
135
136 showhideImmediateTableAction( clname, sh, orderkey );
137 showhideDelayedTableAction( clname, sh, orderkey );
138 return;
139 }
140 if ( !editColTimer ) {
141
142 //
143 // we don't have a timer active so set one up
144 // and clear the action list
145 //
146
147 editColTimer = setInterval( checkVisible, 250 );
148 editColAction = [ ];
149 }
150
151 //
152 // save the action to be taken when the dialog closes
153 //
154
155 editColAction[ clname ] = [ sh, orderkey ];
156 showhideImmediateTableAction( clname, sh, orderkey );
157 }
158
27 </script> 159 </script>
28 160
29<!-- control header --> 161<!-- control header -->
@@ -33,7 +165,6 @@
33 <input class="input-xxlarge" id="search" name="search" type="text" placeholder="Search {%if object_search_display %}{{object_search_display}}{%else%}{{objectname}}{%endif%}" 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%} 165 <input class="input-xxlarge" id="search" name="search" type="text" placeholder="Search {%if object_search_display %}{{object_search_display}}{%else%}{{objectname}}{%endif%}" 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%}
34 <input type="hidden" name="orderby" value="{{request.GET.orderby}}"> 166 <input type="hidden" name="orderby" value="{{request.GET.orderby}}">
35 <input type="hidden" name="page" value="1"> 167 <input type="hidden" name="page" value="1">
36 <input type="hidden" name="count" value="{{request.GET.count}}">
37 <button class="btn" type="submit" value="Search">Search</button> 168 <button class="btn" type="submit" value="Search">Search</button>
38 </form> 169 </form>
39 <div class="pull-right"> 170 <div class="pull-right">
@@ -45,12 +176,27 @@
45<!-- 176<!--
46 {{tablecols|sortcols}} 177 {{tablecols|sortcols}}
47--> 178-->
48 <ul class="dropdown-menu">{% for i in tablecols|sortcols %} 179 <ul id='editcol' class="dropdown-menu">
180 {% for i in tablecols|sortcols %}
49 <li> 181 <li>
50 <label {% if not i.clclass %} class="checkbox muted" {%else%} class="checkbox" {%endif%}> 182 <label {% if not i.clclass %} class="checkbox muted" {%else%} class="checkbox" {%endif%}>
51 <input type="checkbox" class="chbxtoggle" {% if i.clclass %}id="{{i.clclass}}" value="ct{{i.name}}" {% if not i.hidden %}checked="checked"{%endif%} onchange="showhideTableColumn($(this).attr('id'), $(this).is(':checked'))" {%else%} checked disabled {% endif %}/> {{i.name}} 183 <input type="checkbox" class="chbxtoggle"
184 {% if i.clclass %}
185 id="{{i.clclass}}"
186 value="ct{{i.name}}"
187 {% if not i.hidden %}
188 checked="checked"
189 {%endif%}
190 onclick="showhideTableColumn(
191 $(this).attr('id'),
192 $(this).is(':checked'),
193 '{{i.orderkey}}' )"
194 {%else%}
195 checked disabled
196 {% endif %}/> {{i.name}}
52 </label> 197 </label>
53 </li>{% endfor %} 198 </li>
199 {% endfor %}
54 </ul> 200 </ul>
55 </div> 201 </div>
56{% endif %} 202{% endif %}
diff --git a/bitbake/lib/toaster/toastergui/views.py b/bitbake/lib/toaster/toastergui/views.py
index e3b24bace3..4622810cf9 100644
--- a/bitbake/lib/toaster/toastergui/views.py
+++ b/bitbake/lib/toaster/toastergui/views.py
@@ -262,6 +262,7 @@ def builds(request):
262 # TODO: common objects for all table views, adapt as needed 262 # TODO: common objects for all table views, adapt as needed
263 'objects' : build_info, 263 'objects' : build_info,
264 'objectname' : "builds", 264 'objectname' : "builds",
265 'default_orderby' : 'completed_on:-',
265 'fstypes' : fstypes_map, 266 'fstypes' : fstypes_map,
266 'search_term' : search_term, 267 'search_term' : search_term,
267 'total_count' : queryset_with_search.count(), 268 'total_count' : queryset_with_search.count(),
@@ -311,6 +312,7 @@ def builds(request):
311 'qhelp': "The date and time the build finished", 312 'qhelp': "The date and time the build finished",
312 'orderfield': _get_toggle_order(request, "completed_on", True), 313 'orderfield': _get_toggle_order(request, "completed_on", True),
313 'ordericon':_get_toggle_order_icon(request, "completed_on"), 314 'ordericon':_get_toggle_order_icon(request, "completed_on"),
315 'orderkey' : 'completed_on',
314 'filter' : {'class' : 'completed_on', 316 'filter' : {'class' : 'completed_on',
315 'label': 'Show:', 317 'label': 'Show:',
316 'options' : [ 318 'options' : [
@@ -334,6 +336,7 @@ def builds(request):
334 'qhelp': "How many errors were encountered during the build (if any)", 336 'qhelp': "How many errors were encountered during the build (if any)",
335 'orderfield': _get_toggle_order(request, "errors_no", True), 337 'orderfield': _get_toggle_order(request, "errors_no", True),
336 'ordericon':_get_toggle_order_icon(request, "errors_no"), 338 'ordericon':_get_toggle_order_icon(request, "errors_no"),
339 'orderkey' : 'errors_no',
337 'filter' : {'class' : 'errors_no', 340 'filter' : {'class' : 'errors_no',
338 'label': 'Show:', 341 'label': 'Show:',
339 'options' : [ 342 'options' : [
@@ -346,6 +349,7 @@ def builds(request):
346 'qhelp': "How many warnings were encountered during the build (if any)", 349 'qhelp': "How many warnings were encountered during the build (if any)",
347 'orderfield': _get_toggle_order(request, "warnings_no", True), 350 'orderfield': _get_toggle_order(request, "warnings_no", True),
348 'ordericon':_get_toggle_order_icon(request, "warnings_no"), 351 'ordericon':_get_toggle_order_icon(request, "warnings_no"),
352 'orderkey' : 'warnings_no',
349 'filter' : {'class' : 'warnings_no', 353 'filter' : {'class' : 'warnings_no',
350 'label': 'Show:', 354 'label': 'Show:',
351 'options' : [ 355 'options' : [
@@ -358,6 +362,7 @@ def builds(request):
358 'qhelp': "How long it took the build to finish", 362 'qhelp': "How long it took the build to finish",
359 'orderfield': _get_toggle_order(request, "timespent", True), 363 'orderfield': _get_toggle_order(request, "timespent", True),
360 'ordericon':_get_toggle_order_icon(request, "timespent"), 364 'ordericon':_get_toggle_order_icon(request, "timespent"),
365 'orderkey' : 'timespent',
361 }, 366 },
362 {'name': 'Log', 367 {'name': 'Log',
363 'dclass': "span4", 368 'dclass': "span4",
@@ -365,6 +370,7 @@ def builds(request):
365 'clclass': 'log', 'hidden': 1, 370 'clclass': 'log', 'hidden': 1,
366 'orderfield': _get_toggle_order(request, "cooker_log_path"), 371 'orderfield': _get_toggle_order(request, "cooker_log_path"),
367 'ordericon':_get_toggle_order_icon(request, "cooker_log_path"), 372 'ordericon':_get_toggle_order_icon(request, "cooker_log_path"),
373 'orderkey' : 'cooker_log_path',
368 }, 374 },
369 {'name': 'Output', 'clclass': 'output', 375 {'name': 'Output', 'clclass': 'output',
370 'qhelp': "The root file system types produced by the build. You can find them in your <code>/build/tmp/deploy/images/</code> directory", 376 'qhelp': "The root file system types produced by the build. You can find them in your <code>/build/tmp/deploy/images/</code> directory",
@@ -502,7 +508,7 @@ def task( request, build_id, task_id ):
502 'log_head' : log_head, 508 'log_head' : log_head,
503 'log_body' : log_body, 509 'log_body' : log_body,
504 'showing_matches' : False, 510 'showing_matches' : False,
505 'uri_list' : uri_list, 511 'uri_list' : uri_list,
506 } 512 }
507 if request.GET.get( 'show_matches', "" ): 513 if request.GET.get( 'show_matches', "" ):
508 context[ 'showing_matches' ] = True 514 context[ 'showing_matches' ] = True
@@ -559,6 +565,7 @@ def target(request, build_id, target_id):
559 'objects': packages, 565 'objects': packages,
560 'packages_sum' : packages_sum['installed_size__sum'], 566 'packages_sum' : packages_sum['installed_size__sum'],
561 'object_search_display': "packages included", 567 'object_search_display': "packages included",
568 'default_orderby' : 'name:+',
562 'tablecols':[ 569 'tablecols':[
563 { 570 {
564 'name':'Package', 571 'name':'Package',
@@ -575,6 +582,7 @@ def target(request, build_id, target_id):
575 'qhelp':'The size of the package', 582 'qhelp':'The size of the package',
576 'orderfield': _get_toggle_order(request, "size", True), 583 'orderfield': _get_toggle_order(request, "size", True),
577 'ordericon':_get_toggle_order_icon(request, "size"), 584 'ordericon':_get_toggle_order_icon(request, "size"),
585 'orderkey' : 'size',
578 'clclass': 'size', 586 'clclass': 'size',
579 'dclass' : 'span2', 587 'dclass' : 'span2',
580 'hidden' : 0, 588 'hidden' : 0,
@@ -582,6 +590,7 @@ def target(request, build_id, target_id):
582 { 590 {
583 'name':'Size over total (%)', 591 'name':'Size over total (%)',
584 'qhelp':'Proportion of the overall included package size represented by this package', 592 'qhelp':'Proportion of the overall included package size represented by this package',
593 'orderkey' : 'size',
585 'clclass': 'size_over_total', 594 'clclass': 'size_over_total',
586 'dclass' : 'span2', 595 'dclass' : 'span2',
587 'hidden' : 1, 596 'hidden' : 1,
@@ -591,6 +600,7 @@ def target(request, build_id, target_id):
591 'qhelp':'The license under which the package is distributed. Multiple license names separated by the pipe character indicates a choice between licenses. Multiple license names separated by the ampersand character indicates multiple licenses exist that cover different parts of the source', 600 'qhelp':'The license under which the package is distributed. Multiple license names separated by the pipe character indicates a choice between licenses. Multiple license names separated by the ampersand character indicates multiple licenses exist that cover different parts of the source',
592 'orderfield': _get_toggle_order(request, "license"), 601 'orderfield': _get_toggle_order(request, "license"),
593 'ordericon':_get_toggle_order_icon(request, "license"), 602 'ordericon':_get_toggle_order_icon(request, "license"),
603 'orderkey' : 'license',
594 'clclass': 'license', 604 'clclass': 'license',
595 'hidden' : 1, 605 'hidden' : 1,
596 }, 606 },
@@ -611,6 +621,7 @@ def target(request, build_id, target_id):
611 'qhelp':'The name of the recipe building the package', 621 'qhelp':'The name of the recipe building the package',
612 'orderfield': _get_toggle_order(request, "recipe__name"), 622 'orderfield': _get_toggle_order(request, "recipe__name"),
613 'ordericon':_get_toggle_order_icon(request, "recipe__name"), 623 'ordericon':_get_toggle_order_icon(request, "recipe__name"),
624 'orderkey' : 'recipe__name',
614 'clclass': 'recipe_name', 625 'clclass': 'recipe_name',
615 'hidden' : 0, 626 'hidden' : 0,
616 }, 627 },
@@ -625,6 +636,7 @@ def target(request, build_id, target_id):
625 'qhelp':'The name of the layer providing the recipe that builds the package', 636 'qhelp':'The name of the layer providing the recipe that builds the package',
626 'orderfield': _get_toggle_order(request, "recipe__layer_version__layer__name"), 637 'orderfield': _get_toggle_order(request, "recipe__layer_version__layer__name"),
627 'ordericon':_get_toggle_order_icon(request, "recipe__layer_version__layer__name"), 638 'ordericon':_get_toggle_order_icon(request, "recipe__layer_version__layer__name"),
639 'orderkey' : 'recipe__layer_version__layer__name',
628 'clclass': 'layer_name', 640 'clclass': 'layer_name',
629 'hidden' : 1, 641 'hidden' : 1,
630 }, 642 },
@@ -633,6 +645,7 @@ def target(request, build_id, target_id):
633 'qhelp':'The Git branch of the layer providing the recipe that builds the package', 645 'qhelp':'The Git branch of the layer providing the recipe that builds the package',
634 'orderfield': _get_toggle_order(request, "recipe__layer_version__branch"), 646 'orderfield': _get_toggle_order(request, "recipe__layer_version__branch"),
635 'ordericon':_get_toggle_order_icon(request, "recipe__layer_version__branch"), 647 'ordericon':_get_toggle_order_icon(request, "recipe__layer_version__branch"),
648 'orderkey' : 'recipe__layer_version__branch',
636 'clclass': 'layer_branch', 649 'clclass': 'layer_branch',
637 'hidden' : 1, 650 'hidden' : 1,
638 }, 651 },
@@ -830,21 +843,25 @@ def tasks_common(request, build_id, variant, task_anchor):
830 object_search_display="time data" 843 object_search_display="time data"
831 filter_search_display="tasks" 844 filter_search_display="tasks"
832 mandatory_parameters = { 'count': 25, 'page' : 1, 'orderby':'elapsed_time:-'}; 845 mandatory_parameters = { 'count': 25, 'page' : 1, 'orderby':'elapsed_time:-'};
846 default_orderby = 'elapsed_time:-';
833 elif 'diskio' == variant: 847 elif 'diskio' == variant:
834 title_variant='Disk I/O' 848 title_variant='Disk I/O'
835 object_search_display="disk I/O data" 849 object_search_display="disk I/O data"
836 filter_search_display="tasks" 850 filter_search_display="tasks"
837 mandatory_parameters = { 'count': 25, 'page' : 1, 'orderby':'disk_io:-'}; 851 mandatory_parameters = { 'count': 25, 'page' : 1, 'orderby':'disk_io:-'};
852 default_orderby = 'disk_io:-';
838 elif 'cpuusage' == variant: 853 elif 'cpuusage' == variant:
839 title_variant='CPU usage' 854 title_variant='CPU usage'
840 object_search_display="CPU usage data" 855 object_search_display="CPU usage data"
841 filter_search_display="tasks" 856 filter_search_display="tasks"
842 mandatory_parameters = { 'count': 25, 'page' : 1, 'orderby':'cpu_usage:-'}; 857 mandatory_parameters = { 'count': 25, 'page' : 1, 'orderby':'cpu_usage:-'};
858 default_orderby = 'cpu_usage:-';
843 else : 859 else :
844 title_variant='Tasks' 860 title_variant='Tasks'
845 object_search_display="tasks" 861 object_search_display="tasks"
846 filter_search_display="tasks" 862 filter_search_display="tasks"
847 mandatory_parameters = { 'count': 25, 'page' : 1, 'orderby':'order:+'}; 863 mandatory_parameters = { 'count': 25, 'page' : 1, 'orderby':'order:+'};
864 default_orderby = 'order:+';
848 865
849 template = 'tasks.html' 866 template = 'tasks.html'
850 retval = _verify_parameters( request.GET, mandatory_parameters ) 867 retval = _verify_parameters( request.GET, mandatory_parameters )
@@ -886,12 +903,14 @@ def tasks_common(request, build_id, variant, task_anchor):
886 'name':'Order', 903 'name':'Order',
887 'qhelp':'The running sequence of each task in the build', 904 'qhelp':'The running sequence of each task in the build',
888 'clclass': 'order', 'hidden' : 1, 905 'clclass': 'order', 'hidden' : 1,
906 'orderkey' : 'order',
889 'orderfield':_get_toggle_order(request, "order"), 907 'orderfield':_get_toggle_order(request, "order"),
890 'ordericon':_get_toggle_order_icon(request, "order")} 908 'ordericon':_get_toggle_order_icon(request, "order")}
891 if 'tasks' == variant: tc_order['hidden']='0'; del tc_order['clclass'] 909 if 'tasks' == variant: tc_order['hidden']='0'; del tc_order['clclass']
892 tc_recipe={ 910 tc_recipe={
893 'name':'Recipe', 911 'name':'Recipe',
894 'qhelp':'The name of the recipe to which each task applies', 912 'qhelp':'The name of the recipe to which each task applies',
913 'orderkey' : 'recipe__name',
895 'orderfield': _get_toggle_order(request, "recipe__name"), 914 'orderfield': _get_toggle_order(request, "recipe__name"),
896 'ordericon':_get_toggle_order_icon(request, "recipe__name"), 915 'ordericon':_get_toggle_order_icon(request, "recipe__name"),
897 } 916 }
@@ -905,6 +924,7 @@ def tasks_common(request, build_id, variant, task_anchor):
905 'qhelp':'The name of the task', 924 'qhelp':'The name of the task',
906 'orderfield': _get_toggle_order(request, "task_name"), 925 'orderfield': _get_toggle_order(request, "task_name"),
907 'ordericon':_get_toggle_order_icon(request, "task_name"), 926 'ordericon':_get_toggle_order_icon(request, "task_name"),
927 'orderkey' : 'task_name',
908 } 928 }
909 tc_executed={ 929 tc_executed={
910 'name':'Executed', 930 'name':'Executed',
@@ -912,6 +932,7 @@ def tasks_common(request, build_id, variant, task_anchor):
912 'clclass': 'executed', 'hidden' : 0, 932 'clclass': 'executed', 'hidden' : 0,
913 'orderfield': _get_toggle_order(request, "task_executed"), 933 'orderfield': _get_toggle_order(request, "task_executed"),
914 'ordericon':_get_toggle_order_icon(request, "task_executed"), 934 'ordericon':_get_toggle_order_icon(request, "task_executed"),
935 'orderkey' : 'task_executed',
915 'filter' : { 936 'filter' : {
916 'class' : 'executed', 937 'class' : 'executed',
917 'label': 'Show:', 938 'label': 'Show:',
@@ -928,6 +949,7 @@ def tasks_common(request, build_id, variant, task_anchor):
928 'clclass': 'outcome', 'hidden' : 0, 949 'clclass': 'outcome', 'hidden' : 0,
929 'orderfield': _get_toggle_order(request, "outcome"), 950 'orderfield': _get_toggle_order(request, "outcome"),
930 'ordericon':_get_toggle_order_icon(request, "outcome"), 951 'ordericon':_get_toggle_order_icon(request, "outcome"),
952 'orderkey' : 'outcome',
931 'filter' : { 953 'filter' : {
932 'class' : 'outcome', 954 'class' : 'outcome',
933 'label': 'Show:', 955 'label': 'Show:',
@@ -947,6 +969,7 @@ def tasks_common(request, build_id, variant, task_anchor):
947 'qhelp':'Path to the task log file', 969 'qhelp':'Path to the task log file',
948 'orderfield': _get_toggle_order(request, "logfile"), 970 'orderfield': _get_toggle_order(request, "logfile"),
949 'ordericon':_get_toggle_order_icon(request, "logfile"), 971 'ordericon':_get_toggle_order_icon(request, "logfile"),
972 'orderkey' : 'logfile',
950 'clclass': 'task_log', 'hidden' : 1, 973 'clclass': 'task_log', 'hidden' : 1,
951 } 974 }
952 tc_cache={ 975 tc_cache={
@@ -955,6 +978,7 @@ def tasks_common(request, build_id, variant, task_anchor):
955 'clclass': 'cache_attempt', 'hidden' : 0, 978 'clclass': 'cache_attempt', 'hidden' : 0,
956 'orderfield': _get_toggle_order(request, "sstate_result"), 979 'orderfield': _get_toggle_order(request, "sstate_result"),
957 'ordericon':_get_toggle_order_icon(request, "sstate_result"), 980 'ordericon':_get_toggle_order_icon(request, "sstate_result"),
981 'orderkey' : 'sstate_result',
958 'filter' : { 982 'filter' : {
959 'class' : 'cache_attempt', 983 'class' : 'cache_attempt',
960 'label': 'Show:', 984 'label': 'Show:',
@@ -973,6 +997,7 @@ def tasks_common(request, build_id, variant, task_anchor):
973 'qhelp':'How long it took the task to finish in seconds', 997 'qhelp':'How long it took the task to finish in seconds',
974 'orderfield': _get_toggle_order(request, "elapsed_time", True), 998 'orderfield': _get_toggle_order(request, "elapsed_time", True),
975 'ordericon':_get_toggle_order_icon(request, "elapsed_time"), 999 'ordericon':_get_toggle_order_icon(request, "elapsed_time"),
1000 'orderkey' : 'elapsed_time',
976 'clclass': 'time_taken', 'hidden' : 1, 1001 'clclass': 'time_taken', 'hidden' : 1,
977 } 1002 }
978 if 'buildtime' == variant: tc_time['hidden']='0'; del tc_time['clclass']; tc_cache['hidden']='1'; 1003 if 'buildtime' == variant: tc_time['hidden']='0'; del tc_time['clclass']; tc_cache['hidden']='1';
@@ -981,6 +1006,7 @@ def tasks_common(request, build_id, variant, task_anchor):
981 'qhelp':'The percentage of task CPU utilization', 1006 'qhelp':'The percentage of task CPU utilization',
982 'orderfield': _get_toggle_order(request, "cpu_usage", True), 1007 'orderfield': _get_toggle_order(request, "cpu_usage", True),
983 'ordericon':_get_toggle_order_icon(request, "cpu_usage"), 1008 'ordericon':_get_toggle_order_icon(request, "cpu_usage"),
1009 'orderkey' : 'cpu_usage',
984 'clclass': 'cpu_used', 'hidden' : 1, 1010 'clclass': 'cpu_used', 'hidden' : 1,
985 } 1011 }
986 if 'cpuusage' == variant: tc_cpu['hidden']='0'; del tc_cpu['clclass']; tc_cache['hidden']='1'; 1012 if 'cpuusage' == variant: tc_cpu['hidden']='0'; del tc_cpu['clclass']; tc_cache['hidden']='1';
@@ -989,6 +1015,7 @@ def tasks_common(request, build_id, variant, task_anchor):
989 'qhelp':'Number of miliseconds the task spent doing disk input and output', 1015 'qhelp':'Number of miliseconds the task spent doing disk input and output',
990 'orderfield': _get_toggle_order(request, "disk_io", True), 1016 'orderfield': _get_toggle_order(request, "disk_io", True),
991 'ordericon':_get_toggle_order_icon(request, "disk_io"), 1017 'ordericon':_get_toggle_order_icon(request, "disk_io"),
1018 'orderkey' : 'disk_io',
992 'clclass': 'disk_io', 'hidden' : 1, 1019 'clclass': 'disk_io', 'hidden' : 1,
993 } 1020 }
994 if 'diskio' == variant: tc_diskio['hidden']='0'; del tc_diskio['clclass']; tc_cache['hidden']='1'; 1021 if 'diskio' == variant: tc_diskio['hidden']='0'; del tc_diskio['clclass']; tc_cache['hidden']='1';
@@ -1000,6 +1027,7 @@ def tasks_common(request, build_id, variant, task_anchor):
1000 'title': title_variant, 1027 'title': title_variant,
1001 'build': Build.objects.filter(pk=build_id)[0], 1028 'build': Build.objects.filter(pk=build_id)[0],
1002 'objects': tasks, 1029 'objects': tasks,
1030 'default_orderby' : default_orderby,
1003 'search_term': search_term, 1031 'search_term': search_term,
1004 'total_count': queryset_with_search.count(), 1032 'total_count': queryset_with_search.count(),
1005 'tablecols':[ 1033 'tablecols':[
@@ -1050,6 +1078,7 @@ def recipes(request, build_id):
1050 'objectname': 'recipes', 1078 'objectname': 'recipes',
1051 'build': Build.objects.filter(pk=build_id)[0], 1079 'build': Build.objects.filter(pk=build_id)[0],
1052 'objects': recipes, 1080 'objects': recipes,
1081 'default_orderby' : 'name:+',
1053 'tablecols':[ 1082 'tablecols':[
1054 { 1083 {
1055 'name':'Recipe', 1084 'name':'Recipe',
@@ -1076,6 +1105,7 @@ def recipes(request, build_id):
1076 'qhelp':'Path to the recipe .bb file', 1105 'qhelp':'Path to the recipe .bb file',
1077 'orderfield': _get_toggle_order(request, "file_path"), 1106 'orderfield': _get_toggle_order(request, "file_path"),
1078 'ordericon':_get_toggle_order_icon(request, "file_path"), 1107 'ordericon':_get_toggle_order_icon(request, "file_path"),
1108 'orderkey' : 'file_path',
1079 'clclass': 'recipe_file', 'hidden': 0, 1109 'clclass': 'recipe_file', 'hidden': 0,
1080 }, 1110 },
1081 { 1111 {
@@ -1083,6 +1113,7 @@ def recipes(request, build_id):
1083 'qhelp':'The section in which recipes should be categorized', 1113 'qhelp':'The section in which recipes should be categorized',
1084 'orderfield': _get_toggle_order(request, "section"), 1114 'orderfield': _get_toggle_order(request, "section"),
1085 'ordericon':_get_toggle_order_icon(request, "section"), 1115 'ordericon':_get_toggle_order_icon(request, "section"),
1116 'orderkey' : 'section',
1086 'clclass': 'recipe_section', 'hidden': 0, 1117 'clclass': 'recipe_section', 'hidden': 0,
1087 }, 1118 },
1088 { 1119 {
@@ -1090,6 +1121,7 @@ def recipes(request, build_id):
1090 'qhelp':'The list of source licenses for the recipe. Multiple license names separated by the pipe character indicates a choice between licenses. Multiple license names separated by the ampersand character indicates multiple licenses exist that cover different parts of the source', 1121 'qhelp':'The list of source licenses for the recipe. Multiple license names separated by the pipe character indicates a choice between licenses. Multiple license names separated by the ampersand character indicates multiple licenses exist that cover different parts of the source',
1091 'orderfield': _get_toggle_order(request, "license"), 1122 'orderfield': _get_toggle_order(request, "license"),
1092 'ordericon':_get_toggle_order_icon(request, "license"), 1123 'ordericon':_get_toggle_order_icon(request, "license"),
1124 'orderkey' : 'license',
1093 'clclass': 'recipe_license', 'hidden': 0, 1125 'clclass': 'recipe_license', 'hidden': 0,
1094 }, 1126 },
1095 { 1127 {
@@ -1097,6 +1129,7 @@ def recipes(request, build_id):
1097 'qhelp':'The name of the layer providing the recipe', 1129 'qhelp':'The name of the layer providing the recipe',
1098 'orderfield': _get_toggle_order(request, "layer_version__layer__name"), 1130 'orderfield': _get_toggle_order(request, "layer_version__layer__name"),
1099 'ordericon':_get_toggle_order_icon(request, "layer_version__layer__name"), 1131 'ordericon':_get_toggle_order_icon(request, "layer_version__layer__name"),
1132 'orderkey' : 'layer_version__layer__name',
1100 'clclass': 'layer_version__layer__name', 'hidden': 0, 1133 'clclass': 'layer_version__layer__name', 'hidden': 0,
1101 }, 1134 },
1102 { 1135 {
@@ -1104,6 +1137,7 @@ def recipes(request, build_id):
1104 'qhelp':'The Git branch of the layer providing the recipe', 1137 'qhelp':'The Git branch of the layer providing the recipe',
1105 'orderfield': _get_toggle_order(request, "layer_version__branch"), 1138 'orderfield': _get_toggle_order(request, "layer_version__branch"),
1106 'ordericon':_get_toggle_order_icon(request, "layer_version__branch"), 1139 'ordericon':_get_toggle_order_icon(request, "layer_version__branch"),
1140 'orderkey' : 'layer_version__branch',
1107 'clclass': 'layer_version__branch', 'hidden': 1, 1141 'clclass': 'layer_version__branch', 'hidden': 1,
1108 }, 1142 },
1109 { 1143 {
@@ -1116,6 +1150,7 @@ def recipes(request, build_id):
1116 'qhelp':'Path to the layer prodiving the recipe', 1150 'qhelp':'Path to the layer prodiving the recipe',
1117 'orderfield': _get_toggle_order(request, "layer_version__layer__local_path"), 1151 'orderfield': _get_toggle_order(request, "layer_version__layer__local_path"),
1118 'ordericon':_get_toggle_order_icon(request, "layer_version__layer__local_path"), 1152 'ordericon':_get_toggle_order_icon(request, "layer_version__layer__local_path"),
1153 'orderkey' : 'layer_version__layer__local_path',
1119 'clclass': 'layer_version__layer__local_path', 'hidden': 1, 1154 'clclass': 'layer_version__layer__local_path', 'hidden': 1,
1120 }, 1155 },
1121 ] 1156 ]
@@ -1198,6 +1233,7 @@ def configvars(request, build_id):
1198 'build': Build.objects.filter(pk=build_id)[0], 1233 'build': Build.objects.filter(pk=build_id)[0],
1199 'objects' : variables, 1234 'objects' : variables,
1200 'total_count':queryset_with_search.count(), 1235 'total_count':queryset_with_search.count(),
1236 'default_orderby' : 'variable_name:+',
1201 'search_term':search_term, 1237 'search_term':search_term,
1202 # Specifies the display of columns for the table, appearance in "Edit columns" box, toggling default show/hide, and specifying filters for columns 1238 # Specifies the display of columns for the table, appearance in "Edit columns" box, toggling default show/hide, and specifying filters for columns
1203 'tablecols' : [ 1239 'tablecols' : [
@@ -1213,6 +1249,7 @@ def configvars(request, build_id):
1213 {'name': 'Set in file', 1249 {'name': 'Set in file',
1214 'qhelp': "The last configuration file that touched the variable value", 1250 'qhelp': "The last configuration file that touched the variable value",
1215 'clclass': 'file', 'hidden' : 0, 1251 'clclass': 'file', 'hidden' : 0,
1252 'orderkey' : 'vhistory__file_name',
1216 'filter' : { 1253 'filter' : {
1217 'class' : 'vhistory__file_name', 1254 'class' : 'vhistory__file_name',
1218 'label': 'Show:', 1255 'label': 'Show:',
@@ -1259,6 +1296,7 @@ def bpackage(request, build_id):
1259 'objectname': 'packages built', 1296 'objectname': 'packages built',
1260 'build': Build.objects.filter(pk=build_id)[0], 1297 'build': Build.objects.filter(pk=build_id)[0],
1261 'objects' : packages, 1298 'objects' : packages,
1299 'default_orderby' : 'name:+',
1262 'tablecols':[ 1300 'tablecols':[
1263 { 1301 {
1264 'name':'Package', 1302 'name':'Package',
@@ -1275,6 +1313,7 @@ def bpackage(request, build_id):
1275 'qhelp':'The size of the package', 1313 'qhelp':'The size of the package',
1276 'orderfield': _get_toggle_order(request, "size", True), 1314 'orderfield': _get_toggle_order(request, "size", True),
1277 'ordericon':_get_toggle_order_icon(request, "size"), 1315 'ordericon':_get_toggle_order_icon(request, "size"),
1316 'orderkey' : 'size',
1278 'clclass': 'size', 'hidden': 0, 1317 'clclass': 'size', 'hidden': 0,
1279 'dclass' : 'span2', 1318 'dclass' : 'span2',
1280 }, 1319 },
@@ -1283,6 +1322,7 @@ def bpackage(request, build_id):
1283 'qhelp':'The license under which the package is distributed. Multiple license names separated by the pipe character indicates a choice between licenses. Multiple license names separated by the ampersand character indicates multiple licenses exist that cover different parts of the source', 1322 'qhelp':'The license under which the package is distributed. Multiple license names separated by the pipe character indicates a choice between licenses. Multiple license names separated by the ampersand character indicates multiple licenses exist that cover different parts of the source',
1284 'orderfield': _get_toggle_order(request, "license"), 1323 'orderfield': _get_toggle_order(request, "license"),
1285 'ordericon':_get_toggle_order_icon(request, "license"), 1324 'ordericon':_get_toggle_order_icon(request, "license"),
1325 'orderkey' : 'license',
1286 'clclass': 'license', 'hidden': 1, 1326 'clclass': 'license', 'hidden': 1,
1287 }, 1327 },
1288 { 1328 {
@@ -1290,6 +1330,7 @@ def bpackage(request, build_id):
1290 'qhelp':'The name of the recipe building the package', 1330 'qhelp':'The name of the recipe building the package',
1291 'orderfield': _get_toggle_order(request, "recipe__name"), 1331 'orderfield': _get_toggle_order(request, "recipe__name"),
1292 'ordericon':_get_toggle_order_icon(request, "recipe__name"), 1332 'ordericon':_get_toggle_order_icon(request, "recipe__name"),
1333 'orderkey' : 'recipe__name',
1293 'clclass': 'recipe__name', 'hidden': 0, 1334 'clclass': 'recipe__name', 'hidden': 0,
1294 }, 1335 },
1295 { 1336 {
@@ -1302,6 +1343,7 @@ def bpackage(request, build_id):
1302 'qhelp':'The name of the layer providing the recipe that builds the package', 1343 'qhelp':'The name of the layer providing the recipe that builds the package',
1303 'orderfield': _get_toggle_order(request, "recipe__layer_version__layer__name"), 1344 'orderfield': _get_toggle_order(request, "recipe__layer_version__layer__name"),
1304 'ordericon':_get_toggle_order_icon(request, "recipe__layer_version__layer__name"), 1345 'ordericon':_get_toggle_order_icon(request, "recipe__layer_version__layer__name"),
1346 'orderkey' : 'recipe__layer_version__layer__name',
1305 'clclass': 'recipe__layer_version__layer__name', 'hidden': 1, 1347 'clclass': 'recipe__layer_version__layer__name', 'hidden': 1,
1306 }, 1348 },
1307 { 1349 {
@@ -1309,6 +1351,7 @@ def bpackage(request, build_id):
1309 'qhelp':'The Git branch of the layer providing the recipe that builds the package', 1351 'qhelp':'The Git branch of the layer providing the recipe that builds the package',
1310 'orderfield': _get_toggle_order(request, "recipe__layer_version__branch"), 1352 'orderfield': _get_toggle_order(request, "recipe__layer_version__branch"),
1311 'ordericon':_get_toggle_order_icon(request, "recipe__layer_version__branch"), 1353 'ordericon':_get_toggle_order_icon(request, "recipe__layer_version__branch"),
1354 'orderkey' : 'recipe__layer_version__layer__branch',
1312 'clclass': 'recipe__layer_version__branch', 'hidden': 1, 1355 'clclass': 'recipe__layer_version__branch', 'hidden': 1,
1313 }, 1356 },
1314 { 1357 {
@@ -1321,6 +1364,7 @@ def bpackage(request, build_id):
1321 'qhelp':'Path to the layer providing the recipe that builds the package', 1364 'qhelp':'Path to the layer providing the recipe that builds the package',
1322 'orderfield': _get_toggle_order(request, "recipe__layer_version__layer__local_path"), 1365 'orderfield': _get_toggle_order(request, "recipe__layer_version__layer__local_path"),
1323 'ordericon':_get_toggle_order_icon(request, "recipe__layer_version__layer__local_path"), 1366 'ordericon':_get_toggle_order_icon(request, "recipe__layer_version__layer__local_path"),
1367 'orderkey' : 'recipe__layer_version__layer__local_path',
1324 'clclass': 'recipe__layer_version__layer__local_path', 'hidden': 1, 1368 'clclass': 'recipe__layer_version__layer__local_path', 'hidden': 1,
1325 }, 1369 },
1326 ] 1370 ]