Completed
Push — add/wpcom-shortcodes ( a1e11f...b0321d )
by
unknown
223:34 queued 215:24
created

Jetpack_Debugger::jetpack_debug_display_handler()   F

Complexity

Conditions 26
Paths > 20000

Size

Total Lines 288
Code Lines 199

Duplication

Lines 0
Ratio 0 %

Importance

Changes 0
Metric Value
cc 26
eloc 199
nc 82944
nop 0
dl 0
loc 288
rs 2
c 0
b 0
f 0

How to fix   Long Method    Complexity   

Long Method

Small methods make your code easier to understand, in particular if combined with a good name. Besides, if your method is small, finding a good name is usually much easier.

For example, if you find yourself adding comments to a method's body, this is usually a good sign to extract the commented part to a new method, and use the comment as a starting point when coming up with a good name for this new method.

Commonly applied refactorings include:

1
<?php
2
3
class Jetpack_Debugger {
4
5
	private static function is_jetpack_support_open() {
6
		try {
7
			$url = add_query_arg( 'ver', JETPACK__VERSION, 'https://jetpack.com/is-support-open/' );
8
			$response = wp_remote_request( esc_url_raw( $url ) );
9
			if ( is_wp_error( $response ) ) {
10
				return false;
11
			}
12
			$body = wp_remote_retrieve_body( $response );
13
			$json = json_decode( $body );
14
			return ( ( bool ) $json->is_support_open );
15
		}
16
		catch ( Exception $e ) {
17
			return true;
18
		}
19
	}
20
21
	static function seconds_to_time( $seconds ) {
22
		$units = array(
23
			"week"   => 7*24*3600,
24
			"day"    =>   24*3600,
25
			"hour"   =>      3600,
26
			"minute" =>        60,
27
			"second" =>         1,
28
		);
29
		// specifically handle zero
30
		if ( $seconds == 0 ) return "0 seconds";
31
		$human_readable = "";
32
		foreach ( $units as $name => $divisor ) {
33
			if ( $quot = intval( $seconds / $divisor) ) {
34
				$human_readable .= "$quot $name";
35
				$human_readable .= ( abs( $quot ) > 1 ? "s" : "" ) . ", ";
36
				$seconds -= $quot * $divisor;
37
			}
38
		}
39
		return substr( $human_readable, 0, -2 );
40
	}
41
42
	public static function jetpack_increase_timeout() {
43
		return 30; // seconds
44
	}
45
46
	public static function jetpack_debug_display_handler() {
47
		if ( ! current_user_can( 'manage_options' ) )
48
			wp_die( esc_html__('You do not have sufficient permissions to access this page.', 'jetpack' ) );
49
50
		$current_user = wp_get_current_user();
51
52
		$user_id = get_current_user_id();
53
		$user_tokens = Jetpack_Options::get_option( 'user_tokens' );
54
		if ( is_array( $user_tokens ) && array_key_exists( $user_id, $user_tokens ) ) {
55
			$user_token = $user_tokens[$user_id];
56
		} else {
57
			$user_token = '[this user has no token]';
58
		}
59
		unset( $user_tokens );
60
61
		$debug_info = "\r\n";
62
		foreach ( array(
63
			'CLIENT_ID'   => 'id',
64
			'BLOG_TOKEN'  => 'blog_token',
65
			'MASTER_USER' => 'master_user',
66
			'CERT'        => 'fallback_no_verify_ssl_certs',
67
			'TIME_DIFF'   => 'time_diff',
68
			'VERSION'     => 'version',
69
			'OLD_VERSION' => 'old_version',
70
			'PUBLIC'      => 'public',
71
		) as $label => $option_name ) {
72
			$debug_info .= "\r\n" . esc_html( $label . ": " . Jetpack_Options::get_option( $option_name ) );
73
		}
74
75
		$debug_info .= "\r\n" . esc_html( "USER_ID: " . $user_id );
76
		$debug_info .= "\r\n" . esc_html( "USER_TOKEN: " . $user_token );
77
		$debug_info .= "\r\n" . esc_html( "PHP_VERSION: " . PHP_VERSION );
78
		$debug_info .= "\r\n" . esc_html( "WORDPRESS_VERSION: " . $GLOBALS['wp_version'] );
79
		$debug_info .= "\r\n" . esc_html( "JETPACK__VERSION: " . JETPACK__VERSION );
80
		$debug_info .= "\r\n" . esc_html( "JETPACK__PLUGIN_DIR: " . JETPACK__PLUGIN_DIR );
81
		$debug_info .= "\r\n" . esc_html( "SITE_URL: " . site_url() );
82
		$debug_info .= "\r\n" . esc_html( "HOME_URL: " . home_url() );
83
84
		$debug_info .= "\r\n";
85
		require_once JETPACK__PLUGIN_DIR . 'sync/class.jetpack-sync-modules.php';
86
		$sync_module = Jetpack_Sync_Modules::get_module( 'full-sync' );
87
		$sync_statuses = $sync_module->get_status();
88
		$human_readable_sync_status = array();
89
		foreach( $sync_statuses  as $sync_status => $sync_status_value ) {
90
			$human_readable_sync_status[ $sync_status ] =
91
				in_array( $sync_status, array( 'started', 'queue_finished', 'send_started', 'finished' ) )
92
				? date( 'r', $sync_status_value ) : $sync_status_value ;
93
		}
94
95
		$debug_info .= "\r\n". sprintf( esc_html__( 'Jetpack Sync Full Status: `%1$s`', 'jetpack' ), print_r( $human_readable_sync_status, 1 ) );
96
97
		require_once JETPACK__PLUGIN_DIR. 'sync/class.jetpack-sync-sender.php';
98
99
		$queue = Jetpack_Sync_Sender::get_instance()->get_sync_queue();
100
101
		$debug_info .= "\r\n". sprintf( esc_html__( 'Sync Queue size: %1$s', 'jetpack' ), $queue->size() );
102
		$debug_info .= "\r\n". sprintf( esc_html__( 'Sync Queue lag: %1$s', 'jetpack' ), self::seconds_to_time( $queue->lag() ) );
103
104
		$full_sync_queue = Jetpack_Sync_Sender::get_instance()->get_full_sync_queue();
105
106
		$debug_info .= "\r\n". sprintf( esc_html__( 'Full Sync Queue size: %1$s', 'jetpack' ), $full_sync_queue->size() );
107
		$debug_info .= "\r\n". sprintf( esc_html__( 'Full Sync Queue lag: %1$s', 'jetpack' ), self::seconds_to_time( $full_sync_queue->lag() ) );
108
109
		$debug_info .= "\r\n";
110
111
		foreach ( array (
112
					  'HTTP_HOST',
113
					  'SERVER_PORT',
114
					  'HTTPS',
115
					  'GD_PHP_HANDLER',
116
					  'HTTP_AKAMAI_ORIGIN_HOP',
117
					  'HTTP_CF_CONNECTING_IP',
118
					  'HTTP_CLIENT_IP',
119
					  'HTTP_FASTLY_CLIENT_IP',
120
					  'HTTP_FORWARDED',
121
					  'HTTP_FORWARDED_FOR',
122
					  'HTTP_INCAP_CLIENT_IP',
123
					  'HTTP_TRUE_CLIENT_IP',
124
					  'HTTP_X_CLIENTIP',
125
					  'HTTP_X_CLUSTER_CLIENT_IP',
126
					  'HTTP_X_FORWARDED',
127
					  'HTTP_X_FORWARDED_FOR',
128
					  'HTTP_X_IP_TRAIL',
129
					  'HTTP_X_REAL_IP',
130
					  'HTTP_X_VARNISH',
131
					  'REMOTE_ADDR'
132
				  ) as $header ) {
133
			if ( isset( $_SERVER[ $header ] ) ) {
134
				$debug_info .= "\r\n" . esc_html( $header . ": " . $_SERVER[ $header ] );
135
			}
136
		}
137
138
		$debug_info .= "\r\n" . esc_html( "PROTECT_TRUSTED_HEADER: " . json_encode( get_site_option( 'trusted_ip_header' ) ) );
139
140
		$debug_info .= "\r\n\r\nTEST RESULTS:\r\n\r\n";
141
		$debug_raw_info = '';
142
143
144
		$tests = array();
145
146
		$tests['HTTP']['result'] = wp_remote_get( preg_replace( '/^https:/', 'http:', JETPACK__API_BASE ) . 'test/1/' );
147
		$tests['HTTP']['fail_message'] = esc_html__( 'Your site isn’t reaching the Jetpack servers.', 'jetpack' );
148
149
		$tests['HTTPS']['result'] = wp_remote_get( preg_replace( '/^http:/', 'https:', JETPACK__API_BASE ) . 'test/1/' );
150
		$tests['HTTPS']['fail_message'] = esc_html__( 'Your site isn’t securely reaching the Jetpack servers.', 'jetpack' );
151
152
		$identity_crisis_message = '';
153
		if ( $identity_crisis = Jetpack::check_identity_crisis() ) {
154
			$identity_crisis_message .= sprintf(
155
				__( 'Your url is set as `%1$s`, but your WordPress.com connection lists it as `%2$s`!', 'jetpack' ),
156
				$identity_crisis['home'],
157
				$identity_crisis['wpcom_home']
158
			);
159
			$identity_crisis = new WP_Error( 'identity-crisis', $identity_crisis_message, $identity_crisis );
160
		} else {
161
			$identity_crisis = 'PASS';
162
		}
163
		$tests['IDENTITY_CRISIS']['result'] = $identity_crisis;
164
		$tests['IDENTITY_CRISIS']['fail_message'] = esc_html__( 'Something has gotten mixed up in your Jetpack Connection!', 'jetpack' );
165
166
		$self_xml_rpc_url = home_url( 'xmlrpc.php' );
167
168
		$testsite_url = Jetpack::fix_url_for_bad_hosts( JETPACK__API_BASE . 'testsite/1/?url=' );
169
170
		add_filter( 'http_request_timeout', array( 'Jetpack_Debugger', 'jetpack_increase_timeout' ) );
171
172
		$tests['SELF']['result'] = wp_remote_get( $testsite_url . $self_xml_rpc_url );
173
		if ( is_wp_error( $tests['SELF']['result'] ) && 0 == strpos( $tests['SELF']['result']->get_error_message(), 'Operation timed out' ) ){
174
			$tests['SELF']['fail_message'] = esc_html__( 'Your site did not get a response from our debugging service in the expected timeframe. If you are not experiencing other issues, this could be due to a slow connection between your site and our server.', 'jetpack' );
175
		} else {
176
			$tests['SELF']['fail_message'] = esc_html__( 'It looks like your site can not communicate properly with Jetpack.', 'jetpack' );
177
		}
178
179
		remove_filter( 'http_request_timeout', array( 'Jetpack_Debugger', 'jetpack_increase_timeout' ) );
180
181
		?>
182
		<div class="wrap">
183
			<h2><?php esc_html_e( 'Jetpack Debugging Center', 'jetpack' ); ?></h2>
184
			<h3><?php _e( "Testing your site's compatibility with Jetpack...", 'jetpack' ); ?></h3>
185
			<div class="jetpack-debug-test-container">
186
			<?php
187
			ob_start();
188
			foreach ( $tests as $test_name => $test_info ) :
189
				if ( 'PASS' !== $test_info['result'] && ( is_wp_error( $test_info['result'] ) ||
190
					false == ( $response_code = wp_remote_retrieve_response_code( $test_info['result'] ) )  ||
191
					'200' != $response_code ) ) {
0 ignored issues
show
Bug introduced by
The variable $response_code does not seem to be defined for all execution paths leading up to this point.

If you define a variable conditionally, it can happen that it is not defined for all execution paths.

Let’s take a look at an example:

function myFunction($a) {
    switch ($a) {
        case 'foo':
            $x = 1;
            break;

        case 'bar':
            $x = 2;
            break;
    }

    // $x is potentially undefined here.
    echo $x;
}

In the above example, the variable $x is defined if you pass “foo” or “bar” as argument for $a. However, since the switch statement has no default case statement, if you pass any other value, the variable $x would be undefined.

Available Fixes

  1. Check for existence of the variable explicitly:

    function myFunction($a) {
        switch ($a) {
            case 'foo':
                $x = 1;
                break;
    
            case 'bar':
                $x = 2;
                break;
        }
    
        if (isset($x)) { // Make sure it's always set.
            echo $x;
        }
    }
    
  2. Define a default value for the variable:

    function myFunction($a) {
        $x = ''; // Set a default which gets overridden for certain paths.
        switch ($a) {
            case 'foo':
                $x = 1;
                break;
    
            case 'bar':
                $x = 2;
                break;
        }
    
        echo $x;
    }
    
  3. Add a value for the missing path:

    function myFunction($a) {
        switch ($a) {
            case 'foo':
                $x = 1;
                break;
    
            case 'bar':
                $x = 2;
                break;
    
            // We add support for the missing case.
            default:
                $x = '';
                break;
        }
    
        echo $x;
    }
    
Loading history...
192
					$debug_info .= $test_name . ": FAIL\r\n";
193
					?>
194
					<div class="jetpack-test-error">
195
						<p>
196
							<a class="jetpack-test-heading" href="#"><?php echo $test_info['fail_message']; ?>
197
							<span class="noticon noticon-collapse"></span>
198
							</a>
199
						</p>
200
						<pre class="jetpack-test-details"><?php echo esc_html( $test_name ); ?>:
201
	<?php echo esc_html( is_wp_error( $test_info['result'] ) ? $test_info['result']->get_error_message() : print_r( $test_info['result'], 1 ) ); ?></pre>
202
					</div><?php
203
				} else {
204
					$debug_info .= $test_name . ": PASS\r\n";
205
				}
206
				$debug_raw_info .= "\r\n\r\n" . $test_name . "\r\n" . esc_html( is_wp_error( $test_info['result'] ) ? $test_info['result']->get_error_message() : print_r( $test_info['result'], 1 ) );
207
				?>
208
			<?php endforeach;
209
			$html = ob_get_clean();
210
211
			if ( '' == trim( $html ) ) {
212
				echo '<div class="jetpack-tests-succed">' . esc_html__( 'Your Jetpack setup looks a-okay!', 'jetpack' ) . '</div>';
213
			}
214
			else {
215
				echo '<h3>' . esc_html__( 'There seems to be a problem with your site’s ability to communicate with Jetpack!', 'jetpack' ) . '</h3>';
216
				echo $html;
217
			}
218
			$debug_info .= "\r\n\r\nRAW TEST RESULTS:" . $debug_raw_info ."\r\n";
219
			?>
220
			</div>
221
			<div class="entry-content">
222
				<h3><?php esc_html_e( 'Trouble with Jetpack?', 'jetpack' ); ?></h3>
223
				<h4><?php esc_html_e( 'It may be caused by one of these issues, which you can diagnose yourself:', 'jetpack' ); ?></h4>
224
				<ol>
225
					<li><b><em><?php esc_html_e( 'A known issue.', 'jetpack' ); ?></em></b>  <?php echo sprintf( __( 'Some themes and plugins have <a href="%1$s" target="_blank">known conflicts</a> with Jetpack – check the <a href="%2$s" target="_blank">list</a>. (You can also browse the <a href="%3$s" target="_blank">Jetpack support pages</a> or <a href="%4$s" target="_blank">Jetpack support forum</a> to see if others have experienced and solved the problem.)', 'jetpack' ), 'http://jetpack.com/support/getting-started-with-jetpack/known-issues/', 'http://jetpack.com/support/getting-started-with-jetpack/known-issues/', 'http://jetpack.com/support/', 'https://wordpress.org/support/plugin/jetpack' ); ?></li>
226
					<li><b><em><?php esc_html_e( 'An incompatible plugin.', 'jetpack' ); ?></em></b>  <?php esc_html_e( "Find out by disabling all plugins except Jetpack. If the problem persists, it's not a plugin issue. If the problem is solved, turn your plugins on one by one until the problem pops up again – there's the culprit! Let us know, and we'll try to help.", 'jetpack' ); ?></li>
227
					<li>
228
						<b><em><?php esc_html_e( 'A theme conflict.', 'jetpack' ); ?></em></b>
229
						<?php
230
							$default_theme = wp_get_theme( WP_DEFAULT_THEME );
231
232
							if ( $default_theme->exists() ) {
233
								echo esc_html( sprintf( __( "If your problem isn't known or caused by a plugin, try activating %s (the default WordPress theme).", 'jetpack' ), $default_theme->get( 'Name' ) ) );
234
							} else {
235
								esc_html_e( "If your problem isn't known or caused by a plugin, try activating the default WordPress theme.", 'jetpack' );
236
							}
237
						?>
238
						<?php esc_html_e( "If this solves the problem, something in your theme is probably broken – let the theme's author know.", 'jetpack' ); ?>
239
					</li>
240
					<li><b><em><?php esc_html_e( 'A problem with your XMLRPC file.', 'jetpack' ); ?></em></b>  <?php echo sprintf( __( 'Load your <a href="%s">XMLRPC file</a>. It should say “XML-RPC server accepts POST requests only.” on a line by itself.', 'jetpack' ), site_url( 'xmlrpc.php' ) ); ?>
241
						<ul>
242
							<li>- <?php esc_html_e( "If it's not by itself, a theme or plugin is displaying extra characters. Try steps 2 and 3.", 'jetpack' ); ?></li>
243
							<li>- <?php esc_html_e( "If you get a 404 message, contact your web host. Their security may block XMLRPC.", 'jetpack' ); ?></li>
244
						</ul>
245
					</li>
246
				</ol>
247
				<?php if ( self::is_jetpack_support_open() ): ?>
248
				<p class="jetpack-show-contact-form"><?php echo sprintf( __( 'If none of these help you find a solution, <a href="%s">click here to contact Jetpack support</a>. Tell us as much as you can about the issue and what steps you\'ve tried to resolve it, and one of our Happiness Engineers will be in touch to help.', 'jetpack' ), Jetpack::admin_url( array( 'page' => 'jetpack-debugger', 'contact' => true ) ) ); ?>
249
				</p>
250
				<?php endif; ?>
251
				<hr />
252
				<?php if ( Jetpack::is_active() ) : ?>
253
					<div id="connected-user-details">
254
						<p><?php printf( __( 'The primary connection is owned by <strong>%s</strong>\'s WordPress.com account.', 'jetpack' ), esc_html( Jetpack::get_master_user_email() ) ); ?></p>
255
					</div>
256
				<?php else : ?>
257
					<div id="dev-mode-details">
258
						<p><?php printf(
259
							__( 'Would you like to use Jetpack on your local development site? You can do so thanks to <a href="%s">Jetpack\'s development mode</a>.', 'jetpack' ),
260
							'https://jetpack.com/support/development-mode/'
261
						); ?></p>
262
					</div>
263
				<?php endif; ?>
264
			</div>
265
			<div id="contact-message" <?php if( ! isset( $_GET['contact'] ) ) {?>  style="display:none" <?php } ?>>
266
			<?php if ( self::is_jetpack_support_open() ): ?>
267
				<form id="contactme" method="post" action="https://jetpack.com/contact-support/">
268
					<input type="hidden" name="action" value="submit">
269
					<input type="hidden" name="jetpack" value="needs-service">
270
271
					<input type="hidden" name="contact_form" id="contact_form" value="1">
272
					<input type="hidden" name="blog_url" id="blog_url" value="<?php echo esc_attr( site_url() ); ?>">
273
					<?php
274
						$subject_line = sprintf(
275
							/* translators: %s is the URL of the site */
276
							_x( 'from: %s Jetpack contact form', 'Support request email subject line', 'jetpack' ),
277
							esc_attr( site_url() )
278
						);
279
280
						if ( Jetpack::is_development_version() ) {
281
							$subject_line = 'BETA ' . $subject_line;
282
						}
283
284
						$subject_line_input = printf(
0 ignored issues
show
Unused Code introduced by
$subject_line_input is not used, you could remove the assignment.

This check looks for variable assignements that are either overwritten by other assignments or where the variable is not used subsequently.

$myVar = 'Value';
$higher = false;

if (rand(1, 6) > 3) {
    $higher = true;
} else {
    $higher = false;
}

Both the $myVar assignment in line 1 and the $higher assignment in line 2 are dead. The first because $myVar is never used and the second because $higher is always overwritten for every possible time line.

Loading history...
285
							'<input type="hidden" name="subject" id="subject" value="%s"">',
286
							$subject_line
287
						);
288
					?>
289
					<div class="formbox">
290
						<label for="message" class="h"><?php esc_html_e( 'Please describe the problem you are having.', 'jetpack' ); ?></label>
291
						<textarea name="message" cols="40" rows="7" id="did"></textarea>
292
					</div>
293
294
					<div id="name_div" class="formbox">
295
						<label class="h" for="your_name"><?php esc_html_e( 'Name', 'jetpack' ); ?></label>
296
			  			<span class="errormsg"><?php esc_html_e( 'Let us know your name.', 'jetpack' ); ?></span>
297
						<input name="your_name" type="text" id="your_name" value="<?php esc_html_e( $current_user->display_name, 'jetpack'); ?>" size="40">
298
					</div>
299
300
					<div id="email_div" class="formbox">
301
						<label class="h" for="your_email"><?php esc_html_e( 'Email', 'jetpack' ); ?></label>
302
			  			<span class="errormsg"><?php esc_html_e( 'Use a valid email address.', 'jetpack' ); ?></span>
303
						<input name="your_email" type="text" id="your_email" value="<?php esc_html_e( $current_user->user_email, 'jetpack'); ?>" size="40">
304
					</div>
305
306
					<div id="toggle_debug_form_info" class="formbox">
307
						<p><?php _e( 'The test results and some other useful debug information will be sent to the support team. Please feel free to <a href="#">review/modify</a> this information.', 'jetpack' ); ?></p>
308
					</div>
309
310
					<div id="debug_info_form_div" class="formbox" style="display:none">
311
						<label class="h" for="debug_info"><?php esc_html_e( 'Debug Info', 'jetpack' ); ?></label>
312
			  			<textarea name="debug_info" cols="40" rows="7" id="debug_form_info"><?php echo esc_attr( $debug_info ); ?></textarea>
313
					</div>
314
315
					<div style="clear: both;"></div>
316
317
					<div id="blog_div" class="formbox">
318
						<div id="submit_div" class="contact-support">
319
						<input type="submit" name="submit" value="<?php esc_html_e( 'Submit &#187;', 'jetpack' ); ?>">
320
						</div>
321
					</div>
322
					<div style="clear: both;"></div>
323
				</form>
324
			<?php endif; ?>
325
		</div> <!-- contact-message, hidden by default. -->
326
		<div id="toggle_debug_info"><a href="#"><?php _e( 'View Advanced Debug Results', 'jetpack' ); ?></a></div>
327
			<div id="debug_info_div" style="display:none">
328
			<h4><?php esc_html_e( 'Debug Info', 'jetpack' ); ?></h4>
329
			<div id="debug_info"><pre><?php echo esc_html( $debug_info ) ; ?></pre></div>
330
		</div>
331
		</div>
332
	<?php
333
	}
334
335
	public static function jetpack_debug_admin_head() {
336
		?>
337
		<style type="text/css">
338
339
			.jetpack-debug-test-container {
340
				margin-top: 20px;
341
				margin-bottom: 30px;
342
			}
343
344
			.jetpack-tests-succed {
345
				font-size: large;
346
				color: #8BAB3E;
347
			}
348
349
			.jetpack-test-details {
350
				margin: 4px 6px;
351
				padding: 10px;
352
				overflow: auto;
353
				display: none;
354
			}
355
356
			.jetpack-test-error {
357
				margin-bottom: 10px;
358
				background: #FFEBE8;
359
				border: solid 1px #C00;
360
				border-radius: 3px;
361
			}
362
363
			.jetpack-test-error p {
364
				margin: 0;
365
				padding: 0;
366
			}
367
368
			.jetpack-test-error a.jetpack-test-heading {
369
				padding: 4px 6px;
370
				display: block;
371
				text-decoration: none;
372
				color: inherit;
373
			}
374
375
			.jetpack-test-error .noticon {
376
				float: right;
377
			}
378
379
			form#contactme {
380
				border: 1px solid #dfdfdf;
381
				background: #eaf3fa;
382
				padding: 20px;
383
				margin: 10px;
384
				background-color: #eaf3fa;
385
				border-radius: 5px;
386
				font-size: 15px;
387
			}
388
389
			form#contactme label.h {
390
				color: #444;
391
				display: block;
392
				font-weight: bold;
393
				margin: 0 0 7px 10px;
394
				text-shadow: 1px 1px 0 #fff;
395
			}
396
397
			.formbox {
398
				margin: 0 0 25px 0;
399
			}
400
401
			.formbox input[type="text"], .formbox input[type="email"], .formbox input[type="url"], .formbox textarea, #debug_info_div {
402
				border: 1px solid #e5e5e5;
403
				border-radius: 11px;
404
				box-shadow: inset 0 1px 1px rgba(0,0,0,0.1);
405
				color: #666;
406
				font-size: 14px;
407
				padding: 10px;
408
				width: 97%;
409
			}
410
			#debug_info_div {
411
				border-radius: 0;
412
				margin-top: 16px;
413
				background: #FFF;
414
				padding: 16px;
415
			}
416
			.formbox .contact-support input[type="submit"] {
417
				float: right;
418
				margin: 0 !important;
419
				border-radius: 20px !important;
420
				cursor: pointer;
421
				font-size: 13pt !important;
422
				height: auto !important;
423
				margin: 0 0 2em 10px !important;
424
				padding: 8px 16px !important;
425
				background-color: #ddd;
426
				border: 1px solid rgba(0,0,0,0.05);
427
				border-top-color: rgba(255,255,255,0.1);
428
				border-bottom-color: rgba(0,0,0,0.15);
429
				color: #333;
430
				font-weight: 400;
431
				display: inline-block;
432
				text-align: center;
433
				text-decoration: none;
434
			}
435
436
			.formbox span.errormsg {
437
				margin: 0 0 10px 10px;
438
				color: #d00;
439
				display: none;
440
			}
441
442
			.formbox.error span.errormsg {
443
				display: block;
444
			}
445
446
			#contact-message ul {
447
				margin: 0 0 20px 10px;
448
			}
449
450
			#contact-message li {
451
				margin: 0 0 10px 10px;
452
				list-style: disc;
453
				display: list-item;
454
			}
455
456
			#debug_info_div, #toggle_debug_info, #debug_info_div p {
457
				font-size: 12px;
458
			}
459
460
		</style>
461
		<script type="text/javascript">
462
		jQuery( document ).ready( function($) {
463
464
			$( '#debug_info' ).prepend( 'jQuery version: ' + jQuery.fn.jquery + "\r\n" );
465
			$( '#debug_form_info' ).prepend( 'jQuery version: ' + jQuery.fn.jquery + "\r\n" );
466
467
			$( '.jetpack-test-error .jetpack-test-heading' ).on( 'click', function() {
468
				$( this ).parents( '.jetpack-test-error' ).find( '.jetpack-test-details' ).slideToggle();
469
				return false;
470
			} );
471
472
			$( '.jetpack-show-contact-form a' ).on( 'click', function() {
473
				$( '#contact-message' ).slideToggle();
474
				return false;
475
			} );
476
477
			$( '#toggle_debug_info a' ).on( 'click', function() {
478
				$( '#debug_info_div' ).slideToggle();
479
				return false;
480
			} );
481
482
			$( '#toggle_debug_form_info a' ).on( 'click', function() {
483
				$( '#debug_info_form_div' ).slideToggle();
484
				return false;
485
			} );
486
487
			$( 'form#contactme' ).on( "submit", function(e){
488
				var form = $( this );
489
				var message = form.find( '#did' );
490
				var name = form.find( '#your_name' );
491
				var email = form.find( '#your_email' )
492
				var validation_error = false;
493
				if( !name.val() ) {
494
					name.parents( '.formbox' ).addClass( 'error' );
495
					validation_error = true;
496
				}
497
				if( !email.val() ) {
498
					email.parents( '.formbox' ).addClass( 'error' );
499
					validation_error = true;
500
				}
501
				if ( validation_error ) {
502
					return false;
503
				}
504
				message.val( message.val() + "\r\n\r\n----------------------------------------------\r\n\r\nDEBUG INFO:\r\n" + $('#debug_form_info').val()  );
505
				return true;
506
	    	});
507
508
		} );
509
		</script>
510
		<?php
511
	}
512
}
513