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
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
|
// Copyright (c) 2012 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 <gtk/gtk.h>
#include "base/compiler_specific.h"
#include "base/logging.h"
#include "base/macros.h"
#include "base/strings/utf_string_conversions.h"
#include "remoting/base/string_resources.h"
#include "remoting/host/continue_window.h"
#include "ui/base/glib/glib_signal.h"
#include "ui/base/l10n/l10n_util.h"
namespace remoting {
class ContinueWindowGtk : public ContinueWindow {
public:
ContinueWindowGtk();
~ContinueWindowGtk() override;
protected:
// ContinueWindow overrides.
void ShowUi() override;
void HideUi() override;
private:
void CreateWindow();
CHROMEG_CALLBACK_1(ContinueWindowGtk, void, OnResponse, GtkDialog*, int);
GtkWidget* continue_window_;
DISALLOW_COPY_AND_ASSIGN(ContinueWindowGtk);
};
ContinueWindowGtk::ContinueWindowGtk()
: continue_window_(nullptr) {
}
ContinueWindowGtk::~ContinueWindowGtk() {
if (continue_window_) {
gtk_widget_destroy(continue_window_);
continue_window_ = nullptr;
}
}
void ContinueWindowGtk::ShowUi() {
DCHECK(CalledOnValidThread());
DCHECK(!continue_window_);
CreateWindow();
gtk_window_set_urgency_hint(GTK_WINDOW(continue_window_), TRUE);
gtk_window_present(GTK_WINDOW(continue_window_));
}
void ContinueWindowGtk::HideUi() {
DCHECK(CalledOnValidThread());
if (continue_window_) {
gtk_widget_destroy(continue_window_);
continue_window_ = nullptr;
}
}
void ContinueWindowGtk::CreateWindow() {
DCHECK(CalledOnValidThread());
DCHECK(!continue_window_);
continue_window_ = gtk_dialog_new_with_buttons(
l10n_util::GetStringUTF8(IDS_PRODUCT_NAME).c_str(),
nullptr,
static_cast<GtkDialogFlags>(GTK_DIALOG_MODAL | GTK_DIALOG_NO_SEPARATOR),
l10n_util::GetStringUTF8(IDS_STOP_SHARING_BUTTON).c_str(),
GTK_RESPONSE_CANCEL,
l10n_util::GetStringUTF8(IDS_CONTINUE_BUTTON).c_str(),
GTK_RESPONSE_OK,
nullptr);
gtk_dialog_set_default_response(GTK_DIALOG(continue_window_),
GTK_RESPONSE_OK);
gtk_window_set_resizable(GTK_WINDOW(continue_window_), FALSE);
// Set always-on-top, otherwise this window tends to be obscured by the
// DisconnectWindow.
gtk_window_set_keep_above(GTK_WINDOW(continue_window_), TRUE);
g_signal_connect(continue_window_, "response",
G_CALLBACK(OnResponseThunk), this);
GtkWidget* content_area =
gtk_dialog_get_content_area(GTK_DIALOG(continue_window_));
GtkWidget* text_label =
gtk_label_new(l10n_util::GetStringUTF8(IDS_CONTINUE_PROMPT).c_str());
gtk_label_set_line_wrap(GTK_LABEL(text_label), TRUE);
// TODO(lambroslambrou): Fix magic numbers, as in disconnect_window_gtk.cc.
gtk_misc_set_padding(GTK_MISC(text_label), 12, 12);
gtk_container_add(GTK_CONTAINER(content_area), text_label);
gtk_widget_show_all(content_area);
}
void ContinueWindowGtk::OnResponse(GtkDialog* dialog, int response_id) {
DCHECK(CalledOnValidThread());
if (response_id == GTK_RESPONSE_OK) {
ContinueSession();
} else {
DisconnectSession();
}
HideUi();
}
// static
scoped_ptr<HostWindow> HostWindow::CreateContinueWindow() {
return make_scoped_ptr(new ContinueWindowGtk());
}
} // namespace remoting
|