• Stars
    star
    302
  • Rank 138,030 (Top 3 %)
  • Language
    JavaScript
  • License
    Apache License 2.0
  • Created over 11 years ago
  • Updated almost 7 years ago

Reviews

There are no reviews yet. Be the first to send feedback to the community and the maintainers!

Repository Details

AngularJS directive for the bootstrap-switch jQuery plugin.

angular-bootstrap-switch

Bower version NPM version Build Status Apache License

AngularJS directive for the bootstrap-switch jQuery plugin.

Usage

Installation

$ bower install angular-bootstrap-switch

or

$ npm install angular-bootstrap-switch

This will install AngularJS, jQuery, and the original bootstrap-switch.

Registration

To be able to use the directive, you need to register the angular-bootstrap-switch module as a dependency:

angular.module('yourModule', ['frapontillo.bootstrap-switch'
    // other dependencies
]);

Directive

The directive can work on both element and attribute levels. The following example contains all of the supported attributes:

<input
    bs-switch
    ng-model="isSelected"
    type="checkbox"
    switch-active="{{ isActive }}"
    switch-readonly="{{ isReadonly }}"
    switch-size="{{ size }}"
    switch-animate="{{ animate }}"
    switch-label="{{ label }}"
    switch-icon="{{ icon }}"
    switch-on-text="{{ onLabel }}"
    switch-off-text="{{ offLabel }}"
    switch-on-color="{{ on }}"
    switch-off-color="{{ off }}"
    switch-radio-off="{{ radioOff }}"
    switch-label-width="{{ labelWidth }}"
    switch-handle-width="{{ handleWidth }}"
    switch-inverse="{{ inverse }}"
    switch-change="onChange()"
    ng-true-value="'yep'"
    ng-false-value="'nope'">

Short doc for all of the attributes:

  • ng-model, the value to bind the switch to
  • type, has to be one of checkbox and radio. This value is mandatory and must be a string, as it cannot be changed once set (see this answer on StackOverflow). If you choose radio, be sure to follow the AngularJS radio specs, meaning you have to specify the same ngModel and a different value or ng-value attribute for each radio
  • switch-active, determines if the switch is enabled or not (changes the inner input's disabled attribute)
  • switch-readonly, determines if the switch is read-only or not (changes the inner input's readonly attribute)
  • switch-size, can be the empty string as default, mini, small, large
  • switch-animate, determines if the switch animates when toggled
  • switch-on-text, sets the positive (checked) text
  • switch-off-text, sets the negative (unchecked) text
  • switch-on-color, sets the positive (checked) class, can be primary (as default), default, info, success, warning, danger
  • switch-off-color, sets the negative (unchecked) class, can be default (as default), primary, info, success, warning, danger
  • switch-label, sets the toggle label
  • switch-icon, sets the toggle icon (e.g. icon-save)
  • switch-wrapper, sets the main container class, use a falsy value to fall back to the default one
  • switch-radio-off, allows a radio button to be unchecked by the user (from true to false)
  • switch-label-width, sets the width of the middle label
  • switch-handle-width, sets the width of both handles
  • switch-inverse, inverts the on/off handles
  • switch-change, evaluates an expression whenever the model value changes. Instead, ng-change will fire when view value changes (e.g from a click)

Migrating from bootstrap-switch~2

Read the CHANGELOG information to learn what's different in 0.3.0.

Examples

The example folder shows a simple working demo of the switch.

Compatibility

IE8 requires you to attach the directive to an <input type="checkbox"> or <input type="radio">. Due to some incompatibilities it is not possible to use a custom tag or div instead.

Development

Test and build

To build the directive yourself you need to have NodeJS. Then do the following:

$ npm install -g grunt-cli bower karma
$ npm install
$ bower install
$ grunt test-travis
$ grunt build

Contribute

To contribute, please follow the generic AngularJS Contributing Guidelines, with the only exception to send the PR to the develop branch instead of master.

Author

Francesco Pontillo (mailto:[email protected])

License

   Copyright 2014-2017 Francesco Pontillo

   Licensed under the Apache License, Version 2.0 (the "License");
   you may not use this file except in compliance with the License.
   You may obtain a copy of the License at

     http://www.apache.org/licenses/LICENSE-2.0

   Unless required by applicable law or agreed to in writing, software
   distributed under the License is distributed on an "AS IS" BASIS,
   WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
   See the License for the specific language governing permissions and
   limitations under the License.

More Repositories

1

ImageViewEx

[DEPRECATED] - Extension of Android's ImageView that supports animated GIFs and includes a better density management.
Java
220
star
2

angular-filters

A collection of useful filters for AngularJS.
JavaScript
92
star
3

knockout-rest

A simple library to extend Knockout.js objects with RESTful actions.
JavaScript
63
star
4

angular-bootstrap-duallistbox

Angular directive to include Bootstrap Dual Listbox in your apps.
JavaScript
45
star
5

angular-gage

AngularJS directive for the JustGage (http://justgage.com/) gauge.
JavaScript
39
star
6

node-rdp

Microsoft Remote Desktop Protocol wrapper for NodeJS
JavaScript
26
star
7

vgd-monopoly-uniba

A sample Unity3D videogame made in college.
C#
13
star
8

angular-highcharts

Angular Highcharts - Easy Highcharts for your AngularJS app!
JavaScript
13
star
9

hubot-github-notify

Hubot script to notify users of GitHub comment mentions, issues/PRs assignments
CoffeeScript
9
star
10

actions-on-google-twitter-raffle

Learn how to connect Google Assistant to the Twitter APIs
4
star
11

chromecast-audio-amplifier-3d-box

3D model for a Chromecast Audio + amplifier box (and cover).
3
star
12

poppins-pr-vote

btford/mary-poppins plugin for keeping track of votes in PRs.
JavaScript
3
star
13

jquery-ui-google-buttons

jQueryUI buttons styled as in Google products, with more colors.
3
star
14

crowd-pulse

Reactive and Extensible Social Extraction and Analysis System
2
star
15

multiwordnet-simple

Fork of the original MultiWordNet converted into a SQLite3 database and text files. Because laziness.
JavaScript
2
star
16

jquery-ui-shadowize

Adds Google-like progressive shadows to a fixed element when scrolling in a page.
JavaScript
2
star
17

AndroidAsyncLib

Android library made of convenience methods for delegating asynchronous methods to a Service.
Java
2
star
18

stop-words

Fork of code.google.com/p/stop-words that enables merging.
JavaScript
2
star
19

crowd-pulse-lemmatize-morphit

Crowd Pulse lemmatizer for the Italian language
Java
1
star
20

docker-youtrack

Docker image for JetBrains YouTrack
Shell
1
star
21

city-tracker-2013

City bug tracker app made for AUH Italy 2013
Java
1
star
22

bd2-project-uniba

University project for the Database Systems 2 course.
JavaScript
1
star
23

gradle-switch-dependencies-plugin

Gradle Plugin to conditionally switch dependencies
Groovy
1
star
24

BundleDotNet

.NET library implementing the Bundle class, just like the one on the Android SDK.
C#
1
star
25

actions-on-google-campobasso

Workshop material (in Italian) for the March 2018 Actions on Google event in Campobasso
JavaScript
1
star
26

crowd-pulse-web-service

Crowd Pulse RESTful Web Service
JavaScript
1
star