changelog.html
186 lines
| 7.5 KiB
| text/html
|
HtmlLexer
r547 | ## -*- coding: utf-8 -*- | ||
<%inherit file="/base/base.html"/> | |||
<%def name="title()"> | |||
r619 | ${c.repo_name} ${_('Changelog')} - ${c.rhodecode_name} | ||
r547 | </%def> | ||
<%def name="breadcrumbs_links()"> | |||
${h.link_to(u'Home',h.url('/'))} | |||
» | |||
${h.link_to(c.repo_name,h.url('summary_home',repo_name=c.repo_name))} | |||
» | |||
${_('Changelog')} - ${_('showing ')} ${c.size if c.size <= c.total_cs else c.total_cs} ${_('out of')} ${c.total_cs} ${_('revisions')} | |||
</%def> | |||
<%def name="page_nav()"> | |||
${self.menu('changelog')} | |||
</%def> | |||
<%def name="main()"> | |||
<div class="box"> | |||
<!-- box / title --> | |||
<div class="title"> | |||
${self.breadcrumbs()} | |||
</div> | |||
<div class="table"> | |||
% if c.pagination: | |||
<div id="graph"> | |||
<div id="graph_nodes"> | |||
<canvas id="graph_canvas"></canvas> | |||
</div> | |||
<div id="graph_content"> | |||
<div class="container_header"> | |||
r977 | ${h.form(h.url.current(),method='get')} | ||
r1656 | <div class="info_box" style="float:left"> | ||
r1756 | ${h.submit('set',_('Show'),class_="ui-btn")} | ||
r977 | ${h.text('size',size=1,value=c.size)} | ||
r1304 | <span class="rev">${_('revisions')}</span> | ||
r977 | </div> | ||
${h.end_form()} | |||
r1656 | <div style="float:right">${h.select('branch_filter',c.branch_name,c.branch_filters)}</div> | ||
r977 | <div id="rev_range_container" style="display:none"></div> | ||
r547 | </div> | ||
r977 | |||
r547 | %for cnt,cs in enumerate(c.pagination): | ||
<div id="chg_${cnt+1}" class="container"> | |||
<div class="left"> | |||
r977 | <div class="date"> | ||
${h.checkbox(cs.short_id,class_="changeset_range")} | |||
r1837 | <span class="tooltip" title="${cs.date}"><a href="${h.url('changeset_home',repo_name=c.repo_name,revision=cs.raw_id)}">${cs.revision}:${h.short_id(cs.raw_id)}</a></span> | ||
r977 | </div> | ||
r547 | <div class="author"> | ||
<div class="gravatar"> | |||
r1463 | <img alt="gravatar" src="${h.gravatar_url(h.email(cs.author),16)}"/> | ||
r547 | </div> | ||
r1764 | <div title="${cs.author}" class="user">${h.person(cs.author)}</div> | ||
r547 | </div> | ||
r1837 | <div class="message">${h.urlify_commit(h.wrap_paragraphs(cs.message))}</div> | ||
r547 | </div> | ||
<div class="right"> | |||
r1431 | <div id="${cs.raw_id}_changes_info" class="changes"> | ||
r1436 | <span id="${cs.raw_id}" class="changed_total tooltip" title="${_('Affected number of files, click to show more details')}">${len(cs.affected_files)}</span> | ||
r547 | </div> | ||
%if len(cs.parents)>1: | |||
r1656 | <div class="merge">${_('merge')}</div> | ||
r566 | %endif | ||
%if cs.parents: | |||
r547 | %for p_cs in reversed(cs.parents): | ||
r648 | <div class="parent">${_('Parent')} ${p_cs.revision}: ${h.link_to(h.short_id(p_cs.raw_id), | ||
r636 | h.url('changeset_home',repo_name=c.repo_name,revision=p_cs.raw_id),title=p_cs.message)} | ||
r547 | </div> | ||
%endfor | |||
r566 | %else: | ||
<div class="parent">${_('No parents')}</div> | |||
%endif | |||
r547 | <span class="logtags"> | ||
r699 | %if cs.branch: | ||
r547 | <span class="branchtag" title="${'%s %s' % (_('branch'),cs.branch)}"> | ||
r699 | ${h.link_to(cs.branch,h.url('files_home',repo_name=c.repo_name,revision=cs.raw_id))}</span> | ||
%endif | |||
r547 | %for tag in cs.tags: | ||
<span class="tagtag" title="${'%s %s' % (_('tag'),tag)}"> | |||
r636 | ${h.link_to(tag,h.url('files_home',repo_name=c.repo_name,revision=cs.raw_id))}</span> | ||
r547 | %endfor | ||
</span> | |||
</div> | |||
</div> | |||
%endfor | |||
<div class="pagination-wh pagination-left"> | |||
${c.pagination.pager('$link_previous ~2~ $link_next')} | |||
</div> | |||
</div> | |||
</div> | |||
r1050 | <script type="text/javascript" src="${h.url('/js/graph.js')}"></script> | ||
r547 | <script type="text/javascript"> | ||
YAHOO.util.Event.onDOMReady(function(){ | |||
r977 | |||
//Monitor range checkboxes and build a link to changesets | |||
r1431 | //ranges | ||
r977 | var checkboxes = YUD.getElementsByClassName('changeset_range'); | ||
var url_tmpl = "${h.url('changeset_home',repo_name=c.repo_name,revision='__REVRANGE__')}"; | |||
YUE.on(checkboxes,'click',function(e){ | |||
var checked_checkboxes = []; | |||
for (pos in checkboxes){ | |||
if(checkboxes[pos].checked){ | |||
checked_checkboxes.push(checkboxes[pos]); | |||
} | |||
} | |||
if(checked_checkboxes.length>1){ | |||
var rev_end = checked_checkboxes[0].name; | |||
var rev_start = checked_checkboxes[checked_checkboxes.length-1].name; | |||
var url = url_tmpl.replace('__REVRANGE__', | |||
rev_start+'...'+rev_end); | |||
var link = "<a href="+url+">${_('Show selected changes __S -> __E')}</a>" | |||
link = link.replace('__S',rev_start); | |||
link = link.replace('__E',rev_end); | |||
YUD.get('rev_range_container').innerHTML = link; | |||
YUD.setStyle('rev_range_container','display',''); | |||
} | |||
else{ | |||
YUD.setStyle('rev_range_container','display','none'); | |||
} | |||
}); | |||
r1656 | // Fetch changeset details | ||
r1431 | YUE.on(YUD.getElementsByClassName('changed_total'),'click',function(e){ | ||
var id = e.currentTarget.id | |||
var url = "${h.url('changelog_details',repo_name=c.repo_name,cs='__CS__')}" | |||
var url = url.replace('__CS__',id); | |||
ypjax(url,id+'_changes_info',function(){tooltip_activate()}); | |||
}); | |||
r1656 | // change branch filter | ||
YUE.on(YUD.get('branch_filter'),'change',function(e){ | |||
var selected_branch = e.currentTarget.options[e.currentTarget.selectedIndex].value; | |||
var url_main = "${h.url('changelog_home',repo_name=c.repo_name)}"; | |||
var url = "${h.url('changelog_home',repo_name=c.repo_name,branch='__BRANCH__')}"; | |||
var url = url.replace('__BRANCH__',selected_branch); | |||
if(selected_branch != ''){ | |||
window.location = url; | |||
}else{ | |||
window.location = url_main; | |||
} | |||
}); | |||
r1431 | |||
r1429 | function set_canvas(heads) { | ||
r547 | var c = document.getElementById('graph_nodes'); | ||
var t = document.getElementById('graph_content'); | |||
canvas = document.getElementById('graph_canvas'); | |||
var div_h = t.clientHeight; | |||
c.style.height=div_h+'px'; | |||
canvas.setAttribute('height',div_h); | |||
r1429 | c.style.height=max_w+'px'; | ||
canvas.setAttribute('width',max_w); | |||
r547 | }; | ||
r1429 | var heads = 1; | ||
var max_heads = 0; | |||
r547 | var jsdata = ${c.jsdata|n}; | ||
r1429 | |||
for( var i=0;i<jsdata.length;i++){ | |||
var m = Math.max.apply(Math, jsdata[i][1]); | |||
if (m>max_heads){ | |||
max_heads = m; | |||
} | |||
} | |||
var max_w = Math.max(100,max_heads*25); | |||
set_canvas(max_w); | |||
r547 | var r = new BranchRenderer(); | ||
r1429 | r.render(jsdata,max_w); | ||
r1656 | |||
r547 | }); | ||
</script> | |||
%else: | |||
${_('There are no changes yet')} | |||
%endif | |||
</div> | |||
</div> | |||
</%def> |