You might know the timestamps feature on YouTube, but how can you have it for videos on your site? Rather than waiting for a complete video to run from zero seconds to the point you are referring to, timestamps enable you to jump to any second of the video directly where a timestamp regulates. You can add timestamps as many as the parts you want to have fast access. Let’s create YouTube video timestamps using MB Views!
This is an example I’d like to create today:

Video Version
Before Getting Started
In this practice, I assume that each video is saved in a post of a custom post type. To make the timestamps easier, we should save the video URL in a custom field instead of in the content of the post. Then, we will use custom fields created with Meta Box to input timestamps and short descriptions for them.
So, we need the Meta Box core plugin to have a framework to create custom fields, and also the custom post type if any. You can download it directly from wordpress.org.
Besides, we’ll use some Meta Box extensions for more advanced features as follows:
- MB Views: to create and style the template for the page without touching the theme files;
- MB Builder: to have a UI on the back end to create custom fields.
You can install them individually or use Meta Box AIO.
Create Custom Fields
As mentioned, I’ll create a field to input the ID of the video. It is a part of the video URL, and we just need this for quick and short saving. You can find this ID on the URL of the video as you can see here.

The Timestamp and Description will be grouped in pairs and were set to add more than one timestamp for each video, as follows.

Now, move to the Meta Box > Custom Fields to create them.

Choose the Text field for the video ID.

Insert a Group field for timestamps.

We should set it to be collapsible since there may be too many timestamps you want to add. Also, turn on the Cloneable option to set the group to be cloneable. This helps to add multiple pairs of timestamps and its descriptions.

After configuring all the fields, move to the Settings tab. Choose Location as Post type and select a post type to which you want to assign these fields.

Then, go to the post editor, and you will see the fields displayed.

Display the Timestamps
Get Timestamps from Custom Fields
As I said, I will not add video directly to the post as usual. I will use the MB Views to display it, as well as along with the timestamps.
Go to MB Views to create a template for it.

As usual, to get data from custom fields, we just go to insert the wanted field from this list.

The timestamps are in a cloneable group, so whenever you click to the group, a loop will be generated in the template.

Then, insert the subfield inside.

Insert the Video ID field as the same.

Now, move to the settings of the view, since we will display the timestamps in each post, choose the type as Singular.

And choose the post type you want.

Now, go to a post on frontend, and you will see the result. Still there is no video displayed, and all of the timestamps just are text now.

So, we should go back to the template and customize the code a bit more to display the video and make the timestamps work as we expected.
Convert Data for Using JavaScript
We should use JavaScript to display the video from the video ID, as well as display timestamps in the clickable style and make them work on the video. That’s why we are going to have an array to store the values and transfer them to a HTML tag for using JavaScript later.
Back to the template created with MB Views. First, create an array to store the timestamps and descriptions. Add this code at the first line.
{% set TimestampsArray = [] %}

Then, add these lines of code to pass the value from custom fields to the array.
{% set TimestampsArray = TimestampsArray|merge( 
        [
            { 
                "timestamp": ,
                "description":
            }
        ] ) %}

 {{clone.timestamp}} and  {{clone.description}} are the ones to get data from custom fields. So, move them to the 6th and 7th lines as follows.

Also remove the {{ }} symbols.

I also have another array to store the video ID along with the timestamps and description.

{% 
    set TimestampsObject = 
    [
        {"id": },
        {
            'Timestamps': 
        }
    ]
%}
Also move  {{ post.video_id }} to assign it to the array.

Fill in the name of the first array to the  Timestamps key, then the timestamps and description from it will be get and pass to the new array as well.

Add the code  <div id="video_player"></div> . This is an HTML ID that’ll be used to display video using JavaScript later.

There’s nothing displayed in the template so far.
To display the timestamps, insert fields from the list on the right sidebar once again.

Add an A tag to the line where we display the timestamps information:
<li><a href="javascript:void(0);" onclick="setCurrentTime({{loop.index0}})"> </a></li>

 onclick="setCurrentTime({{loop.index0}})" is an attribute that helps to trigger the moment someone clicks on the timestamp and its description. It’ll let us know where they want to jump to on the timeline of the player.

As well as, based on that event, we will force the player to play from the regulated time.
Next, for JavaScript, add this line:
<div id="Timestamps_ID" data-timestamp='{{TimestampsObject|json_encode()}}'></div>
It’s to create an HTML tag with the data-timestamp attribute to obtain data from the created array.

Add JavaScript
As mentioned, we use JavaScript to display the video, and make the timestamps work on the video as well.
Still in the template created with MB Views, move to the JavaScript tab.
Add some codes as follows to convert the JSON that we created in the template to an array containing JavaScript objects named  TimestampsObjectData.

var getTimestampsID = document.getElementById("Timestamps_ID");
var TimestampsObjectData = JSON.parse(getTimestampsID.getAttribute("data-timestamp"));
We must do this to make the following scripts run.
The next part is to initialize a YouTube player based on YouTube API.

var tag = document.createElement('script');
tag.src = "https://www.youtube.com/iframe_api";
var firstScriptTag = document.getElementsByTagName('script')[0];
firstScriptTag.parentNode.insertBefore(tag, firstScriptTag);
var player;
function onYouTubeIframeAPIReady() {
    my_player = new YT.Player('video_player', {
        videoId: TimestampsObjectData[0].id,
        host: 'http://www.youtube.com',
    });
}
 video_player is the HTML ID that I created in the template.

 videoId: TimestampsObjectData[0].id, helps to get the ID of the video from the  TimestampsObjectData array.

 [0].id stipulates that only the ID will be get.

Also in this script, I created  my_player JavaScript object converted from the player. This object will help to create a JavasScript action to jump to a specific position on the timeline.

Next, we should convert time to seconds using the following lines of code. We usually use 0:00 - 0:30 - 1:13 format for video timing. Then, we should convert it to 0 - 30 - 73 format.

// Converting Time to Seconds
function hmsToSecondsOnly(str) {
    var p = str.split(':'),
        s = 0, m = 1;
    while (p.length > 0) {
        s += m * parseInt(p.pop(), 10);
        m *= 60;
    }
    return s;
}
In the template, we had an attribute  onclick="setCurrentTime({{loop.index0}})" to trigger which timestamp the user clicked on. So now, we have some lines to admit that moment and force the player to play from the clicked timestamp.

function setCurrentTime(slideNum) {
    Timeobject = TimestampsObjectData[1].Timestamps;
    Timeobject = Timeobject.map(function (item) {
        return hmsToSecondsOnly(item.timestamp)
    })
    my_player.seekTo(Timeobject[slideNum]);
}
 setCurrentTime(slideNum) is the mentioned attribute.

 Timeobject = TimestampsObjectData[1].Timestamps; is to get data about the timestamps from the  TimestampsObjectData object.

The values stored in this array will have the form as [0:00,Intro ; 0:30,Before Getting Started ; 1:13,Create a Custom Post Type]. It includes the timestamps and their descriptions. However, we need the timestamps only for this action. Then, we have the below lines to remove the description.

As well as the return values will be converted to seconds format. And now, the array will be [0,30,73] format.

From those values in the array,  [slideNum] is from the attribute  onclick="setCurrentTime({{loop.index0}}) , and will check it matches to which value in the array. Then, it will find out exactly the position on the timeline of the player that the user wants to jump to.
![[slideNum] is from the attribute onclick="setCurrentTime({{loop.index0}})](https://imgur.elightup.com/skWhrxr.png)
 my_player.seekTo(Timeobject[slideNum]); will help to jump to that position.

Now, go to a post on frontend, you will see the video player frame, along with the timestamp. Whenever you click on a timestamp, the player will jump to the corresponding time on the timeline and play.

Style the Page
If you want to change the displaying of the timestamp, back to the template and custom the code one more time. I’m adding some headings, and classes.

<h2>Video Version</h2>
<div class="video-container">
    <div id="video_player"></div>
    <div class="video-timestamp">
        <div id="Timestamps_ID" data-timestamp='{{TimestampsObject|json_encode()}}'></div>
        <strong>Timestamps:</strong>
        <ul>
            {% for clone in post.timestamps %}
                <li><a href="javascript:void(0);" onclick="setCurrentTime({{loop.index0}})"> {{ clone.timestamp }} {{ clone.description }}</a></li>
            {% endfor %}
        </ul>
    </div>
</div>
And now, using CSS to change the style.

.video-container ul{
    list-style: none;
    padding-left: 0px;
}
.video-container ul li {
    padding:5px 0px;
}
Now, go back to the page on the frontend, you’ll see a new look of the page.

Last Words
Creating video timestamps helps improve user experience and show up more prominently in video search results. The simplest method is to add a timestamp using MB Views. Let’s try and enjoy it! If you want to suggest any tutorials, feel free to leave a comment and keep track of our blog. Thanks!
- MB Views: How To Display Relationships?
- How to Create Reusable Template Parts in WordPress
- How to Create YouTube Video Timestamps on WordPress Website - P1 - Using MB Views
- How to Randomize Hero Image in WordPress - Using MB Views
- How to Display a Video Playlist - Using MB Views
- How to Create a Reading Progress Bar in WordPress Posts - P1 - Using MB Views
- How to Create Reading Time to Your WordPress Posts - Using MB Views
- How to Add Code to Header and Footer in WordPress - Using MB Views
- How to Create Charts in Posts - Using MB Views
- How to Create a Dynamic Horizontal Posts Accordion - Using MB Views
- How to Manage & Display Course Schedule With Filters
- How to Create the Rating Feature for a WordPress Website - Using MB Views
- Author Bio
- Better 404 Page
- Blogs for Developers
- Building a Simple Listing Website with Filters
- Building an Event Website
- Building Forms with MB Frontend Submission
- Coding
- Create a Chronological Timeline
- Custom Fields Fundamentals
- Design Patterns
- Displaying Posts with Filters
- Download and Preview Buttons
- Dynamic Banners
- Dynamic Landing Page
- FAQs Page
- Featured Products
- Filter Posts by Relationships
- Full Site Editing
- Google Fonts
- Gutenberg
- Hotel Booking
- Latest Products
- Logo Carousel
- MB Builder Applications
- MB Group Applications
- MB Views Applications
- Most Viewed Posts
- Opening Hours
- OTA Website
- Pricing Table Page
- Product Page
- Product Variations
- Querying and Showing Posts by Custom Fields
- Recipe
- Related Posts via Relationship
- Restaurant Menus
- SEO Analysis
- Simple LMS
- Speed Up Website
- Taxonomy Thumbnails
- Team Members
- User Profile
- Video Gallery
 
	
	 How to Have a Chronological Timeline in WordPress - P2 - Using MB Views
							How to Have a Chronological Timeline in WordPress - P2 - Using MB Views						 How to Create a Timeline Page - P1 - Using Meta Box and Bricks
							How to Create a Timeline Page - P1 - Using Meta Box and Bricks						 How to Display a Video Playlist - Using MB Views
							How to Display a Video Playlist - Using MB Views