File: nsIRollupListener.h

package info (click to toggle)
firefox 149.0-1
  • links: PTS, VCS
  • area: main
  • in suites: sid
  • size: 4,767,760 kB
  • sloc: cpp: 7,416,064; javascript: 6,752,859; ansic: 3,774,850; python: 1,250,473; xml: 641,578; asm: 439,191; java: 186,617; sh: 56,634; makefile: 18,856; objc: 13,092; perl: 12,763; pascal: 5,960; yacc: 4,583; cs: 3,846; lex: 1,720; ruby: 1,002; php: 436; lisp: 258; awk: 105; sql: 66; sed: 53; csh: 10; exp: 6
file content (78 lines) | stat: -rw-r--r-- 2,584 bytes parent folder | download
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
/* -*- Mode: C++; 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/. */

#ifndef _nsIRollupListener_h_
#define _nsIRollupListener_h_

#include "nsTArray.h"
#include "nsPoint.h"
#include "Units.h"

class nsIContent;
class nsIWidget;

class nsIRollupListener {
 public:
  enum class AllowAnimations : bool { No, Yes };
  struct RollupOptions {
    // aCount is the number of popups in a chain to close. If this is
    // zero, then all popups are closed.
    uint32_t mCount = 0;
    // This is the mouse pointer position where the event that triggered the
    // rollup occurred, which may be nullptr.
    const mozilla::LayoutDeviceIntPoint* mPoint = nullptr;
    // Whether to allow panel animations.
    AllowAnimations mAllowAnimations = AllowAnimations::Yes;
  };

  /**
   * Notifies the object to rollup, optionally returning the node that
   * was just rolled up in aLastRolledUp, if non-null.
   *
   * aLastRolledUp is not addrefed.
   *
   * Returns true if the event that the caller is processing should be consumed.
   */
  MOZ_CAN_RUN_SCRIPT_BOUNDARY
  virtual bool Rollup(const RollupOptions&,
                      nsIContent** aLastRolledUp = nullptr) = 0;

  /**
   * Asks the RollupListener if it should rollup on mouse wheel events
   */
  virtual bool ShouldRollupOnMouseWheelEvent() = 0;

  /**
   * Asks the RollupListener if it should consume mouse wheel events
   */
  virtual bool ShouldConsumeOnMouseWheelEvent() = 0;

  /**
   * Asks the RollupListener if it should rollup on mouse activate, eg. X-Mouse
   */
  virtual bool ShouldRollupOnMouseActivate() = 0;

  /*
   * Retrieve the widgets for open menus and store them in the array
   * aWidgetChain. The number of menus of the same type should be returned,
   * for example, if a context menu is open, return only the number of menus
   * that are part of the context menu chain. This allows closing up only
   * those menus in different situations. The returned value should be exactly
   * the same number of widgets added to aWidgetChain.
   */
  virtual uint32_t GetSubmenuWidgetChain(
      nsTArray<nsIWidget*>* aWidgetChain) = 0;

  virtual nsIWidget* GetRollupWidget() = 0;

  /**
   * If a native menu is currently shown, closes the menu.
   * Returns true if a native menu was open.
   */
  virtual bool RollupNativeMenu() { return false; }
};

#endif /* _nsIRollupListener_h_ */