remotion
Version:
Render videos in React
32 lines • 2.27 kB
JavaScript
;
Object.defineProperty(exports, "__esModule", { value: true });
exports.Audio = void 0;
const jsx_runtime_1 = require("react/jsx-runtime");
const react_1 = require("react");
const get_environment_1 = require("../get-environment");
const sequencing_1 = require("../sequencing");
const validate_media_props_1 = require("../validate-media-props");
const validate_start_from_props_1 = require("../validate-start-from-props");
const AudioForDevelopment_1 = require("./AudioForDevelopment");
const AudioForRendering_1 = require("./AudioForRendering");
const shared_audio_tags_1 = require("./shared-audio-tags");
const AudioRefForwardingFunction = (props, ref) => {
const audioContext = (0, react_1.useContext)(shared_audio_tags_1.SharedAudioContext);
const { startFrom, endAt, ...otherProps } = props;
const onError = (0, react_1.useCallback)((e) => {
throw new Error(`Could not play audio with src ${otherProps.src}: ${e.currentTarget.error}`);
}, [otherProps.src]);
if (typeof startFrom !== 'undefined' || typeof endAt !== 'undefined') {
(0, validate_start_from_props_1.validateStartFromProps)(startFrom, endAt);
const startFromFrameNo = startFrom !== null && startFrom !== void 0 ? startFrom : 0;
const endAtFrameNo = endAt !== null && endAt !== void 0 ? endAt : Infinity;
return ((0, jsx_runtime_1.jsx)(sequencing_1.Sequence, Object.assign({ layout: "none", from: 0 - startFromFrameNo, showInTimeline: false, durationInFrames: endAtFrameNo }, { children: (0, jsx_runtime_1.jsx)(exports.Audio, Object.assign({}, otherProps, { ref: ref }), void 0) }), void 0));
}
(0, validate_media_props_1.validateMediaProps)(props, 'Audio');
if ((0, get_environment_1.getRemotionEnvironment)() === 'rendering') {
return (0, jsx_runtime_1.jsx)(AudioForRendering_1.AudioForRendering, Object.assign({}, props, { ref: ref, onError: onError }), void 0);
}
return ((0, jsx_runtime_1.jsx)(AudioForDevelopment_1.AudioForDevelopment, Object.assign({ shouldPreMountAudioTags: audioContext !== null && audioContext.numberOfAudioTags > 0 }, props, { ref: ref, onError: onError }), void 0));
};
exports.Audio = (0, react_1.forwardRef)(AudioRefForwardingFunction);
//# sourceMappingURL=Audio.js.map