annotate sites/all/modules/webform/js/webform.js @ 9:830c812b520f

added smtp module
author root <root@paio.local>
date Mon, 28 Oct 2013 15:34:27 +0000
parents ff03f76ab3fe
children
rev   line source
danielebarchiesi@0 1
danielebarchiesi@0 2 /**
danielebarchiesi@0 3 * JavaScript behaviors for the front-end display of webforms.
danielebarchiesi@0 4 */
danielebarchiesi@0 5
danielebarchiesi@0 6 (function ($) {
danielebarchiesi@0 7
danielebarchiesi@0 8 Drupal.behaviors.webform = Drupal.behaviors.webform || {};
danielebarchiesi@0 9
danielebarchiesi@0 10 Drupal.behaviors.webform.attach = function(context) {
danielebarchiesi@0 11 // Calendar datepicker behavior.
danielebarchiesi@0 12 Drupal.webform.datepicker(context);
danielebarchiesi@0 13 };
danielebarchiesi@0 14
danielebarchiesi@0 15 Drupal.webform = Drupal.webform || {};
danielebarchiesi@0 16
danielebarchiesi@0 17 Drupal.webform.datepicker = function(context) {
danielebarchiesi@0 18 $('div.webform-datepicker').each(function() {
danielebarchiesi@0 19 var $webformDatepicker = $(this);
danielebarchiesi@0 20 var $calendar = $webformDatepicker.find('input.webform-calendar');
danielebarchiesi@0 21
danielebarchiesi@0 22 // Ensure the page we're on actually contains a datepicker.
danielebarchiesi@0 23 if ($calendar.length == 0) {
danielebarchiesi@0 24 return;
danielebarchiesi@0 25 }
danielebarchiesi@0 26
danielebarchiesi@0 27 var startDate = $calendar[0].className.replace(/.*webform-calendar-start-(\d{4}-\d{2}-\d{2}).*/, '$1').split('-');
danielebarchiesi@0 28 var endDate = $calendar[0].className.replace(/.*webform-calendar-end-(\d{4}-\d{2}-\d{2}).*/, '$1').split('-');
danielebarchiesi@0 29 var firstDay = $calendar[0].className.replace(/.*webform-calendar-day-(\d).*/, '$1');
danielebarchiesi@0 30 // Convert date strings into actual Date objects.
danielebarchiesi@0 31 startDate = new Date(startDate[0], startDate[1] - 1, startDate[2]);
danielebarchiesi@0 32 endDate = new Date(endDate[0], endDate[1] - 1, endDate[2]);
danielebarchiesi@0 33
danielebarchiesi@0 34 // Ensure that start comes before end for datepicker.
danielebarchiesi@0 35 if (startDate > endDate) {
danielebarchiesi@0 36 var laterDate = startDate;
danielebarchiesi@0 37 startDate = endDate;
danielebarchiesi@0 38 endDate = laterDate;
danielebarchiesi@0 39 }
danielebarchiesi@0 40
danielebarchiesi@0 41 var startYear = startDate.getFullYear();
danielebarchiesi@0 42 var endYear = endDate.getFullYear();
danielebarchiesi@0 43
danielebarchiesi@0 44 // Set up the jQuery datepicker element.
danielebarchiesi@0 45 $calendar.datepicker({
danielebarchiesi@0 46 dateFormat: 'yy-mm-dd',
danielebarchiesi@0 47 yearRange: startYear + ':' + endYear,
danielebarchiesi@0 48 firstDay: parseInt(firstDay),
danielebarchiesi@0 49 minDate: startDate,
danielebarchiesi@0 50 maxDate: endDate,
danielebarchiesi@0 51 onSelect: function(dateText, inst) {
danielebarchiesi@0 52 var date = dateText.split('-');
danielebarchiesi@0 53 $webformDatepicker.find('select.year, input.year').val(+date[0]);
danielebarchiesi@0 54 $webformDatepicker.find('select.month').val(+date[1]);
danielebarchiesi@0 55 $webformDatepicker.find('select.day').val(+date[2]);
danielebarchiesi@0 56 },
danielebarchiesi@0 57 beforeShow: function(input, inst) {
danielebarchiesi@0 58 // Get the select list values.
danielebarchiesi@0 59 var year = $webformDatepicker.find('select.year, input.year').val();
danielebarchiesi@0 60 var month = $webformDatepicker.find('select.month').val();
danielebarchiesi@0 61 var day = $webformDatepicker.find('select.day').val();
danielebarchiesi@0 62
danielebarchiesi@0 63 // If empty, default to the current year/month/day in the popup.
danielebarchiesi@0 64 var today = new Date();
danielebarchiesi@0 65 year = year ? year : today.getFullYear();
danielebarchiesi@0 66 month = month ? month : today.getMonth() + 1;
danielebarchiesi@0 67 day = day ? day : today.getDate();
danielebarchiesi@0 68
danielebarchiesi@0 69 // Make sure that the default year fits in the available options.
danielebarchiesi@0 70 year = (year < startYear || year > endYear) ? startYear : year;
danielebarchiesi@0 71
danielebarchiesi@0 72 // jQuery UI Datepicker will read the input field and base its date off
danielebarchiesi@0 73 // of that, even though in our case the input field is a button.
danielebarchiesi@0 74 $(input).val(year + '-' + month + '-' + day);
danielebarchiesi@0 75 }
danielebarchiesi@0 76 });
danielebarchiesi@0 77
danielebarchiesi@0 78 // Prevent the calendar button from submitting the form.
danielebarchiesi@0 79 $calendar.click(function(event) {
danielebarchiesi@0 80 $(this).focus();
danielebarchiesi@0 81 event.preventDefault();
danielebarchiesi@0 82 });
danielebarchiesi@0 83 });
danielebarchiesi@0 84 }
danielebarchiesi@0 85
danielebarchiesi@0 86 })(jQuery);