search_commit.mako
98 lines
| 4.0 KiB
| application/x-mako
|
MakoHtmlLexer
r1282 | <%namespace name="base" file="/base/base.mako"/> | |||
r3467 | <%namespace name="search" file="/search/search.mako"/> | |||
r1282 | ||||
r3319 | % if c.formatted_results: | |||
r1282 | <table class="rctable search-results"> | |||
<tr> | ||||
<th>${_('Repository')}</th> | ||||
<th>${_('Commit')}</th> | ||||
<th></th> | ||||
<th>${_('Commit message')}</th> | ||||
<th> | ||||
%if c.sort == 'newfirst': | ||||
<a href="${c.url_generator(sort='oldfirst')}">${_('Age (new first)')}</a> | ||||
%else: | ||||
<a href="${c.url_generator(sort='newfirst')}">${_('Age (old first)')}</a> | ||||
%endif | ||||
</th> | ||||
<th>${_('Author')}</th> | ||||
</tr> | ||||
%for entry in c.formatted_results: | ||||
## search results are additionally filtered, and this check is just a safe gate | ||||
r3376 | % if c.rhodecode_user.is_admin or h.HasRepoPermissionAny('repository.write','repository.read','repository.admin')(entry['repository'], 'search results commit check'): | |||
r1282 | <tr class="body"> | |||
<td class="td-componentname"> | ||||
r3376 | <% repo_type = entry.get('repo_type') or h.get_repo_type_by_name(entry.get('repository')) %> | |||
r3467 | ${search.repo_icon(repo_type)} | |||
r1785 | ${h.link_to(entry['repository'], h.route_path('repo_summary',repo_name=entry['repository']))} | |||
r1282 | </td> | |||
<td class="td-commit"> | ||||
${h.link_to(h._shorten_commit_id(entry['commit_id']), | ||||
r1951 | h.route_path('repo_commit',repo_name=entry['repository'],commit_id=entry['commit_id']))} | |||
r1282 | </td> | |||
<td class="td-message expand_commit search open" data-commit-id="${h.md5_safe(entry['repository'])+entry['commit_id']}" id="t-${h.md5_safe(entry['repository'])+entry['commit_id']}" title="${_('Expand commit message')}"> | ||||
r3187 | <div> | |||
r3168 | <i class="icon-expand-linked"></i> | |||
r1282 | </div> | |||
</td> | ||||
<td data-commit-id="${h.md5_safe(entry['repository'])+entry['commit_id']}" id="c-${h.md5_safe(entry['repository'])+entry['commit_id']}" class="message td-description open"> | ||||
%if entry.get('message_hl'): | ||||
${h.literal(entry['message_hl'])} | ||||
%else: | ||||
${h.urlify_commit_message(entry['message'], entry['repository'])} | ||||
%endif | ||||
</td> | ||||
<td class="td-time"> | ||||
${h.age_component(h.time_to_utcdatetime(entry['date']))} | ||||
</td> | ||||
<td class="td-user author"> | ||||
r3319 | <% | |||
## es6 stores this as object | ||||
author = entry['author'] | ||||
if isinstance(author, dict): | ||||
author = author['email'] | ||||
%> | ||||
${base.gravatar_with_user(author)} | ||||
r1282 | </td> | |||
</tr> | ||||
% endif | ||||
%endfor | ||||
</table> | ||||
r3319 | %if c.cur_query: | |||
r1282 | <div class="pagination-wh pagination-left"> | |||
${c.formatted_results.pager('$link_previous ~2~ $link_next')} | ||||
</div> | ||||
%endif | ||||
<script> | ||||
$('.expand_commit').on('click',function(e){ | ||||
var target_expand = $(this); | ||||
var cid = target_expand.data('commit-id'); | ||||
if (target_expand.hasClass('open')){ | ||||
r3376 | $('#c-'+cid).css({'height': '1.5em', 'white-space': 'nowrap', 'text-overflow': 'ellipsis', 'overflow':'hidden'}); | |||
$('#t-'+cid).css({'height': 'auto', 'line-height': '.9em', 'text-overflow': 'ellipsis', 'overflow':'hidden'}); | ||||
r1282 | target_expand.removeClass('open'); | |||
} | ||||
else { | ||||
r3376 | $('#c-'+cid).css({'height': 'auto', 'white-space': 'normal', 'text-overflow': 'initial', 'overflow':'visible'}); | |||
$('#t-'+cid).css({'height': 'auto', 'max-height': 'none', 'text-overflow': 'initial', 'overflow':'visible'}); | ||||
r1282 | target_expand.addClass('open'); | |||
} | ||||
}); | ||||
r3319 | ||||
$(".message.td-description").mark( | ||||
"${c.searcher.query_to_mark(c.cur_query, 'message')}", | ||||
{ | ||||
"className": 'match', | ||||
"accuracy": "complementary", | ||||
"ignorePunctuation": ":._(){}[]!'+=".split("") | ||||
} | ||||
); | ||||
r1282 | </script> | |||
r3319 | ||||
% endif | ||||