UNPKG

chrome-devtools-frontend

Version:
126 lines (113 loc) 4.83 kB
// Copyright 2014 The Chromium Authors // Use of this source code is governed by a BSD-style license that can be // found in the LICENSE file. /* eslint-disable @devtools/no-imperative-dom-api */ import * as Common from '../../../../core/common/common.js'; import * as i18n from '../../../../core/i18n/i18n.js'; import * as Platform from '../../../../core/platform/platform.js'; import * as Settings from '../../../components/settings/settings.js'; import * as VisualLogging from '../../../visual_logging/visual_logging.js'; import * as UI from '../../legacy.js'; const UIStrings = { /** * @description Note when a setting change will require the user to reload DevTools */ srequiresReload: '*Requires reload', /** * @description Message to display if a setting change requires a reload of DevTools */ oneOrMoreSettingsHaveChanged: 'One or more settings have changed which requires a reload to take effect', } as const; const str_ = i18n.i18n.registerUIStrings('ui/legacy/components/settings_ui/SettingsUI.ts', UIStrings); const i18nString = i18n.i18n.getLocalizedString.bind(undefined, str_); export function createSettingCheckbox( name: Common.UIString.LocalizedString, setting: Common.Settings.Setting<boolean>, tooltip?: string): UI.UIUtils.CheckboxLabel { const label = UI.UIUtils.CheckboxLabel.create(name, undefined, undefined, setting.name); label.name = name; UI.UIUtils.bindCheckbox(label, setting); if (tooltip) { UI.Tooltip.Tooltip.install(label, tooltip); } return label; } const createSettingSelect = function( name: string, options: Common.Settings.SimpleSettingOption[], requiresReload: boolean|null, setting: Common.Settings.Setting<unknown>, subtitle?: string): HTMLElement { const container = document.createElement('div'); const settingSelectElement = container.createChild('p'); settingSelectElement.classList.add('settings-select'); const label = settingSelectElement.createChild('label'); const select = settingSelectElement.createChild('select'); label.textContent = name; if (subtitle) { container.classList.add('chrome-select-label'); label.createChild('p').textContent = subtitle; } select.setAttribute('jslog', `${VisualLogging.dropDown().track({change: true}).context(setting.name)}`); UI.ARIAUtils.bindLabelToControl(label, select); for (const option of options) { if (option.text && typeof option.value === 'string') { select.add( UI.UIUtils.createOption(option.text, option.value, Platform.StringUtilities.toKebabCase(option.value))); } } let reloadWarning: HTMLElement|(Element | null) = (null as Element | null); if (requiresReload) { reloadWarning = container.createChild('p', 'reload-warning hidden'); reloadWarning.textContent = i18nString(UIStrings.srequiresReload); UI.ARIAUtils.markAsAlert(reloadWarning); } const {deprecation} = setting; if (deprecation) { const warning = new Settings.SettingDeprecationWarning.SettingDeprecationWarning(); warning.data = deprecation; label.appendChild(warning); } setting.addChangeListener(settingChanged); settingChanged(); select.addEventListener('change', selectChanged, false); return container; function settingChanged(): void { const newValue = setting.get(); for (let i = 0; i < options.length; i++) { if (options[i].value === newValue) { select.selectedIndex = i; } } select.disabled = setting.disabled(); } function selectChanged(): void { // Don't use event.target.value to avoid conversion of the value to string. setting.set(options[select.selectedIndex].value); if (reloadWarning) { reloadWarning.classList.remove('hidden'); UI.InspectorView.InspectorView.instance().displayReloadRequiredWarning( i18nString(UIStrings.oneOrMoreSettingsHaveChanged)); } } }; export const createControlForSetting = function( setting: Common.Settings.Setting<unknown>, subtitle?: string): HTMLElement|null { const uiTitle = setting.title(); switch (setting.type()) { case Common.Settings.SettingType.BOOLEAN: { const component = new Settings.SettingCheckbox.SettingCheckbox(); component.data = { setting: setting as Common.Settings.Setting<boolean>, }; component.onchange = () => { if (setting.reloadRequired()) { UI.InspectorView.InspectorView.instance().displayReloadRequiredWarning( i18nString(UIStrings.oneOrMoreSettingsHaveChanged)); } }; return component; } case Common.Settings.SettingType.ENUM: return createSettingSelect(uiTitle, setting.options(), setting.reloadRequired(), setting, subtitle); default: console.error('Invalid setting type: ' + setting.type()); return null; } };