1 /* -*- Mode: C++; tab-width: 2; indent-tabs-mode: nil; c-basic-offset: 2 -*- */
2 /* This Source Code Form is subject to the terms of the Mozilla Public
3 * License, v. 2.0. If a copy of the MPL was not distributed with this
4 * file, You can obtain one at http://mozilla.org/MPL/2.0/. */
9 #ifndef MOZILLA_INTERNAL_API
10 # error "This header is only usable from within libxul (MOZILLA_INTERNAL_API)."
17 #include "mozilla/Maybe.h"
18 #include "mozilla/widget/ThemeChangeKind.h"
19 #include "mozilla/ColorScheme.h"
27 using Modifiers
= uint16_t;
28 struct StyleColorSchemeFlags
;
35 class FullLookAndFeel
;
38 enum class StyleSystemColor
: uint8_t;
39 enum class StyleSystemColorScheme
: uint8_t;
40 enum class StyleSystemFont
: uint8_t;
44 using ColorID
= StyleSystemColor
;
45 using ColorScheme
= mozilla::ColorScheme
;
47 // When modifying this list, also modify nsXPLookAndFeel::sIntPrefs
48 // in widget/xpwidgts/nsXPLookAndFeel.cpp.
50 // default, may be overriden by OS
52 // Amount of blinks that happen before the caret stops blinking.
54 // pixel width of caret
56 // select textfields when focused via tab/accesskey?
57 SelectTextfieldsOnKeyFocus
,
58 // delay before submenus open
60 // can popups overlap menu/task bar?
62 // should overlay scrollbars be used?
64 // allow H and V overlay scrollbars to overlap?
65 AllowOverlayScrollbarsOverlap
,
66 // skip navigating to disabled menu item?
67 SkipNavigatingDisabledMenuItem
,
68 // begin a drag if the mouse is moved further than the threshold while the
72 // Accessibility theme being used?
73 UseAccessibilityTheme
,
75 // position of scroll arrows in a scrollbar
78 // each button can take one of four values:
79 ScrollButtonLeftMouseButtonAction
,
80 // 0 - scrolls one line, 1 - scrolls one page
81 ScrollButtonMiddleMouseButtonAction
,
82 // 2 - scrolls to end, 3 - button ignored
83 ScrollButtonRightMouseButtonAction
,
85 // delay for opening spring loaded folders
87 // delay for closing spring loaded folders
89 // delay for triggering the tree scrolling
91 // delay for scrolling the tree
93 // the maximum number of lines to be scrolled at ones
95 // Should menu items blink when they're chosen?
96 ChosenMenuItemsShouldBlink
,
99 * A Boolean value to determine whether the Windows accent color
100 * should be applied to the title bar.
102 * The value of this metric is not used on other platforms. These platforms
103 * should return NS_ERROR_NOT_IMPLEMENTED when queried for this metric.
105 WindowsAccentColorInTitlebar
,
107 /* Whether Windows mica effect is enabled and available */
111 * A Boolean value to determine whether the macOS Big Sur-specific
112 * theming should be used.
117 * A Boolean value to determine whether macOS is in RTL mode or not.
121 /* Native macOS titlebar height. */
125 * AlertNotificationOrigin indicates from which corner of the
126 * screen alerts slide in, and from which direction (horizontal/vertical).
127 * 0, the default, represents bottom right, sliding vertically.
128 * Use any bitwise combination of the following constants:
129 * NS_ALERT_HORIZONTAL (1), NS_ALERT_LEFT (2), NS_ALERT_TOP (4).
139 AlertNotificationOrigin
,
142 * If true, clicking on a scrollbar (not as in dragging the thumb) defaults
143 * to scrolling the view corresponding to the clicked point. Otherwise, we
144 * only do so if the scrollbar is clicked using the middle mouse button or
145 * if shift is pressed when the scrollbar is clicked.
150 * IME and spell checker underline styles, the values should be
151 * NS_DECORATION_LINE_STYLE_*. They are defined below.
153 IMERawInputUnderlineStyle
,
154 IMESelectedRawTextUnderlineStyle
,
155 IMEConvertedTextUnderlineStyle
,
156 IMESelectedConvertedTextUnderline
,
157 SpellCheckerUnderlineStyle
,
160 * If this metric != 0, support window dragging on the menubar.
164 * 0: scrollbar button repeats to scroll only when cursor is on the button.
165 * 1: scrollbar button repeats to scroll even if cursor is outside of it.
167 ScrollbarButtonAutoRepeatBehavior
,
169 * A Boolean value to determine whether swipe animations should be used.
171 SwipeAnimationEnabled
,
174 * Controls whether overlay scrollbars display when the user moves
175 * the mouse in a scrollable frame.
177 ScrollbarDisplayOnMouseMove
,
180 * Overlay scrollbar animation constants.
182 ScrollbarFadeBeginDelay
,
183 ScrollbarFadeDuration
,
186 * Distance in pixels to offset the context menu from the cursor
189 ContextMenuOffsetVertical
,
190 ContextMenuOffsetHorizontal
,
191 TooltipOffsetVertical
,
194 * A boolean value indicating whether client-side decorations are
195 * supported by the user's GTK version.
200 * A boolean value indicating whether semi-transparent
201 * windows are available.
203 GTKCSDTransparencyAvailable
,
206 * A boolean value indicating whether client-side decorations should
207 * contain a minimize button.
209 GTKCSDMinimizeButton
,
212 * A boolean value indicating whether client-side decorations should
213 * contain a maximize button.
215 GTKCSDMaximizeButton
,
218 * A boolean value indicating whether client-side decorations should
219 * contain a close button.
224 * An Integer value that will represent the position of the Minimize button
225 * in GTK Client side decoration header.
227 GTKCSDMinimizeButtonPosition
,
230 * An Integer value that will represent the position of the Maximize button
231 * in GTK Client side decoration header.
233 GTKCSDMaximizeButtonPosition
,
236 * An Integer value that will represent the position of the Close button
237 * in GTK Client side decoration header.
239 GTKCSDCloseButtonPosition
,
242 * A boolean value indicating whether titlebar buttons are located
243 * in left titlebar corner.
245 GTKCSDReversedPlacement
,
248 * A boolean value indicating whether or not the OS is using a dark theme,
249 * which we may want to switch to as well if not overridden by the user.
254 * Corresponding to prefers-reduced-motion.
255 * https://drafts.csswg.org/mediaqueries-5/#prefers-reduced-motion
259 PrefersReducedMotion
,
262 * Corresponding to prefers-reduced-transparency.
263 * https://drafts.csswg.org/mediaqueries-5/#prefers-reduced-transparency
267 PrefersReducedTransparency
,
270 * Corresponding to inverted-colors.
271 * https://drafts.csswg.org/mediaqueries-5/#inverted
278 * Corresponding to PointerCapabilities in ServoTypes.h
284 PrimaryPointerCapabilities
,
286 * Corresponding to union of PointerCapabilities values in ServoTypes.h
287 * E.g. if there is a mouse and a digitizer, the value will be
288 * 'Coarse | Fine | Hover'.
290 AllPointerCapabilities
,
292 /** The scrollbar size, in CSS pixels. */
295 /** A boolean value to determine whether a touch device is present */
296 TouchDeviceSupportPresent
,
298 /** GTK titlebar radius */
301 /** GTK button-to-button spacing in the inline axis */
302 TitlebarButtonSpacing
,
305 * Corresponding to dynamic-range.
306 * https://drafts.csswg.org/mediaqueries-5/#dynamic-range
312 /** Whether XUL panel animations are enabled. */
315 /* Whether we should hide the cursor while typing */
316 HideCursorWhileTyping
,
318 /* The StyleGtkThemeFamily of the current GTK theme. */
321 /* Whether macOS' full keyboard access is enabled */
324 // TODO(krosylight): This should ultimately be able to replace
325 // IntID::AllPointerCapabilities. (Bug 1918207)
327 // Note that PrimaryPointerCapabilities may not be replaceable as it has a
328 // bit more system specific heuristic, e.g. IsTabletMode on Windows.
332 * Not an ID; used to define the range of valid IDs. Must be last.
337 // This is a common enough integer that seems worth the shortcut.
338 static bool UseOverlayScrollbars() {
339 return GetInt(IntID::UseOverlayScrollbars
);
342 static constexpr int32_t kDefaultTooltipOffset
= 21;
343 static int32_t TooltipOffsetVertical() {
344 return GetInt(IntID::TooltipOffsetVertical
, kDefaultTooltipOffset
);
347 // Returns keyCode value of a modifier key which is used for accesskey.
348 // Returns 0 if the platform doesn't support access key.
349 static uint32_t GetMenuAccessKey();
350 // Modifier mask for the menu accesskey.
351 static Modifiers
GetMenuAccessKeyModifiers();
354 eScrollArrow_None
= 0,
355 eScrollArrow_StartBackward
= 0x1000,
356 eScrollArrow_StartForward
= 0x0100,
357 eScrollArrow_EndBackward
= 0x0010,
358 eScrollArrow_EndForward
= 0x0001
362 // single arrow at each end
363 eScrollArrowStyle_Single
=
364 eScrollArrow_StartBackward
| eScrollArrow_EndForward
,
365 // both arrows at bottom/right, none at top/left
366 eScrollArrowStyle_BothAtBottom
=
367 eScrollArrow_EndBackward
| eScrollArrow_EndForward
,
368 // both arrows at both ends
369 eScrollArrowStyle_BothAtEachEnd
=
370 eScrollArrow_EndBackward
| eScrollArrow_EndForward
|
371 eScrollArrow_StartBackward
| eScrollArrow_StartForward
,
372 // both arrows at top/left, none at bottom/right
373 eScrollArrowStyle_BothAtTop
=
374 eScrollArrow_StartBackward
| eScrollArrow_StartForward
377 // When modifying this list, also modify nsXPLookAndFeel::sFloatPrefs
378 // in widget/nsXPLookAndFeel.cpp.
380 IMEUnderlineRelativeSize
,
381 SpellCheckerUnderlineRelativeSize
,
383 // The width/height ratio of the cursor. If used, the CaretWidth int metric
384 // should be added to the calculated caret width.
387 // GTK text scale factor.
390 // Mouse pointer scaling factor.
393 // Not an ID; used to define the range of valid IDs. Must be last.
397 using FontID
= mozilla::StyleSystemFont
;
399 enum class PointingDeviceKinds
: uint8_t {
406 static ColorScheme
SystemColorScheme() {
407 return GetInt(IntID::SystemUsesDarkTheme
) ? ColorScheme::Dark
408 : ColorScheme::Light
;
411 static bool IsDarkColor(nscolor
);
413 static ColorScheme
ColorSchemeForStyle(
414 const dom::Document
&, const StyleColorSchemeFlags
&,
415 ColorSchemeMode
= ColorSchemeMode::Used
);
416 static ColorScheme
ColorSchemeForFrame(
417 const nsIFrame
*, ColorSchemeMode
= ColorSchemeMode::Used
);
419 // Whether standins for native colors should be used (that is, colors faked,
420 // taken from win7, mostly). This forces light appearance, effectively.
421 enum class UseStandins
: bool { No
, Yes
};
422 static UseStandins
ShouldUseStandins(const dom::Document
&, ColorID
);
424 // Returns a native color value (might be overwritten by prefs) for a given
428 // ColorID::TextSelectForeground might return NS_SAME_AS_FOREGROUND_COLOR.
429 // ColorID::IME* might return NS_TRANSPARENT, NS_SAME_AS_FOREGROUND_COLOR or
430 // NS_40PERCENT_FOREGROUND_COLOR.
431 // These values have particular meaning. Then, they are not an actual
433 static Maybe
<nscolor
> GetColor(ColorID
, ColorScheme
, UseStandins
);
435 // Gets the color with appropriate defaults for UseStandins, ColorScheme etc
436 // for a given frame.
437 static Maybe
<nscolor
> GetColor(ColorID
, const nsIFrame
*);
439 // Versions of the above which returns the color if found, or a default (which
440 // defaults to opaque black) otherwise.
441 static nscolor
Color(ColorID aId
, ColorScheme aScheme
,
442 UseStandins aUseStandins
,
443 nscolor aDefault
= NS_RGB(0, 0, 0)) {
444 return GetColor(aId
, aScheme
, aUseStandins
).valueOr(aDefault
);
447 static nscolor
Color(ColorID aId
, nsIFrame
* aFrame
,
448 nscolor aDefault
= NS_RGB(0, 0, 0)) {
449 return GetColor(aId
, aFrame
).valueOr(aDefault
);
452 static float GetTextScaleFactor() {
453 float f
= GetFloat(FloatID::TextScaleFactor
, 1.0f
);
454 if (MOZ_UNLIKELY(f
<= 0.0f
)) {
460 struct ZoomSettings
{
461 float mFullZoom
= 1.0f
;
462 float mTextZoom
= 1.0f
;
465 static ZoomSettings
SystemZoomSettings();
468 * GetInt() and GetFloat() return a int or float value for aID. The result
469 * might be distance, time, some flags or a int value which has particular
470 * meaning. See each document at definition of each ID for the detail.
471 * The result is always 0 when they return error. Therefore, if you want to
472 * use a value for the default value, you should use the other method which
473 * returns int or float directly.
475 static nsresult
GetInt(IntID
, int32_t* aResult
);
476 static nsresult
GetFloat(FloatID aID
, float* aResult
);
478 static int32_t GetInt(IntID aID
, int32_t aDefault
= 0) {
480 if (NS_FAILED(GetInt(aID
, &result
))) {
486 static float GetFloat(FloatID aID
, float aDefault
= 0.0f
) {
488 if (NS_FAILED(GetFloat(aID
, &result
))) {
495 * Retrieve the name and style of a system-theme font. Returns true
496 * if the system theme specifies this font, false if a default should
497 * be used. In the latter case neither aName nor aStyle is modified.
499 * Size of the font should be in CSS pixels, not device pixels.
501 * @param aID Which system-theme font is wanted.
502 * @param aName The name of the font to use.
503 * @param aStyle Styling to apply to the font.
505 static bool GetFont(FontID aID
, nsString
& aName
, gfxFontStyle
& aStyle
);
508 * GetPasswordCharacter() returns a unicode character which should be used
509 * for a masked character in password editor. E.g., '*'.
511 static char16_t
GetPasswordCharacter();
514 * If the latest character in password field shouldn't be hidden by the
515 * result of GetPasswordCharacter(), GetEchoPassword() returns TRUE.
518 static bool GetEchoPassword();
521 * Whether we should be drawing in the titlebar by default.
523 static bool DrawInTitlebar();
525 enum class TitlebarAction
{
531 WindowMaximizeToggle
,
532 // We don't support more actions (maximize-horizontal, maximize-vertical,..)
533 // as they're implemented as part of Wayland gtk_surface1 protocol
534 // which is not accessible to us.
537 enum class TitlebarEvent
{
543 * Get system defined action for titlebar events.
545 static TitlebarAction
GetTitlebarAction(TitlebarEvent aEvent
);
548 * The millisecond to mask password value.
549 * This value is only valid when GetEchoPassword() returns true.
551 static uint32_t GetPasswordMaskDelay();
553 /** Gets theme information for about:support */
554 static void GetThemeInfo(nsACString
&);
557 * When system look and feel is changed, Refresh() must be called. Then,
558 * cached data would be released.
560 static void Refresh();
563 * GTK's initialization code can't be run off main thread, call this
564 * if you plan on using LookAndFeel off main thread later.
566 * This initialized state may get reset due to theme changes, so it
567 * must be called prior to each potential off-main-thread LookAndFeel
568 * call, not just once.
570 static void NativeInit();
572 static void SetData(widget::FullLookAndFeel
&& aTables
);
573 static void NotifyChangedAllWindows(widget::ThemeChangeKind
);
574 static bool HasPendingGlobalThemeChange() { return sGlobalThemeChanged
; }
575 static void HandleGlobalThemeChange() {
576 if (MOZ_UNLIKELY(HasPendingGlobalThemeChange())) {
577 DoHandleGlobalThemeChange();
581 static nsresult
GetKeyboardLayout(nsACString
& aLayout
);
584 static void DoHandleGlobalThemeChange();
585 // Set to true when ThemeChanged needs to be called on mTheme (and other
586 // global LookAndFeel. This is used because mTheme is a service, so there's
587 // no need to notify it from more than one prescontext.
588 static bool sGlobalThemeChanged
;
591 MOZ_MAKE_ENUM_CLASS_BITWISE_OPERATORS(LookAndFeel::PointingDeviceKinds
);
593 } // namespace mozilla
595 // ---------------------------------------------------------------------
596 // Special colors for ColorID::IME* and ColorID::SpellCheckerUnderline
597 // ---------------------------------------------------------------------
599 // For background color only.
600 constexpr nscolor NS_TRANSPARENT
= NS_RGBA(0x01, 0x00, 0x00, 0x00);
601 // For foreground color only.
602 constexpr nscolor NS_SAME_AS_FOREGROUND_COLOR
= NS_RGBA(0x02, 0x00, 0x00, 0x00);
603 constexpr nscolor NS_40PERCENT_FOREGROUND_COLOR
=
604 NS_RGBA(0x03, 0x00, 0x00, 0x00);
606 #define NS_IS_SELECTION_SPECIAL_COLOR(c) \
607 ((c) == NS_TRANSPARENT || (c) == NS_SAME_AS_FOREGROUND_COLOR || \
608 (c) == NS_40PERCENT_FOREGROUND_COLOR)
610 // ------------------------------------------
611 // Bits for IntID::AlertNotificationOrigin
612 // ------------------------------------------
614 #define NS_ALERT_HORIZONTAL 1
615 #define NS_ALERT_LEFT 2
616 #define NS_ALERT_TOP 4
618 #endif /* __LookAndFeel */