changeset_file_comment.html
245 lines
| 9.9 KiB
| text/html
|
HtmlLexer
r1888 | ## -*- coding: utf-8 -*- | |||
## usage: | ||||
## <%namespace name="comment" file="/changeset/changeset_file_comment.html"/> | ||||
## ${comment.comment_block(co)} | ||||
## | ||||
<%def name="comment_block(co)"> | ||||
r2187 | <div class="comment" id="comment-${co.comment_id}" line="${co.line_no}"> | |||
r1888 | <div class="comment-wrapp"> | |||
Mads Kiilerich
|
r3197 | <div class="meta"> | ||
r2286 | <div style="float:left"> <img src="${h.gravatar_url(co.author.email, 20)}" /> </div> | |||
Mads Kiilerich
|
r3197 | <div class="user"> | ||
${co.author.username} | ||||
</div> | ||||
<div class="date"> | ||||
r3695 | ${h.age(co.modified_at)} | |||
Mads Kiilerich
|
r3197 | </div> | ||
r3190 | ||||
r3695 | <div style="float:left;padding:4px 0px 0px 5px"> | |||
r3190 | <span class=""> | |||
%if co.pull_request: | ||||
<a href="${h.url('pullrequest_show',repo_name=co.pull_request.other_repo.repo_name,pull_request_id=co.pull_request.pull_request_id)}"> | ||||
%if co.status_change: | ||||
Mads Kiilerich
|
r4051 | ${_('Vote on pull request #%s') % co.pull_request.pull_request_id}: | ||
r3190 | %else: | |||
Mads Kiilerich
|
r3608 | ${_('Comment on pull request #%s') % co.pull_request.pull_request_id} | ||
r3190 | %endif | |||
r3216 | </a> | |||
Mads Kiilerich
|
r4049 | %else: | ||
%if co.status_change: | ||||
${_('Status change on changeset')}: | ||||
%else: | ||||
${_('Comment on changeset')} | ||||
%endif | ||||
r3190 | %endif | |||
</span> | ||||
</div> | ||||
Mads Kiilerich
|
r4049 | |||
%if co.status_change: | ||||
<div style="float:left" class="changeset-status-container"> | ||||
<div style="float:left;padding:10px 2px 0px 2px"></div> | ||||
<div title="${_('Changeset status')}" class="changeset-status-lbl"> ${co.status_change[0].status_lbl}</div> | ||||
<div class="changeset-status-ico"><img src="${h.url(str('/images/icons/flag_status_%s.png' % co.status_change[0].status))}" /></div> | ||||
</div> | ||||
%endif | ||||
r3695 | <a class="permalink" href="#comment-${co.comment_id}">¶</a> | |||
r1888 | %if h.HasPermissionAny('hg.admin', 'repository.admin')() or co.author.user_id == c.rhodecode_user.user_id: | |||
r3695 | <div onClick="deleteComment(${co.comment_id})" class="buttons delete-comment ui-btn small">${_('Delete')}</div> | |||
r1888 | %endif | |||
Mads Kiilerich
|
r3197 | </div> | ||
<div class="text"> | ||||
${h.rst_w_mentions(co.text)|n} | ||||
</div> | ||||
r1888 | </div> | |||
</div> | ||||
</%def> | ||||
r2489 | <%def name="comment_inline_form()"> | |||
r1888 | <div id='comment-inline-form-template' style="display:none"> | |||
r2369 | <div class="comment-inline-form ac"> | |||
r1888 | %if c.rhodecode_user.username != 'default': | |||
r2187 | <div class="overlay"><div class="overlay-text">${_('Submitting...')}</div></div> | |||
r2489 | ${h.form('#', class_='inline-form')} | |||
r3695 | <div id="edit-container_{1}" class="clearfix"> | |||
Vincent Duvert
|
r2307 | <div class="comment-help">${_('Commenting on line {1}.')} | ||
r2427 | ${(_('Comments parsed using %s syntax with %s support.') % ( | |||
('<a href="%s">RST</a>' % h.url('rst_help')), | ||||
Mads Kiilerich
|
r3197 | ('<span style="color:#003367" class="tooltip" title="%s">@mention</span>' % _('Use @username inside this text to send notification to this RhodeCode user')) | ||
r2427 | ) | |||
)|n | ||||
} | ||||
Mads Kiilerich
|
r3753 | <div id="preview-btn_{1}" class="preview-btn ui-btn small">${_('Preview')}</div> | ||
r2368 | </div> | |||
<div class="mentions-container" id="mentions_container_{1}"></div> | ||||
r3695 | <textarea id="text_{1}" name="text" class="comment-block-ta yui-ac-input"></textarea> | |||
</div> | ||||
<div id="preview-container_{1}" class="clearfix" style="display:none"> | ||||
<div class="comment-help"> | ||||
Mads Kiilerich
|
r3753 | ${_('Comment preview')} | ||
<div id="edit-btn_{1}" class="edit-btn ui-btn small">${_('Edit')}</div> | ||||
r3695 | </div> | |||
<div id="preview-box_{1}" class="preview-box"></div> | ||||
r1888 | </div> | |||
<div class="comment-button"> | ||||
<input type="hidden" name="f_path" value="{0}"> | ||||
<input type="hidden" name="line" value="{1}"> | ||||
r2187 | ${h.submit('save', _('Comment'), class_='ui-btn save-inline-form')} | |||
Mads Kiilerich
|
r3254 | ${h.reset('hide-inline-form', _('Cancel'), class_='ui-btn hide-inline-form')} | ||
r1888 | </div> | |||
${h.end_form()} | ||||
%else: | ||||
${h.form('')} | ||||
<div class="clearfix"> | ||||
<div class="comment-help"> | ||||
Vincent Duvert
|
r2302 | ${_('You need to be logged in to comment.')} <a href="${h.url('login_home',came_from=h.url.current())}">${_('Login now')}</a> | ||
r1888 | </div> | |||
</div> | ||||
<div class="comment-button"> | ||||
${h.reset('hide-inline-form', _('Hide'), class_='ui-btn hide-inline-form')} | ||||
</div> | ||||
${h.end_form()} | ||||
%endif | ||||
</div> | ||||
</div> | ||||
</%def> | ||||
r2439 | ## generates inlines taken from c.comments var | |||
<%def name="inlines()"> | ||||
Vincent Duvert
|
r2310 | <div class="comments-number">${ungettext("%d comment", "%d comments", len(c.comments)) % len(c.comments)} ${ungettext("(%d inline)", "(%d inline)", c.inline_cnt) % c.inline_cnt}</div> | ||
r1888 | %for path, lines in c.inline_comments: | |||
% for line,comments in lines.iteritems(): | ||||
r2187 | <div style="display:none" class="inline-comment-placeholder" path="${path}" target_id="${h.safeid(h.safe_unicode(path))}"> | |||
r1888 | %for co in comments: | |||
${comment_block(co)} | ||||
%endfor | ||||
</div> | ||||
%endfor | ||||
%endfor | ||||
r2188 | ||||
r2187 | </%def> | |||
r1888 | ||||
r2608 | ## generate inline comments and the main ones | |||
r3229 | <%def name="generate_comments(include_pr=False)"> | |||
r2187 | <div class="comments"> | |||
<div id="inline-comments-container"> | ||||
r2439 | ## generate inlines for this changeset | |||
${inlines()} | ||||
r2187 | </div> | |||
r2188 | ||||
r1888 | %for co in c.comments: | |||
r2189 | <div id="comment-tr-${co.comment_id}"> | |||
r3200 | ## only render comments that are not from pull request, or from | |||
## pull request and a status change | ||||
r3229 | %if not co.pull_request or (co.pull_request and co.status_change) or include_pr: | |||
r2189 | ${comment_block(co)} | |||
r3200 | %endif | |||
r2189 | </div> | |||
r1888 | %endfor | |||
r2673 | </div> | |||
r2608 | </%def> | |||
## MAIN COMMENT FORM | ||||
Mads Kiilerich
|
r4051 | <%def name="comments(post_url, cur_status, is_pr=False, change_status=True)"> | ||
r2608 | ||||
<div class="comments"> | ||||
r1888 | %if c.rhodecode_user.username != 'default': | |||
r2368 | <div class="comment-form ac"> | |||
r2439 | ${h.form(post_url)} | |||
r3695 | <div id="edit-container" class="clearfix"> | |||
r1888 | <div class="comment-help"> | |||
Vincent Duvert
|
r2307 | ${(_('Comments parsed using %s syntax with %s support.') % (('<a href="%s">RST</a>' % h.url('rst_help')), | ||
Mads Kiilerich
|
r3197 | '<span style="color:#003367" class="tooltip" title="%s">@mention</span>' % | ||
_('Use @username inside this text to send notification to this RhodeCode user')))|n} | ||||
r3104 | %if change_status: | |||
Mads Kiilerich
|
r4051 | | <a id="show_changeset_link" onClick="change_status_show();"> | ||
%if is_pr: | ||||
${_('Vote for pull request status')} | ||||
%else: | ||||
${_('Change changeset status')} | ||||
%endif | ||||
</a> | ||||
Mads Kiilerich
|
r3593 | <input id="show_changeset_status_box" type="checkbox" name="change_changeset_status" style="display: none;" /> | ||
r3104 | %endif | |||
Mads Kiilerich
|
r3753 | <div id="preview-btn" class="preview-btn ui-btn small">${_('Preview')}</div> | ||
r1888 | </div> | |||
r3104 | %if change_status: | |||
r2217 | <div id="status_block_container" class="status-block" style="display:none"> | |||
%for status,lbl in c.changeset_statuses: | ||||
<div class=""> | ||||
r3149 | <img src="${h.url('/images/icons/flag_status_%s.png' % status)}" /> <input ${'checked="checked"' if status == cur_status else ''}" type="radio" class="status_change_radio" name="changeset_status" id="${status}" value="${status}"> | |||
r3102 | <label for="${status}">${lbl}</label> | |||
r2478 | </div> | |||
r2217 | %endfor | |||
Mads Kiilerich
|
r4051 | %if is_pr and change_status: | ||
Mads Kiilerich
|
r4048 | <input id="save_close" type="checkbox" name="save_close" disabled="${'1' if cur_status in ['not_reviewed','under_review'] else ''}"> | ||
<label id="save_close_label" for="save_close" class="${'disabled' if cur_status in ['not_reviewed','under_review'] else ''}">${_("Close (when approved or rejected)")}</label> | ||||
%endif | ||||
r2478 | </div> | |||
r3104 | %endif | |||
r2391 | <div class="mentions-container" id="mentions_container"></div> | |||
r3695 | ${h.textarea('text', class_="comment-block-ta")} | |||
r1888 | </div> | |||
r3695 | ||||
<div id="preview-container" class="clearfix" style="display:none"> | ||||
<div class="comment-help"> | ||||
Mads Kiilerich
|
r3753 | ${_('Comment preview')} | ||
<div id="edit-btn" class="edit-btn ui-btn small">${_('Edit')}</div> | ||||
r3695 | </div> | |||
<div id="preview-box" class="preview-box"></div> | ||||
</div> | ||||
r1888 | <div class="comment-button"> | |||
r2608 | ${h.submit('save', _('Comment'), class_="ui-btn large")} | |||
r1888 | </div> | |||
${h.end_form()} | ||||
</div> | ||||
%endif | ||||
</div> | ||||
r2368 | <script> | |||
Mads Kiilerich
|
r3593 | var change_status_show = function(){ | ||
var show = ! YUD.get('show_changeset_status_box').checked; | ||||
YUD.get('show_changeset_status_box').checked = show; | ||||
YUD.setStyle('status_block_container', 'display', show?'':'none'); | ||||
}; | ||||
r2368 | YUE.onDOMReady(function () { | |||
r2369 | MentionsAutoComplete('text', 'mentions_container', _USERS_AC_DATA, _GROUPS_AC_DATA); | |||
r2478 | ||||
r3103 | YUE.on(YUQ('.status_change_radio'), 'change',function(e){ | |||
Mads Kiilerich
|
r3197 | var val = e.currentTarget.value; | ||
if (val == 'approved' || val == 'rejected') { | ||||
Mads Kiilerich
|
r4048 | YUD.removeClass('save_close_label', 'disabled'); | ||
YUD.get('save_close').disabled = false; | ||||
Mads Kiilerich
|
r3197 | }else{ | ||
Mads Kiilerich
|
r4048 | YUD.addClass('save_close_label', 'disabled'); | ||
YUD.get('save_close').disabled = true; | ||||
Mads Kiilerich
|
r3197 | } | ||
r3103 | }) | |||
r3695 | YUE.on('preview-btn', 'click', function(e){ | |||
var _text = YUD.get('text').value; | ||||
if(!_text){ | ||||
return | ||||
} | ||||
var post_data = {'text': _text}; | ||||
YUD.addClass('preview-box', 'unloaded'); | ||||
YUD.get('preview-box').innerHTML = _TM['Loading ...']; | ||||
YUD.setStyle('edit-container', 'display', 'none'); | ||||
YUD.setStyle('preview-container', 'display', ''); | ||||
var url = pyroutes.url('changeset_comment_preview', {'repo_name': '${c.repo_name}'}); | ||||
ajaxPOST(url,post_data,function(o){ | ||||
YUD.get('preview-box').innerHTML = o.responseText; | ||||
YUD.removeClass('preview-box', 'unloaded'); | ||||
}) | ||||
}) | ||||
YUE.on('edit-btn', 'click', function(e){ | ||||
YUD.setStyle('edit-container', 'display', ''); | ||||
YUD.setStyle('preview-container', 'display', 'none'); | ||||
}) | ||||
r2478 | ||||
r2368 | }); | |||
</script> | ||||
r1888 | </%def> | |||