/* * Copyright (c) 2018-2020, Andreas Kling * Copyright (c) 2021, Tobias Christiansen * Copyright (c) 2021-2025, Sam Atkins * Copyright (c) 2022-2023, MacDue * * SPDX-License-Identifier: BSD-2-Clause */ #pragma once #include #include #include namespace Web::CSS { class TransformationStyleValue final : public StyleValueWithDefaultOperators { public: static ValueComparingNonnullRefPtr create(PropertyID property, TransformFunction transform_function, StyleValueVector&& values) { return adopt_ref(*new (nothrow) TransformationStyleValue(property, transform_function, move(values))); } virtual ~TransformationStyleValue() override = default; static ValueComparingNonnullRefPtr identity_transformation(TransformFunction); TransformFunction transform_function() const { return m_properties.transform_function; } StyleValueVector const& values() const { return m_properties.values; } ErrorOr to_matrix(Optional) const; virtual void serialize(StringBuilder&, SerializationMode) const override; ErrorOr> reify_a_transform_function(JS::Realm&) const; virtual ValueComparingNonnullRefPtr absolutized(ComputationContext const&) const override; bool properties_equal(TransformationStyleValue const& other) const { return m_properties == other.m_properties; } virtual bool is_computationally_independent() const override { return all_of(m_properties.values, [](auto& value) { return value->is_computationally_independent(); }); } private: TransformationStyleValue(PropertyID property, TransformFunction transform_function, StyleValueVector&& values) : StyleValueWithDefaultOperators(Type::Transformation) , m_properties { .property = property, .transform_function = transform_function, .values = move(values) } { } struct Properties { PropertyID property; TransformFunction transform_function; StyleValueVector values; bool operator==(Properties const& other) const; } m_properties; }; }