mirror of
https://github.com/LadybirdBrowser/ladybird.git
synced 2025-10-05 07:39:16 +00:00
CSSUnitValue is a typed-om type which we will implement separately in the future. However, it still seems useful to give our dimension values a base class. (Maybe they could be templated in the future?) So instead of deleting it entirely, rename it to DimensionStyleValue and make its API match our style better.
46 lines
1.2 KiB
C++
46 lines
1.2 KiB
C++
/*
|
|
* Copyright (c) 2023-2024, Sam Atkins <sam@ladybird.org>
|
|
*
|
|
* SPDX-License-Identifier: BSD-2-Clause
|
|
*/
|
|
|
|
#pragma once
|
|
|
|
#include <LibWeb/CSS/Flex.h>
|
|
#include <LibWeb/CSS/StyleValues/DimensionStyleValue.h>
|
|
|
|
namespace Web::CSS {
|
|
|
|
class FlexStyleValue final : public DimensionStyleValue {
|
|
public:
|
|
static ValueComparingNonnullRefPtr<FlexStyleValue const> create(Flex flex)
|
|
{
|
|
return adopt_ref(*new (nothrow) FlexStyleValue(move(flex)));
|
|
}
|
|
virtual ~FlexStyleValue() override = default;
|
|
|
|
Flex const& flex() const { return m_flex; }
|
|
virtual double raw_value() const override { return m_flex.raw_value(); }
|
|
virtual StringView unit_name() const override { return m_flex.unit_name(); }
|
|
|
|
virtual String to_string(SerializationMode serialization_mode) const override { return m_flex.to_string(serialization_mode); }
|
|
|
|
bool equals(StyleValue const& other) const override
|
|
{
|
|
if (type() != other.type())
|
|
return false;
|
|
auto const& other_flex = other.as_flex();
|
|
return m_flex == other_flex.m_flex;
|
|
}
|
|
|
|
private:
|
|
FlexStyleValue(Flex&& flex)
|
|
: DimensionStyleValue(Type::Flex)
|
|
, m_flex(flex)
|
|
{
|
|
}
|
|
|
|
Flex m_flex;
|
|
};
|
|
|
|
}
|