| 
									
										
										
										
											2022-08-24 12:21:15 +02:00
										 |  |  | /*
 | 
					
						
							|  |  |  |  * Copyright (c) 2022, Martin Falisse <mfalisse@outlook.com> | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * SPDX-License-Identifier: BSD-2-Clause | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #pragma once
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
											  
											
												LibWeb: Add parent classes for managing GridTrackSizes
Add classes ExplicitTrackSizing and MetaGridTrackSize which will allow
for managing properties like auto-fill and minmax.
In the following CSS example there are 3 classes that will be used:
grid-template-column: repeat(auto-fill, minmax(50px, 1fr) 75px);
ExplicitTrackSizing - will contain the entire value. e.g.
repeat(auto-fill, minmax(50px, 1fr) 75px)
With a flag if it's a repeat, as well as references to the
MetaGridTrackSizes which is the next step down.
MetaGridTrackSize:
Contain the individual grid track sizes. Here there are two:
minmax(50px, 1fr) as well as 75px.
This way can keep track if it's a minmax function or not, and the
references to both GridTrackSizes in the case it is, or in just the one
if it is not.
GridTrackSize:
Is the most basic element, in this case there are three in total; two of
which are held by the first MetaGridTrackSize, and the third is held by
the second MetaGridTrackSize.
Examples: 50px, 1fr and 75px.
											
										 
											2022-10-09 19:34:27 +02:00
										 |  |  | #include <AK/Vector.h>
 | 
					
						
							| 
									
										
										
										
											2023-05-10 22:38:44 +03:00
										 |  |  | #include <LibWeb/CSS/PercentageOr.h>
 | 
					
						
							| 
									
										
										
										
											2023-05-28 19:31:26 +03:00
										 |  |  | #include <LibWeb/Layout/AvailableSpace.h>
 | 
					
						
							| 
									
										
										
										
											2022-08-24 12:21:15 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  | namespace Web::CSS { | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2022-10-30 13:27:57 +01:00
										 |  |  | class GridSize { | 
					
						
							| 
									
										
										
										
											2022-08-24 12:21:15 +02:00
										 |  |  | public: | 
					
						
							|  |  |  |     enum class Type { | 
					
						
							| 
									
										
										
										
											2023-05-10 22:38:44 +03:00
										 |  |  |         LengthPercentage, | 
					
						
							| 
									
										
										
										
											2022-08-24 12:21:15 +02:00
										 |  |  |         FlexibleLength, | 
					
						
							| 
									
										
										
										
											2024-07-22 22:49:52 +02:00
										 |  |  |         FitContent, | 
					
						
							| 
									
										
										
										
											2023-01-16 17:33:30 +01:00
										 |  |  |         MaxContent, | 
					
						
							|  |  |  |         MinContent, | 
					
						
							| 
									
										
										
										
											2022-08-24 12:21:15 +02:00
										 |  |  |     }; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-07-22 22:49:52 +02:00
										 |  |  |     GridSize(Type, LengthPercentage); | 
					
						
							| 
									
										
										
										
											2023-05-10 22:38:44 +03:00
										 |  |  |     GridSize(LengthPercentage); | 
					
						
							| 
									
										
										
										
											2023-09-28 15:23:04 +01:00
										 |  |  |     GridSize(Flex); | 
					
						
							| 
									
										
										
										
											2023-01-16 17:33:30 +01:00
										 |  |  |     GridSize(Type); | 
					
						
							| 
									
										
										
										
											2022-10-30 13:27:57 +01:00
										 |  |  |     GridSize(); | 
					
						
							|  |  |  |     ~GridSize(); | 
					
						
							| 
									
										
										
										
											2022-08-24 12:21:15 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2022-10-30 13:27:57 +01:00
										 |  |  |     static GridSize make_auto(); | 
					
						
							| 
									
										
										
										
											2022-09-07 15:09:32 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2022-08-24 12:21:15 +02:00
										 |  |  |     Type type() const { return m_type; } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-05-28 19:31:26 +03:00
										 |  |  |     bool is_auto(Layout::AvailableSize const&) const; | 
					
						
							|  |  |  |     bool is_fixed(Layout::AvailableSize const&) const; | 
					
						
							| 
									
										
										
										
											2022-08-24 12:21:15 +02:00
										 |  |  |     bool is_flexible_length() const { return m_type == Type::FlexibleLength; } | 
					
						
							| 
									
										
										
										
											2024-07-22 22:49:52 +02:00
										 |  |  |     bool is_fit_content() const { return m_type == Type::FitContent; } | 
					
						
							| 
									
										
										
										
											2023-01-16 17:33:30 +01:00
										 |  |  |     bool is_max_content() const { return m_type == Type::MaxContent; } | 
					
						
							|  |  |  |     bool is_min_content() const { return m_type == Type::MinContent; } | 
					
						
							| 
									
										
										
										
											2022-08-24 12:21:15 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-09-28 16:16:25 +01:00
										 |  |  |     LengthPercentage length_percentage() const { return m_value.get<LengthPercentage>(); } | 
					
						
							|  |  |  |     double flex_factor() const { return m_value.get<Flex>().to_fr(); } | 
					
						
							| 
									
										
										
										
											2022-08-24 12:21:15 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-01-16 17:33:30 +01:00
										 |  |  |     // https://www.w3.org/TR/css-grid-2/#layout-algorithm
 | 
					
						
							|  |  |  |     // An intrinsic sizing function (min-content, max-content, auto, fit-content()).
 | 
					
						
							| 
									
										
										
										
											2023-05-28 19:31:26 +03:00
										 |  |  |     bool is_intrinsic(Layout::AvailableSize const&) const; | 
					
						
							| 
									
										
										
										
											2022-09-07 15:12:38 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2022-10-15 13:21:43 +02:00
										 |  |  |     bool is_definite() const | 
					
						
							|  |  |  |     { | 
					
						
							| 
									
										
										
										
											2023-09-28 16:16:25 +01:00
										 |  |  |         return type() == Type::LengthPercentage && !length_percentage().is_auto(); | 
					
						
							| 
									
										
										
										
											2022-10-15 13:21:43 +02:00
										 |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-05-10 22:38:44 +03:00
										 |  |  |     Size css_size() const; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-08-22 12:35:16 +01:00
										 |  |  |     String to_string() const; | 
					
						
							| 
									
										
										
										
											2025-06-13 17:17:53 +02:00
										 |  |  |     bool operator==(GridSize const& other) const = default; | 
					
						
							| 
									
										
										
										
											2022-08-24 12:21:15 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  | private: | 
					
						
							|  |  |  |     Type m_type; | 
					
						
							| 
									
										
										
										
											2023-09-28 16:16:25 +01:00
										 |  |  |     Variant<Empty, LengthPercentage, Flex> m_value; | 
					
						
							| 
									
										
										
										
											2022-08-24 12:21:15 +02:00
										 |  |  | }; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-07-22 22:49:52 +02:00
										 |  |  | class GridFitContent { | 
					
						
							|  |  |  | public: | 
					
						
							|  |  |  |     GridFitContent(GridSize); | 
					
						
							|  |  |  |     GridFitContent(); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     GridSize max_grid_size() const& { return m_max_grid_size; } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     String to_string() const; | 
					
						
							| 
									
										
										
										
											2025-06-13 17:17:53 +02:00
										 |  |  |     bool operator==(GridFitContent const& other) const = default; | 
					
						
							| 
									
										
										
										
											2024-07-22 22:49:52 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  | private: | 
					
						
							|  |  |  |     GridSize m_max_grid_size; | 
					
						
							|  |  |  | }; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2022-10-30 13:27:57 +01:00
										 |  |  | class GridMinMax { | 
					
						
							| 
									
										
											  
											
												LibWeb: Add parent classes for managing GridTrackSizes
Add classes ExplicitTrackSizing and MetaGridTrackSize which will allow
for managing properties like auto-fill and minmax.
In the following CSS example there are 3 classes that will be used:
grid-template-column: repeat(auto-fill, minmax(50px, 1fr) 75px);
ExplicitTrackSizing - will contain the entire value. e.g.
repeat(auto-fill, minmax(50px, 1fr) 75px)
With a flag if it's a repeat, as well as references to the
MetaGridTrackSizes which is the next step down.
MetaGridTrackSize:
Contain the individual grid track sizes. Here there are two:
minmax(50px, 1fr) as well as 75px.
This way can keep track if it's a minmax function or not, and the
references to both GridTrackSizes in the case it is, or in just the one
if it is not.
GridTrackSize:
Is the most basic element, in this case there are three in total; two of
which are held by the first MetaGridTrackSize, and the third is held by
the second MetaGridTrackSize.
Examples: 50px, 1fr and 75px.
											
										 
											2022-10-09 19:34:27 +02:00
										 |  |  | public: | 
					
						
							| 
									
										
										
										
											2022-10-30 13:27:57 +01:00
										 |  |  |     GridMinMax(CSS::GridSize min_grid_size, CSS::GridSize max_grid_size); | 
					
						
							|  |  |  |     GridMinMax() = default; | 
					
						
							| 
									
										
										
										
											2022-10-15 13:04:24 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2022-10-30 13:27:57 +01:00
										 |  |  |     GridSize min_grid_size() const& { return m_min_grid_size; } | 
					
						
							|  |  |  |     GridSize max_grid_size() const& { return m_max_grid_size; } | 
					
						
							| 
									
										
											  
											
												LibWeb: Add parent classes for managing GridTrackSizes
Add classes ExplicitTrackSizing and MetaGridTrackSize which will allow
for managing properties like auto-fill and minmax.
In the following CSS example there are 3 classes that will be used:
grid-template-column: repeat(auto-fill, minmax(50px, 1fr) 75px);
ExplicitTrackSizing - will contain the entire value. e.g.
repeat(auto-fill, minmax(50px, 1fr) 75px)
With a flag if it's a repeat, as well as references to the
MetaGridTrackSizes which is the next step down.
MetaGridTrackSize:
Contain the individual grid track sizes. Here there are two:
minmax(50px, 1fr) as well as 75px.
This way can keep track if it's a minmax function or not, and the
references to both GridTrackSizes in the case it is, or in just the one
if it is not.
GridTrackSize:
Is the most basic element, in this case there are three in total; two of
which are held by the first MetaGridTrackSize, and the third is held by
the second MetaGridTrackSize.
Examples: 50px, 1fr and 75px.
											
										 
											2022-10-09 19:34:27 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-08-22 12:35:16 +01:00
										 |  |  |     String to_string() const; | 
					
						
							| 
									
										
										
										
											2025-06-13 17:17:53 +02:00
										 |  |  |     bool operator==(GridMinMax const& other) const = default; | 
					
						
							| 
									
										
										
										
											2022-10-30 13:27:57 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  | private: | 
					
						
							|  |  |  |     GridSize m_min_grid_size; | 
					
						
							|  |  |  |     GridSize m_max_grid_size; | 
					
						
							|  |  |  | }; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-01-05 04:24:36 +01:00
										 |  |  | struct GridLineNames { | 
					
						
							|  |  |  |     Vector<String> names; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     String to_string() const; | 
					
						
							| 
									
										
										
										
											2025-06-13 17:17:53 +02:00
										 |  |  |     bool operator==(GridLineNames const& other) const = default; | 
					
						
							| 
									
										
										
										
											2024-01-05 04:24:36 +01:00
										 |  |  | }; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2022-10-30 13:27:57 +01:00
										 |  |  | class GridTrackSizeList { | 
					
						
							|  |  |  | public: | 
					
						
							| 
									
										
										
										
											2024-01-05 04:24:36 +01:00
										 |  |  |     GridTrackSizeList(Vector<Variant<ExplicitGridTrack, GridLineNames>>&& list); | 
					
						
							| 
									
										
										
										
											2022-10-30 13:27:57 +01:00
										 |  |  |     GridTrackSizeList(); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-06-07 13:04:06 +03:00
										 |  |  |     static GridTrackSizeList make_none(); | 
					
						
							| 
									
										
											  
											
												LibWeb: Add parent classes for managing GridTrackSizes
Add classes ExplicitTrackSizing and MetaGridTrackSize which will allow
for managing properties like auto-fill and minmax.
In the following CSS example there are 3 classes that will be used:
grid-template-column: repeat(auto-fill, minmax(50px, 1fr) 75px);
ExplicitTrackSizing - will contain the entire value. e.g.
repeat(auto-fill, minmax(50px, 1fr) 75px)
With a flag if it's a repeat, as well as references to the
MetaGridTrackSizes which is the next step down.
MetaGridTrackSize:
Contain the individual grid track sizes. Here there are two:
minmax(50px, 1fr) as well as 75px.
This way can keep track if it's a minmax function or not, and the
references to both GridTrackSizes in the case it is, or in just the one
if it is not.
GridTrackSize:
Is the most basic element, in this case there are three in total; two of
which are held by the first MetaGridTrackSize, and the third is held by
the second MetaGridTrackSize.
Examples: 50px, 1fr and 75px.
											
										 
											2022-10-09 19:34:27 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-01-05 04:24:36 +01:00
										 |  |  |     Vector<CSS::ExplicitGridTrack> track_list() const; | 
					
						
							|  |  |  |     Vector<Variant<ExplicitGridTrack, GridLineNames>> list() const { return m_list; } | 
					
						
							| 
									
										
										
										
											2022-10-30 13:45:40 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-08-22 12:35:16 +01:00
										 |  |  |     String to_string() const; | 
					
						
							| 
									
										
										
										
											2024-01-05 04:24:36 +01:00
										 |  |  |     bool operator==(GridTrackSizeList const& other) const; | 
					
						
							| 
									
										
											  
											
												LibWeb: Add parent classes for managing GridTrackSizes
Add classes ExplicitTrackSizing and MetaGridTrackSize which will allow
for managing properties like auto-fill and minmax.
In the following CSS example there are 3 classes that will be used:
grid-template-column: repeat(auto-fill, minmax(50px, 1fr) 75px);
ExplicitTrackSizing - will contain the entire value. e.g.
repeat(auto-fill, minmax(50px, 1fr) 75px)
With a flag if it's a repeat, as well as references to the
MetaGridTrackSizes which is the next step down.
MetaGridTrackSize:
Contain the individual grid track sizes. Here there are two:
minmax(50px, 1fr) as well as 75px.
This way can keep track if it's a minmax function or not, and the
references to both GridTrackSizes in the case it is, or in just the one
if it is not.
GridTrackSize:
Is the most basic element, in this case there are three in total; two of
which are held by the first MetaGridTrackSize, and the third is held by
the second MetaGridTrackSize.
Examples: 50px, 1fr and 75px.
											
										 
											2022-10-09 19:34:27 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  | private: | 
					
						
							| 
									
										
										
										
											2024-01-05 04:24:36 +01:00
										 |  |  |     Vector<Variant<ExplicitGridTrack, GridLineNames>> m_list; | 
					
						
							| 
									
										
											  
											
												LibWeb: Add parent classes for managing GridTrackSizes
Add classes ExplicitTrackSizing and MetaGridTrackSize which will allow
for managing properties like auto-fill and minmax.
In the following CSS example there are 3 classes that will be used:
grid-template-column: repeat(auto-fill, minmax(50px, 1fr) 75px);
ExplicitTrackSizing - will contain the entire value. e.g.
repeat(auto-fill, minmax(50px, 1fr) 75px)
With a flag if it's a repeat, as well as references to the
MetaGridTrackSizes which is the next step down.
MetaGridTrackSize:
Contain the individual grid track sizes. Here there are two:
minmax(50px, 1fr) as well as 75px.
This way can keep track if it's a minmax function or not, and the
references to both GridTrackSizes in the case it is, or in just the one
if it is not.
GridTrackSize:
Is the most basic element, in this case there are three in total; two of
which are held by the first MetaGridTrackSize, and the third is held by
the second MetaGridTrackSize.
Examples: 50px, 1fr and 75px.
											
										 
											2022-10-09 19:34:27 +02:00
										 |  |  | }; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2022-10-30 13:27:57 +01:00
										 |  |  | class GridRepeat { | 
					
						
							| 
									
										
											  
											
												LibWeb: Add parent classes for managing GridTrackSizes
Add classes ExplicitTrackSizing and MetaGridTrackSize which will allow
for managing properties like auto-fill and minmax.
In the following CSS example there are 3 classes that will be used:
grid-template-column: repeat(auto-fill, minmax(50px, 1fr) 75px);
ExplicitTrackSizing - will contain the entire value. e.g.
repeat(auto-fill, minmax(50px, 1fr) 75px)
With a flag if it's a repeat, as well as references to the
MetaGridTrackSizes which is the next step down.
MetaGridTrackSize:
Contain the individual grid track sizes. Here there are two:
minmax(50px, 1fr) as well as 75px.
This way can keep track if it's a minmax function or not, and the
references to both GridTrackSizes in the case it is, or in just the one
if it is not.
GridTrackSize:
Is the most basic element, in this case there are three in total; two of
which are held by the first MetaGridTrackSize, and the third is held by
the second MetaGridTrackSize.
Examples: 50px, 1fr and 75px.
											
										 
											2022-10-09 19:34:27 +02:00
										 |  |  | public: | 
					
						
							| 
									
										
										
										
											2022-10-15 13:02:45 +02:00
										 |  |  |     enum class Type { | 
					
						
							|  |  |  |         AutoFit, | 
					
						
							|  |  |  |         AutoFill, | 
					
						
							| 
									
										
										
										
											2022-10-30 13:27:57 +01:00
										 |  |  |         Default, | 
					
						
							| 
									
										
										
										
											2022-10-15 13:02:45 +02:00
										 |  |  |     }; | 
					
						
							| 
									
										
										
										
											2022-10-30 13:27:57 +01:00
										 |  |  |     GridRepeat(GridTrackSizeList, int repeat_count); | 
					
						
							|  |  |  |     GridRepeat(GridTrackSizeList, Type); | 
					
						
							|  |  |  |     GridRepeat(); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     bool is_auto_fill() const { return m_type == Type::AutoFill; } | 
					
						
							|  |  |  |     bool is_auto_fit() const { return m_type == Type::AutoFit; } | 
					
						
							|  |  |  |     bool is_default() const { return m_type == Type::Default; } | 
					
						
							|  |  |  |     int repeat_count() const | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         VERIFY(is_default()); | 
					
						
							|  |  |  |         return m_repeat_count; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |     GridTrackSizeList grid_track_size_list() const& { return m_grid_track_size_list; } | 
					
						
							|  |  |  |     Type type() const& { return m_type; } | 
					
						
							| 
									
										
										
										
											2022-10-15 13:02:45 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-08-22 12:35:16 +01:00
										 |  |  |     String to_string() const; | 
					
						
							| 
									
										
										
										
											2025-06-13 17:17:53 +02:00
										 |  |  |     bool operator==(GridRepeat const& other) const = default; | 
					
						
							| 
									
										
										
										
											2022-10-15 13:02:45 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2022-10-30 13:27:57 +01:00
										 |  |  | private: | 
					
						
							|  |  |  |     Type m_type; | 
					
						
							|  |  |  |     GridTrackSizeList m_grid_track_size_list; | 
					
						
							|  |  |  |     int m_repeat_count { 0 }; | 
					
						
							|  |  |  | }; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | class ExplicitGridTrack { | 
					
						
							|  |  |  | public: | 
					
						
							| 
									
										
										
										
											2025-06-13 17:12:04 +02:00
										 |  |  |     ExplicitGridTrack(Variant<GridFitContent, GridRepeat, GridMinMax, GridSize>&& value); | 
					
						
							| 
									
										
										
										
											2024-07-22 22:49:52 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2025-06-13 17:12:04 +02:00
										 |  |  |     bool is_fit_content() const { return m_value.has<GridFitContent>(); } | 
					
						
							|  |  |  |     GridFitContent const& fit_content() const { return m_value.get<GridFitContent>(); } | 
					
						
							| 
									
										
											  
											
												LibWeb: Add parent classes for managing GridTrackSizes
Add classes ExplicitTrackSizing and MetaGridTrackSize which will allow
for managing properties like auto-fill and minmax.
In the following CSS example there are 3 classes that will be used:
grid-template-column: repeat(auto-fill, minmax(50px, 1fr) 75px);
ExplicitTrackSizing - will contain the entire value. e.g.
repeat(auto-fill, minmax(50px, 1fr) 75px)
With a flag if it's a repeat, as well as references to the
MetaGridTrackSizes which is the next step down.
MetaGridTrackSize:
Contain the individual grid track sizes. Here there are two:
minmax(50px, 1fr) as well as 75px.
This way can keep track if it's a minmax function or not, and the
references to both GridTrackSizes in the case it is, or in just the one
if it is not.
GridTrackSize:
Is the most basic element, in this case there are three in total; two of
which are held by the first MetaGridTrackSize, and the third is held by
the second MetaGridTrackSize.
Examples: 50px, 1fr and 75px.
											
										 
											2022-10-09 19:34:27 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2025-06-13 17:12:04 +02:00
										 |  |  |     bool is_repeat() const { return m_value.has<GridRepeat>(); } | 
					
						
							|  |  |  |     GridRepeat const& repeat() const { return m_value.get<GridRepeat>(); } | 
					
						
							| 
									
										
										
										
											2022-10-30 13:27:57 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2025-06-13 17:12:04 +02:00
										 |  |  |     bool is_minmax() const { return m_value.has<GridMinMax>(); } | 
					
						
							|  |  |  |     GridMinMax const& minmax() const { return m_value.get<GridMinMax>(); } | 
					
						
							| 
									
										
											  
											
												LibWeb: Add parent classes for managing GridTrackSizes
Add classes ExplicitTrackSizing and MetaGridTrackSize which will allow
for managing properties like auto-fill and minmax.
In the following CSS example there are 3 classes that will be used:
grid-template-column: repeat(auto-fill, minmax(50px, 1fr) 75px);
ExplicitTrackSizing - will contain the entire value. e.g.
repeat(auto-fill, minmax(50px, 1fr) 75px)
With a flag if it's a repeat, as well as references to the
MetaGridTrackSizes which is the next step down.
MetaGridTrackSize:
Contain the individual grid track sizes. Here there are two:
minmax(50px, 1fr) as well as 75px.
This way can keep track if it's a minmax function or not, and the
references to both GridTrackSizes in the case it is, or in just the one
if it is not.
GridTrackSize:
Is the most basic element, in this case there are three in total; two of
which are held by the first MetaGridTrackSize, and the third is held by
the second MetaGridTrackSize.
Examples: 50px, 1fr and 75px.
											
										 
											2022-10-09 19:34:27 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2025-06-13 17:12:04 +02:00
										 |  |  |     bool is_default() const { return m_value.has<GridSize>(); } | 
					
						
							|  |  |  |     GridSize const& grid_size() const { return m_value.get<GridSize>(); } | 
					
						
							| 
									
										
											  
											
												LibWeb: Add parent classes for managing GridTrackSizes
Add classes ExplicitTrackSizing and MetaGridTrackSize which will allow
for managing properties like auto-fill and minmax.
In the following CSS example there are 3 classes that will be used:
grid-template-column: repeat(auto-fill, minmax(50px, 1fr) 75px);
ExplicitTrackSizing - will contain the entire value. e.g.
repeat(auto-fill, minmax(50px, 1fr) 75px)
With a flag if it's a repeat, as well as references to the
MetaGridTrackSizes which is the next step down.
MetaGridTrackSize:
Contain the individual grid track sizes. Here there are two:
minmax(50px, 1fr) as well as 75px.
This way can keep track if it's a minmax function or not, and the
references to both GridTrackSizes in the case it is, or in just the one
if it is not.
GridTrackSize:
Is the most basic element, in this case there are three in total; two of
which are held by the first MetaGridTrackSize, and the third is held by
the second MetaGridTrackSize.
Examples: 50px, 1fr and 75px.
											
										 
											2022-10-09 19:34:27 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-08-22 12:35:16 +01:00
										 |  |  |     String to_string() const; | 
					
						
							| 
									
										
										
										
											2025-06-13 17:12:04 +02:00
										 |  |  |     bool operator==(ExplicitGridTrack const& other) const = default; | 
					
						
							| 
									
										
											  
											
												LibWeb: Add parent classes for managing GridTrackSizes
Add classes ExplicitTrackSizing and MetaGridTrackSize which will allow
for managing properties like auto-fill and minmax.
In the following CSS example there are 3 classes that will be used:
grid-template-column: repeat(auto-fill, minmax(50px, 1fr) 75px);
ExplicitTrackSizing - will contain the entire value. e.g.
repeat(auto-fill, minmax(50px, 1fr) 75px)
With a flag if it's a repeat, as well as references to the
MetaGridTrackSizes which is the next step down.
MetaGridTrackSize:
Contain the individual grid track sizes. Here there are two:
minmax(50px, 1fr) as well as 75px.
This way can keep track if it's a minmax function or not, and the
references to both GridTrackSizes in the case it is, or in just the one
if it is not.
GridTrackSize:
Is the most basic element, in this case there are three in total; two of
which are held by the first MetaGridTrackSize, and the third is held by
the second MetaGridTrackSize.
Examples: 50px, 1fr and 75px.
											
										 
											2022-10-09 19:34:27 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  | private: | 
					
						
							| 
									
										
										
										
											2025-06-13 17:12:04 +02:00
										 |  |  |     Variant<GridFitContent, GridRepeat, GridMinMax, GridSize> m_value; | 
					
						
							| 
									
										
											  
											
												LibWeb: Add parent classes for managing GridTrackSizes
Add classes ExplicitTrackSizing and MetaGridTrackSize which will allow
for managing properties like auto-fill and minmax.
In the following CSS example there are 3 classes that will be used:
grid-template-column: repeat(auto-fill, minmax(50px, 1fr) 75px);
ExplicitTrackSizing - will contain the entire value. e.g.
repeat(auto-fill, minmax(50px, 1fr) 75px)
With a flag if it's a repeat, as well as references to the
MetaGridTrackSizes which is the next step down.
MetaGridTrackSize:
Contain the individual grid track sizes. Here there are two:
minmax(50px, 1fr) as well as 75px.
This way can keep track if it's a minmax function or not, and the
references to both GridTrackSizes in the case it is, or in just the one
if it is not.
GridTrackSize:
Is the most basic element, in this case there are three in total; two of
which are held by the first MetaGridTrackSize, and the third is held by
the second MetaGridTrackSize.
Examples: 50px, 1fr and 75px.
											
										 
											2022-10-09 19:34:27 +02:00
										 |  |  | }; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2022-08-24 12:21:15 +02:00
										 |  |  | } |