blob: 7d8e07229308c6a14fffe8047ae04a2de0b31e72 (
plain)
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
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
|
// Copyright (c) 2010 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.
#include "chrome_frame/infobars/infobar_manager.h"
#include "base/logging.h"
#include "base/scoped_ptr.h"
#include "chrome_frame/infobars/internal/host_window_manager.h"
#include "chrome_frame/infobars/internal/infobar_window.h"
// Connects InfobarWindow to HostWindowManager, and exposes the result as an
// InfobarManager.
class InfobarManagerImpl
: public InfobarManager,
public InfobarWindow::Host,
public HostWindowManager::Delegate {
public:
explicit InfobarManagerImpl(HostWindowManager* manager);
// Implementation of InfobarManager
virtual bool Show(InfobarContent* content, InfobarType type);
virtual void Hide(InfobarType type);
virtual void HideAll();
// Implementation of HostWindowManager::Delegate
virtual void AdjustDisplacedWindowDimensions(RECT* rect);
// Implementation of InfobarWindow::Host
virtual HWND GetContainerWindow();
virtual void UpdateLayout();
private:
// Not owned by this instance.
HostWindowManager* manager_;
// Infobar windows.
scoped_ptr<InfobarWindow> infobars_[END_OF_INFOBAR_TYPE];
DISALLOW_COPY_AND_ASSIGN(InfobarManagerImpl);
}; // class InfobarManagerImpl
InfobarManagerImpl::InfobarManagerImpl(HostWindowManager* manager)
: manager_(manager) {
for (int index = 0; index < END_OF_INFOBAR_TYPE; ++index) {
infobars_[index].reset(
new InfobarWindow(static_cast<InfobarType>(index)));
infobars_[index]->SetHost(this);
}
}
bool InfobarManagerImpl::Show(InfobarContent* content, InfobarType type) {
DCHECK(type >= FIRST_INFOBAR_TYPE && type < END_OF_INFOBAR_TYPE);
return infobars_[type]->Show(content);
}
void InfobarManagerImpl::Hide(InfobarType type) {
DCHECK(type >= FIRST_INFOBAR_TYPE && type < END_OF_INFOBAR_TYPE);
infobars_[type]->Hide();
}
void InfobarManagerImpl::HideAll() {
for (int index = 0; index < END_OF_INFOBAR_TYPE; ++index)
Hide(static_cast<InfobarType>(index));
}
void InfobarManagerImpl::AdjustDisplacedWindowDimensions(RECT* rect) {
for (int index = 0; index < END_OF_INFOBAR_TYPE; ++index) {
if (infobars_[index] != NULL)
infobars_[index]->ReserveSpace(rect);
}
}
HWND InfobarManagerImpl::GetContainerWindow() {
return *manager_;
}
void InfobarManagerImpl::UpdateLayout() {
manager_->UpdateLayout();
}
InfobarManager::~InfobarManager() {
}
InfobarManager* InfobarManager::Get(HWND tab_window) {
HostWindowManager::Delegate* delegate =
HostWindowManager::GetDelegateForHwnd(tab_window);
if (delegate != NULL)
return static_cast<InfobarManagerImpl*>(delegate);
scoped_ptr<HostWindowManager> host_manager(new HostWindowManager());
// Transferred to host_manager in call to Initialize.
InfobarManagerImpl* infobar_manager = new InfobarManagerImpl(
host_manager.get());
if (host_manager->Initialize(tab_window, infobar_manager)) {
host_manager.release(); // takes ownership of itself
return infobar_manager;
}
return NULL;
}
|