* chore: Remove unused "rendertest" stuff (#6015) * fix: restore ability to create status change documents (#5963) * fix: restore ability to create status change documents Fixes #5962 * chore: address review comment * fix: Provide human-friendly status in submission status API response (#6011) Co-authored-by: nectostr <bastinda96@gmail.com> * fix: Make name/email lookups case-insensitive (#5972) (#6007) * fix: Make name/email lookups case-insensitive (#5972) Use icontains so that looking up name or email is case insensitive Added a test Fixes: 5972 * fix: Use __iexact not __icontains * fix: Clarify no-action-needed (#5918) (#6020) When a draft is submitted for manual processing, clarify that no action is needed; the Secretariat has the next steps. Fixes: #5918 * fix: Fix menu hover issue (#6019) * fix: Fix menu hover issue Fixes #5702 * Fix leftmenu hover issue * fix: Server error from api_get_session_materials() (#6025) Fixes #5877 * fix: Clarify Questionnaire label (#4688) (#6017) When filtering nominees, `Questionnaire` implies `Accepted == yes` so fix the dropdown test tosay that. Fixes: #4688 * chore: Merge from @martinthomson's rfc-txt-html (#6023) * fix:no history entry when changing RFC Editor note for doc (#6021) * fix:no history entry when changing RFC Editor note for doc * fix:no history entry when changing RFC Editor note for doc --------- Co-authored-by: Priyanka Narkar <priyankanarkar@dhcp-91f8.meeting.ietf.org> * fix: avoid deprecation warning on view_list() for objs without CommunityList Fixes #5942 * fix: return 404 for non-existing revisions (#6014) * fix: return 404 for non-existing revisions Links to non-existing revisions to docs should return 404 * fix: change rfc/rev and search behaviour * refactor: fix tab level * fix: return 404 for rfc revision for bibtex * fix: provide date for revisions in bibtex output (#6029) * fix: provide date for revisions in bibtex output * refactor: change walrus to if's * fix: specify particular revision for events * fix: review refactoring issue fixes #5447 * fix: Remove automatically suggested document for document that is already has review request (fixes #3211) (#5425) * Added check that if there is already review request for the document in question, ignore the automatic suggestion for that document. Fixes #3211. * fix: dont block on open requests for a previous version. Add tests --------- Co-authored-by: Nicolas Giard <github@ngpixel.com> Co-authored-by: Robert Sparks <rjsparks@nostrum.com> * feat: IAB statements (#5940) * feat: support iab and iesg statements. Import iab statements. (#5895) * feat: infrastructure for statements doctype * chore: basic test framework * feat: basic statement document view * feat: show replaced statements * chore: black * fix: state help for statements * fix: cleanout non-relevant email expansions * feat: import iab statements, provide group statements tab * fix: guard against running import twice * feat: build redirect csv for iab statements * fix: set document state on import * feat: show published date on main doc view * feat: handle pdf statements * feat: create new and update statements * chore: copyright block updates * chore: remove flakes * chore: black * feat: add edit/new buttons for the secretariat * fix: address PR #5895 review comments * fix: pin pydantic until inflect catches up (#5901) (#5902) * chore: re-un-pin pydantic * feat: include submitter in email about submitted slides (#6033) * feat: include submitter in email about submitted slides fixes #6031 * chore: remove unintended whitespace change * chore(dev): update .vscode/settings.json with new taskExplorer settings * fix: Add editorial stream to proceedings (#6027) * fix: Add editorial stream to proceedings Fixes #5717 * fix: Move editorial stream after the irtf in proceedings * fix: Add editorial stream to meeting materials (#6047) Fixes #6042 * fix: Shows requested reviews for doc fixes (#6022) * Fix: Shows requested reviews for doc * Changed template includes to only give required variables to them. * feat: allow openId to choose an unactive email if there are none active (#6041) * feat: allow openId to choose an unactive email if there are no active ones * chore: correct typo * chore: rename unactive to inactive * fix: Make review table more responsive (#6053) * fix: Improve layout of review table * Progress * Progress * Final changes * Fix tests * Remove fluff * Undo commits * ci: add --validate-html-harder to tests * ci: add --validate-html-harder to build.yml workflow * fix: Set colspan to actual number of columns (#6069) * fix: Clean up view_feedback_pending (#6070) - Remove "Unclassified" column header, which caused misalignment in the table body. - Show the message author - previously displayed as `(None)`. * docs: Update LICENSE year * fix: Remove IESG state edit button when state is 'dead' (#6051) (#6065) * fix: Correctly order "last call requested" column in the IESG dashboard (#6079) * ci: update dev sandbox init script to start memcached * feat: Reclassify nomcom feedback (#6002) * fix: Clean up view_feedback_pending - Remove "Unclassified" column header, which caused misalignment in the table body. - Show the message author - previously displayed as `(None)`. * feat: Reclassify nomcom feedback (#4669) - There's a new `Chair/Advisor Tasks` menu item `Reclassify feedback`. - I overloaded `view_feedback*` URLs with a `?reclassify` parameter. - This adds a checkbox to each feedback message, and a `Reclassify` button at the bottom of each feedback page. - "Reclassifying" basically de-classifies the feedback, and punts it back to the "Pending emails" view for reclassification. - If a feedback has been applied to multiple nominees, declassifying it from one nominee removes it from all. * fix: Remove unused local variables * fix: Fix some missing and mis-nested html * test: Add tests for reclassifying feedback * refactor: Substantial redesign of feedback reclassification - Break out reclassify_feedback* as their own URLs and views, and revert changes to view_feedback*.html. - Replace checkboxes with a Reclassify button on each message. * fix: Remember to clear the feedback associations when reclassifying * feat: Add an 'Overcome by events' feedback type * refactor: When invoking reclassification from a view-feedback page, load the corresponding reclassify-feedback page * fix: De-conflict migration with 0004_statements Also change the coding style to match, and add a reverse migration. * fix: Fix a test case to account for new feedback type * fix: 842e730 broke the Back button * refactor: Reclassify feedback directly instead of putting it back in the work queue * fix: Adjust tests to new workflow * refactor: Further refine reclassification to avoid redirects * refactor: Impose a FeedbackTypeName ordering Also add FeedbackTypeName.legend field, rather than synthesizing it every time we classify or reclassify feedback. In the reclassification forms, only show the relevant feedback types. * refactor: Merge reclassify_feedback_* back into view_feedback_* This means the "Reclassify" button is always present, but eliminates some complexity. * refactor: Add filter(used=True) on FeedbackTypeName querysets * refactor: Add the new FeedbackTypeName to the reclassification success message * fix: Secure reclassification against rogue nomcom members * fix: Print decoded key and fully clean up test nomcom (#6094) * fix: Delete Person records when deleting a test nomcom * fix: Decode test nomcom private key before printing * test: Use correct time zone for test_statement_doc_view (#6064) * chore(deps): update all npm dependencies for playwright (#6061) Co-authored-by: depfu[bot] <23717796+depfu[bot]@users.noreply.github.com> * chore(deps): update all npm dependencies for dev/diff (#6062) Co-authored-by: depfu[bot] <23717796+depfu[bot]@users.noreply.github.com> * chore(deps): update all npm dependencies for dev/coverage-action (#6063) Co-authored-by: depfu[bot] <23717796+depfu[bot]@users.noreply.github.com> * fix: Hash cache key for default memcached cache (#6089) * feat: Show docs that an AD hasn't balloted on that need ballots to progress (#6075) * fix(doc): Unify help texts for document states (#6060) * Fix IESG State help text link (only) * Intermediate checkpoint * Correct URL filtering of state descriptions * Unify help texts for document states * Remove redundant load static from template --------- Co-authored-by: Robert Sparks <rjsparks@nostrum.com> * ci: fix sandbox start.sh memcached user * fix: refactor how settings handles cache definitions (#6099) * fix: refactor how settings handles cache definitions * chore: more english-speaker readable expression * fix: Cast cache key to str before calling encode (#6100) --------- Co-authored-by: Robert Sparks <rjsparks@nostrum.com> Co-authored-by: Liubov Kurafeeva <liubov.kurafeeva@gmail.com> Co-authored-by: nectostr <bastinda96@gmail.com> Co-authored-by: Rich Salz <rsalz@akamai.com> Co-authored-by: PriyankaN <priyanka@amsl.com> Co-authored-by: Priyanka Narkar <priyankanarkar@dhcp-91f8.meeting.ietf.org> Co-authored-by: Ali <alireza83@gmail.com> Co-authored-by: Roman Beltiukov <maybe.hello.world@gmail.com> Co-authored-by: Tero Kivinen <kivinen@iki.fi> Co-authored-by: Nicolas Giard <github@ngpixel.com> Co-authored-by: Kesara Rathnayake <kesara@fq.nz> Co-authored-by: Jennifer Richards <jennifer@staff.ietf.org> Co-authored-by: Paul Selkirk <paul@painless-security.com> Co-authored-by: depfu[bot] <23717796+depfu[bot]@users.noreply.github.com> Co-authored-by: Jim Fenton <fenton@bluepopcorn.net>
447 lines
21 KiB
HTML
447 lines
21 KiB
HTML
{# Copyright The IETF Trust 2016-2020, All Rights Reserved #}
|
|
{% load origin %}
|
|
{% load static %}
|
|
{% load ietf_filters %}
|
|
{% load person_filters %}
|
|
{% origin %}
|
|
|
|
<tbody class="meta align-top {% if not document_html %} border-top{% endif %}">
|
|
<tr>
|
|
<th scope="row">Document</th>
|
|
<th scope="row">{% if document_html %}Document type{% else %}Type{% endif %}</th>
|
|
<td class="edit"></td>
|
|
<td>
|
|
{% if doc.get_state_slug == "rfc" and not snapshot %}
|
|
<span class="text-success">RFC
|
|
{% if not document_html %}
|
|
- {{ doc.std_level }}
|
|
{% else %}
|
|
<span class="badge rounded-pill badge-{% if not snapshot %}{{ doc|std_level_to_label_format }}{% else %}draft{% endif %}">{{ doc.std_level }}</span>
|
|
{% endif %}
|
|
</span>
|
|
{% if published %}
|
|
{% if document_html %}<br>{% else %}({% endif %}{{ doc.pub_date|date:"F Y" }}{% if not document_html %}){% endif %}
|
|
{% else %}
|
|
<span class="text-body-secondary">(Publication date unknown)</span>
|
|
{% endif %}
|
|
{% if document_html %}<br>{% endif %}
|
|
{% if has_verified_errata or has_errata %}
|
|
<a class="{% if document_html %}btn btn-primary btn-sm my-1{% else %}badge rounded-pill text-bg-danger text-decoration-none{% endif %}"
|
|
href="https://www.rfc-editor.org/errata_search.php?rfc={{ doc.rfc_number }}" title="Click to view errata." rel="nofollow">
|
|
{% if document_html %}View errata{% else %}Errata{% endif %}
|
|
</a>
|
|
{% endif %}
|
|
{% if document_html and doc.get_state_slug == "rfc" and not snapshot %}
|
|
<a class="btn btn-sm btn-warning"
|
|
title="Click to report an error in the document."
|
|
href="https://www.rfc-editor.org/errata.php#reportnew"
|
|
target="_blank">
|
|
Report errata
|
|
</a>
|
|
{% endif %}
|
|
{% if doc.related_ipr %}
|
|
<a title="Click to view IPR declarations." class="{% if document_html %}btn btn-warning btn-sm my-1{% else %}badge rounded-pill text-bg-warning text-decoration-none{% endif %}" href="{% url 'ietf.ipr.views.search' %}?submit=draft&id={{ doc.name }}">IPR</a>
|
|
{% endif %}
|
|
{% if obsoleted_by %}<div>Obsoleted by {{ obsoleted_by|urlize_related_source_list:document_html|join:", " }}</div>{% endif %}
|
|
{% if updated_by %}<div>Updated by {{ updated_by|urlize_related_source_list:document_html|join:", " }}</div>{% endif %}
|
|
{% if obsoletes %}<div>Obsoletes {{ obsoletes|urlize_related_target_list:document_html|join:", " }}</div>{% endif %}
|
|
{% if updates %}<div>Updates {{ updates|urlize_related_target_list:document_html|join:", " }}</div>{% endif %}
|
|
{% if status_changes %}
|
|
<div>Status changed by {{ status_changes|urlize_related_source_list|join:", " }}</div>
|
|
{% endif %}
|
|
{% if proposed_status_changes %}
|
|
<div>Proposed status changed by {{ proposed_status_changes|urlize_related_source_list|join:", " }}</div>
|
|
{% endif %}
|
|
{% if rfc_aliases %}<div>Also known as {{ rfc_aliases|join:", "|urlize_ietf_docs }}</div>{% endif %}
|
|
{% if draft_name %}
|
|
<div>
|
|
Was
|
|
<a href="{% url 'ietf.doc.views_doc.document_main' name=draft_name %}">{{ draft_name }}</a>
|
|
{% if submission %}({{ submission|safe }}){% endif %}
|
|
</div>
|
|
{% endif %}
|
|
{% else %}
|
|
{% if snapshot and doc.doc.get_state_slug == 'rfc' %}
|
|
<div{% if document_html %} class="alert alert-warning small"{% endif %}>This is an older version of an Internet-Draft that was ultimately published as <a href="{% url 'ietf.doc.views_doc.document_html' name=doc.doc.canonical_name %}">{{doc.doc.canonical_name|prettystdname}}</a>.</div>
|
|
{% elif snapshot and doc.rev != latest_rev %}
|
|
<div{% if document_html %} class="alert alert-warning small"{% endif %}>This is an older version of an Internet-Draft whose latest revision state is "{{ doc.doc.get_state }}".</div>
|
|
{% else %}
|
|
<span class="{% if doc.get_state_slug == 'active' %}text-success{% elif doc.get_state_slug == 'expired' or doc.get_state_slug == 'repl' %}text-danger{% endif %}">{% if snapshot and doc.rev == latest_rev %}{{ doc.doc.get_state }}{% else %}{{ doc.get_state }}{% endif %} Internet-Draft</span>
|
|
{% if submission %}({{ submission|safe }}){% endif %}
|
|
{% if resurrected_by %}- resurrect requested by {{ resurrected_by }}{% endif %}
|
|
{% endif %}
|
|
{% endif %}
|
|
{% if doc.get_state_slug != "active" and doc.get_state_slug != "rfc" %}
|
|
<div class="badge rounded-pill text-bg-warning{% if not document_html %} float-end{% endif %}">
|
|
Expired & archived
|
|
</div>
|
|
{% endif %}
|
|
</td>
|
|
</tr>
|
|
{% if document_html %}
|
|
<tr>
|
|
<td></td>
|
|
<th scope="row">Select version</th>
|
|
<td class="edit"></td>
|
|
<td>
|
|
{% include "doc/revisions_list.html" with document_html=document_html %}
|
|
</td>
|
|
</tr>
|
|
{% if diff_revisions|length > 1 %}
|
|
<tr>
|
|
<td></td>
|
|
<th scope="row">Compare versions</th>
|
|
<td class="edit"></td>
|
|
<td>
|
|
{% include "doc/document_history_form.html" with doc=doc diff_revisions=diff_revisions action=rfcdiff_base_url document_html=document_html snapshot=snapshot only %}
|
|
</td>
|
|
</tr>
|
|
{% endif %}
|
|
{% endif %}
|
|
<tr>
|
|
<td></td>
|
|
<th scope="row">Author{% if doc.pk %}{{ doc.authors|pluralize }}{% endif %}</th>
|
|
<td class="edit">
|
|
{% if can_edit_authors %}
|
|
<a class="btn btn-primary btn-sm"
|
|
href="{% url 'ietf.doc.views_doc.edit_authors' name=doc.name %}">Edit</a>
|
|
{% endif %}
|
|
</td>
|
|
<td>
|
|
{# Implementation that uses the current primary email for each author #}
|
|
{% if doc.pk %}{% for author in doc.authors %}
|
|
{% person_link author %}{% if not forloop.last %},{% endif %}
|
|
{% endfor %}{% endif %}
|
|
{% if document_html and not snapshot or document_html and doc.rev == latest_rev%}
|
|
<br>
|
|
<a class="btn btn-primary btn-sm mt-1" href="mailto:{{ doc.name }}@ietf.org?subject={{ doc.name}}" title="Send email to the document authors">Email authors</a>
|
|
{% endif %}
|
|
</td>
|
|
</tr>
|
|
{% if not document_html %}
|
|
{# FIXME: This shows the date of the last history event, which is not what participants necessarily expect here. #}
|
|
<tr>
|
|
<td></td>
|
|
<th scope="row">Last updated</th>
|
|
<td class="edit"></td>
|
|
<td>
|
|
{{ doc.time|date:"Y-m-d" }}
|
|
{% if latest_revision and latest_revision.time|date:"Y-m-d" != doc.time|date:"Y-m-d" %}
|
|
<span class="text-body-secondary">(Latest revision {{ latest_revision.time|date:"Y-m-d" }})</span>
|
|
{% endif %}
|
|
</td>
|
|
</tr>
|
|
{% endif %}
|
|
{% if replaces or not document_html and can_edit_stream_info %}
|
|
<tr>
|
|
<td></td>
|
|
<th scope="row">Replaces</th>
|
|
<td class="edit">
|
|
{% if can_edit_stream_info and not snapshot %}
|
|
<a class="btn btn-primary btn-sm"
|
|
href="{% url 'ietf.doc.views_draft.replaces' name=doc.name %}">Edit</a>
|
|
{% endif %}
|
|
</td>
|
|
<td>
|
|
{% if replaces %}
|
|
{% if document_html %}
|
|
{{ replaces|urlize_related_target_list:document_html|join:"<br>" }}
|
|
{% else %}
|
|
{{ replaces|urlize_related_target_list:document_html|join:", " }}
|
|
{% endif %}
|
|
{% else %}
|
|
<span class="text-body-secondary">(None)</span>
|
|
{% endif %}
|
|
</td>
|
|
</tr>
|
|
{% endif %}
|
|
{% if replaced_by %}
|
|
<tr>
|
|
<td></td>
|
|
<th scope="row">
|
|
Replaced by
|
|
</th>
|
|
<td class="edit">
|
|
</td>
|
|
<td>
|
|
{% if document_html %}
|
|
{{ replaced_by|urlize_related_source_list:document_html|join:"<br>" }}
|
|
{% else %}
|
|
{{ replaced_by|urlize_related_source_list:document_html|join:", " }}
|
|
{% endif %}
|
|
</td>
|
|
</tr>
|
|
{% endif %}
|
|
{% if can_view_possibly_replaces %}
|
|
{% if possibly_replaces %}
|
|
<tr>
|
|
<td></td>
|
|
<th scope="row">
|
|
Possibly Replaces
|
|
</th>
|
|
<td class="edit">
|
|
{% if can_edit_replaces and not snapshot %}
|
|
<a class="btn btn-primary btn-sm"
|
|
href="{% url 'ietf.doc.views_draft.review_possibly_replaces' name=doc.name %}">
|
|
Edit
|
|
</a>
|
|
{% endif %}
|
|
</td>
|
|
<td>
|
|
{% if document_html %}
|
|
{{ possibly_replaces|urlize_related_target_list:document_html|join:"<br>" }}
|
|
{% else %}
|
|
{{ possibly_replaces|urlize_related_target_list:document_html|join:", " }}
|
|
{% endif %}
|
|
</td>
|
|
</tr>
|
|
{% endif %}
|
|
{% if possibly_replaced_by %}
|
|
<tr>
|
|
<td></td>
|
|
<th scope="row">
|
|
Possibly Replaced By
|
|
</th>
|
|
<td class="edit">
|
|
{% if can_edit_replaces and not snapshot %}
|
|
{% comment %}<a class="btn btn-primary btn-sm"
|
|
href="{% url 'ietf.doc.views_draft.review_possibly_replaces' name=doc.name %}">Edit</a>{% endcomment %}
|
|
{% endif %}
|
|
</td>
|
|
<td>
|
|
{% if document_html %}
|
|
{{ possibly_replaced_by|urlize_related_source_list:document_html|join:"<br>" }}
|
|
{% else %}
|
|
{{ possibly_replaced_by|urlize_related_source_list:document_html|join:", " }}
|
|
{% endif %}
|
|
</td>
|
|
</tr>
|
|
{% endif %}
|
|
{% endif %}
|
|
<tr>
|
|
<td></td>
|
|
<th scope="row">
|
|
RFC stream
|
|
</th>
|
|
<td class="edit">
|
|
{% if can_change_stream and not snapshot %}
|
|
<a class="btn btn-primary btn-sm"
|
|
href="{% url 'ietf.doc.views_draft.change_stream' name=doc.name %}">
|
|
Edit
|
|
</a>
|
|
{% endif %}
|
|
</td>
|
|
<td {% if stream_desc == "(None)" %}class="text-body-secondary"{%endif%}>
|
|
{% if stream_desc != "(None)" %}
|
|
{% if doc.stream.name|lower in 'iab,irtf,ise,editorial' %}
|
|
<a href="{% url 'ietf.group.views.stream_documents' acronym=doc.stream.name|lower %}">
|
|
{% endif %}
|
|
{% if document_html %}
|
|
{% if doc.stream.name|lower in 'iab,ietf,irtf' %}
|
|
{% include "logo.html" with org=doc.stream.name|lower classes="w-25 mt-1" title=stream_desc nor=True only %}
|
|
{% else %}
|
|
{{ stream_desc }}
|
|
{% endif %}
|
|
{% else %}
|
|
{{ stream_desc }}
|
|
{% endif %}
|
|
{% if doc.stream.name|lower in 'iab,irtf,ise,editorial' %}
|
|
</a>
|
|
{% endif %}
|
|
{% else %}
|
|
{{ stream_desc }}
|
|
{% endif %}
|
|
</td>
|
|
</tr>
|
|
{% if doc.get_state_slug != "rfc" and not snapshot %}
|
|
<tr>
|
|
<td></td>
|
|
<th scope="row">
|
|
Intended RFC status
|
|
</th>
|
|
<td class="edit">
|
|
{% if can_edit_stream_info and not snapshot %}
|
|
<a class="btn btn-primary btn-sm"
|
|
href="{% url 'ietf.doc.views_draft.change_intention' name=doc.name %}">
|
|
Edit
|
|
</a>
|
|
{% endif %}
|
|
</td>
|
|
<td>
|
|
{% if doc.intended_std_level %}
|
|
{{ doc.intended_std_level }}
|
|
{% else %}
|
|
<span class="text-body-secondary">
|
|
(None)
|
|
</span>
|
|
{% endif %}
|
|
</td>
|
|
</tr>
|
|
{% endif %}
|
|
<tr>
|
|
<td></td>
|
|
<th scope="row">
|
|
{% if document_html %}Other formats{% else %}Formats{% endif %}
|
|
</th>
|
|
<td class="edit">
|
|
</td>
|
|
<td>
|
|
{% if document_html %}
|
|
{% include "doc/document_format_buttons.html" with skip_format="htmlized" %}
|
|
{% else %}
|
|
{% include "doc/document_format_buttons.html" %}
|
|
{% endif %}
|
|
</td>
|
|
</tr>
|
|
{% if not document_html %}
|
|
{% for check in doc.submission.latest_checks %}
|
|
{% if check.passed != None and check.symbol.strip %}
|
|
<tr>
|
|
<td></td>
|
|
<th scope="row">
|
|
{{ check.checker|title }}
|
|
</th>
|
|
<td class="edit">
|
|
</td>
|
|
<td>
|
|
{% if check.errors or check.warnings %}
|
|
<span class="checker-warning"
|
|
data-bs-toggle="modal"
|
|
data-bs-target="#check-{{ check.pk }}"
|
|
title="{{ check.checker|title }} returned warnings or errors.">
|
|
{{ check.symbol|safe }}
|
|
</span>
|
|
{% else %}
|
|
<span class="checker-success"
|
|
data-bs-toggle="modal"
|
|
data-bs-target="#check-{{ check.pk }}"
|
|
title="{{ check.checker|title }} passed">
|
|
{{ check.symbol|safe }}
|
|
</span>
|
|
{% endif %}
|
|
<a href="#"
|
|
data-bs-toggle="modal"
|
|
data-bs-target="#check-{{ check.pk }}">
|
|
{{ check.errors }} errors, {{ check.warnings }} warnings
|
|
</a>
|
|
{% include "doc/yang-check-modal-overlay.html" %}
|
|
</td>
|
|
</tr>
|
|
{% endif %}
|
|
{% endfor %}
|
|
{% if review_assignments or can_request_review %}
|
|
<tr>
|
|
<td></td>
|
|
<th scope="row">
|
|
Reviews
|
|
</th>
|
|
<td class="edit">
|
|
</td>
|
|
<td>
|
|
{% for review_assignment in review_assignments %}
|
|
{% include "doc/review_assignment_summary.html" with current_doc_name=doc.name current_rev=doc.rev review_assignment=review_assignment only %}
|
|
{% endfor %}
|
|
{% for review_request in review_requests %}
|
|
{% include "doc/review_request_summary.html" with review_request=review_request only %}
|
|
{% endfor %}
|
|
{% if no_review_from_teams %}
|
|
{% for team in no_review_from_teams %}
|
|
{{ team.acronym.upper }}{% if not forloop.last %},{% endif %}
|
|
{% endfor %}
|
|
will not review this version
|
|
{% endif %}
|
|
{% if can_request_review or can_submit_unsolicited_review_for_teams %}
|
|
<div {% if review_assignments or no_review_from_teams %}class="mt-3"{% endif %}>
|
|
{% if can_request_review %}
|
|
<a class="btn btn-primary btn-sm"
|
|
href="{% url "ietf.doc.views_review.request_review" doc.name %}">
|
|
<i class="bi bi-check-circle">
|
|
</i>
|
|
Request review
|
|
</a>
|
|
{% endif %}
|
|
{% if can_submit_unsolicited_review_for_teams|length == 1 %}
|
|
<a class="btn btn-primary btn-sm"
|
|
href="{% url "ietf.doc.views_review.complete_review" doc.name can_submit_unsolicited_review_for_teams.0.acronym %}">
|
|
<i class="bi bi-pencil-square">
|
|
</i>
|
|
Submit unsolicited review
|
|
</a>
|
|
{% elif can_submit_unsolicited_review_for_teams %}
|
|
<a class="btn btn-primary btn-sm"
|
|
href="{% url "ietf.doc.views_review.submit_unsolicited_review_choose_team" doc.name %}">
|
|
<i class="bi bi-pencil-square">
|
|
</i>
|
|
Submit unsolicited review
|
|
</a>
|
|
{% endif %}
|
|
</div>
|
|
{% endif %}
|
|
</td>
|
|
</tr>
|
|
{% endif %}
|
|
{% if conflict_reviews %}
|
|
<tr>
|
|
<td></td>
|
|
<th scope="row">
|
|
IETF conflict review
|
|
</th>
|
|
<td class="edit">
|
|
</td>
|
|
<td>
|
|
{{ conflict_reviews|join:", "|urlize_ietf_docs }}
|
|
</td>
|
|
</tr>
|
|
{% endif %}
|
|
{% endif %}
|
|
{% with doc.docextresource_set.all as resources %}
|
|
{% if resources or doc.group and doc.group.list_archive or can_edit_stream_info or can_edit_individual %}
|
|
<tr>
|
|
<td>
|
|
</td>
|
|
<th scope="row">
|
|
Additional resources
|
|
</th>
|
|
<td class="edit">
|
|
{% if can_edit_stream_info or can_edit_individual %}
|
|
<a class="btn btn-primary btn-sm"
|
|
href="{% url 'ietf.doc.views_draft.edit_doc_extresources' name=doc.name %}">
|
|
Edit
|
|
</a>
|
|
{% endif %}
|
|
</td>
|
|
<td>
|
|
{% if resources or doc.group and doc.group.list_archive %}
|
|
{% for resource in resources|dictsort:"display_name" %}
|
|
{% if resource.name.type.slug == 'url' or resource.name.type.slug == 'email' %}
|
|
<a href="{{ resource.value }}" title="{{ resource.name.name }}">
|
|
{% firstof resource.display_name resource.name.name %}
|
|
</a>
|
|
<br>
|
|
{# Maybe make how a resource displays itself a method on the class so templates aren't doing this switching #}
|
|
{% else %}
|
|
<span title="{{ resource.name.name }}">
|
|
{% firstof resource.display_name resource.name.name %}: {{ resource.value|escape }}
|
|
</span>
|
|
<br>
|
|
{% endif %}
|
|
{% endfor %}
|
|
{% if doc.group and doc.group.list_archive %}
|
|
{% if doc.group.list_archive|startswith:settings.MAILING_LIST_ARCHIVE_URL %}
|
|
<a href="{{ doc.group.list_archive }}?q={{ doc.name }}">
|
|
Mailing list discussion
|
|
</a>
|
|
{% elif doc.group.list_archive|is_valid_url %}
|
|
<a href="{{ doc.group.list_archive }}">
|
|
Mailing list discussion
|
|
</a>
|
|
{% else %}
|
|
{{ doc.group.list_archive|urlencode }}
|
|
{% endif %}
|
|
{% endif %}
|
|
{% endif %}
|
|
</td>
|
|
</tr>
|
|
{% endif %}
|
|
{% endwith %}
|
|
</tbody> |