website/wp-content/plugins/gravityforms/js/form_editor.js

3846 lines
130 KiB
JavaScript

//-------------------------------------------------
// INITIALIZING PAGE
//-------------------------------------------------
jQuery(document).ready(function() {
setTimeout("CloseStatus();", 5000);
jQuery('.field_type input').each(function(){
var $this = jQuery(this);
var type = $this.data('type');
var onClick = $this.attr('onclick');
if(typeof type =='undefined'){
// deprecate buttons without the type data attribute
if(onClick.indexOf('StartAddField') > -1){
if (/StartAddField\([ ]?'(.*?)[ ]?'/.test( onClick )){
type = onClick.match( /'(.*?)'/ )[1];
$this.data('type', type);
}
}
if(window.console){
console.log('Deprecated button for the ' + this.value + ' field. Since v1.9 the field type must be specified in the "type" data attribute.');
}
}
if(typeof type != 'undefined' && (typeof onClick == 'undefined' || onClick == '')){
jQuery(this).click(function(){
StartAddField(type);
})
}
});
jQuery('#gform_fields').sortable({
cancel: '#field_settings',
handle: '.gfield_admin_icons',
start: function(event, ui){
gforms_dragging = ui.item[0].id;
},
tolerance: "pointer",
over: function( event, ui ) {
jQuery( '#no-fields').hide();
if(ui.helper.hasClass('ui-draggable-dragging')){
ui.helper.data('original_width', ui.helper.width())
ui.helper.data('original_height', ui.helper.height())
ui.helper.width(ui.sender.width()-25);
ui.helper.height(ui.placeholder.height());
} else {
var h = ui.helper.height();
if(h > 300){
h = 300;
}
ui.placeholder.height(h);
}
},
out: function( event, ui ) {
if ( jQuery('#gform_fields li').length === 1 ) {
jQuery( '#no-fields' ).show();
}
if(ui.helper && ui.helper.hasClass('ui-draggable-dragging')){
ui.helper.width(ui.helper.data('original_width'));
ui.helper.height(ui.helper.data('original_height'));
}
},
placeholder: "field-drop-zone",
beforeStop: function( event, ui ) {
jQuery('#gform_fields').height('100%');
var type = ui.helper.data('type');
if(typeof type == 'undefined'){
return;
}
var li = "<li id='gform_adding_field_spinner'><i class='gficon-gravityforms-spinner-icon gficon-spin'></i></li>";
var index = ui.item.index();
ui.item.replaceWith( li );
StartAddField(type, index);
}
});
jQuery('.field_type input').draggable({
connectToSortable: "#gform_fields",
helper: function(){
return jQuery(this).clone(true);
},
revert: 'invalid',
cancel: false,
appendTo: '#wpbody',
containment: 'document',
start: function(event, ui){
if(gf_vars["currentlyAddingField"] == true){
return false;
}
}
});
jQuery('#field_choices, #field_columns').sortable({
axis: 'y',
handle: '.field-choice-handle',
update: function(event, ui){
var fromIndex = ui.item.data("index");
var toIndex = ui.item.index();
MoveFieldChoice(fromIndex, toIndex);
}
});
jQuery('.field_input_choices').sortable({
axis: 'y',
handle: '.field-choice-handle',
update: function(event, ui){
var fromIndex = ui.item.data("index");
var toIndex = ui.item.index();
var inputId = ui.item.data("input_id");
var $ul = ui.item.parent();
MoveInputChoice($ul, inputId, fromIndex, toIndex);
}
});
MakeNoFieldsDroppable();
if(typeof gf_global['view'] == 'undefined' || gf_global['view'] != 'settings')
InitializeForm(form);
//for backwards compatibility <1.7
jQuery(document).trigger('gform_load_form_settings', [form]);
SetupUnsavedChangesWarning();
//log deprecated events
if (window.console){
var doc = jQuery(document)[0];
var data = jQuery.hasData(doc) && jQuery._data(doc);
if (data){
var deprecatedEvents = new Array('gform_load_form_settings');
for (var e in data.events) {
if (jQuery.inArray(e, deprecatedEvents) !== -1) {
console.log('Gravity Forms API warning: The jQuery event "' + e + '" is deprecated on this page since version 1.7');
}
}
}
}
// store original value of input before change
jQuery(document).on('focus', '#field_choices input.field-choice-text, #field_choices input.field-choice-value', function(){
jQuery(this).data('previousValue', jQuery(this).val());
});
InitializeFieldSettings();
});
function MakeNoFieldsDroppable() {
jQuery('#no-fields').droppable({
over: function (event, ui) {
jQuery('#gform_fields').height(jQuery( this ).height());
jQuery( this ).hide();
},
out : function (event, ui) {
jQuery( this ).show();
}
});
}
function CloseStatus(){
jQuery('.updated_base, .error_base').slideUp();
}
function InitializeFieldSettings(){
jQuery('#field_max_file_size').on('input propertychange', function(){
var $this = jQuery(this),
inputValue = parseInt($this.val());
var value = inputValue ? inputValue : '';
SetFieldProperty('maxFileSize', value);
}).on('change', function(){
var field = GetSelectedField();
var value = field.maxFileSize ? field.maxFileSize : '';
var maskedValue = value === '' ? '' : value + "MB";
this.value = maskedValue;
});
jQuery(document).on('input propertychange', '.field_default_value', function(){
SetFieldDefaultValue(this.value);
});
jQuery(document).on('input propertychange', '.field_placeholder, .field_placeholder_textarea', function(){
SetFieldPlaceholder(this.value);
});
jQuery('#field_choices').on('change' , '.field-choice-price', function() {
var field = GetSelectedField();
var i = jQuery(this).parent('li').index();
var price = field.choices[i].price;
this.value = price;
});
jQuery('.field_input_choices')
.on('input propertychange', 'input', function () {
var $li = jQuery(this).closest('li'),
index = $li.data('index'),
inputId = $li.data('input_id'),
value = $li.find('.field-choice-value').val(),
text = $li.find('.field-choice-text').val();
SetInputChoice(inputId, index, value, text);
})
.on('click keypress', 'input:radio, input:checkbox', function () {
var $li = jQuery(this).closest('li'),
index = $li.data('index'),
inputId = $li.data('input_id'),
value = $li.find('.field-choice-value').val(),
text = $li.find('.field-choice-text').val();
SetInputChoice(inputId, index, value, text);
})
.on('click keypress', '.field-input-insert-choice', function () {
var $li = jQuery(this).closest('li'),
$ul = $li.closest('ul'),
index = $li.data('index'),
inputId = $li.data('input_id');
InsertInputChoice($ul, inputId, index + 1);
})
.on('click keypress', '.field-input-delete-choice', function () {
var $li = jQuery(this).closest('li'),
$ul = $li.closest('ul'),
index = $li.data('index'),
inputId = $li.data('input_id');
DeleteInputChoice($ul, inputId, index);
});
jQuery('.field_input_choice_values_enabled').on('click keypress', function(){
var $container = jQuery(this).parent().siblings('.gfield_settings_input_choices_container');
ToggleInputChoiceValue($container, this.checked);
var $ul = $container.find('ul');
SetInputChoices($ul);
});
jQuery('.input_placeholders_setting')
.on('input propertychange', '.input_placeholder', function(){
var inputId = jQuery(this).closest('.input_placeholder_row').data('input_id');
SetInputPlaceholder(this.value, inputId);
})
.on('input propertychange', '#field_single_placeholder', function(){
SetFieldPlaceholder(this.value);
});
//add onclick event to disable placeholder when the rich text editor is on
jQuery('#field_rich_text_editor').on('click keypress', function(){
var field = GetSelectedField();
if (this.checked ){
var disablePlaceHolder = true;
//see if a field is using this in conditional logic and warn it will not work with rich text editor
if ( HasConditionalLogicDependency(field.id,field.value) ){
if ( ! confirm(gf_vars.conditionalLogicRichTextEditorWarning) ){
//user cancelled setting rte, uncheck
jQuery('#field_rich_text_editor').prop('checked', false);
disablePlaceHolder = false;
}
}
if (disablePlaceHolder){
jQuery('#field_placeholder, #field_placeholder_textarea').prop('disabled', true);
jQuery('span#placeholder_warning').css('display','block');
}
}
else{
jQuery('#field_placeholder, #field_placeholder_textarea').prop('disabled', false);
jQuery('span#placeholder_warning').css('display','none');
}
});
jQuery('.prepopulate_field_setting')
.on('input propertychange', '.field_input_name', function(){
var inputId = jQuery(this).closest('.field_input_name_row').data('input_id');
SetInputName(this.value, inputId);
})
.on('input propertychange', '#field_input_name', function(){
SetInputName(this.value);
});
jQuery('.custom_inputs_setting, .custom_inputs_sub_setting, .sub_labels_setting')
.on('click keypress', '.input_active_icon', function(){
var inputId = jQuery(this).closest('.field_custom_input_row').data('input_id');
ToggleInputHidden(this, inputId);
})
.on('input propertychange', '.field_custom_input_default_label', function(){
var inputId = jQuery(this).closest('.field_custom_input_row').data('input_id');
SetInputCustomLabel(this.value, inputId);
})
.on('input propertychange', '#field_single_custom_label', function(){
SetInputCustomLabel(this.value);
});
jQuery('.default_input_values_setting')
.on('input propertychange', '.default_input_value', function(){
var inputId = jQuery(this).closest('.default_input_value_row').data('input_id');
SetInputDefaultValue(this.value, inputId);
})
.on('input', '#field_single_default_value', function(){
SetFieldDefaultValue(this.value);
});
jQuery('.choices_setting, .columns_setting')
.on('input propertychange', '.field-choice-input', function(e){
var $this = jQuery(this);
var li = $this.closest('li.field-choice-row');
var inputType = li.data('input_type');
var i = li.data('index');
SetFieldChoice( inputType, i);
if($this.hasClass('field-choice-text') || $this.hasClass('field-choice-value')){
CheckChoiceConditionalLogicDependency(this);
e.stopPropagation();
}
});
jQuery('#field_enable_copy_values_option').on('click keypress', function(){
SetCopyValuesOptionProperties(this.checked);
ToggleCopyValuesOption(false);
if(this.checked == false){
ToggleCopyValuesActivated(false);
}
});
jQuery('#field_copy_values_option_label').on('input propertychange', function(){
SetCopyValuesOptionLabel(this.value);
});
jQuery('#field_copy_values_option_field').on('change', function(){
SetFieldProperty('copyValuesOptionField', jQuery(this).val());
});
jQuery('#field_copy_values_option_default').on('change', function(){
SetFieldProperty('copyValuesOptionDefault', this.checked == true ? 1 : 0);
ToggleCopyValuesActivated(this.checked);
});
jQuery('#field_label').on('input propertychange', function(){
SetFieldLabel(this.value);
});
jQuery('#field_description').on('blur', function(){
var field = GetSelectedField();
if ( field.description != this.value ) {
SetFieldDescription(this.value);
RefreshSelectedFieldPreview();
}
});
jQuery('#field_checkbox_label').on('input propertychange', function(){
var field = GetSelectedField();
if ( field.checkboxLabel != this.value ) {
SetFieldCheckboxLabel(this.value);
RefreshSelectedFieldPreview();
}
});
jQuery('#field_content').on('input propertychange', function(){
SetFieldProperty('content', this.value);
});
jQuery('#next_button_text_input, #next_button_image_url').on('input propertychange', function(){
SetPageButton('next');
});
jQuery('#previous_button_image_url, #previous_button_text_input').on('input propertychange', function(){
SetPageButton('previous');
});
jQuery('#field_custom_field_name_text').on('input propertychange', function(){
SetFieldProperty('postCustomFieldName', this.value);
});
jQuery('#field_customfield_content_template').on('input propertychange', function(){
SetCustomFieldTemplate();
});
jQuery('#gfield_calendar_icon_url').on('input propertychange', function(){
SetFieldProperty('calendarIconUrl', this.value);
});
jQuery('#field_max_files').on('input propertychange', function(){
SetFieldProperty('maxFiles', this.value);
});
jQuery('#field_maxrows').on('input propertychange', function(){
SetFieldProperty('maxRows', this.value);
});
jQuery('#field_mask_text').on('input propertychange', function(){
SetFieldProperty('inputMaskValue', this.value);
});
jQuery('#field_file_extension').on('input propertychange', function(){
SetFieldProperty('allowedExtensions', this.value);
});
jQuery('#field_maxlen')
.on('keypress', function(event){
return ValidateKeyPress(event, GetMaxLengthPattern(), false)
})
.on('change keyup', function(){
SetMaxLength(this);
});
jQuery('#field_range_min').on('input propertychange', function(){
SetFieldProperty('rangeMin', this.value);
});
jQuery('#field_range_max').on('input propertychange', function(){
SetFieldProperty('rangeMax', this.value);
});
jQuery('#field_calculation_formula').on('input propertychange', function(){
SetFieldProperty('calculationFormula', this.value.trim());
});
jQuery('#field_error_message').on('input propertychange', function(){
SetFieldProperty('errorMessage', this.value);
});
jQuery('#field_css_class').on('input propertychange', function(){
SetFieldProperty('cssClass', this.value);
});
jQuery('#field_admin_label').on('input propertychange', function(){
SetFieldProperty('adminLabel', this.value);
});
jQuery('#field_add_icon_url').on('input propertychange', function(){
SetFieldProperty('addIconUrl', this.value);
});
jQuery('#field_delete_icon_url').on('input propertychange', function(){
SetFieldProperty('deleteIconUrl', this.value);
});
}
function InitializeForm(form){
if ( form.fields.length > 0 ) {
jQuery( '#no-fields').detach().appendTo( '#no-fields-stash');
}
if(form.lastPageButton && form.lastPageButton.type === 'image')
jQuery('#last_page_button_image').prop('checked', true);
else if(!form.lastPageButton || form.lastPageButton.type !== 'image')
jQuery('#last_page_button_text').prop('checked', true);
jQuery('#last_page_button_text_input').val(form.lastPageButton ? form.lastPageButton.text : gf_vars['previousLabel']);
jQuery('#last_page_button_image_url').val(form.lastPageButton ? form.lastPageButton.imageUrl : '');
TogglePageButton('last_page', true);
if(form.postStatus)
jQuery('#field_post_status').val(form.postStatus);
if(form.postAuthor)
jQuery('#field_post_author').val(form.postAuthor);
//default to checked
if(form.useCurrentUserAsAuthor === undefined)
form.useCurrentUserAsAuthor = true;
jQuery('#gfield_current_user_as_author').prop('checked', form.useCurrentUserAsAuthor ? true : false);
if(form.postCategory)
jQuery('#field_post_category').val(form.postCategory);
if(form.postFormat)
jQuery('#field_post_format').val(form.postFormat);
if(form.postContentTemplateEnabled){
jQuery('#gfield_post_content_enabled').prop('checked', true);
jQuery('#field_post_content_template').val(form.postContentTemplate);
}
else{
jQuery('#gfield_post_content_enabled').prop('checked', false);
jQuery('#field_post_content_template').val('');
}
TogglePostContentTemplate(true);
if(form.postTitleTemplateEnabled){
jQuery('#gfield_post_title_enabled').prop('checked', true);
jQuery('#field_post_title_template').val(form.postTitleTemplate);
}
else{
jQuery('#gfield_post_title_enabled').prop('checked', false);
jQuery('#field_post_title_template').val('');
}
TogglePostTitleTemplate(true);
jQuery('#gform_last_page_settings').click(function () {FieldClick(this);});
jQuery('#gform_pagination').click(function () {FieldClick(this);});
jQuery('#gform_fields').on('click', '.gfield', function () {FieldClick(this);});
var paginationType = form['pagination'] && form['pagination']['type'] ? form['pagination']['type'] : 'percentage';
var paginationSteps = paginationType === 'steps' ? true : false;
var paginationPercentage = paginationType === 'percentage' ? true : false;
var paginationNone = paginationType === 'none' ? true : false;
if(paginationSteps)
jQuery('#pagination_type_steps').prop('checked', true);
else if(paginationPercentage)
jQuery('#pagination_type_percentage').prop('checked', true);
else if(paginationNone)
jQuery('#pagination_type_none').prop('checked', true);
jQuery('#first_page_css_class').val(form['firstPageCssClass']);
jQuery('#field_settings, #last_page_settings, #pagination_settings').tabs({selected:0});
TogglePageBreakSettings();
InitPaginationOptions(true);
InitializeFields();
}
function LoadFieldSettings(){
//loads settings
field = GetSelectedField();
var inputType = GetInputType(field);
jQuery("#field_label").val(field.label);
if(field.type == "html"){
jQuery(".tooltip_form_field_label_html").show();
jQuery(".tooltip_form_field_label").hide();
}
else{
jQuery(".tooltip_form_field_label_html").hide();
jQuery(".tooltip_form_field_label").show();
}
jQuery("#field_admin_label").val(field.adminLabel);
jQuery("#field_content").val(field["content"] == undefined ? "" : field["content"]);
jQuery("#post_custom_field_type").val(field.inputType);
jQuery("#post_tag_type").val(field.inputType);
jQuery("#field_size").val(field.size);
jQuery("#field_required").prop("checked", field.isRequired == true ? true : false);
jQuery("#field_margins").prop("checked", field.disableMargins == true ? true : false);
jQuery("#field_no_duplicates").prop("checked", field.noDuplicates == true ? true : false);
jQuery("#field_default_value").val(field.defaultValue == undefined ? "" : field.defaultValue);
jQuery("#field_default_value_textarea").val(field.defaultValue == undefined ? "" : field.defaultValue);
jQuery("#field_description").val(field.description == undefined ? "" : field.description);
jQuery("#field_description").attr('placeholder', field.descriptionPlaceholder == undefined ? "" : field.descriptionPlaceholder);
jQuery("#field_checkbox_label").val(field.checkboxLabel == undefined ? "" : field.checkboxLabel);
jQuery("#field_css_class").val(field.cssClass == undefined ? "" : field.cssClass);
jQuery("#field_range_min").val( field.rangeMin == undefined || field.rangeMin === false ? "" : field.rangeMin);
jQuery("#field_range_max").val(field.rangeMax == undefined || field.rangeMax === false ? "" : field.rangeMax);
jQuery("#field_name_format").val(field.nameFormat);
jQuery('#field_force_ssl').prop('checked', field.forceSSL ? true : false);
jQuery('#credit_card_style').val(field.creditCardStyle ? field.creditCardStyle : "style1");
if (field.useRichTextEditor){
//disable the placeholder when the rich text editor is checked, show message indicating why disabled
jQuery('#field_placeholder, #field_placeholder_textarea').prop('disabled', true);
jQuery('span#placeholder_warning').css('display','block');
//jQuery('span#placeholder_warning').text('Placeholder text is not supported when using the Rich Text Editor.');
}
else{
jQuery('#field_placeholder, #field_placeholder_textarea').prop('disabled', false);
jQuery('span#placeholder_warning').css('display','none');
//jQuery('span#placeholder_warning').text('');
}
if(typeof field.labelPlacement == 'undefined'){
field.labelPlacement = '';
}
if(typeof field.descriptionPlacement == 'undefined'){
field.descriptionPlacement = '';
}
if(typeof field.subLabelPlacement == 'undefined'){
field.subLabelPlacement = '';
}
jQuery("#field_label_placement").val(field.labelPlacement);
jQuery("#field_description_placement").val(field.descriptionPlacement);
jQuery("#field_sub_label_placement").val(field.subLabelPlacement);
if((field.labelPlacement == 'left_label' || field.labelPlacement == 'right_label' || (field.labelPlacement == '' && form.labelPlacement != 'top_label'))){
jQuery('#field_description_placement_container').hide();
} else {
jQuery('#field_description_placement_container').show();
}
// field.adminOnly is the old property which stored the visibility setting; only reference if field.visibility is not set
SetFieldVisibility( field.visibility, true );
if(typeof field.placeholder == 'undefined'){
field.placeholder = '';
}
jQuery("#field_placeholder, #field_placeholder_textarea").val(field.placeholder);
jQuery("#field_file_extension").val(field.allowedExtensions == undefined ? "" : field.allowedExtensions);
jQuery("#field_multiple_files").prop("checked", field.multipleFiles ? true : false);
jQuery("#field_max_files").val(field.maxFiles ? field.maxFiles : "" );
jQuery("#field_max_file_size").val(field.maxFileSize ? field.maxFileSize + "MB" : "" );
ToggleMultiFile(true);
jQuery("#field_phone_format").val(field.phoneFormat);
jQuery("#field_error_message").val(field.errorMessage);
jQuery('#field_select_all_choices').prop('checked', field.enableSelectAll ? true : false);
jQuery('#field_other_choice').prop('checked', field.enableOtherChoice ? true : false);
jQuery('#field_add_icon_url').val(field.addIconUrl ? field.addIconUrl : "");
jQuery('#field_delete_icon_url').val(field.deleteIconUrl ? field.deleteIconUrl : "");
jQuery('#gfield_enable_enhanced_ui').prop('checked', field.enableEnhancedUI ? true : false);
jQuery("#gfield_password_strength_enabled").prop("checked", field.passwordStrengthEnabled == true ? true : false);
jQuery("#gfield_password_visibility_enabled").prop("checked", field.passwordVisibilityEnabled == true ? true : false);
TogglePasswordVisibility( true );
jQuery("#gfield_min_strength").val(field.minPasswordStrength == undefined ? "" : field.minPasswordStrength);
TogglePasswordStrength(true);
jQuery("#gfield_email_confirm_enabled").prop("checked", field.emailConfirmEnabled == true ? true : false);
//Creating blank item for number format to existing number fields so that user is not force into a format (for backwards compatibility)
if(!field.numberFormat){
if(jQuery("#field_number_format #field_number_format_blank").length == 0){
jQuery("#field_number_format").prepend("<option id='field_number_format_blank' value=''>" + gf_vars["selectFormat"] + "</option>");
}
}
else
jQuery("#field_number_format_blank").remove();
jQuery("#field_number_format").val(field.numberFormat ? field.numberFormat : "");
// Handle calculation options
// hide rounding option for calculation product fields
if (field.type == 'product' && field.inputType == 'calculation') {
field.enableCalculation = true;
jQuery('.field_calculation_rounding').hide();
jQuery('.field_enable_calculation').hide();
} else {
jQuery('.field_enable_calculation').show();
if (field.type == 'number' && field.numberFormat == "currency") {
jQuery('.field_calculation_rounding').hide();
} else {
jQuery('.field_calculation_rounding').show();
}
}
jQuery('#field_enable_calculation').prop('checked', field.enableCalculation ? true : false);
ToggleCalculationOptions(field.enableCalculation, field);
jQuery('#field_calculation_formula').val(field.calculationFormula);
var rounding = gformIsNumber(field.calculationRounding) ? field.calculationRounding : "norounding";
jQuery('#field_calculation_rounding').val(rounding);
jQuery("#option_field_type").val(field.inputType);
var productFieldType = jQuery("#product_field_type");
productFieldType.val(field.inputType);
if(has_entry(field.id)){
productFieldType.prop("disabled", true);
} else{
productFieldType.prop("disabled", false);
}
jQuery("#donation_field_type").val(field.inputType);
jQuery("#quantity_field_type").val(field.inputType);
if(field["inputType"] == "hiddenproduct" || field["inputType"] == "singleproduct" || field["inputType"] == "singleshipping" || field["inputType"] == "calculation"){
var basePrice = field.basePrice == undefined ? "" : field.basePrice;
jQuery("#field_base_price").val(field.basePrice == undefined ? "" : field.basePrice);
SetBasePrice(basePrice);
}
jQuery("#shipping_field_type").val(field.inputType);
jQuery("#field_disable_quantity").prop("checked", field.disableQuantity == true ? true : false);
SetDisableQuantity(field.disableQuantity == true);
var isPassword = field.enablePasswordInput ? true : false
jQuery("#field_password").prop("checked", isPassword ? true : false);
jQuery("#field_maxlen").val(typeof field.maxLength == "undefined" ? "" : field.maxLength);
jQuery("#field_maxrows").val(typeof field.maxRows == "undefined" ? "" : field.maxRows);
var addressType = field.addressType == undefined ? "international" : field.addressType;
jQuery('#field_address_type').val(addressType);
if(field.type == 'address'){
field = UpgradeAddressField(field);
}
if(field.type == 'email' || field.inputType == 'email' ){
field = UpgradeEmailField(field);
}
if(field.type === 'consent'){
field = UpgradeConsentField(field);
}
var defaultState = field.defaultState == undefined ? "" : field.defaultState;
var defaultProvince = field.defaultProvince == undefined ? "" : field.defaultProvince; //for backwards compatibility
var defaultStateProvince = addressType == "canadian" && defaultState == "" ? defaultProvince : defaultState;
jQuery("#field_address_default_state_" + addressType).val(defaultStateProvince);
jQuery("#field_address_default_country_" + addressType).val(field.defaultCountry == undefined ? "" : field.defaultCountry);
SetAddressType(true);
jQuery("#gfield_display_title").prop("checked", field.displayTitle == true ? true : false);
jQuery("#gfield_display_caption").prop("checked", field.displayCaption == true ? true : false);
jQuery("#gfield_display_description").prop("checked", field.displayDescription == true ? true : false);
var customFieldExists = CustomFieldExists(field.postCustomFieldName);
jQuery("#field_custom_field_name_select")[0].selectedIndex = 0;
jQuery("#field_custom_field_name_text").val("");
if(customFieldExists)
jQuery("#field_custom_field_name_select").val(field.postCustomFieldName);
else
jQuery("#field_custom_field_name_text").val(field.postCustomFieldName);
if(customFieldExists)
jQuery("#field_custom_existing").prop("checked", true);
else
jQuery("#field_custom_new").prop("checked", true);
ToggleCustomField(true);
jQuery('#gfield_customfield_content_enabled').prop("checked", field.customFieldTemplateEnabled ? true : false);
jQuery('#field_customfield_content_template').val(field.customFieldTemplateEnabled ? field.customFieldTemplate : "");
ToggleCustomFieldTemplate(true);
if(field.displayAllCategories)
jQuery("#gfield_category_all").prop("checked", true);
else
jQuery("#gfield_category_select").prop("checked", true);
ToggleCategory(true);
jQuery('#gfield_post_category_initial_item_enabled').prop("checked", field.categoryInitialItemEnabled ? true : false);
jQuery('#field_post_category_initial_item').val(field.categoryInitialItemEnabled ? field.categoryInitialItem : "");
TogglePostCategoryInitialItem(true);
var hasPostFeaturedImage = field.postFeaturedImage ? true : false;
jQuery('#gfield_featured_image').prop('checked', hasPostFeaturedImage);
if (typeof field.inputMaskIsCustom != 'boolean') {
field.inputMaskIsCustom = !IsStandardMask(field.inputMaskValue);
}
var isStandardMask = !field.inputMaskIsCustom;
jQuery("#field_input_mask").prop('checked', field.inputMask ? true : false);
if(isStandardMask){
jQuery("#field_mask_standard").prop("checked", true);
jQuery("#field_mask_select").val(field.inputMaskValue);
}
else{
jQuery("#field_mask_custom").prop("checked", true);
jQuery("#field_mask_text").val(field.inputMaskValue);
}
ToggleInputMask(true);
ToggleInputMaskOptions(true);
if(inputType == "creditcard"){
field = UpgradeCreditCardField(field);
if(!field.creditCards || field.creditCards.length <= 0)
field.creditCards = ['amex', 'visa', 'discover', 'mastercard'];
for(i in field.creditCards) {
if(!field.creditCards.hasOwnProperty(i))
continue;
jQuery('#field_credit_card_' + field.creditCards[i]).prop('checked', true);
}
}
if(inputType == 'date'){
field = UpgradeDateField(field);
}
if(inputType == 'time'){
field = UpgradeTimeField(field);
}
CreateDefaultValuesUI(field);
CreatePlaceholdersUI(field);
CreateCustomizeInputsUI(field);
CreateInputLabelsUI(field);
if(!field["dateType"] && inputType == "date"){
field["dateType"] = "datepicker";
}
jQuery("#field_date_input_type").val(field["dateType"]);
jQuery("#gfield_calendar_icon_url").val(field["calendarIconUrl"] == undefined ? "" : field["calendarIconUrl"]);
jQuery('#field_date_format').val(field['dateFormat'] == "dmy" ? "dmy" : field['dateFormat']);
jQuery('#field_time_format').val(field['timeFormat'] == "24" ? "24" : "12");
SetCalendarIconType(field["calendarIconType"], true);
ToggleDateCalendar(true);
LoadDateInputs();
LoadTimeInputs();
field.allowsPrepopulate = field.allowsPrepopulate ? true : false; //needed when property is undefined
field.useRichTextEditor = field.useRichTextEditor ? true : false;
jQuery("#field_prepopulate").prop("checked", field.allowsPrepopulate ? true : false);
jQuery("#field_rich_text_editor").prop("checked", field.useRichTextEditor ? true : false);
if(has_entry(field.id)){
jQuery('#field_rich_text_editor').prop("disabled", true);
} else{
jQuery('#field_rich_text_editor').prop("disabled", false);
}
CreateInputNames(field);
ToggleInputName(true);
var canHaveConditionalLogic = GetFirstRuleField() > 0;
if(field["type"] == "page"){
LoadFieldConditionalLogic(canHaveConditionalLogic, "next_button");
LoadFieldConditionalLogic(canHaveConditionalLogic, "page");
}
else{
LoadFieldConditionalLogic(canHaveConditionalLogic, "field");
}
jQuery("#field_enable_copy_values_option").prop("checked", field.enableCopyValuesOption == true ? true : false);
jQuery("#field_copy_values_option_default").prop("checked", field.copyValuesOptionDefault == true ? true : false);
var copyValueOptions = GetCopyValuesFieldsOptions(field.copyValuesOptionField, field);
if(copyValueOptions.length>0){
jQuery("#field_enable_copy_values_option").prop("disabled", false);
jQuery("#field_copy_values_disabled").hide();
jQuery("#field_copy_values_option_field").html(copyValueOptions);
} else {
jQuery("#field_enable_copy_values_option").prop("disabled", true);
jQuery("#field_copy_values_disabled").show();
}
ToggleCopyValuesOption(field.enableCopyValuesOption, true);
if(field.nextButton){
if(field.nextButton.type == "image")
jQuery("#next_button_image").prop("checked", true);
else
jQuery("#next_button_text").prop("checked", true);
jQuery("#next_button_text_input").val(field.nextButton.text);
jQuery("#next_button_image_url").val(field.nextButton.imageUrl);
}
if(field.previousButton){
if(field.previousButton.type == "image")
jQuery("#previous_button_image").prop("checked", true);
else
jQuery("#previous_button_text").prop("checked", true);
jQuery("#previous_button_text_input").val(field.previousButton.text);
jQuery("#previous_button_image_url").val(field.previousButton.imageUrl);
}
TogglePageButton("next", true);
TogglePageButton("previous", true);
jQuery(".gfield_category_checkbox").each(function(){
if(field["choices"]){
for(var i=0; i<field["choices"].length; i++){
if(this.value == field["choices"][i].value){
this.checked = true;
return;
}
}
}
this.checked = false;
});
if(has_entry(field.id))
jQuery("#field_type, #field_multiple_files").prop("disabled", true);
else
jQuery("#field_type, #field_multiple_files").prop("disabled", false);
jQuery("#field_custom_field_name").val(field.postCustomFieldName);
jQuery( '#field_columns_enabled' )
.prop( 'checked', Boolean( field.enableColumns ) )
.prop( 'disabled', has_entry( field.id ) );
LoadFieldChoices(field);
//displays appropriate settings
jQuery(".field_setting").hide();
var allSettings = fieldSettings[field.type];
if(field.inputType && field.type != 'post_category')
allSettings += "," + fieldSettings[field.inputType];
jQuery(allSettings).show();
//hide post category drop down if post category field is in the form
for(var i=0; i<form.fields.length; i++){
if(form.fields[i].type == "post_category"){
jQuery(".post_category_setting").hide();
break;
}
}
// hide "Display placeholder" option for post category field if input type is not a select
if(field.type == 'post_category' && inputType != 'select') {
jQuery('.post_category_initial_item_setting').hide();
jQuery('#gfield_post_category_initial_item_enabled').prop('checked', false);
SetCategoryInitialItem();
}
//hide "Enable calculation" option for quantity fields
if(field.type == 'quantity') {
jQuery('.calculation_setting').hide();
}
jQuery("#post_category_field_type").val(field.inputType);
var fg = field.simpleCaptchaFontColor == undefined ? "" : field.simpleCaptchaFontColor;
jQuery("#field_captcha_fg").val(fg);
SetColorPickerColor("field_captcha_fg", fg);
var bg = field.simpleCaptchaBackgroundColor == undefined ? "" : field.simpleCaptchaBackgroundColor;
jQuery("#field_captcha_bg").val(bg);
SetColorPickerColor("field_captcha_bg", bg);
jQuery("#field_captcha_type").val(field.captchaType == undefined ? "captcha" : field.captchaType);
jQuery("#field_captcha_badge").val(field.captchaBadge == undefined ? "bottomright" : field.captchaBadge);
jQuery("#field_captcha_size").val(field.simpleCaptchaSize == undefined ? "medium" : field.simpleCaptchaSize);
//controlling settings based on captcha type
if(field["type"] == "captcha"){
var recaptcha_settings = ".captcha_language_setting, .captcha_theme_setting";
var simple_captcha_settings = ".captcha_size_setting, .captcha_fg_setting, .captcha_bg_setting";
if(field["captchaType"] == "simple_captcha" || field["captchaType"] == "math"){
jQuery(simple_captcha_settings).show();
jQuery(recaptcha_settings).hide();
}
else{
jQuery(simple_captcha_settings).hide();
jQuery(recaptcha_settings).show();
}
//mapping blackglass (from older version) to dark and all other themes to light
var theme = field.captchaTheme == undefined || ['blackglass', 'dark'].indexOf( field.captchaTheme ) < 0 ? 'light' : 'dark';
jQuery('#field_captcha_theme').val( theme).show();
//check the captcha theme to reset the language since the language cannot be specifically checked
var lang = field.captchaLanguage == undefined ? 'en' : field.captchaLanguage;
jQuery('#field_captcha_language').val( lang ).show();
//add captcha option to drop down if it does not already exist
if ( jQuery('#field_captcha_type option[value="captcha"]').length < 1){
jQuery('#field_captcha_type').prepend('<option value="captcha">reCAPTCHA</option>');
}
}
//Display custom field template for texareas and text fields
if(field["type"] == "post_custom_field" && (field["inputType"] == "textarea" || field["inputType"] == "text")){
jQuery(".customfield_content_template_setting").show();
}
if(field["type"] == "name"){
if(typeof field["nameFormat"] == 'undefined' || field["nameFormat"] != "advanced"){
field = MaybeUpgradeNameField(field);
} else {
SetUpAdvancedNameField();
}
if(field["nameFormat"] == "simple"){
jQuery(".default_value_setting").show();
jQuery(".size_setting").show();
jQuery('#field_name_fields_container').html('').hide();
jQuery('.sub_label_placement_setting').hide();
jQuery('.name_prefix_choices_setting').hide();
jQuery('.name_format_setting').hide();
jQuery('.name_setting').hide();
jQuery('.default_input_values_setting').hide();
jQuery('.default_value_setting').show();
} else if(field["nameFormat"] == "extended") {
jQuery('.name_format_setting').show();
jQuery('.name_prefix_choices_setting').hide();
jQuery('.name_setting').hide();
jQuery('.default_input_values_setting').hide();
jQuery('.input_placeholders_setting').hide();
}
}
// if a product or option field, hide "other choice" setting
if(jQuery.inArray(field['type'], ['product', 'option', 'shipping']) != -1) {
jQuery(".other_choice_setting").hide();
}
// if calc enabled, hide range
if(field.enableCalculation) {
jQuery('li.range_setting').hide();
}
if(field.type == 'text') {
if(field.inputMask) {
jQuery(".maxlen_setting").hide();
} else {
jQuery(".maxlen_setting").show();
}
}
if(inputType == "date"){
ToggleDateSettings(field);
}
if(inputType == "email"){
ToggleEmailSettings(field);
}
// Setup Password field.
if ( field.type === 'password' || field.inputType === 'password' ) {
// Upgrade Password field properties.
field = UpgradePasswordField( field );
// Create Password inputs UI.
var passwordFields = GetCustomizeInputsUI( field );
jQuery( '#field_password_fields_container' ).html( passwordFields );
jQuery( '#field_password_fields_container table tr:eq(1) td:eq(0) img' ).remove();
// Show/Hide Size setting.
var confirmEnabled = field.inputs[1].isHidden == 'undefined' ? true : ! field.inputs[1].isHidden;
if ( confirmEnabled ) {
jQuery( '.size_setting' ).hide();
}
// Hide Password sub-label.
jQuery( '.password_setting .custom_inputs_setting ' ).on( 'click keypress', '.input_active_icon', function () {
var field = GetSelectedField(),
confirmEnabled = ! field.inputs[1].isHidden,
passwordSubLabel = jQuery( 'label[for="input_' + field.id + '"]' );
if ( confirmEnabled ) {
passwordSubLabel.show();
jQuery( '.size_setting' ).hide();
} else {
passwordSubLabel.hide();
jQuery( '.size_setting' ).show();
}
} );
}
jQuery(document).trigger('gform_load_field_settings', [field, form]);
jQuery("#field_settings").appendTo(".field_selected");
jQuery("#field_settings").tabs("option", "active", 0);
ShowSettings("field_settings");
gform.doAction('gform_post_load_field_settings', [field, form]);
SetProductField(field);
var tabsToHide = [];
// Hide the appearance tab if it has no settings
var $appearanceSettings = jQuery("#gform_tab_3 li.field_setting").filter(function() {
return jQuery(this).is(':hidden') && jQuery(this).css('display') != 'none';
});
if($appearanceSettings.length == 0){
tabsToHide.push(1);
}
// Hide the advanced tab if it has no settings
var $advancedSettings = jQuery("#gform_tab_2 li.field_setting").filter(function() {
return jQuery(this).is(':hidden') && jQuery(this).css('display') != 'none';
});
if($advancedSettings.length == 0){
tabsToHide.push(2);
}
if(tabsToHide.length > 0){
jQuery("#field_settings").tabs({disabled:tabsToHide});
} else {
jQuery("#field_settings").tabs({disabled:[]});
}
Placeholders.enable();
}
function ToggleDateSettings(field){
var isDateField = field["dateType"] == "datefield";
var isDatePicker = field["dateType"] == "datepicker";
var isDateDropDown = field["dateType"] == "datedropdown";
jQuery('.placeholder_setting').toggle(isDatePicker);
jQuery('.default_value_setting').toggle(isDatePicker);
jQuery('.sub_label_placement_setting').toggle(isDateField);
jQuery('.sub_labels_setting').toggle(isDateField);
jQuery('.default_input_values_setting').toggle(isDateDropDown || isDateField);
jQuery('.input_placeholders_setting').toggle(isDateDropDown || isDateField);
}
function SetUpAdvancedNameField(){
field = GetSelectedField();
jQuery('.name_format_setting').hide();
jQuery('.name_setting').show();
jQuery('.name_prefix_choices_setting').show();
var nameFields = GetCustomizeInputsUI(field);
jQuery('#field_name_fields_container').html(nameFields).show();
var prefixInput = GetInput(field, field.id + '.2');
var prefixChoices = GetInputChoices(prefixInput);
jQuery('#field_prefix_choices').html(prefixChoices);
ToggleNamePrefixUI(!prefixInput.isHidden);
jQuery('.name_setting .custom_inputs_setting').on('click', '.input_active_icon', function(){
var inputId = jQuery(this).data('input_id');
if(inputId.toString().indexOf(".2") >=0){
var isActive = this.src.indexOf("active1.png") >=0;
ToggleNamePrefixUI(isActive);
}
});
jQuery('.default_value_setting').hide();
jQuery('.default_input_values_setting').show();
jQuery('.input_placeholders_setting').show();
CreateDefaultValuesUI(field);
CreatePlaceholdersUI(field);
CreateInputNames(field);
}
function GetCopyValuesFieldsOptions(selectedFieldId, currentField){
var options = [], label, field, option, currentType = GetInputType(currentField), selected;
for(var i = 0; i < form.fields.length;i++){
field = form.fields[i];
if(field.id != currentField.id && GetInputType(field) == currentType && !field.enableCopyValuesOption){
label = GetLabel(field);
selected = selectedFieldId == field.id ? 'selected="selected"' : '';
option = '<option value="' + field.id + '" ' + selected + '>' + label + '</option>';
options.push(option);
}
}
return options.join('');
}
function ToggleNamePrefixUI(isActive){
jQuery('.name_prefix_choices_setting').toggle(isActive);
}
function TogglePageBreakSettings(){
if(HasPageBreak()){
jQuery("#gform_last_page_settings").show();
jQuery("#gform_pagination").show();
}
else
{
jQuery("#gform_last_page_settings").hide();
jQuery("#gform_pagination").hide();
}
}
function SetDisableQuantity(isChecked){
SetFieldProperty('disableQuantity', isChecked);
if(isChecked)
jQuery(".field_selected .ginput_quantity_label, .field_selected .ginput_quantity").hide();
else
jQuery(".field_selected .ginput_quantity_label, .field_selected .ginput_quantity").show();
}
function SetBasePrice(number){
if(!number)
number = 0;
var currency = GetCurrentCurrency();
var price = currency.toMoney(number);
if(price == false)
price = 0;
jQuery("#field_base_price").val(price);
SetFieldProperty('basePrice', price);
jQuery(".field_selected .ginput_product_price, .field_selected .ginput_shipping_price").html(price);
jQuery(".field_selected .ginput_amount").val(price);
}
function ChangeAddressType(){
field = GetSelectedField();
if(field["type"] != "address")
return;
var addressType = jQuery("#field_address_type").val();
var countryInput = GetInput(field, field.id + ".6");
var country = jQuery("#field_address_country_" + addressType).val();
if(country == ''){
countryInput.isHidden = false
} else {
countryInput.isHidden = true;
}
SetAddressType(false);
}
function SetAddressType(isInit){
field = GetSelectedField();
if(field["type"] != "address")
return;
SetAddressProperties();
jQuery(".gfield_address_type_container").hide();
var speed = isInit ? "" : "slow";
jQuery("#address_type_container_" + jQuery("#field_address_type").val()).show(speed);
CreatePlaceholdersUI(field);
}
function UpdateAddressFields(){
var addressType = jQuery("#field_address_type").val();
field = GetSelectedField();
var address_fields_str = GetCustomizeInputsUI(field);
jQuery("#field_address_fields_container").html(address_fields_str);
//change zip label
var zipInput = GetInput(field, field.id + ".5");
var zip_label = jQuery("#field_address_zip_label_" + addressType).val();
jQuery("#field_custom_input_default_label_" + field.id + "_5").text(zip_label);
jQuery("#field_custom_input_label_" + field.id + "\\.5").attr("placeholder", zip_label);
if(!zipInput.customLabel){
jQuery(".field_selected #input_" + field["id"] + "_5_label").html(zip_label);
}
//change state label
var stateInput = GetInput(field, field.id + ".4");
var state_label = jQuery("#field_address_state_label_" + addressType).val();
jQuery("#field_custom_input_default_label_" + field.id + "_4").text(state_label);
jQuery("#field_custom_input_label_" + field.id + "\\.4").attr("placeholder", state_label);
if(!stateInput.customLabel){
jQuery(".field_selected #input_" + field["id"] + "_4_label").html(state_label);
}
//hide country drop down if this address type applies to a specific country
var hide_country = jQuery("#field_address_country_" + addressType).val() != "";
if(hide_country){
jQuery('.field_selected #input_' + field.id + '_6_container').hide();
jQuery('.field_custom_input_row_input_' + field.id + '_6').hide();
} else {
//selects default country and displays drop down
jQuery(".field_selected #input_" + field.id + "_6").val(jQuery("#field_address_default_country_" + addressType).val());
jQuery(".field_selected #input_" + field.id + "_6_container").show();
jQuery('.field_selected .field_custom_input_row_input_' + field.id + '_6').show();
}
var has_state_drop_down = jQuery("#field_address_has_states_" + addressType).val() != "";
if(has_state_drop_down){
jQuery(".field_selected .state_text").hide();
var selected_state = jQuery("#field_address_default_state_" + addressType).val()
var state_dropdown = jQuery(".field_selected .state_dropdown");
state_dropdown.append(jQuery('<option></option>').val(selected_state).html(selected_state));
state_dropdown.val(selected_state).show();
}
else{
jQuery(".field_selected .state_dropdown").hide();
jQuery(".field_selected .state_text").show();
}
}
function SetAddressProperties(){
field = GetSelectedField();
var addressType = jQuery("#field_address_type").val();
SetFieldProperty("addressType", addressType);
SetFieldProperty("defaultState", jQuery("#field_address_default_state_" + addressType).val());
SetFieldProperty("defaultProvince",""); //for backwards compatibility
//Only save the hide country property for address types that have that option (ones with no country)
var country = jQuery("#field_address_country_" + addressType).val();
if(country == ""){
country = jQuery("#field_address_default_country_" + addressType).val();
}
SetFieldProperty("defaultCountry",country);
UpdateAddressFields();
}
function MaybeUpgradeNameField(field){
if(typeof field.nameFormat == 'undefined' || field.nameFormat == '' || field.nameFormat == 'normal' || (field.nameFormat == 'simple' && !has_entry(field.id))){
field = UpgradeNameField(field, true, true, true);
}
return field;
}
function UpgradeNameField(field, prefixHiddex, middleHidden, suffixHidden){
field.nameFormat = 'advanced';
field.inputs = MergeInputArrays(GetAdvancedNameFieldInputs(field, prefixHiddex, middleHidden, suffixHidden), field.inputs);
RefreshSelectedFieldPreview(function(){
SetUpAdvancedNameField();
});
return field;
}
function UpgradeDateField(field){
if(field.type != 'date' && field.inputType != 'date' ){
return field;
}
if(typeof field.dateType != 'undefined' && field.dateType != 'datepicker' && !field.inputs){
field.inputs = GetDateFieldInputs(field);
}
return field;
}
function UpgradeTimeField(field){
if(field.type != 'time' && field.inputType != 'time' ){
return field;
}
if(!field.inputs){
field.inputs = GetTimeFieldInputs(field);
}
return field;
}
function UpgradeEmailField(field){
if(field.type != 'email' && field.inputType != 'email'){
return field;
}
if(field.emailConfirmEnabled && !field.inputs){
field.inputs = GetEmailFieldInputs(field);
field.inputs[0].placeholder = field.placeholder
}
return field;
}
function UpgradePasswordField(field){
if(field.type != 'password' && field.inputType != 'password'){
return field;
}
if(!field.inputs){
field.inputs = GetPasswordFieldInputs(field);
field.inputs[0].placeholder = field.placeholder
}
return field;
}
function UpgradeAddressField(field){
if(field.hideCountry){
var countryInput = GetInput(field, field.id + ".6");
countryInput.isHidden = true;
}
delete field.hideCountry;
if(field.hideAddress2){
var address2Input = GetInput(field, field.id + ".2");
address2Input.isHidden = true;
}
delete field.hideAddress2;
if(field.hideState){
var stateInput = GetInput(field, field.id + ".4");
stateInput.isHidden = true;
}
delete field.hideState;
return field;
}
function UpgradeConsentField(field) {
if(field.type !== 'consent'){
return field;
}
if(field.choices[1] && field.choices[1]['value'] === "0"){
field.choices.pop();
}
return field;
}
function TogglePasswordVisibility( isInit ){
if ( jQuery( '#gfield_password_visibility_enabled' ).is( ":checked" ) ) {
jQuery( '.gfield.field_selected .ginput_container_password span button' ).show();
} else {
jQuery( '.gfield.field_selected .ginput_container_password span button' ).hide();
}
}
function TogglePasswordStrength(isInit){
var speed = isInit ? "" : "slow";
if(jQuery("#gfield_password_strength_enabled").is(":checked")){
jQuery("#gfield_min_strength_container").show(speed);
}
else{
jQuery("#gfield_min_strength_container").hide(speed);
}
}
function ToggleCategory(isInit){
var speed = isInit ? "" : "slow";
if(jQuery("#gfield_category_all").is(":checked")){
jQuery("#gfield_settings_category_container").hide(speed);
SetFieldProperty("displayAllCategories", true);
SetFieldProperty("choices", new Array()); //reset selected categories
}
else{
jQuery("#gfield_settings_category_container").show(speed);
SetFieldProperty("displayAllCategories", false);
}
}
function SetCopyValuesOptionLabel(value){
SetFieldProperty('copyValuesOptionLabel', value);
jQuery('.field_selected .copy_values_option_label').html(value);
}
function SetCustomFieldTemplate(){
var enabled = jQuery("#gfield_customfield_content_enabled").is(":checked");
SetFieldProperty("customFieldTemplate", enabled ? jQuery("#field_customfield_content_template").val() : null);
SetFieldProperty("customFieldTemplateEnabled", enabled );
}
function SetCategoryInitialItem(){
var enabled = jQuery("#gfield_post_category_initial_item_enabled").is(":checked");
SetFieldProperty("categoryInitialItem", enabled ? jQuery("#field_post_category_initial_item").val() : null);
SetFieldProperty("categoryInitialItemEnabled", enabled );
}
function PopulateContentTemplate(fieldName){
if(jQuery("#" + fieldName).val().length == 0){
var field = GetSelectedField();
jQuery("#" + fieldName).val("{" + field.label + ":" + field.id + "}");
}
}
function TogglePostContentTemplate(isInit){
var speed = isInit ? "" : "slow";
if(jQuery("#gfield_post_content_enabled").is(":checked")){
jQuery("#gfield_post_content_container").show(speed);
if(!isInit){
PopulateContentTemplate("field_post_content_template");
}
}
else{
jQuery("#gfield_post_content_container").hide(speed);
}
}
function TogglePostTitleTemplate(isInit){
var speed = isInit ? "" : "slow";
if(jQuery("#gfield_post_title_enabled").is(":checked")){
jQuery("#gfield_post_title_container").show(speed);
if(!isInit)
PopulateContentTemplate("field_post_title_template");
}
else{
jQuery("#gfield_post_title_container").hide(speed);
}
}
function ToggleCustomFieldTemplate(isInit){
var speed = isInit ? "" : "slow";
if(jQuery("#gfield_customfield_content_enabled").is(":checked")){
jQuery("#gfield_customfield_content_container").show(speed);
if(!isInit){
PopulateContentTemplate("field_customfield_content_template");
}
}
else{
jQuery("#gfield_customfield_content_container").hide(speed);
}
}
function ToggleInputName(isInit){
var speed = isInit ? "" : "slow";
if(jQuery('#field_prepopulate').is(":checked")){
jQuery('#field_input_name_container').show(speed);
}
else{
jQuery('#field_input_name_container').hide(speed);
jQuery("#field_input_name").val("");
}
}
function SetFieldColumns(){
SetFieldChoices();
}
function ToggleChoiceValue(isInit){
var speed = isInit ? "" : "slow";
var field = GetSelectedField();
var suffix = field.enablePrice ? "_and_price" : "";
var container = jQuery('#gfield_settings_choices_container');
//removing all classes
container.removeClass("choice_with_price choice_with_value choice_with_value_and_price");
var isShowValues = jQuery('#field_choice_values_enabled').is(":checked");
if(isShowValues){
container.addClass("choice_with_value" + suffix);
}
else if(field.enablePrice){
container.addClass("choice_with_price");
}
}
function ToggleInputChoiceValue($container, enabled){
if(typeof enabled == 'undefined'){
enabled = false;
}
var field = GetSelectedField();
var inputId = $container.find('li').data('input_id');
var input = GetInput(field, inputId);
input.enableChoiceValue = enabled;
//removing all classes
$container.removeClass("choice_with_value");
if(enabled){
$container.addClass("choice_with_value");
}
}
function ToggleCopyValuesActivated(isActivated){
jQuery('.field_selected .copy_values_activated').prop('checked', isActivated);
var field = GetSelectedField();
jQuery('#input_'+ field.id).toggle(!isActivated);
}
function TogglePageButton(button_name, isInit){
var isText = jQuery("#" + button_name + "_button_text").is(":checked");
show_element = isText ? "#" + button_name + "_button_text_container" : "#" + button_name + "_button_image_container"
hide_element = isText ? "#" + button_name + "_button_image_container" : "#" + button_name + "_button_text_container";
if(isInit){
jQuery(hide_element).hide();
jQuery(show_element).show();
}
else{
jQuery(hide_element).hide();
jQuery(show_element).fadeIn(800);
}
}
function SetPageButton(button_name){
field = GetSelectedField();
var buttonType = jQuery("#" + button_name + "_button_image").is(":checked") ? "image" : "text";
field[button_name + "Button"]["type"] = buttonType;
if(buttonType == "image"){
field[button_name + "Button"]["text"] = "";
field[button_name + "Button"]["imageUrl"] = jQuery("#" + button_name + "_button_image_url").val();
}
else{
field[button_name + "Button"]["text"] = jQuery("#" + button_name + "_button_text_input").val();
field[button_name + "Button"]["imageUrl"] = "";
}
}
function ToggleCustomField(isInit){
var isExisting = jQuery("#field_custom_existing").is(":checked");
show_element = isExisting ? "#field_custom_field_name_select" : "#field_custom_field_name_text"
hide_element = isExisting ? "#field_custom_field_name_text" : "#field_custom_field_name_select";
var speed = isInit ? "" : "";
jQuery(hide_element).hide(speed);
jQuery(show_element).show(speed);
}
function ToggleInputMask(isInit){
var speed = isInit ? "" : "slow";
if(jQuery("#field_input_mask").is(":checked")){
jQuery("#gform_input_mask").show(speed);
jQuery(".maxlen_setting").hide();
SetFieldProperty('inputMask', true);
//setting max length to blank
jQuery("#field_maxlen").val("");
SetFieldProperty('maxLength', "");
}
else{
jQuery("#gform_input_mask").hide(speed);
jQuery(".maxlen_setting").show();
SetFieldProperty('inputMask', false);
SetFieldProperty('inputMaskValue', '');
SetFieldProperty('inputMaskIsCustom', false);
}
}
function ToggleInputMaskOptions(isInit){
var isStandard = jQuery('#field_mask_standard').is(':checked'),
show_element = isStandard ? '#field_mask_select' : '#field_mask_text, .mask_text_description',
hide_element = isStandard ? '#field_mask_text, .mask_text_description' : '#field_mask_select',
speed = isInit ? '' : '';
jQuery(hide_element).val('').hide(speed);
jQuery(show_element).show(speed);
if (!isInit) {
SetFieldProperty('inputMaskValue', '');
SetFieldProperty('inputMaskIsCustom', !isStandard);
}
}
function ToggleAutoresponder(){
if(jQuery("#form_autoresponder_enabled").is(":checked"))
jQuery("#form_autoresponder_container").show("slow");
else
jQuery("#form_autoresponder_container").hide("slow");
}
function ToggleMultiFile(isInit){
var speed = isInit ? "" : "slow";
if(jQuery("#field_multiple_files").prop("checked")){
jQuery("#gform_multiple_files_options").show(speed);
var $uploadField = jQuery('.gform_fileupload_multifile');
var pluploadSettings = $uploadField.data('settings');
if ( pluploadSettings && typeof pluploadSettings.chunk_size != 'undefined' ) {
jQuery('#gform_server_max_file_size_notice').hide();
}
SetFieldProperty('multipleFiles', true);
}
else{
jQuery("#gform_multiple_files_options").hide(speed);
SetFieldProperty('multipleFiles', false);
jQuery("#field_max_files").val("");
SetFieldProperty('maxFiles', "");
}
if(!isInit){
var field = GetSelectedField();
jQuery("#field_settings").slideUp(function(){StartChangeInputType("fileupload", field);});
}
}
function HasPostContentField(){
for(var i=0; i<form.fields.length; i++){
var type = form.fields[i].type;
if(type == "post_content")
return true;
}
return false;
}
function HasPostTitleField(){
for(var i=0; i<form.fields.length; i++){
var type = form.fields[i].type;
if(type == "post_title")
return true;
}
return false;
}
function HasCustomField(){
for(var i=0; i<form.fields.length; i++){
var type = form.fields[i].type;
if(type == "post_custom_field")
return true;
}
return false;
}
function HasPageBreak(){
for(var i=0; i<form.fields.length; i++){
var type = form.fields[i].type;
if(type == "page")
return true;
}
return false;
}
function SetNextButtonConditionalLogic(isChecked){
var field = GetSelectedField();
field.nextButton.conditionalLogic = isChecked ? new ConditionalLogic() : null;
}
function UpdateFormObject(){
form.postContentTemplateEnabled = false;
form.postTitleTemplateEnabled = false;
form.postTitleTemplate = "";
form.postContentTemplate = "";
if(HasPostField()){
form.postAuthor = jQuery('#field_post_author').val() ? jQuery('#field_post_author').val() : "";
form.useCurrentUserAsAuthor = jQuery('#gfield_current_user_as_author').is(":checked");
form.postCategory = jQuery('#field_post_category').val();
form.postFormat = jQuery('#field_post_format').length != 0 ? jQuery('#field_post_format').val() : 0;
form.postStatus = jQuery('#field_post_status').val();
}
if(jQuery("#gfield_post_content_enabled").is(":checked") && HasPostContentField()){
form.postContentTemplateEnabled = true;
form.postContentTemplate = jQuery("#field_post_content_template").val();
}
if(jQuery("#gfield_post_title_enabled").is(":checked") && HasPostTitleField()){
form.postTitleTemplateEnabled = true;
form.postTitleTemplate = jQuery("#field_post_title_template").val();
}
if(jQuery("#gform_last_page_settings").is(":visible")){
form.lastPageButton = new Button();
form.lastPageButton.type = jQuery("#last_page_button_text").is(":checked") ? "text" : "image";
if(form.lastPageButton.type == "image"){
form.lastPageButton.text = "";
form.lastPageButton.imageUrl = jQuery("#last_page_button_image_url").val();
}
else{
form.lastPageButton.text = jQuery("#last_page_button_text_input").val();
form.lastPageButton.imageUrl = "";
}
}
else{
form.lastPageButton = null;
}
if(jQuery("#gform_pagination").is(":visible")){
form["pagination"] = new Object();
var type = jQuery("input[name=\"pagination_type\"]:checked").val();
form["pagination"]["type"] = type;
var pageNames = jQuery(".gform_page_names input");
form["pagination"]["pages"] = new Array();
for(var i=0; i<pageNames.length; i++){
form["pagination"]["pages"].push(jQuery(pageNames[i]).val());
}
if(type == "percentage"){
form["pagination"]["style"] = jQuery("#percentage_style").val();
form["pagination"]["backgroundColor"] = form["pagination"]["style"] == "custom" ? jQuery("#percentage_style_custom_bgcolor").val() : null;
form["pagination"]["color"] = form["pagination"]["style"] == "custom" ? jQuery("#percentage_style_custom_color").val() : null;
form["pagination"]["display_progressbar_on_confirmation"] = jQuery("#percentage_confirmation_display").is(":checked");
form["pagination"]["progressbar_completion_text"] = jQuery("#percentage_confirmation_display").is(":checked") ? jQuery("#percentage_confirmation_page_name").val() : null;
}
else{
form["pagination"]["backgroundColor"] = null;
form["pagination"]["color"] = null;
form["pagination"]["display_progressbar_on_confirmation"] = null;
form["pagination"]["progressbar_completion_text"] = null;
}
form["firstPageCssClass"] = jQuery("#first_page_css_class").val();
}
else{
form["pagination"] = null;
form["firstPageCssClass"] = null;
}
SortFields();
// allow users to update form with custom function before save
if(window["gform_before_update"]){
form = window["gform_before_update"](form);
if(window.console)
console.log('"gform_before_update" is deprecated since version 1.7! Use the "gform_pre_form_editor_save" filter instead.');
}
// new method for filtering the form object before save
form = gform.applyFilters('gform_pre_form_editor_save', form);
}
function EndUpdateForm(formId){
jQuery("#please_wait_container").hide();
jQuery("#after_update_dialog").hide();
jQuery("#after_update_error_dialog").hide();
if(formId)
jQuery("#after_update_dialog").slideDown();
else
jQuery("#after_update_error_dialog").slideDown();
setTimeout(function(){jQuery('#after_update_dialog').slideUp();}, 5000);
}
function SortFields(){
var fields = new Array();
jQuery(".gfield").each(function(){
id = this.id.substr(6);
fields.push(GetFieldById(id));
}
);
form.fields = fields;
}
/**
* Mark a field for deletion upon save.
*
* @param element The field element being deleted.
*/
function DeleteField( element ) {
// Get field ID from element.
var fieldId = jQuery( element )[0].id.split( '_' )[2];
// Confirm that user is aware about entry data being deleted.
if ( ! HasConditionalLogicDependency( fieldId ) && ! confirm( gf_vars.confirmationDeleteField ) ) {
return;
}
// If conditional logic dependency is found, confirm that user is aware and wants to proceed.
if ( HasConditionalLogicDependency( fieldId ) && ! confirm( gf_vars.conditionalLogicDependency ) ) {
return;
}
// Initialize deleted field property.
if ( ! form.deletedFields ) {
form.deletedFields = [];
}
// Add field ID to form object.
form.deletedFields.push( fieldId );
// Loop through form fields.
for ( var i = 0; i < form.fields.length; i++ ) {
// If field ID matches the one to be deleted, delete it.
if ( form.fields[i].id == fieldId ) {
// Remove the field.
form.fields.splice(i, 1);
// Move field settings element outside of the field before it is deleted.
jQuery( '#field_settings').insertBefore( '#gform_fields' );
// Fade out field, then remove.
jQuery( '#field_' + fieldId ).fadeOut( 'slow', function() {
// Remove field element.
jQuery( '#field_' + fieldId ).remove();
// Show no fields placeholder if there are no form fields.
if ( form.fields.length === 0 ) {
jQuery( '#no-fields' ).detach().appendTo( '#gform_fields' ).show();
}
} );
// Hide field settings panel.
HideSettings( 'field_settings' );
break;
}
}
// Toggle page break settings.
TogglePageBreakSettings();
// Run field deleted action.
jQuery( document).trigger( 'gform_field_deleted', [ form, fieldId ] );
}
/**
* Check if a field or choice has a field with conditional logic dependent upon it.
*
* If a field is being deleted, only a field ID is required. If a choice is being edited or deleted
* both the field ID and the value of the choice should be provided. This function will then loop
* through all form fields and each field's conditional logic rules to find if any field depends on
* the field being modified for conditional logic.
*
* Triggered when:
* delete field pass field ID
* delete choice pass field ID, value
* edit choice pass field ID, value
*
* @param fieldId the field ID that is being edited or deleted
* @param value Optional the value of the choice being edited or deleted
*
* @returns {Boolean}
*/
function HasConditionalLogicDependencyLegwork(fieldId, value) {
// check form button conditional logic
if(form.button && ObjectHasConditionalLogicDependency(form.button, fieldId, value) )
return true;
// check confirmations conditional logic
for(i in form.confirmations) {
if(!form.confirmations.hasOwnProperty(i))
continue;
if( ObjectHasConditionalLogicDependency(form.confirmations[i], fieldId, value) )
return true;
}
// check notifications conditional logic
for(i in form.notifications) {
if(!form.notifications.hasOwnProperty(i))
continue;
if( ObjectHasConditionalLogicDependency(form.notifications[i], fieldId, value) )
return true;
}
// check field conditional logic
for(i in form.fields) {
if(!form.fields.hasOwnProperty(i))
continue;
var field = form.fields[i];
if( ObjectHasConditionalLogicDependency(field, fieldId, value) )
return true;
// if this is a page field, check the next button conditional logic as well
if( GetInputType(field) == 'page' && ObjectHasConditionalLogicDependency(field.nextButton, fieldId, value) )
return true;
}
return false;
}
/**
* Runs the check for conditional logic dependencies and then applies a filter to result.
*
* Couldn't find a tidier way of applying the filter in the original function so I made this
* caller function so the code remains effecient and user can override the result in cases
* of failure and success.
*
* @param fieldId
* @param value
*/
function HasConditionalLogicDependency(fieldId, value) {
var result = HasConditionalLogicDependencyLegwork(fieldId, value);
return gform.applyFilters('gform_has_conditional_logic_dependency', result, fieldId, value);
}
/**
* Determine if an object has a conditional logic rule dependent on the field and/or value provided.
*
* All GF objects (fields, buttons, confirmations, etc) that have conditional logic have it stored in a
* 'conditionaLogic' property. This function checks if this property exists and if so loops through all
* the rules until it finds a match. If not match is found, function returns false.
*
* @param object The GF Object that has conditional logic property (fields, buttons, confirmation, notifications, paging)
* @param fieldId The fieldId being modified and on which a dependency is being searched for
* @param value Optional The value of the choice being being modified or deleted
*
* @returns {Boolean}
*/
function ObjectHasConditionalLogicDependency(object, fieldId, value) {
if(!object.conditionalLogic)
return false;
if(typeof value == 'undefined')
var value = false;
var rules = object.conditionalLogic.rules;
for(i in rules) {
if(! rules.hasOwnProperty(i))
continue;
var rule = rules[i];
// if rule field ID does not match the field ID of the field being modified, continue
if(rule.fieldId != fieldId)
continue;
// if value is provided and the rule value does not match provided value, continue
if(value !== false && rule.value != value)
continue;
if (!value && !rule.value) {
var ruleField = GetFieldById(fieldId);
if (ruleField && ruleField.choices && ruleField.placeholder) {
continue;
}
}
return true;
}
return false;
}
function HasDependentRule(rules, fieldId, value) {
if(typeof value == 'undefined')
value = false;
for(i in rules) {
if(! rules.hasOwnProperty(i))
continue;
var rule = rules[i];
// if rule field ID does not match the field ID of the field being modified, continue
if(rule.fieldId != fieldId)
continue;
// if value is provided and the rule value does not match provided value, continue
if(value !== false && rule.value != value)
continue;
return true;
}
return false;
}
function CheckChoiceConditionalLogicDependency(input) {
var field = GetSelectedField();
var previousValue = jQuery(input).data('previousValue'); // Get the value before checking. Fixes an issue in Chrome on Windows.
if (previousValue == undefined){
//set a value because undefined cannot be saved with jQuery data
previousValue = '';
}
if(HasConditionalLogicDependency(field.id, previousValue)) {
// confirm that the user wants to make the modification
if(confirm(gf_vars.conditionalLogicDependencyChoiceEdit)) {
return;
}
// if user does not want to make modification, replace with original value
jQuery(input).val(previousValue).trigger('keyup');
jQuery(input).data('previousValue', previousValue);
}
}
function StartDuplicateField(element) {
var sourcefieldId = jQuery(element)[0].id.split("_")[2];
for(fieldIndex in form.fields){
if(! form.fields.hasOwnProperty(fieldIndex))
continue;
if(form.fields[fieldIndex].id == sourcefieldId) {
// create a copy of the field
var field = Copy(form.fields[fieldIndex]);
field.id = GetNextFieldId();
if(field.inputs != null) {
for(inputIndex in field.inputs) {
if(!field.inputs.hasOwnProperty(inputIndex))
continue;
var id = field.inputs[inputIndex]['id'] + '',
newId = id == sourcefieldId ? field.id : id.replace(/(\d+\.)/, field.id + '.');
field.inputs[inputIndex]['id'] = newId;
}
}
/**
* Modify the field that is being duplicated.
*
* @param object field The duplicated field.
* @param object form The current form object.
*
* @since @todo
*/
field = gform.applyFilters( 'gform_duplicate_field', field, form );
field = gform.applyFilters( 'gform_duplicate_field_{0}'.format( GetInputType( field ) ), field, form );
form.fields.splice(fieldIndex, 0, field);
DuplicateField(field, sourcefieldId);
return;
}
}
}
function EndDuplicateField(field, fieldString, sourceFieldId) {
//sets up DOM for new field
jQuery('#gform_fields li#field_' + sourceFieldId).after(fieldString);
var newFieldElement = jQuery('#field_' + field.id);
//highlighting animation
newFieldElement.animate({ backgroundColor: '#FFFBCC' }, 'fast', function(){jQuery(this).animate({backgroundColor: '#FFF'}, 'fast', function(){jQuery(this).css('background-color', '');})});
//Closing editors
HideSettings('field_settings');
HideSettings('form_settings');
HideSettings('last_page_settings');
TogglePageBreakSettings();
InitializeFields();
}
function GetFieldsByType(types){
var fields = new Array();
for(var i=0; i<form["fields"].length; i++){
if(IndexOf(types, form["fields"][i]["type"]) >= 0)
fields.push(form["fields"][i]);
}
return fields;
}
function GetNextFieldId(){
var nextFieldId;
if ( typeof form.nextFieldId == 'undefined' ) {
var max = 0;
for(var i=0; i<form.fields.length; i++){
if(parseFloat(form.fields[i].id) > max)
max = parseFloat(form.fields[i].id);
}
if (form.deletedFields) {
for (var i = 0; i < form.deletedFields.length; i++) {
if (parseFloat(form.deletedFields[i]) > max)
max = parseFloat(form.deletedFields[i]);
}
}
nextFieldId = parseFloat(max) + 1;
} else {
nextFieldId = parseInt(form.nextFieldId);
}
form.nextFieldId = nextFieldId + 1;
return nextFieldId;
}
function EndAddField(field, fieldString, index){
gf_vars['currentlyAddingField'] = false;
jQuery('#gform_adding_field_spinner').remove();
//sets up DOM for new field
if(typeof index != 'undefined'){
form.fields.splice(index, 0, field);
if (index === 0) {
jQuery('#gform_fields').prepend(fieldString);
} else {
jQuery('#gform_fields').children().eq(index - 1).after(fieldString);
}
} else {
jQuery('#gform_fields').append(fieldString);
//creates new javascript field
form.fields.push(field);
}
var newFieldElement = jQuery('#field_' + field.id);
newFieldElement.animate({ backgroundColor: '#FFFBCC' }, 'fast', function(){jQuery(this).animate({backgroundColor: '#FFF'}, 'fast', function(){jQuery(this).css('background-color', '');})})
if ( jQuery( '#no-fields-stash li').length === 0 ) {
// Stash the "no fields" placeholder away from the fields to avoid a sortable wobble.
jQuery( '#no-fields').detach().appendTo( '#no-fields-stash' );
}
//Unselects all fields
jQuery('.selectable').removeClass('field_selected');
//Closing editors
HideSettings('field_settings');
HideSettings('form_settings');
HideSettings('last_page_settings');
//Select current field
newFieldElement.addClass('field_selected');
//initializes new field with default data
SetFieldSize(field.size);
TogglePageBreakSettings();
InitializeFields();
newFieldElement.removeClass('field_selected');
jQuery(document).trigger('gform_field_added', [form, field]);
}
function StartChangeNameFormat(format){
field = GetSelectedField();
UpgradeNameField(field, false, true, false);
}
function StartChangeCaptchaType(captchaType){
field = GetSelectedField();
field["captchaType"] = captchaType;
SetFieldProperty('captchaType', captchaType);
//jQuery("#field_settings").slideUp(function(){StartChangeInputType(field["captchaType"], field);});
jQuery("#field_settings").slideUp(function(){StartChangeInputType(field["type"], field);});
ResetRecaptcha();
}
function ResetRecaptcha(){
field = GetSelectedField();
field['captchaLanguage'] = 'en';
field['captchaTheme'] = 'light';
}
function StartChangeProductType(type) {
field = GetSelectedField();
if (type === 'radio' || type === 'select') {
field.enablePrice = true;
} else {
field.enablePrice = null;
field.choices = null;
}
if (type !== 'calculation') {
field.enableCalculation = false;
field.calculationFormula = '';
}
return StartChangeInputType(type, field);
}
function StartChangeDonationType(type){
field = GetSelectedField();
if(type != "donation")
field["enablePrice"] = true;
else
field["enablePrice"] = null;
return StartChangeInputType(type, field);
}
function StartChangeShippingType(type) {
field = GetSelectedField();
if (type !== 'singleshipping') {
field.enablePrice = true;
} else {
field.enablePrice = null;
field.choices = null;
}
return StartChangeInputType(type, field);
}
function StartChangePostCategoryType(type){
if(type == 'dropdown') {
jQuery('.post_category_initial_item_setting').hide();
} else {
jQuery('.post_category_initial_item_setting').show();
}
field = GetSelectedField();
return StartChangeInputType(type, field);
}
function StartChangePostCustomFieldType( type ) {
if ( jQuery.inArray( type, [ 'radio', 'select', 'checkbox', 'multiselect' ] ) === -1 ) {
field.choices = null;
}
return StartChangeInputType(type, field);
}
function EndChangeInputType(params){
var fieldId = params.id, fieldType = params.type, fieldString = params.fieldString;
jQuery("#field_" + fieldId).html(fieldString);
var field = GetFieldById(fieldId);
//setting input type if different than field type
field.inputType = field.type != fieldType ? fieldType : "";
SetDefaultValues(field);
SetFieldLabel(field.label);
SetFieldSize(field.size);
SetFieldDefaultValue(field.defaultValue);
SetFieldDescription(field.description);
SetFieldCheckboxLabel(field.checkboxLabel);
SetFieldRequired(field.isRequired);
InitializeFields();
LoadFieldSettings();
}
function InitializeFields(){
//Border on/off logic on mouse over
jQuery('.selectable').hover(
function () {
jQuery(this).addClass('field_hover');
},
function () {
jQuery(this).removeClass('field_hover');
}
).focus(
function () {
jQuery('.field_hover').removeClass('field_hover');
jQuery(this).addClass('field_hover');
}
);
jQuery('.field_delete_icon, .field_duplicate_icon').click(function(event){
event.stopPropagation();
});
jQuery('#field_settings, #form_settings, #last_page_settings, #pagination_settings, .captcha_message, .form_delete_icon, .all-merge-tags').click(function(event){
event.stopPropagation();
});
}
function FieldClick(field){
//disable click that happens right after dragging ends
if(gforms_dragging == field.id){
gforms_dragging = 0;
return;
}
// force focus to ensure onblur events fire for field setting inputs
jQuery('input#gform_force_focus').focus();
if(jQuery(field).hasClass("field_selected")) {
var element_id = "";
switch(field.id){
case "gform_heading" :
element_id = "#form_settings";
jQuery('.gf_form_toolbar_settings a').removeClass("gf_toolbar_active");
break;
case "gform_last_page_settings" :
element_id = "#last_page_settings";
break;
case "gform_pagination" :
element_id = "#pagination_settings";
break;
default:
element_id = "#field_settings";
}
jQuery(element_id).slideUp(function(){
jQuery(field).removeClass("field_selected").addClass("field_hover");
HideSettings("field_settings");
});
return;
}
//unselects all fields
jQuery(".selectable").removeClass("field_selected");
//selects current field
jQuery(field).removeClass("field_hover").addClass("field_selected");
//if this is a field (not the form title), load appropriate field type settings
if(field.id == "gform_heading"){
//hide field settings
HideSettings("field_settings");
HideSettings("last_page_settings");
HideSettings("pagination_settings");
InitializeFormConditionalLogic();
//Displaying form settings
ShowSettings("form_settings");
//highlighting toolbar item
jQuery('.gf_form_toolbar_settings a').addClass("gf_toolbar_active");
}
else if(field.id == "gform_last_page_settings"){
//hide field settings
HideSettings("field_settings");
HideSettings("form_settings");
HideSettings("pagination_settings");
//Displaying form settings
ShowSettings("last_page_settings");
}
else if(field.id == "gform_pagination"){
//hide field settings
HideSettings("field_settings");
HideSettings("form_settings");
HideSettings("last_page_settings");
InitPaginationOptions();
//Displaying pagination settings
ShowSettings("pagination_settings");
}
else{
//hide form settings
HideSettings("form_settings");
HideSettings("last_page_settings");
HideSettings("pagination_settings");
//selects current field
LoadFieldSettings();
}
}
function TogglePercentageStyle(isInit){
var speed = isInit ? "" : "slow";
if(jQuery("#percentage_style").val() == 'custom'){
jQuery('.percentage_custom_container').show(speed);
}
else{
jQuery('.percentage_custom_container').hide(speed);
}
}
function TogglePercentageConfirmationText(isInit){
var speed = isInit ? "" : "slow";
if(jQuery("#percentage_confirmation_display").is(":checked")){
jQuery('.percentage_confirmation_page_name_setting').show(speed);
}
else{
jQuery('.percentage_confirmation_page_name_setting').hide(speed);
}
}
function CustomFieldExists(name){
if(!name)
return true;
var options = jQuery("#field_custom_field_name_select option");
for(var i=0; i<options.length; i++)
{
if(options[i].value == name)
return true;
}
return false;
}
function IsStandardMask(value){
if(!value)
return true;
var options = jQuery("#field_mask_select option");
for(var i=0; i<options.length; i++)
{
if(options[i].value == value)
return true;
}
return false;
}
function LoadFieldChoices(field){
//loading ui
jQuery('#field_choice_values_enabled').prop("checked", field.enableChoiceValue ? true : false);
ToggleChoiceValue();
var container_name = GetInputType(field) == "list" ? "field_columns" : "field_choices";
jQuery("#" + container_name).html(GetFieldChoices(field));
//loading bulk input
LoadBulkChoices(field);
jQuery(document).trigger('gform_load_field_choices', [field]);
gform.doAction('gform_load_field_choices', [field]);
}
function LoadInputChoices($ul, input){
//loading ui
var $container = $ul.parent();
$container.find('.field_input_choice_values_enabled').prop("checked", input.enableChoiceValue ? true : false);
ToggleInputChoiceValue($container, input.enableChoiceValue);
jQuery($ul).html(GetInputChoices(input));
}
function LoadBulkChoices(field){
LoadCustomChoices();
if(!field.choices)
return;
var choices = new Array();
var choice;
for(var i=0; i<field.choices.length; i++){
choice = field.choices[i].text == field.choices[i].value ? field.choices[i].text : field.choices[i].text + "|" + field.choices[i].value;
if(field.enablePrice && field.choices[i]["price"] != "")
choice += "|:" + field.choices[i]["price"];
choices.push(choice);
}
/**
* Filter bulk loaded choices *after* they've been formatted for the bulk UI.
*
* This filter is useful if you would like to format the choices to provide additional parameters for choice-based settings.
*
* @since 2.3
*
* @param array bulkChoices The formatted choices.
* @param array choices The choice objects from the current field.
*/
choices = gform.applyFilters( 'gform_choices_post_bulk_load', choices, field.choices );
jQuery("#gfield_bulk_add_input").val(choices.join("\n"));
}
function DisplayCustomMessage(message){
jQuery("#bulk_custom_message").html(message).slideDown();
//slide up after 2 seconds
setTimeout(
function(){
jQuery("#bulk_custom_message").slideUp();
}, 2000
);
}
function LoadCustomChoices(){
jQuery(".choice_section_header, .bulk_custom_choice").remove();
if(!IsEmpty(gform_custom_choices)){
var str = "<li class='choice_section_header'>" + gf_vars.customChoices + "</li>";
for(key in gform_custom_choices){
if(!gform_custom_choices.hasOwnProperty(key))
continue;
var selectChoiceAction = 'SelectCustomChoice( jQuery(this).data("key") );';
str += "<li class='bulk_custom_choice'><a href='javascript:void(0);' data-key='" + escapeAttr( key ) + "' onclick='" + selectChoiceAction + "' onkeypress='" + selectChoiceAction + "' class='bulk-choice bulk_custom_choice'>" + escapeHtml( key ) + "</a></li>";
}
str += "<li class='choice_section_header'>" + gf_vars.predefinedChoices + "</li>";
jQuery("#bulk_items").prepend(str);
}
}
function SelectCustomChoice( name ){
jQuery("#gfield_bulk_add_input").val(gform_custom_choices[name].join("\n"));
gform_selected_custom_choice = name;
InitBulkCustomPanel();
}
function SelectPredefinedChoice(name){
jQuery('#gfield_bulk_add_input').val(gform_predefined_choices[name].join('\n'));
gform_selected_custom_choice = "";
InitBulkCustomPanel();
}
function InsertBulkChoices(choices){
field = GetSelectedField();
field.choices = new Array();
var enableValue = false;
for(var i=0; i<choices.length; i++){
text_price = choices[i].split("|:");
text_value = text_price[0];
price = "";
if(text_price.length > 1){
var currency = GetCurrentCurrency();
price = currency.toMoney(text_price[1]);
}
text_value = text_value.split("|");
field.choices.push(new Choice(jQuery.trim(text_value[0]), jQuery.trim(text_value[text_value.length -1]), jQuery.trim(price)));
if(text_value.length > 1)
enableValue = true;
}
/**
* Fires after bulk choices have been added to the field object and before the UI has been re-rendered.
*
* This action is useful if you need to alter other field settings based on the choices.
*
* @since 2.3
*
* @param array field The currently selected field object.
*/
gform.doAction( 'gform_bulk_insert_choices', field );
if(enableValue){
field["enableChoiceValue"] = true;
jQuery('#field_choice_values_enabled').prop("checked", true);
ToggleChoiceValue();
}
LoadFieldChoices(field);
UpdateFieldChoices( GetInputType( field ) );
}
function InitBulkCustomPanel(){
if(gform_selected_custom_choice.length == 0){
CloseCustomChoicesPanel();
}
else{
LoadCustomChoicesPanel();
}
}
function LoadCustomChoicesPanel(isNew, speed){
if(isNew){
jQuery("#custom_choice_name").val("");
jQuery("#bulk_save_button").html(gf_vars.save);
jQuery("#bulk_cancel_link").show();
jQuery("#bulk_delete_link").hide();
}
else{
jQuery("#custom_choice_name").val(gform_selected_custom_choice);
jQuery("#bulk_save_button").html(gf_vars.update);
jQuery("#bulk_cancel_link").hide();
jQuery("#bulk_delete_link").show();
}
if(!speed)
speed = '';
jQuery("#bulk_save_as").hide(speed);
jQuery("#bulk_custom_edit").show(speed);
}
function CloseCustomChoicesPanel(speed){
if(!speed)
speed = '';
jQuery("#bulk_save_as").show(speed);
jQuery("#bulk_custom_edit").hide(speed);
}
function IsEmpty(array){
var key;
for (key in array) {
if (array.hasOwnProperty(key))
return false;
}
return true;
}
function SetFieldChoice(inputType, index){
var text = jQuery("#" + inputType + "_choice_text_" + index).val();
var value = jQuery("#" + inputType + "_choice_value_" + index).val();
var price = jQuery("#" + inputType + "_choice_price_" + index).val();
field = GetSelectedField();
field.choices[index].text = text;
field.choices[index].value = field.enableChoiceValue ? value : text;
if(field.enablePrice){
var currency = GetCurrentCurrency();
var price = currency.toMoney(price);
if(!price)
price = "";
field.choices[index]["price"] = price;
//jQuery("#" + inputType + "_choice_price_" + index).val(price);
}
//set field selections
jQuery("#field_choices :radio, #field_choices :checkbox").each(function(index){
field.choices[index].isSelected = this.checked;
});
LoadBulkChoices(field);
UpdateFieldChoices(GetInputType(field));
}
function SetInputChoice(inputId, index, value, text){
var field = GetSelectedField();
var input = GetInput(field, inputId);
inputId = inputId.toString().replace('.', '_');
input.choices[index].text = text;
input.choices[index].value = input.enableChoiceValue ? value : text;
//set field selections
jQuery(".field-input-choice-" + inputId + ":radio, .field-input-choice-" + inputId + ":checkbox").each(function(index){
input.choices[index].isSelected = this.checked;
});
UpdateInputChoices(input);
}
function UpdateFieldChoices(fieldType){
var choices = '';
var selector = '';
if(fieldType == "checkbox")
field.inputs = new Array();
var skip = 0;
switch(GetInputType(field)){
case "select" :
for(var i=0; i<field.choices.length; i++)
{
selected = field.choices[i].isSelected ? "selected='selected'" : "";
var choiceValue = field.choices[i].value ? field.choices[i].value : field.choices[i].text;
choices += "<option value='" + choiceValue.replace(/'/g, "&#039;") + "' " + selected + ">" + field.choices[i].text + "</option>";
}
break;
case "checkbox" :
for(var i=0; i<field.choices.length; i++)
{
//Skipping ids that are multiple of ten to avoid conflicts with other fields (i.e. 5.1 and 5.10)
if((i + 1 + skip) % 10 == 0){
skip++;
}
var field_number = field.id + '.' + (i + 1 + skip);
field.inputs.push(new Input(field_number, field.choices[i].text));
var id = 'choice_' + field.id + '_' + i;
checked = field.choices[i].isSelected ? "checked" : "";
if(i < 5)
choices += "<li><input type='" + fieldType + "' " + checked + " id='" + id +"' disabled='disabled'><label for='" + id + "'>" + field.choices[i].text + "</label></li>";
}
if(field.choices.length > 5)
choices += "<li class='gchoice_total'>" + gf_vars["editToViewAll"].replace("%d", field.choices.length) + "</li>";
break;
case "radio" :
for(var i=0; i<field.choices.length; i++)
{
var id = 'choice_' + field.id + '_' + i;
checked = field.choices[i].isSelected ? "checked" : "";
if(i < 5)
choices += "<li><input type='" + fieldType + "' " + checked + " id='" + id +"' disabled='disabled'><label for='" + id + "'>" + field.choices[i].text + "</label></li>";
}
choices += field.enableOtherChoice ? "<li><input type='" + fieldType + "' " + checked + " id='" + id +"' disabled='disabled'><input type='text' value='" + gf_vars.otherChoiceValue + "' disabled='disabled' /></li>" : "";
if(field.choices.length > 5)
choices += "<li class='gchoice_total'>" + gf_vars["editToViewAll"].replace("%d", field.choices.length) + "</li>";
break;
case "list" :
var has_columns = field["choices"] != null;
columns = has_columns ? field["choices"] : [[]];
var class_attr = "";
if(has_columns){
choices += "<thead><tr>";
for(var i=0; i<columns.length; i++){
choices += "<th>" + columns[i]["text"] + "</th>";
}
choices += "<th>&nbsp;</th></tr></thead>";
}
else{
class_attr = "class='gf_list_one_column'";
}
choices += "<tbody>";
choices += "<tr>";
for(var j=0; j<columns.length; j++){
choices += "<td " + class_attr +"><input type='text' disabled='disabled' /></td>";
}
choices +="<td><img src='" + gf_vars["baseUrl"] + "/images/add.png' class='add_list_item' style='cursor:pointer; margin:0 3px;' /></td>";
choices +="</tr></tbody>";
break;
}
selector = '.gfield_' + fieldType;
jQuery(".field_selected " + selector).html(choices);
}
function UpdateInputChoices(input){
var choices = '';
for(var i=0; i<input.choices.length; i++) {
var selected = input.choices[i].isSelected ? "selected='selected'" : "";
var choiceValue = input.choices[i].value ? input.choices[i].value : input.choices[i].text;
choices += "<option value='" + choiceValue.replace(/'/g, "&#039;") + "' " + selected + ">" + input.choices[i].text + "</option>";
}
var inputId = input.id.toString().replace('.', '_');
jQuery(".field_selected #input_" + inputId).html(choices);
}
function InsertFieldChoice(index){
field = GetSelectedField();
var price = field["enablePrice"] ? "0.00" : "";
var new_choice = new Choice("", "", price);
if(window["gform_new_choice_" + field.type])
new_choice = window["gform_new_choice_" + field.type](field, new_choice);
field.choices.splice(index, 0, new_choice);
LoadFieldChoices(field);
UpdateFieldChoices(GetInputType(field));
}
function InsertInputChoice($ul, inputId, index){
var field = GetSelectedField();
var input = GetInput(field, inputId);
var new_choice = new Choice("", "");
input.choices.splice(index, 0, new_choice);
LoadInputChoices($ul, input);
UpdateInputChoices(input);
}
function DeleteFieldChoice(index){
field = GetSelectedField();
var value = jQuery('#' + GetInputType(field) + '_choice_value_' + index).val();
if( HasConditionalLogicDependency(field.id, value) ) {
if(!confirm(gf_vars.conditionalLogicDependencyChoice))
return;
}
field.choices.splice(index, 1);
LoadFieldChoices(field);
UpdateFieldChoices(GetInputType(field));
}
function DeleteInputChoice($ul, inputId, index){
var field = GetSelectedField();
var input = GetInput(field, inputId);
input.choices.splice(index, 1);
LoadInputChoices($ul, input);
UpdateInputChoices(input);
}
function MoveFieldChoice(fromIndex, toIndex){
field = GetSelectedField();
var choice = field.choices[fromIndex];
//deleting from old position
field.choices.splice(fromIndex, 1);
//inserting into new position
field.choices.splice(toIndex, 0, choice);
LoadFieldChoices(field);
UpdateFieldChoices(GetInputType(field));
}
function MoveInputChoice($ul, inputId, fromIndex, toIndex){
var field = GetSelectedField();
var input = GetInput(field, inputId);
var choice = input.choices[fromIndex];
//deleting from old position
input.choices.splice(fromIndex, 1);
//inserting into new position
input.choices.splice(toIndex, 0, choice);
LoadInputChoices($ul, input);
UpdateInputChoices(input);
}
function GetFieldType(fieldId){
return fieldId.substr(0, fieldId.lastIndexOf("_"));
}
function GetSelectedField() {
var $field = jQuery( '.field_selected' );
if( $field.length <= 0 ) {
return false;
}
var id = $field[0].id.substr( 6 );
return GetFieldById( id );
}
function SetPasswordProperty(isChecked){
SetFieldProperty("enablePasswordInput", isChecked);
}
function ToggleDateCalendar(isInit){
var speed = isInit ? "" : "slow";
var dateType = jQuery("#field_date_input_type").val();
if(dateType == "datefield" || dateType == "datedropdown"){
jQuery("#date_picker_container").hide(speed);
SetCalendarIconType("none");
}
else{
jQuery("#date_picker_container").show(speed);
}
}
function ToggleCalendarIconUrl(isInit){
var speed = isInit ? "" : "slow";
if(jQuery("#gsetting_icon_custom").is(":checked")){
jQuery("#gfield_icon_url_container").show(speed);
}
else{
jQuery("#gfield_icon_url_container").hide(speed);
jQuery("#gfield_calendar_icon_url").val("");
SetFieldProperty('calendarIconUrl', '');
}
}
function SetTimeFormat(format){
SetFieldProperty('timeFormat', format);
LoadTimeInputs();
}
function LoadTimeInputs(){
var field = GetSelectedField();
if(field.type != 'time' && field.inputType != 'time'){
return;
}
var format = jQuery("#field_time_format").val();
if(format == "24"){
jQuery('#input_default_value_row_input_' + field.id +'_3').hide();
jQuery(".field_selected .gfield_time_ampm").hide();
} else {
jQuery('#input_default_value_row_input_' + field.id +'_3').show();
jQuery(".field_selected .gfield_time_ampm").show();
}
jQuery('#input_placeholder_row_input_' + field.id +'_3').hide(); // no support for placeholder
jQuery('.field_custom_input_row_' + field.id +'_3').hide();
}
function SetDateFormat(format){
SetFieldProperty('dateFormat', format);
LoadDateInputs();
}
function LoadDateInputs(){
var type = jQuery("#field_date_input_type").val();
var format = jQuery("#field_date_format").val();
//setting up field positions
var position = format ? format.substr(0,3) : "mdy";
if(type == "datefield"){
switch(position){
case "ymd" :
jQuery(".field_selected #gfield_input_date_month").remove().insertBefore(".field_selected #gfield_input_date_day");
jQuery(".field_selected #gfield_input_date_year").remove().insertBefore(".field_selected #gfield_input_date_month");
break;
case "mdy" :
jQuery(".field_selected #gfield_input_date_day").remove().insertBefore(".field_selected #gfield_input_date_year");
jQuery(".field_selected #gfield_input_date_month").remove().insertBefore(".field_selected #gfield_input_date_day");
break;
case "dmy" :
jQuery(".field_selected #gfield_input_date_month").remove().insertBefore(".field_selected #gfield_input_date_year");
jQuery(".field_selected #gfield_input_date_day").remove().insertBefore(".field_selected #gfield_input_date_month");
break;
}
jQuery(".field_selected .ginput_date").show();
jQuery(".field_selected .ginput_date_dropdown").hide();
jQuery(".field_selected #gfield_input_datepicker").hide();
jQuery(".field_selected #gfield_input_datepicker_icon").hide();
}
else if(type == "datedropdown"){
switch(position){
case "ymd" :
jQuery(".field_selected #gfield_dropdown_date_month").remove().insertBefore(".field_selected #gfield_dropdown_date_day");
jQuery(".field_selected #gfield_dropdown_date_year").remove().insertBefore(".field_selected #gfield_dropdown_date_month");
break;
case "mdy" :
jQuery(".field_selected #gfield_dropdown_date_day").remove().insertBefore(".field_selected #gfield_dropdown_date_year");
jQuery(".field_selected #gfield_dropdown_date_month").remove().insertBefore(".field_selected #gfield_dropdown_date_day");
break;
case "dmy" :
jQuery(".field_selected #gfield_dropdown_date_month").remove().insertBefore(".field_selected #gfield_dropdown_date_year");
jQuery(".field_selected #gfield_dropdown_date_day").remove().insertBefore(".field_selected #gfield_dropdown_date_month");
break;
}
jQuery(".field_selected .ginput_date_dropdown").css("display", "inline");
jQuery(".field_selected .ginput_date").hide();
jQuery(".field_selected #gfield_input_datepicker").hide();
jQuery(".field_selected #gfield_input_datepicker_icon").hide();
}
else{
jQuery(".field_selected .ginput_date").hide();
jQuery(".field_selected .ginput_date_dropdown").hide();
jQuery(".field_selected #gfield_input_datepicker").show();
//Displaying or hiding the calendar icon
if(jQuery("#gsetting_icon_calendar").is(":checked"))
jQuery(".field_selected #gfield_input_datepicker_icon").show();
else
jQuery(".field_selected #gfield_input_datepicker_icon").hide();
}
}
function SetCalendarIconType(iconType, isInit){
field = GetSelectedField();
if(GetInputType(field) != "date")
return;
if(iconType == undefined)
iconType = "none";
if(iconType == "none")
jQuery("#gsetting_icon_none").prop("checked", true);
else if(iconType == "calendar")
jQuery("#gsetting_icon_calendar").prop("checked", true);
else if(iconType == "custom")
jQuery("#gsetting_icon_custom").prop("checked", true);
SetFieldProperty('calendarIconType', iconType);
ToggleCalendarIconUrl(isInit);
LoadDateInputs();
}
function SetDateInputType(type){
field = GetSelectedField();
if(GetInputType(field) != "date")
return;
field.dateType = type;
field.inputs = GetDateFieldInputs(field);
CreateDefaultValuesUI(field);
CreatePlaceholdersUI(field);
CreateInputLabelsUI(field);
ToggleDateSettings(field);
ResetDefaultInputValues(field);
ResetInputPlaceholders(field);
ToggleDateCalendar();
LoadDateInputs();
}
function SetPostImageMeta(){
var displayTitle = jQuery('.field_selected #gfield_display_title').is(":checked");
var displayCaption = jQuery('.field_selected #gfield_display_caption').is(":checked");
var displayDescription = jQuery('.field_selected #gfield_display_description').is(":checked");
var displayLabel = (displayTitle || displayCaption || displayDescription);
//setting property
SetFieldProperty('displayTitle', displayTitle);
SetFieldProperty('displayCaption', displayCaption);
SetFieldProperty('displayDescription', displayDescription);
//updating UI
jQuery('.field_selected .ginput_post_image_title').css("display", displayTitle ? "block" : "none");
jQuery('.field_selected .ginput_post_image_caption').css("display", displayCaption ? "block" : "none");
jQuery('.field_selected .ginput_post_image_description').css("display", displayDescription ? "block" : "none");
jQuery('.field_selected .ginput_post_image_file').css("display", displayLabel ? "block" : "none");
}
function SetFeaturedImage() {
var isChecked = jQuery('#gfield_featured_image').is(':checked');
if(isChecked) {
for(i in form.fields) {
if(!form.fields.hasOwnProperty(i))
continue;
form.fields[i].postFeaturedImage = false;
}
SetFieldProperty('postFeaturedImage', true);
}
else{
SetFieldProperty('postFeaturedImage', false);
}
}
function SetFieldProperty(name, value){
if(value == undefined)
value = "";
GetSelectedField()[name] = value;
}
function SetInputName(value, inputId){
var field = GetSelectedField();
if(value)
value = value.trim();
if(!inputId){
field["inputName"] = value;
}
else{
for(var i=0; i<field["inputs"].length; i++){
if(field["inputs"][i]["id"] == inputId){
field["inputs"][i]["name"] = value;
return;
}
}
}
}
function SetInputDefaultValue(value, inputId){
var field = GetSelectedField(), $select, elementId, ele;
if(value)
value = value.trim();
for(var i=0; i<field["inputs"].length; i++){
if(field["inputs"][i]["id"] == inputId){
field["inputs"][i]["defaultValue"] = value;
jQuery('[name="input_' + inputId + '"], #input_' + inputId.toString().replace('.', '_')).each(function(){
var type = this.nodeName;
if( type == 'INPUT'){
jQuery(this).val(value);
} else {
$select = jQuery(this);
value = value.toLowerCase();
$select
.val('')
.children()
.each(function () {
if(this.value.toLowerCase() == value){
$select.val(this.value);
return false;
}
});
}
});
return;
}
}
}
function SetInputPlaceholder(value, inputId){
var field = GetSelectedField(), ele, elementId;
if(value)
value = value.trim();
for(var i=0; i<field["inputs"].length; i++){
if(field["inputs"][i]["id"] == inputId){
field["inputs"][i]["placeholder"] = value;
jQuery('[name="input_' + inputId + '"], #input_' + inputId.toString().replace('.', '_')).each(function(){
var type = this.nodeName;
if( type == 'INPUT'){
jQuery(this).prop("placeholder", value);
} else if (type == 'SELECT'){
jQuery(this).find('option[value=""]').text(value);
}
});
return;
}
}
}
function ResetInputPlaceholders(field){
if(!field){
field = GetSelectedField()
}
if(!field.inputs){
return
}
jQuery(field.inputs).each(function(){
var placeholder = typeof this.placeholder != 'undefined' ? this.placeholder : '';
SetInputPlaceholder(placeholder, this.id);
})
}
function ResetDefaultInputValues(field){
if(!field){
field = GetSelectedField()
}
if(!field.inputs){
return
}
jQuery(field.inputs).each(function(){
var defaultValue = typeof this.defaultValue != 'undefined' ? this.defaultValue : '';
SetInputDefaultValue(defaultValue, this.id);
})
}
function SetInputCustomLabel(value, inputId){
var field = GetSelectedField(), elementID, label, input;
if(value)
value = value.trim();
for(var i=0; i<field["inputs"].length; i++){
input = field["inputs"][i];
if(input.id == inputId){
if(value == ''){
delete input.customLabel;
label = typeof input.defaultLabel != 'undefined' ? input.defaultLabel : input.label;
} else {
input.customLabel = value;
label = value;
}
elementID = 'input_' + field.inputs[i].id;
elementID = elementID.replace('.', '_');
elementID = '.ginput_container label[for=' + elementID + "]";
jQuery(elementID).text(label);
return;
}
}
}
function SetInputHidden(isHidden, inputId){
var field = GetSelectedField();
for(var i=0; i<field["inputs"].length; i++){
if(field["inputs"][i]["id"] == inputId){
field["inputs"][i]["isHidden"] = isHidden;
inputId = inputId.toString().replace('.','_');
jQuery("#input_" + inputId + "_container").toggle(!isHidden);
return;
}
}
}
function SetSelectedCategories(){
var field = GetSelectedField();
field["choices"] = new Array();
jQuery(".gfield_category_checkbox").each(function(){
if(this.checked)
field["choices"].push(new Choice(this.name, this.value));
});
field["choices"].sort(function(a, b){return ( a["text"].toLowerCase() > b["text"].toLowerCase() );});
}
function SetFieldLabel(label){
var requiredElement = jQuery(".field_selected .gfield_required")[0];
jQuery(".field_selected .gfield_label, .field_selected .gsection_title").text(label).append(requiredElement);
SetFieldProperty("label", label);
}
function SetCaptchaTheme(theme, thumbnailUrl){
jQuery(".field_selected .gfield_captcha").attr("src", thumbnailUrl);
SetFieldProperty("captchaTheme", theme);
}
function SetCaptchaSize(size){
var type = jQuery("#field_captcha_type").val();
SetFieldProperty("simpleCaptchaSize", size);
RedrawCaptcha();
jQuery(".field_selected .gfield_captcha_input_container").removeClass(type + "_small").removeClass(type + "_medium").removeClass(type + "_large").addClass(type + "_" + size);
}
function SetCaptchaFontColor(color){
SetFieldProperty("simpleCaptchaFontColor", color);
RedrawCaptcha();
}
function SetCaptchaBackgroundColor(color){
SetFieldProperty("simpleCaptchaBackgroundColor", color);
RedrawCaptcha();
}
function RedrawCaptcha(){
var captchaType = jQuery("#field_captcha_type").val();
if(captchaType == "math"){
url_1 = GetCaptchaUrl(1);
url_2 = GetCaptchaUrl(2);
url_3 = GetCaptchaUrl(3);
jQuery(".field_selected .gfield_captcha:eq(0)").attr("src", url_1);
jQuery(".field_selected .gfield_captcha:eq(1)").attr("src", url_2);
jQuery(".field_selected .gfield_captcha:eq(2)").attr("src", url_3);
}
else{
url = GetCaptchaUrl();
jQuery(".field_selected .gfield_captcha").attr("src", url);
}
}
function SetFieldSize(size){
jQuery(".field_selected .small, .field_selected .medium, .field_selected .large").removeClass("small").removeClass("medium").removeClass("large").addClass(size);
SetFieldProperty("size", size);
}
function SetFieldLabelPlacement(labelPlacement){
var labelPlacementClass = labelPlacement ? labelPlacement : form.labelPlacement;
SetFieldProperty("labelPlacement", labelPlacement);
jQuery(".field_selected").removeClass("top_label").removeClass("right_label").removeClass("left_label").removeClass("hidden_label").addClass(labelPlacementClass);
if((field.labelPlacement == 'left_label' || field.labelPlacement == 'right_label' || (field.labelPlacement == '' && form.labelPlacement != 'top_label'))){
jQuery('#field_description_placement').val('');
SetFieldProperty("descriptionPlacement", '');
jQuery('#field_description_placement_container').hide('slow');
} else {
jQuery('#field_description_placement_container').show('slow');
}
SetFieldProperty("labelPlacement", labelPlacement);
RefreshSelectedFieldPreview();
}
function SetFieldDescriptionPlacement(descriptionPlacement){
var isDescriptionAbove = descriptionPlacement == 'above' || (descriptionPlacement == '' && form.descriptionPlacement == 'above)');
SetFieldProperty("descriptionPlacement", descriptionPlacement);
RefreshSelectedFieldPreview(function(){
if(isDescriptionAbove){
jQuery(".field_selected").addClass("description_above");
} else {
jQuery(".field_selected").removeClass("description_above");
}
});
}
function SetFieldSubLabelPlacement(subLabelPlacement){
SetFieldProperty("subLabelPlacement", subLabelPlacement);
RefreshSelectedFieldPreview();
}
function SetFieldVisibility( visibility, handleInputs, isInit ) {
if (!isInit && visibility == 'administrative' && HasConditionalLogicDependency(field.id)) {
if( ! confirm( gf_vars.conditionalLogicDependencyAdminOnly ) ) {
return false;
}
}
var isWhitelisted = false;
for( var i = 0; i < gf_vars.visibilityOptions.length; i++ ) {
if( gf_vars.visibilityOptions[i].value == visibility ) {
isWhitelisted = true;
break;
}
}
if( ! isWhitelisted ) {
visibility = 'visible';
}
SetFieldProperty( 'visibility', visibility );
if( handleInputs ) {
var $inputs = jQuery( 'input[name="field_visibility"]' );
$inputs.prop( 'checked', false );
$inputs.filter( '[value="' + visibility + '"]' ).prop( 'checked', true );
}
}
function SetFieldDefaultValue(defaultValue){
jQuery(".field_selected > div > input:visible, .field_selected > div > textarea:visible, .field_selected > div > select:visible").val(defaultValue);
SetFieldProperty('defaultValue', defaultValue);
}
function SetFieldPlaceholder(placeholder){
jQuery(".field_selected > div > input:visible, .field_selected > div > textarea:visible, .field_selected > div > select:visible").each(function(){
var type = this.nodeName;
var $this = jQuery(this);
if(type == 'INPUT' || type == 'TEXTAREA'){
jQuery(this).prop("placeholder", placeholder);
} else if (type == 'SELECT'){
var $option = $this.find('option[value=""]');
if($option.length>0){
if(placeholder.length > 0){
$option.text(placeholder);
} else {
$option.remove();
}
} else {
$this.prepend('<option value="">' + placeholder + '</option>');
$this.val('');
}
}
});
SetFieldProperty('placeholder', placeholder);
}
function SetFieldDescription(description){
if(description == undefined)
description = "";
SetFieldProperty('description', description);
}
function SetFieldCheckboxLabel(text){
if(text == undefined)
text = "";
SetFieldProperty('checkboxLabel', text);
}
function SetPasswordStrength(isEnabled){
if(isEnabled){
jQuery(".field_selected .gfield_password_strength").show();
}
else{
jQuery(".field_selected .gfield_password_strength").hide();
//resetting min strength
jQuery("#gfield_min_strength").val("");
SetFieldProperty('minPasswordStrength', "");
}
SetFieldProperty('passwordStrengthEnabled', isEnabled);
}
function ToggleEmailSettings(field){
var isConfirmEnabled = typeof field.emailConfirmEnabled != 'undefined' && field.emailConfirmEnabled == true;
jQuery('.placeholder_setting').toggle(!isConfirmEnabled);
jQuery('.default_value_setting').toggle(!isConfirmEnabled);
jQuery('.sub_label_placement_setting').toggle(isConfirmEnabled);
jQuery('.sub_labels_setting').toggle(isConfirmEnabled);
jQuery('.default_input_values_setting').toggle(isConfirmEnabled);
jQuery('.input_placeholders_setting').toggle(isConfirmEnabled);
}
function SetEmailConfirmation(isEnabled){
var field = GetSelectedField();
if(isEnabled){
jQuery(".field_selected .ginput_single_email").hide();
jQuery(".field_selected .ginput_confirm_email").show();
}
else{
jQuery(".field_selected .ginput_confirm_email").hide();
jQuery(".field_selected .ginput_single_email").show();
}
field['emailConfirmEnabled'] = isEnabled;
field.inputs = GetEmailFieldInputs(field);
CreateDefaultValuesUI(field);
CreatePlaceholdersUI(field);
CreateCustomizeInputsUI(field);
CreateInputLabelsUI(field);
ToggleEmailSettings(field);
}
function SetCardType(elem, value) {
var cards = GetSelectedField()['creditCards'] ? GetSelectedField()['creditCards'] : new Array();
if(jQuery(elem).is(':checked')) {
if(jQuery.inArray(value, cards) == -1) {
jQuery('.gform_card_icon_' + value).fadeIn();
cards[cards.length] = value;
}
} else {
var index = jQuery.inArray(value, cards);
if(index != -1) {
jQuery('.gform_card_icon_' + value).fadeOut();
cards.splice(index, 1);
}
}
SetFieldProperty('creditCards', cards);
}
function SetFieldRequired(isRequired){
var required = isRequired ? "*" : "";
jQuery(".field_selected .gfield_required").html(required);
SetFieldProperty('isRequired', isRequired);
}
function SetMaxLength(input) {
var patt = GetMaxLengthPattern();
var cleanValue = '';
var characters = input.value.split('');
for(i in characters) {
if(!characters.hasOwnProperty(i))
continue;
if( !patt.test(characters[i]) )
cleanValue += characters[i];
}
input.value = cleanValue;
SetFieldProperty('maxLength', cleanValue);
}
function GetMaxLengthPattern() {
return /[a-zA-Z\-!@#$%^&*();'":_+=<,>.~`?\/|\[\]\{\}\\]/;
}
/**
* Validate any keypress events based on a provided RegExp.
*
* Function retrieves the character code from the keypress event and tests it against provided pattern.
* Optionally specify 'matchPositive' argument to false in order to return true if the character is NOT
* in the provided pattern.
*
* @param event The JS keypress event.
* @param patt RegExp to test keypress character against.
* @param matchPositive Defaults to true. Whether to return true if the character is found or NOT found in the pattern.
*/
function ValidateKeyPress(event, patt, matchPositive) {
var matchPositive = typeof matchPositive == 'undefined' ? true : matchPositive;
var char = event['which'] ? event.which : event.keyCode;
var isMatch = patt.test(String.fromCharCode(char));
if(event.ctrlKey)
return true;
return matchPositive ? isMatch : !isMatch;
}
function IndexOf(ary, item){
for(var i=0; i<ary.length; i++)
if(ary[i] == item)
return i;
return -1;
}
function ToggleCalculationOptions(isEnabled, field) {
if(isEnabled) {
jQuery('#calculation_options').gfSlide('down');
if(field.type != 'product')
jQuery('li.range_setting').gfSlide('up');
} else {
jQuery('#calculation_options').gfSlide('up');
if(field.type != 'product')
jQuery('li.range_setting').gfSlide('down');
SetFieldProperty('calculationFormula', '');
SetFieldProperty('calculationRounding', '');
}
SetFieldProperty('enableCalculation', isEnabled);
}
function FormulaContentCallback() {
SetFieldProperty('calculationFormula', jQuery('#field_calculation_formula').val().trim());
}
function SetupUnsavedChangesWarning() {
// apply system changes to the form, unsaved notification should only apply for user-made changes
UpdateFormObject();
// store a json copy of original form to determine if user-made changes were made
gforms_original_json = jQuery.toJSON(form);
window.onbeforeunload = function(){
UpdateFormObject();
if ( gforms_original_json != jQuery.toJSON(form) && !gf_vars.isFormTrash ) {
return "You have unsaved changes.";
}
}
}
function ToggleRichTextEditor( isEnabled ) {
var field = GetSelectedField(),
$input = jQuery( '#input_' + field.id ),
$preview = jQuery( '#input_' + field.id + '_rte_preview' );
if( isEnabled ) {
$input.hide();
$preview.show();
} else {
$preview.hide();
$input.show();
}
SetFieldProperty( 'useRichTextEditor', isEnabled );
}
//------------------------------------------------------------------------------------------------------------------------
//Color Picker
function iColorShow(mouseX, mouseY, id, callback){
jQuery("#iColorPicker").css({'top': (mouseY - 150) +"px",'left':mouseX +"px",'position':'absolute'}).fadeIn("fast");
jQuery("#iColorPickerBg").css({'position':'absolute','top':0,'left':0,'width':'100%','height':'100%'}).fadeIn("fast");
var def=jQuery("#"+id).val();
jQuery('#colorPreview span').text(def);
jQuery('#colorPreview').css('background',def);
jQuery('#color').val(def);
var hxs=jQuery('#iColorPicker');
for(i=0;i<hxs.length;i++){
var tbl=document.getElementById('hexSection'+i);
var tblChilds=tbl.childNodes;
for(j=0;j<tblChilds.length;j++){
var tblCells=tblChilds[j].childNodes;
for(k=0;k<tblCells.length;k++){
jQuery(tblChilds[j].childNodes[k]).unbind().mouseover(
function(a){var aaa="#"+jQuery(this).attr('hx');jQuery('#colorPreview').css('background',aaa);jQuery('#colorPreview span').text(aaa)}
).click(function(){
var aaa="#"+jQuery(this).attr('hx');
jQuery("#"+id).val(aaa);
jQuery("#chip_"+id).css("background-color",aaa);
jQuery("#iColorPickerBg").hide();
jQuery("#iColorPicker").fadeOut();
if(callback)
window[callback](aaa);
jQuery(this)})
}
}
}
}
this.iColorPicker=function(){
jQuery("input.iColorPicker").each(function(i){if(i==0){jQuery(document.createElement("div")).attr("id","iColorPicker").css('display','none').html('<table class="pickerTable" id="pickerTable0"><thead id="hexSection0"><tr><td style="background:#f00;" hx="f00"></td><td style="background:#ff0" hx="ff0"></td><td style="background:#0f0" hx="0f0"></td><td style="background:#0ff" hx="0ff"></td><td style="background:#00f" hx="00f"></td><td style="background:#f0f" hx="f0f"></td><td style="background:#fff" hx="fff"></td><td style="background:#ebebeb" hx="ebebeb"></td><td style="background:#e1e1e1" hx="e1e1e1"></td><td style="background:#d7d7d7" hx="d7d7d7"></td><td style="background:#cccccc" hx="cccccc"></td><td style="background:#c2c2c2" hx="c2c2c2"></td><td style="background:#b7b7b7" hx="b7b7b7"></td><td style="background:#acacac" hx="acacac"></td><td style="background:#a0a0a0" hx="a0a0a0"></td><td style="background:#959595" hx="959595"></td></tr><tr><td style="background:#ee1d24" hx="ee1d24"></td><td style="background:#fff100" hx="fff100"></td><td style="background:#00a650" hx="00a650"></td><td style="background:#00aeef" hx="00aeef"></td><td style="background:#2f3192" hx="2f3192"></td><td style="background:#ed008c" hx="ed008c"></td><td style="background:#898989" hx="898989"></td><td style="background:#7d7d7d" hx="7d7d7d"></td><td style="background:#707070" hx="707070"></td><td style="background:#626262" hx="626262"></td><td style="background:#555" hx="555"></td><td style="background:#464646" hx="464646"></td><td style="background:#363636" hx="363636"></td><td style="background:#262626" hx="262626"></td><td style="background:#111" hx="111"></td><td style="background:#000" hx="000"></td></tr><tr><td style="background:#f7977a" hx="f7977a"></td><td style="background:#fbad82" hx="fbad82"></td><td style="background:#fdc68c" hx="fdc68c"></td><td style="background:#fff799" hx="fff799"></td><td style="background:#c6df9c" hx="c6df9c"></td><td style="background:#a4d49d" hx="a4d49d"></td><td style="background:#81ca9d" hx="81ca9d"></td><td style="background:#7bcdc9" hx="7bcdc9"></td><td style="background:#6ccff7" hx="6ccff7"></td><td style="background:#7ca6d8" hx="7ca6d8"></td><td style="background:#8293ca" hx="8293ca"></td><td style="background:#8881be" hx="8881be"></td><td style="background:#a286bd" hx="a286bd"></td><td style="background:#bc8cbf" hx="bc8cbf"></td><td style="background:#f49bc1" hx="f49bc1"></td><td style="background:#f5999d" hx="f5999d"></td></tr><tr><td style="background:#f16c4d" hx="f16c4d"></td><td style="background:#f68e54" hx="f68e54"></td><td style="background:#fbaf5a" hx="fbaf5a"></td><td style="background:#fff467" hx="fff467"></td><td style="background:#acd372" hx="acd372"></td><td style="background:#7dc473" hx="7dc473"></td><td style="background:#39b778" hx="39b778"></td><td style="background:#16bcb4" hx="16bcb4"></td><td style="background:#00bff3" hx="00bff3"></td><td style="background:#438ccb" hx="438ccb"></td><td style="background:#5573b7" hx="5573b7"></td><td style="background:#5e5ca7" hx="5e5ca7"></td><td style="background:#855fa8" hx="855fa8"></td><td style="background:#a763a9" hx="a763a9"></td><td style="background:#ef6ea8" hx="ef6ea8"></td><td style="background:#f16d7e" hx="f16d7e"></td></tr><tr><td style="background:#ee1d24" hx="ee1d24"></td><td style="background:#f16522" hx="f16522"></td><td style="background:#f7941d" hx="f7941d"></td><td style="background:#fff100" hx="fff100"></td><td style="background:#8fc63d" hx="8fc63d"></td><td style="background:#37b44a" hx="37b44a"></td><td style="background:#00a650" hx="00a650"></td><td style="background:#00a99e" hx="00a99e"></td><td style="background:#00aeef" hx="00aeef"></td><td style="background:#0072bc" hx="0072bc"></td><td style="background:#0054a5" hx="0054a5"></td><td style="background:#2f3192" hx="2f3192"></td><td style="background:#652c91" hx="652c91"></td><td style="background:#91278f" hx="91278f"></td><td style="background:#ed008c" hx="ed008c"></td><td style="background:#ee105a" hx="ee105a"></td></tr><tr><td style="background:#9d0a0f" hx="9d0a0f"></td><td style="background:#a1410d" hx="a1410d"></td><td style="background:#a36209" hx="a36209"></td><td style="background:#aba000" hx="aba000"></td><td style="background:#588528" hx="588528"></td><td style="background:#197b30" hx="197b30"></td><td style="background:#007236" hx="007236"></td><td style="background:#00736a" hx="00736a"></td><td style="background:#0076a4" hx="0076a4"></td><td style="background:#004a80" hx="004a80"></td><td style="background:#003370" hx="003370"></td><td style="background:#1d1363" hx="1d1363"></td><td style="background:#450e61" hx="450e61"></td><td style="background:#62055f" hx="62055f"></td><td style="background:#9e005c" hx="9e005c"></td><td style="background:#9d0039" hx="9d0039"></td></tr><tr><td style="background:#790000" hx="790000"></td><td style="background:#7b3000" hx="7b3000"></td><td style="background:#7c4900" hx="7c4900"></td><td style="background:#827a00" hx="827a00"></td><td style="background:#3e6617" hx="3e6617"></td><td style="background:#045f20" hx="045f20"></td><td style="background:#005824" hx="005824"></td><td style="background:#005951" hx="005951"></td><td style="background:#005b7e" hx="005b7e"></td><td style="background:#003562" hx="003562"></td><td style="background:#002056" hx="002056"></td><td style="background:#0c004b" hx="0c004b"></td><td style="background:#30004a" hx="30004a"></td><td style="background:#4b0048" hx="4b0048"></td><td style="background:#7a0045" hx="7a0045"></td><td style="background:#7a0026" hx="7a0026"></td></tr></thead><tbody><tr><td style="border:1px solid #000;background:#fff;cursor:pointer;height:60px;-moz-background-clip:-moz-initial;-moz-background-origin:-moz-initial;-moz-background-inline-policy:-moz-initial;" colspan="16" align="center" id="colorPreview"><span style="color:#000;border:1px solid rgb(0, 0, 0);padding:5px;background-color:#fff;font:11px Arial, Helvetica, sans-serif;"></span></td></tr></tbody></table><style>#iColorPicker input{margin:2px}</style>').appendTo("body");jQuery(document.createElement("div")).attr("id","iColorPickerBg").click(function(){jQuery("#iColorPickerBg").hide();jQuery("#iColorPicker").fadeOut()}).appendTo("body");jQuery('table.pickerTable td').css({'width':'12px','height':'14px','border':'1px solid #000','cursor':'pointer'});jQuery('#iColorPicker table.pickerTable').css({'border-collapse':'collapse'});jQuery('#iColorPicker').css({'border':'1px solid #ccc','background':'#333','padding':'5px','color':'#fff','z-index':9999})}
jQuery('#colorPreview').css({'height':'50px'});
})
};
jQuery(function(){iColorPicker()});
function SetColorPickerColor(field_name, color, callback){
var chip = jQuery('#chip_' + field_name);
chip.css("background-color", color);
if(callback)
window[callback](color);
}
function SetFieldChoices(){
var field = GetSelectedField();
for(var i=0; i<field.choices.length; i++){
SetFieldChoice(GetInputType(field), i);
}
}
function SetInputChoices($ul){
var field = GetSelectedField(), $this, value, text, inputId;
$ul.find('li').each(function(i){
$this = jQuery(this);
inputId = $this.data('input_id');
value = $this.find('.field-choice-value').val();
text = $this.find('.field-choice-text').val();
SetInputChoice(inputId, i, value, text);
});
}
function MergeInputArrays(inputs1, inputs2){
var inputA, inputB;
for(var i=0; i<inputs1.length; ++i) {
inputA = inputs1[i];
inputB = GetInput({inputs: inputs2},inputA.id);
if(inputB){
inputs1[i] = jQuery.extend(inputA, inputB);
}
}
return inputs1;
}
/**
* Quick jQuery plugin that allows a variable to be passed which determins whether to
* instantly hide the element or slideUp instead.
*/
jQuery.fn.gfSlide = function(direction) {
var isVisible = jQuery('#field_settings').is(':visible');
if(direction == 'up') {
if(!isVisible) {
this.hide();
} else {
this.slideUp();
}
} else {
if(!isVisible) {
this.show();
} else {
this.slideDown();
}
}
return this;
};
/**
* Form Editor conditional logic should not allow adminOnly fields to be selectable. Also exclude the current field from being
* set in conditional logic for itself.
*/
gform.addFilter( 'gform_is_conditional_logic_field', function( isConditionalLogicField, field ) {
if( field.visibility == 'administrative' ) {
isConditionalLogicField = false;
} else if( field.id == GetSelectedField().id ) {
isConditionalLogicField = false;
}
return isConditionalLogicField;
} );
/**
* Validates the calculation formula.
*
* @since 2.4.6.8 Moved from form_detail.php and added filter.
* @since 1.8
*
* @param formula The formula to be validated.
*
* @return boolean
*/
function IsValidFormula(formula) {
if (formula == '') {
return true;
}
var patt = /{([^}]+)}/i,
exprPatt = /^[0-9 -/*\(\)]+$/i,
expr = formula.replace(/(\r\n|\n|\r)/gm, ''),
match,
result = false;
while (match = patt.exec(expr)) {
expr = expr.replace(match[0], 1);
}
if (exprPatt.test(expr)) {
try {
var r = eval(expr);
result = !isNaN(parseFloat(r)) && isFinite(r);
} catch (e) {
result = false;
}
}
/**
* Allow the validation result to be overridden.
*
* @since 2.4.6.8
*
* @param result The validation result.
* @param formula The calculation formula being validated.
*/
return gform.applyFilters( 'gform_is_valid_formula_form_editor', result, formula );
}