mirror of
https://github.com/LadybirdBrowser/ladybird.git
synced 2025-10-04 07:09:41 +00:00
This reverts 0e3487b9ab
.
Back when I made that change, I thought we could make our StyleValue
classes match the typed-om definitions directly. However, they have
different requirements. Typed-om types need to be mutable and GCed,
whereas StyleValues are immutable and ideally wouldn't require a JS VM.
While I was already making such a cataclysmic change, I've moved it into
the StyleValues directory, because it *not* being there has bothered me
for a long time. 😅
36 lines
969 B
C++
36 lines
969 B
C++
/*
|
|
* Copyright (c) 2024, Matthew Olsson <mattco@serenityos.org>.
|
|
*
|
|
* SPDX-License-Identifier: BSD-2-Clause
|
|
*/
|
|
|
|
#pragma once
|
|
|
|
#include <LibWeb/Animations/Animation.h>
|
|
#include <LibWeb/CSS/PropertyID.h>
|
|
#include <LibWeb/CSS/StyleValues/StyleValue.h>
|
|
|
|
namespace Web::CSS {
|
|
|
|
// https://www.w3.org/TR/css-animations-2/#cssanimation
|
|
class CSSAnimation : public Animations::Animation {
|
|
WEB_PLATFORM_OBJECT(CSSAnimation, Animations::Animation);
|
|
GC_DECLARE_ALLOCATOR(CSSAnimation);
|
|
|
|
public:
|
|
static GC::Ref<CSSAnimation> create(JS::Realm&);
|
|
|
|
FlyString const& animation_name() const { return id(); }
|
|
|
|
virtual Animations::AnimationClass animation_class() const override;
|
|
virtual Optional<int> class_specific_composite_order(GC::Ref<Animations::Animation> other) const override;
|
|
|
|
private:
|
|
explicit CSSAnimation(JS::Realm&);
|
|
|
|
virtual void initialize(JS::Realm&) override;
|
|
|
|
virtual bool is_css_animation() const override { return true; }
|
|
};
|
|
|
|
}
|