/*! UIkit 2.27.2 | www.getuikit.com | © 2014 YOOtheme | MIT License */ (function(addon) {

var component;

if (window.UIkit) {
    component = addon(UIkit);
}

if (typeof define == 'function' && define.amd) {
    define('uikit-form-password', ['uikit'], function(){
        return component || addon(UIkit);
    });
}

})(function(UI){

"use strict";

UI.component('formPassword', {

    defaults: {
        lblShow: 'Show',
        lblHide: 'Hide'
    },

    boot: function() {
        // init code
        UI.$html.on('click.formpassword.uikit', '[data-uk-form-password]', function(e) {

            var ele = UI.$(this);

            if (!ele.data('formPassword')) {

                e.preventDefault();

                UI.formPassword(ele, UI.Utils.options(ele.attr('data-uk-form-password')));
                ele.trigger('click');
            }
        });
    },

    init: function() {

        var $this = this;

        this.on('click', function(e) {

            e.preventDefault();

            if($this.input.length) {
                var type = $this.input.attr('type');
                $this.input.attr('type', type=='text' ? 'password':'text');
                $this.element.html($this.options[type=='text' ? 'lblShow':'lblHide']);
            }
        });

        this.input = this.element.next('input').length ? this.element.next('input') : this.element.prev('input');
        this.element.html(this.options[this.input.is('[type="password"]') ? 'lblShow':'lblHide']);

        this.element.data('formPassword', this);
    }
});

return UI.formPassword;

});