blob: 4715796890d5fa4b0e0b77dbe9a1b09895574afe [file] [log] [blame]
/**
* @license
* Copyright 2016 Google LLC
* SPDX-License-Identifier: Apache-2.0
*/
import {RevisionInfo, ChangeInfo, RequestPayload} from '../../../types/common';
import {EventType, ShowAlertEventDetail} from '../../../types/events';
import {PluginApi} from '../../../api/plugin';
import {UIActionInfo} from './gr-change-actions-js-api';
import {windowLocationReload} from '../../../utils/dom-util';
import {PopupPluginApi} from '../../../api/popup';
import {GrPopupInterface} from '../../plugins/gr-popup-interface/gr-popup-interface';
import {getAppContext} from '../../../services/app-context';
interface ButtonCallBacks {
onclick: (event: Event) => boolean;
}
export class GrPluginActionContext {
private popups: PopupPluginApi[] = [];
private readonly reporting = getAppContext().reportingService;
constructor(
public readonly plugin: PluginApi,
public readonly action: UIActionInfo,
public readonly change: ChangeInfo,
public readonly revision: RevisionInfo
) {}
popup(element: Node) {
this.plugin.popup().then(popApi => {
const popupEl = (popApi as GrPopupInterface)._getElement();
if (!popupEl) {
throw new Error('Popup element not found');
}
popupEl.appendChild(element);
this.popups.push(popApi);
});
}
hide() {
for (const popupApi of this.popups) {
popupApi.close();
}
this.popups.splice(0);
}
refresh() {
windowLocationReload();
}
textfield(): HTMLElement {
return document.createElement('paper-input');
}
br() {
return document.createElement('br');
}
msg(text: string) {
const label = document.createElement('gr-label');
label.appendChild(document.createTextNode(text));
return label;
}
div(...els: Node[]) {
const div = document.createElement('div');
for (const el of els) {
div.appendChild(el);
}
return div;
}
button(label: string, callbacks: ButtonCallBacks | undefined) {
const onClick = callbacks && callbacks.onclick;
const button = document.createElement('gr-button');
button.appendChild(document.createTextNode(label));
if (onClick) {
this.plugin.eventHelper(button).onTap(onClick);
}
return button;
}
checkbox() {
const checkbox = document.createElement('input');
checkbox.type = 'checkbox';
return checkbox;
}
label(checkbox: Node, title: string) {
return this.div(checkbox, this.msg(title));
}
prependLabel(title: string, checkbox: Node) {
return this.label(checkbox, title);
}
call(payload: RequestPayload, onSuccess: (result: unknown) => void) {
if (!this.action.method) return;
if (!this.action.__url) {
this.reporting.error(
new Error(`Unable to ${this.action.method} to ${this.action.__key}!`)
);
return;
}
this.plugin
.restApi()
.send(this.action.method, this.action.__url, payload)
.then(onSuccess)
.catch((error: unknown) => {
document.dispatchEvent(
new CustomEvent<ShowAlertEventDetail>(EventType.SHOW_ALERT, {
detail: {
message: `Plugin network error: ${error}`,
},
})
);
});
}
}