説明なし

contact-info-admin.js 1.5KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455
  1. /* global ajaxurl, contact_info_api_key_ajax_obj */
  2. ( function ( $ ) {
  3. $( document ).on( 'change', '.jp-contact-info-showmap', function () {
  4. var $checkbox = $( this ),
  5. isChecked = $checkbox.is( ':checked' );
  6. $checkbox.closest( '.widget' ).find( '.jp-contact-info-admin-map' ).toggle( isChecked );
  7. } );
  8. $( document ).on( 'widget-synced', function ( event, widgetContainer ) {
  9. // This event fires for all widgets, so restrict this to Contact Info widgets and the API key input.
  10. if (
  11. ! widgetContainer.is( '[id*="widget_contact_info"]' ) ||
  12. ! $( document.activeElement ).is( 'input[id*="apikey"]' )
  13. ) {
  14. return;
  15. }
  16. event.preventDefault();
  17. var $apikey_input = widgetContainer.find( 'input[id*="apikey"]' );
  18. $.post(
  19. ajaxurl,
  20. {
  21. _ajax_nonce: contact_info_api_key_ajax_obj.nonce,
  22. action: 'customize-contact-info-api-key',
  23. apikey: $apikey_input.val(),
  24. },
  25. function ( data ) {
  26. var $map_element = $apikey_input
  27. .closest( '.jp-contact-info-admin-map' )
  28. .parent()
  29. .find( '.jp-contact-info-embed-map' );
  30. var $warning_span = $map_element.find( '[class*="notice"]' );
  31. if ( '1' !== data.result ) {
  32. if ( $warning_span.length === 0 ) {
  33. $map_element.append(
  34. '<span class="notice notice-warning" style="display: block;">' +
  35. data.result +
  36. '</span>'
  37. );
  38. } else if ( $warning_span.text() !== data.result ) {
  39. $warning_span.text( data.result );
  40. }
  41. } else {
  42. $map_element.empty();
  43. }
  44. }
  45. );
  46. } );
  47. } )( window.jQuery );