Source code for mgnipy.emgapi_v2_client.models.super_study_detail
from __future__ import annotations
from collections.abc import Mapping
from typing import (
TYPE_CHECKING,
Any,
TypeVar,
cast,
)
from attrs import define as _attrs_define
from attrs import field as _attrs_field
from ..types import (
UNSET,
Unset,
)
if TYPE_CHECKING:
from ..models.genome_catalogue_list import GenomeCatalogueList
from ..models.m_gnify_study import MGnifyStudy
T = TypeVar("T", bound="SuperStudyDetail")
[docs]
@_attrs_define
class SuperStudyDetail:
"""
Attributes:
slug (str):
title (str):
flagship_studies (list[MGnifyStudy]):
related_studies (list[MGnifyStudy]):
genome_catalogues (list[GenomeCatalogueList]):
description (None | str | Unset):
logo_url (None | str | Unset):
"""
slug: str
title: str
flagship_studies: list[MGnifyStudy]
related_studies: list[MGnifyStudy]
genome_catalogues: list[GenomeCatalogueList]
description: None | str | Unset = UNSET
logo_url: None | str | Unset = UNSET
additional_properties: dict[str, Any] = _attrs_field(init=False, factory=dict)
[docs]
def to_dict(self) -> dict[str, Any]:
slug = self.slug
title = self.title
flagship_studies = []
for flagship_studies_item_data in self.flagship_studies:
flagship_studies_item = flagship_studies_item_data.to_dict()
flagship_studies.append(flagship_studies_item)
related_studies = []
for related_studies_item_data in self.related_studies:
related_studies_item = related_studies_item_data.to_dict()
related_studies.append(related_studies_item)
genome_catalogues = []
for genome_catalogues_item_data in self.genome_catalogues:
genome_catalogues_item = genome_catalogues_item_data.to_dict()
genome_catalogues.append(genome_catalogues_item)
description: None | str | Unset
if isinstance(self.description, Unset):
description = UNSET
else:
description = self.description
logo_url: None | str | Unset
if isinstance(self.logo_url, Unset):
logo_url = UNSET
else:
logo_url = self.logo_url
field_dict: dict[str, Any] = {}
field_dict.update(self.additional_properties)
field_dict.update(
{
"slug": slug,
"title": title,
"flagship_studies": flagship_studies,
"related_studies": related_studies,
"genome_catalogues": genome_catalogues,
}
)
if description is not UNSET:
field_dict["description"] = description
if logo_url is not UNSET:
field_dict["logo_url"] = logo_url
return field_dict
[docs]
@classmethod
def from_dict(cls: type[T], src_dict: Mapping[str, Any]) -> T:
from ..models.genome_catalogue_list import GenomeCatalogueList
from ..models.m_gnify_study import MGnifyStudy
d = dict(src_dict)
slug = d.pop("slug")
title = d.pop("title")
flagship_studies = []
_flagship_studies = d.pop("flagship_studies")
for flagship_studies_item_data in _flagship_studies:
flagship_studies_item = MGnifyStudy.from_dict(flagship_studies_item_data)
flagship_studies.append(flagship_studies_item)
related_studies = []
_related_studies = d.pop("related_studies")
for related_studies_item_data in _related_studies:
related_studies_item = MGnifyStudy.from_dict(related_studies_item_data)
related_studies.append(related_studies_item)
genome_catalogues = []
_genome_catalogues = d.pop("genome_catalogues")
for genome_catalogues_item_data in _genome_catalogues:
genome_catalogues_item = GenomeCatalogueList.from_dict(
genome_catalogues_item_data
)
genome_catalogues.append(genome_catalogues_item)
def _parse_description(data: object) -> None | str | Unset:
if data is None:
return data
if isinstance(data, Unset):
return data
return cast(None | str | Unset, data)
description = _parse_description(d.pop("description", UNSET))
def _parse_logo_url(data: object) -> None | str | Unset:
if data is None:
return data
if isinstance(data, Unset):
return data
return cast(None | str | Unset, data)
logo_url = _parse_logo_url(d.pop("logo_url", UNSET))
super_study_detail = cls(
slug=slug,
title=title,
flagship_studies=flagship_studies,
related_studies=related_studies,
genome_catalogues=genome_catalogues,
description=description,
logo_url=logo_url,
)
super_study_detail.additional_properties = d
return super_study_detail
@property
def additional_keys(self) -> list[str]:
return list(self.additional_properties.keys())
def __getitem__(self, key: str) -> Any:
return self.additional_properties[key]
def __setitem__(self, key: str, value: Any) -> None:
self.additional_properties[key] = value
def __delitem__(self, key: str) -> None:
del self.additional_properties[key]
def __contains__(self, key: str) -> bool:
return key in self.additional_properties