// Copyright (c) 2013 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 UI_MESSAGE_CENTER_COCOA_NOTIFICATION_CONTROLLER_H_
#define UI_MESSAGE_CENTER_COCOA_NOTIFICATION_CONTROLLER_H_
#import <Cocoa/Cocoa.h>
#include <string>
#import "base/mac/scoped_nsobject.h"
#include "ui/message_center/message_center_export.h"
namespace message_center {
class MessageCenter;
class Notification;
}
@class HoverImageButton;
// The base view controller class for notifications. A notification at minimum
// has an image, title, body, and close button. This controller can be used as
// the content for both a popup bubble and a view in the notification tray.
MESSAGE_CENTER_EXPORT
@interface MCNotificationController : NSViewController {
 @protected
  // The message object. Weak.
  const message_center::Notification* notification_;
  // A copy of the notification ID.
  std::string notificationID_;
  // Controller of the notifications, where action messages are forwarded. Weak.
  message_center::MessageCenter* messageCenter_;
  // The button that invokes |-close:|, in the upper-right corner.
  base::scoped_nsobject<HoverImageButton> closeButton_;
  // The small icon associated with the notification, on the bottom right.
  base::scoped_nsobject<NSImageView> smallImage_;
  // The large icon associated with the notification, on the left side.
  base::scoped_nsobject<NSImageView> icon_;
  // The title of the message.
  base::scoped_nsobject<NSTextView> title_;
  // Body text of the message. Hidden for list notifications.
  base::scoped_nsobject<NSTextView> message_;
  // Context-giving text of the message.  Alternate font used to distinguish it.
  base::scoped_nsobject<NSTextView> contextMessage_;
  // Container for optional list view that contains multiple items.
  base::scoped_nsobject<NSView> listView_;
  // Container for optional progress bar view.
  base::scoped_nsobject<NSProgressIndicator> progressBarView_;
  // Container for optional items at the bottom of the notification.
  base::scoped_nsobject<NSView> bottomView_;
}
// Creates a new controller for a given notification.
- (id)initWithNotification:(const message_center::Notification*)notification
    messageCenter:(message_center::MessageCenter*)messageCenter;
// If the model object changes, this method will update the views to reflect
// the new model object. Returns the updated frame of the notification.
- (NSRect)updateNotification:(const message_center::Notification*)notification;
// Action for clicking on the notification's |closeButton_|.
- (void)close:(id)sender;
// Accessor for the notification.
- (const message_center::Notification*)notification;
// Gets the notification ID. This string is owned by the NotificationController
// rather than the model object, so it's safe to use after the Notification has
// been deleted.
- (const std::string&)notificationID;
// Called when the user clicks within the notification view.
- (void)notificationClicked;
@end
@interface MCNotificationController (TestingInterface)
- (NSImageView*)smallImageView;
- (NSImageView*)iconView;
@end
#endif  // UI_MESSAGE_CENTER_COCOA_NOTIFICATION_CONTROLLER_H_