An open API service indexing awesome lists of open source software.

https://github.com/podlove/chapters

Elixir library to parse and format podcast chapters marks
https://github.com/podlove/chapters

elixir elixir-library podcasting

Last synced: 2 months ago
JSON representation

Elixir library to parse and format podcast chapters marks

Awesome Lists containing this project

README

          

# Chapters

[![Build Status](https://travis-ci.org/podlove/chapters.svg?branch=master)](https://travis-ci.org/podlove/chapters)

[Online Documentation](https://hexdocs.pm/chapters).
[Github Changelog](https://github.com/podlove/chapters/blob/master/CHANGELOG.md)

Podcast chapter parser and formatter.

Supports:

- [Podlove Simple Chapters](https://podlove.org/simple-chapters/) (xml/psc)
- mp4chaps
- JSON

[Changelog](changelog.html)

## Basic Usage

Decode from mp4chaps

```elixir
iex(1)> chapters = Chapters.decode(~S"""
...(1)> 00:00:00 Intro
...(1)> 00:01:59 Podlove
...(1)> """, :mp4chaps)
[
%Chapters.Chapter{href: nil, image: nil, start: 0, title: "Intro"},
%Chapters.Chapter{
href: "http://podlove.org/",
image: nil,
start: 119000,
title: "Podlove"
}
]

```

Encode to PSC

```elixir
iex> Chapters.encode(chapters, :psc) |> IO.puts


```

Encode to mp4chaps

```elixir
iex> Chapters.encode(chapters, :mp4chaps) |> IO.puts
00:00:00.000 Intro
00:01:59.000 Podlove
```

Encode to JSON

```elixir
iex> Chapters.encode(chapters, :json) |> IO.puts
[{"start":"00:00:00.000","title":"Intro"},{"start":"00:01:59.000","title":"Podlove","href":"http://podlove.org/"}]
```

## Installation

The package can be installed by adding `chapters` to your list of dependencies in `mix.exs`:

```elixir
def deps do
[
{:chapters, "~> 1.0"}
]
end
```

## License

Chapters is [MIT Licensed][license].

[license]: https://github.com/podlove/chapters/blob/master/LICENSE