pub struct Team {
pub id: Uuid,
pub spec_id: Option<String>,
pub name: String,
pub description: String,
pub parent_team_id: Option<Uuid>,
pub member_ids: Vec<Uuid>,
pub created_at: DateTime<Utc>,
pub modified_at: Option<DateTime<Utc>>,
pub archived: bool,
}Expand description
Represents a team in the system Teams can contain users (members) and can be nested (parent/child teams)
Fields§
§id: UuidUnique identifier for the team
spec_id: Option<String>Human-friendly spec ID (e.g., “$TEAM-001”)
name: StringTeam name
description: StringTeam description (optional)
parent_team_id: Option<Uuid>Parent team ID for nested teams (None if top-level team)
member_ids: Vec<Uuid>User IDs of team members
created_at: DateTime<Utc>When the team was created
modified_at: Option<DateTime<Utc>>When the team was last modified
archived: boolWhether the team is archived
Implementations§
Source§impl Team
impl Team
Sourcepub fn new(
name: String,
description: String,
parent_team_id: Option<Uuid>,
) -> Self
pub fn new( name: String, description: String, parent_team_id: Option<Uuid>, ) -> Self
Creates a new team (without spec_id - use RequirementsStore::add_team_with_id for auto-generated ID)
Sourcepub fn new_with_spec_id(
name: String,
description: String,
parent_team_id: Option<Uuid>,
spec_id: String,
) -> Self
pub fn new_with_spec_id( name: String, description: String, parent_team_id: Option<Uuid>, spec_id: String, ) -> Self
Creates a new team with a spec_id
Sourcepub fn display_id(&self) -> &str
pub fn display_id(&self) -> &str
Returns display name: spec_id if available, otherwise name
Sourcepub fn add_member(&mut self, user_id: Uuid)
pub fn add_member(&mut self, user_id: Uuid)
Adds a member to the team
Sourcepub fn remove_member(&mut self, user_id: &Uuid) -> bool
pub fn remove_member(&mut self, user_id: &Uuid) -> bool
Removes a member from the team
Sourcepub fn has_member(&self, user_id: &Uuid) -> bool
pub fn has_member(&self, user_id: &Uuid) -> bool
Checks if a user is a member of this team
Sourcepub fn member_count(&self) -> usize
pub fn member_count(&self) -> usize
Returns the number of members
Trait Implementations§
Source§impl<'de> Deserialize<'de> for Team
impl<'de> Deserialize<'de> for Team
Source§fn deserialize<__D>(__deserializer: __D) -> Result<Self, __D::Error>where
__D: Deserializer<'de>,
fn deserialize<__D>(__deserializer: __D) -> Result<Self, __D::Error>where
__D: Deserializer<'de>,
Deserialize this value from the given Serde deserializer. Read more
Source§impl TS for Team
impl TS for Team
Source§type WithoutGenerics = Team
type WithoutGenerics = Team
If this type does not have generic parameters, then
WithoutGenerics should just be Self.
If the type does have generic parameters, then all generic parameters must be replaced with
a dummy type, e.g ts_rs::Dummy or ().
The only requirement for these dummy types is that EXPORT_TO must be None. Read moreSource§type OptionInnerType = Team
type OptionInnerType = Team
If the implementing type is
std::option::Option<T>, then this associated type is set to T.
All other implementations of TS should set this type to Self instead.Source§fn docs() -> Option<String>
fn docs() -> Option<String>
JSDoc comment to describe this type in TypeScript - when
TS is derived, docs are
automatically read from your doc comments or #[doc = ".."] attributesSource§fn decl_concrete() -> String
fn decl_concrete() -> String
Declaration of this type using the supplied generic arguments.
The resulting TypeScript definition will not be generic. For that, see
TS::decl().
If this type is not generic, then this function is equivalent to TS::decl().Source§fn decl() -> String
fn decl() -> String
Declaration of this type, e.g.
type User = { user_id: number, ... }.
This function will panic if the type has no declaration. Read moreSource§fn inline() -> String
fn inline() -> String
Formats this types definition in TypeScript, e.g
{ user_id: number }.
This function will panic if the type cannot be inlined.Source§fn inline_flattened() -> String
fn inline_flattened() -> String
Flatten a type declaration.
This function will panic if the type cannot be flattened.
This function will panic if the type cannot be flattened.
Source§fn visit_generics(v: &mut impl TypeVisitor)where
Self: 'static,
fn visit_generics(v: &mut impl TypeVisitor)where
Self: 'static,
Iterates over all type parameters of this type.
Source§fn output_path() -> Option<PathBuf>
fn output_path() -> Option<PathBuf>
Returns the output path to where
The returned path does not include the base directory from
T should be exported.The returned path does not include the base directory from
TS_RS_EXPORT_DIR. Read moreSource§fn visit_dependencies(v: &mut impl TypeVisitor)where
Self: 'static,
fn visit_dependencies(v: &mut impl TypeVisitor)where
Self: 'static,
Iterates over all dependency of this type.
Source§fn dependencies() -> Vec<Dependency>where
Self: 'static,
fn dependencies() -> Vec<Dependency>where
Self: 'static,
Resolves all dependencies of this type recursively.
Source§fn export() -> Result<(), ExportError>where
Self: 'static,
fn export() -> Result<(), ExportError>where
Self: 'static,
Manually export this type to the filesystem.
To export this type together with all of its dependencies, use
TS::export_all. Read moreSource§fn export_all() -> Result<(), ExportError>where
Self: 'static,
fn export_all() -> Result<(), ExportError>where
Self: 'static,
Manually export this type to the filesystem, together with all of its dependencies.
To export only this type, without its dependencies, use
To export only this type, without its dependencies, use
TS::export. Read moreSource§fn export_all_to(out_dir: impl AsRef<Path>) -> Result<(), ExportError>where
Self: 'static,
fn export_all_to(out_dir: impl AsRef<Path>) -> Result<(), ExportError>where
Self: 'static,
Manually export this type into the given directory, together with all of its dependencies.
To export only this type, without its dependencies, use
To export only this type, without its dependencies, use
TS::export. Read moreSource§fn export_to_string() -> Result<String, ExportError>where
Self: 'static,
fn export_to_string() -> Result<String, ExportError>where
Self: 'static,
Auto Trait Implementations§
impl Freeze for Team
impl RefUnwindSafe for Team
impl Send for Team
impl Sync for Team
impl Unpin for Team
impl UnsafeUnpin for Team
impl UnwindSafe for Team
Blanket Implementations§
Source§impl<T> BorrowMut<T> for Twhere
T: ?Sized,
impl<T> BorrowMut<T> for Twhere
T: ?Sized,
Source§fn borrow_mut(&mut self) -> &mut T
fn borrow_mut(&mut self) -> &mut T
Mutably borrows from an owned value. Read more