chromium/chrome/browser/ui/chromeos/read_write_cards/read_write_card_controller.h

// Copyright 2023 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_CHROMEOS_READ_WRITE_CARDS_READ_WRITE_CARD_CONTROLLER_H_
#define CHROME_BROWSER_UI_CHROMEOS_READ_WRITE_CARDS_READ_WRITE_CARD_CONTROLLER_H_

#include <string>

#include "base/component_export.h"

class Profile;

namespace gfx {
class Rect;
}  // namespace gfx

namespace chromeos {

// A controller to manage the creation/dismissal of Quick Answers and Editor
// Menu related views.
class ReadWriteCardController {
 public:
  ReadWriteCardController() = default;
  virtual ~ReadWriteCardController() = default;

  // Called when the context menu is shown but the surrounding text still
  // pending.
  // `profile` is the profile that is associated with the browser in which the
  // context menu is shown.
  virtual void OnContextMenuShown(Profile* profile) = 0;

  // Called when the surrounding text is available.
  // `anchor_bounds` is the bounds of the anchor view, which is the context menu
  // for browser.
  // `selected_text` is the text selected by the user. Could be empty.
  // `surrounding_text` is the text surrounding selection.
  virtual void OnTextAvailable(const gfx::Rect& anchor_bounds,
                               const std::string& selected_text,
                               const std::string& surrounding_text) = 0;

  // Called when the bounds of the anchor view changes.
  virtual void OnAnchorBoundsChanged(const gfx::Rect& anchor_bounds) = 0;

  // Called when the context menu is closed.
  // `is_other_command_executed`: whether commands other than the card view is
  // executed, e.g. the commands in the context menu.
  virtual void OnDismiss(bool is_other_command_executed) = 0;
};

}  // namespace chromeos

#endif  // CHROME_BROWSER_UI_CHROMEOS_READ_WRITE_CARDS_READ_WRITE_CARD_CONTROLLER_H_