/*
- * Copyright (c) 2019 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.
#include <dali-toolkit-test-suite-utils.h>
#include <dali-toolkit/dali-toolkit.h>
#include <toolkit-text-utils.h>
+#include <dali/devel-api/events/key-event-devel.h>
#include <dali-toolkit/internal/controls/text-controls/text-field-impl.h>
#include <dali-toolkit/internal/text/text-controller.h>
#include <dali-toolkit/internal/text/text-control-interface.h>
unsigned long timeStamp,
const Dali::KeyEvent::State& keyState )
{
- return Dali::KeyEvent( keyName,
- keyString,
- keyCode,
- keyModifier,
- timeStamp,
- keyState );
+ return DevelKeyEvent::New( keyName, "", keyString, keyCode, keyModifier, timeStamp, keyState, "", "", Device::Class::NONE, Device::Subclass::NONE );
}
} // namespace
END_TEST;
}
+int UtcDaliTextControllerImfPreeditStyleReverse(void)
+{
+ tet_infoline(" UtcDaliTextControllerImfPreeditStyleReverse");
+ ToolkitTestApplication application;
+
+ // Creates a text controller.
+ ControllerPtr controller = Controller::New();
+
+ std::string text;
+ InputMethodContext::EventData imfEvent;
+
+ DALI_TEST_CHECK(controller);
+
+ // Configures the text controller similarly to the text-field.
+ ConfigureTextField(controller);
+
+ InputMethodContext inputMethodContext = InputMethodContext::New();
+
+ // Send PRE_EDIT event
+ imfEvent = InputMethodContext::EventData(InputMethodContext::PRE_EDIT, "Reverse", 0, 7);
+ controller->OnInputMethodContextEvent(inputMethodContext, imfEvent);
+
+ // For coverage, mEditableControlInterface is required.
+ // Creates a temporary text-field to use mEditableControlInterface.
+ TextField field = TextField::New();
+ Toolkit::Internal::TextField& fieldImpl = GetImpl(field);
+ ControllerPtr fieldController = fieldImpl.GetTextController();
+ Controller::Impl& fieldControllerImpl = Controller::Impl::GetImplementation(*fieldController.Get());
+ Controller::Impl& controllerImpl = Controller::Impl::GetImplementation(*controller.Get());
+
+ // For coverage, mEditableControlInterface is required.
+ controllerImpl.mEditableControlInterface = fieldControllerImpl.mEditableControlInterface;
+
+ // Set the preedit style as REVERSE
+ inputMethodContext.SetPreeditStyle(InputMethodContext::PreeditStyle::REVERSE);
+ controller->GetNaturalSize();
+
+ controller->GetText(text);
+ DALI_TEST_EQUALS("Reverse", text, TEST_LOCATION);
+
+ tet_result(TET_PASS);
+ END_TEST;
+}
+
int UtcDaliTextControllerTextPopupButtonTouched(void)
{
tet_infoline(" UtcDaliTextControllerTextPopupButtonTouched");
TextSelectionPopup::CLIPBOARD );
textPopup.EnableButtons( buttonsToEnable );
- Stage::GetCurrent().Add( textPopup );
+ application.GetScene().Add( textPopup );
textPopup.ShowPopup();
// Render and notify
// Sets some text.
controller->SetText( "Hello world" );
+ // When the TextSelectionPopup is active, the controller has focus.
+ controller->KeyboardFocusGainEvent();
+
// Select the whole text.
button = PushButton::DownCast( textPopup.FindChildByName( OPTION_SELECT_ALL ) );
DALI_TEST_CHECK( button );
tet_infoline(" UtcDaliTextControllerSetGetLineSpacingProperty");
ToolkitTestApplication application;
- const Size size( Dali::Stage::GetCurrent().GetSize() );
+ const Size size( application.GetScene().GetSize() );
// single line text
const std::string textSingle("A Quick Brown Fox Jumps Over The Lazy Dog");
// single line, line spacing = 0px
{
const float EXPECTED_SPACING = 0.0f;
- const Vector2 EXPECTED_LAYOUT_SIZE( 342.0f, 19.0f);
- const Vector3 EXPECTED_NATURAL_SIZE( 342.0f, 20.0f, 0.0f );
+ const Vector2 EXPECTED_LAYOUT_SIZE( 349.0f, 19.0f);
+ const Vector3 EXPECTED_NATURAL_SIZE( 350.0f, 20.0f, 0.0f );
controller->SetText(textSingle);
controller->Relayout(size);
// single line, line spacing = 20px
{
const float EXPECTED_SPACING = 20.0f;
- const Vector2 EXPECTED_LAYOUT_SIZE( 342.0f, 19.0f );
- const Vector3 EXPECTED_NATURAL_SIZE( 342.0f, 40.0f, 0.0f );
+ const Vector2 EXPECTED_LAYOUT_SIZE( 349.0f, 19.0f );
+ const Vector3 EXPECTED_NATURAL_SIZE( 350.0f, 40.0f, 0.0f );
controller->SetText(textSingle);
controller->Relayout(size);
// multi-line, line spacing = 0px
{
const float EXPECTED_SPACING = 0.0f;
- const Vector2 EXPECTED_LAYOUT_SIZE( 332.0f, 39.0f );
- const Vector3 EXPECTED_NATURAL_SIZE( 118.0f, 58.0f, 0.0f );
+ const Vector2 EXPECTED_LAYOUT_SIZE( 339.0f, 39.0f );
+ const Vector3 EXPECTED_NATURAL_SIZE( 122.0f, 58.0f, 0.0f );
controller->SetText(textMulti);
controller->Relayout(size);
// multi-line, line spacing = 20px
{
const float EXPECTED_SPACING = 20.0f;
- const Vector2 EXPECTED_LAYOUT_SIZE( 118.0f, 57.0f );
- const Vector3 EXPECTED_NATURAL_SIZE( 118.0f, 118.0f, 0.0f );
+ const Vector2 EXPECTED_LAYOUT_SIZE( 121.0f, 57.0f );
+ const Vector3 EXPECTED_NATURAL_SIZE( 122.0f, 118.0f, 0.0f );
controller->SetText(textMulti);
controller->Relayout(size);
// multi-line, line spacing = 30px
{
const float EXPECTED_SPACING = 30.0f;
- const Vector2 EXPECTED_LAYOUT_SIZE( 118.0f, 117.0f );
- const Vector3 EXPECTED_NATURAL_SIZE( 118.0f, 148.0f, 0.0f );
+ const Vector2 EXPECTED_LAYOUT_SIZE( 121.0f, 117.0f );
+ const Vector3 EXPECTED_NATURAL_SIZE( 122.0f, 148.0f, 0.0f );
controller->SetText(textMulti);
controller->Relayout(size);
mImpl.mOperationsPending = Controller::ALL_OPERATIONS;
// Perform a relayout
- const Size size( Dali::Stage::GetCurrent().GetSize() );
+ const Size size( application.GetScene().GetSize() );
controller->Relayout(size);
tet_result(TET_PASS);
mImpl.mOperationsPending = Controller::NO_OPERATION;
// simulate a key event.
- controller->KeyEvent( GenerateKey( "", "", DALI_KEY_CURSOR_LEFT, 0, 0, Dali::KeyEvent::Down ) );
+ controller->KeyEvent( GenerateKey( "", "", DALI_KEY_CURSOR_LEFT, 0, 0, Dali::KeyEvent::DOWN ) );
// change the input color
const Vector4 newInputColor( 1.0f, 0.0f, 0.0f, 1.0f );
DALI_TEST_EQUALS( Controller::COLOR, static_cast<Controller::OperationsMask>( mImpl.mOperationsPending & Controller::COLOR ), TEST_LOCATION );
// Perform a relayout
- const Size size( Dali::Stage::GetCurrent().GetSize() );
+ const Size size( application.GetScene().GetSize() );
controller->Relayout(size);
tet_result(TET_PASS);
mImpl.mOperationsPending = Controller::NO_OPERATION;
// simulate a key event.
- controller->KeyEvent( GenerateKey( "", "", DALI_KEY_CURSOR_LEFT, 0, 0, Dali::KeyEvent::Down ) );
+ controller->KeyEvent( GenerateKey( "", "", DALI_KEY_CURSOR_LEFT, 0, 0, Dali::KeyEvent::DOWN ) );
// change the input font family
controller->SetInputFontFamily("SamsungOneUI_300");
TEST_LOCATION );
// Perform a relayout
- const Size size( Dali::Stage::GetCurrent().GetSize() );
+ const Size size( application.GetScene().GetSize() );
controller->Relayout(size);
tet_result(TET_PASS);
mImpl.mOperationsPending = Controller::NO_OPERATION;
// simulate a key event.
- controller->KeyEvent( GenerateKey( "", "", DALI_KEY_CURSOR_LEFT, 0, 0, Dali::KeyEvent::Down ) );
+ controller->KeyEvent( GenerateKey( "", "", DALI_KEY_CURSOR_LEFT, 0, 0, Dali::KeyEvent::DOWN ) );
// change the input font weight
controller->SetInputFontWeight( TextAbstraction::FontWeight::BOLD );
TEST_LOCATION );
// Perform a relayout
- const Size size( Dali::Stage::GetCurrent().GetSize() );
+ const Size size( application.GetScene().GetSize() );
controller->Relayout(size);
tet_result(TET_PASS);
mImpl.mOperationsPending = Controller::NO_OPERATION;
// simulate a key event.
- controller->KeyEvent( GenerateKey( "", "", DALI_KEY_CURSOR_LEFT, 0, 0, Dali::KeyEvent::Down ) );
+ controller->KeyEvent( GenerateKey( "", "", DALI_KEY_CURSOR_LEFT, 0, 0, Dali::KeyEvent::DOWN ) );
// change the input font width
controller->SetInputFontWidth( TextAbstraction::FontWidth::EXPANDED );
TEST_LOCATION );
// Perform a relayout
- const Size size( Dali::Stage::GetCurrent().GetSize() );
+ const Size size( application.GetScene().GetSize() );
controller->Relayout(size);
tet_result(TET_PASS);
mImpl.mOperationsPending = Controller::NO_OPERATION;
// simulate a key event.
- controller->KeyEvent( GenerateKey( "", "", DALI_KEY_CURSOR_LEFT, 0, 0, Dali::KeyEvent::Down ) );
+ controller->KeyEvent( GenerateKey( "", "", DALI_KEY_CURSOR_LEFT, 0, 0, Dali::KeyEvent::DOWN ) );
// change the input font slant
controller->SetInputFontSlant( TextAbstraction::FontSlant::ROMAN );
TEST_LOCATION );
// Perform a relayout
- const Size size( Dali::Stage::GetCurrent().GetSize() );
+ const Size size( application.GetScene().GetSize() );
controller->Relayout(size);
tet_result(TET_PASS);
mImpl.mOperationsPending = Controller::NO_OPERATION;
// simulate a key event.
- controller->KeyEvent( GenerateKey( "", "", DALI_KEY_CURSOR_LEFT, 0, 0, Dali::KeyEvent::Down ) );
+ controller->KeyEvent( GenerateKey( "", "", DALI_KEY_CURSOR_LEFT, 0, 0, Dali::KeyEvent::DOWN ) );
// change the input font point size
controller->SetInputFontPointSize( 1.2f );
TEST_LOCATION );
// Perform a relayout
- const Size size( Dali::Stage::GetCurrent().GetSize() );
+ const Size size( application.GetScene().GetSize() );
controller->Relayout(size);
tet_result(TET_PASS);
controller->SelectEvent( 0.f, 0.f, SelectionType::INTERACTIVE );
// Perform a relayout
- const Size size( Dali::Stage::GetCurrent().GetSize() );
+ const Size size( application.GetScene().GetSize() );
controller->Relayout(size);
// Get the implementation of the text controller
controller->GetNaturalSize();
// Simulate a key event to delete text
- controller->KeyEvent( GenerateKey( "", "", DALI_KEY_BACKSPACE, 0, 0, Dali::KeyEvent::Down ) );
+ controller->KeyEvent( GenerateKey( "", "", DALI_KEY_BACKSPACE, 0, 0, Dali::KeyEvent::DOWN ) );
DALI_TEST_EQUALS( EventData::EDITING, mImpl.mEventData->mState, TEST_LOCATION );
// Perform a relayout
- const Size size( Dali::Stage::GetCurrent().GetSize() );
+ const Size size( application.GetScene().GetSize() );
controller->Relayout( size );
tet_result(TET_PASS);
application.Render();
// Perform a relayout
- const Size size( Dali::Stage::GetCurrent().GetSize() );
+ const Size size( application.GetScene().GetSize() );
controller->Relayout(size);
// simulate a key event.
- controller->KeyEvent( GenerateKey( "a", "a", 38, 0, 0, Dali::KeyEvent::Down ) );
+ controller->KeyEvent( GenerateKey( "a", "a", 38, 0, 0, Dali::KeyEvent::DOWN ) );
// change the input font point size
controller->SetInputFontPointSize( 20.f );
END_TEST;
}
+
+int UtcDaliTextControllerDeleteSurroundings(void)
+{
+ tet_infoline(" UtcDaliTextControllerDeleteSurroundings");
+ ToolkitTestApplication application;
+
+ // Creates a text controller.
+ ControllerPtr controller = Controller::New();
+
+ ConfigureTextField( controller );
+
+ // Get the implementation of the text controller
+ Controller::Impl& mImpl = Controller::Impl::GetImplementation( *controller.Get() );
+
+ DALI_TEST_EQUALS( EventData::INACTIVE, mImpl.mEventData->mState, TEST_LOCATION );
+
+ InputMethodContext inputMethodContext = InputMethodContext::New();
+ // Add some pre-edit text, such as Korean
+ InputMethodContext::EventData imfEvent = InputMethodContext::EventData( InputMethodContext::PRE_EDIT, "ㅂㅂㅂ", 0, 3 );
+ controller->OnInputMethodContextEvent( inputMethodContext, imfEvent );
+
+ // Perform a relayout
+ const Size size( application.GetScene().GetSize() );
+
+ application.SendNotification();
+ application.Render();
+
+ controller->Relayout( size );
+
+ // Simulate a key event to delete one text
+ controller->KeyEvent( GenerateKey( "", "", DALI_KEY_BACKSPACE, 0, 0, Dali::KeyEvent::DOWN ) );
+
+ // Send DELETE_SURROUNDING event (Delete All text)
+ imfEvent = InputMethodContext::EventData( InputMethodContext::DELETE_SURROUNDING, "", -2, 2 );
+ controller->OnInputMethodContextEvent( inputMethodContext, imfEvent );
+
+ application.SendNotification();
+ application.Render();
+
+ controller->Relayout( size );
+
+ // simulate a key event to add text
+ controller->KeyEvent( GenerateKey( "ㅇ", "ㅇ", 238, 0, 0, Dali::KeyEvent::DOWN ) );
+ controller->KeyEvent( GenerateKey( "ㅇ", "ㅇ", 238, 0, 0, Dali::KeyEvent::DOWN ) );
+
+ DALI_TEST_EQUALS( EventData::EDITING, mImpl.mEventData->mState, TEST_LOCATION );
+
+ // Force to update the model.
+ controller->GetNaturalSize();
+
+ application.SendNotification();
+ application.Render();
+
+ controller->Relayout( size );
+
+ tet_result(TET_PASS);
+
+ END_TEST;
+}