forked from chromium/chromium
-
Notifications
You must be signed in to change notification settings - Fork 0
/
selection_controller_delegate.h
66 lines (55 loc) · 2.83 KB
/
selection_controller_delegate.h
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
// Copyright 2016 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_VIEWS_SELECTION_CONTROLLER_DELEGATE_H_
#define UI_VIEWS_SELECTION_CONTROLLER_DELEGATE_H_
#include "ui/views/views_export.h"
namespace views {
// An interface implemented/managed by a view which uses the
// SelectionController.
class VIEWS_EXPORT SelectionControllerDelegate {
public:
// Returns the associated RenderText instance to be used for selection.
virtual gfx::RenderText* GetRenderTextForSelectionController() = 0;
// Methods related to properties of the associated view.
// Returns true if the associated text view is read only.
virtual bool IsReadOnly() const = 0;
// Returns whether the associated view supports drag-and-drop.
virtual bool SupportsDrag() const = 0;
// Returns whether there is a drag operation originating from the associated
// view.
virtual bool HasTextBeingDragged() const = 0;
// Sets whether text is being dragged from the associated view. Called only if
// the delegate supports drag.
virtual void SetTextBeingDragged(bool value) = 0;
// Returns the height of the associated view.
virtual int GetViewHeight() const = 0;
// Returns the width of the associated view.
virtual int GetViewWidth() const = 0;
// Returns the drag selection timer delay. This is the duration after which a
// drag selection is updated when the event location is outside the text
// bounds.
virtual int GetDragSelectionDelay() const = 0;
// Called before a pointer action which may change the associated view's
// selection and/or text. Should not be called in succession and must always
// be followed by an OnAfterPointerAction call.
virtual void OnBeforePointerAction() = 0;
// Called after a pointer action. |text_changed| and |selection_changed| can
// be used by subclasses to make any necessary updates like redraw the text.
// Must always be preceeded by an OnBeforePointerAction call.
virtual void OnAfterPointerAction(bool text_changed,
bool selection_changed) = 0;
// Pastes the text from the selection clipboard at the current cursor
// position. Always called within a pointer action for a non-readonly view.
// Returns true if some text was pasted.
virtual bool PasteSelectionClipboard() = 0;
// Updates the selection clipboard with the currently selected text. Should
// empty the selection clipboard if no text is currently selected.
// NO-OP if the associated text view is obscured. Since this does not modify
// the render text instance, it may be called outside of a pointer action.
virtual void UpdateSelectionClipboard() = 0;
protected:
virtual ~SelectionControllerDelegate() = default;
};
} // namespace views
#endif // UI_VIEWS_SELECTION_CONTROLLER_DELEGATE_H_