summaryrefslogtreecommitdiff
path: root/crates/material_theme/src/text_input.rs
diff options
context:
space:
mode:
authorpml68 <contact@pml68.dev>2025-04-28 10:56:49 +0200
committerpml68 <contact@pml68.dev>2025-04-28 10:56:49 +0200
commitdac7e82e0bff128097653fe05829b2d576fcdb2f (patch)
tree6f36736e79eecd6904933c6876af1df58e6b605b /crates/material_theme/src/text_input.rs
parentfeat(material_theme): implement `image::Catalog` (under feature flag) (diff)
downloadiced-builder-dac7e82e0bff128097653fe05829b2d576fcdb2f.tar.gz
refactor(material_theme)!: make `Theme` an enum with `Custom` variant
Diffstat (limited to '')
-rw-r--r--crates/material_theme/src/text_input.rs38
1 files changed, 10 insertions, 28 deletions
diff --git a/crates/material_theme/src/text_input.rs b/crates/material_theme/src/text_input.rs
index 5de5993..ed5e02a 100644
--- a/crates/material_theme/src/text_input.rs
+++ b/crates/material_theme/src/text_input.rs
@@ -2,7 +2,7 @@ use iced_widget::core::{Background, Border, Color};
use iced_widget::text_input::{Catalog, Status, Style, StyleFn};
use super::Theme;
-use crate::utils::{DISABLED_CONTAINER_OPACITY, DISABLED_TEXT_OPACITY};
+use crate::utils::{disabled_container, disabled_text};
impl Catalog for Theme {
type Class<'a> = StyleFn<'a, Self>;
@@ -17,23 +17,20 @@ impl Catalog for Theme {
}
pub fn default(theme: &Theme, status: Status) -> Style {
- let surface = theme.colorscheme.surface;
- let primary = theme.colorscheme.primary;
+ let surface = theme.colors().surface;
+ let primary = theme.colors().primary;
let active = Style {
background: Background::Color(surface.surface_container.highest),
border: Border {
- color: theme.colorscheme.outline.color,
+ color: theme.colors().outline.color,
width: 1.0,
radius: 4.into(),
},
icon: surface.on_surface_variant,
placeholder: surface.on_surface_variant,
value: surface.on_surface,
- selection: Color {
- a: DISABLED_TEXT_OPACITY,
- ..primary.color
- },
+ selection: disabled_text(primary.color),
};
match status {
@@ -48,28 +45,13 @@ pub fn default(theme: &Theme, status: Status) -> Style {
Status::Disabled => Style {
background: Color::TRANSPARENT.into(),
border: Border {
- color: Color {
- a: DISABLED_CONTAINER_OPACITY,
- ..surface.on_surface
- },
+ color: disabled_container(surface.on_surface),
..active.border
},
- icon: Color {
- a: DISABLED_TEXT_OPACITY,
- ..surface.on_surface
- },
- placeholder: Color {
- a: DISABLED_TEXT_OPACITY,
- ..surface.on_surface
- },
- value: Color {
- a: DISABLED_TEXT_OPACITY,
- ..surface.on_surface
- },
- selection: Color {
- a: DISABLED_TEXT_OPACITY,
- ..surface.on_surface
- },
+ icon: disabled_text(surface.on_surface),
+ placeholder: disabled_text(surface.on_surface),
+ value: disabled_text(surface.on_surface),
+ selection: disabled_text(surface.on_surface),
},
Status::Focused { .. } => Style {
border: Border {