ladybird/Libraries/LibWeb/CSS/StyleValues/TimeStyleValue.h
Sam Atkins 99bce9a94d LibWeb/CSS: Replace CSSUnitValue with DimensionStyleValue
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.
2025-08-08 15:19:03 +01:00

49 lines
1.4 KiB
C++

/*
* Copyright (c) 2018-2020, Andreas Kling <andreas@ladybird.org>
* Copyright (c) 2021, Tobias Christiansen <tobyase@serenityos.org>
* Copyright (c) 2021-2024, Sam Atkins <sam@ladybird.org>
* Copyright (c) 2022-2023, MacDue <macdue@dueutil.tech>
*
* SPDX-License-Identifier: BSD-2-Clause
*/
#pragma once
#include <LibWeb/CSS/StyleValues/DimensionStyleValue.h>
#include <LibWeb/CSS/Time.h>
namespace Web::CSS {
class TimeStyleValue : public DimensionStyleValue {
public:
static ValueComparingNonnullRefPtr<TimeStyleValue const> create(Time time)
{
return adopt_ref(*new (nothrow) TimeStyleValue(move(time)));
}
virtual ~TimeStyleValue() override = default;
Time const& time() const { return m_time; }
virtual double raw_value() const override { return m_time.raw_value(); }
virtual StringView unit_name() const override { return m_time.unit_name(); }
virtual String to_string(SerializationMode serialization_mode) const override { return m_time.to_string(serialization_mode); }
bool equals(StyleValue const& other) const override
{
if (type() != other.type())
return false;
auto const& other_time = other.as_time();
return m_time == other_time.m_time;
}
private:
explicit TimeStyleValue(Time time)
: DimensionStyleValue(Type::Time)
, m_time(move(time))
{
}
Time m_time;
};
}