如何使用Gravity Forms中的新过滤器重新初始化datepicker

时间:2016-03-03 21:53:15

标签: jquery datepicker gravity-forms-plugin

我正在使用重力表单数据选择器,如果值等于" Framingham",则需要根据表单顶部的选择字段禁用日期范围。我非常确定我需要销毁日期选择器并在更改时重新初始化它,但我并不完全确定。如果" Framingham"未选择则45天应为30天。这是我能得到的:

jQuery(function(){
        jQuery('#input_3_23').on('change', function(){
            if(jQuery(this).val() == 'Framingham'){

                for(var i=0; i<45; i++){ 
                      var day=new Date(year, month, date + i);
                      disabledDays.push(("0" + (day.getMonth() + 1)).slice(-2) + '/' + ("0" + day.getDate()).slice(-2) + '/' +  day.getFullYear()   );
                }

                gform.addFilter( 'gform_datepicker_options_pre_init', function( optionsObj, formId, fieldId ) {
                    if (formId == 3 && fieldId == 14 || formId == 3 && fieldId == 15 || formId == 3 && fieldId == 16) {
                        optionsObj.minDate = 0;

                        optionsObj.beforeShowDay = function(date) {
                            var checkdate = jQuery.datepicker.formatDate('mm/dd/yy', date);
                            return [disabledDays.indexOf(checkdate) == -1];
                        };
                    }
                return optionsObj;

                });
            }
        });
    });

我还有一个用户可选的disableDays数组,这是

的位置
return [disabledDays.indexOf(checkdate) == -1];

来自。任何帮助都会非常感激!

1 个答案:

答案 0 :(得分:0)

不太优雅但更简单的解决方案可能是在表单中添加两个日期字段。一个是45天的帽子,另一个是30天的帽子。然后你可以使用Gravity Forms&#39;条件逻辑,根据您在下拉字段中选择的值显示/隐藏相应的日期字段。

如果你走这条路线,你可能也会对GP Limit Dates感兴趣,这样你就可以在没有任何自定义代码的情况下限制日期范围。