lintel-contrib-popovers

Popovers for lintel.

Usage no npm install needed!

<script type="module">
  import lintelContribPopovers from 'https://cdn.skypack.dev/lintel-contrib-popovers';
</script>

README

lintel-contrib-popovers

Popovers for lintel.

npm Bower

Getting Started

This module requires Lintel.

If you haven't used Lintel before, be sure to check out the Getting Started guide, as it explains how to install and use this module. Once you're familiar with that process, you may install this module with this command:

bower install lintel-contrib-popovers --save

Once the module has been installed, you will have to load it in your main SASS file:

@import "bower_components/lintel-contrib-popovers/sass/popovers.scss"

This module also includes a JavaScript component, which you will have to load separately.

<script src="bower_components/lintel-contrib-popovers/dist/popovers.min.js" type="text/javascript"></script>

You can use wiredep or grunt-wiredep to automatically inject files in your build process.

Variables

Check the vars file in the sass folder to see the full list of variables you can customize.

$popover-include-states

Default value: true

Include styling for the default states.

$popover-padding-y & $popover-padding-x

Change the padding-top/bottom and padding-left/right.

Also available for finer control:
$popover-header-padding-*
$popover-body-padding-*
$popover-footer-padding-*

$popover-animate

Default value: $animate-fast

Default fade-in speed.

$popover-arrow-width

Default value: 15px

$popover-bg

Default value: #fff

$popover-border

Default value: $border-dark

$popover-border-radius

Default value: $border-radius-base

$popover-box-shadow

Default value: $box-shadow-light

$popover-text

Default value: $text-base

Popover font color.

$popover-z-index

Default value: $z-index-2xl

$popover--bg, $popover--border, $popover-*-text

Change the header, body, or footer background, border, and text color.

$popover-title-font-size

Default value: $font-size-h4

$popover-close-opacity

Default value: 0.4

$popover-close-padding-y

Default value: 0

$popover-close-padding-x

Default value: 0

$popover-*-min

Min-width for the default sizes (xs, sm, md, lg, xl). Change md for the default popover width.

Mixins

Check the mixins file in the sass folder to see how you can extend this module.

popover-state($bg, $border, $text) {

Creates a new popover state.

.popover-primary {
  @include popover-state(
    $bg: $popover-primary-bg,
    $border: $popover-primary-border,
    $text: $popover-primary-text
  );
}

JavaScript

Options

Name Type Default Description
onShow function Callback function to execute every time popover is shown.
onHide function Callback function to execute every time popover is hidden.
esc boolean true Close popover on escape key.
show boolean true Show popover when invoking .popover()

Methods

Name Parameters Description
toggle (options, relatedTarget) Toggle popover. Related target required first time popover is shown.
show (options, relatedTarget) Show popover. Related target required first time popover is shown.
hide Hide popover.

Events

Event Description
show.lt.popover Fires immediately before popover is shown. Can prevent popover from showing here. Trigger button (if provided) can be accessed under relatedTarget.
shown.lt.popover Fires immediately after popover is shown.
hide.lt.popover Fires immediately before popover is hidden. Can prevent popover from hiding here.
hidden.lt.popover Fires immediately after popover is hidden.

Data-attr

Add data-toggle="popover" and data-target="#selector" to a button/element. You can add additional options as data-attributes.

<button type="button" data-toggle="popover" data-target="#myPopover">
  Popover
</button>
<div id="myPopover" class="popover">
...
</div>

jQuery

Call the jQuery plugin on the popover, passing in any options and the related target (button).

var options = {
  placement: 'bottom',
  onShow: function(popover, button) {
    console.log('onShow', popover, button);
  },
  onHide: function(popover, button) {
    console.log('onHide', popover, button);
  }
};

$('#myButton').click(function(e) {
  $('#myPopover').popover(options, this); // this == button
});

Alternatively, you can use the default options:

$('#myButton').click(function(e) {
  $('#myPopover').popover('toggle', this); // this == button
});

Examples

Popover Template

<div class="popover" id="myPopover" tabindex="-1" role="dialog" aria-hidden="true">
  <div class="popover-content">
    <div class="popover-header">
      <button type="button" class="popover-close" data-toggle="popover-close" aria-label="Close"><span aria-hidden="true">&times;</span></button>
      <h1 class="popover-title">Popover Title</h1>
    </div>
    <div class="popover-body">
      <div class="form-group">
        <label class="form-label">
          Email
          <input class="form-control" type="text" placeholder="Email">
        </label>
      </div>
      <div class="form-group">
        <label class="form-label">
          Password
          <input class="form-control" type="password" placeholder="Password">
        </label>
      </div>
    </div>
    <div class="popover-footer">
      <div class="btn-group">
        <button class="btn" type="button">Cancel</button>
        <button class="btn btn-primary" type="button">OK</button>
      </div>
    </div>
  </div>
</div>

Popover Header

<div class="popover-header">
  <h1 class="popover-title">Popover Title</h1>
</div>

Popover Header with Linked Title

<div class="popover-header">
  <h1 class="popover-title">
    <a href="#" class="popover-title-link">Popover Title</a>
  </h1>
</div>

Popover Header with Close Button

<div class="popover-header">
  <button type="button" class="popover-close" data-toggle="popover-close" aria-label="Close"><span aria-hidden="true">&times;</span></button>
  <h1 class="popover-title">
    <a href="#" class="popover-title-link">Popover Title</a>
  </h1>
</div>

Popover Header with Right Side Actions

NOTE: There should be no whitespace after .popover-header-actions. See Fighting the Space Between Inline Block Elements.

<div class="popover-header">
  <div class="popover-header-actions">
    <div class="btn-group">
      <button class="btn" type="button">Cancel</button>
      <button class="btn btn-primary" type="button">OK</button>
    </div>
    <button type="button" class="popover-close" aria-label="Close"><span aria-hidden="true">&times;</span></button>
  </div><!--
  --><h1 class="popover-title">Popover Title</h1>
</div>

Popover Footer with Right Side Actions

NOTE: There should be no whitespace after .popover-footer-actions. See Fighting the Space Between Inline Block Elements.

<div class="popover-footer">
  <div class="popover-footer-actions">
    <div class="btn-group">
      <button class="btn" type="button">Cancel</button>
      <button class="btn btn-primary" type="button">OK</button>
    </div>
  </div><!--
  --><button class="btn" type="button">
    Left Button
  </button>
</div>

Contributing

In lieu of a formal styleguide, take care to maintain the existing coding style. Add unit tests for any new or changed functionality. Lint and test your code using Grunt.

License

Copyright (c) 2015 Marius Craciunoiu. Licensed under the MIT license.