The original version, written by Artur Gabitov, expected Markdown and Bootstrap 4. This version requires Bootstrap 5 and HTML, not Markdown.
More information is available on my web site about this Jekyll plugin and my other Jekyll plugins.
Add this to your project's Gemfile
:
gem 'jekyll_bootstrap5_tabs'
Add this to your project's _config.yml
:
plugins:
- jekyll_bootstrap5_tabs
And then execute:
$ bundle
Bootstrap 5 is required.
One way to include Bootstrap 5 into a page within your project is to add the following HTML into the <head/>
tag:
<link href="https://cdn.jsdelivr.net/npm/[email protected]/dist/css/bootstrap.min.css" rel="stylesheet"
integrity="sha384-1BmE4kWBq78iYhFldvKuhfTAU6auU8tT94WrHftjDbrCEXSU1oBoqyl2QvZ6jIW3" crossorigin="anonymous">
...and add this to the bottom of the HTML file, within the <body/>
tag:
<script src="https://cdn.jsdelivr.net/npm/[email protected]/dist/js/bootstrap.bundle.min.js"></script>
See this working minimal Bootstrap 5 tab example
The jekyll_bootstrap5_tabs
plugin provides two new Liquid tags: tabs
and tab
.
Jekyll interprets the Liquid language when embedded into HTML pages.
For example, given the following content in a Jekyll page that has minimal front matter:
---
---
{% tabs demo %}
{% tab demo#Home %}
Home at last!
{% endtab %}
{% tab demo#Profile %}
Profile meeee...
{% endtab %}
{% tab demo#Messages %}
Messages - I have none
{% endtab %}
{% endtabs %}
The outer tabs tag has a name: demo
.
Conceptually, this name defines a namespace scope for the inner tab
tags,
but actually this version does not use the name for any purpose.
The inner tab
tags reference the outer tabs
tag (yes, this is redundant),
and introduces the name of the tab that it defines after the octothorpe (aka hash mark, number sign, and pound sign: #).
A Bootstrap 5 tab is created for every tab
tag, and the id
for each tag
is defined by the characters
following the octothorpe.
This id
is also displayed as the label for the tab
, so if you want it capitalized a certain way,
specify the tag capitalization in the tab
tag.
The current implementation does not allow spaces within tab labels. Instead, tab labels may only consist of one word each.
The jekyll_bootstrap5_tabs
plugin will generate code similar to the following.
<ul class="nav nav-tabs">
<li class="nav-item">
<a class="nav-link active" data-bs-toggle="tab" aria-current="page" href="#home">Home</a>
</li>
<li class="nav-item">
<a class="nav-link" data-bs-toggle="tab" aria-current="page" href="#profile">Profile</a>
</li>
<li class="nav-item">
<a class="nav-link" data-bs-toggle="tab" aria-current="page" href="#messages">Messages</a>
</li>
</ul>
<div class="tab-content">
<div class="tab-pane active" id="home" aria-labelledby="home-tab">
<editor_fold Home>
Home at last!
</editor_fold>
</div>
<div class="tab-pane" id="profile" aria-labelledby="profile-tab">
<editor_fold Profile>
Profile meeee...
</editor_fold>
</div>
<div class="tab-pane" id="messages" aria-labelledby="messages-tab">
<editor_fold Messages>
Messages - I have none
</editor_fold>
</div>
</div>
By default, the plugin output is not pretty-printed.
However, you can enable pretty-printing for a single set of tabs by including the pretty
keyword in the tabs
tag,
like this:
{% tabs demo pretty %}
... tab tags go here
{% endtabs%}
You can enable pretty-printing for the entire Jekyll site by adding the following to _config.yaml
:
jekyll_bootstrap5_tabs:
- pretty: true
$ rake build jekyll_bootstrap5_tabs.gemspec
jekyll_bootstrap5_tabs 1.0.0 built to pkg/jekyll_bootstrap5_tabs-1.0.0.gem.
The most recently built gem is provided in pkg/
.
$ gem install pkg/jekyll_bootstrap5_tabs-1.0.0.gem
Fetching slim-4.1.0.gem
Fetching temple-0.8.2.gem
Successfully installed temple-0.8.2
Successfully installed slim-4.1.0
Successfully installed jekyll_bootstrap5_tabs-1.0.0
Parsing documentation for temple-0.8.2
Installing ri documentation for temple-0.8.2
Parsing documentation for slim-4.1.0
Installing ri documentation for slim-4.1.0
Parsing documentation for jekyll_bootstrap5_tabs-1.0.0
Installing ri documentation for jekyll_bootstrap5_tabs-1.0.0
Done installing documentation for temple, slim, jekyll_bootstrap5_tabs after 0 seconds
3 gems installed
Now go use the gem in a Jekyll project!
I (Mike Slinn) wanted to understand more about how Artur Gabitov got the Slim language part to work. He only provided the end result, without any hint of how he had accomplished this. I took on the discovery of implementing a minimal development scaffold for the Slim Language. Check out the Slim Explorer!
After checking out the repo, run bin/setup
to install dependencies.
You can also run bin/console
for an interactive prompt that will allow you to experiment.
To install this gem onto your local machine, run:
$ rake install:local
The following also does the same thing:
$ bundle exec rake install
Examine the newly built gem:
$ gem info jekyll_bootstrap5_tabs
*** LOCAL GEMS ***
jekyll_bootstrap5_tabs (1.0.0)
Author: Mike Slinn
Homepage:
https://github.com/mslinn/jekyll_bootstrap5_tabs
License: MIT
Installed at: /home/mslinn/.gems
Jekyll plugin that enables Bootstrap 5 tabs in Jekyll 4 websites.
To release a new version,
-
Update the version number in
version.rb
. -
Commit all changes to git; if you don't the next step might fail with an unexplainable error message.
-
Run the following:
$ bundle exec rake release
The above creates a git tag for the version, commits the created tag, and pushes the new
.gem
file to RubyGems.org.
- Fork the project
- Create a descriptively named feature branch
- Add your feature
- Submit a pull request
The gem is available as open source under the terms of the MIT License.