XylotrechusZ
<?php if (!defined('FW')) die('Forbidden');
/**
* @see FW_Settings_Form::_form_render()
* @var FW_Settings_Form $form
* @var array $values
* @var string $input_name_reset
* @var string $input_name_save
* @var string $js_form_selector Form CSS selector safe to be used in js (js escaped)
* @var bool $is_theme_settings Backwards compatibility with old Theme Settings hooks
*/
?>
<?php if ($form->get_is_side_tabs()): ?>
<div class="fw-settings-form-header fw-row">
<div class="fw-col-xs-12 fw-col-sm-6">
<h2><?php echo $form->get_string('title'); ?></h2>
</div>
<div class="fw-col-xs-12 fw-col-sm-6">
<div class="form-header-buttons">
<?php
/**
* Make sure firs submit button is Save button
* because the first button is "clicked" when you press enter in some input
* and the form is submitted.
* So to prevent form Reset on input Enter, make Save button first in html
*/
echo fw_html_tag('input', array(
'type' => 'submit',
'name' => $input_name_save,
'class' => 'fw-hidden',
));
?>
<?php
echo implode(
'<i class="submit-button-separator"></i>',
apply_filters(
$is_theme_settings
? 'fw_settings_form_header_buttons'
: 'fw:settings-form:'. $form->get_id() .':side-tabs:header-buttons',
array(
fw_html_tag('input', array(
'type' => 'submit',
'name' => $input_name_reset,
'value' => $form->get_string('reset_button'),
'class' => 'button-secondary button-large submit-button-reset fw-settings-form-reset-btn',
)),
fw_html_tag('input', array(
'type' => 'submit',
'name' => $input_name_save,
'value' => $form->get_string('save_button'),
'class' => 'button-primary button-large submit-button-save',
))
)
)
);
?>
</div>
</div>
</div>
<script type="text/javascript">
jQuery(function($){
fwEvents.one('fw:options:init', function(data){
$('<?php echo $js_form_selector ?>').on(
'fw:settings-form:reset fw:settings-form:init-header',
function(){
$(this).find('.fw-settings-form-header:not(.initialized)').addClass('initialized');
}
).trigger('fw:settings-form:init-header');
});
});
</script>
<?php endif; ?>
<?php echo fw()->backend->render_options($form->get_options(), $values); ?>
<div class="form-footer-buttons">
<!-- This div is required to follow after options in order to have special styles in case options will contain tabs (css adjacent selector + ) -->
<?php echo implode(
$form->get_is_side_tabs() ? ' ' : ' ',
apply_filters(
$is_theme_settings
? 'fw_settings_form_footer_buttons'
: 'fw:settings-form:'. $form->get_id() .':side-tabs:footer-buttons',
array(
fw_html_tag('input', array(
'type' => 'submit',
'name' => $input_name_save,
'value' => $form->get_string('save_button'),
'class' => 'button-primary button-large',
)),
fw_html_tag('input', array(
'type' => 'submit',
'name' => $input_name_reset,
'value' => $form->get_string('reset_button'),
'class' => 'button-secondary button-large fw-settings-form-reset-btn',
))
)
)
); ?>
</div>
<!-- reset warning -->
<script type="text/javascript">
jQuery( function ( $ ) {
$( document.body ).on(
'click.fw-settings-form-reset-warning',
'<?php echo $js_form_selector ?> input[name="<?php echo esc_js( $input_name_reset ) ?>"]',
function ( e ) {
/**
* on confirm() the submit input looses focus
* fwForm.isAdminPage() must be able to select the input to send it in _POST
* so use alternative solution http://stackoverflow.com/a/5721762
*/
$( this ).closest( 'form' ).find( '[clicked]:submit' ).removeAttr( 'clicked' );
$( this ).attr( 'clicked', '' );
var resetWarning = '<?php echo esc_js( $form->get_string( 'reset_warning' ) ); ?>',
data = { 'reset_warning': resetWarning };
if ( ! confirm( resetWarning ) ) {
e.preventDefault();
$( document.body ).trigger( 'fw:settings-form:cancel-reset', data );
$( this ).removeAttr( 'clicked' );
} else {
$( document.body ).trigger( 'fw:settings-form:before-reset', data );
}
}
);
} );
</script>
<!-- end: reset warning -->
<script type="text/javascript">
jQuery(function($){
var $form = $('<?php echo $js_form_selector ?>:first'),
timeoutId = 0;
$form.on('change.fw_settings_form_delayed_change', function(){
clearTimeout(timeoutId);
/**
* Run on timeout to prevent too often trigger (and cpu load) when a bunch of changes will happen at once
*/
timeoutId = setTimeout(function () {
$form.trigger('fw:settings-form:delayed-change');
}, 333);
});
});
</script>
<?php if ($form->get_is_ajax_submit()): ?>
<!-- ajax submit -->
<div id="fw-settings-form-ajax-save-extra-message"
data-html="<?php echo fw_htmlspecialchars(apply_filters(
$is_theme_settings
? 'fw_settings_form_ajax_save_loading_extra_message'
: 'fw:settings-form:'. $form->get_id() .':ajax-submit:extra-message',
''
)) ?>"></div>
<script type="text/javascript">
jQuery(function ($) {
function isReset($submitButton) {
return $submitButton.length && $submitButton.attr('name') == '<?php echo esc_js($input_name_reset) ?>';
}
var formSelector = '<?php echo $js_form_selector ?>',
loadingExtraMessage = $('#fw-settings-form-ajax-save-extra-message').attr('data-html'),
loadingModalId = 'fw-options-ajax-save-loading';
$(formSelector).addClass('prevent-all-tabs-init'); // fixes https://github.com/ThemeFuse/Unyson/issues/1491
fwForm.initAjaxSubmit({
selector: formSelector,
loading: function(elements, show) {
if (show) {
var title, description;
if (isReset(elements.$submitButton)) {
title = '<?php echo esc_js(__('Resetting', 'fw')) ?>';
description =
'<?php echo esc_js(__('We are currently resetting your settings.', 'fw')) ?>'+
'<br/>'+
'<?php echo esc_js(__('This may take a few moments.', 'fw')) ?>';
} else {
title = '<?php echo esc_js(__('Saving', 'fw')) ?>';
description =
'<?php echo esc_js(__('We are currently saving your settings.', 'fw')) ?>'+
'<br/>'+
'<?php echo esc_js(__('This may take a few moments.', 'fw')); ?>';
}
fw.soleModal.show(
loadingModalId,
'<h2 class="fw-text-muted">'+
'<img src="" alt="Loading" class="wp-spinner" /> '+
title +
'</h2>'+
'<p class="fw-text-muted"><em>'+ description +'</em></p>'+ loadingExtraMessage,
{
autoHide: 60000,
allowClose: false
}
);
return 500; // fixes https://github.com/ThemeFuse/Unyson/issues/1491
} else {
// fw.soleModal.hide(loadingModalId); // we need to show loading until the form reset ajax will finish
}
},
afterSubmitDelay: function (elements) {
fwEvents.trigger('fw:options:init:tabs', {$elements: elements.$form});
},
onErrors: function( elements, data ) {
var message = $.map( data.errors, function( mssg ) { return '<p class="fw-text-danger">' + mssg + '</p>' } ) + fw.soleModal.renderFlashMessages( data.flash_messages );
fw.soleModal.hide( loadingModalId );
fw.soleModal.show(
'fw-options-ajax-save-error',
'<p class="fw-text-danger">' + message + '</p>'
);
},
onAjaxError: function(elements, data) {
{
var message = String(data.errorThrown);
if (data.jqXHR.responseText && data.jqXHR.responseText.indexOf('Fatal error') > -1) {
message = $(data.jqXHR.responseText).text().split(' in ').shift();
}
}
fw.soleModal.hide(loadingModalId);
fw.soleModal.show(
'fw-options-ajax-save-error',
'<p class="fw-text-danger">'+ message +'</p>'
);
},
onSuccess: function(elements, ajaxData) {
/**
* Display messages
*/
do {
/**
* Don't display the "Settings successfully saved" message
* users will click often on the Save button, it's obvious it was saved if no error is shown.
*/
delete ajaxData.flash_messages.success.fw_settings_form_save;
if (
_.isEmpty(ajaxData.flash_messages.error)
&&
_.isEmpty(ajaxData.flash_messages.warning)
&&
_.isEmpty(ajaxData.flash_messages.info)
&&
_.isEmpty(ajaxData.flash_messages.success)
) {
// no messages to display
break;
}
var noErrors = _.isEmpty(ajaxData.flash_messages.error) && _.isEmpty(ajaxData.flash_messages.warning);
// remove success messages, do not make user wait
ajaxData.flash_messages = _.omit(ajaxData.flash_messages, 'success');
var modalHtml = fw.soleModal.renderFlashMessages(ajaxData.flash_messages);
if (modalHtml.length) {
fw.soleModal.show(
'fw-options-ajax-save-success',
'<div style="margin: 0 35px;">' + modalHtml + '</div>',
{
autoHide: noErrors
? 1000 // hide fast the message if everything went fine
: 10000,
showCloseButton: false,
hidePrevious: noErrors ? false : true // close and open popup when there are errors
}
);
} else {
fw.soleModal.hide('fw-options-ajax-save-success');
}
} while(false);
/**
* Refresh form html on Reset
*/
if (isReset(elements.$submitButton)) {
jQuery.ajax({
type: "GET",
dataType: 'text'
}).done(function(html){
fw.soleModal.hide(loadingModalId);
var $form = jQuery(formSelector, html);
html = undefined; // not needed anymore
if (!$form.length) {
alert('Can\'t find the form in the ajax response');
return;
}
// waitSoleModalFadeOut -> formFadeOut -> formReplace -> formFadeIn
setTimeout(function(){
elements.$form.css('transition', 'opacity ease .3s');
elements.$form.css('opacity', '0');
elements.$form.trigger('fw:settings-form:before-html-reset');
fwEvents.trigger('fw:options:teardown', {$elements: elements.$form});
setTimeout(function() {
var scrollTop = jQuery(window).scrollTop();
// replace form html
{
elements.$form.css({
'display': 'block',
'height': elements.$form.height() +'px'
});
elements.$form.get(0).innerHTML = $form.get(0).innerHTML;
$form = undefined; // not needed anymore
elements.$form.css({
'display': '',
'height': ''
});
}
fwEvents.trigger('fw:options:init', {$elements: elements.$form});
jQuery(window).scrollTop(scrollTop);
// fadeIn
{
elements.$form.css('opacity', '');
setTimeout(function(){
elements.$form.css('transition', '');
elements.$form.css('visibility', '');
}, 300);
}
elements.$form.trigger('fw:settings-form:reset');
}, 300);
}, 300);
}).fail(function(jqXHR, textStatus, errorThrown){
fw.soleModal.hide(loadingModalId);
elements.$form.css({
'opacity': '',
'transition': '',
'visibility': ''
});
console.error(jqXHR, textStatus, errorThrown);
alert('Ajax error (more details in console)');
});
} else {
fw.soleModal.hide(loadingModalId);
elements.$form.trigger('fw:settings-form:saved');
}
}
});
});
</script>
<!-- end: ajax submit -->
<?php endif; ?>
<?php if (
$form->get_is_side_tabs()
&&
apply_filters(
$is_theme_settings
? 'fw:settings-form:side-tabs:open-all-boxes'
: 'fw:settings-form:'. $form->get_id() .':side-tabs:open-all-boxes',
true
)
): ?>
<!-- open all postboxes -->
<script type="text/javascript">
jQuery(function ($) {
var execTimeoutId = 0;
fwEvents.on('fw:options:init', function(data){
// use timeout to be executed after the script from backend-options.js
clearTimeout(execTimeoutId);
execTimeoutId = setTimeout(function(){
// undo not first boxes auto close
data.$elements.find(
'<?php echo $js_form_selector ?> .fw-backend-postboxes > .fw-postbox:not(:first-child)'
).removeClass('closed');
}, 10);
});
});
</script>
<?php endif; ?>
<?php if (!empty($_GET['_focus_tab'])): ?>
<script type="text/javascript">
jQuery(function($){
fwEvents.one('fw:options:init', function(){
setTimeout(function(){
$('<?php echo $js_form_selector ?> a[href="#<?php echo esc_js($_GET['_focus_tab']); ?>"]')
.trigger('click');
}, 90);
});
});
</script>
<?php endif; ?>
<?php do_action(
$is_theme_settings
? 'fw_settings_form_footer'
: 'fw:settings-form:'. $form->get_id() .':footer'
); ?>