mirror of
https://github.com/mozilla/gecko-dev.git
synced 2024-12-12 00:50:40 +00:00
12867b1a3f
Differential Revision: https://phabricator.services.mozilla.com/D18734
115 lines
3.9 KiB
C++
115 lines
3.9 KiB
C++
/* -*- Mode: C++; tab-width: 8; indent-tabs-mode: nil; c-basic-offset: 2 -*- */
|
|
/* vim: set ts=8 sts=2 et sw=2 tw=80: */
|
|
/* 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 nsCheckboxRadioFrame_h___
|
|
#define nsCheckboxRadioFrame_h___
|
|
|
|
#include "mozilla/Attributes.h"
|
|
#include "nsIFormControlFrame.h"
|
|
#include "nsAtomicContainerFrame.h"
|
|
#include "nsDisplayList.h"
|
|
|
|
/**
|
|
* nsCheckboxRadioFrame is used for radio buttons and checkboxes.
|
|
* It also has two static methods (RegUnRegAccessKey and
|
|
* GetScreenHeight) that are used by other form controls.
|
|
*/
|
|
class nsCheckboxRadioFrame final : public nsAtomicContainerFrame,
|
|
public nsIFormControlFrame {
|
|
public:
|
|
NS_DECL_QUERYFRAME
|
|
NS_DECL_FRAMEARENA_HELPERS(nsCheckboxRadioFrame)
|
|
|
|
explicit nsCheckboxRadioFrame(ComputedStyle* aStyle,
|
|
nsPresContext* aPresContext);
|
|
|
|
// nsIFrame replacements
|
|
virtual bool IsFrameOfType(uint32_t aFlags) const override {
|
|
return nsAtomicContainerFrame::IsFrameOfType(
|
|
aFlags & ~(nsIFrame::eReplaced | nsIFrame::eReplacedContainsBlock));
|
|
}
|
|
|
|
virtual void BuildDisplayList(nsDisplayListBuilder* aBuilder,
|
|
const nsDisplayListSet& aLists) override {
|
|
DO_GLOBAL_REFLOW_COUNT_DSP("nsCheckboxRadioFrame");
|
|
DisplayBorderBackgroundOutline(aBuilder, aLists);
|
|
}
|
|
|
|
/**
|
|
* Both GetMinISize and GetPrefISize will return whatever GetIntrinsicISize
|
|
* returns.
|
|
*/
|
|
virtual nscoord GetMinISize(gfxContext* aRenderingContext) override;
|
|
virtual nscoord GetPrefISize(gfxContext* aRenderingContext) override;
|
|
|
|
/**
|
|
* Our auto size is just intrinsic width and intrinsic height.
|
|
*/
|
|
virtual mozilla::LogicalSize ComputeAutoSize(
|
|
gfxContext* aRenderingContext, mozilla::WritingMode aWM,
|
|
const mozilla::LogicalSize& aCBSize, nscoord aAvailableISize,
|
|
const mozilla::LogicalSize& aMargin, const mozilla::LogicalSize& aBorder,
|
|
const mozilla::LogicalSize& aPadding, ComputeSizeFlags aFlags) override;
|
|
|
|
/**
|
|
* Respond to a gui event
|
|
* @see nsIFrame::HandleEvent
|
|
*/
|
|
virtual nsresult HandleEvent(nsPresContext* aPresContext,
|
|
mozilla::WidgetGUIEvent* aEvent,
|
|
nsEventStatus* aEventStatus) override;
|
|
|
|
virtual nscoord GetLogicalBaseline(
|
|
mozilla::WritingMode aWritingMode) const override;
|
|
|
|
/**
|
|
* Respond to the request to resize and/or reflow
|
|
* @see nsIFrame::Reflow
|
|
*/
|
|
virtual void Reflow(nsPresContext* aCX, ReflowOutput& aDesiredSize,
|
|
const ReflowInput& aReflowInput,
|
|
nsReflowStatus& aStatus) override;
|
|
|
|
virtual void DestroyFrom(nsIFrame* aDestructRoot,
|
|
PostDestroyData& aPostDestroyData) override;
|
|
|
|
// new behavior
|
|
|
|
virtual void SetFocus(bool aOn = true, bool aRepaint = false) override;
|
|
|
|
// nsIFormControlFrame
|
|
virtual nsresult SetFormProperty(nsAtom* aName,
|
|
const nsAString& aValue) override;
|
|
|
|
// AccessKey Helper function
|
|
static nsresult RegUnRegAccessKey(nsIFrame* aFrame, bool aDoReg);
|
|
|
|
/**
|
|
* Returns the usable screen rect in app units, eg the rect where we can
|
|
* draw dropdowns.
|
|
*/
|
|
static nsRect GetUsableScreenRect(nsPresContext* aPresContext);
|
|
|
|
protected:
|
|
virtual ~nsCheckboxRadioFrame();
|
|
|
|
static nscoord DefaultSize() {
|
|
// XXXmats We have traditionally always returned 9px for GetMin/PrefISize
|
|
// but we might want to factor in what the theme says, something like:
|
|
// GetMinimumWidgetSize - GetWidgetPadding - GetWidgetBorder.
|
|
return nsPresContext::CSSPixelsToAppUnits(9);
|
|
}
|
|
|
|
/**
|
|
* Get the state of the checked attribute.
|
|
* @param aState set to true if the checked attribute is set,
|
|
* false if the checked attribute has been removed
|
|
*/
|
|
void GetCurrentCheckState(bool* aState);
|
|
};
|
|
|
|
#endif
|