( function( $ ) { 'use strict'; if ( typeof wp3cxc2c === 'undefined' || wp3cxc2c === null ) { return; } $( function() { $( '#clicktotalk-form-editor' ).tabs( { active: wp3cxc2c.activeTab, activate: function( event, ui ) { $( '#active-tab' ).val( ui.newTab.index() ); } } ); $( '#clicktotalk-form-editor-tabs' ).focusin( function( event ) { $( '#clicktotalk-form-editor .keyboard-interaction' ).css( 'visibility', 'visible' ); } ).focusout( function( event ) { $( '#clicktotalk-form-editor .keyboard-interaction' ).css( 'visibility', 'hidden' ); } ); if ( '' === $( '#title' ).val() ) { $( '#title' ).focus(); } wp3cxc2c.titleHint(); $( '.clicktotalk-form-editor-box-mail span.mailtag' ).click( function( event ) { var range = document.createRange(); range.selectNodeContents( this ); window.getSelection().addRange( range ); } ); wp3cxc2c.updateConfigErrors(); $( '[data-config-field]' ).change( function() { var postId = $( '#post_ID' ).val(); if ( ! postId || -1 == postId ) { return; } var data = []; $( this ).closest( 'form' ).find( '[data-config-field]' ).each( function() { data.push( { 'name': $( this ).attr( 'name' ).replace( /^wp3cxc2c-/, '' ).replace( /-/g, '_' ), 'value': $( this ).val() } ); } ); data.push( { 'name': 'context', 'value': 'dry-run' } ); $.ajax( { method: 'POST', url: wp3cxc2c.apiSettings.getRoute( '/clicktotalk-forms/' + postId ), beforeSend: function( xhr ) { xhr.setRequestHeader( 'X-WP-Nonce', wp3cxc2c.apiSettings.nonce ); }, data: data } ).done( function( response ) { wp3cxc2c.configValidator.errors = response.config_errors; wp3cxc2c.updateConfigErrors(); } ); } ); $( window ).on( 'beforeunload', function( event ) { var changed = false; $( '#wp3cxc2c-admin-form-element :input[type!="hidden"]' ).each( function() { if ( $( this ).is( ':checkbox, :radio' ) ) { if ( this.defaultChecked != $( this ).is( ':checked' ) ) { changed = true; } } else if ( $( this ).is( 'select' ) ) { $( this ).find( 'option' ).each( function() { if ( this.defaultSelected != $( this ).is( ':selected' ) ) { changed = true; } } ); } else { if ( this.defaultValue != $( this ).val() ) { changed = true; } } } ); if ( changed ) { event.returnValue = wp3cxc2c.saveAlert; return wp3cxc2c.saveAlert; } } ); $( '#wp3cxc2c-admin-form-element' ).submit( function() { if ( 'copy' != this.action.value ) { $( window ).off( 'beforeunload' ); } if ( 'save' == this.action.value ) { $( '#publishing-action .spinner' ).addClass( 'is-active' ); } } ); } ); wp3cxc2c.updateConfigErrors = function() { var errors = wp3cxc2c.configValidator.errors; var errorCount = { total: 0 }; $( '[data-config-field]' ).each( function() { $( this ).removeAttr( 'aria-invalid' ); $( this ).next( 'ul.config-error' ).remove(); var section = $( this ).attr( 'data-config-field' ); if ( errors[ section ] ) { var $list = $( '' ).attr( { 'role': 'alert', 'class': 'config-error' } ); $.each( errors[ section ], function( i, val ) { var $li = $( '
  • ' ).append( $( '' ) ).append( $( '' ).text( wp3cxc2c.configValidator.iconAlt ) ).append( ' ' ); if ( val.link ) { $li.append( $( '' ).attr( 'href', val.link ).text( val.message ) ); } else { $li.text( val.message ); } $li.appendTo( $list ); var tab = section .replace( /^mail_\d+\./, 'mail.' ).replace( /\..*$/, '' ); if ( ! errorCount[ tab ] ) { errorCount[ tab ] = 0; } errorCount[ tab ] += 1; errorCount.total += 1; } ); $( this ).after( $list ).attr( { 'aria-invalid': 'true' } ); } } ); $( '#clicktotalk-form-editor-tabs > li' ).each( function() { var $item = $( this ); $item.find( 'span.dashicons' ).remove(); var tab = $item.attr( 'id' ).replace( /-panel-tab$/, '' ); $.each( errors, function( key, val ) { key = key.replace( /^mail_\d+\./, 'mail.' ); if ( key.replace( /\..*$/, '' ) == tab.replace( '-', '_' ) ) { var $mark = $( '' ); $item.find( 'a.ui-tabs-anchor' ).first().append( $mark ); return false; } } ); var $tabPanelError = $( '#' + tab + '-panel > div.config-error:first' ); $tabPanelError.empty(); if ( errorCount[ tab.replace( '-', '_' ) ] ) { $tabPanelError .append( ' ' ); if ( 1 < errorCount[ tab.replace( '-', '_' ) ] ) { var manyErrorsInTab = wp3cxc2c.configValidator.manyErrorsInTab .replace( '%d', errorCount[ tab.replace( '-', '_' ) ] ); $tabPanelError.append( manyErrorsInTab ); } else { $tabPanelError.append( wp3cxc2c.configValidator.oneErrorInTab ); } } } ); $( '#misc-publishing-actions .misc-pub-section.config-error' ).remove(); if ( errorCount.total ) { var $warning = $( '
    ' ) .addClass( 'misc-pub-section config-error' ) .append( ' ' ); if ( 1 < errorCount.total ) { $warning.append( wp3cxc2c.configValidator.manyErrors.replace( '%d', errorCount.total ) ); } else { $warning.append( wp3cxc2c.configValidator.oneError ); } $warning.append( '
    ' ).append( $( '' ) .attr( 'href', wp3cxc2c.configValidator.docUrl ) .text( wp3cxc2c.configValidator.howToCorrect ) ); $( '#misc-publishing-actions' ).append( $warning ); } }; /** * Copied from wptitlehint() in wp-admin/js/post.js */ wp3cxc2c.titleHint = function() { var $title = $( '#title' ); var $titleprompt = $( '#title-prompt-text' ); if ( '' === $title.val() ) { $titleprompt.removeClass( 'screen-reader-text' ); } $titleprompt.click( function() { $( this ).addClass( 'screen-reader-text' ); $title.focus(); } ); $title.blur( function() { if ( '' === $(this).val() ) { $titleprompt.removeClass( 'screen-reader-text' ); } } ).focus( function() { $titleprompt.addClass( 'screen-reader-text' ); } ).keydown( function( e ) { $titleprompt.addClass( 'screen-reader-text' ); $( this ).unbind( e ); } ); }; wp3cxc2c.apiSettings.getRoute = function( path ) { var url = wp3cxc2c.apiSettings.root; url = url.replace( wp3cxc2c.apiSettings.namespace, wp3cxc2c.apiSettings.namespace + path ); return url; }; } )( jQuery );