Skip to content
Projects
Groups
Snippets
Help
This project
Loading...
Sign in / Register
Toggle navigation
bugzilla
Project
Project
Details
Activity
Cycle Analytics
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Charts
Issues
0
Issues
0
List
Board
Labels
Milestones
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Charts
Registry
Registry
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Charts
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
Ivan Ivlev
bugzilla
Commits
c47b010b
You need to sign in or sign up before continuing.
Commit
c47b010b
authored
Mar 17, 2010
by
Max Kanat-Alexander
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Bug 545587: Make colchange.cgi use the database to determine buglist-able
columns, instead of having a fixed list. r=LpSolit, a=LpSolit
parent
a41f75dd
Hide whitespace changes
Inline
Side-by-side
Showing
3 changed files
with
62 additions
and
69 deletions
+62
-69
Hook.pm
Bugzilla/Hook.pm
+0
-15
colchange.cgi
colchange.cgi
+39
-44
change-columns.html.tmpl
template/en/default/list/change-columns.html.tmpl
+23
-10
No files found.
Bugzilla/Hook.pm
View file @
c47b010b
...
...
@@ -428,21 +428,6 @@ spaces.
=back
=head2 colchange_columns
This happens in F<colchange.cgi> right after the list of possible display
columns have been defined and gives you the opportunity to add additional
display columns to the list of selectable columns.
Params:
=over
=item C<columns> - An arrayref containing an array of column IDs. Any IDs
added by this hook must have been defined in the the L</buglist_columns> hook.
=back
=head2 config_add_panels
If you want to add new panels to the Parameters administrative interface,
...
...
colchange.cgi
View file @
c47b010b
...
...
@@ -24,7 +24,6 @@
# Pascal Held <paheld@gmail.com>
use
strict
;
use
lib
qw(. lib)
;
use
Bugzilla
;
...
...
@@ -34,7 +33,24 @@ use Bugzilla::CGI;
use
Bugzilla::Search::
Saved
;
use
Bugzilla::
Error
;
use
Bugzilla::
User
;
use
Bugzilla::
Keyword
;
use
Storable
qw(dclone)
;
# Maps parameters that control columns to the names of columns.
use
constant
COLUMN_PARAMS
=>
{
'useclassification'
=>
[
'classification'
],
'usebugaliases'
=>
[
'alias'
],
'usetargetmilestone'
=>
[
'target_milestone'
],
'useqacontact'
=>
[
'qa_contact'
,
'qa_contact_realname'
],
'usestatuswhiteboard'
=>
[
'status_whiteboard'
],
};
# We only show these columns if an object of this type exists in the
# database.
use
constant
COLUMN_CLASSES
=>
{
'Bugzilla::Flag'
=>
'flagtypes.name'
,
'Bugzilla::Keyword'
=>
'keywords'
,
};
Bugzilla
->
login
();
...
...
@@ -42,52 +58,31 @@ my $cgi = Bugzilla->cgi;
my
$template
=
Bugzilla
->
template
;
my
$vars
=
{};
# The master list not only says what fields are possible, but what order
# they get displayed in.
my
@masterlist
=
(
"opendate"
,
"changeddate"
,
"bug_severity"
,
"priority"
,
"rep_platform"
,
"assigned_to"
,
"assigned_to_realname"
,
"reporter"
,
"reporter_realname"
,
"bug_status"
,
"resolution"
);
my
$columns
=
dclone
(
Bugzilla::Search::
COLUMNS
);
if
(
Bugzilla
->
params
->
{
"useclassification"
})
{
push
(
@masterlist
,
"classification"
);
}
# You can't manually select "relevance" as a column you want to see.
delete
$columns
->
{
'relevance'
};
push
(
@masterlist
,
(
"product"
,
"component"
,
"version"
,
"op_sys"
));
if
(
Bugzilla
->
params
->
{
"usebugaliases"
})
{
unshift
(
@masterlist
,
"alias"
);
}
if
(
Bugzilla
->
params
->
{
"usetargetmilestone"
})
{
push
(
@masterlist
,
"target_milestone"
);
}
if
(
Bugzilla
->
params
->
{
"useqacontact"
})
{
push
(
@masterlist
,
"qa_contact"
);
push
(
@masterlist
,
"qa_contact_realname"
);
}
if
(
Bugzilla
->
params
->
{
"usestatuswhiteboard"
})
{
push
(
@masterlist
,
"status_whiteboard"
);
}
if
(
Bugzilla::
Keyword
->
any_exist
)
{
push
(
@masterlist
,
"keywords"
);
}
if
(
Bugzilla
->
has_flags
)
{
push
(
@masterlist
,
"flagtypes.name"
);
}
if
(
Bugzilla
->
user
->
is_timetracker
)
{
push
(
@masterlist
,
(
"estimated_time"
,
"remaining_time"
,
"actual_time"
,
"percentage_complete"
,
"deadline"
));
foreach
my
$param
(
keys
%
{
COLUMN_PARAMS
()
})
{
next
if
Bugzilla
->
params
->
{
$param
};
foreach
my
$column
(
@
{
COLUMN_PARAMS
->
{
$param
}
})
{
delete
$columns
->
{
$column
};
}
}
push
(
@masterlist
,
(
"short_desc"
,
"short_short_desc"
));
my
@custom_fields
=
grep
{
$_
->
type
!=
FIELD_TYPE_MULTI_SELECT
}
Bugzilla
->
active_custom_fields
;
push
(
@masterlist
,
map
{
$_
->
name
}
@custom_fields
);
foreach
my
$class
(
keys
%
{
COLUMN_CLASSES
()
})
{
eval
(
"use $class; 1;"
)
||
die
$@
;
my
$column
=
COLUMN_CLASSES
->
{
$class
};
delete
$columns
->
{
$column
}
if
!
$class
->
any_exist
;
}
Bugzilla::Hook::
process
(
'colchange_columns'
,
{
'columns'
=>
\
@masterlist
}
);
if
(
!
Bugzilla
->
user
->
is_timetracker
)
{
foreach
my
$column
(
TIMETRACKING_FIELDS
)
{
delete
$columns
->
{
$column
};
}
}
$vars
->
{
'
masterlist'
}
=
\
@masterlist
;
$vars
->
{
'
columns'
}
=
$columns
;
my
@collist
;
if
(
defined
$cgi
->
param
(
'rememberedquery'
))
{
...
...
@@ -96,8 +91,8 @@ if (defined $cgi->param('rememberedquery')) {
@collist
=
DEFAULT_COLUMN_LIST
;
}
else
{
if
(
defined
$cgi
->
param
(
"selected_columns"
))
{
my
%
legal_list
=
map
{
$_
=>
1
}
@masterlist
;
@collist
=
grep
{
exists
$legal_list
{
$_
}
}
$cgi
->
param
(
"selected_columns"
);
@collist
=
grep
{
exists
$columns
->
{
$_
}
}
$cgi
->
param
(
"selected_columns"
);
}
if
(
defined
$cgi
->
param
(
'splitheader'
))
{
$splitheader
=
$cgi
->
param
(
'splitheader'
)?
1
:
0
;
...
...
template/en/default/list/change-columns.html.tmpl
View file @
c47b010b
...
...
@@ -34,10 +34,22 @@
[% PROCESS "global/field-descs.none.tmpl" %]
[% field_descs.short_short_desc = "Summary (first 60 characters)" %]
[% field_descs.short_desc = "Full Summary" %]
[% field_descs.assigned_to_realname = "Assignee Realname" %]
[% field_descs.reporter_realname = "Reporter Realname" %]
[% field_descs.qa_contact_realname = "QA Contact Realname" %]
[% field_descs.short_desc = "Summary (Full)" %]
[% field_descs.assigned_to_realname = "$field_descs.assigned_to Real Name" %]
[% field_descs.reporter_realname = "$field_descs.reporter Real Name" %]
[% field_descs.qa_contact_realname = "$field_descs.qa_contact Real Name" %]
[%# Create a mapping of field descriptions to field names, so that
# the "Available Columns" list can be sorted alphabetically by
# field description.
#%]
[% SET available_columns = {} %]
[% FOREACH column = columns.keys %]
[% NEXT IF collist.contains(column) %]
[%# We lowecase the keys so that the sort happens case-insensitively. %]
[% SET column_desc = field_descs.$column || column FILTER lower %]
[% available_columns.$column_desc = column %]
[% END %]
<form name="changecolumns" action="colchange.cgi" onsubmit="change_submit();">
<input type="hidden" name="rememberedquery" value="[% buffer FILTER html %]">
...
...
@@ -70,12 +82,13 @@
[% (field_descs.${column} || column) FILTER html %]
</option>
[% END %]
[% FOREACH column = masterlist %]
[% IF lsearch(collist, column) == -1 %]
<option value="[% column FILTER html %]">
[% (field_descs.${column} || column) FILTER html %]
</option>
[% END %]
[% FOREACH key = available_columns.keys.sort %]
[% SET column = available_columns.$key %]
<option value="[% column FILTER html %]">
[%# Don't display the lower-cased column description,
# display the correct-case one. %]
[% (field_descs.$column || column) FILTER html %]
</option>
[% END %]
</select>
</td>
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment