Logo Questions Linux Laravel Mysql Ubuntu Git Menu
 

Reset bootstrap switch state

Firstly, here is a JsFiddle: http://jsfiddle.net/VTv2j/76/

This is what I want to happen:

  1. Switch starts in the indeterminate / in-between state (this works)
  2. Event fires when user chooses either state (this works)
  3. When use clicks RESET the switch goes back to the indeterminate / in-between state (this works)
  4. Event fires when user chooses either state (this DOES NOT work)

What is happening is if the user goes back to whatever the previous state was then no event fires. So say it was on YES, they click RESET, then click YES again - no event fires (but if it was previously on YES, and the reset then went to NO then the event would fire).

I've got no idea how to approach this. I've tried things like destroying and recreating the switch:

$('input[name=test]').bootstrapSwitch('destroy');
$('input[name=test]').bootstrapSwitch();

To no avail unfortunately.

Here is the important thing for me - all I need to know is when the user moves from the indeterminate state to ANY state. I don't actually care what they choose, as long as they choose something. So if anyone can think of a different type of workaround with that in mind (maybe it makes it easier) that would definitely be welcome.

Any help is appreciated, this is driving me crazy.

like image 360
b85411 Avatar asked Oct 23 '25 10:10

b85411


1 Answers

Here's a working version of the code above: http://jsfiddle.net/byzwng4t/1/

function initializeSwitch(selector) {
    $(selector).bootstrapSwitch('destroy', true);
    $(selector).bootstrapSwitch({
        'state': null
    }); 
    $(selector).on('switchChange.bootstrapSwitch', function(event, state) {
        console.log('change event' + (new Date()).getTime());
    });
}

$(function() {
    initializeSwitch('input[name=test]');

    $('.reset').click(function() {
        initializeSwitch('input[name=test]');
    });
});

The trick is to bind the events again after destroying the switch.

like image 150
Joshua Arvin Lat Avatar answered Oct 25 '25 23:10

Joshua Arvin Lat



Donate For Us

If you love us? You can donate to us via Paypal or buy me a coffee so we can maintain and grow! Thank you!