X-Git-Url: http://git.freeside.biz/gitweb/?a=blobdiff_plain;f=rt%2Fshare%2Fhtml%2FElements%2FShowUser;h=4dc41af8105ecd5979d98be244ac2d0af36492f3;hb=44dd00a3ff974a17999e86e64488e996edc71e3c;hp=01de7256afd310102eac8ad45c79590e6b18c3ef;hpb=e70abd21bab68b23488f7ef1ee2e693a3b365691;p=freeside.git diff --git a/rt/share/html/Elements/ShowUser b/rt/share/html/Elements/ShowUser index 01de7256a..4dc41af81 100644 --- a/rt/share/html/Elements/ShowUser +++ b/rt/share/html/Elements/ShowUser @@ -1,40 +1,40 @@ %# BEGIN BPS TAGGED BLOCK {{{ -%# +%# %# COPYRIGHT: -%# -%# This software is Copyright (c) 1996-2009 Best Practical Solutions, LLC -%# -%# +%# +%# This software is Copyright (c) 1996-2019 Best Practical Solutions, LLC +%# +%# %# (Except where explicitly superseded by other copyright notices) -%# -%# +%# +%# %# LICENSE: -%# +%# %# This work is made available to you under the terms of Version 2 of %# the GNU General Public License. A copy of that license should have %# been provided with this software, but in any event can be snarfed %# from www.gnu.org. -%# +%# %# This work is distributed in the hope that it will be useful, but %# WITHOUT ANY WARRANTY; without even the implied warranty of %# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU %# General Public License for more details. -%# +%# %# You should have received a copy of the GNU General Public License %# along with this program; if not, write to the Free Software %# Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA %# 02110-1301 or visit their web page on the internet at %# http://www.gnu.org/licenses/old-licenses/gpl-2.0.html. -%# -%# +%# +%# %# CONTRIBUTION SUBMISSION POLICY: -%# +%# %# (The following paragraph is not intended to limit the rights granted %# to you to modify and distribute this software under the terms of %# the GNU General Public License and is only of importance to you if %# you choose to contribute your changes and enhancements to the %# community by submitting them to Best Practical Solutions, LLC.) -%# +%# %# By intentionally submitting any modifications, corrections or %# derivatives to this work, or any other work intended for use with %# Request Tracker, to Best Practical Solutions, LLC, you confirm that @@ -43,29 +43,53 @@ %# royalty-free, perpetual, license to use, copy, create derivative %# works based on those contributions, and sublicense and distribute %# those contributions and any derivatives thereof. -%# +%# %# END BPS TAGGED BLOCK }}} -%# Released under the terms of version 2 of the GNU Public License <%INIT> # $User is an RT::User object # $Address is Email::Address object -my $comp = '/Elements/ShowUser'. ucfirst lc $style; -unless ( $m->comp_exists( $comp ) ) { - $RT::Logger->error( - 'Either system config or user #' - . $session{'CurrentUser'}->id - . ' picked UsernameFormat '. $style - . ', but '. $comp . "doesn't exist" - ); - return $m->comp('/Elements/ShowUserConcise', - User => $User, Address => $Address, - ); +my $display = RT::User->Format( + User => $User, + Address => $Address, + CurrentUser => $session{CurrentUser}, + Format => $style, +); + +# RT::User->Format does this itself, but we want to make sure we have a $User +# if at all possible for the rest of our code below. +if ($Address and not $User) { + $User = RT::User->new( $session{CurrentUser} ); + $User->LoadByEmail( $Address->address ); + undef $User unless $User->id; } -return $m->comp( $comp, User => $User, Address => $Address ); + +my %system_user = ( + RT->Nobody->id => 1, + RT->SystemUser->id => 1, +); + +$m->callback( + ARGSRef => \%ARGS, + User => $User, + Address => $Address, + display => \$display, + system_user => \%system_user, + CallbackName => 'Modify', +); <%ARGS> $User => undef $Address => undef -$style => RT->Config->Get('UsernameFormat', $session{'CurrentUser'}) +$style => undef +$Link => 1 +id ? 'data-user-id="'.$User->id.'"' : "" |n %>>\ +% if ($Link and $User and $User->id and not $system_user{$User->id} and $session{CurrentUser}->Privileged) { +/User/Summary.html?id=<% $User->id %>">\ +<% $display %>\ +\ +% } else { +<% $display %>\ +% } +\