| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197 |
- // ================================================================================
- // == This file is a part of Turbo Badger. (C) 2011-2014, Emil Segerås ==
- // == See tb_core.h for more information. ==
- // ================================================================================
- #include "tb_toggle_container.h"
- #include "tb_widgets_reader.h"
- #include "tb_node_tree.h"
- namespace tb {
- // == TBSectionHeader =====================================
- TBSectionHeader::TBSectionHeader()
- {
- SetSkinBg(TBIDC("TBSectionHeader"));
- SetGravity(WIDGET_GRAVITY_LEFT | WIDGET_GRAVITY_RIGHT);
- SetToggleMode(true);
- }
- bool TBSectionHeader::OnEvent(const TBWidgetEvent &ev)
- {
- if (ev.target == this && ev.type == EVENT_TYPE_CHANGED && GetParent()->GetParent())
- {
- if (TBSection *section = TBSafeCast<TBSection>(GetParent()->GetParent()))
- {
- section->GetContainer()->SetValue(GetValue());
- // Try to scroll the container into view when expanded
- section->SetPendingScrollIntoView(GetValue() ? true : false);
- }
- }
- return TBButton::OnEvent(ev);
- }
- // == TBSectionHeader =====================================
- TBSection::TBSection()
- : m_pending_scroll(false)
- {
- SetGravity(WIDGET_GRAVITY_LEFT | WIDGET_GRAVITY_RIGHT);
- SetSkinBg(TBIDC("TBSection"), WIDGET_INVOKE_INFO_NO_CALLBACKS);
- m_layout.SetSkinBg(TBIDC("TBSection.layout"), WIDGET_INVOKE_INFO_NO_CALLBACKS);
- m_toggle_container.SetSkinBg(TBIDC("TBSection.container"));
- m_toggle_container.SetToggle(TBToggleContainer::TOGGLE_EXPANDED);
- m_toggle_container.SetGravity(WIDGET_GRAVITY_ALL);
- m_layout.SetAxis(AXIS_Y);
- m_layout.SetGravity(WIDGET_GRAVITY_ALL);
- m_layout.SetLayoutSize(LAYOUT_SIZE_AVAILABLE);
- // ATOMIC BEGIN
- m_toggle_container_layout.SetSkinBg(TBIDC("TBSection.layout"), WIDGET_INVOKE_INFO_NO_CALLBACKS);
- m_toggle_container_layout.SetAxis(AXIS_Y);
- m_toggle_container_layout.SetGravity(WIDGET_GRAVITY_ALL);
- m_toggle_container_layout.SetLayoutSize(LAYOUT_SIZE_AVAILABLE);
- m_toggle_container.AddChild(&m_toggle_container_layout);
- // ATOMIC END
- AddChild(&m_layout);
- m_layout.AddChild(&m_header);
- m_layout.AddChild(&m_toggle_container);
- }
- TBSection::~TBSection()
- {
- // ATOMIC BEGIN
- while (TBWidget* child = m_toggle_container_layout.GetFirstChild())
- {
- m_toggle_container_layout.RemoveChild(child);
- }
- m_toggle_container.RemoveChild(&m_toggle_container_layout);
- // ATOMIC END
- m_layout.RemoveChild(&m_toggle_container);
- m_layout.RemoveChild(&m_header);
- RemoveChild(&m_layout);
- }
- void TBSection::SetValue(int value)
- {
- m_header.SetValue(value);
- m_toggle_container.SetValue(value);
- }
- // ATOMIC BEGIN
- void TBSection::AddToggleChild(TBWidget *child, WIDGET_Z z, WIDGET_INVOKE_INFO info)
- {
- m_toggle_container_layout.AddChild(child, z, info);
- }
- void TBSection::AddToggleChildRelative(TBWidget *child, WIDGET_Z_REL z, TBWidget *reference, WIDGET_INVOKE_INFO info)
- {
- m_toggle_container_layout.AddChildRelative(child, z, reference, info);
- }
- void TBSection::RemoveToggleChild(TBWidget* child)
- {
- m_toggle_container_layout.RemoveChild(child);
- }
- void TBSection::DeleteAllToggleChildren()
- {
- m_toggle_container_layout.DeleteAllChildren();
- }
- TBWidget* TBSection::GetFirstToggleChild()
- {
- return m_toggle_container_layout.GetFirstChild();
- }
- TBWidget* TBSection::GetToggleWidgetById(const TBID &id)
- {
- return m_toggle_container_layout.GetWidgetByTouchId(id);
- }
- // ATOMIC END
- void TBSection::OnProcessAfterChildren()
- {
- if (m_pending_scroll)
- {
- m_pending_scroll = false;
- ScrollIntoViewRecursive();
- }
- }
- PreferredSize TBSection::OnCalculatePreferredSize(const SizeConstraints &constraints)
- {
- PreferredSize ps = TBWidget::OnCalculatePreferredContentSize(constraints);
- // We should not grow larger than we are, when there's extra space available.
- ps.max_h = ps.pref_h;
- return ps;
- }
- // == TBToggleContainer ===================================
- TBToggleContainer::TBToggleContainer()
- : m_toggle(TOGGLE_NOTHING)
- , m_invert(false)
- , m_value(0)
- {
- SetSkinBg(TBIDC("TBToggleContainer"), WIDGET_INVOKE_INFO_NO_CALLBACKS);
- }
- void TBToggleContainer::SetToggle(TOGGLE toggle)
- {
- if (toggle == m_toggle)
- return;
- if (m_toggle == TOGGLE_EXPANDED)
- InvalidateLayout(INVALIDATE_LAYOUT_RECURSIVE);
- m_toggle = toggle;
- UpdateInternal();
- }
- void TBToggleContainer::SetInvert(bool invert)
- {
- if (invert == m_invert)
- return;
- m_invert = invert;
- UpdateInternal();
- }
- void TBToggleContainer::SetValue(int value)
- {
- if (value == m_value)
- return;
- m_value = value;
- UpdateInternal();
- InvalidateSkinStates();
- }
- void TBToggleContainer::UpdateInternal()
- {
- bool on = GetIsOn();
- switch (m_toggle)
- {
- case TOGGLE_NOTHING:
- break;
- case TOGGLE_ENABLED:
- SetState(WIDGET_STATE_DISABLED, !on);
- break;
- case TOGGLE_OPACITY:
- SetOpacity(on ? 1.f : 0);
- break;
- case TOGGLE_EXPANDED:
- SetVisibilility(on ? WIDGET_VISIBILITY_VISIBLE : WIDGET_VISIBILITY_GONE);
- // Also disable when collapsed so tab focus skips the children.
- SetState(WIDGET_STATE_DISABLED, !on);
- break;
- };
- }
- }; // namespace tb
|