website/wp-content/plugins/gravityforms/form_settings.php

2598 lines
91 KiB
PHP

<?php
if ( ! class_exists( 'GFForms' ) ) {
die();
}
/**
* Class GFFormSettings
*
* Handles the form settings page.
*
* @since Unknown
*/
class GFFormSettings {
/**
* Determines which form settings page to display.
*
* @access public
* @since Unknown
*
* @used-by GFForms::forms()
* @uses GFFormSettings::form_settings_ui()
* @uses GFFormSettings::confirmations_page()
* @uses GFFormSettings::notification_page()
*
* @return void
*/
public static function form_settings_page() {
$subview = rgget( 'subview' ) ? rgget( 'subview' ) : 'settings';
switch ( $subview ) {
case 'settings':
self::form_settings_ui();
break;
case 'confirmation':
self::confirmations_page();
break;
case 'notification':
self::notification_page();
break;
case 'personal-data':
self::personal_data_page();
break;
default:
/**
* Fires when the settings page view is determined
*
* Used to add additional pages to the form settings
*
* @since Unknown
*
* @param string $subview Used to complete the action name, allowing an additional subview to be detected
*/
do_action( "gform_form_settings_page_{$subview}" );
}
}
/**
* Displays the form settings UI.
*
* @since Unknown
* @access public
*
* @used-by GFFormSettings::form_settings_page()
* @uses GFCommon::get_base_path()
* @uses GFFormsModel::get_form_meta()
* @uses GFFormsModel::maybe_sanitize_form_settings()
* @uses GFFormSettings::activate_save()
* @uses GFFormSettings::deactivate_save()
* @uses GFFormDetail::save_form_info()
* @uses GFFormSettings::page_header()
* @uses GFCommon::gf_global()
* @uses GFFormSettings::output_field_scripts()
* @uses gform_tooltip()
* @uses GFFormSettings::page_footer()
*
* @return void
*/
public static function form_settings_ui() {
require_once( GFCommon::get_base_path() . '/form_detail.php' );
$form_id = rgget( 'id' );
$form = RGFormsModel::get_form_meta( $form_id );
$update_result = array();
if ( rgpost( 'gform_meta' ) ) {
// Die if not posted from correct page
check_admin_referer( "gform_save_form_settings_{$form_id}", 'gform_save_form_settings' );
$updated_form = json_decode( rgpost( 'gform_meta' ), true );
$updated_form['fields'] = $form['fields'];
// -- Standard form settings --
$updated_form['title'] = rgpost( 'form_title_input' );
$updated_form['description'] = rgpost( 'form_description_input' );
$updated_form['labelPlacement'] = rgpost( 'form_label_placement' );
$updated_form['descriptionPlacement'] = rgpost( 'form_description_placement' );
$updated_form['subLabelPlacement'] = rgpost( 'form_sub_label_placement' );
// -- Advanced form settings --
$updated_form['cssClass'] = rgpost( 'form_css_class' );
$updated_form['enableHoneypot'] = rgpost( 'form_enable_honeypot' );
$updated_form['enableAnimation'] = rgpost( 'form_enable_animation' );
// Form button settings
$updated_form['button']['type'] = rgpost( 'form_button' );
$updated_form['button']['text'] = rgpost( 'form_button' ) == 'text' ? rgpost( 'form_button_text_input' ) : '';
$updated_form['button']['imageUrl'] = rgpost( 'form_button' ) == 'image' ? rgpost( 'form_button_image_url' ) : '';
// Save and Continue settings
$updated_form['save']['enabled'] = rgpost( 'form_save_enabled' );
$updated_form['save']['button']['type'] = 'link';
$updated_form['save']['button']['text'] = rgpost( 'form_save_button_text' );
// limit entries settings
$updated_form['limitEntries'] = rgpost( 'form_limit_entries' );
$updated_form['limitEntriesCount'] = $updated_form['limitEntries'] ? rgpost( 'form_limit_entries_count' ) : '';
$updated_form['limitEntriesPeriod'] = $updated_form['limitEntries'] ? rgpost( 'form_limit_entries_period' ) : '';
$updated_form['limitEntriesMessage'] = $updated_form['limitEntries'] ? rgpost( 'form_limit_entries_message' ) : '';
// form scheduling settings
$updated_form['scheduleForm'] = rgpost( 'form_schedule_form' );
$updated_form['scheduleStart'] = $updated_form['scheduleForm'] ? rgpost( 'gform_schedule_start' ) : '';
$updated_form['scheduleStartHour'] = $updated_form['scheduleForm'] ? rgpost( 'form_schedule_start_hour' ) : '';
$updated_form['scheduleStartMinute'] = $updated_form['scheduleForm'] ? rgpost( 'form_schedule_start_minute' ) : '';
$updated_form['scheduleStartAmpm'] = $updated_form['scheduleForm'] ? rgpost( 'form_schedule_start_ampm' ) : '';
$updated_form['scheduleEnd'] = $updated_form['scheduleForm'] ? rgpost( 'form_schedule_end' ) : '';
$updated_form['scheduleEndHour'] = $updated_form['scheduleForm'] ? rgpost( 'form_schedule_end_hour' ) : '';
$updated_form['scheduleEndMinute'] = $updated_form['scheduleForm'] ? rgpost( 'form_schedule_end_minute' ) : '';
$updated_form['scheduleEndAmpm'] = $updated_form['scheduleForm'] ? rgpost( 'form_schedule_end_ampm' ) : '';
$updated_form['schedulePendingMessage'] = $updated_form['scheduleForm'] ? rgpost( 'form_schedule_pending_message' ) : '';
$updated_form['scheduleMessage'] = $updated_form['scheduleForm'] ? rgpost( 'form_schedule_message' ) : '';
// require login settings
$updated_form['requireLogin'] = rgpost( 'form_require_login' );
$updated_form['requireLoginMessage'] = $updated_form['requireLogin'] ? rgpost( 'form_require_login_message' ) : '';
$updated_form = GFFormsModel::maybe_sanitize_form_settings( $updated_form );
if ( $updated_form['save']['enabled'] ) {
$updated_form = self::activate_save( $updated_form );
} else {
$updated_form = self::deactivate_save( $updated_form );
}
/**
* Filters the updated form settings before being saved.
*
* @since 1.7
*
* @param array $updated_form The form settings.
*/
$updated_form = apply_filters( 'gform_pre_form_settings_save', $updated_form );
$update_result = GFFormDetail::save_form_info( $form_id, addslashes( json_encode( $updated_form ) ) );
// update working form object with updated form object
$form = $updated_form;
}
$form = gf_apply_filters( array( 'gform_admin_pre_render', $form_id ), $form );
self::page_header( __( 'Form Settings', 'gravityforms' ) );
?>
<script type="text/javascript">
<?php GFCommon::gf_global(); ?>
var form = <?php echo json_encode( $form ); ?>;
var fieldSettings = [];
jQuery(document).ready(function ($) {
HandleUnsavedChanges('#gform_form_settings');
jQuery('.datepicker').datepicker({showOn: 'both', changeMonth: true, changeYear: true, buttonImage: "<?php echo GFCommon::get_base_url() ?>/images/calendar.png", buttonImageOnly: true, dateFormat: 'mm/dd/yy'});
ToggleConditionalLogic(true, 'form_button');
jQuery('tr:hidden .gf_animate_sub_settings').hide();
jQuery(document).trigger('gform_load_form_settings', [form]);
});
/**
* New Form Settings Functions
*/
function SaveFormSettings() {
hasUnsavedChanges = false;
// 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 "gform_pre_form_settings_save" php hook instead.');
}
// set fields to empty array to avoid issues with post data being too long
form.fields = [];
jQuery("#gform_meta").val(jQuery.toJSON(form));
jQuery("form#gform_form_settings").submit();
}
function UpdateLabelPlacement() {
var placement = jQuery("#form_label_placement").val();
if (placement == 'top_label') {
jQuery('#description_placement_setting').show('slow');
}
else {
jQuery('#description_placement_setting').hide('slow');
jQuery('#form_description_placement').val('below');
UpdateDescriptionPlacement();
}
}
function UpdateDescriptionPlacement() {
var placement = jQuery("#form_description_placement").val();
//jQuery("#gform_fields").removeClass("description_below").removeClass("description_above").addClass("description_" + placement);
jQuery(".gfield_description").each(function () {
var prevElement = placement == 'above' ? '.gfield_label' : '.ginput_container:visible';
jQuery(this).siblings(prevElement).after(jQuery(this).remove());
});
}
function ToggleButton() {
var isText = jQuery("#form_button_text").is(":checked");
var show_element = isText ? '#form_button_text_setting' : '#form_button_image_path_setting';
var hide_element = isText ? '#form_button_image_path_setting' : '#form_button_text_setting';
jQuery(hide_element).hide();
jQuery(show_element).fadeIn();
}
function ToggleEnableSave() {
if (jQuery("#form_save_enabled").is(":checked")) {
ShowSettingRow('#form_save_button_text_setting');
ShowSettingRow('#form_save_warning');
} else {
HideSettingRow('#form_save_warning');
HideSettingRow('#form_save_button_text_setting');
}
}
function ToggleLimitEntry() {
if (jQuery("#gform_limit_entries").is(":checked")) {
ShowSettingRow('#limit_entries_count_setting');
ShowSettingRow('#limit_entries_message_setting');
}
else {
HideSettingRow('#limit_entries_count_setting');
HideSettingRow('#limit_entries_message_setting');
}
}
function ShowSettingRow(elemId) {
jQuery(elemId).show().find('.gf_animate_sub_settings').slideDown();
}
function HideSettingRow(elemId) {
var elem = jQuery(elemId);
elem.find('.gf_animate_sub_settings').slideUp(function () {
elem.hide();
});
}
function ToggleSchedule() {
if (jQuery("#gform_schedule_form").is(":checked")) {
ShowSettingRow('#schedule_start_setting');
ShowSettingRow('#schedule_end_setting');
ShowSettingRow('#schedule_pending_message_setting');
ShowSettingRow('#schedule_message_setting');
}
else {
HideSettingRow('#schedule_start_setting');
HideSettingRow('#schedule_end_setting');
HideSettingRow('#schedule_pending_message_setting');
HideSettingRow('#schedule_message_setting');
}
}
function ToggleRequireLogin() {
if (jQuery("#gform_require_login").is(":checked")) {
ShowSettingRow('#require_login_message_setting');
}
else {
HideSettingRow('#require_login_message_setting');
}
}
function SetButtonConditionalLogic(isChecked) {
form.button.conditionalLogic = isChecked ? new ConditionalLogic() : null;
}
function HandleUnsavedChanges(elemId) {
hasUnsavedChanges = false;
jQuery(elemId).find('input, select, textarea').change(function () {
hasUnsavedChanges = true;
});
window.onbeforeunload = function () {
if (hasUnsavedChanges){
return '<?php echo esc_js( 'You have unsaved changes.', 'gravityforms' ); ?>';
}
}
}
function ShowAdvancedFormSettings() {
jQuery('#form_setting_advanced').slideDown();
jQuery('.show_advanced_settings_container').slideUp();
}
<?php self::output_field_scripts() ?>
</script>
<?php
switch ( rgar( $update_result, 'status' ) ) {
case 'invalid_json' :
?>
<div class="error below-h2" id="after_update_error_dialog">
<p>
<?php _e( 'There was an error while saving your form.', 'gravityforms' ) ?>
<?php printf( __( 'Please %scontact our support team%s.', 'gravityforms' ), '<a href="https://www.gravityforms.com/support/">', '</a>' ) ?>
</p>
</div>
<?php
break;
case 'duplicate_title':
?>
<div class="error below-h2" id="after_update_error_dialog">
<p>
<?php _e( 'The form title you have entered has already been used. Please enter a unique form title.', 'gravityforms' ) ?>
</p>
</div>
<?php
break;
default:
if ( ! empty( $update_result ) ) {
?>
<div class="updated below-h2" id="after_update_dialog">
<p>
<strong><?php _e( 'Form settings updated successfully.', 'gravityforms' ); ?></strong>
</p>
</div>
<?php
}
break;
}
// These variables are used to convenient "wrap" child form settings in the appropriate HTML.
$subsetting_open = '
<td colspan="2" class="gf_sub_settings_cell">
<div class="gf_animate_sub_settings">
<table>
<tr>';
$subsetting_close = '
</tr>
</table>
</div>
</td>';
// Create form settings table rows and put them into an array.
// Form title.
$tr_form_title = '
<tr>
<th>
' .
__( 'Form title', 'gravityforms' ) . ' ' .
gform_tooltip( 'form_title', '', true ) .
'
</th>
<td>
<input type="text" id="form_title_input" name="form_title_input" class="fieldwidth-3" value="' . esc_attr( $form['title'] ) . '" />
</td>
</tr>';
// Form description.
$tr_form_description = '
<tr>
<th>
' .
__( 'Form description', 'gravityforms' ) . ' ' .
gform_tooltip( 'form_description', '', true ) .
'
</th>
<td>
<textarea id="form_description_input" name="form_description_input" class="fieldwidth-3 fieldheight-2">' . esc_html( rgar( $form, 'description' ) ) . '</textarea>
</td>
</tr>';
// Form label placement.
$alignment_options = array(
'top_label' => __( 'Top aligned', 'gravityforms' ),
'left_label' => __( 'Left aligned', 'gravityforms' ),
'right_label' => __( 'Right aligned', 'gravityforms' )
);
$label_dd = '';
foreach ( $alignment_options as $value => $label ) {
$selected = $form['labelPlacement'] == $value ? 'selected="selected"' : '';
$label_dd .= '<option value="' . $value . '" ' . $selected . '>' . $label . '</option>';
}
$tr_form_label_placement = '
<tr>
<th>
' .
__( 'Label placement', 'gravityforms' ) . ' ' .
gform_tooltip( 'form_label_placement', '', true ) .
'
</th>
<td>
<select id="form_label_placement" name="form_label_placement" onchange="UpdateLabelPlacement();">' .
$label_dd .
'</select>
</td>
</tr>';
// Form description placement.
$style = $form['labelPlacement'] != 'top_label' ? 'display:none;' : '';
$description_dd = '';
$description_options = array(
'below' => __( 'Below inputs', 'gravityforms' ),
'above' => __( 'Above inputs', 'gravityforms' )
);
foreach ( $description_options as $value => $label ) {
$selected = rgar( $form, 'descriptionPlacement' ) == $value ? 'selected="selected"' : '';
$description_dd .= '<option value="' . $value . '" ' . $selected . '>' . $label . '</option>';
}
$tr_form_description_placement = '
<tr id="description_placement_setting" style="' . $style . '">
<th>
' .
__( 'Description placement', 'gravityforms' ) . ' ' .
gform_tooltip( 'form_description_placement', '', true ) .
'
</th>
<td>
<select id="form_description_placement" name="form_description_placement">' .
$description_dd .
'</select>
</td>
</tr>';
// Sub-label placement.
$sub_label_placement_dd = '';
$sub_label_placement_options = array(
'below' => __( 'Below inputs', 'gravityforms' ),
'above' => __( 'Above inputs', 'gravityforms' )
);
foreach ( $sub_label_placement_options as $value => $label ) {
$selected = rgar( $form, 'subLabelPlacement' ) == $value ? 'selected="selected"' : '';
$sub_label_placement_dd .= '<option value="' . $value . '" ' . $selected . '>' . $label . '</option>';
}
$tr_sub_label_placement = '
<tr id="sub_label_placement_setting">
<th>
' .
__( 'Sub-Label Placement', 'gravityforms' ) . ' ' .
gform_tooltip( 'form_sub_label_placement', '', true ) .
'
</th>
<td>
<select id="form_sub_label_placement" name="form_sub_label_placement">' .
$sub_label_placement_dd .
'</select>
</td>
</tr>';
//css class name.
$tr_css_class_name = '
<tr>
<th>
<label for="form_css_class" style="display:block;">' .
__( 'CSS Class Name', 'gravityforms' ) . ' ' .
gform_tooltip( 'form_css_class', '', true ) .
'</label>
</th>
<td>
<input type="text" id="form_css_class" name="form_css_class" class="fieldwidth-3" value="' . esc_attr( rgar( $form, 'cssClass' ) ) . '" />
</td>
</tr>';
// Create form advanced settings table rows.
// Create form button rows.
$form_button_type = rgars( $form, 'button/type' );
$text_button_checked = '';
$image_button_checked = '';
$text_style_display = '';
$image_style_display = '';
if ( $form_button_type == 'text' ) {
$text_button_checked = 'checked="checked"';
$image_style_display = 'display:none;';
} else if ( $form_button_type == 'image' ) {
$image_button_checked = 'checked="checked"';
$text_style_display = 'display:none;';
}
// Form button.
$tr_form_button = '
<tr>
<th>
' . __( 'Input type', 'gravityforms' ) . '
</th>
<td>
<input type="radio" id="form_button_text" name="form_button" value="text" onclick="ToggleButton();" onkeypress="ToggleButton();" ' . $text_button_checked . ' />
<label for="form_button_text" class="inline">' .
__( 'Text', 'gravityforms' ) .
'</label>
&nbsp;&nbsp;
<input type="radio" id="form_button_image" name="form_button" value="image" onclick="ToggleButton();" onkeypress="ToggleButton();" ' . $image_button_checked . ' />
<label for="form_button_image" class="inline">' .
__( 'Image', 'gravityforms' ) . '</label>
</td>
</tr>';
// Form button text.
$tr_form_button_text = $subsetting_open . '
<tr id="form_button_text_setting" class="child_setting_row" style="' . $text_style_display . '">
<th>
' .
__( 'Button text', 'gravityforms' ) . ' ' .
gform_tooltip( 'form_button_text', '', true ) .
'
</th>
<td>
<input type="text" id="form_button_text_input" name="form_button_text_input" class="fieldwidth-3" value="' . esc_attr( rgars( $form, 'button/text' ) ) . '" />
</td>
</tr>';
// Form button image path.
$tr_form_button_image_path = '
<tr id="form_button_image_path_setting" class="child_setting_row" style="' . $image_style_display . '">
<th>
' .
__( 'Button image path', 'gravityforms' ) . ' ' .
gform_tooltip( 'form_button_image', '', true ) .
'
</th>
<td>
<input type="text" id="form_button_image_url" name="form_button_image_url" class="fieldwidth-3" value="' . esc_attr( rgars( $form, 'button/imageUrl' ) ) . '" />
</td>
</tr>' . $subsetting_close;
// Form button conditional logic.
$button_conditional_checked = '';
if ( rgars( $form, 'button/conditionalLogic' ) ) {
$button_conditional_checked = 'checked="checked"';
}
$tr_form_button_conditional = '
<tr>
<th>
' . __( 'Button conditional logic', 'gravityforms' ) . ' ' . gform_tooltip( 'form_button_conditional_logic', '', true ) . '
</th>
<td>
<input type="checkbox" id="form_button_conditional_logic" onclick="SetButtonConditionalLogic(this.checked); ToggleConditionalLogic(false, \'form_button\');" onkeypress="SetButtonConditionalLogic(this.checked); ToggleConditionalLogic(false, \'form_button\');"' . $button_conditional_checked . ' />
<label for="form_button_conditional_logic" class="inline">' . ' ' . __( 'Enable Conditional Logic', 'gravityforms' ) . '</label>
</td>
</tr>
<tr>
<td colspan="2">
<div id="form_button_conditional_logic_container" class="gf_animate_sub_settings" style="display:none;">
<!-- content dynamically created from js.php -->
</div>
</td>
</tr>';
// Create save and continue rows.
$save_enabled_checked = '';
$save_enabled_style = '';
if ( rgars( $form, 'save/enabled' ) ) {
$save_enabled_checked = 'checked="checked"';
} else {
$save_enabled_style = 'style="display:none;"';
}
$save_button_text = isset( $form['save']['button']['text'] ) ? esc_attr( rgars( $form, 'save/button/text' ) ) : __( 'Save and Continue Later', 'gravityforms' );
$tr_enable_save = '
<tr>
<th>
' . __( 'Save and Continue', 'gravityforms' ) . ' ' . gform_tooltip( 'form_enable_save', '', true ) . '
</th>
<td>
<input type="checkbox" id="form_save_enabled" name="form_save_enabled" onclick="ToggleEnableSave();" onkeypress="ToggleEnableSave();" value="1" ' . $save_enabled_checked . ' />
<label for="form_save_enabled">' . __( 'Enable Save and Continue', 'gravityforms' ) . '</label>
</td>
</tr>';
// Warning.
$tr_save_warning = '
<tr id="form_save_warning" class="child_setting_row" ' . $save_enabled_style . '>
' . $subsetting_open . '
<th>
</th>
<td>
<div class="gforms_help_alert fieldwidth-3">
<div>
<i class="fa fa-warning"></i>
'. __('This feature stores potentially private and sensitive data on this server and protects it with a unique link which is displayed to the user on the page in plain, unencrypted text. The link is similar to a password so it\'s strongly advisable to ensure that the page enforces a secure connection (HTTPS) before activating this setting.', 'gravityforms').
'</div>
<br />
<div>
<i class="fa fa-warning"></i>
'. __('When this setting is activated two confirmations and one notification are automatically generated and can be modified in their respective editors. When this setting is deactivated the confirmations and the notification will be deleted automatically and any modifications will be lost.', 'gravityforms').
'</div>
</div>
</td>
</tr>';
// Save button text.
$tr_save_button_text = '
<tr id="form_save_button_text_setting" class="child_setting_row" ' . $save_enabled_style . '>
<th>
' .
__( 'Link text', 'gravityforms' ) . ' ' .
gform_tooltip( 'form_save_button_text', '', true ) .
'
</th>
<td>
<input type="text" id="form_save_button_text" name="form_save_button_text" class="fieldwidth-3" value="' . $save_button_text . '" />
</td>
' . $subsetting_close . '
</tr>';
// Limit entries.
$limit_entry_checked = '';
$limit_entry_style = '';
$limit_entries_dd = '';
if ( rgar( $form, 'limitEntries' ) ) {
$limit_entry_checked = 'checked="checked"';
} else {
$limit_entry_style = 'display:none';
}
$limit_periods = array(
'' => __( 'total entries', 'gravityforms' ),
'day' => __( 'per day', 'gravityforms' ),
'week' => __( 'per week', 'gravityforms' ),
'month' => __( 'per month', 'gravityforms' ),
'year' => __( 'per year', 'gravityforms' )
);
foreach ( $limit_periods as $value => $label ) {
$selected = rgar( $form, 'limitEntriesPeriod' ) == $value ? 'selected="selected"' : '';
$limit_entries_dd .= '<option value="' . $value . '" ' . $selected . '>' . $label . '</option>';
}
$tr_limit_entries = '
<tr>
<th>
' . __( 'Limit number of entries', 'gravityforms' ) . ' ' . gform_tooltip( 'form_limit_entries', '', true ) . '
</th>
<td>
<input type="checkbox" id="gform_limit_entries" name="form_limit_entries" onclick="ToggleLimitEntry();" onkeypress="ToggleLimitEntry();" value="1" ' . $limit_entry_checked . ' />
<label for="gform_limit_entries">' . __( 'Enable entry limit', 'gravityforms' ) . '</label>
</td>
</tr>';
// Limit entries count.
$tr_limit_entries_count = '
<tr id="limit_entries_count_setting" class="child_setting_row" style="' . esc_attr( $limit_entry_style ) . '">
' . $subsetting_open . '
<th>
' .
__( 'Number of Entries', 'gravityforms' ) .
'
</th>
<td>
<input type="text" id="gform_limit_entries_count" name="form_limit_entries_count" style="width:70px;" value="' . esc_attr( rgar( $form, 'limitEntriesCount' ) ) . '" />
&nbsp;
<select id="gform_limit_entries_period" name="form_limit_entries_period" style="height:22px;">' .
$limit_entries_dd .
'</select>
</td>
' . $subsetting_close . '
</tr>';
// Limit entries message.
$tr_limit_entries_message = '
<tr id="limit_entries_message_setting" class="child_setting_row" style="' . $limit_entry_style . '">
' . $subsetting_open . '
<th>
<label for="form_limit_entries_message">' .
__( 'Entry Limit Reached Message', 'gravityforms' ) .
'</label>
</th>
<td>
<textarea id="form_limit_entries_message" name="form_limit_entries_message" class="fieldwidth-3">' . esc_html( rgar( $form, 'limitEntriesMessage' ) ) . '</textarea>
</td>
' . $subsetting_close . '
</tr>
';
// Schedule form.
$schedule_form_checked = '';
$schedule_form_style = '';
$start_hour_dd = '';
$start_minute_dd = '';
$start_am_selected = '';
$start_pm_selected = '';
$end_hour_dd = '';
$end_minute_dd = '';
$end_am_selected = '';
$end_pm_selected = '';
if ( rgar( $form, 'scheduleForm' ) ) {
$schedule_form_checked = 'checked="checked"';
} else {
$schedule_form_style = 'display:none';
}
// Create start hour dd options.
for ( $i = 1; $i <= 12; $i ++ ) {
$selected = rgar( $form, 'scheduleStartHour' ) == $i ? 'selected="selected"' : '';
$start_hour_dd .= '<option value="' . $i . '" ' . $selected . '>' . $i . '</option>';
}
// Create start minute dd options.
foreach ( array( '00', '15', '30', '45' ) as $value ) {
$selected = rgar( $form, 'scheduleStartMinute' ) == $value ? 'selected="selected"' : '';
$start_minute_dd .= '<option value="' . $value . '" ' . $selected . '>' . $value . '</option>';
}
// Set start am/pm.
if ( rgar( $form, 'scheduleStartAmpm' ) == 'am' ) {
$start_am_selected = 'selected="selected"';
} elseif ( rgar( $form, 'scheduleStartAmpm' ) == 'pm' ) {
$start_pm_selected = 'selected="selected"';
}
// Create end hour dd options.
for ( $i = 1; $i <= 12; $i ++ ) {
$selected = rgar( $form, 'scheduleEndHour' ) == $i ? 'selected="selected"' : '';
$end_hour_dd .= '<option value="' . $i . ' "' . $selected . '>' . $i . '</option>';
}
// Create end minute dd options.
foreach ( array( '00', '15', '30', '45' ) as $value ) {
$selected = rgar( $form, 'scheduleEndMinute' ) == $value ? 'selected="selected"' : '';
$end_minute_dd .= '<option value="' . $value . '" ' . $selected . '>' . $value . '</option>';
}
// Set end am/pm.
if ( rgar( $form, 'scheduleEndAmpm' ) == 'am' ) {
$end_am_selected = 'selected="selected"';
} elseif ( rgar( $form, 'scheduleEndAmpm' ) == 'pm' ) {
$end_pm_selected = 'selected="selected"';
}
// Schedule form.
$tr_schedule_form = '
<tr>
<th>
' . __( 'Schedule form', 'gravityforms' ) . ' ' . gform_tooltip( 'form_schedule_form', '', true ) . '
</th>
<td>
<input type="checkbox" id="gform_schedule_form" name="form_schedule_form" value="1" onclick="ToggleSchedule();" onkeypress="ToggleSchedule();"' . $schedule_form_checked . '/>
<label for="gform_schedule_form">' . __( 'Schedule form', 'gravityforms' ) . '</label>
</td>
</tr>';
// Schedule start.
$tr_schedule_start = '
<tr id="schedule_start_setting" class="child_setting_row" style="' . $schedule_form_style . '">
' . $subsetting_open . '
<th>
<label for="gform_schedule_start">' . __( 'Schedule Start Date/Time', 'gravityforms' ) . '</label>
</th>
<td>
<input type="text" id="gform_schedule_start" name="gform_schedule_start" class="datepicker" value="' . esc_attr( rgar( $form, 'scheduleStart' ) ) . '" />
&nbsp;&nbsp;
<select id="gform_schedule_start_hour" name="form_schedule_start_hour">' .
$start_hour_dd .
'</select>
:
<select id="gform_schedule_start_minute" name="form_schedule_start_minute">' .
$start_minute_dd .
'</select>
<select id="gform_schedule_start_ampm" name="form_schedule_start_ampm">
<option value="am" ' . $start_am_selected . '>AM</option>
<option value="pm" ' . $start_pm_selected . '>PM</option>
</select>
</td>
' . $subsetting_close . '
</tr>';
// Schedule end.
$tr_schedule_end = '
<tr id="schedule_end_setting" class="child_setting_row" style="' . esc_attr( $schedule_form_style ) . '">
' . $subsetting_open . '
<th>
' . __( 'Schedule Form End Date/Time', 'gravityforms' ) . '
</th>
<td>
<input type="text" id="gform_schedule_end" name="form_schedule_end" class="datepicker" value="' . esc_attr( rgar( $form, 'scheduleEnd' ) ) . '" />
&nbsp;&nbsp;
<select id="gform_schedule_end_hour" name="form_schedule_end_hour">' .
$end_hour_dd .
'</select>
:
<select id="gform_schedule_end_minute" name="form_schedule_end_minute">' .
$end_minute_dd .
'</select>
<select id="gform_schedule_end_ampm" name="form_schedule_end_ampm">
<option value="am" ' . $end_am_selected . '>AM</option>
<option value="pm" ' . $end_pm_selected . '>PM</option>
</select>
</td>
' . $subsetting_close . '
</tr>';
// Schedule message.
$tr_schedule_pending_message = '
<tr id="schedule_pending_message_setting" class="child_setting_row" style="' . esc_attr( $schedule_form_style ) . '">
' . $subsetting_open . '
<th>
' . __( 'Form Pending Message', 'gravityforms' ) . '
</th>
<td>
<textarea id="gform_schedule_pending_message" name="form_schedule_pending_message" class="fieldwidth-3">' . esc_html( rgar( $form, 'schedulePendingMessage' ) ) . '</textarea>
</td>
' . $subsetting_close . '
</td>';
// Schedule message.
$tr_schedule_message = '
<tr id="schedule_message_setting" class="child_setting_row" style="' . esc_attr( $schedule_form_style ) . '">
' . $subsetting_open . '
<th>
' . __( 'Form Expired Message', 'gravityforms' ) . '
</th>
<td>
<textarea id="gform_schedule_message" name="form_schedule_message" class="fieldwidth-3">' . esc_html( rgar( $form, 'scheduleMessage' ) ) . '</textarea>
</td>
' . $subsetting_close . '
</td>';
// Honey pot.
$honey_pot_checked = '';
if ( rgar( $form, 'enableHoneypot' ) ) {
$honey_pot_checked = 'checked="checked"';
}
$tr_honey_pot = '
<tr>
<th>
' . __( 'Anti-spam honeypot', 'gravityforms' ) . ' ' . gform_tooltip( 'form_honeypot', '', true ) . '
</th>
<td>
<input type="checkbox" id="gform_enable_honeypot" name="form_enable_honeypot" value="1" ' . $honey_pot_checked . '/>
<label for="gform_enable_honeypot">' . __( 'Enable anti-spam honeypot', 'gravityforms' ) . '</label>
</td>
</tr>';
// Enable animation.
$enable_animation_checked = '';
if ( rgar( $form, 'enableAnimation' ) ) {
$enable_animation_checked = 'checked="checked"';
}
$tr_enable_animation = '
<tr>
<th>
' . __( 'Animated transitions', 'gravityforms' ) . ' ' . gform_tooltip( 'form_animation', '', true ) . '
</th>
<td>
<input type="checkbox" id="gform_enable_animation" name="form_enable_animation" value="1" ' . $enable_animation_checked . ' />
<label for="gform_enable_animation">' . __( 'Enable animations', 'gravityforms' ) . '</label>
</td>
</tr>';
// Require login.
$require_login_checked = '';
$require_login_style = '';
if ( rgar( $form, 'requireLogin' ) ) {
$require_login_checked = 'checked="checked"';
} else {
$require_login_style = 'display:none';
}
$tr_requires_login = '
<tr>
<th>
' . __( 'Require user to be logged in', 'gravityforms' ) . ' ' . gform_tooltip( 'form_require_login', '', true ) . '
</th>
<td>
<input type="checkbox" id="gform_require_login" name="form_require_login" value="1" onclick="ToggleRequireLogin();" onkeypress="ToggleRequireLogin();"' . $require_login_checked . ' />
<label for="gform_require_login">' . __( 'Require user to be logged in', 'gravityforms' ) . '</label>
</td>
</tr>';
// Require login message.
$tr_requires_login_message = '
<tr id="require_login_message_setting" class="child_setting_row" style="' . esc_attr( $require_login_style ) . '">
' . $subsetting_open . '
<th>
' . __( 'Require Login Message', 'gravityforms' ) . ' ' . gform_tooltip( 'form_require_login_message', '', true ) . '
</th>
<td>
<textarea id="gform_require_login_message" name="form_require_login_message" class="fieldwidth-3">' . esc_html( rgar( $form, 'requireLoginMessage' ) ) . '</textarea>
</td>
' . $subsetting_close . '
</td>';
// Populate arrays with table rows
$form_basics = array( 'form_title' => $tr_form_title, 'form_description' => $tr_form_description );
$form_layout = array( 'form_label_placement' => $tr_form_label_placement, 'form_description_placement' => $tr_form_description_placement, 'form_sub_label_placement' => $tr_sub_label_placement, 'css_class_name' => $tr_css_class_name );
$form_button = array( 'form_button_type' => $tr_form_button, 'form_button_text' => $tr_form_button_text, 'form_button_image_path' => $tr_form_button_image_path, 'form_button_conditional' => $tr_form_button_conditional );
$save_button = array( 'save_enabled' => $tr_enable_save, 'save_warning' => $tr_save_warning, 'save_button_text' => $tr_save_button_text );
$form_restrictions = array( 'limit_entries' => $tr_limit_entries, 'number_of_entries' => $tr_limit_entries_count, 'entry_limit_message' => $tr_limit_entries_message, 'schedule_form' => $tr_schedule_form, 'schedule_start' => $tr_schedule_start, 'schedule_end' => $tr_schedule_end, 'schedule_pending_message' => $tr_schedule_pending_message, 'schedule_message' => $tr_schedule_message, 'requires_login' => $tr_requires_login, 'requires_login_message' => $tr_requires_login_message );
$form_options = array( 'honey_pot' => $tr_honey_pot, 'enable_animation' => $tr_enable_animation );
$form_settings = array(
__( 'Form Basics', 'gravityforms' ) => $form_basics,
__( 'Form Layout', 'gravityforms' ) => $form_layout,
__( 'Form Button', 'gravityforms' ) => $form_button,
__( 'Save and Continue', 'gravityforms' ) => $save_button,
__( 'Restrictions', 'gravityforms' ) => $form_restrictions,
__( 'Form Options', 'gravityforms' ) => $form_options,
);
/**
* Filters the form settings before they are displayed.
*
* @since 1.7
*
* @param array $form_settings The form settings.
* @param array $form The Form Object.
*/
$form_settings = apply_filters( 'gform_form_settings', $form_settings, $form );
?>
<div class="gform_panel gform_panel_form_settings" id="form_settings">
<h3><span><i class="fa fa-cogs"></i> <?php esc_html_e( 'Form Settings', 'gravityforms' ) ?></span></h3>
<form action="" method="post" id="gform_form_settings">
<table class="gforms_form_settings" cellspacing="0" cellpadding="0">
<?php
// Write out array of table rows
if ( is_array( $form_settings ) ) {
foreach ( $form_settings as $key => $value ) {
?>
<tr>
<td colspan="2">
<h4 class="gf_settings_subgroup_title"><?php echo esc_html( $key ); ?></h4>
</td>
</tr>
<?php
if ( is_array( $value ) ) {
foreach ( $value as $tr ) {
echo $tr;
}
}
}
}
?>
</table>
<div id="gform_custom_settings">
<?php
/**
* Fires after form settings are generated, within a custom settings div.
*
* Used to insert custom form settings within the General settings.
*
* @since Unknown
*
* @param int $form_id The ID of the form that settings are being accessed on.
*/
?>
<?php do_action( 'gform_properties_settings', 100, $form_id ); ?>
<?php do_action( 'gform_properties_settings', 200, $form_id ); ?>
<?php do_action( 'gform_properties_settings', 300, $form_id ); ?>
<?php do_action( 'gform_properties_settings', 400, $form_id ); ?>
<?php do_action( 'gform_properties_settings', 500, $form_id ); ?>
<?php
/**
* Fires after form settings are generated, within a custom settings div.
*
* Used to insert custom form settings within the Advanced settings.
*
* @since Unknown
*
* @param int $form_id The ID of the form that settings are being accessed on.
*/
?>
<?php do_action( 'gform_advanced_settings', 100, $form_id ); ?>
<?php do_action( 'gform_advanced_settings', 200, $form_id ); ?>
<?php do_action( 'gform_advanced_settings', 300, $form_id ); ?>
<?php do_action( 'gform_advanced_settings', 400, $form_id ); ?>
<?php do_action( 'gform_advanced_settings', 500, $form_id ); ?>
<?php do_action( 'gform_advanced_settings', 600, $form_id ); ?>
<?php do_action( 'gform_advanced_settings', 700, $form_id ); ?>
<?php do_action( 'gform_advanced_settings', 800, $form_id ); ?>
</div>
<?php wp_nonce_field( "gform_save_form_settings_{$form_id}", 'gform_save_form_settings' ); ?>
<input type="hidden" id="gform_meta" name="gform_meta" />
<input type="button" id="gform_save_settings" name="gform_save_settings" value="<?php _e( 'Update Form Settings', 'gravityforms' ); ?>" class="button-primary gfbutton" onclick="SaveFormSettings();" onkeypress="SaveFormSettings();" />
</form>
</div> <!-- / gform_panel_form_settings -->
<?php
self::page_footer();
}
/**
* Runs the appropriate Confirmations page content.
*
* @since Unknown
* @access public
*
* @used-by GFFormSettings::form_settings_page()
* @uses GFFormSettings::confirmations_edit_page()
* @uses GFFormSettings::confirmations_list_page()
*
* @return void
*/
public static function confirmations_page() {
$form_id = rgget( 'id' );
$confirmation_id = rgget( 'cid' );
if ( ! rgblank( $confirmation_id ) ) {
self::confirmations_edit_page( $form_id, $confirmation_id );
} else {
self::confirmations_list_page( $form_id );
}
}
/**
* Displays the Confirmations listing page.
*
* @since Unknown
* @access public
*
* @used-by GFFormSettings::confirmations_page()
* @uses GFFormSettings::maybe_process_confirmation_list_action()
* @uses GFFormSettings::page_header()
* @uses GFFormsModel::get_form_meta()
* @uses GFConfirmationTable::prepare_items()
* @uses GFConfirmationTable::display()
* @uses GFFormSettings::page_footer()
*
* @param int $form_id The form ID to display the confirmations for.
*
* @return void
*/
public static function confirmations_list_page( $form_id ) {
self::maybe_process_confirmation_list_action();
self::page_header( __( 'Confirmations', 'gravityforms' ) );
$add_new_url = add_query_arg( array( 'cid' => 0 ) );
?>
<h3><span><i class="fa fa-envelope-o"></i> <?php _e( 'Confirmations', 'gravityforms' ) ?>
<a id="add-new-confirmation" class="add-new-h2" href="<?php echo esc_url( $add_new_url ) ?>"><?php _e( 'Add New', 'gravityforms' ) ?></a></span>
</h3>
<?php $form = GFFormsModel::get_form_meta( $form_id ); ?>
<script type="text/javascript">
var form = <?php echo json_encode( $form ); ?>;
function ToggleActive(img, confirmation_id) {
var is_active = img.src.indexOf("active1.png") >= 0
if (is_active) {
img.src = img.src.replace("active1.png", 'active0.png');
jQuery(img).attr('title', '<?php _e( 'Inactive', 'gravityforms' ) ?>').attr('alt', '<?php _e( 'Inactive', 'gravityforms' ) ?>');
}
else {
img.src = img.src.replace("active0.png", 'active1.png');
jQuery(img).attr('title', '<?php _e( 'Active', 'gravityforms' ) ?>').attr('alt', '<?php _e( 'Active', 'gravityforms' ) ?>');
}
var mysack = new sack("<?php echo admin_url( 'admin-ajax.php' )?>");
mysack.execute = 1;
mysack.method = 'POST';
mysack.setVar("action", "rg_update_confirmation_active");
mysack.setVar("rg_update_confirmation_active", "<?php echo wp_create_nonce( 'rg_update_confirmation_active' ) ?>");
mysack.setVar("form_id", <?php echo intval( $form_id ) ?>);
mysack.setVar("confirmation_id", confirmation_id);
mysack.setVar("is_active", is_active ? 0 : 1);
mysack.onError = function () {
alert('<?php echo esc_js( __( 'Ajax error while updating confirmation', 'gravityforms' ) ) ?>')
};
mysack.runAJAX();
return true;
}
</script>
<?php
$confirmation_table = new GFConfirmationTable( $form );
$confirmation_table->prepare_items();
?>
<form id="confirmation_list_form" method="post">
<?php $confirmation_table->display(); ?>
<input id="action_argument" name="action_argument" type="hidden" />
<input id="action" name="action" type="hidden" />
<?php wp_nonce_field( 'gform_confirmation_list_action', 'gform_confirmation_list_action' ) ?>
</form>
<?php
self::page_footer();
}
/**
* Displays the Confirmation Edit page.
*
* @since Unknown
* @access public
*
* @used-by GFFormSettings::confirmations_page()
* @uses GFFormsModel::get_form_meta()
* @uses GFFormSettings::handle_confirmation_edit_submission()
* @uses GFFormSettings::is_unique_name()
* @uses GFFormSettings::get_confirmation_ui_settings()
* @uses GFFormsModel::get_entry_meta()
* @uses GFFormSettings::confirmation_looks_unsafe()
* @uses GFCommon::add_dismissible_message()
* @uses GFFormSettings::page_header()
* @uses GFFormSettings::output_field_scripts()
* @uses GFFormSettings::page_footer()
*
* @param int $form_id The ID of the form confirmations are being edited for.
* @param int $confirmation_id The confirmation ID being edited.
*/
public static function confirmations_edit_page( $form_id, $confirmation_id ) {
$form_id = absint( $form_id );
/**
* Filters to form meta being used within the confirmations edit page.
*
* @since Unknown
*
* @uses GFFormsModel::get_form_meta()
*
* @param array GFFormsModel::get_form_meta() The Form Object.
*/
$form = gf_apply_filters( array( 'gform_admin_pre_render', $form_id ), GFFormsModel::get_form_meta( $form_id ) );
$duplicated_cid = sanitize_key( rgget( 'duplicatedcid' ) );
$is_duplicate = empty( $_POST ) && ! empty( $duplicated_cid );
if ( $is_duplicate ) {
$confirmation_id = $duplicated_cid;
}
$confirmation = self::handle_confirmation_edit_submission( rgar( $form['confirmations'], $confirmation_id, array() ), $form );
if ( $is_duplicate ) {
$count = 2;
$name = $confirmation['name'];
$new_name = $name . ' - Copy 1';
while ( ! self::is_unique_name( $new_name, $form['confirmations'] ) ) {
$new_name = $name . " - Copy $count";
$count ++;
}
$confirmation['name'] = $new_name;
$confirmation['id'] = 'new';
if ( $confirmation['isDefault'] ) {
$confirmation['isDefault'] = false;
$confirmation['conditionalLogic'] = '';
}
}
$confirmation_ui_settings = self::get_confirmation_ui_settings( $confirmation );
$entry_meta = GFFormsModel::get_entry_meta( $form_id );
/**
* Filters the entry meta used within confirmations.
*
* @since Unknown
*
* @param array $entry_meta The Entry Object.
* @param array $form The Form Object.
* @param int $confirmation_id The ID of the confirmation being edited.
*/
$entry_meta = apply_filters( 'gform_entry_meta_conditional_logic_confirmations', $entry_meta, $form, $confirmation_id );
if ( ! empty( $confirmation['message'] ) && self::confirmation_looks_unsafe( $confirmation['message'] ) ) {
$dismissible_message = esc_html__( 'Your confirmation message appears to contain a merge tag as the value for an HTML attribute. Depending on the attribute and field type, this might be a security risk. %sFurther details%s', 'gravityforms' );
$dismissible_message = sprintf( $dismissible_message, '<a href="https://docs.gravityforms.com/security-warning-merge-tags-html-attribute-values/" target="_blank">', '</a>' );
GFCommon::add_dismissible_message( $dismissible_message, 'confirmation_unsafe_' . $form_id );
}
self::page_header( __( 'Confirmations', 'gravityforms' ) );
?>
<script type="text/javascript">
var confirmation = <?php echo $confirmation ? json_encode( $confirmation ) : 'new ConfirmationObj()' ?>;
var form = <?php echo json_encode( $form ); ?>;
var entry_meta = <?php echo GFCommon::json_encode( $entry_meta ) ?>;
jQuery(document).ready(function ($) {
if ( confirmation.event == 'form_saved' || confirmation.event == 'form_save_email_sent' ) {
$('#form_confirmation_redirect, #form_confirmation_show_page').attr('disabled', true);
}
SetConfirmationConditionalLogic();
<?php if ( ! rgar( $confirmation, 'isDefault' ) ) : ?>
ToggleConditionalLogic(true, 'confirmation');
<?php endif; ?>
ToggleConfirmation();
<?php if ( $is_duplicate ) :?>
$('#confirmation_conditional_logic_container').pointer({
content: <?php echo json_encode( sprintf( '<h3>%s</h3><p>%s</p>', __( 'Important', 'gravityforms' ), __( 'Ensure that the conditional logic for this confirmation is different from all the other confirmations for this form and then press save to create the new confirmation.', 'gravityforms' ) ) ); ?>,
position: {
edge: 'bottom', // arrow direction
align: 'center' // vertical alignment
},
pointerWidth: 300
}).pointer('open');
<?php endif; ?>
});
gform.addFilter('gform_merge_tags', 'MaybeAddSaveMergeTags');
function MaybeAddSaveMergeTags(mergeTags, elementId, hideAllFields, excludeFieldTypes, isPrepop, option) {
var event = confirmation.event;
if ( event === 'form_saved' || event === 'form_save_email_sent' ) {
mergeTags['other'].tags.push({ tag: '{save_link}', label: <?php echo json_encode( __( 'Save &amp; Continue Link', 'gravityforms' ) ) ?> });
mergeTags['other'].tags.push({ tag: '{save_token}', label: <?php echo json_encode( __( 'Save &amp; Continue Token', 'gravityforms' ) ) ?> });
}
if ( event === 'form_saved' ) {
mergeTags['other'].tags.push({ tag: '{save_email_input}', label: <?php echo json_encode( __( 'Save &amp; Continue Email Input', 'gravityforms' ) ) ?> });
}
return mergeTags;
}
<?php self::output_field_scripts() ?>
</script>
<style type="text/css">
#confirmation_action_type {
display: none;
}
</style>
<div id="confirmation-editor">
<form id="confirmation_edit_form" method="post">
<table class="form-table gforms_form_settings">
<?php array_map( array( __class__, 'output' ), $confirmation_ui_settings ); ?>
</table>
<?php
/**
* @deprecated
* @see gform_confirmation_ui_settings
*/
do_action( 'gform_confirmation_settings', 100, $form_id );
do_action( 'gform_confirmation_settings', 200, $form_id );
?>
<input type="hidden" id="confirmation_id" name="confirmation_id" value="<?php echo esc_attr( $confirmation_id ); ?>" />
<input type="hidden" id="form_id" name="form_id" value="<?php echo esc_attr( $form_id ); ?>" />
<input type="hidden" id="is_default" name="is_default" value="<?php echo rgget( 'isDefault', $confirmation ) ?>" />
<input type="hidden" id="conditional_logic" name="conditional_logic" value="<?php echo htmlentities( json_encode( rgget( 'conditionalLogic', $confirmation ) ) ); ?>" />
<p class="submit">
<input type="submit" name="save" value="<?php _e( 'Save Confirmation', 'gravityforms' ); ?>" onclick="StashConditionalLogic(event);" onkeypress="StashConditionalLogic(event);" class="button-primary">
</p>
<?php wp_nonce_field( 'gform_confirmation_edit', 'gform_confirmation_edit' ); ?>
</form>
</div> <!-- / confirmation-editor -->
<?php
self::page_footer();
}
/**
* Displays the Confirmations page within the form settings.
*
* @used-by GFFormSettings::confirmations_edit_page()
* @uses GFCommon::$errors
* @uses GFFormsModel::get_form_meta()
* @uses gform_tooltip()
*
* @param array $confirmation The confirmation to display details for.
*
* @return array $ui_settings The content of the Confirmations page.
*/
public static function get_confirmation_ui_settings( $confirmation ) {
/**
* These variables are used to convenient "wrap" child form settings in the appropriate HTML.
*/
$subsetting_open = '
<td colspan="2" class="gf_sub_settings_cell">
<div class="gf_animate_sub_settings">
<table style="width:100%">
<tr>';
$subsetting_close = '
</tr>
</table>
</div>
</td>';
$ui_settings = array();
$confirmation_type = rgar( $confirmation, 'type' ) ? rgar( $confirmation, 'type' ) : 'message';
$is_valid = ! empty( GFCommon::$errors );
$is_default = rgar( $confirmation, 'isDefault' );
$form_id = rgget( 'id' );
$form = RGFormsModel::get_form_meta( $form_id );
ob_start(); ?>
<?php $class = ! $is_default && ! $is_valid && $confirmation_type == 'page' && ! rgar( $confirmation, 'name' ) ? 'gfield_error' : ''; ?>
<tr <?php echo $is_default ? 'style="display:none;"' : ''; ?> class="<?php echo $class; ?>">
<th><?php _e( 'Confirmation Name', 'gravityforms' ); ?></th>
<td>
<input type="text" id="form_confirmation_name" name="form_confirmation_name" value="<?php echo esc_attr( rgar( $confirmation, 'name' ) ); ?>" />
</td>
</tr> <!-- / confirmation name -->
<?php $ui_settings['confirmation_name'] = ob_get_contents();
ob_clean(); ?>
<tr>
<th><?php _e( 'Confirmation Type', 'gravityforms' ); ?></th>
<td>
<input type="radio" id="form_confirmation_show_message" name="form_confirmation" <?php checked( 'message', $confirmation_type ); ?> value="message" onclick="ToggleConfirmation();" onkeypress="ToggleConfirmation();" />
<label for="form_confirmation_show_message" class="inline">
<?php _e( 'Text', 'gravityforms' ); ?>
<?php gform_tooltip( 'form_confirmation_message' ) ?>
</label>
&nbsp;&nbsp;
<input type="radio" id="form_confirmation_show_page" name="form_confirmation" <?php checked( 'page', $confirmation_type ); ?> value="page" onclick="ToggleConfirmation();" onkeypress="ToggleConfirmation();" />
<label for="form_confirmation_show_page" class="inline">
<?php _e( 'Page', 'gravityforms' ); ?>
<?php gform_tooltip( 'form_redirect_to_webpage' ) ?>
</label>
&nbsp;&nbsp;
<input type="radio" id="form_confirmation_redirect" name="form_confirmation" <?php checked( 'redirect', $confirmation_type ); ?> value="redirect" onclick="ToggleConfirmation();" onkeypress="ToggleConfirmation();" />
<label for="form_confirmation_redirect" class="inline">
<?php _e( 'Redirect', 'gravityforms' ); ?>
<?php gform_tooltip( 'form_redirect_to_url' ) ?>
</label>
</td>
</tr> <!-- / confirmation type -->
<?php $ui_settings['confirmation_type'] = ob_get_contents();
ob_clean(); ?>
<tr id="form_confirmation_message_container" <?php echo $confirmation_type != 'message' ? 'style="display:none;"' : ''; ?> >
<?php echo $subsetting_open; ?>
<th><?php _e( 'Message', 'gravityforms' ); ?></th>
<td>
<span class="mt-form_confirmation_message"></span>
<?php
wp_editor( rgar( $confirmation, 'message' ), 'form_confirmation_message', array( 'autop' => false, 'editor_class' => 'merge-tag-support mt-wp_editor mt-manual_position mt-position-right' ) );
?>
<div style="margin-top:5px;">
<input type="checkbox" id="form_disable_autoformatting" name="form_disable_autoformatting" value="1" <?php echo empty( $confirmation['disableAutoformat'] ) ? '' : "checked='checked'" ?> />
<label for="form_disable_autoformatting"><?php _e( 'Disable Auto-formatting', 'gravityforms' ) ?> <?php gform_tooltip( 'form_confirmation_autoformat' ) ?></label>
</div>
</td>
<?php echo $subsetting_close; ?>
</tr> <!-- / confirmation message -->
<?php $ui_settings['confirmation_message'] = ob_get_contents();
ob_clean(); ?>
<?php $class = ! $is_valid && $confirmation_type == 'page' && ! rgar( $confirmation, 'pageId' ) ? 'gfield_error' : ''; ?>
<tr class="form_confirmation_page_container" <?php echo $confirmation_type != 'page' ? 'style="display:none;"' : '' ?> class="<?php echo $class; ?>">
<?php echo $subsetting_open; ?>
<th><?php _e( 'Page', 'gravityforms' ); ?></th>
<td>
<?php wp_dropdown_pages( array( 'name' => 'form_confirmation_page', 'selected' => rgar( $confirmation, 'pageId' ), 'show_option_none' => __( 'Select a page', 'gravityforms' ) ) ); ?>
</td>
<?php echo $subsetting_close; ?>
</tr> <!-- / confirmation page -->
<?php $ui_settings['confirmation_page'] = ob_get_contents();
ob_clean(); ?>
<tr class="form_confirmation_page_container" <?php echo $confirmation_type != 'page' ? 'style="display:none;"' : '' ?> class="<?php echo $class; ?>">
<?php echo $subsetting_open; ?>
<th><?php _e( 'Redirect Query String', 'gravityforms' ); ?> <?php gform_tooltip( 'form_redirect_querystring' ) ?></th>
<td>
<input type="checkbox" id="form_page_use_querystring" name="form_page_use_querystring" <?php echo empty( $confirmation['queryString'] ) ? '' : "checked='checked'" ?> onclick="TogglePageQueryString()" onkeypress="TogglePageQueryString()" />
<label for="form_page_use_querystring"><?php _e( 'Pass Field Data Via Query String', 'gravityforms' ) ?></label>
<div id="form_page_querystring_container" <?php echo empty( $confirmation['queryString'] ) ? 'style="display:none;"' : ''; ?> >
<?php
$query_string = rgget( 'queryString', $confirmation );
?>
<textarea name="form_page_querystring" id="form_page_querystring" class="merge-tag-support mt-position-right mt-hide_all_fields mt-option-url" style="width:98%; height:100px;"><?php echo esc_textarea( $query_string ); ?></textarea><br />
<div class="instruction"><?php _e( 'Sample: phone={Phone:1}&email={Email:2}', 'gravityforms' ); ?></div>
</div>
</td>
<?php echo $subsetting_close; ?>
</tr> <!-- / confirmation page use querystring -->
<?php $ui_settings['confirmation_page_querystring'] = ob_get_contents();
ob_clean(); ?>
<?php $class = ! $is_valid && $confirmation_type == 'redirect' && ! rgar( $confirmation, 'url' ) ? 'gfield_error' : ''; ?>
<tr class="form_confirmation_redirect_container <?php echo $class; ?>" <?php echo $confirmation_type != 'redirect' ? 'style="display:none;"' : '' ?> >
<?php echo $subsetting_open; ?>
<th><?php _e( 'Redirect URL', 'gravityforms' ); ?></th>
<td>
<input type="text" id="form_confirmation_url" name="form_confirmation_url" value="<?php echo esc_attr( rgget( 'url', $confirmation ) ); ?>" style="width:98%;" />
</td>
<?php echo $subsetting_close; ?>
</tr> <!-- / confirmation url -->
<?php $ui_settings['confirmation_url'] = ob_get_contents();
ob_clean(); ?>
<tr class="form_confirmation_redirect_container" <?php echo $confirmation_type != 'redirect' ? 'style="display:none;"' : '' ?> >
<?php echo $subsetting_open; ?>
<th><?php _e( 'Redirect Query String', 'gravityforms' ); ?> <?php gform_tooltip( 'form_redirect_querystring' ) ?></th>
<td>
<input type="checkbox" id="form_redirect_use_querystring" name="form_redirect_use_querystring" <?php echo empty( $confirmation['queryString'] ) ? '' : "checked='checked'" ?> onclick="ToggleQueryString()" onkeypress="ToggleQueryString()" />
<label for="form_redirect_use_querystring"><?php _e( 'Pass Field Data Via Query String', 'gravityforms' ) ?></label>
<div id="form_redirect_querystring_container" <?php echo empty( $confirmation['queryString'] ) ? 'style="display:none;"' : ''; ?> >
<?php
$query_string = rgget( 'queryString', $confirmation );
?>
<textarea name="form_redirect_querystring" id="form_redirect_querystring" class="merge-tag-support mt-position-right mt-hide_all_fields mt-option-url" style="width:98%; height:100px;"><?php echo esc_textarea( $query_string ); ?></textarea><br />
<div class="instruction"><?php _e( 'Sample: phone={Phone:1}&email={Email:2}', 'gravityforms' ); ?></div>
</div>
</td>
<?php echo $subsetting_close; ?>
</tr> <!-- / confirmation use querystring -->
<?php $ui_settings['confirmation_querystring'] = ob_get_contents();
ob_clean(); ?>
<tr <?php echo rgget( 'isDefault', $confirmation ) ? 'style="display:none;"' : ''; ?> >
<th><?php _e( 'Conditional Logic', 'gravityforms' ); ?></th>
<td>
<input type="checkbox" id="confirmation_conditional_logic" name="confirmation_conditional_logic" style="display:none;" checked="checked" />
<div id="confirmation_conditional_logic_container">
<!-- content populated dynamically by form_admin.js -->
</div>
</td>
</tr> <!-- conditional logic -->
<?php $ui_settings['confirmation_conditional_logic'] = ob_get_contents();
ob_clean(); ?>
<?php
ob_end_clean();
/**
* Filters the confirmation page before it is returned.
*
* @since Unknown
*
* @param array $ui_settings The Settings page markup.
* @param array $confirmation Contains the confirmation details.
* @param array $form The Form Object.
*/
$ui_settings = gf_apply_filters( array( 'gform_confirmation_ui_settings', $form_id ), $ui_settings, $confirmation, $form );
return $ui_settings;
}
/**
* Runs the notification page.
*
* @since Unknown
* @access public
*
* @used-by GFFormSettings::form_settings_page()
* @uses GFNotification::notification_page()
*
* @return void
*/
public static function notification_page() {
require_once( 'notification.php' );
// Page header loaded in below function because admin messages were not yet available to the header to display.
GFNotification::notification_page();
}
/**
* Renders the Personal Data page.
*
* @since 2.4
*/
public static function personal_data_page() {
self::page_header( __( 'Personal Data', 'gravityforms' ) );
require_once( 'includes/class-personal-data.php' );
$form_id = absint( rgget( 'id' ) );
if ( isset( $_POST['save_personal_data_settings'])) {
GF_Personal_Data::process_form_settings( $form_id );
}
GF_Personal_Data::form_settings( $form_id );
self::page_footer();
}
/**
* Displays the form settings page header.
*
* @since Unknown
* @access public
*
* @used-by GFFormSettings::confirmations_edit_page()
* @used-by GFFormSettings::confirmations_list_page()
* @used-by GFFormSettings::form_settings_ui()
* @used-by GFNotification::notification_edit_page()
* @used-by GFNotification::notification_list_page()
* @used-by GFAddOn::form_settings_page()
* @uses SCRIPT_DEBUG
* @uses GFFormsModel::get_form_meta()
* @uses GFFormSettings::get_tabs()
* @uses GFCommon::form_page_title()
* @uses GFCommon::display_dismissible_message()
* @uses GFCommon::display_admin_message()
* @uses GFForms::top_toolbar()
* @uses GFCommon::get_browser_class()
*
* @param string $title The title to display as the page header. Defaults to empty string.
*
* @return void
*/
public static function page_header( $title = '' ) {
// Print admin styles.
wp_print_styles( array( 'jquery-ui-styles', 'gform_admin', 'wp-pointer' ) );
$form = GFFormsModel::get_form_meta( rgget( 'id' ) );
$current_tab = rgempty( 'subview', $_GET ) ? 'settings' : rgget( 'subview' );
$setting_tabs = GFFormSettings::get_tabs( $form['id'] );
// Kind of boring having to pass the title, optionally get it from the settings tab
if ( ! $title ) {
foreach ( $setting_tabs as $tab ) {
if ( $tab['name'] == $current_tab ) {
$title = $tab['label'];
}
}
}
?>
<div class="wrap gforms_edit_form gforms_form_settings_wrap <?php echo GFCommon::get_browser_class() ?>">
<?php GFCommon::form_page_title( $form ); ?>
<?php GFCommon::display_dismissible_message(); ?>
<?php GFCommon::display_admin_message(); ?>
<?php RGForms::top_toolbar(); ?>
<div id="gform_tab_group" class="gform_tab_group vertical_tabs">
<ul id="gform_tabs" class="gform_tabs">
<?php
foreach ( $setting_tabs as $tab ) {
$query = array( 'subview' => $tab['name'] );
if ( rgar( $tab, 'capabilities' ) && ! GFCommon::current_user_can_any( $tab['capabilities'] ) ) {
continue;
}
if ( isset( $tab['query'] ) )
$query = array_merge( $query, $tab['query'] );
$url = add_query_arg( $query );
?>
<li <?php echo $current_tab == $tab['name'] ? "class='active'" : '' ?>>
<a href="<?php echo esc_url( $url ); ?>"><?php echo esc_html( $tab['label'] ) ?></a><span></span>
</li>
<?php
}
?>
</ul>
<div id="gform_tab_container_1" class="gform_tab_container">
<div class="gform_tab_content" id="tab_<?php echo esc_attr( $current_tab ); ?>">
<?php
}
/**
* Displays the Settings page footer.
*
* @since Unknown
* @access public
*
* @used-by GFFormSettings::confirmations_edit_page()
* @used-by GFFormSettings::confirmations_list_page()
* @used-by GFFormSettings::form_settings_ui()
* @used-by GFNotification::notification_edit_page()
* @used-by GFNotification::notification_list_page()
* @used-by GFAddOn::form_settings_page()
*
* @return void
*/
public static function page_footer() {
?>
</div>
<!-- / gform_tab_content -->
</div>
<!-- / gform_tab_container -->
</div>
<!-- / gform_tab_group -->
<br class="clear" style="clear: both;" />
</div> <!-- / wrap -->
<?php
}
/**
* Gets the Settings page tabs.
*
* @since Unknown
* @access public
*
* @used-by GFFormSettings::page_header()
* @used-by GFForms::get_form_settings_sub_menu_items()
* @used-by GFForms::modify_admin_title()
*
* @param int $form_id The form ID to get tabs for.
*
* @return array $settings_tabs The form settings tabs to display.
*/
public static function get_tabs( $form_id ) {
$setting_tabs = array(
'10' => array(
'name' => 'settings',
'label' => __( 'Form Settings', 'gravityforms' ),
'capabilities' => array( 'gravityforms_edit_forms' ),
),
'20' => array(
'name' => 'confirmation',
'label' => __( 'Confirmations', 'gravityforms' ),
'query' => array( 'cid' => null, 'duplicatedcid' => null ),
'capabilities' => array( 'gravityforms_edit_forms' ),
),
'30' => array(
'name' => 'notification',
'label' => __( 'Notifications', 'gravityforms' ),
'query' => array( 'nid' => null ),
'capabilities' => array( 'gravityforms_edit_forms' ),
),
'40' => array(
'name' => 'personal-data',
'label' => __( 'Personal Data', 'gravityforms' ),
'query' => array( 'nid' => null ),
'capabilities' => array( 'gravityforms_edit_forms' ),
),
);
/**
* Filters the settings tabs before they are returned.
*
* Tabs are not sorted yet, and will be sorted numerically.
*
* @since Unknown
*
* @param array $setting_tabs The settings tabs.
* @param int $form_id The ID of the form being accessed.
*/
$setting_tabs = apply_filters( 'gform_form_settings_menu', $setting_tabs, $form_id );
ksort( $setting_tabs, SORT_NUMERIC );
return $setting_tabs;
}
/**
* Handles the submission of confirmations page edits.
*
* @since Unknown
* @access public
*
* @used-by GFFormSettings::confirmations_edit_page()
* @uses GFFormSettings::maybe_wp_kses()
* @uses GFFormsModel::sanitize_conditional_logic()
* @uses GFCommon::add_error_message()
* @uses GFCommon::is_valid_url()
* @uses GFCommon::has_merge_tag()
* @uses GFFormsModel::trim_conditional_logic_values_from_element()
* @uses GFFormsModel::save_form_confirmations()
* @uses GFCommon::add_message()
*
* @param array $confirmation The confirmation details.
* @param array $form The Form Object.
*
* @return array $confirmation The Confirmation that was submitted.
*/
public static function handle_confirmation_edit_submission( $confirmation, $form ) {
if ( empty( $_POST ) || ! check_admin_referer( 'gform_confirmation_edit', 'gform_confirmation_edit' ) ) {
return $confirmation;
}
$is_new_confirmation = ! $confirmation;
if ( $is_new_confirmation ) {
$confirmation['id'] = uniqid();
}
$name = sanitize_text_field( rgpost( 'form_confirmation_name' ) );
$confirmation['name'] = $name;
$type = rgpost( 'form_confirmation' );
if ( ! in_array( $type, array( 'message', 'page', 'redirect' ) ) ) {
$type = 'message';
}
$confirmation['type'] = $type;
// Filter HTML for users without the unfiltered_html capability
$confirmation_message = self::maybe_wp_kses( rgpost( 'form_confirmation_message' ) );
$failed_validation = false;
$confirmation['message'] = $confirmation_message;
$confirmation['disableAutoformat'] = (bool) rgpost( 'form_disable_autoformatting' );
$confirmation['pageId'] = absint( rgpost( 'form_confirmation_page' ) );
$confirmation['url'] = rgpost( 'form_confirmation_url' );
$query_string = '' != rgpost( 'form_redirect_querystring' ) ? rgpost( 'form_redirect_querystring' ) : rgpost( 'form_page_querystring' );
$confirmation['queryString'] = wp_strip_all_tags( $query_string );
$confirmation['isDefault'] = (bool) rgpost( 'is_default' );
// if is default confirmation, override any submitted conditional logic with empty array
$confirmation['conditionalLogic'] = $confirmation['isDefault'] ? array() : json_decode( rgpost( 'conditional_logic' ), ARRAY_A );
$confirmation['conditionalLogic'] = GFFormsModel::sanitize_conditional_logic( $confirmation['conditionalLogic'] );
if ( ! $confirmation['name'] ) {
$failed_validation = true;
GFCommon::add_error_message( __( 'You must specify a Confirmation Name.', 'gravityforms' ) );
}
switch ( $type ) {
case 'page':
if ( empty( $confirmation['pageId'] ) ) {
$failed_validation = true;
GFCommon::add_error_message( __( 'You must select a Confirmation Page.', 'gravityforms' ) );
}
break;
case 'redirect':
if ( ( empty( $confirmation['url'] ) || ! GFCommon::is_valid_url( $confirmation['url'] ) ) && ! GFCommon::has_merge_tag( $confirmation['url'] ) ) {
$failed_validation = true;
GFCommon::add_error_message( __( 'You must specify a valid Redirect URL.', 'gravityforms' ) );
}
break;
}
if ( $failed_validation ) {
return $confirmation;
}
/**
* Filters the confirmation before it is saved.
*
* @since Unknown
*
* @param array $confirmation The confirmation details.
* @param array $form The Form Object.
* @param bool $is_new_confirmation True if this is a new confirmation. False if editing existing.
*/
$confirmation = gf_apply_filters( array( 'gform_pre_confirmation_save', $form['id'] ), $confirmation, $form, $is_new_confirmation );
// trim values
$confirmation = GFFormsModel::trim_conditional_logic_values_from_element( $confirmation, $form );
// add current confirmation to confirmations array
$form['confirmations'][ $confirmation['id'] ] = $confirmation;
// save updated confirmations array
$result = GFFormsModel::save_form_confirmations( $form['id'], $form['confirmations'] );
if ( $result !== false ) {
$url = remove_query_arg( array( 'cid', 'duplicatedcid' ) );
GFCommon::add_message( sprintf( __( 'Confirmation saved successfully. %sBack to confirmations.%s', 'gravityforms' ), '<a href="' . esc_url( $url ) . '">', '</a>' ) );
} else {
GFCommon::add_error_message( __( 'There was an issue saving this confirmation.', 'gravityforms' ) );
}
return $confirmation;
}
/**
* Processes actions made from the Confirmations List page.
*
* @since Unknown
* @access public
*
* @used-by GFFormSettings::confirmations_list_page()
* @uses GFFormSettings::delete_confirmation()
* @uses GFCommon::add_message()
* @uses GFCommon::add_error_message()
*
* @return void
*/
public static function maybe_process_confirmation_list_action() {
if ( empty( $_POST ) || ! check_admin_referer( 'gform_confirmation_list_action', 'gform_confirmation_list_action' ) )
return;
$action = rgpost( 'action' );
$object_id = rgpost( 'action_argument' );
switch ( $action ) {
case 'delete':
$confirmation_deleted = self::delete_confirmation( $object_id, rgget( 'id' ) );
if ( $confirmation_deleted ) {
GFCommon::add_message( __( 'Confirmation deleted.', 'gravityforms' ) );
} else {
GFCommon::add_error_message( __( 'There was an issue deleting this confirmation.', 'gravityforms' ) );
}
break;
}
}
/**
* Delete a form confirmation by ID.
*
* @since Unknown
* @access public
*
* @used-by GFFormSettings::maybe_process_confirmation_list_action()
* @used-by GFForms::delete_confirmation()
* @uses GFFormsModel::get_form_meta()
* @uses GFFormsModel::flush_current_forms()
* @uses GFFormsModel::save_form_confirmations()
*
* @param array $confirmation_id The confirmation to be deleted.
* @param int|array $form_id The form ID or Form Object form the confirmation being deleted.
*
* @return mixed The result of the database operation.
*/
public static function delete_confirmation( $confirmation_id, $form_id ) {
if ( ! $form_id )
return false;
$form = ! is_array( $form_id ) ? RGFormsModel::get_form_meta( $form_id ) : $form_id;
/**
* Fires right before a confirmation is deleted.
*
* @since 1.9
*
* @param int $form['confirmations'][$confirmation_id] The ID of the confirmation being deleted.
* @param array $form The Form object.
*/
do_action( 'gform_pre_confirmation_deleted', $form['confirmations'][ $confirmation_id ], $form );
unset( $form['confirmations'][ $confirmation_id ] );
// clear form cache so next retrieval of form meta will reflect deleted notification
RGFormsModel::flush_current_forms();
return RGFormsModel::save_form_confirmations( $form['id'], $form['confirmations'] );
}
/**
* Echos a variable.
*
* @since Unknown
* @access public
*
* @used-by GFNotification::notification_edit_page()
*
* @param string $a Thing to echo.
*
* @return void
*/
public static function output( $a ) {
echo $a;
}
/**
* Checks if a confirmation name is unique.
*
* @since Unknown
* @access public
*
* @used-by GFFormSettings::confirmations_edit_page()
*
* @param string $name The confirmation name to check for.
* @param array $confirmations The confirmations to check through.
*
* @return bool True if unique. False otherwise.
*/
public static function is_unique_name( $name, $confirmations ) {
foreach ( $confirmations as $confirmation ) {
if ( strtolower( rgar( $confirmation, 'name' ) ) == strtolower( $name ) )
return false;
}
return true;
}
/**
* Outputs scripts for conditional logic fields.
*
* @since Unknown
* @access public
*
* @uses GF_Fields::get_all()
* @uses GF_Field::is_conditional_logic_supported()
*
* @param bool $echo If the scripts should be echoed. Defaults to true.
*
* @return string $script_str The scripts to be output.
*/
public static function output_field_scripts( $echo = true ) {
$script_str = '';
$conditional_logic_fields = array();
foreach ( GF_Fields::get_all() as $gf_field ) {
if ( $gf_field->is_conditional_logic_supported() ) {
$conditional_logic_fields[] = $gf_field->type;
}
}
$script_str .= sprintf( 'function GetConditionalLogicFields(){return %s;}', json_encode( $conditional_logic_fields ) ) . PHP_EOL;
if ( ! empty( $script_str ) && $echo ) {
echo $script_str;
}
return $script_str;
}
/**
* Handles the saving of notifications and confirmations when activated.
*
* @since Unknown
* @access public
*
* @used-by GFFormSettings::form_settings_ui()
* @uses GFFormsModel::save_form_notifications()
* @uses GFFormsModel::save_form_confirmations()
*
* @param array $form The Form Object to be saved.
*
* @return array $form The Form Object.
*/
public static function activate_save( $form ) {
$form_id = $form['id'];
$has_save_notification = false;
foreach ( $form['notifications'] as $notification ) {
if ( rgar( $notification, 'event' ) == 'form_save_email_requested' ) {
$has_save_notification = true;
break;
}
}
if ( ! $has_save_notification ) {
$notification_id = uniqid();
$form['notifications'][ $notification_id ] = array(
'id' => $notification_id,
'isDefault' => true,
'name' => __( 'Save and Continue Email', 'gravityforms' ),
'event' => 'form_save_email_requested',
'toType' => 'hidden',
'from' => '{admin_email}',
'subject' => __( 'Link to continue {form_title}' ),
'message' => __( 'Thank you for saving {form_title}. Please use the unique link below to return to the form from any computer. <br /><br /> {save_link} <br /><br /> Remember that the link will expire after 30 days so please return via the provided link to complete your form submission.', 'gravityforms' ),
);
GFFormsModel::save_form_notifications( $form_id, $form['notifications'] );
}
$has_save_confirmation = false;
foreach ( $form['confirmations'] as $confirmation ) {
if ( rgar( $confirmation, 'event' ) == 'form_saved' ) {
$has_save_confirmation = true;
break;
}
}
if ( ! $has_save_confirmation ) {
$confirmation_1 = GFFormsModel::get_default_confirmation( 'form_saved' );
$confirmation_2 = GFFormsModel::get_default_confirmation( 'form_save_email_sent' );
$form['confirmations'][ $confirmation_1['id'] ] = $confirmation_1;
$form['confirmations'][ $confirmation_2['id'] ] = $confirmation_2;
GFFormsModel::save_form_confirmations( $form_id, $form['confirmations'] );
}
return $form;
}
/**
* Handles the saving of confirmation and notifications when deactivating.
*
* @since Unknown
* @access public
*
* @uses GFFormsModel::save_form_notifications()
* @uses GFFormsModel::save_form_confirmations()
*
* @param array $form The Form Object.
*
* @return array $form The Form Object.
*/
public static function deactivate_save( $form ) {
$form_id = $form['id'];
foreach ( $form['notifications'] as $notification_id => $notification ) {
if ( rgar( $notification, 'isDefault' ) && rgar( $notification, 'event' ) == 'form_save_email_requested' ) {
unset( $form['notifications'][ $notification_id ] );
GFFormsModel::save_form_notifications( $form_id, $form['notifications'] );
break;
}
}
$changed = false;
foreach ( $form['confirmations'] as $confirmation_id => $confirmation ) {
$event = rgar( $confirmation, 'event' );
if ( rgar( $confirmation, 'isDefault' ) && ( $event == 'form_saved' || $event == 'form_save_email_sent' ) ) {
unset( $form['confirmations'][ $confirmation_id ] );
$changed = true;
}
}
if ( $changed ) {
GFFormsModel::save_form_confirmations( $form_id, $form['confirmations'] );
}
return $form;
}
/**
* Alias for GFCommon::maybe_wp_kses()
*
* @since Unknown
* @access private
*
* @used-by GFFormSettings::handle_confirmation_edit_submission()
* @uses GFCommon::maybe_wp_kses()
*
* @param string $html The HTML markup to sanitize.
* @param string $allowed_html The allowed HTML content. Defaults to 'post'.
* @param array $allowed_protocols Allowed protocols. Defaults to empty array.
*
* @return string The sanitized HTML markup.
*/
private static function maybe_wp_kses( $html, $allowed_html = 'post', $allowed_protocols = array() ) {
if ( ! current_user_can( 'unfiltered_html' ) ) {
$html = self::remove_unsafe_merge_tags( $html );
}
return GFCommon::maybe_wp_kses( $html, $allowed_html, $allowed_protocols );
}
/**
* Removes merge tags used as HTML attributes.
*
* @since 2.0.7.8
* @access public
*
* @param string $text The confirmation text to check.
*
* @return bool True if unsafe. False if all is good in the world.
*/
public static function remove_unsafe_merge_tags( $text ) {
preg_match_all( '/(\S+)\s*=\s*["|\']({[^{]*?:(\d+(\.\d+)?)(:(.*?))?})["|\']/mi', $text, $matches, PREG_SET_ORDER );
if ( is_array( $matches ) && count( $matches ) > 0 ) {
foreach ( $matches as $match ) {
// Ignore conditional shortcodes
if ( strtolower( $match[1] ) !== 'merge_tag' ) {
// Remove the merge tag
$text = str_replace( $match[0], $match[1] . '=""', $text );
}
}
}
return $text;
}
/**
* Checks the text for merge tags as attribute values.
*
* @since Unknown
* @access public
*
* @used-by GFFormSettings::confirmations_edit_page()
*
* @param string $text The confirmation text to check.
*
* @return bool True if unsafe. False if all is good in the world.
*/
public static function confirmation_looks_unsafe( $text ) {
$unsafe = false;
preg_match_all( '/[\<^]*.(\S+)\s*=\s*["|\']({[^{]*?:(\d+(\.\d+)?)(:(.*?))?})["|\']/mi', $text, $matches, PREG_SET_ORDER );
if ( is_array( $matches ) && count( $matches ) > 0 ) {
foreach ( $matches as $match ) {
if ( strtolower( $match[1] ) !== 'merge_tag' ) {
$unsafe = true;
}
}
}
return $unsafe;
}
/**
* Handles the saving of form titles.
*
* @since Unknown
* @access public
*
* @uses GFAPI::get_form()
* @uses GFAPI::update_form()
*
* @return void
*/
public static function save_form_title() {
check_admin_referer( 'gf_save_title', 'gf_save_title' );
$form_title = json_decode( rgpost( 'title' ) );
$form_id = rgpost( 'formId' );
$result = array( 'isValid' => true, 'message' => '' );
if ( empty( $form_title ) ) {
$result['isValid'] = false;
$result['message'] = __( 'Please enter a form title.', 'gravityforms' );
} elseif ( ! GFFormsModel::is_unique_title( $form_title, $form_id ) ) {
$result['isValid'] = false;
$result['message'] = __( 'Please enter a unique form title.', 'gravityforms' );
} else {
$form = GFAPI::get_form( $form_id );
$form['title'] = $form_title;
GFAPI::update_form( $form, $form_id );
}
die( json_encode( $result ) );
}
}
// Include WP_List_Table.
require_once( ABSPATH . '/wp-admin/includes/class-wp-list-table.php' );
/**
* Class GFConfirmationTable
*
* Handles the creation of a list table for displaying the confirmations listing.
*
* @since Unknown
*
* @used-by GFFormSettings::confirmations_list_page()
* @uses WP_List_Table
*
* @param array $form The form to display the confirmation listing for.
*/
class GFConfirmationTable extends WP_List_Table {
/**
* @since Unknown
* @access public
*
* @var array The Form Object to get confirmations from.
*/
public $form;
/**
* GFConfirmationTable constructor.
*
* @since Unknown
* @access public
*
* @uses GFConfirmationTable::$form
* @uses WP_List_Table::$_column_headers
* @uses WP_List_Table::__construct()
*
* @param array $form The Form Object to display the confirmation listing for.
*/
function __construct( $form ) {
$this->form = $form;
$this->_column_headers = array(
array(
'cb' => '',
'name' => __( 'Name', 'gravityforms' ),
'type' => __( 'Type', 'gravityforms' ),
'content' => __( 'Content', 'gravityforms' )
),
array(),
array( 'name' => array( 'name', false ) ),
'name',
);
parent::__construct();
}
/**
* Prepares the confirmation items.
*
* @since Unknown
* @access public
*
* @used-by GFFormSettings::confirmations_list_page()
* @uses WP_List_Table::$items
* @uses GFConfirmationTable::$form
*
* @return void
*/
function prepare_items() {
$this->items = $this->form['confirmations'];
switch ( rgget( 'orderby' ) ) {
case 'name':
// Sort confirmations alphabetically.
usort( $this->items, array( $this, 'sort_confirmations' ) );
// Reverse sort.
if ( 'desc' === rgget( 'order' ) ) {
$this->items = array_reverse( $this->items );
}
break;
default:
break;
}
}
/**
* Sort confirmations alphabetically.
*
* @since 2.4
* @access public
*
* @param array $a First confirmation to compare.
* @param array $b Second confirmation to compare.
*
* @return int
*/
function sort_confirmations( $a = array(), $b = array() ) {
return strcasecmp( $a['name'], $b['name'] );
}
/**
* Displays the list table.
*
* @since Unknown
* @access public
*
* @used-by GFFormSettings::confirmations_list_page()
* @uses WP_List_Table::get_table_classes()
* @uses WP_List_Table::print_column_headers()
* @uses WP_List_Table::display_rows_or_placeholder()
*
* @return void
*/
function display() {
$singular = rgar( $this->_args, 'singular' );
?>
<table class="wp-list-table <?php echo implode( ' ', $this->get_table_classes() ); ?>" cellspacing="0">
<thead>
<tr>
<?php $this->print_column_headers(); ?>
</tr>
</thead>
<tfoot>
<tr>
<?php $this->print_column_headers( false ); ?>
</tr>
</tfoot>
<tbody id="the-list"<?php if ( $singular )
echo " class='list:$singular'"; ?>>
<?php $this->display_rows_or_placeholder(); ?>
</tbody>
</table>
<?php
}
/**
* Displays a single list table row.
*
* @since Unknown
* @access public
*
* @used-by WP_List_Table::display_rows()
* @uses WP_List_Table::single_row_columns()
*
* @param array $item The row item.
*
* @return void
*/
function single_row( $item ) {
static $row_class = '';
$row_class = ( $row_class == '' ? ' class="alternate"' : '' );
echo '<tr id="confirmation-' . $item['id'] . '" ' . $row_class . '>';
echo $this->single_row_columns( $item );
echo '</tr>';
}
/**
* Gets the list table column headers.
*
* @since Unknown
* @access public
*
* @used-by WP_List_Table::get_default_primary_column_name()
* @uses WP_List_Table::$_column_headers
*
* @return string The primary column header.
*/
function get_columns() {
return $this->_column_headers[0];
}
/**
* Gets the column content.
*
* @since Unknown
* @access public
*
* @uses GFConfirmationTable::get_column_content()
*
* @param array $item The column item to process.
*
* @return string The column content HTML markup.
*/
function column_content( $item ) {
return self::get_column_content( $item );
}
/**
* Sets the default column data.
*
* @since Unknown
* @access public
*
* @used-by WP_List_Table::single_row_columns()
*
* @param object $item The column item.
* @param string $column The column name.
*
* @return void
*/
function column_default( $item, $column ) {
echo rgar( $item, $column );
}
/**
* Sets the column type.
*
* @since Unknown
* @access public
*
* @uses GFConfirmationTable::get_column_type()
*
* @param object $item The column item.
*
* @return string The column type.
*/
function column_type( $item ) {
return self::get_column_type( $item );
}
/**
* Handles the activation/deactivation button on confirmation list table items.
*
* @since Unknown
* @access public
*
* @used-by WP_List_Table::single_row_columns()
* @uses GFCommon::get_base_url()
*
* @param object $item The list table item.
*
* @return void
*/
function column_cb( $item ) {
if ( isset( $item['isDefault'] ) && $item['isDefault'] )
return;
$is_active = isset( $item['isActive'] ) ? $item['isActive'] : true;
?>
<img src="<?php echo GFCommon::get_base_url() ?>/images/active<?php echo intval( $is_active ) ?>.png" style="cursor: pointer;margin:-5px 0 0 8px;" alt="<?php $is_active ? __( 'Active', 'gravityforms' ) : __( 'Inactive', 'gravityforms' ); ?>" title="<?php echo $is_active ? __( 'Active', 'gravityforms' ) : __( 'Inactive', 'gravityforms' ); ?>" onclick="ToggleActive(this, '<?php echo $item['id'] ?>'); " onkeypress="ToggleActive(this, '<?php echo $item['id'] ?>'); " />
<?php
}
/**
* Displays the available confirmation list item actions.
*
* @since Unknown
* @access public
*
* @param object $item The list table column item.
*
* @return void
*/
function column_name( $item ) {
$edit_url = add_query_arg( array( 'cid' => $item['id'] ) );
$duplicate_url = add_query_arg( array( 'cid' => 0, 'duplicatedcid' => $item['id'] ) );
$actions = apply_filters(
'gform_confirmation_actions', array(
'edit' => '<a href="' . esc_url( $edit_url ) . '">' . __( 'Edit', 'gravityforms' ) . '</a>',
'duplicate' => '<a href="' . esc_url( $duplicate_url ) . '">' . __( 'Duplicate', 'gravityforms' ) . '</a>',
'delete' => '<a class="submitdelete" onclick="javascript: if(confirm(\'' . __( 'WARNING: You are about to delete this confirmation.', 'gravityforms' ) . __( "\'Cancel\' to stop, \'OK\' to delete.", 'gravityforms' ) . '\')){ DeleteConfirmation(\'' . esc_js( $item['id'] ) . '\'); }" onkeypress="javascript: if(confirm(\'' . __( 'WARNING: You are about to delete this confirmation.', 'gravityforms' ) . __( "\'Cancel\' to stop, \'OK\' to delete.", 'gravityforms' ) . '\')){ DeleteConfirmation(\'' . esc_js( $item['id'] ) . '\'); }" style="cursor:pointer;">' . __( 'Delete', 'gravityforms' ) . '</a>'
)
);
if ( isset( $item['isDefault'] ) && $item['isDefault'] ){
unset( $actions['delete'] );
}
?>
<a href="<?php echo esc_url( $edit_url ); ?>"><strong><?php echo esc_html( rgar( $item, 'name' ) ); ?></strong></a>
<div class="row-actions">
<?php
if ( is_array( $actions ) && ! empty( $actions ) ) {
$keys = array_keys( $actions );
$last_key = array_pop( $keys );
foreach ( $actions as $key => $html ) {
$divider = $key == $last_key ? '' : ' | ';
?>
<span class="<?php echo $key; ?>">
<?php echo $html . $divider; ?>
</span>
<?php
}
}
?>
</div>
<?php
}
/**
* Displays the confirmations list item column content.
*
* @since Unknown
* @access public
*
* @param object $item The list item.
*
* @return string The HTML markup for the column content.
*/
public static function get_column_content( $item ) {
switch ( rgar( $item, 'type' ) ) {
case 'message':
return '<a class="limit-text">' . wp_kses_post( $item['message'] ) . '</a>';
case 'page':
$page = get_post( $item['pageId'] );
if ( empty( $page ) ) {
return __( '<em>This page does not exist.</em>', 'gravityforms' );
}
return '<a href="' . get_permalink( $item['pageId'] ) . '">' . esc_html( $page->post_title ) . '</a>';
case 'redirect':
$url_pieces = parse_url( $item['url'] );
$url_connector = rgar( $url_pieces, 'query' ) ? '&' : '?';
$url = rgar( $item, 'queryString' ) ? "{$item['url']}{$url_connector}{$item['queryString']}" : $item['url'];
$url = esc_url( $url );
return '<a class="limit-text">' . $url . '</a>';
}
return '';
}
/**
* Gets the column type.
*
* @since Unknwon
* @access public
*
* @used-by GFConfirmationTable::column_type()
*
* @param object $item The column item.
*
* @return string The column item type. If none found, empty string. Escaped.
*/
public static function get_column_type( $item ) {
switch ( rgar( $item, 'type' ) ) {
case 'message':
return __( 'Text', 'gravityforms' );
case 'page':
return __( 'Page', 'gravityforms' );
case 'redirect':
return __( 'Redirect', 'gravityforms' );
}
return '';
}
}