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
|
// Copyright (c) 2009 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.
// EditSearchEngineDialog provides text fields for editing a keyword: the title,
// url and actual keyword. It is used by the KeywordEditorView of the Options
// dialog, and also on its own to confirm the addition of a keyword added by
// the ExternalJSObject via the RenderView.
#ifndef CHROME_BROWSER_VIEWS_EDIT_SEARCH_ENGINE_DIALOG_H_
#define CHROME_BROWSER_VIEWS_EDIT_SEARCH_ENGINE_DIALOG_H_
#pragma once
#include <windows.h>
#include "views/controls/textfield/textfield.h"
#include "views/window/dialog_delegate.h"
namespace views {
class Label;
class ImageView;
class Window;
}
class EditSearchEngineController;
class EditSearchEngineControllerDelegate;
class Profile;
class TemplateURL;
class TemplateURLModel;
class EditSearchEngineDialog : public views::View,
public views::Textfield::Controller,
public views::DialogDelegate {
public:
// The |template_url| and/or |delegate| may be NULL.
EditSearchEngineDialog(const TemplateURL* template_url,
EditSearchEngineControllerDelegate* delegate,
Profile* profile);
virtual ~EditSearchEngineDialog() {}
// Shows the dialog to the user.
static void Show(gfx::NativeWindow parent,
const TemplateURL* template_url,
EditSearchEngineControllerDelegate* delegate,
Profile* profile);
// views::DialogDelegate overrides.
virtual bool IsModal() const;
virtual std::wstring GetWindowTitle() const;
virtual bool IsDialogButtonEnabled(
MessageBoxFlags::DialogButton button) const;
virtual bool Cancel();
virtual bool Accept();
virtual views::View* GetContentsView();
// views::Textfield::Controller overrides. Updates whether the user can
// accept the dialog as well as updating image views showing whether value is
// valid.
virtual void ContentsChanged(views::Textfield* sender,
const std::wstring& new_contents);
virtual bool HandleKeystroke(views::Textfield* sender,
const views::Textfield::Keystroke& key);
private:
void Init();
// Create a Label containing the text with the specified message id.
views::Label* CreateLabel(int message_id);
// Creates a text field with the specified text. If |lowercase| is true, the
// Textfield is configured to map all input to lower case.
views::Textfield* CreateTextfield(const std::wstring& text, bool lowercase);
// Invokes UpdateImageView for each of the images views.
void UpdateImageViews();
// Updates the tooltip and image of the image view based on is_valid. If
// is_valid is false the tooltip of the image view is set to the message with
// id invalid_message_id, otherwise the tooltip is set to the empty text.
void UpdateImageView(views::ImageView* image_view,
bool is_valid,
int invalid_message_id);
// Used to parent window to. May be NULL or an invalid window.
HWND parent_;
// View containing the buttons, text fields ...
views::View* view_;
// Text fields.
views::Textfield* title_tf_;
views::Textfield* keyword_tf_;
views::Textfield* url_tf_;
// Shows error images.
views::ImageView* title_iv_;
views::ImageView* keyword_iv_;
views::ImageView* url_iv_;
scoped_ptr<EditSearchEngineController> controller_;
DISALLOW_COPY_AND_ASSIGN(EditSearchEngineDialog);
};
#endif // CHROME_BROWSER_VIEWS_EDIT_SEARCH_ENGINE_DIALOG_H_
|