blob: 311cfe4ca743215814c695f7aee4642ed5130a2b [file] [log] [blame]
/**
* @license
* Copyright (C) 2020 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.
*/
import {html} from '@polymer/polymer/lib/utils/html-tag.js';
export const htmlTemplate = html`
<style include="shared-styles">
:host {
display: table;
width: 100%;
}
.status {
color: #FFA62F;
display: inline-block;
text-align: center;
font-family: var(--monospace-font-family);
font-size: var(--font-size-mono);
line-height: var(--line-height-mono);
}
.approved.status {
color: var(--vote-text-color-recommended);
}
.rejected.status {
color: var(--vote-text-color-disliked);
}
iron-icon {
color: inherit;
}
.status iron-icon {
vertical-align: top;
}
section {
display: table-row;
}
.show-hide {
float: right;
}
.title {
min-width: 10em;
padding: var(--spacing-s) var(--spacing-m) 0 var(--requirements-horizontal-padding);
}
.value {
padding: var(--spacing-s) 0 0 0;
}
.title,
.value {
display: table-cell;
vertical-align: top;
}
.hidden {
display: none;
}
.showHide {
cursor: pointer;
}
.showHide .title {
padding-bottom: var(--spacing-m);
padding-top: var(--spacing-l);
}
.showHide .value {
padding-top: 0;
vertical-align: middle;
}
.showHide iron-icon {
color: var(--deemphasized-text-color);
float: right;
}
.spacer {
height: var(--spacing-m);
}
</style>
<template is="dom-repeat" items="[[_requirements]]">
<section>
<div class="title requirement">
<span class\$="status [[item.style]]">
<iron-icon class="icon" icon="[[_computeRequirementIcon(item.satisfied)]]"></iron-icon>
</span>
<gr-limited-text class="name" limit="40" text="[[item.fallback_text]]"></gr-limited-text>
</div>
</section>
</template>
<template is="dom-repeat" items="[[_requiredLabels]]">
<section>
<div class="title">
<span class\$="status [[item.style]]">
<iron-icon class="icon" icon="[[item.icon]]"></iron-icon>
</span>
<gr-limited-text class="name" limit="40" text="[[item.label]]"></gr-limited-text>
</div>
<div class="value">
<gr-label-info change="{{change}}" account="[[account]]" mutable="[[mutable]]" label="[[item.label]]" label-info="[[item.labelInfo]]"></gr-label-info>
</div>
</section>
</template>
<section class="spacer"></section>
<section class\$="spacer [[_computeShowOptional(_optionalLabels.*)]]"></section>
<section show-bottom-border\$="[[_showOptionalLabels]]" on-click="_handleShowHide" class\$="showHide [[_computeShowOptional(_optionalLabels.*)]]">
<div class="title">Other labels</div>
<div class="value">
<iron-icon id="showHide" icon="[[_computeShowHideIcon(_showOptionalLabels)]]">
</iron-icon>
</div>
</section>
<template is="dom-repeat" items="[[_optionalLabels]]">
<section class\$="optional [[_computeSectionClass(_showOptionalLabels)]]">
<div class="title">
<span class\$="status [[item.style]]">
<template is="dom-if" if="[[item.icon]]">
<iron-icon class="icon" icon="[[item.icon]]"></iron-icon>
</template>
<template is="dom-if" if="[[!item.icon]]">
<span>[[_computeLabelValue(item.labelInfo.value)]]</span>
</template>
</span>
<gr-limited-text class="name" limit="40" text="[[item.label]]"></gr-limited-text>
</div>
<div class="value">
<gr-label-info change="{{change}}" account="[[account]]" mutable="[[mutable]]" label="[[item.label]]" label-info="[[item.labelInfo]]"></gr-label-info>
</div>
</section>
</template>
<section class\$="spacer [[_computeShowOptional(_optionalLabels.*)]] [[_computeSectionClass(_showOptionalLabels)]]"></section>
`;