
After change 290410, we have converted gr-rest-api into a service and no longer require this import. Change-Id: I7990253fc5c25bab8d9d28ee594754a2eb78947d
104 lines
3.1 KiB
TypeScript
104 lines
3.1 KiB
TypeScript
/**
|
|
* @license
|
|
* Copyright (C) 2017 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 '../gr-tooltip-content/gr-tooltip-content';
|
|
import '../../../styles/shared-styles';
|
|
import {GestureEventListeners} from '@polymer/polymer/lib/mixins/gesture-event-listeners';
|
|
import {LegacyElementMixin} from '@polymer/polymer/lib/legacy/legacy-element-mixin';
|
|
import {PolymerElement} from '@polymer/polymer/polymer-element';
|
|
import {htmlTemplate} from './gr-change-status_html';
|
|
import {customElement, property} from '@polymer/decorators';
|
|
|
|
enum ChangeStates {
|
|
MERGED = 'Merged',
|
|
ABANDONED = 'Abandoned',
|
|
MERGE_CONFLICT = 'Merge Conflict',
|
|
WIP = 'WIP',
|
|
PRIVATE = 'Private',
|
|
}
|
|
|
|
const WIP_TOOLTIP =
|
|
"This change isn't ready to be reviewed or submitted. " +
|
|
"It will not appear on dashboards unless you are CC'ed or assigned, " +
|
|
'and email notifications will be silenced until the review is started.';
|
|
|
|
const MERGE_CONFLICT_TOOLTIP =
|
|
'This change has merge conflicts. ' +
|
|
'Download the patch and run "git rebase master". ' +
|
|
'Upload a new patchset after resolving all merge conflicts.';
|
|
|
|
const PRIVATE_TOOLTIP =
|
|
'This change is only visible to its owner and ' +
|
|
'current reviewers (or anyone with "View Private Changes" permission).';
|
|
|
|
/** @extends PolymerElement */
|
|
@customElement('gr-change-status')
|
|
class GrChangeStatus extends GestureEventListeners(
|
|
LegacyElementMixin(PolymerElement)
|
|
) {
|
|
static get template() {
|
|
return htmlTemplate;
|
|
}
|
|
|
|
@property({type: Boolean, reflectToAttribute: true})
|
|
flat = false;
|
|
|
|
@property({type: String, observer: '_updateChipDetails'})
|
|
status?: ChangeStates;
|
|
|
|
@property({type: String})
|
|
tooltipText = '';
|
|
|
|
_computeStatusString(status: ChangeStates) {
|
|
if (status === ChangeStates.WIP && !this.flat) {
|
|
return 'Work in Progress';
|
|
}
|
|
return status;
|
|
}
|
|
|
|
_toClassName(str?: ChangeStates) {
|
|
return str ? str.toLowerCase().replace(/\s/g, '-') : '';
|
|
}
|
|
|
|
_updateChipDetails(status?: ChangeStates, previousStatus?: ChangeStates) {
|
|
if (previousStatus) {
|
|
this.classList.remove(this._toClassName(previousStatus));
|
|
}
|
|
this.classList.add(this._toClassName(status));
|
|
|
|
switch (status) {
|
|
case ChangeStates.WIP:
|
|
this.tooltipText = WIP_TOOLTIP;
|
|
break;
|
|
case ChangeStates.PRIVATE:
|
|
this.tooltipText = PRIVATE_TOOLTIP;
|
|
break;
|
|
case ChangeStates.MERGE_CONFLICT:
|
|
this.tooltipText = MERGE_CONFLICT_TOOLTIP;
|
|
break;
|
|
default:
|
|
this.tooltipText = '';
|
|
break;
|
|
}
|
|
}
|
|
}
|
|
|
|
declare global {
|
|
interface HTMLElementTagNameMap {
|
|
'gr-change-status': GrChangeStatus;
|
|
}
|
|
}
|