chromium/chrome/browser/resources/ash/settings/device_page/per_device_pointing_stick.ts

// Copyright 2022 The Chromium Authors
// Use of this source code is governed by a BSD-style license that can be
// found in the LICENSE file.

/**
 * @fileoverview
 * 'pointing-stick-settings' allow users to configure their pointing stick
 * settings in system settings.
 */

import '../icons.html.js';
import '../settings_shared.css.js';
import 'chrome://resources/ash/common/cr_elements/localized_link/localized_link.js';
import 'chrome://resources/ash/common/cr_elements/cr_radio_button/cr_radio_button.js';
import 'chrome://resources/ash/common/cr_elements/cr_shared_vars.css.js';
import '../controls/settings_radio_group.js';
import '../controls/settings_slider.js';
import '../controls/settings_toggle_button.js';
import 'chrome://resources/ash/common/cr_elements/cr_slider/cr_slider.js';

import {getInstance as getAnnouncerInstance} from 'chrome://resources/ash/common/cr_elements/cr_a11y_announcer/cr_a11y_announcer.js';
import {I18nMixin} from 'chrome://resources/ash/common/cr_elements/i18n_mixin.js';
import {PolymerElementProperties} from 'chrome://resources/polymer/v3_0/polymer/interfaces.js';
import {PolymerElement} from 'chrome://resources/polymer/v3_0/polymer/polymer_bundled.min.js';

import {RouteObserverMixin} from '../common/route_observer_mixin.js';
import {Route, routes} from '../router.js';

import {PointingStick} from './input_device_settings_types.js';
import {getDeviceStateChangesToAnnounce} from './input_device_settings_utils.js';
import {getTemplate} from './per_device_pointing_stick.html.js';

const SettingsPerDevicePointingStickElementBase =
    RouteObserverMixin(I18nMixin(PolymerElement));

export class SettingsPerDevicePointingStickElement extends
    SettingsPerDevicePointingStickElementBase {
  static get is() {
    return 'settings-per-device-pointing-stick';
  }

  static get template(): HTMLTemplateElement {
    return getTemplate();
  }

  static get properties(): PolymerElementProperties {
    return {
      pointingSticks: {
        type: Array,
        observer: 'onPointingStickListUpdated',
      },
    };
  }

  protected pointingSticks: PointingStick[];

  override currentRouteChanged(route: Route): void {
    // Does not apply to this page.
    if (route !== routes.PER_DEVICE_POINTING_STICK) {
      return;
    }
  }

  private onPointingStickListUpdated(
      newPointingStickList: PointingStick[],
      oldPointingStickList: PointingStick[]|undefined): void {
    if (!oldPointingStickList) {
      return;
    }
    const {msgId, deviceNames} = getDeviceStateChangesToAnnounce(
        newPointingStickList, oldPointingStickList);
    for (const deviceName of deviceNames) {
      getAnnouncerInstance().announce(this.i18n(msgId, deviceName));
    }
  }

  private computeIsLastDevice(index: number): boolean {
    return index === this.pointingSticks.length - 1;
  }
}

declare global {
  interface HTMLElementTagNameMap {
    'settings-per-device-pointing-stick': SettingsPerDevicePointingStickElement;
  }
}

customElements.define(
    SettingsPerDevicePointingStickElement.is,
    SettingsPerDevicePointingStickElement);