Vocalize Audio Player
This project is an implementation of the Vocalize Audio Player
using HTML and JavaScript. It
allows you to
embed and control an audio player on a webpage, including the ability to dynamically change tracks, play all
tracks, and
handle VAST ads.
Table of Contents
Features
- Embed an audio player on your webpage
- Display a track list with play controls
- Supports both Playlist and Single tracks
- Dynamically change the track list
- Supports pre-roll, mid-roll and post-roll ADs via VAST Tags integration
- Supports both Live Audio broadcasts (.m3u8) as well other formats such as .mp4, .webm, .mp3, .wav, .ogg, .aac.
Demo
data:image/s3,"s3://crabby-images/41708/417084e10e79c7aee19089849830b55d827e62c3" alt="Savara"
Savara
Artist
Installation
To use the Vocalize Audio Player
in your project,
- Create a publisher account to get access credentials
- include the following dependencies in your HTML:
<!-- Scripts -->
<script src="https://d3fie7xdql0qop.cloudfront.net/assets/player/main.bundle.js"></script>
Usage
Here’s an example of how to use the Vocalize Audio Player:
1. Single Track
<!--HTML Structure-->
<div class="container pt-5">
<div class="card border-0 border-bottom rounded-0">
<div class="card-body d-flex align-items-center">
<button class="btn btn-outline-success" id="vocalize-track" data-id="radio-citizen">
<i class="bi-play"></i>
</button>
<div class="flex-grow-1 ps-2">
<h5 class="fs-6 mb-0">Radio Citizen</h5>
<p class="fs-6 mb-0"><small>Royal Media Services</small></p>
</div>
</div>
</div>
<div id="vocalize-container" class="mt-3"></div>
</div>
<!--Javascript Initialization-->
<script>
document.addEventListener("DOMContentLoaded", () => {
window.VocalizeAudio.init({
containerId: 'vocalize-container',
style: {
theme: 'light-theme',
},
tracks: [{
id: 'radio-citizen',
name: "Radio Citizen",
artist: "Radio Citizen",
imgUrl: "https://d3fie7xdql0qop.cloudfront.net/audio/radio-citizen.png",
link: "https://radiocitizen-atunwadigital.streamguys1.com/radiocitizen/playlist.m3u8",
}],
vastUrl: "XXXX",
auth: {
"X-Api-Publisher-Id": "XXXX",
"X-Api-Publisher-Secret": "XXXX",
}
});
});
</script>
</body>
2. Multiple Tracks
HTML Structure
<!--HTML Structure-->
<div class="container pt-5">
<div class="card border-0 border-top border-bottom rounded-0">
<div class="card-body d-flex align-items-center">
<h5 class="fs-6 mb-0">Savara</h5>
<p class="fs-6 mb-0"><small>Artist</small></p>
<button class="btn btn-outline-success" id="vocalize-play-all">
<i class="bi-play fw-bolder"></i> Play All
</button>
</div>
</div>
<div id="track-list"></div>
<div id="vocalize-container" class="mt-3"></div>
</div>
<!--Javascript Initialization-->
<script>
document.addEventListener("DOMContentLoaded", () => {
const tracks = [
{
id: 'reggae-ya-kinyozi',
name: "Reggae Ya Kinyozi",
artist: "Savara",
imgUrl: "https://d3fie7xdql0qop.cloudfront.net/audio/Savara-og_image.webp",
link: "https://d3fie7xdql0qop.cloudfront.net/audio/savara.mp3",
},
{
id: 'parapanda',
name: "Parapanda",
artist: "Ari Barokos",
imgUrl: "https://d3fie7xdql0qop.cloudfront.net/audio/Savara-og_image.webp",
link: "https://d3fie7xdql0qop.cloudfront.net/audio/Parapanda.mp3",
},
{
id: 'radio-citizen',
name: "Radio Citizen",
artist: "Radio Citizen",
imgUrl: "https://d3fie7xdql0qop.cloudfront.net/audio/radio-citizen.png",
link: "https://radiocitizen-atunwadigital.streamguys1.com/radiocitizen/playlist.m3u8",
}
];
const trackList = document.getElementById('track-list');
tracks.forEach(track => {
const trackElement = `
<div class="card border-0 border-bottom rounded-0">
<div class="card-body d-flex align-items-center">
<button class="btn btn-outline-success" id="vocalize-track" data-id="${track.id}">
<i class="bi-play"></i>
</button>
<div class="flex-grow-1 ps-2">
<h5 class="fs-6 mb-0">${track.name}</h5>
<p class="fs-6 mb-0"><small>${track.artist}</small></p>
</div>
</div>
</div>
`;
trackList.innerHTML += trackElement;
});
window.VocalizeAudio.init({
containerId: 'vocalize-container',
style: {
theme: 'light-theme',
},
tracks,
vastUrls: [
{ url: 'https://example.com/vast1.xml', weight: 0.5 },
{ url: 'https://example.com/vast2.xml', weight: 0.3 },
{ url: 'https://example.com/vast3.xml', weight: 0.2 },
],
auth: {
"X-Api-Publisher-Id": "XXXX",
"X-Api-Publisher-Secret": "XXXX",
}
});
});
</script>
API
1. Initialize the Vocalize Audio Player.
window.VocalizeAudio.init(options)
Parameters
Paramater | Mandatory/Optional | Description | Example |
---|---|---|---|
containerId | Mandatory | The ID of the container where the player will be rendered. | containerId: 'vocalize-container' |
style.theme | Optional | The theme for the player (e.g., light-theme , dark-theme ). |
style.theme: 'light-theme' |
tracks | Array | An array of track that can be initialized when initializing the player. | tracks: [{...}] |
vastUrls | Array, Optional | The URLS for VAST ads and associated weights | vastUrls: [
|
auth.X-Api-Publisher-Id | String, Mandatory | Your publisher ID. | auth.X-Api-Publisher-Id: "XXXX" |
auth.X-Api-Publisher-Secret | String, Mandatory | Your publisher Secret. | auth.X-Api-Publisher-Secret: "XXXX" |
2. Plays a specific track by its ID.
window.VocalizeAudio.play(trackId)
:Parameters:
Paramater | Mandatory/Optional | Description | Example |
---|---|---|---|
trackId | Optional | The ID of the track to play. If omitted, plays the first track in the list. | window.VocalizeAudio.play(radio-citizen) |
- trackId (string, optional): The ID of the track to play. If omitted, plays the first track in the list.
3. Update list of tracks to be played
-
window.VocalizeAudio.setTracks(tracks)
const newTracks = [
{
}, ];id: 'new-track-1', name: 'New Track 1', artist: 'New Artist', imgUrl: 'https://example.com/new-track-1.jpg', link: 'https://example.com/new-track-1.mp3',
window.VocalizeAudio.setTracks(newTracks);
4. Unloads the audio player for cleanup purposes
window.VocalizeAudio.unload():
<script>
document.addEventListener('pagehide', window.VocalizeAudio.unload());
document.addEventListener('unload', window.VocalizeAudio.unload());
</script>
Notes
- Ensure that you replace 'YOUR_PUBLISHER_ID' and 'YOUR_PUBLISHER_SECRET' with your actual authentication credentials.
- The player supports both audio files and streaming URLs (e.g., .m3u8, .mp4, .webm, .mp3, .wav, .ogg, .aac).
- Customize the HTML and CSS as needed to fit the design of your website.