This source file includes following definitions.
- meterElement
- rendererIsNeeded
- create
- rendererIsNeeded
- createRenderer
- create
- create
- valuePseudoId
- setWidthPercentage
#include "config.h"
#include "core/html/shadow/MeterShadowElement.h"
#include "CSSPropertyNames.h"
#include "HTMLNames.h"
#include "core/html/HTMLMeterElement.h"
#include "core/rendering/RenderMeter.h"
#include "core/rendering/RenderTheme.h"
namespace WebCore {
using namespace HTMLNames;
inline MeterShadowElement::MeterShadowElement(Document& document)
: HTMLDivElement(document)
{
}
HTMLMeterElement* MeterShadowElement::meterElement() const
{
return toHTMLMeterElement(shadowHost());
}
bool MeterShadowElement::rendererIsNeeded(const RenderStyle& style)
{
RenderObject* renderer = meterElement()->renderer();
return renderer && !RenderTheme::theme().supportsMeter(renderer->style()->appearance()) && HTMLDivElement::rendererIsNeeded(style);
}
inline MeterInnerElement::MeterInnerElement(Document& document)
: MeterShadowElement(document)
{
}
PassRefPtr<MeterInnerElement> MeterInnerElement::create(Document& document)
{
RefPtr<MeterInnerElement> element = adoptRef(new MeterInnerElement(document));
element->setShadowPseudoId(AtomicString("-webkit-meter-inner-element", AtomicString::ConstructFromLiteral));
return element.release();
}
bool MeterInnerElement::rendererIsNeeded(const RenderStyle& style)
{
if (meterElement()->hasAuthorShadowRoot())
return HTMLDivElement::rendererIsNeeded(style);
RenderObject* renderer = meterElement()->renderer();
return renderer && !RenderTheme::theme().supportsMeter(renderer->style()->appearance()) && HTMLDivElement::rendererIsNeeded(style);
}
RenderObject* MeterInnerElement::createRenderer(RenderStyle*)
{
return new RenderMeter(this);
}
inline MeterBarElement::MeterBarElement(Document& document)
: MeterShadowElement(document)
{
}
PassRefPtr<MeterBarElement> MeterBarElement::create(Document& document)
{
RefPtr<MeterBarElement> element = adoptRef(new MeterBarElement(document));
element->setShadowPseudoId(AtomicString("-webkit-meter-bar", AtomicString::ConstructFromLiteral));
return element.release();
}
inline MeterValueElement::MeterValueElement(Document& document)
: MeterShadowElement(document)
{
}
PassRefPtr<MeterValueElement> MeterValueElement::create(Document& document)
{
RefPtr<MeterValueElement> element = adoptRef(new MeterValueElement(document));
element->updatePseudo();
return element.release();
}
const AtomicString& MeterValueElement::valuePseudoId() const
{
DEFINE_STATIC_LOCAL(AtomicString, optimumPseudoId, ("-webkit-meter-optimum-value", AtomicString::ConstructFromLiteral));
DEFINE_STATIC_LOCAL(AtomicString, suboptimumPseudoId, ("-webkit-meter-suboptimum-value", AtomicString::ConstructFromLiteral));
DEFINE_STATIC_LOCAL(AtomicString, evenLessGoodPseudoId, ("-webkit-meter-even-less-good-value", AtomicString::ConstructFromLiteral));
HTMLMeterElement* meter = meterElement();
if (!meter)
return optimumPseudoId;
switch (meter->gaugeRegion()) {
case HTMLMeterElement::GaugeRegionOptimum:
return optimumPseudoId;
case HTMLMeterElement::GaugeRegionSuboptimal:
return suboptimumPseudoId;
case HTMLMeterElement::GaugeRegionEvenLessGood:
return evenLessGoodPseudoId;
default:
ASSERT_NOT_REACHED();
return optimumPseudoId;
}
}
void MeterValueElement::setWidthPercentage(double width)
{
setInlineStyleProperty(CSSPropertyWidth, width, CSSPrimitiveValue::CSS_PERCENTAGE);
}
}