File: nsIMockDragServiceController.idl

package info (click to toggle)
firefox 147.0-1
  • links: PTS, VCS
  • area: main
  • in suites: sid
  • size: 4,683,324 kB
  • sloc: cpp: 7,607,156; javascript: 6,532,492; ansic: 3,775,158; python: 1,415,368; xml: 634,556; asm: 438,949; java: 186,241; sh: 62,751; makefile: 18,079; objc: 13,092; perl: 12,808; yacc: 4,583; cs: 3,846; pascal: 3,448; lex: 1,720; ruby: 1,003; php: 436; lisp: 258; awk: 247; sql: 66; sed: 54; csh: 10; exp: 6
file content (68 lines) | stat: -rw-r--r-- 2,536 bytes parent folder | download | duplicates (12)
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
/* -*- Mode: IDL; tab-width: 2; indent-tabs-mode: nil; c-basic-offset: 2 -*-
 *
 * This Source Code Form is subject to the terms of the Mozilla Public
 * License, v. 2.0. If a copy of the MPL was not distributed with this
 * file, You can obtain one at http://mozilla.org/MPL/2.0/. */

#include "nsISupports.idl"

webidl BrowsingContext;

interface nsIDragService;

/**
 * A driver for MockDragService, so that tests can mock system DND behavior.
 * (System DND is not permitted in tests.)
 */
[scriptable, builtinclass, uuid(32037ab0-bfc7-11ee-9f4b-09901bed55fa)]
interface nsIMockDragServiceController : nsISupports
{
  // Types of event that can be sent by this controller.
  cenum EventType : 8 {
    eDragEnter = 0,
    eDragOver = 1,
    eDragExit = 2,
    eDrop = 3,
    eMouseDown = 4,
    eMouseMove = 5,
    eMouseUp = 6,
  };

  /**
   * The nsIDragService that this controller targets.  It is a mock version
   * of the normal nsIDragService.  The caller must replace the drag
   * service in the service manager with this object before sending
   * drag events to it.  This can be done with MockRegistrar or by calling
   * the nsComponentManager directly.
   */
  readonly attribute nsIDragService mockDragService;

  /**
   * Issue the given event from our mock drag service, as if that type
   * of event came from the system.  The mock object attempts to mimic the
   * essential behavior of the native drag classes for this.
   *
   * @param aBC            A BrowsingContext in the widget the event is
   *                       targetted at
   * @param aEventType     Type of event to send
   * @param aScreenX       Screen X coordinate of event
   * @param aScreenY       Screen Y coordinate of event
   * @param aKeyModifiers  Keys that are pressed during event.
   *                       NOTE: Keys should be interpreted as selecting
   *                       the drag action, but that logic is very
   *                       platform-dependent and is not yet mocked.
   *                       Drops will be processed as "moves".
   */
  [can_run_script]
  void sendEvent(in BrowsingContext aBC,
                 in nsIMockDragServiceController_EventType aEventType,
                 in long aScreenX, in long aScreenY,
                 [optional] in uint32_t aKeyModifiers);

  /**
   * Windows' IDropTarget has the ability to "Cancel" a drag that is
   * different than dragleave.  This emulates that behavior for testing.
   */
  [can_run_script]
  void cancelDrag([optional] in uint32_t aKeyModifiers);
};