chrome-devtools-frontend
Version:
Chrome DevTools UI
77 lines (66 loc) • 2.21 kB
JavaScript
// Copyright 2014 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 * as i18n from '../i18n/i18n.js';
import * as UI from '../ui/ui.js';
export const UIStrings = {
/**
*@description Text in Add Source Map URLDialog of the Sources panel
*/
sourceMapUrl: 'Source map URL: ',
/**
*@description Text to add something
*/
add: 'Add',
};
const str_ = i18n.i18n.registerUIStrings('sources/AddSourceMapURLDialog.js', UIStrings);
const i18nString = i18n.i18n.getLocalizedString.bind(undefined, str_);
export class AddSourceMapURLDialog extends UI.Widget.HBox {
/**
* @param {function(string):void} callback
*/
constructor(callback) {
super(/* isWebComponent */ true);
this.registerRequiredCSS('sources/dialog.css', {enableLegacyPatching: false});
this.contentElement.createChild('label').textContent = i18nString(UIStrings.sourceMapUrl);
this._input = UI.UIUtils.createInput('add-source-map', 'text');
this._input.addEventListener('keydown', this._onKeyDown.bind(this), false);
this.contentElement.appendChild(this._input);
const addButton = UI.UIUtils.createTextButton(i18nString(UIStrings.add), this._apply.bind(this));
this.contentElement.appendChild(addButton);
this._dialog = new UI.Dialog.Dialog();
this._dialog.setSizeBehavior(UI.GlassPane.SizeBehavior.MeasureContent);
this._dialog.setDefaultFocusedElement(this._input);
this._callback = callback;
}
/**
* @override
*/
show() {
super.show(this._dialog.contentElement);
// UI.Dialog extends GlassPane and overrides the `show` method with a wider
// accepted type. However, TypeScript uses the supertype declaration to
// determine the full type, which requires a `!Document`.
// @ts-ignore
this._dialog.show();
}
/**
* @param {string} value
*/
_done(value) {
this._dialog.hide();
this._callback(value);
}
_apply() {
this._done(this._input.value);
}
/**
* @param {!KeyboardEvent} event
*/
_onKeyDown(event) {
if (event.key === 'Enter') {
event.consume(true);
this._apply();
}
}
}