
Introduces the gr-syntax-layer element. This element works as an annotation layer that is configured with the diff and asynchronously computes/applies syntax for the diff. Introduces a custom build of Highlight.js which gr-syntax-layer makes use of. Building the script is documented in scripts/vendor/highlight/building.md. The layer is connected to the annotation pipeline in gr-diff-builder as the lowest layer and syntax processing is triggered only after a diff has been completely rendered. A number of styles are added to the gr-diff element for syntax markers. Tests added for gr-syntax-layer. Bug: Issue 3916 Change-Id: Ic33e40f4fe39dfce1a62de133cfaf32be5e3f25a
246 lines
7.0 KiB
HTML
246 lines
7.0 KiB
HTML
<!--
|
|
Copyright (C) 2015 The Android Open Source Project
|
|
|
|
Licensed under the Apache License, Version 2.0 (the "License");
|
|
you may not use this file except in compliance with the License.
|
|
You may obtain a copy of the License at
|
|
|
|
http://www.apache.org/licenses/LICENSE-2.0
|
|
|
|
Unless required by applicable law or agreed to in writing, software
|
|
distributed under the License is distributed on an "AS IS" BASIS,
|
|
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
See the License for the specific language governing permissions and
|
|
limitations under the License.
|
|
-->
|
|
|
|
<link rel="import" href="../../../bower_components/polymer/polymer.html">
|
|
<link rel="import" href="../../shared/gr-button/gr-button.html">
|
|
<link rel="import" href="../../shared/gr-rest-api-interface/gr-rest-api-interface.html">
|
|
<link rel="import" href="../gr-diff-builder/gr-diff-builder.html">
|
|
<link rel="import" href="../gr-diff-comment-thread/gr-diff-comment-thread.html">
|
|
<link rel="import" href="../gr-diff-highlight/gr-diff-highlight.html">
|
|
<link rel="import" href="../gr-diff-selection/gr-diff-selection.html">
|
|
|
|
<dom-module id="gr-diff">
|
|
<template>
|
|
<style>
|
|
:host {
|
|
--light-remove-highlight-color: #fee;
|
|
--dark-remove-highlight-color: #ffd4d4;
|
|
--light-add-highlight-color: #efe;
|
|
--dark-add-highlight-color: #d4ffd4;
|
|
}
|
|
.diffContainer {
|
|
border-bottom: 1px solid #eee;
|
|
border-top: 1px solid #eee;
|
|
display: flex;
|
|
font: 12px var(--monospace-font-family);
|
|
overflow-x: auto;
|
|
will-change: transform;
|
|
}
|
|
table {
|
|
border-collapse: collapse;
|
|
border-right: 1px solid #ddd;
|
|
}
|
|
.lineNum {
|
|
background-color: #eee;
|
|
}
|
|
.image-diff .gr-diff {
|
|
text-align: center;
|
|
}
|
|
.image-diff img {
|
|
max-width: 50em;
|
|
outline: 1px solid #ccc;
|
|
}
|
|
.image-diff label {
|
|
font-family: var(--font-family);
|
|
font-style: italic;
|
|
}
|
|
.diff-row.target-row.target-side-left .lineNum.left,
|
|
.diff-row.target-row.target-side-right .lineNum.right,
|
|
.diff-row.target-row.unified .lineNum {
|
|
background-color: #BBDEFB;
|
|
}
|
|
.diff-row.target-row.target-side-left .lineNum.left:before,
|
|
.diff-row.target-row.target-side-right .lineNum.right:before,
|
|
.diff-row.target-row.unified .lineNum:before {
|
|
color: #000;
|
|
}
|
|
.blank,
|
|
.content {
|
|
background-color: #fff;
|
|
}
|
|
.lineNum,
|
|
.content {
|
|
vertical-align: top;
|
|
white-space: pre;
|
|
}
|
|
.contextLineNum:before,
|
|
.lineNum:before {
|
|
display: inline-block;
|
|
color: #666;
|
|
content: attr(data-value);
|
|
padding: 0 .75em;
|
|
text-align: right;
|
|
width: 100%;
|
|
}
|
|
.canComment .lineNum[data-value] {
|
|
cursor: pointer;
|
|
}
|
|
.canComment .lineNum[data-value]:hover:before {
|
|
background-color: #ccc;
|
|
}
|
|
.canComment .lineNum[data-value="FILE"]:before {
|
|
content: 'File';
|
|
}
|
|
.content {
|
|
overflow: hidden;
|
|
/* Set max and min width since setting width on table cells still
|
|
allows them to shrink. */
|
|
max-width: var(--content-width, 80ch);
|
|
min-width: var(--content-width, 80ch);
|
|
}
|
|
.content.add .intraline,
|
|
.content.add.darkHighlight {
|
|
background-color: var(--dark-add-highlight-color);
|
|
}
|
|
.content.add.lightHighlight {
|
|
background-color: var(--light-add-highlight-color);
|
|
}
|
|
.content.remove .intraline,
|
|
.content.remove.darkHighlight {
|
|
background-color: var(--dark-remove-highlight-color);
|
|
}
|
|
.content.remove.lightHighlight {
|
|
background-color: var(--light-remove-highlight-color);
|
|
}
|
|
.contextControl {
|
|
background-color: #fef;
|
|
color: #849;
|
|
}
|
|
.contextControl gr-button {
|
|
display: inline-block;
|
|
font-family: var(--monospace-font-family);
|
|
text-decoration: none;
|
|
}
|
|
.contextControl td:not(.lineNum) {
|
|
text-align: center;
|
|
}
|
|
.br:after {
|
|
/* Line feed */
|
|
content: '\A';
|
|
}
|
|
.tab {
|
|
display: inline-block;
|
|
}
|
|
.tab.withIndicator:before {
|
|
color: #C62828;
|
|
/* >> character */
|
|
content: '\00BB';
|
|
position: absolute;
|
|
}
|
|
|
|
/* Syntax highlights */
|
|
/* Highlight.js emits the following classes that do not have styles here:
|
|
subst, symbol, class, function, doctag, meta-string, section,
|
|
builtin-name, bulletm, code, formula, quote, addition, deletion
|
|
See:
|
|
http://highlightjs.readthedocs.io/en/latest/css-classes-reference.html
|
|
*/
|
|
.gr-syntax-literal,
|
|
.gr-syntax-keyword,
|
|
.gr-syntax-selector-tag {
|
|
font-weight: bold;
|
|
color: #00f;
|
|
}
|
|
.gr-syntax-built_in {
|
|
color: #555;
|
|
}
|
|
.gr-syntax-type,
|
|
.gr-syntax-selector-pseudo,
|
|
.gr-syntax-template-variable {
|
|
color: #ff00e7;
|
|
}
|
|
.gr-syntax-number {
|
|
color: violet;
|
|
}
|
|
.gr-syntax-regexp,
|
|
.gr-syntax-variable,
|
|
.gr-syntax-selector-attr,
|
|
.gr-syntax-template-tag {
|
|
color: #FA8602;
|
|
}
|
|
.gr-syntax-string,
|
|
.gr-syntax-selector-id {
|
|
color: #018846;
|
|
}
|
|
.gr-syntax-title {
|
|
color: teal;
|
|
}
|
|
.gr-syntax-params {
|
|
color: red;
|
|
}
|
|
.gr-syntax-comment {
|
|
color: #af72a9;
|
|
font-style: italic;
|
|
}
|
|
.gr-syntax-meta {
|
|
color: #0091AD;
|
|
}
|
|
.gr-syntax-meta-keyword {
|
|
color: #00426b;
|
|
font-weight: bold;
|
|
}
|
|
.gr-syntax-tag {
|
|
color: #DB7C00;
|
|
}
|
|
.gr-syntax-name { /* XML/HTML Tag Name */
|
|
color: brown;
|
|
}
|
|
.gr-syntax-attr { /* XML/HTML Attribute */
|
|
color: #8C7250;
|
|
}
|
|
.gr-syntax-attribute { /* CSS Property */
|
|
color: #299596;
|
|
}
|
|
.gr-syntax-emphasis {
|
|
font-style: italic;
|
|
}
|
|
.gr-syntax-strong {
|
|
font-weight: bold;
|
|
}
|
|
.gr-syntax-link {
|
|
color: blue;
|
|
}
|
|
.gr-syntax-selector-class {
|
|
color: #1F71FF;
|
|
}
|
|
</style>
|
|
<div class$="[[_computeContainerClass(_loggedIn, viewMode)]]"
|
|
on-tap="_handleTap">
|
|
<gr-diff-selection>
|
|
<gr-diff-highlight
|
|
id="highlights"
|
|
logged-in="[[_loggedIn]]"
|
|
comments="{{_comments}}">
|
|
<gr-diff-builder
|
|
id="diffBuilder"
|
|
comments="[[_comments]]"
|
|
diff="[[_diff]]"
|
|
view-mode="[[viewMode]]"
|
|
is-image-diff="[[isImageDiff]]"
|
|
base-image="[[_baseImage]]"
|
|
revision-image="[[_revisionImage]]">
|
|
<table id="diffTable"></table>
|
|
</gr-diff-builder>
|
|
</gr-diff-highlight>
|
|
</gr-diff-selection>
|
|
</div>
|
|
<gr-rest-api-interface id="restAPI"></gr-rest-api-interface>
|
|
</template>
|
|
<script src="gr-diff-line.js"></script>
|
|
<script src="gr-diff-group.js"></script>
|
|
<script src="gr-diff.js"></script>
|
|
</dom-module>
|