86 lines
2.3 KiB
JavaScript
86 lines
2.3 KiB
JavaScript
/*! UIkit 2.27.4 | http://www.getuikit.com | (c) 2014 YOOtheme | MIT License */
|
|
(function(addon) {
|
|
|
|
var component;
|
|
|
|
if (window.UIkit2) {
|
|
component = addon(UIkit2);
|
|
}
|
|
|
|
if (typeof define == 'function' && define.amd) {
|
|
define('uikit-form-select', ['uikit'], function(){
|
|
return component || addon(UIkit2);
|
|
});
|
|
}
|
|
|
|
})(function(UI){
|
|
|
|
"use strict";
|
|
|
|
UI.component('formSelect', {
|
|
|
|
defaults: {
|
|
target: '>span:first',
|
|
activeClass: 'uk-active'
|
|
},
|
|
|
|
boot: function() {
|
|
// init code
|
|
UI.ready(function(context) {
|
|
|
|
UI.$('[data-uk-form-select]', context).each(function(){
|
|
|
|
var ele = UI.$(this);
|
|
|
|
if (!ele.data('formSelect')) {
|
|
UI.formSelect(ele, UI.Utils.options(ele.attr('data-uk-form-select')));
|
|
}
|
|
});
|
|
});
|
|
},
|
|
|
|
init: function() {
|
|
|
|
var $this = this;
|
|
|
|
this.target = this.find(this.options.target);
|
|
this.select = this.find('select');
|
|
|
|
// init + on change event
|
|
this.select.on({
|
|
|
|
change: (function(){
|
|
|
|
var select = $this.select[0], fn = function(){
|
|
|
|
try {
|
|
|
|
if($this.options.target === 'input') {
|
|
$this.target.val(select.options[select.selectedIndex].text);
|
|
} else {
|
|
$this.target.text(select.options[select.selectedIndex].text);
|
|
}
|
|
|
|
} catch(e) {}
|
|
|
|
$this.element[$this.select.val() ? 'addClass':'removeClass']($this.options.activeClass);
|
|
|
|
return fn;
|
|
};
|
|
|
|
return fn();
|
|
})(),
|
|
|
|
focus: function(){ $this.target.addClass('uk-focus') },
|
|
blur: function(){ $this.target.removeClass('uk-focus') },
|
|
mouseenter: function(){ $this.target.addClass('uk-hover') },
|
|
mouseleave: function(){ $this.target.removeClass('uk-hover') }
|
|
});
|
|
|
|
this.element.data("formSelect", this);
|
|
}
|
|
});
|
|
|
|
return UI.formSelect;
|
|
});
|