npm package discovery and stats viewer.

Discover Tips

  • General search

    [free text search, go nuts!]

  • Package details

    pkg:[package-name]

  • User packages

    @[username]

Sponsor

Optimize Toolset

I’ve always been into building performant and accessible sites, but lately I’ve been taking it extremely seriously. So much so that I’ve been building a tool to help me optimize and monitor the sites that I build to make sure that I’m making an attempt to offer the best experience to those who visit them. If you’re into performant, accessible and SEO friendly sites, you might like it too! You can check it out at Optimize Toolset.

About

Hi, 👋, I’m Ryan Hefner  and I built this site for me, and you! The goal of this site was to provide an easy way for me to check the stats on my npm packages, both for prioritizing issues and updates, and to give me a little kick in the pants to keep up on stuff.

As I was building it, I realized that I was actually using the tool to build the tool, and figured I might as well put this out there and hopefully others will find it to be a fast and useful way to search and browse npm packages as I have.

If you’re interested in other things I’m working on, follow me on Twitter or check out the open source projects I’ve been publishing on GitHub.

I am also working on a Twitter bot for this site to tweet the most popular, newest, random packages from npm. Please follow that account now and it will start sending out packages soon–ish.

Open Software & Tools

This site wouldn’t be possible without the immense generosity and tireless efforts from the people who make contributions to the world and share their work via open source initiatives. Thank you 🙏

© 2024 – Pkg Stats / Ryan Hefner

@audapolis/webvtt-writer

v1.0.6

Published

A small library to create WebVTT (and SRT) files

Downloads

1,240

Readme

webvtt-writer

A library to create WebVTT (and SRT) files

This repo contains a library to create subtitle-files in the WebVTT and SRT formats which we created for audapolis.

Installation

npm install @audapolis/webvtt-writer

Usage

🏗️ Construction

First, you have to create a WebVtt-Instance. This represents one subtitle file.

import { WebVtt } from '@audapolis/webvtt-writer';

const minimal_vtt = new WebVtt();

You can optionally give it a text header:

const vtt = new WebVtt('Subtitles are cool');

Now you can start adding elements to you subtitle file:

Comments

Comments are an optional component that can be used to add information to a WebVTT file. Comments are intended for those reading the file and are not seen by users.[^mdn_comments]

[^mdn_comments]: https://developer.mozilla.org/en-US/docs/Web/API/WebVTT_API#webvtt_comments)

To add a comment you have to create a new VttComment instance and then add it to the WebVtt object:

import { VttComment } from '@audapolis/webvtt-writer';
const myComment = new VttComment('This is a comment\nIt can even be multiline');
vtt.add(myComment);

Cues

Cues are subtitle lines. Each cue has a start and end time and a payload -- the text that should be displayed. It may optionally also have

  • an identifier
  • cue settings
The simplest cue

Since every cue needs a start time, an end time and a payload, this is one of the simplest cues possible:

import { VttCue } from '@audapolis/webvtt-writer';
const mySimpleCue = new VttCue({
  startTime: 1,
  endTime: 2,
  payload: 'This will be shown\nincluding this second line',
});
vtt.add(mySimpleCue);

Start and end time are given in seconds.

Identifier

A cue may also have an identifier which can be used to reference this cue, for example for styling it. They do not have to be unique, but are often numbered.

const cueWithIdentifier = new VttCue({
  startTime: 3,
  endTime: 4,
  payload: 'This cue has an identifier',
  identifier: "Hey, i'm an identifier",
});
vtt.add(cueWithIdentifier);
Cue Settings

Cue settings are used to position the cue payload text. There are 5 cue settings, whose meanings and possible values are described here:

  • vertical
  • line
  • position
  • size
  • align

All of them are optional but if you want to, you can specify them like this:

import { VttCueSettings } from '@audapolis/webvtt-writer';

const mySettings = new VttCueSettings({ size: '50%' });
const cueWithSettings = new VttCue({
  startTime: 5,
  endTime: 120,
  payload: 'This cue has settings',
  settings: mySettings,
});
vtt.add(cueWithSettings);
Escaping and Payload Tags

The payload may not contain the characters - and < and the usage of > is not recommeneded. Instead their escape sequences should be used. Because of that webvtt-writer automatically escapes the payload and identifier.

However this means that you cannot use a payload which contains cue payload text tags, as they would be escaped as well. If you want to use payload tags, you can set payloadEscaped to true. This will disable automatic payload escaping. Warning: It is now your task to escape the payload text, so use escapeVttString widely. For example:

import { escapeVttString } from '@audapolis/webvtt-writer';

const cueWithoutEscaping = new VttCue({
  startTime: 130,
  endTime: 200,
  payload: `<b>${escapeVttString('This cue')}</b>${escapeVttString(' has cue text tags')}`,
  payloadEscaped: true,
});
vtt.add(cueWithoutEscaping);

✍️ Rendering the subtitles

To get the content of the subtitle file as a string, you can use .toString() on you WebVtt object:

const vttString = vtt.toString();
console.log(vttString);

From the examples above, you should get:

WEBVTT Subtitles are cool

NOTE This is a comment
It can even be multiline

00:00:01.000 --> 00:00:02.000
This will be shown
including this second line

Hey, i'm an identifier
00:00:03.000 --> 00:00:04.000
This cue has an identifier

00:00:05.000 --> 00:02:00.000 size:50%
This cue has settings

00:02:10.000 --> 00:03:20.000
<b>This cue</b> has cue text tags

This can now be written to a file, for example on nodejs like this:

fs.writeFileSync('subtitles.vtt', vttString);
SRT

You can also export the subtitles as an SRT file, which has broader software support. Note: Srt does not support some features of WebVTT. We know of at least:

  • header (including header text)
  • cue text tags
  • cue settings
  • comments

The header, cue settings and comments will simply be ignored when exporting to srt. Since cue text tags are not handled by this library, you have to take care to not add them if you want to create an srt file.

Knowing all this, you can render the srt version of using .toString('srt'):

const srtString = vtt.toString('srt');
console.log(srtString);

This should give you:

00:00:01.000 --> 00:00:02.000
This will be shown
including this second line

Hey, i'm an identifier
00:00:03.000 --> 00:00:04.000
This cue has an identifier

00:00:05.000 --> 00:02:00.000
This cue has settings

00:02:10.000 --> 00:03:20.000
<b>This cue</b> has cue text tags