Error

The error directive provides a template that allows other components to display error messages when errors occur. The parent bb-error directive can contain multiple directives, and each one is optional.

Error settings

  • bb-error — Wraps the error message in a SKY UX-themed container.
    • bb-error-image — Specifies an image to display in the error message.
    • bb-error-title — Specifies a title to display in the error message.
    • bb-error-description — Specifies a description to provide additional details in the error message.
    • bb-error-action — Specifies an action to include in the error message. For example, you can include a button to reload the page or to refresh data.
    • bb-error-type — Attribute to specify a set of pre-defined bb-error-image, bb-error-title, and bb-error-description directives. The user can provide bb-error-image, bb-error-title, and bb-error-description directives to override any of the pre-defined types. It can have the following values, and each of these values can also be applied as an error-type for bb-error-image, bb-error-title, and bb-error-description individually:
      • broken — An error indicating that some functionality on the page is broken.
      • construction — An error indicating that some functionality on the page is under construction.
      • notFound — An error indicating that a page was not found.

In addition to the directive, the error component includes a service that can display simple error messages in a modal window.

Error modal settings

  • bbErrorModal — The service to inject in order to display an error message in a modal window.
    • show(options) — The function to call to display the error modal. The options parameter supports the following properties:
      • errorTitle — Specifies a title to display in the error message.
      • errorDescription — Specifies a description to provide additional details in the error message.

Demo

Pre-defined error types


Custom error content

{{errorCtrl.customErrorTitle}} {{errorCtrl.customErrorDescription}}

Markup

<div ng-controller="ErrorTestController as errorCtrl" ng-cloak>
  <h3>Pre-defined error types</h3>
  <select ng-model="errorCtrl.errorType">
    <option value="broken">Broken</option>
    <option value="notFound">Not found</option>
    <option value="construction">Construction</option>
  </select>
  <bb-error bb-error-type="{{errorCtrl.errorType}}">
    <bb-error-action>
      <button type="button" class="btn-primary btn" ng-click="errorCtrl.action()">{{errorCtrl.actionName}}</button>
    </bb-error-action>
  </bb-error>

  <hr />
  <h3>Custom error content</h3>
  <bb-error>
    <bb-error-image>
      <img role="presentation" src=''/>
    </bb-error-image>
    <bb-error-title>
      {{errorCtrl.customErrorTitle}}
    </bb-error-title>
    <bb-error-description>
      {{errorCtrl.customErrorDescription}}
    </bb-error-description>
    <bb-error-action>
      <button type="button" class="btn-primary btn" ng-click="errorCtrl.action()">{{errorCtrl.customActionName}}</button>
    </bb-error-action>
  </bb-error>

  <hr />
  <button type="button" class="btn btn-primary" ng-click="errorCtrl.openModal()">Open modal</button>
</div>

JavaScript

/*global angular, alert */
(function () {
    'use strict';
    function ErrorTestController(bbErrorModal) {
        var vm = this;

        vm.errorTitle = 'A title thing.';
        vm.errorDescription = 'Try to refresh this page, or come back later.';

        vm.customErrorTitle = 'Custom error title';
        vm.customErrorDescription = 'Custom error description';

        vm.action = function () {
            alert('action clicked!');
        };

        vm.actionName = 'Refresh';
        vm.customActionName = 'Custom action';

        vm.openModal = function () {
            bbErrorModal.open({
                errorTitle: vm.errorTitle,
                errorDescription: vm.errorDescription
            });
        };

        vm.errorType = 'broken';
    }

    ErrorTestController.$inject = ['bbErrorModal'];

    angular.module('stache')
        .controller('ErrorTestController', ErrorTestController);

}());