<div class="container">

  <section id="header">
    <div class="page-header">
      <h1>Bootstrap Timeline with JS Editor</h1>
    </div>
  </section>

  <article id="timeline">
    <ul class="timeline" id="bSTime">
      <li>
        <div class="timeline-badge"><i class="glyphicon glyphicon-check"></i></div>
        <div class="timeline-panel">
          <div class="timeline-heading">
            <h4 class="timeline-title">Sample Timeline Post TITLE</h4>
            <p><small class="text-muted"><i class="glyphicon glyphicon-time"></i> September 25, 2016</small></p>
          </div>
          <div class="timeline-body">
            <p>This is the BODY of a sample Timeline Panel. You can create more panels using the editor below.</p>
          </div>
        </div>
      </li>

      <li class="timeline-inverted">
        <div class="timeline-badge warning"><i class="glyphicon glyphicon-credit-card"></i></div>
        <div class="timeline-panel">
          <div class="timeline-heading">
            <h4 class="timeline-title">Another Sample</h4>
          </div>
          <div class="timeline-body">
            <p>This is another Timeline Panel.  The icon along the Timeline Bar is the BADGE.  This one is the default badge, but you could customize it adding the Boostrap Glyphicon code.</p>
            <p>You could have a second paragraph, too.</p>
          </div>
        </div>
      </li>

      <li>
        <div class="timeline-badge danger"><i class="glyphicon glyphicon-credit-card"></i></div>
        <div class="timeline-panel">
          <div class="timeline-heading">
            <h4 class="timeline-title">Title</h4>
          </div>
          <div class="timeline-body">
            <p>Body.</p>
          </div>
        </div>
      </li>

      <li class="timeline-inverted">
        <div class="timeline-badge success"><i class="glyphicon glyphicon-barcode"></i></div>
        <div class="timeline-panel">
          <div class="timeline-heading">
            <h4 class="timeline-title">Title</h4>
          </div>
          <div class="timeline-body">
            <p>Body.</p>
          </div>
        </div>
      </li>

      <li>
        <div class="timeline-badge info"><i class="glyphicon glyphicon-floppy-disk"></i></div>
        <div class="timeline-panel">
          <div class="timeline-heading">
            <h4 class="timeline-title">Title</h4>
          </div>
          <div class="timeline-body">
            <p>Body.</p>
            <hr>
            <div class="btn-group">
              <button type="button" class="btn btn-primary btn-sm dropdown-toggle" data-toggle="dropdown">
              <i class="glyphicon glyphicon-cog"></i> <span class="caret"></span>
            </button>
              <ul class="dropdown-menu" role="menu">
                <li><a href="#">Action</a></li>
                <li><a href="#">Another action</a></li>
                <li><a href="#">Something else here</a></li>
                <li class="divider"></li>
                <li><a href="#">Separated link</a></li>
              </ul>
            </div>
          </div>
        </div>
      </li>

      <li class="timeline-inverted">
        <div class="timeline-badge success"><i class="glyphicon glyphicon-thumbs-up"></i></div>
        <div class="timeline-panel">
          <div class="timeline-heading">
            <h4 class="timeline-title">Title</h4>
          </div>
          <div class="timeline-body">
            <p>Body</p>
          </div>
        </div>
      </li>

    </ul>

  </article>

  <hr>

  <section id="timelineEditor">
    <form class="editorForm">

      <div class="form-group">
        <label for="newPostTitle">Title:</label>
        <input type="text" class="form-control" id="newPostTitle" placeholder="Post Title Here">
      </div>

      <div class="form-group">
        <label for="newPostBody">Body:</label>
        <textarea class="form-control" id="newPostBody" placeholder="Post Content Here"></textarea>
      </div>

      <div class="form-group">
        <label for="newPostGlyphicon">Bootsrap Glyphicon Badge:</label>
        <input type="text" class="form-control" id="newPostGlyphicon" placeholder="Input Glyphicon Name Here or Use Default">
      </div>

      <div class="form-group">
        <button type="button" class="btn btn-outline-primary btn-lg"><span class="glyphicon glyphicon-ok-sign" aria-hidden="true"></span> Submit New Post
        </button>
      </div>

    </form>

  </section>

</div>
/* */

.editorForm {
  width: 80%;
}

.editorForm label {
  color: #900;
}

.editorForm textarea, .editorForm input {
  background-color: rgba(005, 101, 151, .3);
  color: #FFF;
  border: none;
  border-radius: 4px;
}

.editorForm textarea {
  height: 150px;
}

@media screen and (max-width: 668px) {
  .editorForm {
    width: 100%;
  }
}

/* Bootstrap Timeline CSS */

.timeline {
  list-style: none;
  padding: 20px 0 20px;
  position: relative;
}

.timeline:before {
  top: 0;
  bottom: 0;
  position: absolute;
  content: " ";
  width: 3px;
  background-color: #eeeeee;
  left: 50%;
  margin-left: -1.5px;
}

.timeline > li {
  margin-bottom: 20px;
  position: relative;
}

.timeline > li:before,
.timeline > li:after {
  content: " ";
  display: table;
}

.timeline > li:after {
  clear: both;
}

.timeline > li:before,
.timeline > li:after {
  content: " ";
  display: table;
}

.timeline > li:after {
  clear: both;
}

.timeline > li > .timeline-panel {
  width: 46%;
  float: left;
  border: 1px solid #d4d4d4;
  border-radius: 2px;
  padding: 20px;
  position: relative;
  -webkit-box-shadow: 0 1px 6px rgba(0, 0, 0, 0.175);
  box-shadow: 0 1px 6px rgba(0, 0, 0, 0.175);
}

.timeline > li > .timeline-panel:before {
  position: absolute;
  top: 26px;
  right: -15px;
  display: inline-block;
  border-top: 15px solid transparent;
  border-left: 15px solid #ccc;
  border-right: 0 solid #ccc;
  border-bottom: 15px solid transparent;
  content: " ";
}

.timeline > li > .timeline-panel:after {
  position: absolute;
  top: 27px;
  right: -14px;
  display: inline-block;
  border-top: 14px solid transparent;
  border-left: 14px solid #fff;
  border-right: 0 solid #fff;
  border-bottom: 14px solid transparent;
  content: " ";
}

.timeline > li > .timeline-badge {
  color: #fff;
  width: 50px;
  height: 50px;
  line-height: 50px;
  font-size: 1.4em;
  text-align: center;
  position: absolute;
  top: 16px;
  left: 50%;
  margin-left: -25px;
  background-color: #999999;
  z-index: 100;
  border-top-right-radius: 50%;
  border-top-left-radius: 50%;
  border-bottom-right-radius: 50%;
  border-bottom-left-radius: 50%;
}

.timeline > li.timeline-inverted > .timeline-panel {
  float: right;
}

.timeline > li.timeline-inverted > .timeline-panel:before {
  border-left-width: 0;
  border-right-width: 15px;
  left: -15px;
  right: auto;
}

.timeline > li.timeline-inverted > .timeline-panel:after {
  border-left-width: 0;
  border-right-width: 14px;
  left: -14px;
  right: auto;
}

.timeline-badge.primary {
  background-color: #2e6da4 !important;
}

.timeline-badge.success {
  background-color: #3f903f !important;
}

.timeline-badge.warning {
  background-color: #f0ad4e !important;
}

.timeline-badge.danger {
  background-color: #d9534f !important;
}

.timeline-badge.info {
  background-color: #5bc0de !important;
}

.timeline-title {
  margin-top: 0;
  color: inherit;
}

.timeline-body > p,
.timeline-body > ul {
  margin-bottom: 0;
}

.timeline-body > p + p {
  margin-top: 5px;
}

External CSS

  1. https://cdnjs.cloudflare.com/ajax/libs/twitter-bootstrap/3.3.7/css/bootstrap.min.css

External JavaScript

This Pen doesn't use any external JavaScript resources.