// 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 ASH_BUBBLE_BUBBLE_UTILS_H_
#define ASH_BUBBLE_BUBBLE_UTILS_H_
#include <memory>
#include <optional>
#include <string>
#include "ash/ash_export.h"
#include "ash/style/ash_color_id.h"
#include "ui/color/color_id.h"
#include "ui/gfx/font.h"
namespace ui {
class LocatedEvent;
} // namespace ui
namespace views {
class Label;
} // namespace views
namespace ash {
enum class TypographyToken;
namespace bubble_utils {
// Returns false if `event` should not close a bubble. Returns true if `event`
// should close a bubble, or if more processing is required. Callers may also
// need to check for a click on the view that spawned the bubble (otherwise the
// bubble will close and immediately reopen).
ASH_EXPORT bool ShouldCloseBubbleForEvent(const ui::LocatedEvent& event);
// Applies the specified `style` and `text_color` to the given `label`.
ASH_EXPORT void ApplyStyle(
views::Label* label,
TypographyToken style,
ui::ColorId text_color_id = kColorAshTextColorPrimary);
// Creates a label with optional `text` and `text_color` matching the specified
// `style`. The label will paint correctly even if it is not added to the view
// hierarchy.
ASH_EXPORT std::unique_ptr<views::Label> CreateLabel(
TypographyToken style,
const std::u16string& text = std::u16string(),
ui::ColorId text_color_id = kColorAshTextColorPrimary);
} // namespace bubble_utils
} // namespace ash
#endif // ASH_BUBBLE_BUBBLE_UTILS_H_