2021-09-12 20:05:29 +02:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								/*
  
						 
					
						
							
								
									
										
										
										
											2023-02-20 18:56:08 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								 *  Copyright  ( c )  2021 - 2023 ,  Andreas  Kling  < kling @ serenityos . org > 
							 
						 
					
						
							
								
									
										
										
										
											2021-09-13 19:54:54 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								 *  Copyright  ( c )  2021 ,  Tobias  Christiansen  < tobyase @ serenityos . org > 
							 
						 
					
						
							
								
									
										
										
										
											2023-03-23 17:44:13 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								 *  Copyright  ( c )  2022 - 2023 ,  Sam  Atkins  < atkinssj @ serenityos . org > 
							 
						 
					
						
							
								
									
										
										
										
											2021-09-12 20:05:29 +02:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								 * 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								 *  SPDX - License - Identifier :  BSD - 2 - Clause 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								 */ 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2022-02-06 14:17:42 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								# include  <AK/Debug.h> 
  
						 
					
						
							
								
									
										
										
										
											2022-12-06 03:08:20 -03:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								# include  <AK/Format.h> 
  
						 
					
						
							
								
									
										
										
										
											2021-09-14 00:38:46 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								# include  <AK/NonnullRefPtr.h> 
  
						 
					
						
							
								
									
										
										
										
											2022-04-13 20:05:56 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								# include  <LibWeb/CSS/Enums.h> 
  
						 
					
						
							
								
									
										
										
										
											2021-09-23 12:35:56 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								# include  <LibWeb/CSS/ResolvedCSSStyleDeclaration.h> 
  
						 
					
						
							
								
									
										
										
										
											2021-09-24 13:49:57 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								# include  <LibWeb/CSS/StyleComputer.h> 
  
						 
					
						
							
								
									
										
										
										
											2023-03-23 17:44:13 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								# include  <LibWeb/CSS/StyleValues/BackgroundRepeatStyleValue.h> 
  
						 
					
						
							
								
									
										
										
										
											2023-05-27 15:50:17 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								# include  <LibWeb/CSS/StyleValues/BackgroundSizeStyleValue.h> 
  
						 
					
						
							
								
									
										
										
										
											2023-03-25 00:33:20 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								# include  <LibWeb/CSS/StyleValues/BorderRadiusStyleValue.h> 
  
						 
					
						
							
								
									
										
										
										
											2023-03-30 17:34:14 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								# include  <LibWeb/CSS/StyleValues/CalculatedStyleValue.h> 
  
						 
					
						
							
								
									
										
										
										
											2023-03-23 21:12:15 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								# include  <LibWeb/CSS/StyleValues/ColorStyleValue.h> 
  
						 
					
						
							
								
									
										
										
										
											2023-04-03 00:04:00 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								# include  <LibWeb/CSS/StyleValues/EdgeStyleValue.h> 
  
						 
					
						
							
								
									
										
										
										
											2023-03-24 14:53:08 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								# include  <LibWeb/CSS/StyleValues/GridTrackPlacementStyleValue.h> 
  
						 
					
						
							
								
									
										
										
										
											2023-04-29 17:59:07 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								# include  <LibWeb/CSS/StyleValues/GridTrackSizeListStyleValue.h> 
  
						 
					
						
							
								
									
										
										
										
											2023-03-24 15:04:24 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								# include  <LibWeb/CSS/StyleValues/IdentifierStyleValue.h> 
  
						 
					
						
							
								
									
										
										
										
											2023-03-24 16:55:44 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								# include  <LibWeb/CSS/StyleValues/InitialStyleValue.h> 
  
						 
					
						
							
								
									
										
										
										
											2023-06-01 17:10:28 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								# include  <LibWeb/CSS/StyleValues/IntegerStyleValue.h> 
  
						 
					
						
							
								
									
										
										
										
											2023-03-24 17:04:04 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								# include  <LibWeb/CSS/StyleValues/LengthStyleValue.h> 
  
						 
					
						
							
								
									
										
										
										
											2023-06-01 16:16:15 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								# include  <LibWeb/CSS/StyleValues/NumberStyleValue.h> 
  
						 
					
						
							
								
									
										
										
										
											2023-03-24 17:28:43 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								# include  <LibWeb/CSS/StyleValues/PercentageStyleValue.h> 
  
						 
					
						
							
								
									
										
										
										
											2023-03-24 17:35:31 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								# include  <LibWeb/CSS/StyleValues/PositionStyleValue.h> 
  
						 
					
						
							
								
									
										
										
										
											2023-06-08 15:25:16 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								# include  <LibWeb/CSS/StyleValues/RatioStyleValue.h> 
  
						 
					
						
							
								
									
										
										
										
											2023-03-25 00:02:50 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								# include  <LibWeb/CSS/StyleValues/RectStyleValue.h> 
  
						 
					
						
							
								
									
										
										
										
											2023-03-24 17:45:25 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								# include  <LibWeb/CSS/StyleValues/ShadowStyleValue.h> 
  
						 
					
						
							
								
									
										
										
										
											2023-09-19 15:27:13 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								# include  <LibWeb/CSS/StyleValues/ShorthandStyleValue.h> 
  
						 
					
						
							
								
									
										
										
										
											2023-03-25 00:12:21 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								# include  <LibWeb/CSS/StyleValues/StyleValueList.h> 
  
						 
					
						
							
								
									
										
										
										
											2023-05-27 22:05:48 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								# include  <LibWeb/CSS/StyleValues/TimeStyleValue.h> 
  
						 
					
						
							
								
									
										
										
										
											2023-03-24 17:59:33 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								# include  <LibWeb/CSS/StyleValues/TransformationStyleValue.h> 
  
						 
					
						
							
								
									
										
										
										
											2023-06-15 16:52:45 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								# include  <LibWeb/CSS/StyleValues/URLStyleValue.h> 
  
						 
					
						
							
								
									
										
										
										
											2021-09-12 20:05:29 +02:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								# include  <LibWeb/DOM/Document.h> 
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								# include  <LibWeb/DOM/Element.h> 
  
						 
					
						
							
								
									
										
										
										
											2023-02-25 11:04:29 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								# include  <LibWeb/Layout/Viewport.h> 
  
						 
					
						
							
								
									
										
										
										
											2022-07-19 16:44:24 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								# include  <LibWeb/Painting/PaintableBox.h> 
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								# include  <LibWeb/Painting/StackingContext.h> 
  
						 
					
						
							
								
									
										
										
										
											2023-08-19 08:38:51 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								# include  <LibWeb/Painting/ViewportPaintable.h> 
  
						 
					
						
							
								
									
										
										
										
											2021-09-12 20:05:29 +02:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								namespace  Web : : CSS  {  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2023-11-19 19:47:52 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								JS_DEFINE_ALLOCATOR ( ResolvedCSSStyleDeclaration ) ;  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2023-08-13 13:05:26 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								JS : : NonnullGCPtr < ResolvedCSSStyleDeclaration >  ResolvedCSSStyleDeclaration : : create ( DOM : : Element &  element )  
						 
					
						
							
								
									
										
										
										
											2022-08-07 16:21:26 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								{  
						 
					
						
							
								
									
										
										
										
											2023-08-13 13:05:26 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    return  element . realm ( ) . heap ( ) . allocate < ResolvedCSSStyleDeclaration > ( element . realm ( ) ,  element ) ; 
							 
						 
					
						
							
								
									
										
										
										
											2022-08-07 16:21:26 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								}  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2021-09-23 12:35:56 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								ResolvedCSSStyleDeclaration : : ResolvedCSSStyleDeclaration ( DOM : : Element &  element )  
						 
					
						
							
								
									
										
										
										
											2022-09-24 16:34:04 -06:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    :  CSSStyleDeclaration ( element . realm ( ) ) 
							 
						 
					
						
							
								
									
										
										
										
											2022-08-07 16:21:26 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    ,  m_element ( element ) 
							 
						 
					
						
							
								
									
										
										
										
											2021-09-12 20:05:29 +02:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								{  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								}  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2022-08-28 13:42:07 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								void  ResolvedCSSStyleDeclaration : : visit_edges ( Cell : : Visitor &  visitor )  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								{  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    Base : : visit_edges ( visitor ) ; 
							 
						 
					
						
							
								
									
										
										
										
											2023-11-19 16:18:00 +13:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    visitor . visit ( m_element ) ; 
							 
						 
					
						
							
								
									
										
										
										
											2022-08-28 13:42:07 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								}  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2023-09-29 16:48:54 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								// https://drafts.csswg.org/cssom/#dom-cssstyledeclaration-length
  
						 
					
						
							
								
									
										
										
										
											2021-09-23 12:35:56 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								size_t  ResolvedCSSStyleDeclaration : : length ( )  const  
						 
					
						
							
								
									
										
										
										
											2021-09-12 20:05:29 +02:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								{  
						 
					
						
							
								
									
										
										
										
											2023-09-29 16:48:54 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    // The length attribute must return the number of CSS declarations in the declarations.
 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    // FIXME: Include the number of custom properties.
 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    return  to_underlying ( last_longhand_property_id )  -  to_underlying ( first_longhand_property_id )  +  1 ; 
							 
						 
					
						
							
								
									
										
										
										
											2021-09-12 20:05:29 +02:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								}  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2023-09-29 16:48:54 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								// https://drafts.csswg.org/cssom/#dom-cssstyledeclaration-item
  
						 
					
						
							
								
									
										
										
										
											2023-09-06 19:07:24 +12:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								String  ResolvedCSSStyleDeclaration : : item ( size_t  index )  const  
						 
					
						
							
								
									
										
										
										
											2021-09-12 20:05:29 +02:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								{  
						 
					
						
							
								
									
										
										
										
											2023-09-29 16:48:54 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    // The item(index) method must return the property name of the CSS declaration at position index.
 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    // FIXME: Return custom properties if index > last_longhand_property_id.
 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    if  ( index  >  length ( ) ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        return  { } ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    auto  property_id  =  static_cast < PropertyID > ( index  +  to_underlying ( first_longhand_property_id ) ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    return  MUST ( String : : from_utf8 ( string_from_property_id ( property_id ) ) ) ; 
							 
						 
					
						
							
								
									
										
										
										
											2021-09-12 20:05:29 +02:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								}  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2023-08-19 15:45:00 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								static  NonnullRefPtr < StyleValue  const >  style_value_for_background_property ( Layout : : NodeWithStyle  const &  layout_node ,  Function < NonnullRefPtr < StyleValue  const > ( BackgroundLayerData  const & ) >  callback ,  Function < NonnullRefPtr < StyleValue  const > ( ) >  default_value )  
						 
					
						
							
								
									
										
										
										
											2023-03-30 23:26:28 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								{  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    auto  const &  background_layers  =  layout_node . background_layers ( ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    if  ( background_layers . is_empty ( ) ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        return  default_value ( ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    if  ( background_layers . size ( )  = =  1 ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        return  callback ( background_layers . first ( ) ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    StyleValueVector  values ; 
							 
						 
					
						
							
								
									
										
										
										
											2023-08-19 15:45:00 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    values . ensure_capacity ( background_layers . size ( ) ) ; 
							 
						 
					
						
							
								
									
										
										
										
											2023-03-30 23:26:28 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    for  ( auto  const &  layer  :  background_layers ) 
							 
						 
					
						
							
								
									
										
										
										
											2023-08-19 15:45:00 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								        values . unchecked_append ( callback ( layer ) ) ; 
							 
						 
					
						
							
								
									
										
										
										
											2023-05-02 14:52:31 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    return  StyleValueList : : create ( move ( values ) ,  StyleValueList : : Separator : : Comma ) ; 
							 
						 
					
						
							
								
									
										
										
										
											2023-03-30 23:26:28 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								}  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2023-08-19 14:00:10 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								static  NonnullRefPtr < StyleValue  const >  style_value_for_length_percentage ( LengthPercentage  const &  length_percentage )  
						 
					
						
							
								
									
										
										
										
											2022-01-19 11:52:01 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								{  
						 
					
						
							
								
									
										
										
										
											2023-04-19 11:20:50 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    if  ( length_percentage . is_auto ( ) ) 
							 
						 
					
						
							
								
									
										
										
										
											2023-05-02 14:52:31 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								        return  IdentifierStyleValue : : create ( ValueID : : Auto ) ; 
							 
						 
					
						
							
								
									
										
										
										
											2022-01-19 11:52:01 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    if  ( length_percentage . is_percentage ( ) ) 
							 
						 
					
						
							
								
									
										
										
										
											2023-05-02 14:52:31 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								        return  PercentageStyleValue : : create ( length_percentage . percentage ( ) ) ; 
							 
						 
					
						
							
								
									
										
										
										
											2022-04-03 22:05:03 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    if  ( length_percentage . is_length ( ) ) 
							 
						 
					
						
							
								
									
										
										
										
											2023-05-02 14:52:31 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								        return  LengthStyleValue : : create ( length_percentage . length ( ) ) ; 
							 
						 
					
						
							
								
									
										
										
										
											2022-04-03 22:05:03 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    return  length_percentage . calculated ( ) ; 
							 
						 
					
						
							
								
									
										
										
										
											2022-01-19 11:52:01 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								}  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2023-08-19 14:00:10 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								static  NonnullRefPtr < StyleValue  const >  style_value_for_size ( Size  const &  size )  
						 
					
						
							
								
									
										
										
										
											2022-09-25 15:48:23 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								{  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    if  ( size . is_none ( ) ) 
							 
						 
					
						
							
								
									
										
										
										
											2023-05-02 14:52:31 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								        return  IdentifierStyleValue : : create ( ValueID : : None ) ; 
							 
						 
					
						
							
								
									
										
										
										
											2022-09-25 15:48:23 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    if  ( size . is_percentage ( ) ) 
							 
						 
					
						
							
								
									
										
										
										
											2023-05-02 14:52:31 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								        return  PercentageStyleValue : : create ( size . percentage ( ) ) ; 
							 
						 
					
						
							
								
									
										
										
										
											2022-09-25 15:48:23 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    if  ( size . is_length ( ) ) 
							 
						 
					
						
							
								
									
										
										
										
											2023-05-02 14:52:31 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								        return  LengthStyleValue : : create ( size . length ( ) ) ; 
							 
						 
					
						
							
								
									
										
										
										
											2022-09-25 15:48:23 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    if  ( size . is_auto ( ) ) 
							 
						 
					
						
							
								
									
										
										
										
											2023-05-02 14:52:31 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								        return  IdentifierStyleValue : : create ( ValueID : : Auto ) ; 
							 
						 
					
						
							
								
									
										
										
										
											2023-03-30 10:50:40 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    if  ( size . is_calculated ( ) ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        return  size . calculated ( ) ; 
							 
						 
					
						
							
								
									
										
										
										
											2022-09-25 15:48:23 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    if  ( size . is_min_content ( ) ) 
							 
						 
					
						
							
								
									
										
										
										
											2023-05-02 14:52:31 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								        return  IdentifierStyleValue : : create ( ValueID : : MinContent ) ; 
							 
						 
					
						
							
								
									
										
										
										
											2022-09-25 15:48:23 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    if  ( size . is_max_content ( ) ) 
							 
						 
					
						
							
								
									
										
										
										
											2023-05-02 14:52:31 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								        return  IdentifierStyleValue : : create ( ValueID : : MaxContent ) ; 
							 
						 
					
						
							
								
									
										
										
										
											2022-09-25 15:48:23 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    // FIXME: Support fit-content(<length>)
 
							 
						 
					
						
							
								
									
										
										
										
											2023-08-30 11:53:50 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    if  ( size . is_fit_content ( ) ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        return  IdentifierStyleValue : : create ( ValueID : : FitContent ) ; 
							 
						 
					
						
							
								
									
										
										
										
											2022-09-25 15:48:23 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    TODO ( ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								}  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2023-08-19 14:00:10 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								static  NonnullRefPtr < StyleValue  const >  style_value_for_sided_shorthand ( ValueComparingNonnullRefPtr < StyleValue  const >  top ,  ValueComparingNonnullRefPtr < StyleValue  const >  right ,  ValueComparingNonnullRefPtr < StyleValue  const >  bottom ,  ValueComparingNonnullRefPtr < StyleValue  const >  left )  
						 
					
						
							
								
									
										
										
										
											2023-05-27 16:24:33 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								{  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    bool  top_and_bottom_same  =  top  = =  bottom ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    bool  left_and_right_same  =  left  = =  right ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    if  ( top_and_bottom_same  & &  left_and_right_same  & &  top  = =  left ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        return  top ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    if  ( top_and_bottom_same  & &  left_and_right_same ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        return  StyleValueList : : create ( StyleValueVector  {  move ( top ) ,  move ( right )  } ,  StyleValueList : : Separator : : Space ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    if  ( left_and_right_same ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        return  StyleValueList : : create ( StyleValueVector  {  move ( top ) ,  move ( right ) ,  move ( bottom )  } ,  StyleValueList : : Separator : : Space ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    return  StyleValueList : : create ( StyleValueVector  {  move ( top ) ,  move ( right ) ,  move ( bottom ) ,  move ( left )  } ,  StyleValueList : : Separator : : Space ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								}  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2023-09-29 13:13:18 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								enum  class  LogicalSide  {  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    BlockStart , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    BlockEnd , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    InlineStart , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    InlineEnd , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								} ;  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								static  RefPtr < StyleValue  const >  style_value_for_length_box_logical_side ( Layout : : NodeWithStyle  const & ,  LengthBox  const &  box ,  LogicalSide  logical_side )  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								{  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    // FIXME: Actually determine the logical sides based on layout_node's writing-mode and direction.
 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    switch  ( logical_side )  { 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    case  LogicalSide : : BlockStart : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        return  style_value_for_length_percentage ( box . top ( ) ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    case  LogicalSide : : BlockEnd : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        return  style_value_for_length_percentage ( box . bottom ( ) ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    case  LogicalSide : : InlineStart : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        return  style_value_for_length_percentage ( box . left ( ) ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    case  LogicalSide : : InlineEnd : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        return  style_value_for_length_percentage ( box . right ( ) ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    } 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    VERIFY_NOT_REACHED ( ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								}  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2023-09-29 13:53:47 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								static  RefPtr < StyleValue  const >  style_value_for_shadow ( Vector < ShadowData >  const &  shadow_data )  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								{  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    if  ( shadow_data . is_empty ( ) ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        return  IdentifierStyleValue : : create ( ValueID : : None ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    auto  make_shadow_style_value  =  [ ] ( ShadowData  const &  shadow )  { 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        return  ShadowStyleValue : : create ( 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								            shadow . color , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								            style_value_for_length_percentage ( shadow . offset_x ) , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								            style_value_for_length_percentage ( shadow . offset_y ) , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								            style_value_for_length_percentage ( shadow . blur_radius ) , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								            style_value_for_length_percentage ( shadow . spread_distance ) , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								            shadow . placement ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    } ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    if  ( shadow_data . size ( )  = =  1 ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        return  make_shadow_style_value ( shadow_data . first ( ) ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    StyleValueVector  style_values ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    style_values . ensure_capacity ( shadow_data . size ( ) ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    for  ( auto &  shadow  :  shadow_data ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        style_values . unchecked_append ( make_shadow_style_value ( shadow ) ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    return  StyleValueList : : create ( move ( style_values ) ,  StyleValueList : : Separator : : Comma ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								}  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2023-08-19 15:45:00 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								RefPtr < StyleValue  const >  ResolvedCSSStyleDeclaration : : style_value_for_property ( Layout : : NodeWithStyle  const &  layout_node ,  PropertyID  property_id )  const  
						 
					
						
							
								
									
										
										
										
											2021-09-12 20:05:29 +02:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								{  
						 
					
						
							
								
									
										
										
										
											2023-09-09 12:04:40 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    // A limited number of properties have special rules for producing their "resolved value".
 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    // We also have to manually construct shorthands from their longhands here.
 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    // Everything else uses the computed value.
 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    // https://www.w3.org/TR/cssom-1/#resolved-values
 
							 
						 
					
						
							
								
									
										
										
										
											2023-09-29 13:58:01 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    // The resolved value for a given longhand property can be determined as follows:
 
							 
						 
					
						
							
								
									
										
										
										
											2021-09-12 20:05:29 +02:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								    switch  ( property_id )  { 
							 
						 
					
						
							
								
									
										
										
										
											2023-09-29 13:58:01 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								        // -> background-color
 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        // FIXME: -> border-block-end-color
 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        // FIXME: -> border-block-start-color
 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        // -> border-bottom-color
 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        // FIXME: -> border-inline-end-color
 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        // FIXME: -> border-inline-start-color
 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        // -> border-left-color
 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        // -> border-right-color
 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        // -> border-top-color
 
							 
						 
					
						
							
								
									
										
										
										
											2023-09-29 13:53:47 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								        // -> box-shadow
 
							 
						 
					
						
							
								
									
										
										
										
											2023-09-29 13:58:01 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								        // FIXME: -> caret-color
 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        // -> color
 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        // -> outline-color
 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        // -> A resolved value special case property like color defined in another specification
 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        //    The resolved value is the used value.
 
							 
						 
					
						
							
								
									
										
										
										
											2022-07-14 17:04:03 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    case  PropertyID : : BackgroundColor : 
							 
						 
					
						
							
								
									
										
										
										
											2023-05-02 14:52:31 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								        return  ColorStyleValue : : create ( layout_node . computed_values ( ) . background_color ( ) ) ; 
							 
						 
					
						
							
								
									
										
										
										
											2023-09-29 13:58:01 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    case  PropertyID : : BorderBottomColor : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        return  ColorStyleValue : : create ( layout_node . computed_values ( ) . border_bottom ( ) . color ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    case  PropertyID : : BorderLeftColor : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        return  ColorStyleValue : : create ( layout_node . computed_values ( ) . border_left ( ) . color ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    case  PropertyID : : BorderRightColor : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        return  ColorStyleValue : : create ( layout_node . computed_values ( ) . border_right ( ) . color ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    case  PropertyID : : BorderTopColor : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        return  ColorStyleValue : : create ( layout_node . computed_values ( ) . border_top ( ) . color ) ; 
							 
						 
					
						
							
								
									
										
										
										
											2023-09-29 13:53:47 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    case  PropertyID : : BoxShadow : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        return  style_value_for_shadow ( layout_node . computed_values ( ) . box_shadow ( ) ) ; 
							 
						 
					
						
							
								
									
										
										
										
											2023-09-29 13:58:01 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    case  PropertyID : : Color : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        return  ColorStyleValue : : create ( layout_node . computed_values ( ) . color ( ) ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    case  PropertyID : : OutlineColor : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        return  ColorStyleValue : : create ( layout_node . computed_values ( ) . outline_color ( ) ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    case  PropertyID : : TextDecorationColor : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        return  ColorStyleValue : : create ( layout_node . computed_values ( ) . text_decoration_color ( ) ) ; 
							 
						 
					
						
							
								
									
										
										
										
											2023-09-29 13:53:47 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								        // NOTE: text-shadow isn't listed, but is computed the same as box-shadow.
 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    case  PropertyID : : TextShadow : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        return  style_value_for_shadow ( layout_node . computed_values ( ) . text_shadow ( ) ) ; 
							 
						 
					
						
							
								
									
										
										
										
											2023-09-29 13:58:01 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2023-09-29 12:47:20 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								        // -> line-height
 
							 
						 
					
						
							
								
									
										
										
										
											2023-09-29 13:58:01 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								        //    The resolved value is normal if the computed value is normal, or the used value otherwise.
 
							 
						 
					
						
							
								
									
										
										
										
											2023-09-29 12:47:20 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    case  PropertyID : : LineHeight :  { 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        auto  line_height  =  static_cast < DOM : : Element  const & > ( * layout_node . dom_node ( ) ) . computed_css_values ( ) - > property ( property_id ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        if  ( line_height - > is_identifier ( )  & &  line_height - > to_identifier ( )  = =  ValueID : : Normal ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								            return  line_height ; 
							 
						 
					
						
							
								
									
										
										
										
											2024-01-12 15:34:13 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								        return  LengthStyleValue : : create ( Length : : make_px ( layout_node . computed_values ( ) . line_height ( ) ) ) ; 
							 
						 
					
						
							
								
									
										
										
										
											2023-09-29 12:47:20 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    } 
							 
						 
					
						
							
								
									
										
										
										
											2023-09-29 13:58:01 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        // FIXME: -> block-size
 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        // -> height
 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        // FIXME: -> inline-size
 
							 
						 
					
						
							
								
									
										
										
										
											2023-09-29 13:13:18 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								        // -> margin-block-end
 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        // -> margin-block-start
 
							 
						 
					
						
							
								
									
										
										
										
											2023-09-29 13:58:01 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								        // -> margin-bottom
 
							 
						 
					
						
							
								
									
										
										
										
											2023-09-29 13:13:18 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								        // -> margin-inline-end
 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        // -> margin-inline-start
 
							 
						 
					
						
							
								
									
										
										
										
											2023-09-29 13:58:01 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								        // -> margin-left
 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        // -> margin-right
 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        // -> margin-top
 
							 
						 
					
						
							
								
									
										
										
										
											2023-09-29 13:13:18 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								        // -> padding-block-end
 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        // -> padding-block-start
 
							 
						 
					
						
							
								
									
										
										
										
											2023-09-29 13:58:01 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								        // -> padding-bottom
 
							 
						 
					
						
							
								
									
										
										
										
											2023-09-29 13:13:18 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								        // -> padding-inline-end
 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        // -> padding-inline-start
 
							 
						 
					
						
							
								
									
										
										
										
											2023-09-29 13:58:01 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								        // -> padding-left
 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        // -> padding-right
 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        // -> padding-top
 
							 
						 
					
						
							
								
									
										
										
										
											2023-09-29 13:02:11 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								        // -> width
 
							 
						 
					
						
							
								
									
										
										
										
											2023-09-29 13:58:01 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								        // -> A resolved value special case property like height defined in another specification
 
							 
						 
					
						
							
								
									
										
										
										
											2024-02-05 09:43:55 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    case  PropertyID : : Height :  { 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        // If the property applies to the element or pseudo-element and the resolved value of the
 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        // display property is not none or contents, then the resolved value is the used value.
 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        // Otherwise the resolved value is the computed value.
 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        auto  const &  display  =  layout_node . computed_values ( ) . display ( ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        if  ( ! display . is_none ( )  & &  ! display . is_contents ( )  & &  layout_node . paintable ( ) )  { 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								            if  ( layout_node . paintable ( ) - > is_paintable_box ( ) )  { 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                auto  const &  paintable_box  =  static_cast < Painting : : PaintableBox  const & > ( * layout_node . paintable ( ) ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                auto  const  used_height  =  paintable_box . content_height ( ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                return  style_value_for_size ( Size : : make_px ( used_height ) ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								            } 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								            dbgln ( " FIXME: Support getting used height for ({}) " ,  layout_node . debug_description ( ) ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        } 
							 
						 
					
						
							
								
									
										
										
										
											2023-09-29 13:58:01 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								        return  style_value_for_size ( layout_node . computed_values ( ) . height ( ) ) ; 
							 
						 
					
						
							
								
									
										
										
										
											2024-02-05 09:43:55 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    } 
							 
						 
					
						
							
								
									
										
										
										
											2023-09-29 13:13:18 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    case  PropertyID : : MarginBlockEnd : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        return  style_value_for_length_box_logical_side ( layout_node ,  layout_node . computed_values ( ) . margin ( ) ,  LogicalSide : : BlockEnd ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    case  PropertyID : : MarginBlockStart : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        return  style_value_for_length_box_logical_side ( layout_node ,  layout_node . computed_values ( ) . margin ( ) ,  LogicalSide : : BlockStart ) ; 
							 
						 
					
						
							
								
									
										
										
										
											2023-09-29 13:58:01 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    case  PropertyID : : MarginBottom : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        return  style_value_for_length_percentage ( layout_node . computed_values ( ) . margin ( ) . bottom ( ) ) ; 
							 
						 
					
						
							
								
									
										
										
										
											2023-09-29 13:13:18 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    case  PropertyID : : MarginInlineEnd : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        return  style_value_for_length_box_logical_side ( layout_node ,  layout_node . computed_values ( ) . margin ( ) ,  LogicalSide : : InlineEnd ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    case  PropertyID : : MarginInlineStart : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        return  style_value_for_length_box_logical_side ( layout_node ,  layout_node . computed_values ( ) . margin ( ) ,  LogicalSide : : InlineStart ) ; 
							 
						 
					
						
							
								
									
										
										
										
											2023-09-29 13:58:01 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    case  PropertyID : : MarginLeft : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        return  style_value_for_length_percentage ( layout_node . computed_values ( ) . margin ( ) . left ( ) ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    case  PropertyID : : MarginRight : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        return  style_value_for_length_percentage ( layout_node . computed_values ( ) . margin ( ) . right ( ) ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    case  PropertyID : : MarginTop : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        return  style_value_for_length_percentage ( layout_node . computed_values ( ) . margin ( ) . top ( ) ) ; 
							 
						 
					
						
							
								
									
										
										
										
											2023-09-29 13:13:18 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    case  PropertyID : : PaddingBlockEnd : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        return  style_value_for_length_box_logical_side ( layout_node ,  layout_node . computed_values ( ) . padding ( ) ,  LogicalSide : : BlockEnd ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    case  PropertyID : : PaddingBlockStart : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        return  style_value_for_length_box_logical_side ( layout_node ,  layout_node . computed_values ( ) . padding ( ) ,  LogicalSide : : BlockStart ) ; 
							 
						 
					
						
							
								
									
										
										
										
											2023-09-29 13:58:01 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    case  PropertyID : : PaddingBottom : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        return  style_value_for_length_percentage ( layout_node . computed_values ( ) . padding ( ) . bottom ( ) ) ; 
							 
						 
					
						
							
								
									
										
										
										
											2023-09-29 13:13:18 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    case  PropertyID : : PaddingInlineEnd : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        return  style_value_for_length_box_logical_side ( layout_node ,  layout_node . computed_values ( ) . padding ( ) ,  LogicalSide : : InlineEnd ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    case  PropertyID : : PaddingInlineStart : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        return  style_value_for_length_box_logical_side ( layout_node ,  layout_node . computed_values ( ) . padding ( ) ,  LogicalSide : : InlineStart ) ; 
							 
						 
					
						
							
								
									
										
										
										
											2023-09-29 13:58:01 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    case  PropertyID : : PaddingLeft : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        return  style_value_for_length_percentage ( layout_node . computed_values ( ) . padding ( ) . left ( ) ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    case  PropertyID : : PaddingRight : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        return  style_value_for_length_percentage ( layout_node . computed_values ( ) . padding ( ) . right ( ) ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    case  PropertyID : : PaddingTop : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        return  style_value_for_length_percentage ( layout_node . computed_values ( ) . padding ( ) . top ( ) ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    case  PropertyID : : Width : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        return  style_value_for_size ( layout_node . computed_values ( ) . width ( ) ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        // -> bottom
 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        // -> left
 
							 
						 
					
						
							
								
									
										
										
										
											2023-09-29 13:13:18 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								        // -> inset-block-end
 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        // -> inset-block-start
 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        // -> inset-inline-end
 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        // -> inset-inline-start
 
							 
						 
					
						
							
								
									
										
										
										
											2023-09-29 13:58:01 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								        // -> right
 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        // -> top
 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        // -> A resolved value special case property like top defined in another specification
 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        // FIXME: If the property applies to a positioned element and the resolved value of the display property is not
 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        //    none or contents, and the property is not over-constrained, then the resolved value is the used value.
 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        //    Otherwise the resolved value is the computed value.
 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    case  PropertyID : : Bottom : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        return  style_value_for_length_percentage ( layout_node . computed_values ( ) . inset ( ) . bottom ( ) ) ; 
							 
						 
					
						
							
								
									
										
										
										
											2023-09-29 13:13:18 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    case  PropertyID : : InsetBlockEnd : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        return  style_value_for_length_box_logical_side ( layout_node ,  layout_node . computed_values ( ) . inset ( ) ,  LogicalSide : : BlockEnd ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    case  PropertyID : : InsetBlockStart : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        return  style_value_for_length_box_logical_side ( layout_node ,  layout_node . computed_values ( ) . inset ( ) ,  LogicalSide : : BlockStart ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    case  PropertyID : : InsetInlineEnd : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        return  style_value_for_length_box_logical_side ( layout_node ,  layout_node . computed_values ( ) . inset ( ) ,  LogicalSide : : InlineEnd ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    case  PropertyID : : InsetInlineStart : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        return  style_value_for_length_box_logical_side ( layout_node ,  layout_node . computed_values ( ) . inset ( ) ,  LogicalSide : : InlineStart ) ; 
							 
						 
					
						
							
								
									
										
										
										
											2023-09-29 13:58:01 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    case  PropertyID : : Left : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        return  style_value_for_length_percentage ( layout_node . computed_values ( ) . inset ( ) . left ( ) ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    case  PropertyID : : Right : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        return  style_value_for_length_percentage ( layout_node . computed_values ( ) . inset ( ) . right ( ) ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    case  PropertyID : : Top : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        return  style_value_for_length_percentage ( layout_node . computed_values ( ) . inset ( ) . top ( ) ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        // -> A resolved value special case property defined in another specification
 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        //    As defined in the relevant specification.
 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    case  PropertyID : : Transform :  { 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        auto  transformations  =  layout_node . computed_values ( ) . transformations ( ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        if  ( transformations . is_empty ( ) ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								            return  IdentifierStyleValue : : create ( ValueID : : None ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2023-10-12 12:30:28 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								        // https://drafts.csswg.org/css-transforms-2/#serialization-of-the-computed-value
 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        // The transform property is a resolved value special case property. [CSSOM]
 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        // When the computed value is a <transform-list>, the resolved value is one <matrix()> function or one <matrix3d()> function computed by the following algorithm:
 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        // 1. Let transform be a 4x4 matrix initialized to the identity matrix.
 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        //    The elements m11, m22, m33 and m44 of transform must be set to 1; all other elements of transform must be set to 0.
 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        auto  transform  =  FloatMatrix4x4 : : identity ( ) ; 
							 
						 
					
						
							
								
									
										
										
										
											2023-09-29 13:58:01 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2023-10-12 12:30:28 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								        // 2. Post-multiply all <transform-function>s in <transform-list> to transform.
 
							 
						 
					
						
							
								
									
										
										
										
											2023-09-29 13:58:01 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								        VERIFY ( layout_node . paintable ( ) ) ; 
							 
						 
					
						
							
								
									
										
										
										
											2023-10-12 12:30:28 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								        auto  const &  paintable_box  =  verify_cast < Painting : : PaintableBox  const > ( * layout_node . paintable ( ) ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        for  ( auto  transformation  :  transformations )  { 
							 
						 
					
						
							
								
									
										
										
										
											2024-01-06 18:05:21 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								            transform  =  transform  *  transformation . to_matrix ( paintable_box ) . release_value ( ) ; 
							 
						 
					
						
							
								
									
										
										
										
											2023-10-12 12:30:28 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								        } 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        // https://drafts.csswg.org/css-transforms-1/#2d-matrix
 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        auto  is_2d_matrix  =  [ ] ( Gfx : : FloatMatrix4x4  const &  matrix )  - >  bool  { 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								            // A 3x2 transformation matrix,
 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								            // or a 4x4 matrix where the items m31, m32, m13, m23, m43, m14, m24, m34 are equal to 0
 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								            // and m33, m44 are equal to 1.
 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								            // NOTE: We only care about 4x4 matrices here.
 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								            // NOTE: Our elements are 0-indexed not 1-indexed, and in the opposite order.
 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								            if  ( matrix . elements ( ) [ 0 ] [ 2 ]  ! =  0      // m31
 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                | |  matrix . elements ( ) [ 1 ] [ 2 ]  ! =  0   // m32
 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                | |  matrix . elements ( ) [ 2 ] [ 0 ]  ! =  0   // m13
 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                | |  matrix . elements ( ) [ 2 ] [ 1 ]  ! =  0   // m23
 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                | |  matrix . elements ( ) [ 2 ] [ 3 ]  ! =  0   // m43
 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                | |  matrix . elements ( ) [ 3 ] [ 0 ]  ! =  0   // m14
 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                | |  matrix . elements ( ) [ 3 ] [ 1 ]  ! =  0   // m24
 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                | |  matrix . elements ( ) [ 3 ] [ 2 ]  ! =  0 )  // m34
 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                return  false ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								            if  ( matrix . elements ( ) [ 2 ] [ 2 ]  ! =  1      // m33
 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                | |  matrix . elements ( ) [ 3 ] [ 3 ]  ! =  1 )  // m44
 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                return  false ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								            return  true ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        } ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        // 3. Chose between <matrix()> or <matrix3d()> serialization:
 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        // -> If transform is a 2D matrix
 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        //        Serialize transform to a <matrix()> function.
 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        if  ( is_2d_matrix ( transform ) )  { 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								            StyleValueVector  parameters  { 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                NumberStyleValue : : create ( transform . elements ( ) [ 0 ] [ 0 ] ) , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                NumberStyleValue : : create ( transform . elements ( ) [ 1 ] [ 0 ] ) , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                NumberStyleValue : : create ( transform . elements ( ) [ 0 ] [ 1 ] ) , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                NumberStyleValue : : create ( transform . elements ( ) [ 1 ] [ 1 ] ) , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                NumberStyleValue : : create ( transform . elements ( ) [ 0 ] [ 3 ] ) , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                NumberStyleValue : : create ( transform . elements ( ) [ 1 ] [ 3 ] ) , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								            } ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								            return  TransformationStyleValue : : create ( TransformFunction : : Matrix ,  move ( parameters ) ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        } 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        // -> Otherwise
 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        //        Serialize transform to a <matrix3d()> function.
 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        else  { 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								            StyleValueVector  parameters  { 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                NumberStyleValue : : create ( transform . elements ( ) [ 0 ] [ 0 ] ) , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                NumberStyleValue : : create ( transform . elements ( ) [ 1 ] [ 0 ] ) , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                NumberStyleValue : : create ( transform . elements ( ) [ 2 ] [ 0 ] ) , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                NumberStyleValue : : create ( transform . elements ( ) [ 3 ] [ 0 ] ) , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                NumberStyleValue : : create ( transform . elements ( ) [ 0 ] [ 1 ] ) , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                NumberStyleValue : : create ( transform . elements ( ) [ 1 ] [ 1 ] ) , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                NumberStyleValue : : create ( transform . elements ( ) [ 2 ] [ 1 ] ) , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                NumberStyleValue : : create ( transform . elements ( ) [ 3 ] [ 1 ] ) , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                NumberStyleValue : : create ( transform . elements ( ) [ 0 ] [ 2 ] ) , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                NumberStyleValue : : create ( transform . elements ( ) [ 1 ] [ 2 ] ) , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                NumberStyleValue : : create ( transform . elements ( ) [ 2 ] [ 2 ] ) , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                NumberStyleValue : : create ( transform . elements ( ) [ 3 ] [ 2 ] ) , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                NumberStyleValue : : create ( transform . elements ( ) [ 0 ] [ 3 ] ) , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                NumberStyleValue : : create ( transform . elements ( ) [ 1 ] [ 3 ] ) , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                NumberStyleValue : : create ( transform . elements ( ) [ 2 ] [ 3 ] ) , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                NumberStyleValue : : create ( transform . elements ( ) [ 3 ] [ 3 ] ) , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								            } ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								            return  TransformationStyleValue : : create ( TransformFunction : : Matrix3d ,  move ( parameters ) ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        } 
							 
						 
					
						
							
								
									
										
										
										
											2023-09-29 13:58:01 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    } 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        // -> Any other property
 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        //    The resolved value is the computed value.
 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        //    NOTE: This is handled inside the `default` case.
 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        // NOTE: Everything below is a shorthand that requires some manual construction.
 
							 
						 
					
						
							
								
									
										
										
										
											2023-05-27 15:44:37 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    case  PropertyID : : BackgroundPosition : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        return  style_value_for_background_property ( 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								            layout_node , 
							 
						 
					
						
							
								
									
										
										
										
											2023-08-19 15:45:00 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								            [ ] ( auto &  layer )  - >  NonnullRefPtr < StyleValue >  { 
							 
						 
					
						
							
								
									
										
										
										
											2023-05-27 15:44:37 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								                return  PositionStyleValue : : create ( 
							 
						 
					
						
							
								
									
										
										
										
											2023-08-19 14:00:10 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								                    EdgeStyleValue : : create ( layer . position_edge_x ,  layer . position_offset_x ) , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                    EdgeStyleValue : : create ( layer . position_edge_y ,  layer . position_offset_y ) ) ; 
							 
						 
					
						
							
								
									
										
										
										
											2023-05-27 15:44:37 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								            } , 
							 
						 
					
						
							
								
									
										
										
										
											2023-08-19 15:45:00 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								            [ ] ( )  - >  NonnullRefPtr < StyleValue >  { 
							 
						 
					
						
							
								
									
										
										
										
											2023-05-27 15:44:37 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								                return  PositionStyleValue : : create ( 
							 
						 
					
						
							
								
									
										
										
										
											2023-08-19 14:00:10 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								                    EdgeStyleValue : : create ( PositionEdge : : Left ,  Percentage ( 0 ) ) , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                    EdgeStyleValue : : create ( PositionEdge : : Top ,  Percentage ( 0 ) ) ) ; 
							 
						 
					
						
							
								
									
										
										
										
											2023-05-27 15:44:37 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								            } ) ; 
							 
						 
					
						
							
								
									
										
										
										
											2023-05-27 16:32:08 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    case  PropertyID : : Border :  { 
							 
						 
					
						
							
								
									
										
										
										
											2023-09-29 13:02:11 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								        auto  width  =  style_value_for_property ( layout_node ,  PropertyID : : BorderWidth ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        auto  style  =  style_value_for_property ( layout_node ,  PropertyID : : BorderStyle ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        auto  color  =  style_value_for_property ( layout_node ,  PropertyID : : BorderColor ) ; 
							 
						 
					
						
							
								
									
										
										
										
											2023-05-27 16:32:08 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								        // `border` only has a reasonable value if all four sides are the same.
 
							 
						 
					
						
							
								
									
										
										
										
											2023-09-29 13:02:11 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								        if  ( width - > is_value_list ( )  | |  style - > is_value_list ( )  | |  color - > is_value_list ( ) ) 
							 
						 
					
						
							
								
									
										
										
										
											2023-05-27 16:32:08 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								            return  nullptr ; 
							 
						 
					
						
							
								
									
										
										
										
											2023-09-20 12:50:48 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								        return  ShorthandStyleValue : : create ( property_id , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								            {  PropertyID : : BorderWidth ,  PropertyID : : BorderStyle ,  PropertyID : : BorderColor  } , 
							 
						 
					
						
							
								
									
										
										
										
											2023-09-29 13:02:11 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								            {  width . release_nonnull ( ) ,  style . release_nonnull ( ) ,  color . release_nonnull ( )  } ) ; 
							 
						 
					
						
							
								
									
										
										
										
											2023-05-27 16:32:08 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    } 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    case  PropertyID : : BorderColor :  { 
							 
						 
					
						
							
								
									
										
										
										
											2023-09-29 13:02:11 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								        auto  top  =  style_value_for_property ( layout_node ,  PropertyID : : BorderTopColor ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        auto  right  =  style_value_for_property ( layout_node ,  PropertyID : : BorderRightColor ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        auto  bottom  =  style_value_for_property ( layout_node ,  PropertyID : : BorderBottomColor ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        auto  left  =  style_value_for_property ( layout_node ,  PropertyID : : BorderLeftColor ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        return  style_value_for_sided_shorthand ( top . release_nonnull ( ) ,  right . release_nonnull ( ) ,  bottom . release_nonnull ( ) ,  left . release_nonnull ( ) ) ; 
							 
						 
					
						
							
								
									
										
										
										
											2023-05-27 16:32:08 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    } 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    case  PropertyID : : BorderStyle :  { 
							 
						 
					
						
							
								
									
										
										
										
											2023-09-29 13:02:11 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								        auto  top  =  style_value_for_property ( layout_node ,  PropertyID : : BorderTopStyle ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        auto  right  =  style_value_for_property ( layout_node ,  PropertyID : : BorderRightStyle ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        auto  bottom  =  style_value_for_property ( layout_node ,  PropertyID : : BorderBottomStyle ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        auto  left  =  style_value_for_property ( layout_node ,  PropertyID : : BorderLeftStyle ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        return  style_value_for_sided_shorthand ( top . release_nonnull ( ) ,  right . release_nonnull ( ) ,  bottom . release_nonnull ( ) ,  left . release_nonnull ( ) ) ; 
							 
						 
					
						
							
								
									
										
										
										
											2023-05-27 16:32:08 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    } 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    case  PropertyID : : BorderWidth :  { 
							 
						 
					
						
							
								
									
										
										
										
											2023-09-29 13:02:11 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								        auto  top  =  style_value_for_property ( layout_node ,  PropertyID : : BorderTopWidth ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        auto  right  =  style_value_for_property ( layout_node ,  PropertyID : : BorderRightWidth ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        auto  bottom  =  style_value_for_property ( layout_node ,  PropertyID : : BorderBottomWidth ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        auto  left  =  style_value_for_property ( layout_node ,  PropertyID : : BorderLeftWidth ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        return  style_value_for_sided_shorthand ( top . release_nonnull ( ) ,  right . release_nonnull ( ) ,  bottom . release_nonnull ( ) ,  left . release_nonnull ( ) ) ; 
							 
						 
					
						
							
								
									
										
										
										
											2023-05-27 16:32:08 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    } 
							 
						 
					
						
							
								
									
										
										
										
											2023-05-27 15:52:49 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    case  PropertyID : : Margin :  { 
							 
						 
					
						
							
								
									
										
										
										
											2023-09-29 13:02:11 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								        auto  top  =  style_value_for_property ( layout_node ,  PropertyID : : MarginTop ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        auto  right  =  style_value_for_property ( layout_node ,  PropertyID : : MarginRight ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        auto  bottom  =  style_value_for_property ( layout_node ,  PropertyID : : MarginBottom ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        auto  left  =  style_value_for_property ( layout_node ,  PropertyID : : MarginLeft ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        return  style_value_for_sided_shorthand ( top . release_nonnull ( ) ,  right . release_nonnull ( ) ,  bottom . release_nonnull ( ) ,  left . release_nonnull ( ) ) ; 
							 
						 
					
						
							
								
									
										
										
										
											2021-10-05 17:11:38 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    } 
							 
						 
					
						
							
								
									
										
										
										
											2023-05-27 15:52:49 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    case  PropertyID : : Padding :  { 
							 
						 
					
						
							
								
									
										
										
										
											2023-09-29 13:02:11 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								        auto  top  =  style_value_for_property ( layout_node ,  PropertyID : : PaddingTop ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        auto  right  =  style_value_for_property ( layout_node ,  PropertyID : : PaddingRight ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        auto  bottom  =  style_value_for_property ( layout_node ,  PropertyID : : PaddingBottom ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        auto  left  =  style_value_for_property ( layout_node ,  PropertyID : : PaddingLeft ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        return  style_value_for_sided_shorthand ( top . release_nonnull ( ) ,  right . release_nonnull ( ) ,  bottom . release_nonnull ( ) ,  left . release_nonnull ( ) ) ; 
							 
						 
					
						
							
								
									
										
										
										
											2021-10-05 17:11:38 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    } 
							 
						 
					
						
							
								
									
										
										
										
											2023-05-27 15:52:49 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    case  PropertyID : : Invalid : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        return  IdentifierStyleValue : : create ( ValueID : : Invalid ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    case  PropertyID : : Custom : 
							 
						 
					
						
							
								
									
										
										
										
											2022-02-06 14:17:42 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								        dbgln_if ( LIBWEB_CSS_DEBUG ,  " Computed style for custom properties was requested (?) " ) ; 
							 
						 
					
						
							
								
									
										
										
										
											2023-05-02 14:52:31 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								        return  nullptr ; 
							 
						 
					
						
							
								
									
										
										
										
											2021-09-12 20:05:29 +02:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								    default : 
							 
						 
					
						
							
								
									
										
										
										
											2023-09-09 12:04:40 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								        if  ( ! property_is_shorthand ( property_id ) ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								            return  static_cast < DOM : : Element  const & > ( * layout_node . dom_node ( ) ) . computed_css_values ( ) - > property ( property_id ) ; 
							 
						 
					
						
							
								
									
										
										
										
											2023-09-26 14:05:57 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        // Handle shorthands in a generic way
 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        auto  longhand_ids  =  longhands_for_shorthand ( property_id ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        StyleValueVector  longhand_values ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        longhand_values . ensure_capacity ( longhand_ids . size ( ) ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        for  ( auto  longhand_id  :  longhand_ids ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								            longhand_values . append ( style_value_for_property ( layout_node ,  longhand_id ) . release_nonnull ( ) ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        return  ShorthandStyleValue : : create ( property_id ,  move ( longhand_ids ) ,  move ( longhand_values ) ) ; 
							 
						 
					
						
							
								
									
										
										
										
											2021-09-12 20:05:29 +02:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								    } 
							 
						 
					
						
							
								
									
										
										
										
											2021-09-18 13:14:40 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								}  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2021-09-23 12:35:56 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								Optional < StyleProperty >  ResolvedCSSStyleDeclaration : : property ( PropertyID  property_id )  const  
						 
					
						
							
								
									
										
										
										
											2021-09-18 13:14:40 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								{  
						 
					
						
							
								
									
										
										
										
											2023-05-10 15:33:10 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    // https://www.w3.org/TR/cssom-1/#dom-window-getcomputedstyle
 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    // NOTE: This is a partial enforcement of step 5 ("If elt is connected, ...")
 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    if  ( ! m_element - > is_connected ( ) ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        return  { } ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2023-10-13 17:44:36 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    // FIXME: Be smarter about updating layout if there's no layout node.
 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    //        We may legitimately have no layout node if we're not visible, but this protects against situations
 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    //        where we're requesting the computed style before layout has happened.
 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    if  ( ! m_element - > layout_node ( )  | |  property_affects_layout ( property_id ) )  { 
							 
						 
					
						
							
								
									
										
										
										
											2022-03-20 21:12:19 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								        const_cast < DOM : : Document & > ( m_element - > document ( ) ) . update_layout ( ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    }  else  { 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        // FIXME: If we had a way to update style for a single element, this would be a good place to use it.
 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        const_cast < DOM : : Document & > ( m_element - > document ( ) ) . update_style ( ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    } 
							 
						 
					
						
							
								
									
										
										
										
											2021-09-18 13:14:40 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    if  ( ! m_element - > layout_node ( ) )  { 
							 
						 
					
						
							
								
									
										
										
										
											2024-03-05 18:10:02 -07:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								        auto  style  =  m_element - > document ( ) . style_computer ( ) . compute_style ( const_cast < DOM : : Element & > ( * m_element ) ) ; 
							 
						 
					
						
							
								
									
										
										
										
											2022-12-06 03:08:20 -03:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2022-10-28 15:42:18 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								        // FIXME: This is a stopgap until we implement shorthand -> longhand conversion.
 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        auto  value  =  style - > maybe_null_property ( property_id ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        if  ( ! value )  { 
							 
						 
					
						
							
								
									
										
										
										
											2024-02-21 09:38:31 -05:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								            dbgln ( " FIXME: ResolvedCSSStyleDeclaration::property(property_id={:#x}) No value for property ID in newly computed style case. " ,  to_underlying ( property_id ) ) ; 
							 
						 
					
						
							
								
									
										
										
										
											2022-10-28 15:42:18 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								            return  { } ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        } 
							 
						 
					
						
							
								
									
										
										
										
											2022-04-14 11:52:35 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								        return  StyleProperty  { 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								            . property_id  =  property_id , 
							 
						 
					
						
							
								
									
										
										
										
											2022-10-28 15:42:18 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								            . value  =  value . release_nonnull ( ) , 
							 
						 
					
						
							
								
									
										
										
										
											2022-04-14 11:52:35 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								        } ; 
							 
						 
					
						
							
								
									
										
										
										
											2021-09-18 13:14:40 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    } 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    auto &  layout_node  =  * m_element - > layout_node ( ) ; 
							 
						 
					
						
							
								
									
										
										
										
											2023-08-19 15:45:00 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    auto  value  =  style_value_for_property ( layout_node ,  property_id ) ; 
							 
						 
					
						
							
								
									
										
										
										
											2021-09-18 13:14:40 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    if  ( ! value ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        return  { } ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    return  StyleProperty  { 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        . property_id  =  property_id , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        . value  =  value . release_nonnull ( ) , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    } ; 
							 
						 
					
						
							
								
									
										
										
										
											2021-09-12 20:05:29 +02:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								}  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2022-04-11 16:10:55 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								// https://drafts.csswg.org/cssom/#dom-cssstyledeclaration-setproperty
  
						 
					
						
							
								
									
										
										
										
											2022-09-25 17:03:42 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								WebIDL : : ExceptionOr < void >  ResolvedCSSStyleDeclaration : : set_property ( PropertyID ,  StringView ,  StringView )  
						 
					
						
							
								
									
										
										
										
											2021-09-12 20:05:29 +02:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								{  
						 
					
						
							
								
									
										
										
										
											2022-04-11 16:10:55 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    // 1. If the computed flag is set, then throw a NoModificationAllowedError exception.
 
							 
						 
					
						
							
								
									
										
										
										
											2023-09-06 16:03:01 +12:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    return  WebIDL : : NoModificationAllowedError : : create ( realm ( ) ,  " Cannot modify properties in result of getComputedStyle() " _fly_string ) ; 
							 
						 
					
						
							
								
									
										
										
										
											2022-04-11 16:10:55 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								}  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								// https://drafts.csswg.org/cssom/#dom-cssstyledeclaration-removeproperty
  
						 
					
						
							
								
									
										
										
										
											2023-09-06 19:07:24 +12:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								WebIDL : : ExceptionOr < String >  ResolvedCSSStyleDeclaration : : remove_property ( PropertyID )  
						 
					
						
							
								
									
										
										
										
											2022-04-11 16:10:55 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								{  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    // 1. If the computed flag is set, then throw a NoModificationAllowedError exception.
 
							 
						 
					
						
							
								
									
										
										
										
											2023-09-06 16:03:01 +12:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    return  WebIDL : : NoModificationAllowedError : : create ( realm ( ) ,  " Cannot remove properties from result of getComputedStyle() " _fly_string ) ; 
							 
						 
					
						
							
								
									
										
										
										
											2021-09-12 20:05:29 +02:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								}  
						 
					
						
							
								
									
										
										
										
											2021-10-01 19:57:45 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2023-11-21 10:39:54 +13:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								String  ResolvedCSSStyleDeclaration : : serialized ( )  const  
						 
					
						
							
								
									
										
										
										
											2021-10-01 19:57:45 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								{  
						 
					
						
							
								
									
										
										
										
											2021-10-15 19:38:39 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    // https://www.w3.org/TR/cssom/#dom-cssstyledeclaration-csstext
 
							 
						 
					
						
							
								
									
										
										
										
											2021-10-01 19:57:45 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    // If the computed flag is set, then return the empty string.
 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    // NOTE: ResolvedCSSStyleDeclaration is something you would only get from window.getComputedStyle(),
 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    //       which returns what the spec calls "resolved style". The "computed flag" is always set here.
 
							 
						 
					
						
							
								
									
										
										
										
											2023-11-21 10:39:54 +13:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    return  String  { } ; 
							 
						 
					
						
							
								
									
										
										
										
											2021-10-01 19:57:45 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								}  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2022-11-05 04:51:05 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								// https://drafts.csswg.org/cssom/#dom-cssstyledeclaration-csstext
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								WebIDL : : ExceptionOr < void >  ResolvedCSSStyleDeclaration : : set_css_text ( StringView )  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								{  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    // 1. If the computed flag is set, then throw a NoModificationAllowedError exception.
 
							 
						 
					
						
							
								
									
										
										
										
											2023-09-06 16:03:01 +12:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    return  WebIDL : : NoModificationAllowedError : : create ( realm ( ) ,  " Cannot modify properties in result of getComputedStyle() " _fly_string ) ; 
							 
						 
					
						
							
								
									
										
										
										
											2022-11-05 04:51:05 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								}  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2021-09-12 20:05:29 +02:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								}