| 
									
										
										
										
											2022-08-23 10:36:27 +02:00
										 |  |  | /*
 | 
					
						
							| 
									
										
										
										
											2025-03-20 17:50:10 +01:00
										 |  |  |  * Copyright (c) 2023-2025, Aliaksandr Kalenik <kalenik.aliaksandr@gmail.com> | 
					
						
							| 
									
										
										
										
											2023-03-10 17:40:24 +01:00
										 |  |  |  * Copyright (c) 2022-2023, Martin Falisse <mfalisse@outlook.com> | 
					
						
							| 
									
										
										
										
											2022-08-23 10:36:27 +02:00
										 |  |  |  * | 
					
						
							|  |  |  |  * SPDX-License-Identifier: BSD-2-Clause | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #pragma once
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2022-11-15 22:23:40 +01:00
										 |  |  | #include <LibWeb/CSS/Length.h>
 | 
					
						
							| 
									
										
										
										
											2022-08-23 10:36:27 +02:00
										 |  |  | #include <LibWeb/Layout/FormattingContext.h>
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | namespace Web::Layout { | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-05-06 04:22:35 +03:00
										 |  |  | enum class GridDimension { | 
					
						
							|  |  |  |     Row, | 
					
						
							|  |  |  |     Column | 
					
						
							|  |  |  | }; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-10-10 23:51:54 +02:00
										 |  |  | enum class Alignment { | 
					
						
							| 
									
										
										
										
											2025-03-20 17:50:10 +01:00
										 |  |  |     Baseline, | 
					
						
							|  |  |  |     Center, | 
					
						
							|  |  |  |     End, | 
					
						
							| 
									
										
										
										
											2024-10-10 23:51:54 +02:00
										 |  |  |     Normal, | 
					
						
							| 
									
										
										
										
											2025-03-20 17:50:10 +01:00
										 |  |  |     Safe, | 
					
						
							|  |  |  |     SelfEnd, | 
					
						
							|  |  |  |     SelfStart, | 
					
						
							| 
									
										
										
										
											2024-10-10 23:51:54 +02:00
										 |  |  |     SpaceAround, | 
					
						
							| 
									
										
										
										
											2025-03-20 17:50:10 +01:00
										 |  |  |     SpaceBetween, | 
					
						
							| 
									
										
										
										
											2024-10-10 23:51:54 +02:00
										 |  |  |     SpaceEvenly, | 
					
						
							|  |  |  |     Start, | 
					
						
							|  |  |  |     Stretch, | 
					
						
							| 
									
										
										
										
											2025-03-20 17:50:10 +01:00
										 |  |  |     Unsafe, | 
					
						
							| 
									
										
										
										
											2024-10-10 23:51:54 +02:00
										 |  |  | }; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-05-21 01:04:58 +03:00
										 |  |  | struct GridPosition { | 
					
						
							| 
									
										
										
										
											2023-06-07 12:00:01 +03:00
										 |  |  |     int row; | 
					
						
							|  |  |  |     int column; | 
					
						
							| 
									
										
										
										
											2023-05-21 01:04:58 +03:00
										 |  |  |     inline bool operator==(GridPosition const&) const = default; | 
					
						
							|  |  |  | }; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-06-13 02:41:07 +03:00
										 |  |  | struct GridItem { | 
					
						
							| 
									
										
										
										
											2024-11-15 04:01:23 +13:00
										 |  |  |     GC::Ref<Box const> box; | 
					
						
							| 
									
										
										
										
											2025-02-11 14:50:12 +01:00
										 |  |  |     LayoutState::UsedValues& used_values; | 
					
						
							| 
									
										
										
										
											2023-03-10 17:40:24 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-10-10 23:35:44 +02:00
										 |  |  |     // Position and span are empty if the item is auto-placed which could only be the case for abspos items
 | 
					
						
							|  |  |  |     Optional<int> row; | 
					
						
							|  |  |  |     Optional<size_t> row_span; | 
					
						
							|  |  |  |     Optional<int> column; | 
					
						
							|  |  |  |     Optional<size_t> column_span; | 
					
						
							| 
									
										
										
										
											2023-03-10 17:40:24 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-06-13 02:41:07 +03:00
										 |  |  |     [[nodiscard]] size_t span(GridDimension const dimension) const | 
					
						
							| 
									
										
										
										
											2023-05-14 15:23:39 +03:00
										 |  |  |     { | 
					
						
							| 
									
										
										
										
											2024-10-10 23:35:44 +02:00
										 |  |  |         return dimension == GridDimension::Column ? column_span.value() : row_span.value(); | 
					
						
							| 
									
										
										
										
											2023-05-14 15:23:39 +03:00
										 |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-06-13 02:41:07 +03:00
										 |  |  |     [[nodiscard]] int raw_position(GridDimension const dimension) const | 
					
						
							| 
									
										
										
										
											2023-05-14 15:23:39 +03:00
										 |  |  |     { | 
					
						
							| 
									
										
										
										
											2024-10-10 23:35:44 +02:00
										 |  |  |         return dimension == GridDimension::Column ? column.value() : row.value(); | 
					
						
							| 
									
										
										
										
											2023-05-14 15:23:39 +03:00
										 |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2025-02-11 14:50:12 +01:00
										 |  |  |     [[nodiscard]] CSSPixels add_margin_box_sizes(CSSPixels content_size, GridDimension dimension) const | 
					
						
							| 
									
										
										
										
											2023-05-17 08:34:48 +03:00
										 |  |  |     { | 
					
						
							| 
									
										
										
										
											2023-06-12 14:30:00 +02:00
										 |  |  |         if (dimension == GridDimension::Column) | 
					
						
							| 
									
										
										
										
											2025-02-11 14:50:12 +01:00
										 |  |  |             return used_values.margin_box_left() + content_size + used_values.margin_box_right(); | 
					
						
							|  |  |  |         return used_values.margin_box_top() + content_size + used_values.margin_box_bottom(); | 
					
						
							| 
									
										
										
										
											2023-05-17 08:34:48 +03:00
										 |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-10-10 23:35:44 +02:00
										 |  |  |     [[nodiscard]] int gap_adjusted_position(GridDimension const dimension) const | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         return dimension == GridDimension::Column ? gap_adjusted_column() : gap_adjusted_row(); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-10-03 20:35:57 -06:00
										 |  |  |     [[nodiscard]] int gap_adjusted_row() const; | 
					
						
							|  |  |  |     [[nodiscard]] int gap_adjusted_column() const; | 
					
						
							| 
									
										
										
										
											2025-03-20 18:50:45 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  |     CSS::ComputedValues const& computed_values() const | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         return box->computed_values(); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     CSS::Size const& minimum_size(GridDimension dimension) const | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         return dimension == GridDimension::Column ? computed_values().min_width() : computed_values().min_height(); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     CSS::Size const& maximum_size(GridDimension dimension) const | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         return dimension == GridDimension::Column ? computed_values().max_width() : computed_values().max_height(); | 
					
						
							|  |  |  |     } | 
					
						
							| 
									
										
										
										
											2025-03-20 20:43:55 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  |     CSS::Size const& preferred_size(GridDimension dimension) const | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         return dimension == GridDimension::Column ? computed_values().width() : computed_values().height(); | 
					
						
							|  |  |  |     } | 
					
						
							| 
									
										
										
										
											2025-03-20 20:49:10 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2025-03-20 17:50:10 +01:00
										 |  |  |     CSS::LengthPercentage const& margin_start(GridDimension dimension) const | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         return dimension == GridDimension::Column ? computed_values().margin().left() : computed_values().margin().top(); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     CSS::LengthPercentage const& margin_end(GridDimension dimension) const | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         return dimension == GridDimension::Column ? computed_values().margin().right() : computed_values().margin().bottom(); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     CSSPixels used_margin_box_start(GridDimension dimension) const | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         return dimension == GridDimension::Column ? used_values.margin_box_left() : used_values.margin_box_top(); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     CSSPixels used_margin_box_end(GridDimension dimension) const | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         return dimension == GridDimension::Column ? used_values.margin_box_right() : used_values.margin_box_bottom(); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     CSSPixels used_margin_start(GridDimension dimension) const | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         return dimension == GridDimension::Column ? used_values.margin_left : used_values.margin_top; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     CSSPixels used_margin_end(GridDimension dimension) const | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         return dimension == GridDimension::Column ? used_values.margin_right : used_values.margin_bottom; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2025-03-20 20:49:10 +01:00
										 |  |  |     AvailableSpace available_space() const | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         auto available_width = used_values.has_definite_width() ? AvailableSize::make_definite(used_values.content_width()) : AvailableSize::make_indefinite(); | 
					
						
							|  |  |  |         auto available_height = used_values.has_definite_height() ? AvailableSize::make_definite(used_values.content_height()) : AvailableSize::make_indefinite(); | 
					
						
							|  |  |  |         return { available_width, available_height }; | 
					
						
							|  |  |  |     } | 
					
						
							| 
									
										
										
										
											2023-03-10 17:40:24 +01:00
										 |  |  | }; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-03-04 14:04:15 +01:00
										 |  |  | enum class FoundUnoccupiedPlace { | 
					
						
							|  |  |  |     No, | 
					
						
							|  |  |  |     Yes | 
					
						
							|  |  |  | }; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-06-07 12:00:01 +03:00
										 |  |  | class OccupationGrid { | 
					
						
							|  |  |  | public: | 
					
						
							|  |  |  |     OccupationGrid(size_t columns_count, size_t rows_count) | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         m_max_column_index = max(0, columns_count - 1); | 
					
						
							|  |  |  |         m_max_row_index = max(0, rows_count - 1); | 
					
						
							| 
									
										
										
										
											2023-07-07 22:48:11 -04:00
										 |  |  |     } | 
					
						
							| 
									
										
										
										
											2024-10-03 20:35:57 -06:00
										 |  |  |     OccupationGrid() { } | 
					
						
							| 
									
										
										
										
											2023-06-07 12:00:01 +03:00
										 |  |  | 
 | 
					
						
							|  |  |  |     void set_occupied(int column_start, int column_end, int row_start, int row_end); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     size_t column_count() const | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         return abs(m_min_column_index) + m_max_column_index + 1; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     size_t row_count() const | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         return abs(m_min_row_index) + m_max_row_index + 1; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-07-13 15:49:07 +02:00
										 |  |  |     void set_max_column_index(size_t max_column_index) { m_max_column_index = max_column_index; } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-06-07 12:00:01 +03:00
										 |  |  |     int min_column_index() const { return m_min_column_index; } | 
					
						
							| 
									
										
										
										
											2023-07-07 22:48:11 -04:00
										 |  |  |     int max_column_index() const { return m_max_column_index; } | 
					
						
							|  |  |  |     int min_row_index() const { return m_min_row_index; } | 
					
						
							|  |  |  |     int max_row_index() const { return m_max_row_index; } | 
					
						
							| 
									
										
										
										
											2023-06-07 12:00:01 +03:00
										 |  |  | 
 | 
					
						
							|  |  |  |     bool is_occupied(int column_index, int row_index) const; | 
					
						
							| 
									
										
										
										
											2024-03-04 14:04:15 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  |     FoundUnoccupiedPlace find_unoccupied_place(GridDimension dimension, int& column_index, int& row_index, int column_span, int row_span) const; | 
					
						
							| 
									
										
										
										
											2023-06-07 12:00:01 +03:00
										 |  |  | 
 | 
					
						
							|  |  |  | private: | 
					
						
							|  |  |  |     HashTable<GridPosition> m_occupation_grid; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     int m_min_column_index { 0 }; | 
					
						
							|  |  |  |     int m_max_column_index { 0 }; | 
					
						
							|  |  |  |     int m_min_row_index { 0 }; | 
					
						
							|  |  |  |     int m_max_row_index { 0 }; | 
					
						
							|  |  |  | }; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-01-23 15:19:32 +01:00
										 |  |  | class GridFormattingContext final : public FormattingContext { | 
					
						
							| 
									
										
										
										
											2022-08-23 10:36:27 +02:00
										 |  |  | public: | 
					
						
							| 
									
										
										
										
											2024-09-11 01:03:02 +02:00
										 |  |  |     explicit GridFormattingContext(LayoutState&, LayoutMode, Box const& grid_container, FormattingContext* parent); | 
					
						
							| 
									
										
										
										
											2022-08-23 10:36:27 +02:00
										 |  |  |     ~GridFormattingContext(); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-10-29 00:25:13 +02:00
										 |  |  |     virtual bool inhibits_floating() const override { return true; } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-09-11 01:03:02 +02:00
										 |  |  |     virtual void run(AvailableSpace const& available_space) override; | 
					
						
							| 
									
										
										
										
											2023-03-19 09:57:31 +01:00
										 |  |  |     virtual CSSPixels automatic_content_width() const override; | 
					
						
							| 
									
										
										
										
											2022-11-23 17:46:10 +00:00
										 |  |  |     virtual CSSPixels automatic_content_height() const override; | 
					
						
							| 
									
										
										
										
											2024-10-05 22:18:53 +02:00
										 |  |  |     StaticPositionRect calculate_static_position_rect(Box const&) const; | 
					
						
							| 
									
										
										
										
											2022-09-24 13:39:43 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-05-06 04:22:35 +03:00
										 |  |  |     Box const& grid_container() const { return context_box(); } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2022-09-24 13:39:43 +02:00
										 |  |  | private: | 
					
						
							| 
									
										
										
										
											2025-03-20 17:50:10 +01:00
										 |  |  |     Alignment alignment_for_item(Box const& box, GridDimension dimension) const; | 
					
						
							| 
									
										
										
										
											2023-07-14 20:57:36 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-06-08 02:49:30 +03:00
										 |  |  |     void resolve_items_box_metrics(GridDimension const dimension); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2022-11-04 20:18:48 +00:00
										 |  |  |     CSSPixels m_automatic_content_height { 0 }; | 
					
						
							| 
									
										
										
										
											2024-03-06 16:30:31 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2022-09-17 18:14:11 +02:00
										 |  |  |     bool is_auto_positioned_track(CSS::GridTrackPlacement const&, CSS::GridTrackPlacement const&) const; | 
					
						
							| 
									
										
										
										
											2022-10-15 12:51:00 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-06-10 01:50:48 +03:00
										 |  |  |     struct GridTrack { | 
					
						
							| 
									
										
										
										
											2022-10-30 13:27:57 +01:00
										 |  |  |         CSS::GridSize min_track_sizing_function; | 
					
						
							|  |  |  |         CSS::GridSize max_track_sizing_function; | 
					
						
							| 
									
										
										
										
											2023-05-20 17:46:21 +03:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2022-11-04 20:18:48 +00:00
										 |  |  |         CSSPixels base_size { 0 }; | 
					
						
							| 
									
										
										
										
											2023-05-20 17:46:21 +03:00
										 |  |  |         bool base_size_frozen { false }; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-07-25 23:09:04 +02:00
										 |  |  |         Optional<CSSPixels> growth_limit { 0 }; | 
					
						
							| 
									
										
										
										
											2023-05-20 17:46:21 +03:00
										 |  |  |         bool growth_limit_frozen { false }; | 
					
						
							|  |  |  |         bool infinitely_growable { false }; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2022-11-04 20:18:48 +00:00
										 |  |  |         CSSPixels space_to_distribute { 0 }; | 
					
						
							|  |  |  |         CSSPixels planned_increase { 0 }; | 
					
						
							| 
									
										
										
										
											2023-05-14 19:16:26 +03:00
										 |  |  |         CSSPixels item_incurred_increase { 0 }; | 
					
						
							| 
									
										
										
										
											2023-05-20 17:46:21 +03:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2022-11-06 13:45:05 +01:00
										 |  |  |         bool is_gap { false }; | 
					
						
							| 
									
										
										
										
											2022-11-06 13:37:26 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-06-11 21:58:19 +03:00
										 |  |  |         static GridTrack create_from_definition(CSS::ExplicitGridTrack const& definition); | 
					
						
							| 
									
										
										
										
											2023-06-11 22:45:31 +03:00
										 |  |  |         static GridTrack create_auto(); | 
					
						
							|  |  |  |         static GridTrack create_gap(CSSPixels size); | 
					
						
							| 
									
										
										
										
											2022-10-15 12:51:00 +02:00
										 |  |  |     }; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-01-17 13:50:41 +01:00
										 |  |  |     struct GridArea { | 
					
						
							|  |  |  |         String name; | 
					
						
							| 
									
										
										
										
											2023-05-09 19:53:26 +03:00
										 |  |  |         size_t row_start { 0 }; | 
					
						
							|  |  |  |         size_t row_end { 1 }; | 
					
						
							|  |  |  |         size_t column_start { 0 }; | 
					
						
							|  |  |  |         size_t column_end { 1 }; | 
					
						
							| 
									
										
										
										
											2023-10-22 18:48:35 +02:00
										 |  |  |         bool invalid { false }; /* FIXME: Ignore ignore invalid areas during layout */ | 
					
						
							| 
									
										
										
										
											2023-01-17 13:50:41 +01:00
										 |  |  |     }; | 
					
						
							| 
									
										
										
										
											2023-05-28 22:02:53 +03:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-01-05 04:24:36 +01:00
										 |  |  |     struct GridLine { | 
					
						
							|  |  |  |         Vector<String> names; | 
					
						
							|  |  |  |     }; | 
					
						
							|  |  |  |     Vector<GridLine> m_row_lines; | 
					
						
							|  |  |  |     Vector<GridLine> m_column_lines; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     void init_grid_lines(GridDimension); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-06-10 01:50:48 +03:00
										 |  |  |     Vector<GridTrack> m_grid_rows; | 
					
						
							|  |  |  |     Vector<GridTrack> m_grid_columns; | 
					
						
							| 
									
										
										
										
											2022-10-15 13:21:43 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-06-10 00:41:15 +03:00
										 |  |  |     bool has_gaps(GridDimension const dimension) const | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         if (dimension == GridDimension::Column) { | 
					
						
							| 
									
										
										
										
											2024-11-09 17:38:09 +01:00
										 |  |  |             return !grid_container().computed_values().column_gap().has<CSS::NormalGap>(); | 
					
						
							| 
									
										
										
										
											2023-06-10 00:41:15 +03:00
										 |  |  |         } else { | 
					
						
							| 
									
										
										
										
											2024-11-09 17:38:09 +01:00
										 |  |  |             return !grid_container().computed_values().row_gap().has<CSS::NormalGap>(); | 
					
						
							| 
									
										
										
										
											2023-06-10 00:41:15 +03:00
										 |  |  |         } | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-05-17 15:34:33 +03:00
										 |  |  |     template<typename Callback> | 
					
						
							|  |  |  |     void for_each_spanned_track_by_item(GridItem const& item, GridDimension const dimension, Callback callback) | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         auto& tracks = dimension == GridDimension::Column ? m_grid_columns : m_grid_rows; | 
					
						
							| 
									
										
										
										
											2023-06-10 00:41:15 +03:00
										 |  |  |         auto& gaps = dimension == GridDimension::Column ? m_column_gap_tracks : m_row_gap_tracks; | 
					
						
							|  |  |  |         auto has_gaps = this->has_gaps(dimension); | 
					
						
							|  |  |  |         auto item_span = item.span(dimension); | 
					
						
							|  |  |  |         auto item_index = item.raw_position(dimension); | 
					
						
							|  |  |  |         for (size_t span = 0; span < item_span; span++) { | 
					
						
							|  |  |  |             auto track_index = item_index + span; | 
					
						
							|  |  |  |             if (track_index >= tracks.size()) | 
					
						
							| 
									
										
										
										
											2023-05-17 15:34:33 +03:00
										 |  |  |                 break; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-06-10 00:41:15 +03:00
										 |  |  |             auto& track = tracks[track_index]; | 
					
						
							| 
									
										
										
										
											2023-05-17 15:34:33 +03:00
										 |  |  |             callback(track); | 
					
						
							| 
									
										
										
										
											2023-06-10 00:41:15 +03:00
										 |  |  | 
 | 
					
						
							|  |  |  |             auto is_last_spanned_track = span == item_span - 1; | 
					
						
							|  |  |  |             if (has_gaps && !is_last_spanned_track) { | 
					
						
							|  |  |  |                 auto& gap = gaps[track_index]; | 
					
						
							|  |  |  |                 callback(gap); | 
					
						
							|  |  |  |             } | 
					
						
							| 
									
										
										
										
											2023-05-17 15:34:33 +03:00
										 |  |  |         } | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     template<typename Callback> | 
					
						
							|  |  |  |     void for_each_spanned_track_by_item(GridItem const& item, GridDimension const dimension, Callback callback) const | 
					
						
							|  |  |  |     { | 
					
						
							| 
									
										
										
										
											2023-06-10 00:41:15 +03:00
										 |  |  |         auto& tracks = dimension == GridDimension::Column ? m_grid_columns : m_grid_rows; | 
					
						
							|  |  |  |         auto& gaps = dimension == GridDimension::Column ? m_column_gap_tracks : m_row_gap_tracks; | 
					
						
							|  |  |  |         auto has_gaps = this->has_gaps(dimension); | 
					
						
							|  |  |  |         auto item_span = item.span(dimension); | 
					
						
							|  |  |  |         auto item_index = item.raw_position(dimension); | 
					
						
							|  |  |  |         for (size_t span = 0; span < item_span; span++) { | 
					
						
							|  |  |  |             auto track_index = item_index + span; | 
					
						
							|  |  |  |             if (track_index >= tracks.size()) | 
					
						
							| 
									
										
										
										
											2023-05-17 15:34:33 +03:00
										 |  |  |                 break; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-06-10 00:41:15 +03:00
										 |  |  |             auto& track = tracks[track_index]; | 
					
						
							| 
									
										
										
										
											2023-05-17 15:34:33 +03:00
										 |  |  |             callback(track); | 
					
						
							| 
									
										
										
										
											2023-06-10 00:41:15 +03:00
										 |  |  | 
 | 
					
						
							|  |  |  |             auto is_last_spanned_track = span == item_span - 1; | 
					
						
							|  |  |  |             if (has_gaps && !is_last_spanned_track) { | 
					
						
							|  |  |  |                 auto& gap = gaps[track_index]; | 
					
						
							|  |  |  |                 callback(gap); | 
					
						
							|  |  |  |             } | 
					
						
							| 
									
										
										
										
											2023-05-17 15:34:33 +03:00
										 |  |  |         } | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-06-10 01:50:48 +03:00
										 |  |  |     Vector<GridTrack> m_row_gap_tracks; | 
					
						
							|  |  |  |     Vector<GridTrack> m_column_gap_tracks; | 
					
						
							| 
									
										
										
										
											2023-05-14 15:23:39 +03:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-06-10 01:50:48 +03:00
										 |  |  |     Vector<GridTrack&> m_grid_rows_and_gaps; | 
					
						
							|  |  |  |     Vector<GridTrack&> m_grid_columns_and_gaps; | 
					
						
							| 
									
										
										
										
											2023-05-14 15:23:39 +03:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-06-07 12:00:01 +03:00
										 |  |  |     size_t m_explicit_rows_line_count { 0 }; | 
					
						
							|  |  |  |     size_t m_explicit_columns_line_count { 0 }; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2022-12-28 10:12:30 +01:00
										 |  |  |     OccupationGrid m_occupation_grid; | 
					
						
							| 
									
										
										
										
											2023-04-01 17:43:25 +02:00
										 |  |  |     Vector<GridItem> m_grid_items; | 
					
						
							| 
									
										
										
										
											2022-12-28 10:12:30 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-05-28 19:31:26 +03:00
										 |  |  |     Optional<AvailableSpace> m_available_space; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2025-02-11 14:50:12 +01:00
										 |  |  |     LayoutState::UsedValues& m_grid_container_used_values; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-05-15 15:54:25 +03:00
										 |  |  |     void determine_grid_container_height(); | 
					
						
							| 
									
										
										
										
											2023-05-13 11:55:09 +03:00
										 |  |  |     void determine_intrinsic_size_of_grid_container(AvailableSpace const& available_space); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-09-12 18:02:58 +02:00
										 |  |  |     void layout_absolutely_positioned_element(Box const&); | 
					
						
							| 
									
										
										
										
											2023-08-07 17:06:08 +02:00
										 |  |  |     virtual void parent_context_did_dimension_child_root_box() override; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2025-03-20 17:50:10 +01:00
										 |  |  |     void resolve_grid_item_sizes(GridDimension dimension); | 
					
						
							| 
									
										
										
										
											2023-05-18 17:24:46 +03:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-10-03 20:35:57 -06:00
										 |  |  |     void resolve_track_spacing(GridDimension const dimension); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-05-14 15:23:39 +03:00
										 |  |  |     AvailableSize get_free_space(AvailableSpace const&, GridDimension const) const; | 
					
						
							| 
									
										
										
										
											2022-10-30 13:49:47 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-01-05 04:24:36 +01:00
										 |  |  |     Optional<int> get_line_index_by_line_name(GridDimension dimension, String const&); | 
					
						
							| 
									
										
										
										
											2023-05-06 06:04:40 +03:00
										 |  |  |     CSSPixels resolve_definite_track_size(CSS::GridSize const&, AvailableSpace const&); | 
					
						
							| 
									
										
										
										
											2024-09-09 21:12:39 +02:00
										 |  |  |     int count_of_repeated_auto_fill_or_fit_tracks(GridDimension, CSS::ExplicitGridTrack const& repeated_track); | 
					
						
							| 
									
										
										
										
											2022-12-28 10:12:30 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-05-28 22:02:53 +03:00
										 |  |  |     void build_grid_areas(); | 
					
						
							| 
									
										
										
										
											2023-01-17 13:50:41 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-03-06 15:49:04 +01:00
										 |  |  |     struct PlacementPosition { | 
					
						
							|  |  |  |         int start { 0 }; | 
					
						
							|  |  |  |         int end { 0 }; | 
					
						
							|  |  |  |         size_t span { 1 }; | 
					
						
							|  |  |  |     }; | 
					
						
							|  |  |  |     PlacementPosition resolve_grid_position(Box const& child_box, GridDimension const dimension); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-01-05 21:40:29 +01:00
										 |  |  |     void place_grid_items(); | 
					
						
							| 
									
										
										
										
											2023-05-06 06:04:40 +03:00
										 |  |  |     void place_item_with_row_and_column_position(Box const& child_box); | 
					
						
							|  |  |  |     void place_item_with_row_position(Box const& child_box); | 
					
						
							|  |  |  |     void place_item_with_column_position(Box const& child_box, int& auto_placement_cursor_x, int& auto_placement_cursor_y); | 
					
						
							| 
									
										
										
										
											2022-12-28 10:12:30 +01:00
										 |  |  |     void place_item_with_no_declared_position(Box const& child_box, int& auto_placement_cursor_x, int& auto_placement_cursor_y); | 
					
						
							| 
									
										
										
										
											2024-03-06 16:44:35 +01:00
										 |  |  |     void record_grid_placement(GridItem); | 
					
						
							| 
									
										
										
										
											2022-12-28 10:12:30 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-01-07 09:27:56 +01:00
										 |  |  |     void initialize_grid_tracks_from_definition(GridDimension); | 
					
						
							| 
									
										
										
										
											2024-01-05 21:40:29 +01:00
										 |  |  |     void initialize_grid_tracks_for_columns_and_rows(); | 
					
						
							| 
									
										
										
										
											2023-05-09 18:38:53 +03:00
										 |  |  |     void initialize_gap_tracks(AvailableSpace const&); | 
					
						
							| 
									
										
										
										
											2023-05-10 04:21:56 +03:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-06-20 18:48:20 +03:00
										 |  |  |     void collapse_auto_fit_tracks_if_needed(GridDimension const); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-06-22 00:48:46 +03:00
										 |  |  |     enum class SpaceDistributionPhase { | 
					
						
							|  |  |  |         AccommodateMinimumContribution, | 
					
						
							|  |  |  |         AccommodateMinContentContribution, | 
					
						
							|  |  |  |         AccommodateMaxContentContribution | 
					
						
							|  |  |  |     }; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-06-07 19:11:29 +03:00
										 |  |  |     template<typename Match> | 
					
						
							| 
									
										
										
										
											2023-06-22 00:48:46 +03:00
										 |  |  |     void distribute_extra_space_across_spanned_tracks_base_size(GridDimension dimension, CSSPixels item_size_contribution, SpaceDistributionPhase phase, Vector<GridTrack&>& spanned_tracks, Match matcher); | 
					
						
							| 
									
										
										
										
											2023-06-07 19:11:29 +03:00
										 |  |  | 
 | 
					
						
							|  |  |  |     template<typename Match> | 
					
						
							| 
									
										
										
										
											2023-06-10 01:50:48 +03:00
										 |  |  |     void distribute_extra_space_across_spanned_tracks_growth_limit(CSSPixels item_size_contribution, Vector<GridTrack&>& spanned_tracks, Match matcher); | 
					
						
							| 
									
										
										
										
											2023-06-07 19:11:29 +03:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-01-04 20:55:35 +01:00
										 |  |  |     void initialize_track_sizes(GridDimension); | 
					
						
							|  |  |  |     void resolve_intrinsic_track_sizes(GridDimension); | 
					
						
							|  |  |  |     void increase_sizes_to_accommodate_spanning_items_crossing_content_sized_tracks(GridDimension, size_t span); | 
					
						
							|  |  |  |     void increase_sizes_to_accommodate_spanning_items_crossing_flexible_tracks(GridDimension); | 
					
						
							|  |  |  |     void maximize_tracks_using_available_size(AvailableSpace const& available_space, GridDimension dimension); | 
					
						
							|  |  |  |     void maximize_tracks(GridDimension); | 
					
						
							|  |  |  |     void expand_flexible_tracks(GridDimension); | 
					
						
							|  |  |  |     void stretch_auto_tracks(GridDimension); | 
					
						
							|  |  |  |     void run_track_sizing(GridDimension); | 
					
						
							| 
									
										
										
										
											2023-04-01 19:09:19 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-12-26 18:13:17 +01:00
										 |  |  |     CSSPixels calculate_grid_container_maximum_size(GridDimension const) const; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-05-13 05:51:39 +03:00
										 |  |  |     CSSPixels calculate_min_content_size(GridItem const&, GridDimension const) const; | 
					
						
							|  |  |  |     CSSPixels calculate_max_content_size(GridItem const&, GridDimension const) const; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     CSSPixels calculate_min_content_contribution(GridItem const&, GridDimension const) const; | 
					
						
							|  |  |  |     CSSPixels calculate_max_content_contribution(GridItem const&, GridDimension const) const; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-05-13 15:17:24 +03:00
										 |  |  |     CSSPixels calculate_limited_min_content_contribution(GridItem const&, GridDimension const) const; | 
					
						
							|  |  |  |     CSSPixels calculate_limited_max_content_contribution(GridItem const&, GridDimension const) const; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-05-13 05:51:39 +03:00
										 |  |  |     CSSPixels containing_block_size_for_item(GridItem const&, GridDimension const) const; | 
					
						
							| 
									
										
										
										
											2023-05-13 15:17:24 +03:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-10-30 20:38:49 +01:00
										 |  |  |     CSSPixelRect get_grid_area_rect(GridItem const&) const; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-05-13 15:17:24 +03:00
										 |  |  |     CSSPixels content_size_suggestion(GridItem const&, GridDimension const) const; | 
					
						
							|  |  |  |     Optional<CSSPixels> specified_size_suggestion(GridItem const&, GridDimension const) const; | 
					
						
							| 
									
										
										
										
											2025-03-18 21:44:24 +01:00
										 |  |  |     Optional<CSSPixels> transferred_size_suggestion(GridItem const&, GridDimension const) const; | 
					
						
							| 
									
										
										
										
											2023-05-13 15:17:24 +03:00
										 |  |  |     CSSPixels content_based_minimum_size(GridItem const&, GridDimension const) const; | 
					
						
							|  |  |  |     CSSPixels automatic_minimum_size(GridItem const&, GridDimension const) const; | 
					
						
							|  |  |  |     CSSPixels calculate_minimum_contribution(GridItem const&, GridDimension const) const; | 
					
						
							| 
									
										
										
										
											2022-10-01 14:08:34 +02:00
										 |  |  | }; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2022-08-23 10:36:27 +02:00
										 |  |  | } |