1
  2
  3
  4
  5
  6
  7
  8
  9
 10
 11
 12
 13
 14
 15
 16
 17
 18
 19
 20
 21
 22
 23
 24
 25
 26
 27
 28
 29
 30
 31
 32
 33
 34
 35
 36
 37
 38
 39
 40
 41
 42
 43
 44
 45
 46
 47
 48
 49
 50
 51
 52
 53
 54
 55
 56
 57
 58
 59
 60
 61
 62
 63
 64
 65
 66
 67
 68
 69
 70
 71
 72
 73
 74
 75
 76
 77
 78
 79
 80
 81
 82
 83
 84
 85
 86
 87
 88
 89
 90
 91
 92
 93
 94
 95
 96
 97
 98
 99
100
101
102
103
104
105
106
107
use crate::errors::*;
use crate::types::*;
use uuid::Uuid;

/// Describes a position of a chat in a chat list
#[derive(Debug, Clone, Default, Serialize, Deserialize)]
pub struct ChatPosition {
    #[doc(hidden)]
    #[serde(rename(serialize = "@extra", deserialize = "@extra"))]
    extra: Option<String>,
    #[serde(rename(serialize = "@client_id", deserialize = "@client_id"))]
    client_id: Option<i32>,
    /// The chat list

    #[serde(skip_serializing_if = "ChatList::_is_default")]
    list: ChatList,
    /// A parameter used to determine order of the chat in the chat list. Chats must be sorted by the pair (order, chat.id) in descending order

    #[serde(deserialize_with = "super::_common::number_from_string")]
    order: i64,
    /// True, if the chat is pinned in the chat list
    is_pinned: bool,
    /// Source of the chat in the chat list; may be null
    source: Option<ChatSource>,
}

impl RObject for ChatPosition {
    #[doc(hidden)]
    fn extra(&self) -> Option<&str> {
        self.extra.as_deref()
    }
    #[doc(hidden)]
    fn client_id(&self) -> Option<i32> {
        self.client_id
    }
}

impl ChatPosition {
    pub fn from_json<S: AsRef<str>>(json: S) -> RTDResult<Self> {
        Ok(serde_json::from_str(json.as_ref())?)
    }
    pub fn builder() -> RTDChatPositionBuilder {
        let mut inner = ChatPosition::default();
        inner.extra = Some(Uuid::new_v4().to_string());

        RTDChatPositionBuilder { inner }
    }

    pub fn list(&self) -> &ChatList {
        &self.list
    }

    pub fn order(&self) -> i64 {
        self.order
    }

    pub fn is_pinned(&self) -> bool {
        self.is_pinned
    }

    pub fn source(&self) -> &Option<ChatSource> {
        &self.source
    }
}

#[doc(hidden)]
pub struct RTDChatPositionBuilder {
    inner: ChatPosition,
}

impl RTDChatPositionBuilder {
    pub fn build(&self) -> ChatPosition {
        self.inner.clone()
    }

    pub fn list<T: AsRef<ChatList>>(&mut self, list: T) -> &mut Self {
        self.inner.list = list.as_ref().clone();
        self
    }

    pub fn order(&mut self, order: i64) -> &mut Self {
        self.inner.order = order;
        self
    }

    pub fn is_pinned(&mut self, is_pinned: bool) -> &mut Self {
        self.inner.is_pinned = is_pinned;
        self
    }

    pub fn source<T: AsRef<ChatSource>>(&mut self, source: T) -> &mut Self {
        self.inner.source = Some(source.as_ref().clone());
        self
    }
}

impl AsRef<ChatPosition> for ChatPosition {
    fn as_ref(&self) -> &ChatPosition {
        self
    }
}

impl AsRef<ChatPosition> for RTDChatPositionBuilder {
    fn as_ref(&self) -> &ChatPosition {
        &self.inner
    }
}