From b89effd57b69717f84eae6924729a35325269dc7 Mon Sep 17 00:00:00 2001 From: Romain Petit Date: Tue, 29 Oct 2024 15:26:48 +0100 Subject: [PATCH] feat(Video Type) add new props & make non null props required --- src/types.ts | 47 ++++++++++++++++++++++++++++++++++++----------- 1 file changed, 36 insertions(+), 11 deletions(-) diff --git a/src/types.ts b/src/types.ts index 346e2da..9be94f1 100644 --- a/src/types.ts +++ b/src/types.ts @@ -11,7 +11,7 @@ export interface Video { /** * When an webhook was created, presented in ISO-8601 format. */ - createdAt?: Date; + createdAt: Date; /** * The title of the video content. */ @@ -19,25 +19,45 @@ export interface Video { /** * A description for the video content. */ - description?: string; + description: string; /** * The date and time the API created the video. Date and time are provided using ISO-8601 UTC format. */ - publishedAt?: string; + publishedAt: Date; /** * The date and time the video was updated. Date and time are provided using ISO-8601 UTC format. */ - updatedAt?: Date; + updatedAt: Date; + /** + * The date and time the video was discarded. Date and time are provided using ISO-8601 UTC format. + */ + discardedAt?: Date; + /** + * The date and time the video will be permanently deleted. Date and time are provided using ISO-8601 UTC format. + */ + deletesAt?: Date; + /** + * Returns `true` for videos you discarded. + */ + discarded: boolean; + /** + * Returns the language of a video in [IETF language tag](https://en.wikipedia.org/wiki/IETF_language_tag) format. + */ + language?: Intl.Locale; + /** + * Returns the origin of the last update on the video's `language` attribute. + */ + languageOrigin?: LanguageOrigin; /** * One array of tags (each tag is a string) in order to categorize a video. Tags may include spaces. */ - tags?: Array; + tags: Array; /** * Metadata you can use to categorise and filter videos. Metadata is a list of dictionaries, where each dictionary represents a key value pair for categorising a video. */ - metadata?: Array; - source?: VideoSource; - assets?: VideoAssets; + metadata: Array; + source: VideoSource; + assets: VideoAssets; /** * The id of the player that will be applied on the video. */ @@ -45,15 +65,15 @@ export interface Video { /** * Defines if the content is publicly reachable or if a unique token is needed for each play session. */ - _public?: boolean; + _public: boolean; /** * Defines if video is panoramic. */ - panoramic?: boolean; + panoramic: boolean; /** * This lets you know whether mp4 is supported. If enabled, an mp4 URL will be provided in the response for the video. */ - mp4Support?: boolean; + mp4Support: boolean; } interface Metadata { /** @@ -106,3 +126,8 @@ interface VideoAssets { */ mp4?: string; } + +enum LanguageOrigin { + api = 'api', + auto = 'auto', +}