File: drag_drop_client_observer.h

package info (click to toggle)
chromium 138.0.7204.183-1
  • links: PTS, VCS
  • area: main
  • in suites: trixie
  • size: 6,071,908 kB
  • sloc: cpp: 34,937,088; ansic: 7,176,967; javascript: 4,110,704; python: 1,419,953; asm: 946,768; xml: 739,971; pascal: 187,324; sh: 89,623; perl: 88,663; objc: 79,944; sql: 50,304; cs: 41,786; fortran: 24,137; makefile: 21,806; php: 13,980; tcl: 13,166; yacc: 8,925; ruby: 7,485; awk: 3,720; lisp: 3,096; lex: 1,327; ada: 727; jsp: 228; sed: 36
file content (74 lines) | stat: -rw-r--r-- 2,797 bytes parent folder | download | duplicates (5)
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
// Copyright 2017 The Chromium Authors
// Use of this source code is governed by a BSD-style license that can be
// found in the LICENSE file.

#ifndef UI_AURA_CLIENT_DRAG_DROP_CLIENT_OBSERVER_H_
#define UI_AURA_CLIENT_DRAG_DROP_CLIENT_OBSERVER_H_

#include "ui/aura/aura_export.h"

namespace ui {
namespace mojom {
enum class DragOperation;
}  // namespace mojom

class DropTargetEvent;
}  // namespace ui

namespace aura {
namespace client {

// Observes drag-and-drop sessions. NOTE: drop could be asynchronous. Therefore,
// an active async drop could be interrupted by a new drag-and-drop session. In
// this case, observers are NOT notified of the interrupted async drop.
// Some possible calling orders are listed below:
// 1. Sync/async drop completion: `OnDragStarted()` -> `OnDragUpdated()` ->
// `OnDragCompleted()` -> `OnDropCompleted()`.
// 2. Async drop cancellation: OnDragStarted()` -> `OnDragUpdated()` ->
// `OnDragCompleted()` -> `OnDragCancelled()`.
class AURA_EXPORT DragDropClientObserver {
 public:
  virtual ~DragDropClientObserver() = default;

  // Called when dragging started.
  virtual void OnDragStarted() {}

  // Called when dragging is updated.
  virtual void OnDragUpdated(const ui::DropTargetEvent& event) {}

  // Called when dragging completes successfully.
  virtual void OnDragCompleted(const ui::DropTargetEvent& event) {}

  // Called when dragging is cancelled.
  // NOTE:
  // 1. Drag 'n drop cancellations may be processed asynchronously.
  // Hence, this hook might be called before the action is actually processed.
  // 2. This method is called in a disallowed async drop. In this case,
  // `OnDragCancelled()` is called after `OnDragCompleted()`.
  virtual void OnDragCancelled() {}

  // Called when drop is completed. `drag_operation` indicates the operation
  // when drop completes.
  // NOTE: drop completion could be performed asynchronously. When an async drop
  // is completed after a new drag-and-drop session starts, this method is not
  // called for this drop.
  virtual void OnDropCompleted(ui::mojom::DragOperation drag_operation) {}

#if BUILDFLAG(IS_CHROMEOS)
  // Called when the set of currently selected drag operation changes during the
  // drag. |action| is a bitmask of the actions selected by the client. This is
  // to provide feedback during the operation, it does not take precedence over
  // the operation returned from StartDragAndDrop.
  virtual void OnDragActionsChanged(int actions) {}
#endif

  // Called during destruction of the observed `DragDropClient`. Note that the
  // client being destroyed does not necessarily imply the end of the drag
  // session.
  virtual void OnDragDropClientDestroying() {}
};

}  // namespace client
}  // namespace aura

#endif  // UI_AURA_CLIENT_DRAG_DROP_CLIENT_OBSERVER_H_