blob: 3127dfd3983801c7aa1ada851d6b4c5cbc2844d9 [file] [log] [blame]
// Copyright 2015 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.
#ifndef COMPONENTS_BUBBLE_BUBBLE_DELEGATE_H_
#define COMPONENTS_BUBBLE_BUBBLE_DELEGATE_H_
#include <string>
#include "base/memory/scoped_ptr.h"
#include "components/bubble/bubble_close_reason.h"
class BubbleUi;
// Inherit from this class to define a bubble. A bubble is a small transient UI
// surface anchored to a parent window. Most bubbles are dismissed when they
// lose focus.
class BubbleDelegate {
public:
BubbleDelegate();
virtual ~BubbleDelegate();
// Called by BubbleController to notify a bubble of an event that the bubble
// might want to close on. Return true if the bubble should close for the
// specified reason.
virtual bool ShouldClose(BubbleCloseReason reason) const;
// Called by BubbleController to notify a bubble that it has closed.
virtual void DidClose();
// Called by BubbleController to build the UI that will represent this bubble.
// BubbleDelegate should not keep a reference to this newly created UI.
virtual scoped_ptr<BubbleUi> BuildBubbleUi() = 0;
// Called to update an existing UI. This is the same BubbleUi that was created
// in |BuildBubbleUi|.
// Return true to indicate the UI was updated.
virtual bool UpdateBubbleUi(BubbleUi* bubble_ui);
// Used to identify a bubble for collecting metrics.
virtual std::string GetName() const = 0;
private:
DISALLOW_COPY_AND_ASSIGN(BubbleDelegate);
};
#endif // COMPONENTS_BUBBLE_BUBBLE_DELEGATE_H_