diff --git a/frameworks/core/components_ng/pattern/text_field/text_field_layout_algorithm.cpp b/frameworks/core/components_ng/pattern/text_field/text_field_layout_algorithm.cpp index 7687f2aef08afd350f41c7ce5508b8deeeaab334..534decc9a4b51c59489d1e29cf2b37654d5028db 100644 --- a/frameworks/core/components_ng/pattern/text_field/text_field_layout_algorithm.cpp +++ b/frameworks/core/components_ng/pattern/text_field/text_field_layout_algorithm.cpp @@ -61,6 +61,7 @@ void TextFieldLayoutAlgorithm::ConstructTextStyles( CHECK_NULL_VOID(textFieldPaintProperty); auto isInlineStyle = pattern->IsNormalInlineState(); auto isTextArea = pattern->IsTextArea(); + bool isShowPassword = pattern->IsShowPasswordIcon(); if (!pattern->GetTextValue().empty()) { UpdateTextStyle(frameNode, textFieldLayoutProperty, textFieldTheme, textStyle, pattern->IsDisabled(), @@ -74,6 +75,12 @@ void TextFieldLayoutAlgorithm::ConstructTextStyles( showPlaceHolder = true; } + if (isShowPassword) { + auto colorIcon = textFieldPaintProperty->HasTextColorFlagByUser() ? + textFieldLayoutProperty->GetTextColorValue(textFieldTheme->GetTextColor()) : textFieldTheme->GetTextColor(); + pattern->UpdatePasswordIconColor(colorIcon); + } + if (pattern->GetMaxFontSizeScale().has_value()) { textStyle.SetMaxFontScale(pattern->GetMaxFontSizeScale().value()); } diff --git a/frameworks/core/components_ng/pattern/text_field/text_field_pattern.cpp b/frameworks/core/components_ng/pattern/text_field/text_field_pattern.cpp index bb4beaac216adc5cc6dbc4347e8bbdc790d6bf1e..798aed8a2449464a52f20283aacd63e1ab1380ff 100644 --- a/frameworks/core/components_ng/pattern/text_field/text_field_pattern.cpp +++ b/frameworks/core/components_ng/pattern/text_field/text_field_pattern.cpp @@ -7426,6 +7426,13 @@ void TextFieldPattern::OnObscuredChanged(bool isObscured) host->MarkDirtyNode(PROPERTY_UPDATE_MEASURE_SELF_AND_PARENT); } +void TextFieldPattern::UpdatePasswordIconColor(const Color& color) +{ + auto passwordArea = AceType::DynamicCast(responseArea_); + CHECK_NULL_VOID(passwordArea); + passwordArea->UpdatePasswordIconColor(color); +} + void TextFieldPattern::CreateHandles() { if (IsDragging() || !HasFocus()) { diff --git a/frameworks/core/components_ng/pattern/text_field/text_field_pattern.h b/frameworks/core/components_ng/pattern/text_field/text_field_pattern.h index 6712ad15b7fc94ccfaf327555789d8220c6e4d30..939e459d0e6914c7d8e97b865ccfda2042e4eed7 100644 --- a/frameworks/core/components_ng/pattern/text_field/text_field_pattern.h +++ b/frameworks/core/components_ng/pattern/text_field/text_field_pattern.h @@ -1177,6 +1177,7 @@ public: virtual RefPtr GetFocusHub() const; void UpdateCaretInfoToController(bool forceUpdate = false); void OnObscuredChanged(bool isObscured); + void UpdatePasswordIconColor(const Color& color); const RefPtr& GetResponseArea() { return responseArea_; diff --git a/frameworks/core/components_ng/pattern/text_field/text_input_response_area.cpp b/frameworks/core/components_ng/pattern/text_field/text_input_response_area.cpp index cd72a4e85d2e2863aced484fb3ad8678521a7538..39e0a037be782c172083bf01168ed83c8fceeec6 100644 --- a/frameworks/core/components_ng/pattern/text_field/text_input_response_area.cpp +++ b/frameworks/core/components_ng/pattern/text_field/text_input_response_area.cpp @@ -315,6 +315,16 @@ void PasswordResponseArea::OnPasswordIconClicked() ChangeObscuredState(); } +void PasswordResponseArea::UpdatePasswordIconColor(const Color& color) +{ + showIcon_->SetFillColor(color); + hideIcon_->SetFillColor(color); + + if (!IsSymbolIcon()) { + UpdateImageSource(); + } +} + void PasswordResponseArea::ChangeObscuredState() { auto textFieldPattern = DynamicCast(hostPattern_.Upgrade()); @@ -387,7 +397,7 @@ void PasswordResponseArea::LoadImageSourceInfo() CHECK_NULL_VOID(pipeline); auto themeManager = pipeline->GetThemeManager(); CHECK_NULL_VOID(themeManager); - auto textFieldTheme = themeManager->GetTheme(); + auto textFieldTheme = themeManager->GetTheme(tmpHost->GetThemeScopeId()); CHECK_NULL_VOID(textFieldTheme); if (showIcon_->GetResourceId() == InternalResource::ResourceId::SHOW_PASSWORD_SVG) { showIcon_->SetFillColor(textFieldTheme->GetTextColor()); @@ -462,7 +472,7 @@ void PasswordResponseArea::UpdateSymbolSource() CHECK_NULL_VOID(pipeline); auto themeManager = pipeline->GetThemeManager(); CHECK_NULL_VOID(themeManager); - auto textFieldTheme = themeManager->GetTheme(); + auto textFieldTheme = themeManager->GetTheme(host->GetThemeScopeId()); CHECK_NULL_VOID(textFieldTheme); auto symbolNode = passwordNode_.Upgrade(); CHECK_NULL_VOID(symbolNode); diff --git a/frameworks/core/components_ng/pattern/text_field/text_input_response_area.h b/frameworks/core/components_ng/pattern/text_field/text_input_response_area.h index 00dcc0c3009af34ea97ab1b18eb5150cba3ac326..f5fb5b0bf57ffbf13128162485e1937928abf8fc 100644 --- a/frameworks/core/components_ng/pattern/text_field/text_input_response_area.h +++ b/frameworks/core/components_ng/pattern/text_field/text_input_response_area.h @@ -106,6 +106,7 @@ public: const RefPtr GetFrameNode() override; + void UpdatePasswordIconColor(const Color& color); void OnPasswordIconClicked(); private: