X-Git-Url: http://review.tizen.org/git/?a=blobdiff_plain;f=src%2FTizen.NUI%2Fsrc%2Fpublic%2FBaseComponents%2FTextField.cs;h=1d4d1ae5b90432d3535d8b19df7025a80f5784f8;hb=163d8156dc99b571242d87dcf63e772e4a91bb21;hp=1501cdb8b6201bc81a4688b2244f884b16eb313e;hpb=3fa7211d38b369f7a262cbeeaa4dc566ba35a8fe;p=platform%2Fcore%2Fcsapi%2Ftizenfx.git diff --git a/src/Tizen.NUI/src/public/BaseComponents/TextField.cs b/src/Tizen.NUI/src/public/BaseComponents/TextField.cs index 1501cdb..1d4d1ae 100755 --- a/src/Tizen.NUI/src/public/BaseComponents/TextField.cs +++ b/src/Tizen.NUI/src/public/BaseComponents/TextField.cs @@ -1,5 +1,5 @@ /* - * 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. @@ -21,6 +21,7 @@ using System; using System.Globalization; using System.ComponentModel; using Tizen.NUI.Binding; +using Tizen.NUI.Text; namespace Tizen.NUI.BaseComponents { @@ -35,9 +36,9 @@ namespace Tizen.NUI.BaseComponents private string textFieldPlaceHolderTextFocusedSid = null; private bool systemlangTextFlag = false; private InputMethodContext inputMethodCotext = null; - private TextFieldSelectorData selectorData; private float fontSizeScale = 1.0f; private bool hasFontSizeChangedCallback = false; + private bool isSettingTextInCSharp = false; static TextField() { } @@ -63,7 +64,7 @@ namespace Tizen.NUI.BaseComponents } /// - /// Get attribues, it is abstract function and must be override. + /// Get attributes, it is abstract function and must be override. /// [EditorBrowsable(EditorBrowsableState.Never)] protected override ViewStyle CreateViewStyle() @@ -77,6 +78,8 @@ namespace Tizen.NUI.BaseComponents { SetVisible(false); } + + TextChanged += TextEditorTextChanged; } internal TextField(global::System.IntPtr cPtr, bool cMemoryOwn, bool shown = true) : base(cPtr, cMemoryOwn, null) @@ -85,6 +88,8 @@ namespace Tizen.NUI.BaseComponents { SetVisible(false); } + + TextChanged += TextEditorTextChanged; } internal TextField(TextField handle, bool shown = true) : this(Interop.TextField.NewTextField(TextField.getCPtr(handle)), true) @@ -95,6 +100,8 @@ namespace Tizen.NUI.BaseComponents { SetVisible(false); } + + TextChanged += TextEditorTextChanged; } internal enum ExceedPolicyType @@ -119,7 +126,6 @@ namespace Tizen.NUI.BaseComponents } set { - selectorData?.TranslatableText?.Reset(this); SetValue(TranslatableTextProperty, value); } } @@ -158,7 +164,6 @@ namespace Tizen.NUI.BaseComponents set { SetValue(TranslatablePlaceholderTextProperty, value); - selectorData?.TranslatablePlaceholderText?.Reset(this); } } private string translatablePlaceholderText @@ -197,7 +202,6 @@ namespace Tizen.NUI.BaseComponents set { SetValue(TranslatablePlaceholderTextFocusedProperty, value); - selectorData?.TranslatablePlaceholderTextFocused?.Reset(this); } } private string translatablePlaceholderTextFocused @@ -230,8 +234,7 @@ namespace Tizen.NUI.BaseComponents } set { - SetValueAndForceSendChangeSignal(TextProperty, value); - selectorData?.Text?.Reset(this); + SetValue(TextProperty, value); NotifyPropertyChanged(); } } @@ -283,15 +286,21 @@ namespace Tizen.NUI.BaseComponents set { SetValue(FontFamilyProperty, value); - selectorData?.FontFamily?.Reset(this); NotifyPropertyChanged(); } } /// /// The FontStyle property. + /// The fontStyle map contains the following keys :
+ /// + /// width (string)The width key defines occupied by each glyph. (values: ultraCondensed, extraCondensed, condensed, semiCondensed, normal, semiExpanded, expanded, extraExpanded, ultraExpanded) + /// weight (string)The weight key defines the thickness or darkness of the glyphs. (values: thin, ultraLight, extraLight, light, demiLight, semiLight, book, normal, regular, medium, demiBold, semiBold, bold, ultraBold, extraBold, black, heavy, extraBlack) + /// slant (string)The slant key defines whether to use italics. (values: normal, roman, italic, oblique) + /// ///
/// 3 + [System.Diagnostics.CodeAnalysis.SuppressMessage("Naming", "CA1721: Property names should not match get methods")] public PropertyMap FontStyle { get @@ -306,6 +315,42 @@ namespace Tizen.NUI.BaseComponents } /// + /// Set FontStyle to TextField.
+ ///
+ /// The FontStyle + /// + /// SetFontStyle specifies the requested font style through .
+ ///
+ /// + /// The following example demonstrates how to use the SetFontStyle method. + /// + /// var fontStyle = new Tizen.NUI.Text.FontStyle(); + /// fontStyle.Width = FontWidthType.Expanded; + /// fontStyle.Weight = FontWeightType.Bold; + /// fontStyle.Slant = FontSlantType.Italic; + /// field.SetFontStyle(fontStyle); + /// + /// + [EditorBrowsable(EditorBrowsableState.Never)] + public void SetFontStyle(FontStyle fontStyle) + { + SetValue(FontStyleProperty, TextUtils.GetFontStyleMap(fontStyle)); + } + + /// + /// Get FontStyle from TextField.
+ ///
+ /// The FontStyle + /// + /// + /// + [EditorBrowsable(EditorBrowsableState.Never)] + public FontStyle GetFontStyle() + { + return TextUtils.GetFontStyleStruct((PropertyMap)GetValue(FontStyleProperty)); + } + + /// /// The PointSize property. /// /// 3 @@ -318,7 +363,6 @@ namespace Tizen.NUI.BaseComponents set { SetValue(PointSizeProperty, value); - selectorData?.PointSize?.Reset(this); NotifyPropertyChanged(); } } @@ -409,7 +453,6 @@ namespace Tizen.NUI.BaseComponents set { SetValue(TextColorProperty, value); - selectorData?.TextColor?.Reset(this); NotifyPropertyChanged(); } } @@ -431,7 +474,6 @@ namespace Tizen.NUI.BaseComponents set { SetValue(PlaceholderTextColorProperty, value); - selectorData?.PlaceholderTextColor?.Reset(this); NotifyPropertyChanged(); } } @@ -509,7 +551,6 @@ namespace Tizen.NUI.BaseComponents set { SetValue(PrimaryCursorColorProperty, value); - selectorData?.PrimaryCursorColor?.Reset(this); NotifyPropertyChanged(); } } @@ -673,6 +714,10 @@ namespace Tizen.NUI.BaseComponents /// /// The SelectionHandleImageLeft property. + /// The selectionHandleImageLeft map contains the following key :
+ /// + /// filename (string)The path of image file + /// ///
/// 3 public PropertyMap SelectionHandleImageLeft @@ -690,6 +735,10 @@ namespace Tizen.NUI.BaseComponents /// /// The SelectionHandleImageRight property. + /// The selectionHandleImageRight map contains the following key :
+ /// + /// filename (string)The path of image file + /// ///
/// 3 public PropertyMap SelectionHandleImageRight @@ -706,7 +755,54 @@ namespace Tizen.NUI.BaseComponents } /// + /// Set SelectionHandleImage to TextField.
+ ///
+ /// The SelectionHandleImage + /// + /// SetSelectionHandleImage specifies the display image used for the selection handle through .
+ ///
+ /// + /// The following example demonstrates how to use the SetSelectionHandleImage method. + /// + /// var selectionHandleImage = new Tizen.NUI.Text.SelectionHandleImage(); + /// selectionHandleImage.LeftImageUrl = "handle_downleft.png"; + /// selectionHandleImage.RightImageUrl = "handle_downright.png"; + /// field.SetSelectionHandleImage(selectionHandleImage); + /// + /// + [EditorBrowsable(EditorBrowsableState.Never)] + public void SetSelectionHandleImage(SelectionHandleImage selectionHandleImage) + { + if (!String.IsNullOrEmpty(selectionHandleImage.LeftImageUrl)) + { + SetValue(SelectionHandleImageLeftProperty, TextUtils.GetFileNameMap(selectionHandleImage.LeftImageUrl)); + } + + if (!String.IsNullOrEmpty(selectionHandleImage.RightImageUrl)) + { + SetValue(SelectionHandleImageRightProperty, TextUtils.GetFileNameMap(selectionHandleImage.RightImageUrl)); + } + } + + /// + /// Get SelectionHandleImage from TextField.
+ ///
+ /// The SelectionHandleImage + /// + /// + /// + [EditorBrowsable(EditorBrowsableState.Never)] + public SelectionHandleImage GetSelectionHandleImage() + { + return TextUtils.GetSelectionHandleImageStruct((PropertyMap)GetValue(SelectionHandleImageLeftProperty), (PropertyMap)GetValue(SelectionHandleImageRightProperty)); + } + + /// /// The SelectionHandlePressedImageLeft property. + /// The selectionHandlePressedImageLeft map contains the following key :
+ /// + /// filename (string)The path of image file + /// ///
/// 3 public PropertyMap SelectionHandlePressedImageLeft @@ -724,6 +820,10 @@ namespace Tizen.NUI.BaseComponents /// /// The SelectionHandlePressedImageRight property. + /// The selectionHandlePressedImageRight map contains the following key :
+ /// + /// filename (string)The path of image file + /// ///
/// 3 public PropertyMap SelectionHandlePressedImageRight @@ -740,7 +840,54 @@ namespace Tizen.NUI.BaseComponents } /// + /// Set SelectionHandlePressedImage to TextField.
+ ///
+ /// The SelectionHandleImage + /// + /// SetSelectionHandlePressedImage specifies the display image used for the selection handle through .
+ ///
+ /// + /// The following example demonstrates how to use the SetSelectionHandlePressedImage method. + /// + /// var selectionHandlePressedImage = new Tizen.NUI.Text.SelectionHandleImage(); + /// selectionHandlePressedImage.LeftImageUrl = "handle_pressed_downleft.png"; + /// selectionHandlePressedImage.RightImageUrl = "handle_pressed_downright.png"; + /// field.SetSelectionHandlePressedImage(selectionHandlePressedImage); + /// + /// + [EditorBrowsable(EditorBrowsableState.Never)] + public void SetSelectionHandlePressedImage(SelectionHandleImage selectionHandlePressedImage) + { + if (!String.IsNullOrEmpty(selectionHandlePressedImage.LeftImageUrl)) + { + SetValue(SelectionHandlePressedImageLeftProperty, TextUtils.GetFileNameMap(selectionHandlePressedImage.LeftImageUrl)); + } + + if (!String.IsNullOrEmpty(selectionHandlePressedImage.RightImageUrl)) + { + SetValue(SelectionHandlePressedImageRightProperty, TextUtils.GetFileNameMap(selectionHandlePressedImage.RightImageUrl)); + } + } + + /// + /// Get SelectionHandlePressedImage from TextField.
+ ///
+ /// The SelectionHandlePressedImage + /// + /// + /// + [EditorBrowsable(EditorBrowsableState.Never)] + public SelectionHandleImage GetSelectionHandlePressedImage() + { + return TextUtils.GetSelectionHandleImageStruct((PropertyMap)GetValue(SelectionHandlePressedImageLeftProperty), (PropertyMap)GetValue(SelectionHandlePressedImageRightProperty)); + } + + /// /// The SelectionHandleMarkerImageLeft property. + /// The selectionHandleMarkerImageLeft map contains the following key :
+ /// + /// filename (string)The path of image file + /// ///
/// 3 public PropertyMap SelectionHandleMarkerImageLeft @@ -758,6 +905,10 @@ namespace Tizen.NUI.BaseComponents /// /// The SelectionHandleMarkerImageRight property. + /// The selectionHandleMarkerImageRight map contains the following key :
+ /// + /// filename (string)The path of image file + /// ///
/// 3 public PropertyMap SelectionHandleMarkerImageRight @@ -774,6 +925,49 @@ namespace Tizen.NUI.BaseComponents } /// + /// Set SelectionHandleMarkerImage to TextField.
+ ///
+ /// The SelectionHandleImage + /// + /// SetSelectionHandleMarkerImage specifies the display image used for the selection handle through .
+ ///
+ /// + /// The following example demonstrates how to use the SetSelectionHandleMarkerImage method. + /// + /// var selectionHandleMarkerImage = new Tizen.NUI.Text.SelectionHandleImage(); + /// selectionHandleMarkerImage.LeftImageUrl = "handle_pressed_downleft.png"; + /// selectionHandleMarkerImage.RightImageUrl = "handle_pressed_downright.png"; + /// field.SetSelectionHandleMarkerImage(selectionHandleMarkerImage); + /// + /// + [EditorBrowsable(EditorBrowsableState.Never)] + public void SetSelectionHandleMarkerImage(SelectionHandleImage selectionHandleMarkerImage) + { + if (!String.IsNullOrEmpty(selectionHandleMarkerImage.LeftImageUrl)) + { + SetValue(SelectionHandleMarkerImageLeftProperty, TextUtils.GetFileNameMap(selectionHandleMarkerImage.LeftImageUrl)); + } + + if (!String.IsNullOrEmpty(selectionHandleMarkerImage.RightImageUrl)) + { + SetValue(SelectionHandleMarkerImageRightProperty, TextUtils.GetFileNameMap(selectionHandleMarkerImage.RightImageUrl)); + } + } + + /// + /// Get SelectionHandleMarkerImage from TextField.
+ ///
+ /// The SelectionHandleMarkerImage + /// + /// + /// + [EditorBrowsable(EditorBrowsableState.Never)] + public SelectionHandleImage GetSelectionHandleMarkerImage() + { + return TextUtils.GetSelectionHandleImageStruct((PropertyMap)GetValue(SelectionHandleMarkerImageLeftProperty), (PropertyMap)GetValue(SelectionHandleMarkerImageRightProperty)); + } + + /// /// The SelectionHighlightColor property. /// /// @@ -818,6 +1012,20 @@ namespace Tizen.NUI.BaseComponents /// /// The InputMethodSettings property. /// + /// + /// is a class encapsulating the input method map. Please use the class for this property. + /// + /// + /// The following example demonstrates how to set the InputMethodSettings property. + /// + /// InputMethod method = new InputMethod(); + /// method.PanelLayout = InputMethod.PanelLayoutType.Normal; + /// method.ActionButton = InputMethod.ActionButtonTitleType.Default; + /// method.AutoCapital = InputMethod.AutoCapitalType.Word; + /// method.Variation = 1; + /// textField.InputMethodSettings = method.OutputMap; + /// + /// /// 3 public PropertyMap InputMethodSettings { @@ -889,8 +1097,15 @@ namespace Tizen.NUI.BaseComponents /// /// The InputFontStyle property. + /// The inputFontStyle map contains the following keys :
+ /// + /// width (string)The width key defines occupied by each glyph. (values: ultraCondensed, extraCondensed, condensed, semiCondensed, normal, semiExpanded, expanded, extraExpanded, ultraExpanded) + /// weight (string)The weight key defines the thickness or darkness of the glyphs. (values: thin, ultraLight, extraLight, light, demiLight, semiLight, book, normal, regular, medium, demiBold, semiBold, bold, ultraBold, extraBold, black, heavy, extraBlack) + /// slant (string)The slant key defines whether to use italics. (values: normal, roman, italic, oblique) + /// ///
/// 3 + [System.Diagnostics.CodeAnalysis.SuppressMessage("Naming", "CA1721: Property names should not match get methods")] public PropertyMap InputFontStyle { get @@ -905,6 +1120,42 @@ namespace Tizen.NUI.BaseComponents } /// + /// Set InputFontStyle to TextField.
+ ///
+ /// The FontStyle + /// + /// SetInputFontStyle specifies the requested font style for new input text through .
+ ///
+ /// + /// The following example demonstrates how to use the SetInputFontStyle method. + /// + /// var fontStyle = new Tizen.NUI.Text.FontStyle(); + /// fontStyle.Width = FontWidthType.Expanded; + /// fontStyle.Weight = FontWeightType.Bold; + /// fontStyle.Slant = FontSlantType.Italic; + /// field.SetInputFontStyle(fontStyle); + /// + /// + [EditorBrowsable(EditorBrowsableState.Never)] + public void SetInputFontStyle(FontStyle fontStyle) + { + SetValue(InputFontStyleProperty, TextUtils.GetFontStyleMap(fontStyle)); + } + + /// + /// Get InputFontStyle from TextField.
+ ///
+ /// The FontStyle + /// + /// + /// + [EditorBrowsable(EditorBrowsableState.Never)] + public FontStyle GetInputFontStyle() + { + return TextUtils.GetFontStyleStruct((PropertyMap)GetValue(InputFontStyleProperty)); + } + + /// /// The InputPointSize property. /// /// 3 @@ -923,8 +1174,15 @@ namespace Tizen.NUI.BaseComponents /// /// The Underline property. + /// The underline map contains the following keys :
+ /// + /// enable (bool)Whether the underline is enabled (the default value is false) + /// color (Color)The color of the underline (If not provided then the color of the text is used) + /// height (float)The height in pixels of the underline (the default value is 1.f) + /// ///
/// 3 + [System.Diagnostics.CodeAnalysis.SuppressMessage("Naming", "CA1721: Property names should not match get methods")] public PropertyMap Underline { get @@ -939,6 +1197,42 @@ namespace Tizen.NUI.BaseComponents } /// + /// Set Underline to TextField.
+ ///
+ /// The Underline + /// + /// SetUnderline specifies the underline of the text through .
+ ///
+ /// + /// The following example demonstrates how to use the SetUnderline method. + /// + /// var underline = new Tizen.NUI.Text.Underline(); + /// underline.Enable = true; + /// underline.Color = new Color("#3498DB"); + /// underline.Height = 2.0f; + /// field.SetUnderline(underline); + /// + /// + [EditorBrowsable(EditorBrowsableState.Never)] + public void SetUnderline(Underline underline) + { + SetValue(UnderlineProperty, TextUtils.GetUnderlineMap(underline)); + } + + /// + /// Get Underline from TextField.
+ ///
+ /// The Underline + /// + /// + /// + [EditorBrowsable(EditorBrowsableState.Never)] + public Underline GetUnderline() + { + return TextUtils.GetUnderlineStruct((PropertyMap)GetValue(UnderlineProperty)); + } + + /// /// The InputUnderline property. /// /// 3 @@ -957,8 +1251,15 @@ namespace Tizen.NUI.BaseComponents /// /// The Shadow property. + /// The shadow map contains the following keys :
+ /// + /// color (Color)The color of the shadow (the default color is Color.Black) + /// offset (Vector2)The offset in pixels of the shadow (If not provided then the shadow is not enabled) + /// blurRadius (float)The radius of the Gaussian blur for the soft shadow (If not provided then the soft shadow is not enabled) + /// ///
/// 3 + [System.Diagnostics.CodeAnalysis.SuppressMessage("Naming", "CA1721: Property names should not match get methods")] public PropertyMap Shadow { get @@ -973,6 +1274,41 @@ namespace Tizen.NUI.BaseComponents } /// + /// Set Shadow to TextField.
+ ///
+ /// The Shadow + /// + /// SetShadow specifies the shadow of the text through .
+ ///
+ /// + /// The following example demonstrates how to use the SetShadow method. + /// + /// var shadow = new Tizen.NUI.Text.Shadow(); + /// shadow.Offset = new Vector2(3, 3); + /// shadow.Color = new Color("#F1C40F"); + /// field.SetShadow(shadow); + /// + /// + [EditorBrowsable(EditorBrowsableState.Never)] + public void SetShadow(Tizen.NUI.Text.Shadow shadow) + { + SetValue(ShadowProperty, TextUtils.GetShadowMap(shadow)); + } + + /// + /// Get Shadow from TextField.
+ ///
+ /// The Shadow + /// + /// + /// + [EditorBrowsable(EditorBrowsableState.Never)] + public Tizen.NUI.Text.Shadow GetShadow() + { + return TextUtils.GetShadowStruct((PropertyMap)GetValue(ShadowProperty)); + } + + /// /// The InputShadow property. /// /// 3 @@ -1025,8 +1361,14 @@ namespace Tizen.NUI.BaseComponents /// /// The Outline property. + /// The outline map contains the following keys :
+ /// + /// color (Color)The color of the outline (the default color is Color.White) + /// width (float)The width in pixels of the outline (If not provided then the outline is not enabled) + /// ///
/// 3 + [System.Diagnostics.CodeAnalysis.SuppressMessage("Naming", "CA1721: Property names should not match get methods")] public PropertyMap Outline { get @@ -1041,6 +1383,41 @@ namespace Tizen.NUI.BaseComponents } /// + /// Set Outline to TextField.
+ ///
+ /// The Outline + /// + /// SetOutline specifies the outline of the text through .
+ ///
+ /// + /// The following example demonstrates how to use the SetOutline method. + /// + /// var outline = new Tizen.NUI.Text.Outline(); + /// outline.Width = 2.0f; + /// outline.Color = new Color("#45B39D"); + /// field.SetOutline(outline); + /// + /// + [EditorBrowsable(EditorBrowsableState.Never)] + public void SetOutline(Outline outline) + { + SetValue(OutlineProperty, TextUtils.GetOutlineMap(outline)); + } + + /// + /// Get Outline from TextField.
+ ///
+ /// The Outline + /// + /// + /// + [EditorBrowsable(EditorBrowsableState.Never)] + public Outline GetOutline() + { + return TextUtils.GetOutlineStruct((PropertyMap)GetValue(OutlineProperty)); + } + + /// /// The InputOutline property. /// /// 3 @@ -1059,7 +1436,27 @@ namespace Tizen.NUI.BaseComponents /// /// The HiddenInputSettings property. + /// The hiddenInputSettings map contains the following keys :
+ /// + /// HiddenInputProperty.Mode (int)The mode for input text display (Use HiddenInputModeType) + /// HiddenInputProperty.SubstituteCharacter (int)All input characters are substituted by this character + /// HiddenInputProperty.SubstituteCount (int)Length of text to show or hide, available when HideCount/ShowCount mode is used + /// HiddenInputProperty.ShowLastCharacterDuration (int)Hide last character after this duration, available when ShowLastCharacter mode + /// ///
+ /// + /// See and for a detailed description. + /// + /// + /// The following example demonstrates how to set the HiddenInputSettings property. + /// + /// PropertyMap map = new PropertyMap(); + /// map.Add(HiddenInputProperty.Mode, new PropertyValue((int)HiddenInputModeType.ShowLastCharacter)); + /// map.Add(HiddenInputProperty.ShowLastCharacterDuration, new PropertyValue(500)); + /// map.Add(HiddenInputProperty.SubstituteCharacter, new PropertyValue(0x2A)); + /// textField.HiddenInputSettings = map; + /// + /// /// 3 public Tizen.NUI.PropertyMap HiddenInputSettings { @@ -1075,6 +1472,43 @@ namespace Tizen.NUI.BaseComponents } /// + /// Set HiddenInput to TextField.
+ ///
+ /// The HiddenInput + /// + /// SetHiddenInput specifies the requested font style through .
+ ///
+ /// + /// The following example demonstrates how to use the SetHiddenInput method. + /// + /// var hiddenInput = new Tizen.NUI.Text.HiddenInput(); + /// hiddenInput.Mode = HiddenInputModeType.ShowLastCharacter; + /// hiddenInput.SubstituteCharacter = '★'; + /// hiddenInput.SubstituteCount = 0; + /// hiddenInput.ShowLastCharacterDuration = 1000; + /// field.SetHiddenInput(hiddenInput); + /// + /// + [EditorBrowsable(EditorBrowsableState.Never)] + public void SetHiddenInput(HiddenInput hiddenInput) + { + SetValue(HiddenInputSettingsProperty, TextUtils.GetHiddenInputMap(hiddenInput)); + } + + /// + /// Get HiddenInput from TextField.
+ ///
+ /// The HiddenInput + /// + /// + /// + [EditorBrowsable(EditorBrowsableState.Never)] + public HiddenInput GetHiddenInput() + { + return TextUtils.GetHiddenInputStruct((PropertyMap)GetValue(HiddenInputSettingsProperty)); + } + + /// /// The PixelSize property. /// /// 3 @@ -1087,7 +1521,6 @@ namespace Tizen.NUI.BaseComponents set { SetValue(PixelSizeProperty, value); - selectorData?.PixelSize?.Reset(this); NotifyPropertyChanged(); } } @@ -1148,11 +1581,12 @@ namespace Tizen.NUI.BaseComponents } /// - /// The Selected Text property. + /// The portion of the text that has been selected by the user. /// - /// 8 - /// This will be public opened in tizen_6.0 after ACR done, Before ACR, need to be hidden as inhouse API. - [EditorBrowsable(EditorBrowsableState.Never)] + /// + /// Empty string when nothing is selected. + /// + /// 9 public string SelectedText { get @@ -1166,9 +1600,10 @@ namespace Tizen.NUI.BaseComponents /// /// The start index for selection. /// - /// 8 - /// This will be public opened in tizen_6.0 after ACR done, Before ACR, need to be hidden as inhouse API. - [EditorBrowsable(EditorBrowsableState.Never)] + /// + /// When there is no selection, the index is current cursor position. + /// + /// 9 public int SelectedTextStart { get @@ -1177,19 +1612,15 @@ namespace Tizen.NUI.BaseComponents GetProperty(TextField.Property.SelectedTextStart).Get(out temp); return temp; } - set - { - SetProperty(TextField.Property.SelectedTextStart, new PropertyValue(value)); - NotifyPropertyChanged(); - } } /// /// The end index for selection. /// - /// 8 - /// This will be public opened in tizen_6.0 after ACR done, Before ACR, need to be hidden as inhouse API. - [EditorBrowsable(EditorBrowsableState.Never)] + /// + /// When there is no selection, the index is current cursor position. + /// + /// 9 public int SelectedTextEnd { get @@ -1198,11 +1629,6 @@ namespace Tizen.NUI.BaseComponents GetProperty(TextField.Property.SelectedTextEnd).Get(out temp); return temp; } - set - { - SetProperty(TextField.Property.SelectedTextEnd, new PropertyValue(value)); - NotifyPropertyChanged(); - } } /// @@ -1252,8 +1678,103 @@ namespace Tizen.NUI.BaseComponents } /// + /// The GrabHandleColor property. + /// + /// + /// The property cascade chaining set is possible. For example, this (textField.GrabHandleColor.X = 0.1f;) is possible. + /// + [EditorBrowsable(EditorBrowsableState.Never)] + public Color GrabHandleColor + { + get + { + Color temp = (Color)GetValue(GrabHandleColorProperty); + return new Color(OnGrabHandleColorChanged, temp.R, temp.G, temp.B, temp.A); + } + set + { + SetValue(GrabHandleColorProperty, value); + NotifyPropertyChanged(); + } + } + + /// + /// The ellipsis position of the text. + /// Specifies which portion of the text should be replaced with an ellipsis when the text size exceeds the layout size.
+ ///
+ /// 9 + public EllipsisPosition EllipsisPosition + { + get + { + return (EllipsisPosition)GetValue(EllipsisPositionProperty); + } + set + { + SetValue(EllipsisPositionProperty, value); + NotifyPropertyChanged(); + } + } + + /// + /// Set InputFilter to TextField.
+ ///
+ /// The InputFilter + /// + /// filters input based on regular expressions.
+ /// Users can set the Accepted or Rejected regular expression set, or both.
+ /// If both are used, Rejected has higher priority.
+ /// The character set must follow the regular expression rules.
+ /// Behaviour can not be guaranteed for incorrect grammars.
+ /// Refer the link below for detailed rules.
+ /// The functions in std::regex library use the ECMAScript grammar:
+ /// http://cplusplus.com/reference/regex/ECMAScript/
+ /// InputFiltered signal is emitted when the input is filtered by InputFilter
+ /// See , and for a detailed description.
+ ///
+ /// + /// The following example demonstrates how to use the SetInputFilter method. + /// + /// var inputFilter = new Tizen.NUI.Text.InputFilter(); + /// inputFilter.Accepted = @"[\d]"; // accept whole digits + /// inputFilter.Rejected = "[0-3]"; // reject 0, 1, 2, 3 + /// field.SetInputFilter(inputFilter); // acceptable inputs are 4, 5, 6, 7, 8, 9 + /// + /// + [EditorBrowsable(EditorBrowsableState.Never)] + public void SetInputFilter(InputFilter inputFilter) + { + SetProperty(TextField.Property.InputFilter, new PropertyValue(TextUtils.GetInputFilterMap(inputFilter))); + } + + /// + /// Get InputFilter from TextField.
+ ///
+ /// The InputFilter + /// + /// + /// + [EditorBrowsable(EditorBrowsableState.Never)] + public InputFilter GetInputFilter() + { + var map = new PropertyMap(); + GetProperty(TextField.Property.InputFilter).Get(map); + return TextUtils.GetInputFilterStruct(map); + } + + /// /// The Placeholder property. - /// Gets or sets the placeholder: text, color, font family, font style, point size, and pixel size. + /// The placeholder map contains the following keys :
+ /// + /// text (string)The text to display when the TextField is empty and inactive + /// textFocused (string)The text to display when the placeholder has focus + /// color (Color)The color of the placeholder text + /// fontFamily (string)The fontFamily of the placeholder text + /// fontStyle (PropertyMap)The fontStyle of the placeholder text + /// pointSize (float)The pointSize of the placeholder text + /// pixelSize (float)The pixelSize of the placeholder text + /// ellipsis (bool)The ellipsis of the placeholder text + /// ///
/// /// The following example demonstrates how to set the Placeholder property. @@ -1276,11 +1797,81 @@ namespace Tizen.NUI.BaseComponents /// /// /// 3 + [System.Diagnostics.CodeAnalysis.SuppressMessage("Naming", "CA1721: Property names should not match get methods")] public Tizen.NUI.PropertyMap Placeholder { get { - return (PropertyMap)GetValue(PlaceholderProperty); + PropertyMap map = (PropertyMap)GetValue(PlaceholderProperty); + PropertyValue value = null; + + // text + value = map.Find(0); + if (null != value) + { + value.Get(out string text); + map.Add("text", new PropertyValue(text)); + } + + // textFocused + value = map.Find(1); + if (null != value) + { + value.Get(out string textFocused); + map.Add("textFocused", new PropertyValue(textFocused)); + } + + // color + value = map.Find(2); + if (null != value) + { + Color color = new Color(); + value.Get(color); + map.Add("color", new PropertyValue(color)); + } + + // fontFamily + value = map.Find(3); + if (null != value) + { + value.Get(out string fontFamily); + map.Add("fontFamily", new PropertyValue(fontFamily)); + } + + // fontStyle + value = map.Find(4); + if (null != value) + { + PropertyMap fontStyle = new PropertyMap(); + value.Get(fontStyle); + map.Add("fontStyle", new PropertyValue(fontStyle)); + } + + // pointSize + value = map.Find(5); + if (null != value) + { + value.Get(out float pointSize); + map.Add("pointSize", new PropertyValue(pointSize)); + } + + // pixelSize + value = map.Find(6); + if (null != value) + { + value.Get(out float pixelSize); + map.Add("pixelSize", new PropertyValue(pixelSize)); + } + + // ellipsis + value = map.Find(7); + if (null != value) + { + value.Get(out bool ellipsis); + map.Add("ellipsis", new PropertyValue(ellipsis)); + } + + return map; } set { @@ -1290,6 +1881,52 @@ namespace Tizen.NUI.BaseComponents } /// + /// Set Placeholder to TextField.
+ ///
+ /// The Placeholder + /// + /// SetPlaceholder specifies the attributes of the placeholder property through .
+ ///
+ /// + /// The following example demonstrates how to use the SetPlaceholder method. + /// + /// var placeholder = new Tizen.NUI.Text.Placeholder(); + /// placeholder.Text = "placeholder text"; + /// placeholder.TextFocused = "placeholder textFocused"; + /// placeholder.Color = new Color("#45B39D"); + /// placeholder.FontFamily = "BreezeSans"; + /// placeholder.FontStyle = new Tizen.NUI.Text.FontStyle() + /// { + /// Width = FontWidthType.Expanded, + /// Weight = FontWeightType.ExtraLight, + /// Slant = FontSlantType.Italic, + /// }; + /// placeholder.PointSize = 25.0f; + /// //placeholder.PixelSize = 50.0f; + /// placeholder.Ellipsis = true; + /// field.SetPlaceholder(placeholder); + /// + /// + [EditorBrowsable(EditorBrowsableState.Never)] + public void SetPlaceholder(Placeholder placeholder) + { + SetValue(PlaceholderProperty, TextUtils.GetPlaceholderMap(placeholder)); + } + + /// + /// Get Placeholder from TextField.
+ ///
+ /// The Placeholder + /// + /// + /// + [EditorBrowsable(EditorBrowsableState.Never)] + public Placeholder GetPlaceholder() + { + return TextUtils.GetPlaceholderStruct((PropertyMap)GetValue(PlaceholderProperty)); + } + + /// /// The Ellipsis property.
/// Enable or disable the ellipsis.
/// Placeholder PropertyMap is used to add ellipsis to placeholder text. @@ -1390,30 +2027,6 @@ namespace Tizen.NUI.BaseComponents } } - /// Only used by the IL of xaml, will never changed to not hidden. - [EditorBrowsable(EditorBrowsableState.Never)] - public override bool IsCreateByXaml - { - get - { - return base.IsCreateByXaml; - } - set - { - base.IsCreateByXaml = value; - - if (value == true) - { - this.TextChanged += (obj, e) => - { - this.Text = e.TextField.Text; - }; - } - } - } - - private TextFieldSelectorData EnsureSelectorData() => selectorData ?? (selectorData = new TextFieldSelectorData()); - /// /// Get the InputMethodContext instance. /// @@ -1433,9 +2046,7 @@ namespace Tizen.NUI.BaseComponents /// /// Select the whole text. /// - /// 6 - /// This will be released at Tizen.NET API Level 5.5, so currently this would be used as inhouse API. - [EditorBrowsable(EditorBrowsableState.Never)] + /// 9 public void SelectWholeText() { Interop.TextField.SelectWholeText(SwigCPtr); @@ -1443,20 +2054,35 @@ namespace Tizen.NUI.BaseComponents } /// - /// Clear selection of the text. + /// Select text from start to end index.
+ /// The index is valid when 0 or positive. ///
- /// 8 - /// This will be public opened in tizen_6.0 after ACR done, Before ACR, need to be hidden as inhouse API. - [EditorBrowsable(EditorBrowsableState.Never)] - public void SelectNone() + /// The start index for selection. + /// The end index for selection. + /// + /// If the end index exceeds the maximum value, it is set to the length of the text. + /// + /// 9 + public void SelectText(int start, int end) { - _ = Interop.TextField.SelectNone(SwigCPtr); + if (start < 0) + throw new global::System.ArgumentOutOfRangeException(nameof(start), "Value is less than zero"); + if (end < 0) + throw new global::System.ArgumentOutOfRangeException(nameof(end), "Value is less than zero"); + + Interop.TextField.SelectText(SwigCPtr, (uint)start, (uint)end); if (NDalicPINVOKE.SWIGPendingException.Pending) throw NDalicPINVOKE.SWIGPendingException.Retrieve(); } - internal static global::System.Runtime.InteropServices.HandleRef getCPtr(TextField obj) + /// + /// Clear selection of the text.
+ /// Valid when selection is activate. + ///
+ /// 9 + public void SelectNone() { - return (obj == null) ? new global::System.Runtime.InteropServices.HandleRef(null, global::System.IntPtr.Zero) : obj.SwigCPtr; + _ = Interop.TextField.SelectNone(SwigCPtr); + if (NDalicPINVOKE.SWIGPendingException.Pending) throw NDalicPINVOKE.SWIGPendingException.Retrieve(); } internal SWIGTYPE_p_Dali__SignalT_void_fDali__Toolkit__TextField_Dali__Toolkit__TextField__InputStyle__MaskF_t InputStyleChangedSignal() @@ -1490,7 +2116,6 @@ namespace Tizen.NUI.BaseComponents //Called by User //Release your own managed resources here. //You should release all of your own disposable objects here. - selectorData?.Reset(this); } //Release your own unmanaged resources here. @@ -1498,17 +2123,34 @@ namespace Tizen.NUI.BaseComponents //because the execution order of Finalizes is non-deterministic. if (this.HasBody()) { + if (textFieldCursorPositionChangedCallbackDelegate != null) + { + this.CursorPositionChangedSignal().Disconnect(textFieldCursorPositionChangedCallbackDelegate); + } + if (textFieldMaxLengthReachedCallbackDelegate != null) { this.MaxLengthReachedSignal().Disconnect(textFieldMaxLengthReachedCallbackDelegate); } + if (textFieldSelectionClearedCallbackDelegate != null) + { + this.SelectionClearedSignal().Disconnect(textFieldSelectionClearedCallbackDelegate); + } + + if (textFieldSelectionChangedCallbackDelegate != null) + { + this.SelectionChangedSignal().Disconnect(textFieldSelectionChangedCallbackDelegate); + } + if (textFieldTextChangedCallbackDelegate != null) { TextChangedSignal().Disconnect(textFieldTextChangedCallbackDelegate); } } + TextChanged -= TextEditorTextChanged; + base.Dispose(type); } @@ -1598,6 +2240,14 @@ namespace Tizen.NUI.BaseComponents } } + private void TextEditorTextChanged(object sender, TextChangedEventArgs e) + { + if (!isSettingTextInCSharp) + { + EnforceNotifyBindedInstance(TextProperty); + } + } + internal new class Property { internal static readonly int TEXT = Interop.TextField.TextGet(); @@ -1659,6 +2309,9 @@ namespace Tizen.NUI.BaseComponents internal static readonly int EnableEditing = Interop.TextField.EnableEditingGet(); internal static readonly int PrimaryCursorPosition = Interop.TextField.PrimaryCursorPositionGet(); internal static readonly int FontSizeScale = Interop.TextField.FontSizeScaleGet(); + internal static readonly int GrabHandleColor = Interop.TextField.GrabHandleColorGet(); + internal static readonly int EllipsisPosition = Interop.TextField.EllipsisPositionGet(); + internal static readonly int InputFilter = Interop.TextField.InputFilterGet(); } internal class InputStyle @@ -1713,5 +2366,9 @@ namespace Tizen.NUI.BaseComponents { TextColor = new Color(r, g, b, a); } + private void OnGrabHandleColorChanged(float r, float g, float b, float a) + { + GrabHandleColor = new Color(r, g, b, a); + } } }