blob: caf89515b5aaa7b4fb4a79cf78c26be1b6434e38 [file] [log] [blame]
// Copyright 2018 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.
// @ts-nocheck
// TODO(crbug.com/1011811): Enable TypeScript compiler checks
import * as Common from '../common/common.js'; // eslint-disable-line no-unused-vars
import * as UI from '../ui/ui.js'; // eslint-disable-line no-unused-vars
import {Events, LighthouseController, Presets, RuntimeSettings} from './LighthouseController.js'; // eslint-disable-line no-unused-vars
import {RadioSetting} from './RadioSetting.js';
/**
* @unrestricted
*/
export class StartView extends UI.Widget.Widget {
/**
* @param {!LighthouseController} controller
*/
constructor(controller) {
super();
this.registerRequiredCSS('lighthouse/lighthouseStartView.css', {enableLegacyPatching: true});
this._controller = controller;
this._settingsToolbar = new UI.Toolbar.Toolbar('');
this._render();
}
/**
* @return {!UI.Toolbar.Toolbar}
*/
settingsToolbar() {
return this._settingsToolbar;
}
/**
* @param {string} settingName
* @param {string} label
* @param {!Element} parentElement
*/
_populateRuntimeSettingAsRadio(settingName, label, parentElement) {
const runtimeSetting = RuntimeSettings.find(item => item.setting.name === settingName);
if (!runtimeSetting || !runtimeSetting.options) {
throw new Error(`${settingName} is not a setting with options`);
}
const control = new RadioSetting(runtimeSetting.options, runtimeSetting.setting, runtimeSetting.description);
parentElement.appendChild(control.element);
UI.ARIAUtils.setAccessibleName(control.element, label);
}
/**
* @param {string} settingName
* @param {!UI.Toolbar.Toolbar} toolbar
*/
_populateRuntimeSettingAsToolbarCheckbox(settingName, toolbar) {
const runtimeSetting = RuntimeSettings.find(item => item.setting.name === settingName);
if (!runtimeSetting || !runtimeSetting.title) {
throw new Error(`${settingName} is not a setting with a title`);
}
runtimeSetting.setting.setTitle(runtimeSetting.title);
const control = new UI.Toolbar.ToolbarSettingCheckbox(runtimeSetting.setting, runtimeSetting.description);
toolbar.appendToolbarItem(control);
if (runtimeSetting.learnMore) {
const link = UI.XLink.XLink.create(runtimeSetting.learnMore, ls`Learn more`, 'lighthouse-learn-more');
link.style.padding = '5px';
control.element.appendChild(link);
}
}
/**
* @param {!UI.Fragment.Fragment} fragment
*/
_populateFormControls(fragment) {
// Populate the device type
const deviceTypeFormElements = fragment.$('device-type-form-elements');
this._populateRuntimeSettingAsRadio('lighthouse.device_type', ls`Device`, deviceTypeFormElements);
// Populate the categories
const categoryFormElements = fragment.$('categories-form-elements');
const pluginFormElements = fragment.$('plugins-form-elements');
for (const preset of Presets) {
const formElements = preset.plugin ? pluginFormElements : categoryFormElements;
preset.setting.setTitle(preset.title);
const checkbox = new UI.Toolbar.ToolbarSettingCheckbox(preset.setting, preset.description);
const row = formElements.createChild('div', 'vbox lighthouse-launcher-row');
row.appendChild(checkbox.element);
}
UI.ARIAUtils.markAsGroup(categoryFormElements);
UI.ARIAUtils.setAccessibleName(categoryFormElements, ls`Categories`);
UI.ARIAUtils.markAsGroup(pluginFormElements);
UI.ARIAUtils.setAccessibleName(pluginFormElements, ls`Community Plugins (beta)`);
}
_render() {
this._populateRuntimeSettingAsToolbarCheckbox('lighthouse.clear_storage', this._settingsToolbar);
this._populateRuntimeSettingAsToolbarCheckbox('lighthouse.throttling', this._settingsToolbar);
this._startButton = UI.UIUtils.createTextButton(
ls`Generate report`,
() => this._controller.dispatchEventToListeners(
Events.RequestLighthouseStart,
/* keyboardInitiated */ this._startButton.matches(':focus-visible')),
/* className */ '', /* primary */ true);
this.setDefaultFocusedElement(this._startButton);
const auditsDescription = ls
`Identify and fix common problems that affect your site's performance, accessibility, and user experience.`; // crbug.com/972969
const fragment = UI.Fragment.Fragment.build`
<div class="vbox lighthouse-start-view">
<header>
<div class="lighthouse-logo"></div>
<div class="lighthouse-start-button-container hbox">
${this._startButton}
</div>
<div $="help-text" class="lighthouse-help-text hidden"></div>
<div class="lighthouse-start-view-text">
<span>${auditsDescription}</span>
${UI.XLink.XLink.create('https://developers.google.com/web/tools/lighthouse/', ls`Learn more`)}
</div>
<div $="warning-text" class="lighthouse-warning-text hidden"></div>
</header>
<form>
<div class="lighthouse-form-categories">
<div class="lighthouse-form-section">
<div class="lighthouse-form-section-label">
${ls`Categories`}
</div>
<div class="lighthouse-form-elements" $="categories-form-elements"></div>
</div>
<div class="lighthouse-form-section">
<div class="lighthouse-form-section-label">
<div class="lighthouse-icon-label">${ls`Community Plugins (beta)`}</div>
</div>
<div class="lighthouse-form-elements" $="plugins-form-elements"></div>
</div>
</div>
<div class="lighthouse-form-section">
<div class="lighthouse-form-section-label">
${ls`Device`}
</div>
<div class="lighthouse-form-elements" $="device-type-form-elements"></div>
</div>
</form>
</div>
`;
this._helpText = fragment.$('help-text');
this._warningText = fragment.$('warning-text');
this._populateFormControls(fragment);
this.contentElement.appendChild(fragment.element());
this.contentElement.style.overflow = 'auto';
}
/**
* @override
*/
onResize() {
const useNarrowLayout = this.contentElement.offsetWidth < 560;
const startViewEl = this.contentElement.querySelector('.lighthouse-start-view');
startViewEl.classList.toggle('hbox', !useNarrowLayout);
startViewEl.classList.toggle('vbox', useNarrowLayout);
}
focusStartButton() {
this._startButton.focus();
}
/**
* @param {boolean} isEnabled
*/
setStartButtonEnabled(isEnabled) {
if (this._helpText) {
this._helpText.classList.toggle('hidden', isEnabled);
}
if (this._startButton) {
this._startButton.disabled = !isEnabled;
}
}
/**
* @param {?string} text
*/
setUnauditableExplanation(text) {
if (this._helpText) {
this._helpText.textContent = text;
}
}
/**
* @param {?string} text
*/
setWarningText(text) {
if (this._warningText) {
this._warningText.textContent = text;
this._warningText.classList.toggle('hidden', !text);
this._shouldConfirm = !!text;
}
}
}