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);
|