1use crate::errors::Result;
2use crate::types::*;
3use uuid::Uuid;
4
5#[derive(Debug, Clone, Default, Serialize, Deserialize)]
7pub struct Text {
8 #[doc(hidden)]
9 #[serde(rename(serialize = "@extra", deserialize = "@extra"))]
10 extra: Option<String>,
11 #[serde(rename(serialize = "@client_id", deserialize = "@client_id"))]
12 client_id: Option<i32>,
13 #[serde(default)]
16 text: String,
17}
18
19impl RObject for Text {
20 #[doc(hidden)]
21 fn extra(&self) -> Option<&str> {
22 self.extra.as_deref()
23 }
24 #[doc(hidden)]
25 fn client_id(&self) -> Option<i32> {
26 self.client_id
27 }
28}
29
30impl Text {
31 pub fn from_json<S: AsRef<str>>(json: S) -> Result<Self> {
32 Ok(serde_json::from_str(json.as_ref())?)
33 }
34 pub fn builder() -> TextBuilder {
35 let mut inner = Text::default();
36 inner.extra = Some(Uuid::new_v4().to_string());
37
38 TextBuilder { inner }
39 }
40
41 pub fn text(&self) -> &String {
42 &self.text
43 }
44}
45
46#[doc(hidden)]
47pub struct TextBuilder {
48 inner: Text,
49}
50
51#[deprecated]
52pub type RTDTextBuilder = TextBuilder;
53
54impl TextBuilder {
55 pub fn build(&self) -> Text {
56 self.inner.clone()
57 }
58
59 pub fn text<T: AsRef<str>>(&mut self, text: T) -> &mut Self {
60 self.inner.text = text.as_ref().to_string();
61 self
62 }
63}
64
65impl AsRef<Text> for Text {
66 fn as_ref(&self) -> &Text {
67 self
68 }
69}
70
71impl AsRef<Text> for TextBuilder {
72 fn as_ref(&self) -> &Text {
73 &self.inner
74 }
75}