mlb-api 1.0.3

Endpoints for MLB's public Statcast API.
Documentation
use crate::jobs::JobsResponse;
use crate::MLB_API_DATE_FORMAT;
use crate::request::{RequestURL, RequestURLBuilderExt};
use bon::Builder;
use chrono::NaiveDate;
use std::fmt::{Display, Formatter};
use crate::sport::SportId;

// pub mod games; // needs private mlb-only api key -- absolutely not going to implement this.

/// Returns [`JobsResponse`]
///
/// This request can be replicated with [`JobsRequest`](super::JobsRequest) and a datacaster job type.
///
/// Example: <http://statsapi.mlb.com/api/v1/jobs/umpires>
#[derive(Builder)]
#[builder(derive(Into))]
pub struct JobsUmpiresRequest {
    #[builder(into, default)]
    sport_id: SportId,
    date: Option<NaiveDate>,
}

impl Display for JobsUmpiresRequest {
    fn fmt(&self, f: &mut Formatter<'_>) -> std::fmt::Result {
        write!(f, "http://statsapi.mlb.com/api/v1/jobs/umpires{}", gen_params! { "sportId": self.sport_id, "date"?: self.date.as_ref().map(|date| date.format(MLB_API_DATE_FORMAT)) })
    }
}

impl RequestURL for JobsUmpiresRequest {
	type Response = JobsResponse;
}

impl<S: jobs_umpires_request_builder::State + jobs_umpires_request_builder::IsComplete> RequestURLBuilderExt for JobsUmpiresRequestBuilder<S> {
    type Built = JobsUmpiresRequest;
}