diff options
| author | 2024-09-04 21:25:59 +0200 | |
|---|---|---|
| committer | 2024-09-04 21:26:47 +0200 | |
| commit | f98328f4f1ee58b6288e4f19d7475e7eeb9a7ba7 (patch) | |
| tree | 8fb3e8b470bff711e0ca2f1bf120ab6c66ba9a9d /widget | |
| parent | 8d826cc662554b337282e7c982383f5db428d7aa (diff) | |
| download | iced-f98328f4f1ee58b6288e4f19d7475e7eeb9a7ba7.tar.gz iced-f98328f4f1ee58b6288e4f19d7475e7eeb9a7ba7.tar.bz2 iced-f98328f4f1ee58b6288e4f19d7475e7eeb9a7ba7.zip | |
Add `text::Wrapping` support
Co-authored-by: Neeraj Jaiswal <neerajj85@gmail.com>
Diffstat (limited to '')
| -rw-r--r-- | widget/src/checkbox.rs | 12 | ||||
| -rw-r--r-- | widget/src/helpers.rs | 2 | ||||
| -rw-r--r-- | widget/src/overlay/menu.rs | 1 | ||||
| -rw-r--r-- | widget/src/pick_list.rs | 5 | ||||
| -rw-r--r-- | widget/src/radio.rs | 13 | ||||
| -rw-r--r-- | widget/src/text/rich.rs | 14 | ||||
| -rw-r--r-- | widget/src/text_editor.rs | 13 | ||||
| -rw-r--r-- | widget/src/text_input.rs | 3 | ||||
| -rw-r--r-- | widget/src/toggler.rs | 17 | 
9 files changed, 69 insertions, 11 deletions
| diff --git a/widget/src/checkbox.rs b/widget/src/checkbox.rs index e5abfbb4..32db5090 100644 --- a/widget/src/checkbox.rs +++ b/widget/src/checkbox.rs @@ -50,6 +50,7 @@ pub struct Checkbox<      text_size: Option<Pixels>,      text_line_height: text::LineHeight,      text_shaping: text::Shaping, +    text_wrapping: text::Wrapping,      font: Option<Renderer::Font>,      icon: Icon<Renderer::Font>,      class: Theme::Class<'a>, @@ -81,7 +82,8 @@ where              spacing: Self::DEFAULT_SPACING,              text_size: None,              text_line_height: text::LineHeight::default(), -            text_shaping: text::Shaping::Basic, +            text_shaping: text::Shaping::default(), +            text_wrapping: text::Wrapping::default(),              font: None,              icon: Icon {                  font: Renderer::ICON_FONT, @@ -158,6 +160,12 @@ where          self      } +    /// Sets the [`text::Wrapping`] strategy of the [`Checkbox`]. +    pub fn text_wrapping(mut self, wrapping: text::Wrapping) -> Self { +        self.text_wrapping = wrapping; +        self +    } +      /// Sets the [`Renderer::Font`] of the text of the [`Checkbox`].      ///      /// [`Renderer::Font`]: crate::core::text::Renderer @@ -240,6 +248,7 @@ where                      alignment::Horizontal::Left,                      alignment::Vertical::Top,                      self.text_shaping, +                    self.text_wrapping,                  )              },          ) @@ -348,6 +357,7 @@ where                          horizontal_alignment: alignment::Horizontal::Center,                          vertical_alignment: alignment::Vertical::Center,                          shaping: *shaping, +                        wrapping: text::Wrapping::default(),                      },                      bounds.center(),                      style.icon_color, diff --git a/widget/src/helpers.rs b/widget/src/helpers.rs index 1cb02830..349f02a6 100644 --- a/widget/src/helpers.rs +++ b/widget/src/helpers.rs @@ -767,7 +767,7 @@ where  ///  /// [`Toggler`]: crate::Toggler  pub fn toggler<'a, Message, Theme, Renderer>( -    label: impl Into<Option<String>>, +    label: Option<impl text::IntoFragment<'a>>,      is_checked: bool,      f: impl Fn(bool) -> Message + 'a,  ) -> Toggler<'a, Message, Theme, Renderer> diff --git a/widget/src/overlay/menu.rs b/widget/src/overlay/menu.rs index 73d1cc8c..f05ae40a 100644 --- a/widget/src/overlay/menu.rs +++ b/widget/src/overlay/menu.rs @@ -532,6 +532,7 @@ where                      horizontal_alignment: alignment::Horizontal::Left,                      vertical_alignment: alignment::Vertical::Center,                      shaping: self.text_shaping, +                    wrapping: text::Wrapping::default(),                  },                  Point::new(bounds.x + self.padding.left, bounds.center_y()),                  if is_selected { diff --git a/widget/src/pick_list.rs b/widget/src/pick_list.rs index f7f7b65b..1fc9951e 100644 --- a/widget/src/pick_list.rs +++ b/widget/src/pick_list.rs @@ -81,7 +81,7 @@ where              padding: crate::button::DEFAULT_PADDING,              text_size: None,              text_line_height: text::LineHeight::default(), -            text_shaping: text::Shaping::Basic, +            text_shaping: text::Shaping::default(),              font: None,              handle: Handle::default(),              class: <Theme as Catalog>::default(), @@ -250,6 +250,7 @@ where              horizontal_alignment: alignment::Horizontal::Left,              vertical_alignment: alignment::Vertical::Center,              shaping: self.text_shaping, +            wrapping: text::Wrapping::default(),          };          for (option, paragraph) in options.iter().zip(state.options.iter_mut()) @@ -515,6 +516,7 @@ where                      horizontal_alignment: alignment::Horizontal::Right,                      vertical_alignment: alignment::Vertical::Center,                      shaping, +                    wrapping: text::Wrapping::default(),                  },                  Point::new(                      bounds.x + bounds.width - self.padding.right, @@ -544,6 +546,7 @@ where                      horizontal_alignment: alignment::Horizontal::Left,                      vertical_alignment: alignment::Vertical::Center,                      shaping: self.text_shaping, +                    wrapping: text::Wrapping::default(),                  },                  Point::new(bounds.x + self.padding.left, bounds.center_y()),                  if is_selected { diff --git a/widget/src/radio.rs b/widget/src/radio.rs index 1b02f8ca..cfa961f3 100644 --- a/widget/src/radio.rs +++ b/widget/src/radio.rs @@ -82,6 +82,7 @@ where      text_size: Option<Pixels>,      text_line_height: text::LineHeight,      text_shaping: text::Shaping, +    text_wrapping: text::Wrapping,      font: Option<Renderer::Font>,      class: Theme::Class<'a>,  } @@ -122,10 +123,11 @@ where              label: label.into(),              width: Length::Shrink,              size: Self::DEFAULT_SIZE, -            spacing: Self::DEFAULT_SPACING, //15 +            spacing: Self::DEFAULT_SPACING,              text_size: None,              text_line_height: text::LineHeight::default(), -            text_shaping: text::Shaping::Basic, +            text_shaping: text::Shaping::default(), +            text_wrapping: text::Wrapping::default(),              font: None,              class: Theme::default(),          } @@ -170,6 +172,12 @@ where          self      } +    /// Sets the [`text::Wrapping`] strategy of the [`Radio`] button. +    pub fn text_wrapping(mut self, wrapping: text::Wrapping) -> Self { +        self.text_wrapping = wrapping; +        self +    } +      /// Sets the text font of the [`Radio`] button.      pub fn font(mut self, font: impl Into<Renderer::Font>) -> Self {          self.font = Some(font.into()); @@ -245,6 +253,7 @@ where                      alignment::Horizontal::Left,                      alignment::Vertical::Top,                      self.text_shaping, +                    self.text_wrapping,                  )              },          ) diff --git a/widget/src/text/rich.rs b/widget/src/text/rich.rs index 1eb0d296..921c55a5 100644 --- a/widget/src/text/rich.rs +++ b/widget/src/text/rich.rs @@ -5,7 +5,7 @@ use crate::core::mouse;  use crate::core::renderer;  use crate::core::text::{Paragraph, Span};  use crate::core::widget::text::{ -    self, Catalog, LineHeight, Shaping, Style, StyleFn, +    self, Catalog, LineHeight, Shaping, Style, StyleFn, Wrapping,  };  use crate::core::widget::tree::{self, Tree};  use crate::core::{ @@ -29,6 +29,7 @@ where      font: Option<Renderer::Font>,      align_x: alignment::Horizontal,      align_y: alignment::Vertical, +    wrapping: Wrapping,      class: Theme::Class<'a>,  } @@ -50,6 +51,7 @@ where              font: None,              align_x: alignment::Horizontal::Left,              align_y: alignment::Vertical::Top, +            wrapping: Wrapping::default(),              class: Theme::default(),          }      } @@ -118,6 +120,12 @@ where          self      } +    /// Sets the [`Wrapping`] strategy of the [`Rich`] text. +    pub fn wrapping(mut self, wrapping: Wrapping) -> Self { +        self.wrapping = wrapping; +        self +    } +      /// Sets the default style of the [`Rich`] text.      #[must_use]      pub fn style(mut self, style: impl Fn(&Theme) -> Style + 'a) -> Self @@ -218,6 +226,7 @@ where              self.font,              self.align_x,              self.align_y, +            self.wrapping,          )      } @@ -444,6 +453,7 @@ fn layout<Link, Renderer>(      font: Option<Renderer::Font>,      horizontal_alignment: alignment::Horizontal,      vertical_alignment: alignment::Vertical, +    wrapping: Wrapping,  ) -> layout::Node  where      Link: Clone, @@ -464,6 +474,7 @@ where              horizontal_alignment,              vertical_alignment,              shaping: Shaping::Advanced, +            wrapping,          };          if state.spans != spans { @@ -480,6 +491,7 @@ where                  horizontal_alignment,                  vertical_alignment,                  shaping: Shaping::Advanced, +                wrapping,              }) {                  core::text::Difference::None => {}                  core::text::Difference::Bounds => { diff --git a/widget/src/text_editor.rs b/widget/src/text_editor.rs index 745e3ae8..d1aa4640 100644 --- a/widget/src/text_editor.rs +++ b/widget/src/text_editor.rs @@ -9,7 +9,7 @@ use crate::core::mouse;  use crate::core::renderer;  use crate::core::text::editor::{Cursor, Editor as _};  use crate::core::text::highlighter::{self, Highlighter}; -use crate::core::text::{self, LineHeight, Text}; +use crate::core::text::{self, LineHeight, Text, Wrapping};  use crate::core::time::{Duration, Instant};  use crate::core::widget::operation;  use crate::core::widget::{self, Widget}; @@ -47,6 +47,7 @@ pub struct TextEditor<      width: Length,      height: Length,      padding: Padding, +    wrapping: Wrapping,      class: Theme::Class<'a>,      key_binding: Option<Box<dyn Fn(KeyPress) -> Option<Binding<Message>> + 'a>>,      on_edit: Option<Box<dyn Fn(Action) -> Message + 'a>>, @@ -74,6 +75,7 @@ where              width: Length::Fill,              height: Length::Shrink,              padding: Padding::new(5.0), +            wrapping: Wrapping::default(),              class: Theme::default(),              key_binding: None,              on_edit: None, @@ -148,6 +150,12 @@ where          self      } +    /// Sets the [`Wrapping`] strategy of the [`TextEditor`]. +    pub fn wrapping(mut self, wrapping: Wrapping) -> Self { +        self.wrapping = wrapping; +        self +    } +      /// Highlights the [`TextEditor`] using the given syntax and theme.      #[cfg(feature = "highlighter")]      pub fn highlight( @@ -186,6 +194,7 @@ where              width: self.width,              height: self.height,              padding: self.padding, +            wrapping: self.wrapping,              class: self.class,              key_binding: self.key_binding,              on_edit: self.on_edit, @@ -496,6 +505,7 @@ where              self.font.unwrap_or_else(|| renderer.default_font()),              self.text_size.unwrap_or_else(|| renderer.default_size()),              self.line_height, +            self.wrapping,              state.highlighter.borrow_mut().deref_mut(),          ); @@ -784,6 +794,7 @@ where                          horizontal_alignment: alignment::Horizontal::Left,                          vertical_alignment: alignment::Vertical::Top,                          shaping: text::Shaping::Advanced, +                        wrapping: self.wrapping,                      },                      text_bounds.position(),                      style.placeholder, diff --git a/widget/src/text_input.rs b/widget/src/text_input.rs index 52e37388..92047381 100644 --- a/widget/src/text_input.rs +++ b/widget/src/text_input.rs @@ -251,6 +251,7 @@ where              horizontal_alignment: alignment::Horizontal::Left,              vertical_alignment: alignment::Vertical::Center,              shaping: text::Shaping::Advanced, +            wrapping: text::Wrapping::default(),          };          state.placeholder.update(placeholder_text); @@ -275,6 +276,7 @@ where                  horizontal_alignment: alignment::Horizontal::Center,                  vertical_alignment: alignment::Vertical::Center,                  shaping: text::Shaping::Advanced, +                wrapping: text::Wrapping::default(),              };              state.icon.update(icon_text); @@ -1432,6 +1434,7 @@ fn replace_paragraph<Renderer>(          horizontal_alignment: alignment::Horizontal::Left,          vertical_alignment: alignment::Vertical::Top,          shaping: text::Shaping::Advanced, +        wrapping: text::Wrapping::default(),      });  } diff --git a/widget/src/toggler.rs b/widget/src/toggler.rs index 821e2526..f7b3078c 100644 --- a/widget/src/toggler.rs +++ b/widget/src/toggler.rs @@ -40,13 +40,14 @@ pub struct Toggler<  {      is_toggled: bool,      on_toggle: Box<dyn Fn(bool) -> Message + 'a>, -    label: Option<String>, +    label: Option<text::Fragment<'a>>,      width: Length,      size: f32,      text_size: Option<Pixels>,      text_line_height: text::LineHeight,      text_alignment: alignment::Horizontal,      text_shaping: text::Shaping, +    text_wrapping: text::Wrapping,      spacing: f32,      font: Option<Renderer::Font>,      class: Theme::Class<'a>, @@ -69,7 +70,7 @@ where      ///     will receive the new state of the [`Toggler`] and must produce a      ///     `Message`.      pub fn new<F>( -        label: impl Into<Option<String>>, +        label: Option<impl text::IntoFragment<'a>>,          is_toggled: bool,          f: F,      ) -> Self @@ -79,13 +80,14 @@ where          Toggler {              is_toggled,              on_toggle: Box::new(f), -            label: label.into(), +            label: label.map(text::IntoFragment::into_fragment),              width: Length::Shrink,              size: Self::DEFAULT_SIZE,              text_size: None,              text_line_height: text::LineHeight::default(),              text_alignment: alignment::Horizontal::Left, -            text_shaping: text::Shaping::Basic, +            text_shaping: text::Shaping::default(), +            text_wrapping: text::Wrapping::default(),              spacing: Self::DEFAULT_SIZE / 2.0,              font: None,              class: Theme::default(), @@ -131,6 +133,12 @@ where          self      } +    /// Sets the [`text::Wrapping`] strategy of the [`Toggler`]. +    pub fn text_wrapping(mut self, wrapping: text::Wrapping) -> Self { +        self.text_wrapping = wrapping; +        self +    } +      /// Sets the spacing between the [`Toggler`] and the text.      pub fn spacing(mut self, spacing: impl Into<Pixels>) -> Self {          self.spacing = spacing.into().0; @@ -216,6 +224,7 @@ where                          self.text_alignment,                          alignment::Vertical::Top,                          self.text_shaping, +                        self.text_wrapping,                      )                  } else {                      layout::Node::new(Size::ZERO) | 
