File: status_item_view.h

package info (click to toggle)
chromium-browser 41.0.2272.118-1
  • links: PTS, VCS
  • area: main
  • in suites: jessie-kfreebsd
  • size: 2,189,132 kB
  • sloc: cpp: 9,691,462; ansic: 3,341,451; python: 712,689; asm: 518,779; xml: 208,926; java: 169,820; sh: 119,353; perl: 68,907; makefile: 28,311; yacc: 13,305; objc: 11,385; tcl: 3,186; cs: 2,225; sql: 2,217; lex: 2,215; lisp: 1,349; pascal: 1,256; awk: 407; ruby: 155; sed: 53; php: 14; exp: 11
file content (70 lines) | stat: -rw-r--r-- 2,222 bytes parent folder | download | duplicates (2)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
// 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_STATUS_ITEM_VIEW_H_
#define UI_MESSAGE_CENTER_COCOA_STATUS_ITEM_VIEW_H_

#import <AppKit/AppKit.h>

#include "base/mac/scoped_block.h"
#include "base/mac/scoped_nsobject.h"
#include "ui/message_center/message_center_export.h"

namespace message_center {

// Callback block for when the status item is clicked.
typedef void(^StatusItemClickedCallback)();

}  // namespace message_center

// This view is meant to be used with a NSStatusItem. It will fire a callback
// when it is clicked. It draws a small icon and the unread count, if greater
// than zero, to the icon's right. It can also paint the highlight background
// pattern outside of a mouse event sequence, for when an attached window is
// open.
MESSAGE_CENTER_EXPORT
@interface MCStatusItemView : NSView {
 @private
  // The status item.
  base::scoped_nsobject<NSStatusItem> statusItem_;

  // Callback issued when the status item is clicked.
  base::mac::ScopedBlock<message_center::StatusItemClickedCallback> callback_;

  // The unread count number to be drawn next to the icon.
  size_t unreadCount_;

  // Whether or not we are to display the quiet mode version of the status icon.
  BOOL quietMode_;

  // Whether or not to force the highlight pattern to be drawn.
  BOOL highlight_;

  // Whether or not the view is currently handling mouse events and should
  // draw the highlight pattern.
  BOOL inMouseEventSequence_;
}

@property(copy, nonatomic) message_center::StatusItemClickedCallback callback;
@property(nonatomic) BOOL highlight;

// Designated initializer. Creates a new NSStatusItem in the system menubar.
- (id)init;

// Sets the unread count and quiet mode status of the icon.
- (void)setUnreadCount:(size_t)unreadCount withQuietMode:(BOOL)quietMode;

// Removes the status item from the menubar. Must be called to break the
// retain cycle between self and the NSStatusItem view.
- (void)removeItem;

@end

@interface MCStatusItemView (TestingAPI)

- (size_t)unreadCount;

@end

#endif  // UI_MESSAGE_CENTER_COCOA_STATUS_ITEM_VIEW_H_