chromium/chrome/browser/ui/ash/input_method/announcement_label.h

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

#ifndef CHROME_BROWSER_UI_ASH_INPUT_METHOD_ANNOUNCEMENT_LABEL_H_
#define CHROME_BROWSER_UI_ASH_INPUT_METHOD_ANNOUNCEMENT_LABEL_H_

#include <memory>
#include <string>

#include "base/time/time.h"
#include "base/timer/timer.h"
#include "ui/accessibility/ax_node_data.h"
#include "ui/base/metadata/metadata_header_macros.h"
#include "ui/views/controls/label.h"

namespace ui {
namespace ime {

// Label used for ChromeVox announcements via live regions.
class AnnouncementLabel : public views::Label {
  METADATA_HEADER(AnnouncementLabel, views::Label)

 public:
  explicit AnnouncementLabel(const std::u16string& name);
  ~AnnouncementLabel() override;

  // Make announcement to ChromeVox with the given text after a delay of N
  // milliseconds specified by the param delay.
  void AnnounceAfterDelay(const std::u16string& text, base::TimeDelta delay);

 private:
  // Callback used for delaying announcements
  void DoAnnouncement(const std::u16string text);

  void UpdateAccessibleDescription();

  // Used to delay the ChromeVox announcements. A delay is required as
  // announcements can "override" each other if they are triggered at
  // a similar time. Providing a delay prevents our announcement being
  // blocked by ChromeVox announcements triggered by text updates (i.e.
  // pressing a key will trigger an announcement of the letter found
  // on that key).
  std::unique_ptr<base::OneShotTimer> delay_timer_;

  std::u16string announcement_text_;
};

}  // namespace ime
}  // namespace ui

#endif  // CHROME_BROWSER_UI_ASH_INPUT_METHOD_ANNOUNCEMENT_LABEL_H_