mirror of
https://github.com/RGBCube/serenity
synced 2025-07-04 20:57:35 +00:00
Browser+LibHTML: Deduplicate inspector code
The `DOMElementStyleModel` and `DOMComputedElementStyleModel` classes were replaced by the `StylePropertiesModel`.
This commit is contained in:
parent
988d1deca8
commit
2ced4c4ec7
7 changed files with 60 additions and 145 deletions
48
Libraries/LibHTML/StylePropertiesModel.cpp
Normal file
48
Libraries/LibHTML/StylePropertiesModel.cpp
Normal file
|
@ -0,0 +1,48 @@
|
|||
#include "StylePropertiesModel.h"
|
||||
#include <LibHTML/CSS/PropertyID.h>
|
||||
#include <LibHTML/DOM/Document.h>
|
||||
#include <LibHTML/CSS/StyleProperties.h>
|
||||
|
||||
StylePropertiesModel::StylePropertiesModel(const StyleProperties& properties)
|
||||
: m_properties(properties)
|
||||
{
|
||||
properties.for_each_property([&](auto property_id, auto& property_value) {
|
||||
Value value;
|
||||
value.name = CSS::string_from_property_id(property_id);
|
||||
value.value = property_value.to_string();
|
||||
m_values.append(value);
|
||||
});
|
||||
}
|
||||
|
||||
int StylePropertiesModel::row_count(const GModelIndex&) const
|
||||
{
|
||||
return m_values.size();
|
||||
}
|
||||
|
||||
String StylePropertiesModel::column_name(int column_index) const
|
||||
{
|
||||
switch (column_index) {
|
||||
case Column::PropertyName:
|
||||
return "Name";
|
||||
case Column::PropertyValue:
|
||||
return "Value";
|
||||
default:
|
||||
ASSERT_NOT_REACHED();
|
||||
}
|
||||
}
|
||||
GVariant StylePropertiesModel::data(const GModelIndex& index, Role role) const
|
||||
{
|
||||
auto& value = m_values[index.row()];
|
||||
if (role == Role::Display) {
|
||||
if (index.column() == Column::PropertyName)
|
||||
return value.name;
|
||||
if (index.column() == Column::PropertyValue)
|
||||
return value.value;
|
||||
}
|
||||
return {};
|
||||
}
|
||||
|
||||
void StylePropertiesModel::update()
|
||||
{
|
||||
did_update();
|
||||
}
|
Loading…
Add table
Add a link
Reference in a new issue