/*
- * Copyright (c) 2020 Samsung Electronics Co., Ltd.
+ * Copyright (c) 2021 Samsung Electronics Co., Ltd.
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
// INTERNAL INCLUDES
#include <dali-toolkit/devel-api/visual-factory/transition-data.h>
#include <dali-toolkit/internal/controls/control/control-data-impl.h>
-#include <dali-toolkit/public-api/controls/control.h>
#include <dali-toolkit/public-api/controls/control-impl.h>
+#include <dali-toolkit/public-api/controls/control.h>
+
+namespace
+{
+Dali::Toolkit::Internal::Control::Impl& GetControlImplementation(Dali::Toolkit::Control control)
+{
+ auto& internalControl = Dali::Toolkit::Internal::GetImplementation(control);
+
+ return Dali::Toolkit::Internal::Control::Impl::Get(internalControl);
+}
+
+} // unnamed namespace
namespace Dali
{
return controlDataImpl.VisualEventSignal();
}
-static Toolkit::Internal::Control::Impl *GetControlImplementationIfAny( Dali::Actor actor)
+Dali::Property GetVisualProperty(Control control, Dali::Property::Index index, Dali::Property::Key visualPropertyKey)
{
- Dali::Toolkit::Control c = Toolkit::Control::DownCast( actor );
- if ( c )
- {
- auto &impl1 = Toolkit::Internal::GetImplementation( c );
- auto &impl2 = Toolkit::Internal::Control::Impl::Get( impl1 );
- return &impl2;
- }
- return nullptr;
+ Internal::Control& internalControl = Toolkit::Internal::GetImplementation(control);
+ Internal::Control::Impl& controlDataImpl = Internal::Control::Impl::Get(internalControl);
+ return controlDataImpl.GetVisualProperty(index, visualPropertyKey);
}
-Toolkit::DevelControl::AccessibilityActivateSignalType &AccessibilityActivateSignal( Toolkit::Control control )
+Toolkit::DevelControl::AccessibilityActivateSignalType& AccessibilityActivateSignal(Toolkit::Control control)
{
- auto ac = GetControlImplementationIfAny ( control );
- return ac->mAccessibilityActivateSignal;
+ return GetControlImplementation(control).mAccessibilityActivateSignal;
}
-Toolkit::DevelControl::AccessibilityReadingSkippedSignalType &AccessibilityReadingSkippedSignal( Toolkit::Control control )
+Toolkit::DevelControl::AccessibilityReadingSkippedSignalType& AccessibilityReadingSkippedSignal(Toolkit::Control control)
{
- auto ac = GetControlImplementationIfAny ( control );
- return ac->mAccessibilityReadingSkippedSignal;
+ return GetControlImplementation(control).mAccessibilityReadingSkippedSignal;
}
-Toolkit::DevelControl::AccessibilityReadingCancelledSignalType &AccessibilityReadingCancelledSignal( Toolkit::Control control )
+Toolkit::DevelControl::AccessibilityReadingPausedSignalType& AccessibilityReadingPausedSignal(Toolkit::Control control)
{
- auto ac = GetControlImplementationIfAny ( control );
- return ac->mAccessibilityReadingCancelledSignal;
+ return GetControlImplementation(control).mAccessibilityReadingPausedSignal;
}
-Toolkit::DevelControl::AccessibilityReadingStoppedSignalType &AccessibilityReadingStoppedSignal( Toolkit::Control control )
+Toolkit::DevelControl::AccessibilityReadingResumedSignalType& AccessibilityReadingResumedSignal(Toolkit::Control control)
{
- auto ac = GetControlImplementationIfAny ( control );
- return ac->mAccessibilityReadingStoppedSignal;
+ return GetControlImplementation(control).mAccessibilityReadingResumedSignal;
}
-Toolkit::DevelControl::AccessibilityGetNameSignalType &AccessibilityGetNameSignal( Toolkit::Control control )
+Toolkit::DevelControl::AccessibilityReadingCancelledSignalType& AccessibilityReadingCancelledSignal(Toolkit::Control control)
{
- auto ac = GetControlImplementationIfAny ( control );
- return ac->mAccessibilityGetNameSignal;
+ return GetControlImplementation(control).mAccessibilityReadingCancelledSignal;
}
-Toolkit::DevelControl::AccessibilityGetDescriptionSignalType &AccessibilityGetDescriptionSignal( Toolkit::Control control )
+Toolkit::DevelControl::AccessibilityReadingStoppedSignalType& AccessibilityReadingStoppedSignal(Toolkit::Control control)
{
- auto ac = GetControlImplementationIfAny ( control );
- return ac->mAccessibilityGetDescriptionSignal;
+ return GetControlImplementation(control).mAccessibilityReadingStoppedSignal;
}
-Toolkit::DevelControl::AccessibilityDoGestureSignalType &AccessibilityDoGestureSignal( Toolkit::Control control )
+Toolkit::DevelControl::AccessibilityGetNameSignalType& AccessibilityGetNameSignal(Toolkit::Control control)
{
- auto ac = GetControlImplementationIfAny ( control );
- return ac->mAccessibilityDoGestureSignal;
+ return GetControlImplementation(control).mAccessibilityGetNameSignal;
}
-void AppendAccessibilityRelation( Dali::Actor control, Actor destination, Dali::Accessibility::RelationType relation)
+Toolkit::DevelControl::AccessibilityGetDescriptionSignalType& AccessibilityGetDescriptionSignal(Toolkit::Control control)
{
- if ( auto ac = GetControlImplementationIfAny ( control ) )
- {
- auto index = static_cast<Dali::Property::Array::SizeType>(relation);
- if (index >= ac->mAccessibilityRelations.size())
- {
- DALI_LOG_ERROR( "Relation index exceeds vector size." );
- return;
- }
-
- auto obj = ac->GetAccessibilityObject(destination);
- if (obj)
- ac->mAccessibilityRelations[index].push_back(obj->GetAddress());
- }
+ return GetControlImplementation(control).mAccessibilityGetDescriptionSignal;
}
-void RemoveAccessibilityRelation( Dali::Actor control, Actor destination, Dali::Accessibility::RelationType relation)
+Toolkit::DevelControl::AccessibilityDoGestureSignalType& AccessibilityDoGestureSignal(Toolkit::Control control)
{
- if ( auto ac = GetControlImplementationIfAny ( control ) )
- {
- auto index = static_cast<Dali::Property::Array::SizeType>(relation);
- if (index >= ac->mAccessibilityRelations.size())
- {
- DALI_LOG_ERROR( "Relation index exceeds vector size." );
- return;
- }
-
- auto obj = ac->GetAccessibilityObject(destination);
- if (!obj)
- return;
-
- auto address = obj->GetAddress();
-
- auto &targets = ac->mAccessibilityRelations[index];
- for (auto i = 0u; i < targets.size(); ++i) {
- if (targets[i].ToString() == address.ToString())
- {
- targets[i] = targets.back();
- targets.erase(targets.end() - 1);
- }
- }
- }
+ return GetControlImplementation(control).mAccessibilityDoGestureSignal;
}
-std::vector<std::vector<Accessibility::Address>> GetAccessibilityRelations( Dali::Actor control )
+void AppendAccessibilityRelation(Toolkit::Control control, Dali::Actor destination, Dali::Accessibility::RelationType relation)
{
- if ( auto ac = GetControlImplementationIfAny ( control ) )
+ if(auto destinationAccessible = Accessibility::Accessible::Get(destination))
{
- return ac->mAccessibilityRelations;
+ GetControlImplementation(control).mAccessibilityRelations[relation].insert(destinationAccessible);
}
- return {};
}
-void ClearAccessibilityRelations( Dali::Actor control )
+void RemoveAccessibilityRelation(Toolkit::Control control, Dali::Actor destination, Dali::Accessibility::RelationType relation)
{
- if ( auto ac = GetControlImplementationIfAny ( control ) )
+ if(auto destinationAccessible = Accessibility::Accessible::Get(destination))
{
- for (auto &it : ac->mAccessibilityRelations)
- it.clear();
+ auto& relations = GetControlImplementation(control).mAccessibilityRelations;
+
+ relations[relation].erase(destinationAccessible);
+
+ if(relations[relation].empty())
+ {
+ relations.erase(relation);
+ }
}
}
-void SetAccessibilityConstructor( Dali::Actor control,
- std::function< std::unique_ptr< Dali::Accessibility::Accessible >( Dali::Actor ) > constructor )
+std::vector<Accessibility::Relation> GetAccessibilityRelations(Toolkit::Control control)
{
- if ( auto ac = GetControlImplementationIfAny ( control ) )
+ const auto& relations = GetControlImplementation(control).mAccessibilityRelations;
+ std::vector<Accessibility::Relation> result;
+
+ for(auto& relation : relations)
{
- ac->accessibilityConstructor = constructor;
+ auto& targets = relation.second;
+
+ result.emplace_back(Accessibility::Relation{relation.first, {}});
+ std::copy(targets.begin(), targets.end(), std::back_inserter(result.back().mTargets));
}
+
+ return result;
}
-void AppendAccessibilityAttribute( Dali::Actor control, const std::string& key,
- const std::string value )
+void ClearAccessibilityRelations(Toolkit::Control control)
{
- if ( auto ac = GetControlImplementationIfAny ( control ) )
- {
- ac->AppendAccessibilityAttribute( key, value );
- }
+ GetControlImplementation(control).mAccessibilityRelations.clear();
}
-void RemoveAccessibilityAttribute( Dali::Actor control, const std::string& key )
+void AppendAccessibilityAttribute(Toolkit::Control control, const std::string& key, const std::string& value)
{
- if ( auto ac = GetControlImplementationIfAny ( control ) )
- {
- ac->RemoveAccessibilityAttribute( key );
- }
+ GetControlImplementation(control).AppendAccessibilityAttribute(key, value);
}
-void ClearAccessibilityAttributes( Dali::Actor control )
+void RemoveAccessibilityAttribute(Toolkit::Control control, const std::string& key)
{
- if ( auto ac = GetControlImplementationIfAny ( control ) )
- {
- ac->ClearAccessibilityAttributes();
- }
+ GetControlImplementation(control).RemoveAccessibilityAttribute(key);
}
-void SetAccessibilityReadingInfoType( Dali::Actor control, const Dali::Accessibility::ReadingInfoTypes types )
+void ClearAccessibilityAttributes(Toolkit::Control control)
{
- if ( auto ac = GetControlImplementationIfAny ( control ) )
- {
- ac->SetAccessibilityReadingInfoType( types );
- }
+ GetControlImplementation(control).ClearAccessibilityAttributes();
}
-Dali::Accessibility::ReadingInfoTypes GetAccessibilityReadingInfoType(Dali::Actor control )
+void SetAccessibilityReadingInfoType(Toolkit::Control control, const Dali::Accessibility::ReadingInfoTypes types)
{
- if ( auto ac = GetControlImplementationIfAny ( control ) )
- {
- return ac->GetAccessibilityReadingInfoType();
- }
- return {};
+ GetControlImplementation(control).SetAccessibilityReadingInfoType(types);
}
-bool ClearAccessibilityHighlight( Dali::Actor control )
+Dali::Accessibility::ReadingInfoTypes GetAccessibilityReadingInfoType(Toolkit::Control control)
{
- if ( auto ac = GetControlImplementationIfAny ( control ) )
- {
- auto ptr = dynamic_cast<Dali::Accessibility::Component*>( ac );
- if( ptr )
- return ptr->ClearHighlight();
- }
- return false;
+ return GetControlImplementation(control).GetAccessibilityReadingInfoType();
}
-bool GrabAccessibilityHighlight( Dali::Actor control )
+bool ClearAccessibilityHighlight(Toolkit::Control control)
{
- if ( auto ac = GetControlImplementationIfAny ( control ) )
- {
- auto ptr = dynamic_cast<Dali::Accessibility::Component*>( ac );
- if( ptr )
- return ptr->GrabHighlight();
- }
- return false;
+ return GetControlImplementation(control).GetAccessibleObject()->ClearHighlight();
}
-Dali::Accessibility::States GetAccessibilityStates( Dali::Actor control )
+bool GrabAccessibilityHighlight(Toolkit::Control control)
{
- if ( auto ac = GetControlImplementationIfAny ( control ) )
- {
- auto ptr = dynamic_cast<Dali::Accessibility::Component*>( ac );
- if(ptr)
- return ptr->GetStates();
- }
- return {};
+ return GetControlImplementation(control).GetAccessibleObject()->GrabHighlight();
}
-void NotifyAccessibilityStateChange( Dali::Actor control, Dali::Accessibility::States states, bool doRecursive )
+Dali::Accessibility::States GetAccessibilityStates(Toolkit::Control control)
{
- if ( auto ac = GetControlImplementationIfAny ( control ) )
- {
- ac->GetAccessibilityObject()->NotifyAccessibilityStateChange( states, doRecursive );
- }
+ return GetControlImplementation(control).GetAccessibleObject()->GetStates();
}
-Dali::Accessibility::Accessible *GetBoundAccessibilityObject( Dali::Actor control )
+void NotifyAccessibilityStateChange(Toolkit::Control control, Dali::Accessibility::States states, bool recurse)
{
- return Dali::Accessibility::Accessible::Get( control );
+ GetControlImplementation(control).GetAccessibleObject()->NotifyAccessibilityStateChange(std::move(states), recurse);
}
} // namespace DevelControl