summaryrefslogtreecommitdiffstats
path: root/scene/gui/item_list.cpp
diff options
context:
space:
mode:
Diffstat (limited to 'scene/gui/item_list.cpp')
-rw-r--r--scene/gui/item_list.cpp70
1 files changed, 23 insertions, 47 deletions
diff --git a/scene/gui/item_list.cpp b/scene/gui/item_list.cpp
index e9d34fae3b..dce2888266 100644
--- a/scene/gui/item_list.cpp
+++ b/scene/gui/item_list.cpp
@@ -35,6 +35,8 @@
#include "core/string/translation.h"
#include "scene/theme/theme_db.h"
+PropertyListHelper ItemList::base_property_helper;
+
void ItemList::_shape_text(int p_idx) {
Item &item = items.write[p_idx];
@@ -1678,23 +1680,10 @@ TextServer::OverrunBehavior ItemList::get_text_overrun_behavior() const {
}
bool ItemList::_set(const StringName &p_name, const Variant &p_value) {
- Vector<String> components = String(p_name).split("/", true, 2);
- if (components.size() >= 2 && components[0].begins_with("item_") && components[0].trim_prefix("item_").is_valid_int()) {
- int item_index = components[0].trim_prefix("item_").to_int();
- if (components[1] == "text") {
- set_item_text(item_index, p_value);
- return true;
- } else if (components[1] == "icon") {
- set_item_icon(item_index, p_value);
- return true;
- } else if (components[1] == "disabled") {
- set_item_disabled(item_index, p_value);
- return true;
- } else if (components[1] == "selectable") {
- set_item_selectable(item_index, p_value);
- return true;
- }
+ if (property_helper.property_set_value(p_name, p_value)) {
+ return true;
}
+
#ifndef DISABLE_DEPRECATED
// Compatibility.
if (p_name == "items") {
@@ -1717,42 +1706,19 @@ bool ItemList::_set(const StringName &p_name, const Variant &p_value) {
}
bool ItemList::_get(const StringName &p_name, Variant &r_ret) const {
- Vector<String> components = String(p_name).split("/", true, 2);
- if (components.size() >= 2 && components[0].begins_with("item_") && components[0].trim_prefix("item_").is_valid_int()) {
- int item_index = components[0].trim_prefix("item_").to_int();
- if (components[1] == "text") {
- r_ret = get_item_text(item_index);
- return true;
- } else if (components[1] == "icon") {
- r_ret = get_item_icon(item_index);
- return true;
- } else if (components[1] == "disabled") {
- r_ret = is_item_disabled(item_index);
- return true;
- } else if (components[1] == "selectable") {
- r_ret = is_item_selectable(item_index);
- return true;
- }
- }
- return false;
+ return property_helper.property_get_value(p_name, r_ret);
}
void ItemList::_get_property_list(List<PropertyInfo> *p_list) const {
- for (int i = 0; i < items.size(); i++) {
- p_list->push_back(PropertyInfo(Variant::STRING, vformat("item_%d/text", i)));
-
- PropertyInfo pi = PropertyInfo(Variant::OBJECT, vformat("item_%d/icon", i), PROPERTY_HINT_RESOURCE_TYPE, "Texture2D");
- pi.usage &= ~(get_item_icon(i).is_null() ? PROPERTY_USAGE_STORAGE : 0);
- p_list->push_back(pi);
+ property_helper.get_property_list(p_list, items.size());
+}
- pi = PropertyInfo(Variant::BOOL, vformat("item_%d/selectable", i));
- pi.usage &= ~(is_item_selectable(i) ? PROPERTY_USAGE_STORAGE : 0);
- p_list->push_back(pi);
+bool ItemList::_property_can_revert(const StringName &p_name) const {
+ return property_helper.property_can_revert(p_name);
+}
- pi = PropertyInfo(Variant::BOOL, vformat("item_%d/disabled", i));
- pi.usage &= ~(!is_item_disabled(i) ? PROPERTY_USAGE_STORAGE : 0);
- p_list->push_back(pi);
- }
+bool ItemList::_property_get_revert(const StringName &p_name, Variant &r_property) const {
+ return property_helper.property_get_revert(p_name, r_property);
}
void ItemList::_bind_methods() {
@@ -1919,6 +1885,14 @@ void ItemList::_bind_methods() {
BIND_THEME_ITEM_CUSTOM(Theme::DATA_TYPE_STYLEBOX, ItemList, cursor_style, "cursor_unfocused");
BIND_THEME_ITEM_CUSTOM(Theme::DATA_TYPE_STYLEBOX, ItemList, cursor_focus_style, "cursor");
BIND_THEME_ITEM(Theme::DATA_TYPE_COLOR, ItemList, guide_color);
+
+ Item defaults(true);
+
+ base_property_helper.set_prefix("item_");
+ base_property_helper.register_property(PropertyInfo(Variant::STRING, "text"), defaults.text, "set_item_text", "get_item_text");
+ base_property_helper.register_property(PropertyInfo(Variant::OBJECT, "icon", PROPERTY_HINT_RESOURCE_TYPE, "Texture2D"), defaults.icon, "set_item_icon", "get_item_icon");
+ base_property_helper.register_property(PropertyInfo(Variant::BOOL, "selectable"), defaults.selectable, "set_item_selectable", "is_item_selectable");
+ base_property_helper.register_property(PropertyInfo(Variant::BOOL, "disabled"), defaults.disabled, "set_item_disabled", "is_item_disabled");
}
ItemList::ItemList() {
@@ -1930,6 +1904,8 @@ ItemList::ItemList() {
set_focus_mode(FOCUS_ALL);
set_clip_contents(true);
+
+ property_helper.setup_for_instance(base_property_helper, this);
}
ItemList::~ItemList() {