sample-files
v0.0.5
Published
(Work in Progress) Collection of various multimedia files
Readme
Sample Files
A small collection of files in various formats.
Useful for testing media conversions or having sample files to test media players.
Supports ESM, CJS, and TypeScript.
Installation
npm install sample-files
Usage
By default, this package only includes references to the various sample files.
import { sampleFiles } from 'sample-files';
// Big Buck Bunny - 10 second clip (mp4)
const sampleVideo = sampleFiles.video.mp4.bbb_short;
// Absolute path to the video on your machine
const __sampleVideo = await sampleVideo.path;
// ^ calls sampleVideo.downlolad()
// note: download() only downloads if not already downloadedWhen you await sampleVideo.path, you are actually calling sampleVideo.download() which downloads the video to your machine.
This is intentional, and keeps the filesize of the package very low. If all you need is a nice dictionary of remote files, then you don't need to reference the path at all.
Remote Files (CDN)
// https://raw.githubusercontent.com/cseitz/sample-files/main/assets/video/mp4/bbb_short.mp4
const remoteMP4 = sampleVideo.cdn;You can still access the path directly without await; but the file actually existing is not guarenteed.
import { sampleFiles } from 'sample-files';
// Big Buck Bunny - 10 second clip (mp4)
const sampleVideo = sampleFiles.video.mp4.bbb_short;
// Absolute path to the video on your machine
const __sampleVideo = sampleVideo.__path;
// BE SURE IT IS DOWNLOADED BEFORE YOU USE IT
if (await sampleVideo.isDownloaded()) {
// use the file
}Filtering
You can also filter all the sample files.
import { sampleFiles } from 'sample-files';
// array of all videos (in various formats)
const videos = sampleFiles.filter({ type: 'video' });
// array of all files that are over 10 MB
const largeFiles = sampleFiles.filter(file => file.bytes > 10000000);
// assets/video/mp4/bbb_short.mp4
const bbb_short_mp4 = sampleFiles.filter({ name: 'bbb_short', extension: 'mp4' }).pop();Contributing
If you have any files you would like to add, please create a PR.
Only files that may legally be posted here and published to NPM should be contributed. Please don't make me have to review licenses and stuff... don't put pirated files here.
