/* * jQuery UI Monthpicker * * @licensed MIT * @licensed GPL * * @author Luciano Costa * http://lucianocosta.info/jquery.mtz.monthpicker/ * * Depends: * jquery.ui.core.js */ /** * MIT License * Copyright (c) 2011, Luciano Costa * * Permission is hereby granted, free of charge, to any person obtaining a copy * of this software and associated documentation files (the "Software"), to deal * in the Software without restriction, including without limitation the rights * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell * copies of the Software, and to permit persons to whom the Software is * furnished to do so, subject to the following conditions: * * The above copyright notice and this permission notice shall be included in * all copies or substantial portions of the Software. * * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN * THE SOFTWARE. */ /** * GPL LIcense * Copyright (c) 2011, Luciano Costa * * This program is free software: you can redistribute it and/or modify it * under the terms of the GNU General Public License as published by the * Free Software Foundation, either version 3 of the License, or * (at your option) any later version. * * This program is distributed in the hope that it will be useful, but * WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY * or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License * for more details. * * You should have received a copy of the GNU General Public License along * with this program. If not, see . */ ;(function ($) { var methods = { init : function (options) { return this.each(function () { var $this = $(this), data = $this.data('monthpicker'), year = (options && options.year) ? options.year : (new Date()).getFullYear(), settings = $.extend({ pattern: 'mm/yyyy', selectedMonth: null, selectedMonthName: '', selectedYear: year, startYear: year - 10, finalYear: year + 10, monthNames: ['Jan', 'Feb', 'Mar', 'Apr', 'May', 'Jun', 'Jul', 'Aug', 'Sep', 'Oct', 'Nov', 'Dec'], id: "monthpicker_" + (Math.random() * Math.random()).toString().replace('.', ''), openOnFocus: true, disabledMonths: [] }, options); settings.dateSeparator = settings.pattern.replace(/(mmm|mm|m|yyyy|yy|y)/ig,''); // If the plugin hasn't been initialized yet for this element if (!data) { $(this).data('monthpicker', { 'target': $this, 'settings': settings }); if (settings.openOnFocus === true) { $this.bind('focus', function () { $this.monthpicker('show'); }); } $this.monthpicker('mountWidget', settings); $this.bind('monthpicker-click-month', function (e, month, year) { $this.monthpicker('setValue', settings); $this.monthpicker('hide'); }); // hide widget when user clicks elsewhere on page $this.addClass("mtz-monthpicker-widgetcontainer"); $(document).unbind("mousedown.mtzmonthpicker").bind("mousedown.mtzmonthpicker", function (e) { if (!e.target.className || e.target.className.toString().indexOf('mtz-monthpicker') < 0) { $(".mtz-monthpicker-widgetcontainer").each(function () { if (typeof($(this).data("monthpicker"))!="undefined") { $(this).monthpicker('hide'); } }); } }); } }); }, show: function (n) { var widget = $('#' + this.data('monthpicker').settings.id); var monthpicker = $('#' + this.data('monthpicker').target.attr("id") + ':eq(0)'); widget.css("top", monthpicker.offset().top + monthpicker.outerHeight()); widget.css("left", monthpicker.offset().left); widget.show(); widget.find('select').focus(); this.trigger('monthpicker-show'); }, hide: function () { var widget = $('#' + this.data('monthpicker').settings.id); if (widget.is(':visible')) { widget.hide(); this.trigger('monthpicker-hide'); } }, setValue: function (settings) { var month = settings.selectedMonth, year = settings.selectedYear; if(settings.pattern.indexOf('mmm') >= 0) { month = settings.selectedMonthName; } else if(settings.pattern.indexOf('mm') >= 0 && settings.selectedMonth < 10) { month = '0' + settings.selectedMonth; } if(settings.pattern.indexOf('yyyy') < 0) { year = year.toString().substr(2,2); } if (settings.pattern.indexOf('y') > settings.pattern.indexOf(settings.dateSeparator)) { this.val(month + settings.dateSeparator + year); } else { this.val(year + settings.dateSeparator + month); } this.change(); }, disableMonths: function (months) { var settings = this.data('monthpicker').settings, container = $('#' + settings.id); settings.disabledMonths = months; container.find('.mtz-monthpicker-month').each(function () { var m = parseInt($(this).data('month')); if ($.inArray(m, months) >= 0) { $(this).addClass('ui-state-disabled'); } else { $(this).removeClass('ui-state-disabled'); } }); }, mountWidget: function (settings) { var monthpicker = this, container = $('
'), header = $('
'), combo = $('