#review-panel .review-panel-toolbar resolved-comments-dropdown( entries="reviewPanel.entries" threads="reviewPanel.commentThreads" docs="docs" ) span.review-panel-toolbar-label(ng-click="editor.wantTrackChanges = true;", ng-if="editor.wantTrackChanges === false") Track Changes is strong off span.review-panel-toolbar-label(ng-click="editor.wantTrackChanges = false;", ng-if="editor.wantTrackChanges === true") Track Changes is strong on review-panel-toggle(ng-if="editor.wantTrackChanges == editor.trackChanges", ng-model="editor.wantTrackChanges") span.review-panel-toolbar-spinner(ng-if="editor.wantTrackChanges != editor.trackChanges") i.fa.fa-spin.fa-spinner .rp-entry-list( review-panel-sorted ng-if="reviewPanel.subView === SubViews.CUR_FILE" ) .rp-entry-list-inner .rp-entry-wrapper( ng-repeat="(entry_id, entry) in reviewPanel.entries[editor.open_doc_id]" ) div(ng-if="entry.type === 'insert' || entry.type === 'delete'") change-entry( entry="entry" user="users[entry.metadata.user_id]" on-reject="rejectChange(entry_id);" on-accept="acceptChange(entry_id);" on-indicator-click="toggleReviewPanel();" ) div(ng-if="entry.type === 'comment'") comment-entry( entry="entry" threads="reviewPanel.commentThreads" on-resolve="resolveComment(entry, entry_id)" on-reply="submitReply(entry, entry_id);" on-indicator-click="toggleReviewPanel();" ) div(ng-if="entry.type === 'add-comment'") add-comment-entry( on-start-new="startNewComment();" on-submit="submitNewComment(content);" on-cancel="cancelNewComment();" on-indicator-click="toggleReviewPanel();" ) .rp-entry-list( ng-if="reviewPanel.subView === SubViews.OVERVIEW" ) .rp-overview-loading(ng-if="reviewPanel.overview.loading") i.fa.fa-spinner.fa-spin .rp-overview-file( ng-repeat="doc in docs" ng-if="!reviewPanel.overview.loading" ) .rp-overview-file-header( ng-if="reviewPanel.entries[doc.doc.id] | notEmpty" ) | {{ doc.path }} .rp-entry-wrapper( ng-repeat="(entry_id, entry) in reviewPanel.entries[doc.doc.id] | orderOverviewEntries" ) div(ng-if="entry.type === 'insert' || entry.type === 'delete'") change-entry( entry="entry" user="users[entry.metadata.user_id]" on-indicator-click="toggleReviewPanel();" ng-click="gotoEntry(doc_id, entry)" ) div(ng-if="entry.type === 'comment'") comment-entry( entry="entry" threads="reviewPanel.commentThreads" on-reply="submitReply(entry, entry_id);" on-indicator-click="toggleReviewPanel();" ng-click="gotoEntry(doc_id, entry)" ) .rp-nav a.rp-nav-item( href ng-click="setSubView(SubViews.CUR_FILE);" ng-class="{ 'rp-nav-item-active' : reviewPanel.subView === SubViews.CUR_FILE }" ) i.fa.fa-file-text-o span.rp-nav-label Current file a.rp-nav-item( href ng-click="setSubView(SubViews.OVERVIEW);" ng-class="{ 'rp-nav-item-active' : reviewPanel.subView === SubViews.OVERVIEW }" ) i.fa.fa-list span.rp-nav-label Overview script(type='text/ng-template', id='changeEntryTemplate') div .rp-entry-callout( ng-class="'rp-entry-callout-' + entry.type" ) .rp-entry-indicator( ng-switch="entry.type" ng-class="{ 'rp-entry-indicator-focused': entry.focused }" ng-click="onIndicatorClick();" ) i.fa.fa-pencil(ng-switch-when="insert") i.rp-icon-delete(ng-switch-when="delete") .rp-entry( ng-class="[ 'rp-entry-' + entry.type, (entry.focused ? 'rp-entry-focused' : '')]" ) .rp-entry-body .rp-entry-action-icon(ng-switch="entry.type") i.fa.fa-pencil(ng-switch-when="insert") i.rp-icon-delete(ng-switch-when="delete") .rp-entry-details .rp-entry-description(ng-switch="entry.type") span(ng-switch-when="insert") Added  ins.rp-content-highlight {{ entry.content }} span(ng-switch-when="delete") Deleted  del.rp-content-highlight {{ entry.content }} .rp-entry-metadata | {{ entry.metadata.ts | date : 'MMM d, y h:mm a' }} •  span.rp-entry-user(style="color: hsl({{ user.hue }}, 70%, 40%);") {{ user.name }} .rp-entry-actions a.rp-entry-button(href, ng-click="onReject();") i.fa.fa-times |  Reject a.rp-entry-button(href, ng-click="onAccept();") i.fa.fa-check |  Accept script(type='text/ng-template', id='commentEntryTemplate') div .rp-entry-callout.rp-entry-callout-comment .rp-entry-indicator( ng-class="{ 'rp-entry-indicator-focused': entry.focused }" ng-click="onIndicatorClick();" ) i.fa.fa-comment .rp-entry.rp-entry-comment( ng-class="{ 'rp-entry-focused': entry.focused }" ) div .rp-comment( ng-repeat="comment in threads[entry.thread_id].messages track by comment.id" ) p.rp-comment-content span.rp-entry-user( style="color: hsl({{ comment.user.hue }}, 70%, 40%);" ng-if="$first || comment.user.id !== threads[entry.thread_id].messages[$index - 1].user.id" ) {{ comment.user.name }}:  | {{ comment.content }} .rp-entry-metadata | {{ comment.timestamp | date : 'MMM d, y h:mm a' }} .rp-comment-reply textarea.rp-comment-input( ng-model="entry.replyContent" ng-keypress="handleCommentReplyKeyPress($event);" stop-propagation="click" placeholder="{{ 'Hit \"Enter\" to reply' + (entry.resolved ? ' and re-open' : '') }}" ) .rp-entry-actions a.rp-entry-button(href, ng-click="onResolve();") i.fa.fa-inbox |  Resolve a.rp-entry-button(href, ng-click="onReply();") i.fa.fa-reply |  Reply script(type='text/ng-template', id='resolvedCommentEntryTemplate') .rp-resolved-comment div .rp-resolved-comment-context | Quoted text on  span.rp-resolved-comment-context-file {{ doc.doc.name }} p.rp-resolved-comment-context-quote {{ thread.content }} .rp-comment( ng-repeat="comment in thread.messages track by comment.id" ) p.rp-comment-content span.rp-entry-user( style="color: hsl({{ comment.user.hue }}, 70%, 40%);" ng-if="$first || comment.user.id !== thread.messages[$index - 1].user.id" ) {{ comment.user.name }}:  | {{ comment.content }} .rp-entry-metadata | {{ comment.timestamp | date : 'MMM d, y h:mm a' }} .rp-comment.rp-comment-resolver p.rp-comment-resolver-content span.rp-entry-user( style="color: hsl({{ thread.resolved_by_user.hue }}, 70%, 40%);" ) {{ thread.resolved_by_user.name }}:  | Marked as resolved. .rp-entry-metadata | {{ thread.resolved_at | date : 'MMM d, y h:mm a' }} .rp-entry-actions a.rp-entry-button(href, ng-click="onUnresolve();") |  Re-open a.rp-entry-button(href, ng-click="onDelete();") |  Delete script(type='text/ng-template', id='addCommentEntryTemplate') div .rp-entry-callout.rp-entry-callout-add-comment .rp-entry-indicator( ng-if="!commentState.adding" ng-click="startNewComment(); onIndicatorClick();" tooltip="Add a comment" tooltip-placement="right" tooltip-append-to-body="true" ) i.fa.fa-commenting .rp-entry.rp-entry-add-comment( ng-class="[ (state.isAdding ? 'rp-entry-adding-comment' : ''), (entry.focused ? 'rp-entry-focused' : '')]" ) a.rp-add-comment-btn( href ng-if="!state.isAdding" ng-click="startNewComment();" ) i.fa.fa-comment |  Add comment div(ng-if="state.isAdding") .rp-new-comment textarea.rp-comment-input( ng-model="state.content" ng-keypress="handleCommentKeyPress($event);" placeholder="Add your comment here" ) .rp-entry-actions a.rp-entry-button(href, ng-click="cancelNewComment();") i.fa.fa-times |  Cancel a.rp-entry-button(href, ng-click="submitNewComment()") i.fa.fa-comment |  Comment script(type='text/ng-template', id='resolvedCommentsDropdownTemplate') .resolved-comments //- .resolved-comments-backdrop( //- ng-class="{ 'resolved-comments-backdrop-visible' : state.isOpen }" //- ng-click="state.isOpen = !state.isOpen" //- ) a.resolved-comments-toggle( href ng-click="state.isOpen = !state.isOpen" ) i.fa.fa-inbox .resolved-comments-dropdown( ng-class="{ 'resolved-comments-dropdown-open' : state.isOpen }" ) div( ng-repeat="doc in docs" ) resolved-comment-entry( ng-repeat="thread in resolvedCommentsPerFile[doc.doc.id]" thread="thread" doc="doc" )