blob: ff678ac6176ab02cad550a161109f0d3b77ce44b [file] [log] [blame]
// Copyright 2017 The Chromium Authors. All rights reserved.
// Use of this source code is governed by a BSD-style license that can be
// found in the LICENSE file.
import 'chrome://resources/cr_elements/cr_button/cr_button.m.js';
import 'chrome://resources/cr_elements/cr_dialog/cr_dialog.m.js';
import 'chrome://resources/cr_elements/shared_style_css.m.js';
import 'chrome://resources/polymer/v3_0/paper-spinner/paper-spinner-lite.js';
import './code_section.js';
import './strings.m.js';
import {assert} from 'chrome://resources/js/assert.m.js';
import {html, Polymer} from 'chrome://resources/polymer/v3_0/polymer/polymer_bundled.min.js';
/** @interface */
export class LoadErrorDelegate {
/**
* Attempts to load the previously-attempted unpacked extension.
* @param {string} retryId
* @return {!Promise}
*/
retryLoadUnpacked(retryId) {}
}
Polymer({
is: 'extensions-load-error',
_template: html`{__html_template__}`,
properties: {
/** @type {LoadErrorDelegate} */
delegate: Object,
/** @type {chrome.developerPrivate.LoadError} */
loadError: Object,
/** @private */
retrying_: Boolean,
},
observers: [
'observeLoadErrorChanges_(loadError)',
],
show: function() {
/** @type {!CrDialogElement} */ (this.$.dialog).showModal();
},
close: function() {
/** @type {!CrDialogElement} */ (this.$.dialog).close();
},
/** @private */
onRetryTap_: function() {
this.retrying_ = true;
this.delegate.retryLoadUnpacked(this.loadError.retryGuid)
.then(
() => {
this.close();
},
loadError => {
this.loadError =
/** @type {chrome.developerPrivate.LoadError} */ (loadError);
this.retrying_ = false;
});
},
/** @private */
observeLoadErrorChanges_: function() {
assert(this.loadError);
const source = this.loadError.source;
// CodeSection expects a RequestFileSourceResponse, rather than an
// ErrorFileSource. Massage into place.
// TODO(devlin): Make RequestFileSourceResponse use ErrorFileSource.
/** @type {!chrome.developerPrivate.RequestFileSourceResponse} */
const codeSectionProperties = {
beforeHighlight: source ? source.beforeHighlight : '',
highlight: source ? source.highlight : '',
afterHighlight: source ? source.afterHighlight : '',
title: '',
message: this.loadError.error,
};
this.$.code.code = codeSectionProperties;
},
});