mirror of
				https://github.com/RGBCube/serenity
				synced 2025-10-31 14:22:43 +00:00 
			
		
		
		
	 1682f0b760
			
		
	
	
		1682f0b760
		
	
	
	
	
		
			
			SPDX License Identifiers are a more compact / standardized way of representing file license information. See: https://spdx.dev/resources/use/#identifiers This was done with the `ambr` search and replace tool. ambr --no-parent-ignore --key-from-file --rep-from-file key.txt rep.txt *
		
			
				
	
	
		
			66 lines
		
	
	
	
		
			2.2 KiB
		
	
	
	
		
			C++
		
	
	
	
	
	
			
		
		
	
	
			66 lines
		
	
	
	
		
			2.2 KiB
		
	
	
	
		
			C++
		
	
	
	
	
	
| /*
 | |
|  * Copyright (c) 2021, Andreas Kling <kling@serenityos.org>
 | |
|  *
 | |
|  * SPDX-License-Identifier: BSD-2-Clause
 | |
|  */
 | |
| 
 | |
| #include <AK/ScopeGuard.h>
 | |
| #include <LibWeb/Bindings/CSSStyleDeclarationWrapper.h>
 | |
| #include <LibWeb/CSS/Parser/DeprecatedCSSParser.h>
 | |
| #include <LibWeb/DOM/Element.h>
 | |
| 
 | |
| namespace Web::Bindings {
 | |
| 
 | |
| JS::Value CSSStyleDeclarationWrapper::get(const JS::PropertyName& name, JS::Value receiver, bool without_side_effects) const
 | |
| {
 | |
|     // FIXME: These should actually use camelCase versions of the property names!
 | |
|     auto property_id = CSS::property_id_from_string(name.to_string());
 | |
|     if (property_id == CSS::PropertyID::Invalid)
 | |
|         return Base::get(name, receiver, without_side_effects);
 | |
|     for (auto& property : impl().properties()) {
 | |
|         if (property.property_id == property_id)
 | |
|             return js_string(vm(), property.value->to_string());
 | |
|     }
 | |
|     return js_string(vm(), String::empty());
 | |
| }
 | |
| 
 | |
| bool CSSStyleDeclarationWrapper::put(const JS::PropertyName& name, JS::Value value, JS::Value receiver)
 | |
| {
 | |
|     // FIXME: These should actually use camelCase versions of the property names!
 | |
|     auto property_id = CSS::property_id_from_string(name.to_string());
 | |
|     if (property_id == CSS::PropertyID::Invalid)
 | |
|         return Base::put(name, value, receiver);
 | |
| 
 | |
|     auto css_text = value.to_string(global_object());
 | |
|     if (vm().exception())
 | |
|         return false;
 | |
| 
 | |
|     auto new_value = parse_css_value(CSS::ParsingContext {}, css_text, property_id);
 | |
|     // FIXME: What are we supposed to do if we can't parse it?
 | |
|     if (!new_value)
 | |
|         return false;
 | |
| 
 | |
|     ScopeGuard style_invalidation_guard = [&] {
 | |
|         auto& declaration = downcast<CSS::ElementInlineCSSStyleDeclaration>(impl());
 | |
|         if (auto* element = declaration.element())
 | |
|             element->invalidate_style();
 | |
|     };
 | |
| 
 | |
|     // FIXME: I don't think '!important' is being handled correctly here..
 | |
| 
 | |
|     for (auto& property : impl().m_properties) {
 | |
|         if (property.property_id == property_id) {
 | |
|             property.value = new_value.release_nonnull();
 | |
|             return true;
 | |
|         }
 | |
|     }
 | |
| 
 | |
|     impl().m_properties.append(CSS::StyleProperty {
 | |
|         .property_id = property_id,
 | |
|         .value = new_value.release_nonnull(),
 | |
|         .important = false,
 | |
|     });
 | |
|     return true;
 | |
| }
 | |
| 
 | |
| }
 |