/*
- * Copyright (c) 2018 Samsung Electronics Co., Ltd.
+ * Copyright (c) 2023 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.
#include "control-devel.h"
// EXTERNAL INCLUDES
+#include <dali/public-api/actors/actor.h>
#include <dali/public-api/animation/animation.h>
// 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-impl.h>
-#include <dali-toolkit/devel-api/visual-factory/transition-data.h>
+#include <dali-toolkit/public-api/controls/control.h>
-namespace Dali
+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
+{
namespace Toolkit
{
-
namespace DevelControl
{
+void RegisterVisual(Internal::Control& control, Dali::Property::Index index, Toolkit::Visual::Base& visual)
+{
+ Internal::Control::Impl& controlDataImpl = Internal::Control::Impl::Get(control);
+ controlDataImpl.RegisterVisual(index, visual);
+}
+
+void RegisterVisual(Internal::Control& control, Dali::Property::Index index, Toolkit::Visual::Base& visual, int depthIndex)
+{
+ Internal::Control::Impl& controlDataImpl = Internal::Control::Impl::Get(control);
+ controlDataImpl.RegisterVisual(index, visual, depthIndex);
+}
+
+void RegisterVisual(Internal::Control& control, Dali::Property::Index index, Toolkit::Visual::Base& visual, bool enabled)
+{
+ Internal::Control::Impl& controlDataImpl = Internal::Control::Impl::Get(control);
+ controlDataImpl.RegisterVisual(index, visual, enabled);
+}
+
+void RegisterVisual(Internal::Control& control, Dali::Property::Index index, Toolkit::Visual::Base& visual, bool enabled, int depthIndex)
+{
+ Internal::Control::Impl& controlDataImpl = Internal::Control::Impl::Get(control);
+ controlDataImpl.RegisterVisual(index, visual, enabled, depthIndex);
+}
+
+void UnregisterVisual(Internal::Control& control, Dali::Property::Index index)
+{
+ Internal::Control::Impl& controlDataImpl = Internal::Control::Impl::Get(control);
+ controlDataImpl.UnregisterVisual(index);
+}
+
+Toolkit::Visual::Base GetVisual(const Internal::Control& control, Dali::Property::Index index)
+{
+ const Internal::Control::Impl& controlDataImpl = Internal::Control::Impl::Get(control);
+ return controlDataImpl.GetVisual(index);
+}
+
+void EnableVisual(Internal::Control& control, Dali::Property::Index index, bool enable)
+{
+ Internal::Control::Impl& controlDataImpl = Internal::Control::Impl::Get(control);
+ controlDataImpl.EnableVisual(index, enable);
+}
+
+bool IsVisualEnabled(const Internal::Control& control, Dali::Property::Index index)
+{
+ const Internal::Control::Impl& controlDataImpl = Internal::Control::Impl::Get(control);
+ return controlDataImpl.IsVisualEnabled(index);
+}
+
+Dali::Animation CreateTransition(Internal::Control& control, const Toolkit::TransitionData& handle)
+{
+ Internal::Control::Impl& controlDataImpl = Internal::Control::Impl::Get(control);
+ return controlDataImpl.CreateTransition(handle);
+}
+
+void AddTransitions(Internal::Control& control,
+ Dali::Animation animation,
+ const Toolkit::TransitionData& transitionData)
+{
+ Internal::Control::Impl& controlDataImpl = Internal::Control::Impl::Get(control);
+ controlDataImpl.AddTransitions(animation, transitionData);
+}
+
+void DoAction(Control& control, Dali::Property::Index visualIndex, Dali::Property::Index actionId, const Dali::Property::Value attributes)
+{
+ Internal::Control& controlInternal = Toolkit::Internal::GetImplementation(control);
+ Internal::Control::Impl& controlDataImpl = Internal::Control::Impl::Get(controlInternal);
+ controlDataImpl.DoAction(visualIndex, actionId, attributes);
+}
+
+void DoActionExtension(Control& control, Dali::Property::Index visualIndex, Dali::Property::Index actionId, Dali::Any attributes)
+{
+ Internal::Control& controlInternal = Toolkit::Internal::GetImplementation(control);
+ Internal::Control::Impl& controlDataImpl = Internal::Control::Impl::Get(controlInternal);
+ controlDataImpl.DoActionExtension(visualIndex, actionId, attributes);
+}
+
+void SetInputMethodContext(Internal::Control& control, InputMethodContext& inputMethodContext)
+{
+ Internal::Control::Impl::Get(control).SetInputMethodContext(inputMethodContext);
+}
-void RegisterVisual( Internal::Control& control, Dali::Property::Index index, Toolkit::Visual::Base& visual )
+VisualEventSignalType& VisualEventSignal(Control control)
{
- Internal::Control::Impl& controlDataImpl = Internal::Control::Impl::Get( control );
- controlDataImpl.RegisterVisual( index, visual );
+ Internal::Control& internalControl = Toolkit::Internal::GetImplementation(control);
+ Internal::Control::Impl& controlDataImpl = Internal::Control::Impl::Get(internalControl);
+ return controlDataImpl.VisualEventSignal();
}
-void RegisterVisual( Internal::Control& control, Dali::Property::Index index, Toolkit::Visual::Base& visual, int depthIndex )
+Dali::Property GetVisualProperty(Control control, Dali::Property::Index index, Dali::Property::Key visualPropertyKey)
{
- Internal::Control::Impl& controlDataImpl = Internal::Control::Impl::Get( control );
- controlDataImpl.RegisterVisual( index, visual, depthIndex );
+ Internal::Control& internalControl = Toolkit::Internal::GetImplementation(control);
+ Internal::Control::Impl& controlDataImpl = Internal::Control::Impl::Get(internalControl);
+ return controlDataImpl.GetVisualProperty(index, visualPropertyKey);
}
-void RegisterVisual( Internal::Control& control, Dali::Property::Index index, Toolkit::Visual::Base& visual, bool enabled )
+Toolkit::DevelControl::AccessibilityActivateSignalType& AccessibilityActivateSignal(Toolkit::Control control)
{
- Internal::Control::Impl& controlDataImpl = Internal::Control::Impl::Get( control );
- controlDataImpl.RegisterVisual( index, visual, enabled );
+ return GetControlImplementation(control).mAccessibilityActivateSignal;
}
-void RegisterVisual( Internal::Control& control, Dali::Property::Index index, Toolkit::Visual::Base& visual, bool enabled, int depthIndex )
+Toolkit::DevelControl::AccessibilityReadingSkippedSignalType& AccessibilityReadingSkippedSignal(Toolkit::Control control)
{
- Internal::Control::Impl& controlDataImpl = Internal::Control::Impl::Get( control );
- controlDataImpl.RegisterVisual( index, visual, enabled, depthIndex );
+ return GetControlImplementation(control).mAccessibilityReadingSkippedSignal;
}
-void UnregisterVisual( Internal::Control& control, Dali::Property::Index index )
+Toolkit::DevelControl::AccessibilityReadingPausedSignalType& AccessibilityReadingPausedSignal(Toolkit::Control control)
{
- Internal::Control::Impl& controlDataImpl = Internal::Control::Impl::Get( control );
- controlDataImpl.UnregisterVisual( index );
+ return GetControlImplementation(control).mAccessibilityReadingPausedSignal;
}
-Toolkit::Visual::Base GetVisual( const Internal::Control& control, Dali::Property::Index index )
+Toolkit::DevelControl::AccessibilityReadingResumedSignalType& AccessibilityReadingResumedSignal(Toolkit::Control control)
{
- const Internal::Control::Impl& controlDataImpl = Internal::Control::Impl::Get( control );
- return controlDataImpl.GetVisual( index );
+ return GetControlImplementation(control).mAccessibilityReadingResumedSignal;
}
-void EnableVisual( Internal::Control& control, Dali::Property::Index index, bool enable )
+Toolkit::DevelControl::AccessibilityReadingCancelledSignalType& AccessibilityReadingCancelledSignal(Toolkit::Control control)
{
- Internal::Control::Impl& controlDataImpl = Internal::Control::Impl::Get( control );
- controlDataImpl.EnableVisual( index, enable );
+ return GetControlImplementation(control).mAccessibilityReadingCancelledSignal;
}
-bool IsVisualEnabled( const Internal::Control& control, Dali::Property::Index index )
+Toolkit::DevelControl::AccessibilityReadingStoppedSignalType& AccessibilityReadingStoppedSignal(Toolkit::Control control)
{
- const Internal::Control::Impl& controlDataImpl = Internal::Control::Impl::Get( control );
- return controlDataImpl.IsVisualEnabled( index );
+ return GetControlImplementation(control).mAccessibilityReadingStoppedSignal;
}
-Dali::Animation CreateTransition( Internal::Control& control, const Toolkit::TransitionData& handle )
+Toolkit::DevelControl::AccessibilityGetNameSignalType& AccessibilityGetNameSignal(Toolkit::Control control)
{
- Internal::Control::Impl& controlDataImpl = Internal::Control::Impl::Get( control );
- return controlDataImpl.CreateTransition( handle );
+ return GetControlImplementation(control).mAccessibilityGetNameSignal;
}
+Toolkit::DevelControl::AccessibilityGetDescriptionSignalType& AccessibilityGetDescriptionSignal(Toolkit::Control control)
+{
+ return GetControlImplementation(control).mAccessibilityGetDescriptionSignal;
+}
-void AddTransitions( Internal::Control& control,
- Dali::Animation animation,
- const Toolkit::TransitionData& transitionData )
+Toolkit::DevelControl::AccessibilityDoGestureSignalType& AccessibilityDoGestureSignal(Toolkit::Control control)
{
- Internal::Control::Impl& controlDataImpl = Internal::Control::Impl::Get( control );
- controlDataImpl.AddTransitions( animation, transitionData );
+ return GetControlImplementation(control).mAccessibilityDoGestureSignal;
}
-void DoAction( Control& control, Dali::Property::Index visualIndex, Dali::Property::Index actionId, const Dali::Property::Value attributes )
+void AppendAccessibilityRelation(Toolkit::Control control, Dali::Actor destination, Dali::Accessibility::RelationType relation)
{
- Internal::Control& controlInternal = Toolkit::Internal::GetImplementation( control );
- Internal::Control::Impl& controlDataImpl = Internal::Control::Impl::Get( controlInternal );
- controlDataImpl.DoAction( visualIndex, actionId, attributes );
+ if(auto destinationAccessible = Accessibility::Accessible::Get(destination))
+ {
+ GetControlImplementation(control).mAccessibilityRelations[relation].insert(destinationAccessible);
+ }
}
-void SetInputMethodContext( Internal::Control& control, InputMethodContext& inputMethodContext )
+void RemoveAccessibilityRelation(Toolkit::Control control, Dali::Actor destination, Dali::Accessibility::RelationType relation)
{
- Internal::Control::Impl::Get( control ).SetInputMethodContext( inputMethodContext );
+ if(auto destinationAccessible = Accessibility::Accessible::Get(destination))
+ {
+ auto& relations = GetControlImplementation(control).mAccessibilityRelations;
+
+ relations[relation].erase(destinationAccessible);
+
+ if(relations[relation].empty())
+ {
+ relations.erase(relation);
+ }
+ }
}
-Toolkit::LayoutItem GetLayout( Control control )
+std::vector<Accessibility::Relation> GetAccessibilityRelations(Toolkit::Control control)
{
- const Internal::Control& internalControl = Toolkit::Internal::GetImplementation( control );
- const Internal::Control::Impl& controlDataImpl = Internal::Control::Impl::Get( internalControl );
- return Toolkit::LayoutItem( controlDataImpl.GetLayout().Get() );
+ const auto& relations = GetControlImplementation(control).mAccessibilityRelations;
+ std::vector<Accessibility::Relation> result;
+
+ for(auto& relation : relations)
+ {
+ 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;
}
-Toolkit::LayoutItem GetLayout( Internal::Control& control )
+void ClearAccessibilityRelations(Toolkit::Control control)
{
- Internal::Control::Impl& controlDataImpl = Internal::Control::Impl::Get( control );
- return Toolkit::LayoutItem( controlDataImpl.GetLayout().Get() );
+ GetControlImplementation(control).mAccessibilityRelations.clear();
}
-void SetLayout( Internal::Control& control, Toolkit::LayoutItem layout )
+void AppendAccessibilityAttribute(Toolkit::Control control, const std::string& key, const std::string& value)
{
- Internal::Control::Impl& controlDataImpl = Internal::Control::Impl::Get( control );
- controlDataImpl.SetLayout( GetImplementation( layout ) );
+ GetControlImplementation(control).AppendAccessibilityAttribute(key, value);
}
-void SetLayout( Control control, Toolkit::LayoutItem layout )
+void RemoveAccessibilityAttribute(Toolkit::Control control, const std::string& key)
{
- Internal::Control& internalControl = Toolkit::Internal::GetImplementation( control );
- Internal::Control::Impl& controlDataImpl = Internal::Control::Impl::Get( internalControl );
- if( layout )
+ GetControlImplementation(control).RemoveAccessibilityAttribute(key);
+}
+
+void ClearAccessibilityAttributes(Toolkit::Control control)
+{
+ GetControlImplementation(control).ClearAccessibilityAttributes();
+}
+
+void SetAccessibilityReadingInfoType(Toolkit::Control control, const Dali::Accessibility::ReadingInfoTypes types)
+{
+ GetControlImplementation(control).SetAccessibilityReadingInfoType(types);
+}
+
+Dali::Accessibility::ReadingInfoTypes GetAccessibilityReadingInfoType(Toolkit::Control control)
+{
+ return GetControlImplementation(control).GetAccessibilityReadingInfoType();
+}
+
+bool ClearAccessibilityHighlight(Toolkit::Control control)
+{
+ auto* controlAccessible = GetControlImplementation(control).GetAccessibleObject();
+ if(DALI_LIKELY(controlAccessible))
{
- controlDataImpl.SetLayout( GetImplementation( layout ) );
+ return controlAccessible->ClearHighlight();
}
- else
+ return false;
+}
+
+bool GrabAccessibilityHighlight(Toolkit::Control control)
+{
+ auto* controlAccessible = GetControlImplementation(control).GetAccessibleObject();
+ if(DALI_LIKELY(controlAccessible))
+ {
+ return controlAccessible->GrabHighlight();
+ }
+ return false;
+}
+
+Dali::Accessibility::States GetAccessibilityStates(Toolkit::Control control)
+{
+ auto* controlAccessible = GetControlImplementation(control).GetAccessibleObject();
+ if(DALI_LIKELY(controlAccessible))
{
- controlDataImpl.RemoveLayout();
+ return controlAccessible->GetStates();
}
+ return Dali::Accessibility::States{};
}
-void RequestLayout( Internal::Control& control )
+void NotifyAccessibilityStateChange(Toolkit::Control control, Dali::Accessibility::States states, bool recurse)
{
- Internal::Control::Impl& controlDataImpl = Internal::Control::Impl::Get( control );
- Toolkit::Internal::LayoutItemPtr layoutItem = controlDataImpl.GetLayout();
- if ( layoutItem )
+ auto* controlAccessible = GetControlImplementation(control).GetAccessibleObject();
+ if(DALI_LIKELY(controlAccessible))
{
- layoutItem->RequestLayout();
+ controlAccessible->NotifyAccessibilityStateChange(std::move(states), recurse);
}
}
+bool IsAccessibleCreated(Toolkit::Control control)
+{
+ return GetControlImplementation(control).IsAccessibleCreated();
+}
+
+void EnableCreateAccessible(Toolkit::Control control, bool enable)
+{
+ GetControlImplementation(control).EnableCreateAccessible(enable);
+}
+
+bool IsCreateAccessibleEnabled(Toolkit::Control control)
+{
+ return GetControlImplementation(control).IsCreateAccessibleEnabled();
+}
+
} // namespace DevelControl
} // namespace Toolkit