Merge pull request #75959 from ShadyChibinko/tab_metadata_3x

[3.x] Add tab Metadata to Tabs & TabContainer
This commit is contained in:
Rémi Verschelde 2023-06-07 14:46:21 +02:00
commit f742d98679
No known key found for this signature in database
GPG key ID: C3336907360768E1
6 changed files with 72 additions and 0 deletions

View file

@ -72,6 +72,13 @@
Returns the index of the tab at local coordinates [code]point[/code]. Returns [code]-1[/code] if the point is outside the control boundaries or if there's no tab at the queried position.
</description>
</method>
<method name="get_tab_metadata" qualifiers="const">
<return type="Variant" />
<argument index="0" name="tab_idx" type="int" />
<description>
Returns the metadata value set to the tab at index [code]tab_idx[/code]. If no metadata was previously set, returns [code]null[/code] by default.
</description>
</method>
<method name="get_tab_title" qualifiers="const">
<return type="String" />
<argument index="0" name="tab_idx" type="int" />
@ -116,6 +123,14 @@
Sets an icon for the tab at index [code]tab_idx[/code].
</description>
</method>
<method name="set_tab_metadata">
<return type="void" />
<argument index="0" name="tab_idx" type="int" />
<argument index="1" name="metadata" type="Variant" />
<description>
Sets the metadata value for the tab at index [code]tab_idx[/code].
</description>
</method>
<method name="set_tab_title">
<return type="void" />
<argument index="0" name="tab_idx" type="int" />

View file

@ -69,6 +69,13 @@
Returns the [Texture] for the tab at index [code]tab_idx[/code] or [code]null[/code] if the tab has no [Texture].
</description>
</method>
<method name="get_tab_metadata" qualifiers="const">
<return type="Variant" />
<argument index="0" name="tab_idx" type="int" />
<description>
Returns the metadata value set to the tab at index [code]tab_idx[/code]. If no metadata was previously set, returns [code]null[/code] by default.
</description>
</method>
<method name="get_tab_offset" qualifiers="const">
<return type="int" />
<description>
@ -141,6 +148,14 @@
Sets an [code]icon[/code] for the tab at index [code]tab_idx[/code].
</description>
</method>
<method name="set_tab_metadata">
<return type="void" />
<argument index="0" name="tab_idx" type="int" />
<argument index="1" name="metadata" type="Variant" />
<description>
Sets the metadata value for the tab at index [code]tab_idx[/code].
</description>
</method>
<method name="set_tab_title">
<return type="void" />
<argument index="0" name="tab_idx" type="int" />

View file

@ -931,6 +931,22 @@ bool TabContainer::get_tab_hidden(int p_tab) const {
}
}
void TabContainer::set_tab_metadata(int p_tab, const Variant &p_metadata) {
Control *child = get_tab_control(p_tab);
ERR_FAIL_COND(!child);
child->set_meta("_tab_metadata", p_metadata);
}
Variant TabContainer::get_tab_metadata(int p_tab) const {
Control *child = get_tab_control(p_tab);
ERR_FAIL_COND_V(!child, Variant());
if (child->has_meta("_tab_metadata")) {
return child->get_meta("_tab_metadata");
} else {
return Variant();
}
}
void TabContainer::get_translatable_strings(List<String> *p_strings) const {
Vector<Control *> tabs = _get_tabs();
for (int i = 0; i < tabs.size(); i++) {
@ -1047,6 +1063,8 @@ void TabContainer::_bind_methods() {
ClassDB::bind_method(D_METHOD("get_tab_disabled", "tab_idx"), &TabContainer::get_tab_disabled);
ClassDB::bind_method(D_METHOD("set_tab_hidden", "tab_idx", "hidden"), &TabContainer::set_tab_hidden);
ClassDB::bind_method(D_METHOD("get_tab_hidden", "tab_idx"), &TabContainer::get_tab_hidden);
ClassDB::bind_method(D_METHOD("set_tab_metadata", "tab_idx", "metadata"), &TabContainer::set_tab_metadata);
ClassDB::bind_method(D_METHOD("get_tab_metadata", "tab_idx"), &TabContainer::get_tab_metadata);
ClassDB::bind_method(D_METHOD("get_tab_idx_at_point", "point"), &TabContainer::get_tab_idx_at_point);
ClassDB::bind_method(D_METHOD("set_popup", "popup"), &TabContainer::set_popup);
ClassDB::bind_method(D_METHOD("get_popup"), &TabContainer::get_popup);

View file

@ -107,6 +107,9 @@ public:
void set_tab_hidden(int p_tab, bool p_hidden);
bool get_tab_hidden(int p_tab) const;
void set_tab_metadata(int p_tab, const Variant &p_metadata);
Variant get_tab_metadata(int p_tab) const;
int get_tab_count() const;
void set_current_tab(int p_current);
int get_current_tab() const;

View file

@ -474,6 +474,21 @@ bool Tabs::get_tab_disabled(int p_tab) const {
return tabs[p_tab].disabled;
}
void Tabs::set_tab_metadata(int p_tab, const Variant &p_metadata) {
ERR_FAIL_INDEX(p_tab, tabs.size());
if (tabs[p_tab].metadata == p_metadata) {
return;
}
tabs.write[p_tab].metadata = p_metadata;
}
Variant Tabs::get_tab_metadata(int p_tab) const {
ERR_FAIL_INDEX_V(p_tab, tabs.size(), Variant());
return tabs[p_tab].metadata;
}
void Tabs::set_tab_right_button(int p_tab, const Ref<Texture> &p_right_button) {
ERR_FAIL_INDEX(p_tab, tabs.size());
tabs.write[p_tab].right_button = p_right_button;
@ -963,6 +978,8 @@ void Tabs::_bind_methods() {
ClassDB::bind_method(D_METHOD("get_tab_button_icon", "tab_idx"), &Tabs::get_tab_right_button);
ClassDB::bind_method(D_METHOD("set_tab_disabled", "tab_idx", "disabled"), &Tabs::set_tab_disabled);
ClassDB::bind_method(D_METHOD("get_tab_disabled", "tab_idx"), &Tabs::get_tab_disabled);
ClassDB::bind_method(D_METHOD("set_tab_metadata", "tab_idx", "metadata"), &Tabs::set_tab_metadata);
ClassDB::bind_method(D_METHOD("get_tab_metadata", "tab_idx"), &Tabs::get_tab_metadata);
ClassDB::bind_method(D_METHOD("remove_tab", "tab_idx"), &Tabs::remove_tab);
ClassDB::bind_method(D_METHOD("add_tab", "title", "icon"), &Tabs::add_tab, DEFVAL(""), DEFVAL(Ref<Texture>()));
ClassDB::bind_method(D_METHOD("set_tab_align", "align"), &Tabs::set_tab_align);

View file

@ -60,6 +60,7 @@ private:
Ref<Texture> icon;
int ofs_cache;
bool disabled;
Variant metadata;
int size_cache;
int size_text;
int x_cache;
@ -124,6 +125,9 @@ public:
void set_tab_disabled(int p_tab, bool p_disabled);
bool get_tab_disabled(int p_tab) const;
void set_tab_metadata(int p_tab, const Variant &p_metadata);
Variant get_tab_metadata(int p_tab) const;
void set_tab_right_button(int p_tab, const Ref<Texture> &p_right_button);
Ref<Texture> get_tab_right_button(int p_tab) const;