UNPKG

rx-player

Version:
77 lines 3.14 kB
/** * Copyright 2015 CANAL+ Group * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. */ import type { IManifestMetadata } from "../../../manifest"; /** * All possible initial time options that can be set. * * Written this way (with many type possibilities) on purpose to avoid issues * if the application using the RxPlayer gives undocumented values such as * `null`. * * TODO we shouldn't be that robust, at least not outside the API code, because * if we begin to be that liberal here, where should we end? * We may instead either want to progressively remove tolerance on the wrong * type being given or be better to enforce type-compliancy in the API code. */ export interface IInitialTimeOptions { /** If set, we should begin at this position, in seconds. */ position?: number | null | undefined; /** If set, we should begin at this unix timestamp, in seconds. */ wallClockTime?: number | null | undefined; /** * If set, we should begin at this position relative to the content's start, * in seconds. */ fromFirstPosition?: number | null | undefined; /** * If set, we should begin at this position relative to the content's maximum * seekable position, in seconds. * * It should consequently in most cases be a negative value. */ fromLastPosition?: number | null | undefined; /** * If set, we should begin at this position relative to the content's live * edge if it makes sense, in seconds. * * It should consequently in most cases be a negative value. * * If the live edge is unknown or if it does not make sense for the current * content, that position is relative to the content's maximum position * instead. */ fromLivePosition?: number | null | undefined; /** * If set, we should begin at this position relative to the whole duration of * the content, in percentage. */ percentage?: number | null | undefined; } /** * Returns the calculated initial time for the content described by the given * Manifest: * 1. if a start time is defined by user, calculate starting time from the * manifest information * 2. else if the media is live, use the live edge and suggested delays from * it * 3. else returns the minimum time announced in the manifest * @param {Manifest} manifest * @param {boolean} lowLatencyMode * @param {Object} startAt * @returns {Number} */ export default function getInitialTime(manifest: IManifestMetadata, lowLatencyMode: boolean, startAt?: IInitialTimeOptions): number; //# sourceMappingURL=get_initial_time.d.ts.map