use crate::consts::Champion;
use crate::models::match_v5::Participant;

impl Participant {
    /// This method takes the [`Self::champion_id`] field if it is valid
    /// (`Ok`), otherwise it attempts to parse [`Self::champion_name`] and
    /// returns the `Result`.
    ///
    /// This is needed because some of Riot's [`Self::champion_id`] data is
    /// corrupted, as they describe in the docs:
    ///
    /// > Prior to patch 11.4, on Feb 18th, 2021, this field returned invalid
    /// > championIds. We recommend determining the champion based on the
    /// > championName field for matches played prior to patch 11.4.
    ///
    /// This issue is reported here: <https://github.com/RiotGames/developer-relations/issues/553>.
    pub fn champion(&self) -> Result<Champion, <Champion as std::str::FromStr>::Err> {
        #[allow(deprecated)]
        self.champion_id.or_else(|_| self.champion_name.parse())
    }

    /// This method returns the name portion of the riot ID for this summoner.
    ///
    /// Prior to patch 14.5, this was in the [`Self::riot_id_name`] field.
    /// After, this moved to the `Self.riot_id_game_name` field.
    ///
    /// This method simply returns whichever of the two fields is not `None`.
    pub fn riot_id_game_name(&self) -> Option<&str> {
        self.riot_id_game_name
            .as_deref()
            .or(self.riot_id_name.as_deref())
    }
}