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 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 145 146 147 148 149 150 151 152 153 154 155 156 157 158 159 160 161 162 163 164 165 166 167
|
/* -*- 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/. */
// This defines a common base class for nsITheme implementations, to reduce
// code duplication.
#ifndef _NSNATIVETHEME_H_
#define _NSNATIVETHEME_H_
#include "nsAtom.h"
#include "nsColor.h"
#include "nsCOMPtr.h"
#include "nsString.h"
#include "nsMargin.h"
#include "nsGkAtoms.h"
#include "nsTArray.h"
#include "nsINamed.h"
#include "nsITimer.h"
#include "nsIContent.h"
#include "mozilla/dom/RustTypes.h"
class nsIFrame;
class nsPresContext;
namespace mozilla {
class ComputedStyle;
enum class StyleAppearance : uint8_t;
} // namespace mozilla
class nsNativeTheme : public nsITimerCallback, public nsINamed {
protected:
virtual ~nsNativeTheme() = default;
NS_DECL_ISUPPORTS
NS_DECL_NSITIMERCALLBACK
NS_DECL_NSINAMED
nsNativeTheme();
public:
enum ScrollbarButtonType {
eScrollbarButton_UpTop = 0,
eScrollbarButton_Down = 1 << 0,
eScrollbarButton_Bottom = 1 << 1
};
enum TreeSortDirection {
eTreeSortDirection_Descending,
eTreeSortDirection_Natural,
eTreeSortDirection_Ascending
};
// Returns the content state (hover, focus, etc), see EventStateManager.h
static mozilla::dom::ElementState GetContentState(
nsIFrame* aFrame, mozilla::StyleAppearance aAppearance);
// Returns whether the widget is already styled by content
// Normally called from ThemeSupportsWidget to turn off native theming
// for elements that are already styled.
bool IsWidgetStyled(nsPresContext* aPresContext, nsIFrame* aFrame,
mozilla::StyleAppearance aAppearance);
// RTL chrome direction
static bool IsFrameRTL(nsIFrame* aFrame);
static bool IsHTMLContent(nsIFrame* aFrame);
// button:
bool IsDefaultButton(nsIFrame* aFrame) {
return CheckBooleanAttr(aFrame, nsGkAtoms::_default);
}
bool IsButtonTypeMenu(nsIFrame* aFrame);
// tab:
bool IsSelectedTab(nsIFrame* aFrame) {
return CheckBooleanAttr(aFrame, nsGkAtoms::visuallyselected);
}
bool IsNextToSelectedTab(nsIFrame* aFrame, int32_t aOffset);
bool IsBeforeSelectedTab(nsIFrame* aFrame) {
return IsNextToSelectedTab(aFrame, -1);
}
bool IsAfterSelectedTab(nsIFrame* aFrame) {
return IsNextToSelectedTab(aFrame, 1);
}
bool IsLeftToSelectedTab(nsIFrame* aFrame) {
return IsFrameRTL(aFrame) ? IsAfterSelectedTab(aFrame)
: IsBeforeSelectedTab(aFrame);
}
bool IsRightToSelectedTab(nsIFrame* aFrame) {
return IsFrameRTL(aFrame) ? IsBeforeSelectedTab(aFrame)
: IsAfterSelectedTab(aFrame);
}
// button / toolbarbutton:
bool IsCheckedButton(nsIFrame* aFrame) {
return CheckBooleanAttr(aFrame, nsGkAtoms::checked);
}
bool IsSelectedButton(nsIFrame* aFrame) {
return CheckBooleanAttr(aFrame, nsGkAtoms::checked) ||
CheckBooleanAttr(aFrame, nsGkAtoms::selected);
}
bool IsOpenButton(nsIFrame* aFrame) {
return CheckBooleanAttr(aFrame, nsGkAtoms::open);
}
bool IsPressedButton(nsIFrame* aFrame);
// treeheadercell:
TreeSortDirection GetTreeSortDirection(nsIFrame* aFrame);
bool IsLastTreeHeaderCell(nsIFrame* aFrame);
// tab:
bool IsBottomTab(nsIFrame* aFrame);
bool IsFirstTab(nsIFrame* aFrame);
// progressbar:
bool IsVerticalProgress(nsIFrame* aFrame);
// meter:
bool IsVerticalMeter(nsIFrame* aFrame);
// textfield:
bool IsReadOnly(nsIFrame* aFrame) {
return CheckBooleanAttr(aFrame, nsGkAtoms::readonly);
}
// menupopup:
bool IsSubmenu(nsIFrame* aFrame, bool* aLeftOfParent);
static bool CheckBooleanAttr(nsIFrame* aFrame, nsAtom* aAtom);
static int32_t CheckIntAttr(nsIFrame* aFrame, nsAtom* aAtom,
int32_t defaultValue);
// Helpers for progressbar.
static double GetProgressValue(nsIFrame* aFrame);
static double GetProgressMaxValue(nsIFrame* aFrame);
bool QueueAnimatedContentForRefresh(nsIContent* aContent,
uint32_t aMinimumFrameRate);
nsIFrame* GetAdjacentSiblingFrameWithSameAppearance(nsIFrame* aFrame,
bool aNextSibling);
bool IsRangeHorizontal(nsIFrame* aFrame);
static bool IsDarkBackgroundForScrollbar(nsIFrame*);
static bool IsDarkBackground(nsIFrame*);
static bool IsWidgetScrollbarPart(mozilla::StyleAppearance);
static bool IsWidgetAlwaysNonNative(nsIFrame*, mozilla::StyleAppearance);
private:
uint32_t mAnimatedContentTimeout;
nsCOMPtr<nsITimer> mAnimatedContentTimer;
AutoTArray<nsCOMPtr<nsIContent>, 20> mAnimatedContentList;
};
#endif // _NSNATIVETHEME_H_
|