cda25df74cfb8868f41abfc5a5154729455ac169
[platform/core/uifw/dali-toolkit.git] / dali-toolkit / internal / text / text-editable-control-interface.h
1 #ifndef DALI_TOOLKIT_TEXT_EDITABLE_CONTROL_INTERFACE_H
2 #define DALI_TOOLKIT_TEXT_EDITABLE_CONTROL_INTERFACE_H
3
4 /*
5  * Copyright (c) 2021 Samsung Electronics Co., Ltd.
6  *
7  * Licensed under the Apache License, Version 2.0 (the "License");
8  * you may not use this file except in compliance with the License.
9  * You may obtain a copy of the License at
10  *
11  * http://www.apache.org/licenses/LICENSE-2.0
12  *
13  * Unless required by applicable law or agreed to in writing, software
14  * distributed under the License is distributed on an "AS IS" BASIS,
15  * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
16  * See the License for the specific language governing permissions and
17  * limitations under the License.
18  *
19  */
20
21 // INTERNAL INCLUDES
22 #include <dali-toolkit/internal/text/input-style.h>
23
24 namespace Dali
25 {
26 class Actor;
27
28 namespace Toolkit
29 {
30 namespace Text
31 {
32 /**
33  * @brief An interface that the Text::Controller uses to notify about text changes and add decoration to the text control.
34  */
35 class EditableControlInterface
36 {
37 public:
38   /**
39    * @brief Virtual destructor.
40    */
41   virtual ~EditableControlInterface()
42   {
43   }
44
45   /**
46    * @brief Called to signal that text has been inserted or deleted.
47    *
48    * @param[in] immediate If true, it immediately emits the signal, if false, only emits once the signal when OnRelayout() is called next time.
49    */
50   virtual void TextChanged(bool immediate) = 0;
51
52   /**
53    * @brief Called when the number of characters to be inserted exceeds the maximum limit
54    */
55   virtual void MaxLengthReached() = 0;
56
57   /**
58    * @brief Called to signal that input style has been changed.
59    *
60    * @param[in] inputStyleMask Mask with the bits of the input style that has changed.
61    */
62   virtual void InputStyleChanged(InputStyle::Mask inputStyleMask) = 0;
63
64   /**
65    * @brief Add a decoration.
66    *
67    * @param[in] decoration The actor displaying a decoration.
68    * @param[in] needsClipping Whether the actor needs clipping.
69    */
70   virtual void AddDecoration(Actor& actor, bool needsClipping) = 0;
71
72   /**
73    * @brief Editable status (on/off).
74    *
75    * @return true if it can be edit, else false.
76    */
77   virtual bool IsEditable() const = 0;
78
79   /**
80    * @brief Change the editable status (on/off) .
81    *
82    * @param[in] editable The editable status.
83    */
84   virtual void SetEditable(bool editable) = 0;
85 };
86
87 } // namespace Text
88
89 } // namespace Toolkit
90
91 } // namespace Dali
92
93 #endif // DALI_TOOLKIT_TEXT_EDITABLE_CONTROL_INTERFACE_H