chrome-devtools-frontend
Version:
Chrome DevTools UI
48 lines (41 loc) • 1.72 kB
text/typescript
// Copyright 2020 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 Root from '../root/root.js';
import * as UI from '../ui/ui.js';
// eslint-disable-next-line rulesdir/es_modules_import
import type * as Accessibility from './accessibility.js';
let loadedAccessibilityModule: (typeof Accessibility|undefined);
export const UIStrings = {
/**
* @description Text for accessibility of the web page
*/
accessibility: 'Accessibility',
/**
* @description Command for showing the 'Accessibility' tool
*/
shoAccessibility: 'Show Accessibility',
};
const str_ = i18n.i18n.registerUIStrings('accessibility/accessibility-meta.ts', UIStrings);
const i18nString = i18n.i18n.getLazilyComputedLocalizedString.bind(undefined, str_);
async function loadAccessibilityModule(): Promise<typeof Accessibility> {
if (!loadedAccessibilityModule) {
// Side-effect import resources in module.json
await Root.Runtime.Runtime.instance().loadModulePromise('accessibility');
loadedAccessibilityModule = await import('./accessibility.js');
}
return loadedAccessibilityModule;
}
UI.ViewManager.registerViewExtension({
location: UI.ViewManager.ViewLocationValues.ELEMENTS_SIDEBAR,
id: 'accessibility.view',
title: i18nString(UIStrings.accessibility),
commandPrompt: i18nString(UIStrings.shoAccessibility),
order: 10,
persistence: UI.ViewManager.ViewPersistence.PERMANENT,
async loadView() {
const Accessibility = await loadAccessibilityModule();
return Accessibility.AccessibilitySidebarView.AccessibilitySidebarView.instance();
},
});