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
123
|
// Copyright (c) 2011 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 CHROME_BROWSER_UI_VIEWS_COOKIE_INFO_VIEW_H_
#define CHROME_BROWSER_UI_VIEWS_COOKIE_INFO_VIEW_H_
#pragma once
#include <string>
#include <vector>
#include "base/basictypes.h"
#include "base/compiler_specific.h"
#include "base/string16.h"
#include "net/base/cookie_monster.h"
#include "ui/base/models/combobox_model.h"
#include "views/controls/combobox/combobox_listener.h"
#include "views/view.h"
namespace views {
class GridLayout;
class Label;
class Textfield;
}
///////////////////////////////////////////////////////////////////////////////
// CookieInfoViewDelegate
//
class CookieInfoViewDelegate {
public:
virtual void ModifyExpireDate(bool session_expire) = 0;
protected:
virtual ~CookieInfoViewDelegate() {}
};
///////////////////////////////////////////////////////////////////////////////
// CookieInfoView
//
// Responsible for displaying a tabular grid of Cookie information.
class CookieInfoView : public views::View,
public views::ComboboxListener,
public ui::ComboboxModel {
public:
explicit CookieInfoView(bool editable_expiration_date);
virtual ~CookieInfoView();
// Update the display from the specified CookieNode.
void SetCookie(const std::string& domain,
const net::CookieMonster::CanonicalCookie& cookie_node);
// Update the display from the specified cookie string.
void SetCookieString(const GURL& url, const std::string& cookie_line);
// Clears the cookie display to indicate that no or multiple cookies are
// selected.
void ClearCookieDisplay();
// Enables or disables the cookie property text fields.
void EnableCookieDisplay(bool enabled);
void set_delegate(CookieInfoViewDelegate* delegate) { delegate_ = delegate; }
protected:
// views::View:
virtual void ViewHierarchyChanged(bool is_add,
views::View* parent,
views::View* child) OVERRIDE;
// views::ComboboxListener:
virtual void ItemChanged(views::Combobox* combo_box,
int prev_index,
int new_index) OVERRIDE;
// ui::ComboboxModel:
virtual int GetItemCount() OVERRIDE;
virtual string16 GetItemAt(int index) OVERRIDE;
private:
// Layout helper routines.
void AddLabelRow(int layout_id, views::GridLayout* layout,
views::View* label, views::View* value);
void AddControlRow(int layout_id, views::GridLayout* layout,
views::View* label, views::View* control);
// Sets up the view layout.
void Init();
// Individual property labels
views::Label* name_label_;
views::Textfield* name_value_field_;
views::Label* content_label_;
views::Textfield* content_value_field_;
views::Label* domain_label_;
views::Textfield* domain_value_field_;
views::Label* path_label_;
views::Textfield* path_value_field_;
views::Label* send_for_label_;
views::Textfield* send_for_value_field_;
views::Label* created_label_;
views::Textfield* created_value_field_;
views::Label* expires_label_;
views::Textfield* expires_value_field_;
views::Combobox* expires_value_combobox_;
views::View* expire_view_;
// Option values for expires_value_combobox_.
std::vector<std::wstring> expire_combo_values_;
// True if expiration date can be edited. In this case we will show
// expires_value_combobox_ instead of expires_value_field_. The cookie's
// expiration date is editable only this class is used in
// CookiesPromptView (alert before cookie is set), in all other cases we
// don't let user directly change cookie setting.
bool editable_expiration_date_;
CookieInfoViewDelegate* delegate_;
DISALLOW_COPY_AND_ASSIGN(CookieInfoView);
};
#endif // CHROME_BROWSER_UI_VIEWS_COOKIE_INFO_VIEW_H_
|