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 // show the caret when text is selected?
57 ShowCaretDuringSelection
,
58 // select textfields when focused via tab/accesskey?
59 SelectTextfieldsOnKeyFocus
,
60 // delay before submenus open
62 // can popups overlap menu/task bar?
64 // should overlay scrollbars be used?
66 // allow H and V overlay scrollbars to overlap?
67 AllowOverlayScrollbarsOverlap
,
68 // skip navigating to disabled menu item?
69 SkipNavigatingDisabledMenuItem
,
70 // begin a drag if the mouse is moved further than the threshold while the
74 // Accessibility theme being used?
75 UseAccessibilityTheme
,
77 // position of scroll arrows in a scrollbar
80 // each button can take one of four values:
81 ScrollButtonLeftMouseButtonAction
,
82 // 0 - scrolls one line, 1 - scrolls one page
83 ScrollButtonMiddleMouseButtonAction
,
84 // 2 - scrolls to end, 3 - button ignored
85 ScrollButtonRightMouseButtonAction
,
87 // delay for opening spring loaded folders
89 // delay for closing spring loaded folders
91 // delay for triggering the tree scrolling
93 // delay for scrolling the tree
95 // the maximum number of lines to be scrolled at ones
97 // What type of tab-order to use
99 // Should menu items blink when they're chosen?
100 ChosenMenuItemsShouldBlink
,
103 * A Boolean value to determine whether the Windows accent color
104 * should be applied to the title bar.
106 * The value of this metric is not used on other platforms. These platforms
107 * should return NS_ERROR_NOT_IMPLEMENTED when queried for this metric.
109 WindowsAccentColorInTitlebar
,
112 * A Boolean value to determine whether the Windows default theme is
115 * The value of this metric is not used on other platforms. These platforms
116 * should return NS_ERROR_NOT_IMPLEMENTED when queried for this metric.
121 * A Boolean value to determine whether the DWM compositor is being used
123 * This metric is not used on non-Windows platforms. These platforms
124 * should return NS_ERROR_NOT_IMPLEMENTED when queried for this metric.
129 * A Boolean value to determine whether Windows is themed (Classic vs.
132 * This is Windows-specific and is not implemented on other platforms
133 * (will return the default of NS_ERROR_FAILURE).
138 * A Boolean value to determine whether the current Windows desktop theme
139 * supports Aero Glass.
141 * This is Windows-specific and is not implemented on other platforms
142 * (will return the default of NS_ERROR_FAILURE).
147 * A Boolean value to determine whether the Mac graphite theme is
153 * A Boolean value to determine whether the macOS Big Sur-specific
154 * theming should be used.
159 * A Boolean value to determine whether macOS is in RTL mode or not.
164 * AlertNotificationOrigin indicates from which corner of the
165 * screen alerts slide in, and from which direction (horizontal/vertical).
166 * 0, the default, represents bottom right, sliding vertically.
167 * Use any bitwise combination of the following constants:
168 * NS_ALERT_HORIZONTAL (1), NS_ALERT_LEFT (2), NS_ALERT_TOP (4).
178 AlertNotificationOrigin
,
181 * If true, clicking on a scrollbar (not as in dragging the thumb) defaults
182 * to scrolling the view corresponding to the clicked point. Otherwise, we
183 * only do so if the scrollbar is clicked using the middle mouse button or
184 * if shift is pressed when the scrollbar is clicked.
189 * IME and spell checker underline styles, the values should be
190 * NS_DECORATION_LINE_STYLE_*. They are defined below.
192 IMERawInputUnderlineStyle
,
193 IMESelectedRawTextUnderlineStyle
,
194 IMEConvertedTextUnderlineStyle
,
195 IMESelectedConvertedTextUnderline
,
196 SpellCheckerUnderlineStyle
,
199 * If this metric != 0, support window dragging on the menubar.
203 * 0: scrollbar button repeats to scroll only when cursor is on the button.
204 * 1: scrollbar button repeats to scroll even if cursor is outside of it.
206 ScrollbarButtonAutoRepeatBehavior
,
208 * Delay before showing a tooltip.
212 * A Boolean value to determine whether swipe animations should be used.
214 SwipeAnimationEnabled
,
217 * Controls whether overlay scrollbars display when the user moves
218 * the mouse in a scrollable frame.
220 ScrollbarDisplayOnMouseMove
,
223 * Overlay scrollbar animation constants.
225 ScrollbarFadeBeginDelay
,
226 ScrollbarFadeDuration
,
229 * Distance in pixels to offset the context menu from the cursor
232 ContextMenuOffsetVertical
,
233 ContextMenuOffsetHorizontal
,
236 * A boolean value indicating whether client-side decorations are
237 * supported by the user's GTK version.
242 * A boolean value indicating whether client-side decorations should
243 * contain a minimize button.
245 GTKCSDMinimizeButton
,
248 * A boolean value indicating whether client-side decorations should
249 * contain a maximize button.
251 GTKCSDMaximizeButton
,
254 * A boolean value indicating whether client-side decorations should
255 * contain a close button.
260 * An Integer value that will represent the position of the Minimize button
261 * in GTK Client side decoration header.
263 GTKCSDMinimizeButtonPosition
,
266 * An Integer value that will represent the position of the Maximize button
267 * in GTK Client side decoration header.
269 GTKCSDMaximizeButtonPosition
,
272 * An Integer value that will represent the position of the Close button
273 * in GTK Client side decoration header.
275 GTKCSDCloseButtonPosition
,
278 * A boolean value indicating whether titlebar buttons are located
279 * in left titlebar corner.
281 GTKCSDReversedPlacement
,
284 * A boolean value indicating whether or not the OS is using a dark theme,
285 * which we may want to switch to as well if not overridden by the user.
290 * Corresponding to prefers-reduced-motion.
291 * https://drafts.csswg.org/mediaqueries-5/#prefers-reduced-motion
295 PrefersReducedMotion
,
298 * Corresponding to prefers-reduced-transparency.
299 * https://drafts.csswg.org/mediaqueries-5/#prefers-reduced-transparency
303 PrefersReducedTransparency
,
306 * Corresponding to inverted-colors.
307 * https://drafts.csswg.org/mediaqueries-5/#inverted
314 * Corresponding to PointerCapabilities in ServoTypes.h
320 PrimaryPointerCapabilities
,
322 * Corresponding to union of PointerCapabilities values in ServoTypes.h
323 * E.g. if there is a mouse and a digitizer, the value will be
324 * 'Coarse | Fine | Hover'.
326 AllPointerCapabilities
,
328 /** The scrollbar size, in CSS pixels. */
331 /** A boolean value to determine whether a touch device is present */
332 TouchDeviceSupportPresent
,
334 /** GTK titlebar radius */
338 * Corresponding to dynamic-range.
339 * https://drafts.csswg.org/mediaqueries-5/#dynamic-range
346 /** Whether XUL panel animations are enabled. */
350 * Not an ID; used to define the range of valid IDs. Must be last.
355 // This is a common enough integer that seems worth the shortcut.
356 static bool UseOverlayScrollbars() {
357 return GetInt(IntID::UseOverlayScrollbars
);
360 // Returns keyCode value of a modifier key which is used for accesskey.
361 // Returns 0 if the platform doesn't support access key.
362 static uint32_t GetMenuAccessKey();
363 // Modifier mask for the menu accesskey.
364 static Modifiers
GetMenuAccessKeyModifiers();
367 eScrollArrow_None
= 0,
368 eScrollArrow_StartBackward
= 0x1000,
369 eScrollArrow_StartForward
= 0x0100,
370 eScrollArrow_EndBackward
= 0x0010,
371 eScrollArrow_EndForward
= 0x0001
375 // single arrow at each end
376 eScrollArrowStyle_Single
=
377 eScrollArrow_StartBackward
| eScrollArrow_EndForward
,
378 // both arrows at bottom/right, none at top/left
379 eScrollArrowStyle_BothAtBottom
=
380 eScrollArrow_EndBackward
| eScrollArrow_EndForward
,
381 // both arrows at both ends
382 eScrollArrowStyle_BothAtEachEnd
=
383 eScrollArrow_EndBackward
| eScrollArrow_EndForward
|
384 eScrollArrow_StartBackward
| eScrollArrow_StartForward
,
385 // both arrows at top/left, none at bottom/right
386 eScrollArrowStyle_BothAtTop
=
387 eScrollArrow_StartBackward
| eScrollArrow_StartForward
390 // When modifying this list, also modify nsXPLookAndFeel::sFloatPrefs
391 // in widget/nsXPLookAndFeel.cpp.
393 IMEUnderlineRelativeSize
,
394 SpellCheckerUnderlineRelativeSize
,
396 // The width/height ratio of the cursor. If used, the CaretWidth int metric
397 // should be added to the calculated caret width.
400 // GTK text scale factor.
403 // Mouse pointer scaling factor.
406 // Not an ID; used to define the range of valid IDs. Must be last.
410 using FontID
= mozilla::StyleSystemFont
;
412 static bool WindowsNonNativeMenusEnabled();
414 static ColorScheme
SystemColorScheme() {
415 return GetInt(IntID::SystemUsesDarkTheme
) ? ColorScheme::Dark
416 : ColorScheme::Light
;
419 static bool IsDarkColor(nscolor
);
421 enum class ChromeColorSchemeSetting
{ Light
, Dark
, System
};
422 static ChromeColorSchemeSetting
ColorSchemeSettingForChrome();
423 static ColorScheme
ThemeDerivedColorSchemeForContent();
425 static ColorScheme
ColorSchemeForChrome() {
426 MOZ_ASSERT(sColorSchemeInitialized
);
427 return sChromeColorScheme
;
429 static ColorScheme
PreferredColorSchemeForContent() {
430 MOZ_ASSERT(sColorSchemeInitialized
);
431 return sContentColorScheme
;
434 static ColorScheme
ColorSchemeForStyle(
435 const dom::Document
&, const StyleColorSchemeFlags
&,
436 ColorSchemeMode
= ColorSchemeMode::Used
);
437 static ColorScheme
ColorSchemeForFrame(
438 const nsIFrame
*, ColorSchemeMode
= ColorSchemeMode::Used
);
440 // Whether standins for native colors should be used (that is, colors faked,
441 // taken from win7, mostly). This forces light appearance, effectively.
442 enum class UseStandins
: bool { No
, Yes
};
443 static UseStandins
ShouldUseStandins(const dom::Document
&, ColorID
);
445 // Returns a native color value (might be overwritten by prefs) for a given
449 // ColorID::TextSelectForeground might return NS_SAME_AS_FOREGROUND_COLOR.
450 // ColorID::IME* might return NS_TRANSPARENT, NS_SAME_AS_FOREGROUND_COLOR or
451 // NS_40PERCENT_FOREGROUND_COLOR.
452 // These values have particular meaning. Then, they are not an actual
454 static Maybe
<nscolor
> GetColor(ColorID
, ColorScheme
, UseStandins
);
456 // Gets the color with appropriate defaults for UseStandins, ColorScheme etc
457 // for a given frame.
458 static Maybe
<nscolor
> GetColor(ColorID
, const nsIFrame
*);
460 // Versions of the above which returns the color if found, or a default (which
461 // defaults to opaque black) otherwise.
462 static nscolor
Color(ColorID aId
, ColorScheme aScheme
,
463 UseStandins aUseStandins
,
464 nscolor aDefault
= NS_RGB(0, 0, 0)) {
465 return GetColor(aId
, aScheme
, aUseStandins
).valueOr(aDefault
);
468 static nscolor
Color(ColorID aId
, nsIFrame
* aFrame
,
469 nscolor aDefault
= NS_RGB(0, 0, 0)) {
470 return GetColor(aId
, aFrame
).valueOr(aDefault
);
473 static float GetTextScaleFactor() {
474 float f
= GetFloat(FloatID::TextScaleFactor
, 1.0f
);
475 if (MOZ_UNLIKELY(f
<= 0.0f
)) {
481 struct ZoomSettings
{
482 float mFullZoom
= 1.0f
;
483 float mTextZoom
= 1.0f
;
486 static ZoomSettings
SystemZoomSettings();
489 * GetInt() and GetFloat() return a int or float value for aID. The result
490 * might be distance, time, some flags or a int value which has particular
491 * meaning. See each document at definition of each ID for the detail.
492 * The result is always 0 when they return error. Therefore, if you want to
493 * use a value for the default value, you should use the other method which
494 * returns int or float directly.
496 static nsresult
GetInt(IntID
, int32_t* aResult
);
497 static nsresult
GetFloat(FloatID aID
, float* aResult
);
499 static int32_t GetInt(IntID aID
, int32_t aDefault
= 0) {
501 if (NS_FAILED(GetInt(aID
, &result
))) {
507 static float GetFloat(FloatID aID
, float aDefault
= 0.0f
) {
509 if (NS_FAILED(GetFloat(aID
, &result
))) {
516 * Retrieve the name and style of a system-theme font. Returns true
517 * if the system theme specifies this font, false if a default should
518 * be used. In the latter case neither aName nor aStyle is modified.
520 * Size of the font should be in CSS pixels, not device pixels.
522 * @param aID Which system-theme font is wanted.
523 * @param aName The name of the font to use.
524 * @param aStyle Styling to apply to the font.
526 static bool GetFont(FontID aID
, nsString
& aName
, gfxFontStyle
& aStyle
);
529 * GetPasswordCharacter() returns a unicode character which should be used
530 * for a masked character in password editor. E.g., '*'.
532 static char16_t
GetPasswordCharacter();
535 * If the latest character in password field shouldn't be hidden by the
536 * result of GetPasswordCharacter(), GetEchoPassword() returns TRUE.
539 static bool GetEchoPassword();
542 * Whether we should be drawing in the titlebar by default.
544 static bool DrawInTitlebar();
547 * The millisecond to mask password value.
548 * This value is only valid when GetEchoPassword() returns true.
550 static uint32_t GetPasswordMaskDelay();
552 /** Gets theme information for about:support */
553 static void GetThemeInfo(nsACString
&);
556 * When system look and feel is changed, Refresh() must be called. Then,
557 * cached data would be released.
559 static void Refresh();
562 * GTK's initialization code can't be run off main thread, call this
563 * if you plan on using LookAndFeel off main thread later.
565 * This initialized state may get reset due to theme changes, so it
566 * must be called prior to each potential off-main-thread LookAndFeel
567 * call, not just once.
569 static void NativeInit();
571 static void SetData(widget::FullLookAndFeel
&& aTables
);
572 static void NotifyChangedAllWindows(widget::ThemeChangeKind
);
573 static bool HasPendingGlobalThemeChange() { return sGlobalThemeChanged
; }
574 static void HandleGlobalThemeChange() {
575 if (MOZ_UNLIKELY(HasPendingGlobalThemeChange())) {
576 DoHandleGlobalThemeChange();
579 static void EnsureColorSchemesInitialized() {
580 if (!sColorSchemeInitialized
) {
581 RecomputeColorSchemes();
583 MOZ_ASSERT(sColorSchemeInitialized
);
586 static ColorScheme sChromeColorScheme
;
587 static ColorScheme sContentColorScheme
;
590 static void RecomputeColorSchemes();
591 static bool sColorSchemeInitialized
;
593 static void DoHandleGlobalThemeChange();
594 // Set to true when ThemeChanged needs to be called on mTheme (and other
595 // global LookAndFeel. This is used because mTheme is a service, so there's
596 // no need to notify it from more than one prescontext.
597 static bool sGlobalThemeChanged
;
600 } // namespace mozilla
602 // ---------------------------------------------------------------------
603 // Special colors for ColorID::IME* and ColorID::SpellCheckerUnderline
604 // ---------------------------------------------------------------------
606 // For background color only.
607 constexpr nscolor NS_TRANSPARENT
= NS_RGBA(0x01, 0x00, 0x00, 0x00);
608 // For foreground color only.
609 constexpr nscolor NS_SAME_AS_FOREGROUND_COLOR
= NS_RGBA(0x02, 0x00, 0x00, 0x00);
610 constexpr nscolor NS_40PERCENT_FOREGROUND_COLOR
=
611 NS_RGBA(0x03, 0x00, 0x00, 0x00);
613 #define NS_IS_SELECTION_SPECIAL_COLOR(c) \
614 ((c) == NS_TRANSPARENT || (c) == NS_SAME_AS_FOREGROUND_COLOR || \
615 (c) == NS_40PERCENT_FOREGROUND_COLOR)
617 // ------------------------------------------
618 // Bits for IntID::AlertNotificationOrigin
619 // ------------------------------------------
621 #define NS_ALERT_HORIZONTAL 1
622 #define NS_ALERT_LEFT 2
623 #define NS_ALERT_TOP 4
625 #endif /* __LookAndFeel */