/* globals wp_mail_smtp, jconfirm, ajaxurl */ 'use strict'; var WPMailSMTP = window.WPMailSMTP || {}; WPMailSMTP.Admin = WPMailSMTP.Admin || {}; /** * WP Mail SMTP Admin area module. * * @since 1.6.0 */ WPMailSMTP.Admin.Settings = WPMailSMTP.Admin.Settings || ( function( document, window, $ ) { /** * Public functions and properties. * * @since 1.6.0 * * @type {object} */ var app = { /** * State attribute showing if one of the plugin settings * changed and was not yet saved. * * @since 1.9.0 * * @type {boolean} */ pluginSettingsChanged: false, /** * Start the engine. DOM is not ready yet, use only to init something. * * @since 1.6.0 */ init: function() { // Do that when DOM is ready. $( app.ready ); }, /** * DOM is fully loaded. * * @since 1.6.0 */ ready: function() { app.pageHolder = $( '.wp-mail-smtp-tab-settings' ); app.settingsForm = $( '.wp-mail-smtp-connection-settings-form' ); // If there are screen options we have to move them. $( '#screen-meta-links, #screen-meta' ).prependTo( '#wp-mail-smtp-header-temp' ).show(); app.bindActions(); app.setJQueryConfirmDefaults(); // Flyout Menu. app.initFlyoutMenu(); }, /** * Process all generic actions/events, mostly custom that were fired by our API. * * @since 1.6.0 */ bindActions: function() { // Mailer selection. $( '.wp-mail-smtp-mailer-image', app.settingsForm ).on( 'click', function() { $( this ).parents( '.wp-mail-smtp-mailer' ).find( 'input' ).trigger( 'click' ); } ); $( '.wp-mail-smtp-mailer input', app.settingsForm ).on( 'click', function() { var $input = $( this ); if ( $input.prop( 'disabled' ) ) { // Educational Popup. if ( $input.hasClass( 'educate' ) ) { app.education.upgradeMailer( $input ); } return false; } // Deselect the current mailer. $( '.wp-mail-smtp-mailer', app.settingsForm ).removeClass( 'active' ); // Select the correct one. $( this ).parents( '.wp-mail-smtp-mailer' ).addClass( 'active' ); // Hide all mailers options and display for a currently clicked one. $( '.wp-mail-smtp-mailer-option', app.settingsForm ).addClass( 'hidden' ).removeClass( 'active' ); $( '.wp-mail-smtp-mailer-option-' + $( this ).val(), app.settingsForm ).addClass( 'active' ).removeClass( 'hidden' ); } ); app.mailers.smtp.bindActions(); // Dismiss Pro banner at the bottom of the page. $( '#wp-mail-smtp-pro-banner-dismiss', app.pageHolder ).on( 'click', function() { $.ajax( { url: ajaxurl, dataType: 'json', type: 'POST', data: { action: 'wp_mail_smtp_ajax', task: 'pro_banner_dismiss', nonce: wp_mail_smtp.nonce } } ) .always( function() { $( '#wp-mail-smtp-pro-banner', app.pageHolder ).fadeOut( 'fast' ); } ); } ); // Dissmis educational notices for certain mailers. $( '.js-wp-mail-smtp-mailer-notice-dismiss', app.settingsForm ).on( 'click', function( e ) { e.preventDefault(); var $btn = $( this ), $notice = $btn.parents( '.inline-notice' ); if ( $btn.hasClass( 'disabled' ) ) { return false; } $.ajax( { url: ajaxurl, dataType: 'json', type: 'POST', data: { action: 'wp_mail_smtp_ajax', nonce: wp_mail_smtp.nonce, task: 'notice_dismiss', notice: $notice.data( 'notice' ), mailer: $notice.data( 'mailer' ) }, beforeSend: function() { $btn.addClass( 'disabled' ); } } ) .always( function() { $notice.fadeOut( 'fast', function() { $btn.removeClass( 'disabled' ); } ); } ); } ); // Show/hide debug output. $( '#wp-mail-smtp-debug .error-log-toggle' ).on( 'click', function( e ) { e.preventDefault(); $( '#wp-mail-smtp-debug .error-log' ).slideToggle(); } ); // Copy debug output to clipboard. $( '#wp-mail-smtp-debug .error-log-copy' ).on( 'click', function( e ) { e.preventDefault(); var $self = $( this ); // Get error log. var $content = $( '#wp-mail-smtp-debug .error-log' ); // Copy to clipboard. if ( ! $content.is( ':visible' ) ) { $content.addClass( 'error-log-selection' ); } var range = document.createRange(); range.selectNode( $content[0] ); window.getSelection().removeAllRanges(); window.getSelection().addRange( range ); document.execCommand( 'Copy' ); window.getSelection().removeAllRanges(); $content.removeClass( 'error-log-selection' ); $self.addClass( 'error-log-copy-copied' ); setTimeout( function() { $self.removeClass( 'error-log-copy-copied' ); }, 1500 ); } ); // Remove mailer connection. $( '.js-wp-mail-smtp-provider-remove', app.settingsForm ).on( 'click', function() { return confirm( wp_mail_smtp.text_provider_remove ); } ); // Copy input text to clipboard. $( '.wp-mail-smtp-setting-copy', app.settingsForm ).on( 'click', function( e ) { e.preventDefault(); var target = $( '#' + $( this ).data( 'source_id' ) ).get( 0 ); target.select(); document.execCommand( 'Copy' ); var $buttonIcon = $( this ).find( '.dashicons' ); $buttonIcon .removeClass( 'dashicons-admin-page' ) .addClass( 'wp-mail-smtp-dashicons-yes-alt-green wp-mail-smtp-success wp-mail-smtp-animate' ); setTimeout( function() { $buttonIcon .removeClass( 'wp-mail-smtp-dashicons-yes-alt-green wp-mail-smtp-success wp-mail-smtp-animate' ) .addClass( 'dashicons-admin-page' ); }, 1000 ); } ); // Notice bar: click on the dissmiss button. $( '#wp-mail-smtp-notice-bar' ).on( 'click', '.dismiss', function() { var $notice = $( this ).closest( '#wp-mail-smtp-notice-bar' ); $notice.addClass( 'out' ); setTimeout( function() { $notice.remove(); }, 300 ); $.post( ajaxurl, { action: 'wp_mail_smtp_notice_bar_dismiss', nonce: wp_mail_smtp.nonce, } ); } ); app.triggerExitNotice(); app.beforeSaveChecks(); // Register change event to show/hide plugin supported settings for currently selected mailer. $( '.js-wp-mail-smtp-setting-mailer-radio-input', app.settingsForm ).on( 'change', this.processMailerSettingsOnChange ); // Disable multiple click on the Email Test tab submit button and display a loader icon. $( '.wp-mail-smtp-tab-tools-test #email-test-form' ).on( 'submit', function() { var $button = $( this ).find( '.wp-mail-smtp-btn' ); $button.attr( 'disabled', true ); $button.find( 'span' ).hide(); $button.find( '.wp-mail-smtp-loading' ).show(); } ); $( '.email_test_tab_removal_notice' ).on( 'click', '.notice-dismiss', function() { var $button = $( this ); $.ajax( { url: ajaxurl, dataType: 'json', type: 'POST', data: { action: 'wp_mail_smtp_ajax', nonce: wp_mail_smtp.nonce, task: 'email_test_tab_removal_notice_dismiss', }, beforeSend: function() { $button.prop( 'disabled', true ); }, } ); } ); $( '#wp-mail-smtp-setting-gmail-one_click_setup_enabled-lite' ).on( 'click', function( e ) { e.preventDefault(); app.education.gmailOneClickSetupUpgrade(); } ); }, education: { upgradeMailer: function( $input ) { var mailerName = $input.data( 'title' ).trim(); app.education.upgradeModal( wp_mail_smtp.education.upgrade_title.replace( /%name%/g, mailerName ), wp_mail_smtp.education.upgrade_content.replace( /%name%/g, mailerName ), $input.val() ); }, gmailOneClickSetupUpgrade: function() { app.education.upgradeModal( wp_mail_smtp.education.gmail.one_click_setup_upgrade_title, wp_mail_smtp.education.gmail.one_click_setup_upgrade_content, 'gmail-one-click-setup' ); }, upgradeModal: function( title, content, upgradeUrlUtmContent ) { $.alert( { backgroundDismiss: true, escapeKey: true, animationBounce: 1, type: 'blue', closeIcon: true, title: title, icon: '">' + wp_mail_smtp.education.upgrade_icon_lock + '' + wp_mail_smtp.education.upgrade_bonus + wp_mail_smtp.education.upgrade_doc + '' ); this.$body.addClass( 'wp-mail-smtp-upgrade-mailer-education-modal' ); }, buttons: { confirm: { text: wp_mail_smtp.education.upgrade_button, btnClass: 'btn-confirm', keys: [ 'enter' ], action: function() { var appendChar = /(\?)/.test( wp_mail_smtp.education.upgrade_url ) ? '&' : '?', upgradeURL = wp_mail_smtp.education.upgrade_url + appendChar + 'utm_content=' + encodeURIComponent( upgradeUrlUtmContent ); window.open( upgradeURL, '_blank' ); } } } } ); } }, /** * Individual mailers specific js code. * * @since 1.6.0 */ mailers: { smtp: { bindActions: function() { // Hide SMTP-specific user/pass when Auth disabled. $( '#wp-mail-smtp-setting-smtp-auth' ).on( 'change', function() { $( '#wp-mail-smtp-setting-row-smtp-user, #wp-mail-smtp-setting-row-smtp-pass' ).toggleClass( 'inactive' ); } ); // Port default values based on encryption type. $( '#wp-mail-smtp-setting-row-smtp-encryption input' ).on( 'change', function() { var $input = $( this ), $smtpPort = $( '#wp-mail-smtp-setting-smtp-port', app.settingsForm ); if ( 'tls' === $input.val() ) { $smtpPort.val( '587' ); $( '#wp-mail-smtp-setting-row-smtp-autotls' ).addClass( 'inactive' ); } else if ( 'ssl' === $input.val() ) { $smtpPort.val( '465' ); $( '#wp-mail-smtp-setting-row-smtp-autotls' ).removeClass( 'inactive' ); } else { $smtpPort.val( '25' ); $( '#wp-mail-smtp-setting-row-smtp-autotls' ).removeClass( 'inactive' ); } } ); } } }, /** * Exit notice JS code when plugin settings are not saved. * * @since 1.9.0 */ triggerExitNotice: function() { var $settingPages = $( '.wp-mail-smtp-page-general' ); // Display an exit notice, if settings are not saved. $( window ).on( 'beforeunload', function() { if ( app.pluginSettingsChanged ) { return wp_mail_smtp.text_settings_not_saved; } } ); // Set settings changed attribute, if any input was changed. $( ':input:not( #wp-mail-smtp-setting-license-key, .wp-mail-smtp-not-form-input, #wp-mail-smtp-setting-gmail-one_click_setup_enabled )', $settingPages ).on( 'change', function() { app.pluginSettingsChanged = true; } ); // Clear the settings changed attribute, if the settings are about to be saved. $( 'form', $settingPages ).on( 'submit', function() { app.pluginSettingsChanged = false; } ); }, /** * Perform any checks before the settings are saved. * * Checks: * - warn users if they try to save the settings with the default (PHP) mailer selected. * * @since 2.1.0 */ beforeSaveChecks: function() { app.settingsForm.on( 'submit', function() { if ( $( '.wp-mail-smtp-mailer input:checked', app.settingsForm ).val() === 'mail' ) { var $thisForm = $( this ); $.alert( { backgroundDismiss: false, escapeKey: false, animationBounce: 1, type: 'orange', icon: '">' + wp_mail_smtp.default_mailer_notice.icon_alt + ' 0 ? $overlap.offset().top + $overlap.height() + 85 : 0, viewTop = $( window ).scrollTop(), viewBottom = viewTop + $( window ).height(); if ( wpfooterBottom <= viewBottom && wpfooterTop >= viewTop && overlapBottom > viewBottom ) { $flyoutMenu.addClass( 'out' ); } else { $flyoutMenu.removeClass( 'out' ); } }, 50 ) ); $( window ).trigger( 'scroll' ); } }; // Provide access to public functions/properties. return app; }( document, window, jQuery ) ); // Initialize. WPMailSMTP.Admin.Settings.init();