review/web_templates/changeset.html @ f841259cc87e
Move the individual line comment forms into comments.js.
This *massively* improves performance on large diffs. For example, the review
page for the changeset where I added CherryPy as a bundled app was 38.7mb
before this changeset. With this change it is now 13.2mb.
author |
Steve Losh <steve@stevelosh.com> |
date |
Sat, 27 Mar 2010 13:03:00 -0400 |
parents |
6df093d9f238 |
children |
9d032dbf867d |
{% extends "base.html" %}
{% block title %} at {{ title }}{% endblock %}
{% block header %} at {{ title }}{% endblock %}
{% block content %}
<h2>Changeset {{ rev.rev() }}: {{ rev.description().splitlines()[0] }}</h2>
{% for comment in rcset.review_level_comments() %}
<div class="comment">
{{ macros.gravatar(comment, utils) }}
<div>
<div class="author">
<a href="mailto:${ email(comment.author) }">{{ utils['templatefilters'].person(comment.author) }}</a>
said:
</div>
<div class="message">{{ comment.message }}</div>
</div>
</div>
{% endfor %}
{% if not read_only %}
<div id="comment-review">
<p class="comment-activate"><a href="">Add a comment on this changeset</a></p>
<form id="comment-review-form" method="post" action="">
<div class="field">
<label for="body">Add a comment on this changeset:</label>
<textarea cols="60" rows="6" name="new-comment-body"></textarea>
</div>
<div class="buttons">
<input type="submit" class="button" value="Submit" />
</div>
</form>
</div>
{% endif %}
<h2>Signoffs</h2>
{% for signoff in rcset.signoffs %}
<div class="signoff {{ signoff.opinion }}">
{{ macros.gravatar(signoff, utils) }}
<div>
<div class="author">
<a href="mailto:${ email(signoff.author) }">{{ utils['templatefilters'].person(signoff.author) }}</a>
signed off as <span class="opinion">{{ signoff.opinion }}</span> on this changeset, saying:
</div>
<div class="message">{{ signoff.message }}</div>
</div>
</div>
{% endfor %}
{% if not read_only %}
<div id="signoff-review">
<p class="signoff-activate"><a href="#">Sign off on this changeset (currently unimplemented)</a></p>
</div>
{% endif %}
<h2>Files</h2>
{% for filename in rcset.files() %}
<div class="file-review">
<div class="filename-header">
<a class="fold-file" href=""> ↓</a>
<h3>{{ filename }}</h3>
</div>
<div class="file-review-contents">
{% for comment in rcset.file_level_comments(filename) %}
<div class="comment">
{{ macros.gravatar(comment, utils) }}
<div>
<div class="author">
<a href="mailto:{{ utils['email'](comment.author) }}">
{{ utils['templatefilters'].person(comment.author) }}</a>
said:
</div>
<div class="message">{{ comment.message }}</div>
</div>
</div>
{% endfor %}
{% if not read_only %}
<div id="comment-file">
<p class="comment-activate"><a href="">Add a comment on this file</a></p>
<form id="comment-file-form" method="post" action="">
<div class="field">
<label for="body">Add a comment on this file:</label>
<textarea cols="60" rows="6" name="new-comment-body"></textarea>
</div>
<div class="buttons">
<input type="submit" class="button" value="Submit" />
</div>
<input type="hidden" name="filename" value="{{ filename }}" />
</form>
</div>
{% endif %}
<div class="diff">
<table>
<tbody>
{% set annotated_diff = rcset.annotated_diff(filename) %}
{# We need to ignore the first item from this generator, because
we don't care about providing a line-number prefix (for now!). #}
{% set ignore_this_variable = annotated_diff.next() %}
{% for line in annotated_diff %}
{% if line['skipped'] %}
<tr class="skipped">
<td><code>… skipped {{ line['skipped'] }} lines …</code></td>
</tr>
{% for comment in line['comments'] %}
<tr><td class="comment">
{{ macros.gravatar(comment, utils) }}
<div>
<div class="author">
<a href="mailto:{{ utils['email'](comment.author) }}">
{{ utils['templatefilters'].person(comment.author) }}
</a>
said (on a skipped line):
</div>
<div class="message">{{ comment.message|escape }}</div>
</div>
</td></tr>
{% endfor %}
{% else %}
<tr class="{{ utils['line_type'](line['content']) }}{% if not read_only %} commentable {% endif %}">
<td class="diff-line"><div class="line-data"><span class="linenumber">{{ line['number'] }}</span><span class="filename">{{ filename }}</span></div><code>{{ line['number'] }}: {{ line['content'][1:]|escape }}</code></td>
{% for comment in line['comments'] %}
<tr><td class="comment">
{{ macros.gravatar(comment, utils) }}
<div>
<div class="author">
<a href="mailto:{{ utils['email'](comment.author) }}">
{{ utils['templatefilters'].person(comment.author) }}
</a>
said:
</div>
<div class="message">{{ comment.message }}</div>
</div>
</td></tr>
{% endfor %}
</tr>
{% endif %}
{% endfor %}
</tbody>
</table>
</div>
</div>
</div>
{% endfor %}
{% endblock %}