Completed
Push — add/7777-ga-anonymize-ip ( 94dfd5 )
by
unknown
10:21
created

Jetpack_Connection_Banner   A

Complexity

Total Complexity 25

Size/Duplication

Total Lines 907
Duplicated Lines 1.98 %

Coupling/Cohesion

Components 1
Dependencies 2

Importance

Changes 0
Metric Value
dl 18
loc 907
rs 9.7391
c 0
b 0
f 0
wmc 25
lcom 1
cbo 2

12 Methods

Rating   Name   Duplication   Size   Complexity  
A init() 0 7 2
A __construct() 0 4 1
A cleanup_on_upgrade() 0 5 3
A check_ab_test_not_expired() 0 10 2
A get_random_connection_banner_value() 0 9 2
A build_connect_url_for_slide() 0 8 1
D maybe_initialize_hooks() 0 34 9
A enqueue_banner_scripts() 18 18 1
B render_banner() 0 412 1
B render_banner_b() 0 242 1
A render_connect_prompt_full_screen() 0 57 1
A network_connect_notice() 0 19 1

How to fix   Duplicated Code   

Duplicated Code

Duplicate code is one of the most pungent code smells. A rule that is often used is to re-structure code once it is duplicated in three or more places.

Common duplication problems, and corresponding solutions are:

1
<?php
2
3
class Jetpack_Connection_Banner {
4
	/**
5
	 * @var Jetpack_Connection_Banner
6
	 **/
7
	private static $instance = null;
8
9
	static function init() {
10
		if ( is_null( self::$instance ) ) {
11
			self::$instance = new Jetpack_Connection_Banner();
12
		}
13
14
		return self::$instance;
15
	}
16
17
	/**
18
	 * Jetpack_Connection_Banner constructor.
19
	 *
20
	 * Since we call the Jetpack_Connection_Banner:init() method from the `Jetpack` class, and after
21
	 * the admin_init action fires, we know that the admin is initialized at this point.
22
	 */
23
	private function __construct() {
24
		add_action( 'current_screen', array( $this, 'maybe_initialize_hooks' ) );
25
		add_action( 'updating_jetpack_version', array( $this, 'cleanup_on_upgrade' ), 10, 2 );
26
	}
27
28
	function cleanup_on_upgrade( $new_version = null, $old_version = null ) {
29
		if ( version_compare( $old_version, '4.4', '>=' ) && version_compare( $old_version, '5.3', '<' ) ) {
30
			delete_option( 'jetpack_connection_banner_ab' );
31
		}
32
	}
33
34
	/**
35
	 * Checks whether the connection banner A/B test should be ran.
36
	 *
37
	 * @since 5.3.0
38
	 *
39
	 * @param null $now
40
	 *
41
	 * @return bool
42
	 */
43
	static function check_ab_test_not_expired( $now = null ) {
44
		// Get the current timestamp in GMT
45
		$now = empty( $now ) ? current_time( 'timestamp', 1 ) : $now;
46
47
		// Arguments are hour, minute, second, month, day, year. So, we are getting the timestamp for GMT timestamp
48
		// for the October 5th, 2017.
49
		$expiration = gmmktime( 0, 0, 0, 10, 5, 2017 );
50
51
		return $expiration >= $now;
52
	}
53
54
	/**
55
	 * Gets the value for which connection banner to show, and initializes if not set.
56
	 *
57
	 * @since 5.3.0
58
	 *
59
	 * @return int
60
	 */
61
	static function get_random_connection_banner_value() {
62
		$random_connection_banner = get_option( 'jetpack_connection_banner_ab' );
63
		if ( ! $random_connection_banner ) {
64
			$random_connection_banner = mt_rand( 1, 2 );
65
			update_option( 'jetpack_connection_banner_ab', $random_connection_banner );
66
		}
67
68
		return $random_connection_banner;
69
	}
70
71
	/**
72
	 * Given a string for the the banner was added, and an int that represents the slide to 
73
	 * a URL for, this function returns a connection URL with a from parameter that will
74
	 * support split testing.
75
	 *
76
	 * @param string     $jp_version_banner_added A short version of when the banner was added. Ex. 44
77
	 * @param string|int $slide_num               The index of the slide, 1-indexed. 
78
	 * @return string
79
	 */
80
	function build_connect_url_for_slide( $jp_version_banner_added, $slide_num ) {
81
		global $current_screen;
82
		return Jetpack::init()->build_connect_url(
83
			true, 
84
			false, 
85
			sprintf( 'banner-%s-slide-%s-%s', $jp_version_banner_added, $slide_num, $current_screen->base )
86
		);
87
	}
88
89
	/**
90
	 * Will initialize hooks to display the new (as of 4.4) connection banner if the current user can
91
	 * connect Jetpack, if Jetpack has not been deactivated, and if the current page is the plugins page.
92
	 *
93
	 * This method should not be called if the site is connected to WordPress.com or if the site is in development mode.
94
	 *
95
	 * @since 4.4.0
96
	 * @since 4.5.0 Made the new (as of 4.4) connection banner display to everyone by default.
97
	 * @since 5.3.0 Running another split test between 4.4 banner and a new one in 5.3.
98
	 *
99
	 * @param $current_screen
100
	 */
101
	function maybe_initialize_hooks( $current_screen ) {
102
		// Kill if banner has been dismissed
103
		if ( Jetpack_Options::get_option( 'dismissed_connection_banner' ) ) {
104
			return;
105
		}
106
107
		// Don't show the connect notice anywhere but the plugins.php after activating
108
		if ( 'plugins' !== $current_screen->base && 'dashboard' !== $current_screen->base ) {
109
			return;
110
		}
111
112
		if ( ! current_user_can( 'jetpack_connect' ) ) {
113
			return;
114
		}
115
116
		if ( self::check_ab_test_not_expired() && 2 == self::get_random_connection_banner_value() ) {
117
			add_action( 'admin_notices', array( $this, 'render_banner_b' ) );
118
		} else {
119
			add_action( 'admin_notices', array( $this, 'render_banner' ) );
120
		}
121
122
		add_action( 'admin_enqueue_scripts', array( $this, 'enqueue_banner_scripts' ) );
123
		add_action( 'admin_print_styles', array( Jetpack::init(), 'admin_banner_styles' ) );
124
125
		if ( Jetpack::state( 'network_nag' ) ) {
126
			add_action( 'network_admin_notices', array( $this, 'network_connect_notice' ) );
127
		}
128
129
		// Only fires immediately after plugin activation
130
		if ( get_transient( 'activated_jetpack' ) ) {
131
			add_action( 'admin_notices', array( $this, 'render_connect_prompt_full_screen' ) );
132
			delete_transient( 'activated_jetpack' );
133
		}
134
	}
135
136
	/**
137
	 * Enqueues JavaScript for new connection banner.
138
	 *
139
	 * @since 4.4.0
140
	 */
141 View Code Duplication
	function enqueue_banner_scripts() {
142
		wp_enqueue_script(
143
			'jetpack-connection-banner-js',
144
			plugins_url( '_inc/jetpack-connection-banner.js', JETPACK__PLUGIN_FILE ),
145
			array( 'jquery' ),
146
			JETPACK__VERSION,
147
			true
148
		);
149
150
		wp_localize_script(
151
			'jetpack-connection-banner-js',
152
			'jp_banner',
153
			array(
154
				'ajax_url' => admin_url( 'admin-ajax.php' ),
155
				'connectionBannerNonce' => wp_create_nonce( 'jp-connection-banner-nonce' ),
156
			)
157
		);
158
	}
159
160
	/**
161
	 * Renders the new connection banner as of 4.4.0.
162
	 *
163
	 * @since 4.4.0
164
	 */
165
	function render_banner() { ?>
166
		<div id="message" class="updated jp-wpcom-connect__container">
167
			<div class="jp-wpcom-connect__inner-container">
168
				<span
169
					class="notice-dismiss connection-banner-dismiss"
170
					title="<?php esc_attr_e( 'Dismiss this notice', 'jetpack' ); ?>">
171
				</span>
172
173
				<div class="jp-wpcom-connect__vertical-nav">
174
					<div class="jp-wpcom-connect__vertical-nav-container">
175
						<div class="vertical-menu__feature-item jp-feature-intro vertical-menu__feature-item-is-selected">
176
							<div class="vertical-menu__feature-item-icon">
177
								<svg class="jp-wpcom-connect__svg-jetpack" xmlns="http://www.w3.org/2000/svg" width="20" height="20" viewBox="0 1 20 20" version="1.1"><path d="M14.4 11.3L10.5 18.1 10.5 8.7 13.7 9.5C14.5 9.7 14.9 10.6 14.4 11.3L14.4 11.3ZM9.6 13.3L6.5 12.5C5.7 12.3 5.3 11.4 5.7 10.7L9.6 3.9 9.6 13.3ZM10 1C4.5 1 0 5.5 0 11 0 16.5 4.5 21 10 21 15.5 21 20 16.5 20 11 20 5.5 15.5 1 10 1L10 1Z" /></svg>
178
							</div>
179
							<span class="vertical-menu__feature-item-label"><?php esc_html_e( 'Welcome to Jetpack', 'jetpack' ); ?></span>
180
						</div>
181
						<div class="vertical-menu__feature-item">
182
							<div class="vertical-menu__feature-item-icon">
183
								<svg xmlns="http://www.w3.org/2000/svg" width="20" height="20" viewBox="0 2 20 20" version="1.1"><path d="M7.8 17.6L12.2 17.6 12.2 2 7.8 2 7.8 17.6ZM14.4 17.6L18.9 17.6 18.9 5.3 14.4 5.3 14.4 17.6ZM1.1 17.6L5.6 17.6 5.6 9.8 1.1 9.8 1.1 17.6ZM0 22L20 22 20 19.8 0 19.8 0 22Z" /></svg>
184
							</div>
185
							<span class="vertical-menu__feature-item-label"><?php esc_html_e( 'Stats &amp; Traffic Tools', 'jetpack' ); ?></span>
186
						</div>
187
						<div class="vertical-menu__feature-item">
188
							<div class="vertical-menu__feature-item-icon">
189
								<svg xmlns="http://www.w3.org/2000/svg" width="16" height="20" viewBox="0 1 16 20" version="1.1"><defs><polygon points="16 10 16 0 0 0 0 10 0 20 16 20"/></defs><g stroke="none" stroke-width="1" transform="translate(0.000000, 1.000000)"><mask fill="white"/><path d="M9 13.7L9 16 7 16 7 13.7C6.4 13.4 6 12.7 6 12 6 10.9 6.9 10 8 10 9.1 10 10 10.9 10 12 10 12.7 9.6 13.4 9 13.7L9 13.7ZM5 5C5 3.3 6.3 2 8 2 9.7 2 11 3.3 11 5L11 6 5 6 5 5ZM14 6L13 6 13 5C13 2.2 10.8 0 8 0 5.2 0 3 2.2 3 5L3 6 2 6C0.9 6 0 6.9 0 8L0 18C0 19.1 0.9 20 2 20L14 20C15.1 20 16 19.1 16 18L16 8C16 6.9 15.1 6 14 6L14 6Z" mask="url(#mask-2)"/></g></svg>
190
							</div>
191
							<span class="vertical-menu__feature-item-label"><?php esc_html_e( 'Site Security', 'jetpack' ); ?></span>
192
						</div>
193
						<div class="vertical-menu__feature-item">
194
							<div class="vertical-menu__feature-item-icon">
195
								<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24"><rect x="0" fill="none" width="20" height="20"/><g><path d="M4 6c-1.105 0-2 .895-2 2v12c0 1.1.9 2 2 2h12c1.105 0 2-.895 2-2H4V6zm16-4H8c-1.105 0-2 .895-2 2v12c0 1.105.895 2 2 2h12c1.105 0 2-.895 2-2V4c0-1.105-.895-2-2-2zm-5 14H8V9h7v7zm5 0h-3V9h3v7zm0-9H8V4h12v3z"/></g></svg>
196
							</div>
197
							<span class="vertical-menu__feature-item-label"><?php esc_html_e( 'Professional Themes', 'jetpack' ); ?></span>
198
						</div>
199
						<div class="vertical-menu__feature-item">
200
							<div class="vertical-menu__feature-item-icon">
201
								<svg xmlns="http://www.w3.org/2000/svg" width="20" height="20" viewBox="0 2 20 20" version="1.1"><path d="M6 4L6 10.3 9 7 13.9 12.4 14.5 11.7C15.3 10.8 16.7 10.8 17.5 11.7L18 12.2 18 4 6 4ZM20 4L20 16C20 17.1 19.1 18 18 18L6 18C4.9 18 4 17.1 4 16L4 4C4 2.9 4.9 2 6 2L18 2C19.1 2 20 2.9 20 4L20 4ZM2 20L16 20 16 20C16 21.1 15.1 22 14 22L2 22C0.9 22 0 21.1 0 20L0 8C0 6.9 0.9 6 2 6L2 6 2 20ZM13 7.5C13 6.7 13.7 6 14.5 6 15.3 6 16 6.7 16 7.5 16 8.3 15.3 9 14.5 9 13.7 9 13 8.3 13 7.5L13 7.5Z" /></svg>
202
							</div>
203
							<span class="vertical-menu__feature-item-label"><?php esc_html_e( 'Performance', 'jetpack' ); ?></span>
204
						</div>
205
						<div class="vertical-menu__feature-item wp-app-logo">
206
							<div class="vertical-menu__feature-item-icon">
207
								<svg xmlns="http://www.w3.org/2000/svg" width="20" height="20" viewBox="0 2 20 20" version="1.1"><defs><polygon points="0 20 20 20 20 0 0 0 0 20"/></defs><g stroke="none" stroke-width="1" fill="none" fill-rule="evenodd" transform="translate(0.000000, 2.000000)"><mask fill="white"/><path d="M14.3 17.3L16.9 9.8C17.4 8.6 17.5 7.7 17.5 6.8 17.5 6.5 17.5 6.2 17.5 5.9 18.1 7.1 18.5 8.5 18.5 10 18.5 13.1 16.8 15.9 14.3 17.3L14.3 17.3ZM11.2 6C11.7 6 12.1 5.9 12.1 5.9 12.6 5.9 12.5 5.2 12.1 5.2 12.1 5.2 10.7 5.3 9.8 5.3 9 5.3 7.6 5.2 7.6 5.2 7.1 5.2 7.1 5.9 7.5 5.9 7.5 5.9 8 6 8.4 6L9.7 9.6 7.9 15.2 4.8 6C5.3 6 5.8 5.9 5.8 5.9 6.2 5.9 6.2 5.2 5.7 5.2 5.7 5.2 4.3 5.3 3.4 5.3 3.3 5.3 3.1 5.3 2.9 5.3 4.4 3 7 1.5 10 1.5 12.2 1.5 14.2 2.3 15.7 3.7 15.7 3.7 15.7 3.7 15.6 3.7 14.8 3.7 14.2 4.5 14.2 5.2 14.2 5.9 14.6 6.5 15 7.2 15.4 7.8 15.7 8.5 15.7 9.6 15.7 10.3 15.5 11.1 15.1 12.3L14.2 15.2 11.2 6ZM10 18.5C9.2 18.5 8.4 18.4 7.6 18.2L10.1 10.7 12.8 17.9C12.8 17.9 12.8 18 12.8 18 11.9 18.3 11 18.5 10 18.5L10 18.5ZM1.5 10C1.5 8.8 1.8 7.6 2.2 6.5L6.3 17.7C3.5 16.3 1.5 13.4 1.5 10L1.5 10ZM10 0C4.5 0 0 4.5 0 10 0 15.5 4.5 20 10 20 15.5 20 20 15.5 20 10 20 4.5 15.5 0 10 0L10 0Z" fill="#86A6BD" mask="url(#mask-2)"/></g></svg>
208
							</div>
209
							<span class="vertical-menu__feature-item-label"><?php esc_html_e( 'WordPress Apps', 'jetpack' ); ?></span>
210
						</div>
211
						<div class="vertical-menu__feature-item">
212
							<div class="vertical-menu__feature-item-icon">
213
								<svg xmlns="http://www.w3.org/2000/svg" width="18" height="18" viewBox="0 4 15 15" version="1.1"><polygon points="6.6 4 6.6 10.6 0 10.6 0 12.4 6.6 12.4 6.6 19 8.4 19 8.4 12.4 15 12.4 15 10.6 8.4 10.6 8.4 4"/></svg>
214
							</div>
215
							<span class="vertical-menu__feature-item-label"><?php esc_html_e( 'More Features', 'jetpack' ); ?></span>
216
						</div>
217
					</div>
218
				</div>
219
				<div class="jp-wpcom-connect__content-container">
220
221
					<!-- slide 1: intro -->
222
					<div class="jp-wpcom-connect__slide jp-wpcom-connect__slide-one jp__slide-is-active">
223
						<h2><?php esc_html_e( 'Jetpack simplifies site security, customization, and management.', 'jetpack' ) ?></h2>
224
225
						<div class="jp-wpcom-connect__content-icon jp-connect-illo">
226
							<img src="<?php echo plugins_url( 'jetpack/images/jetpack-welcome.svg', dirname( __FILE__ ) ); ?>" alt="<?php 
227
									esc_attr_e( 
228
										'Jetpack is a free plugin that utilizes powerful WordPress.com servers to enhance your site and simplify managing it', 
229
									'jetpack' 
230
								); ?>" height="auto" width="250" />
231
						</div>
232
233
						<p>
234
							<?php
235
							esc_html_e(
236
								'Jetpack is a free plugin that utilizes powerful WordPress.com servers to enhance your site and simplify managing it.',
237
								'jetpack'
238
							);
239
							?>
240
						</p>
241
242
						<p>
243
							<?php
244
							esc_html_e(
245
								'You get detailed visitor stats, state-of-the-art security services, image performance upgrades, traffic generation tools, and more.',
246
								'jetpack'
247
							);
248
							?>
249
						</p>
250
251
						<p>
252
							<?php
253
							esc_html_e(
254
								'Connect to WordPress.com (free) to get started!',
255
								'jetpack'
256
							);
257
							?>
258
						</p>
259
260
						<p class="jp-banner__button-container">
261
							<a
262
								href="<?php echo esc_url( $this->build_connect_url_for_slide( '44', 1 ) ); ?>"
263
								class="dops-button is-primary">
264
								<?php esc_html_e( 'Connect to WordPress.com', 'jetpack' ); ?>
265
							</a>
266
							<a
267
								href="#"
268
								class="dops-button next-feature"
269
								title="<?php
270
								esc_attr_e(
271
									'Start tour to Learn about the benefits you receive when you connect Jetpack to WordPress.com',
272
									'jetpack'
273
								);
274
								?>">
275
								<?php esc_html_e( 'Start quick tour', 'jetpack' ); ?>
276
							</a>
277
							<span class="jp-banner__tos-blurb">
278
								<?php jetpack_render_tos_blurb(); ?>
279
							</span>
280
						</p>
281
					</div> <!-- end slide 1 -->
282
283
					<!-- slide 2: stats -->
284
					<div class="jp-wpcom-connect__slide jp-wpcom-connect__slide-two">
285
						<h2><?php esc_html_e( 'Detailed stats and traffic tools to help your site grow', 'jetpack' ) ?></h2>
286
287
						<div class="jp-wpcom-connect__content-icon jp-connect-illo">
288
							<img src="<?php echo plugins_url( 'jetpack/images/stats-people.svg', dirname( __FILE__ ) ); ?>" alt="<?php 
289
								esc_attr_e( 
290
									'Get clear and concise stats and analytics about your visitors',
291
								 'jetpack' 
292
								); ?>" height="auto" width="225" />
293
						</div>
294
295
						<p>
296
							<?php
297
							esc_html_e(
298
								'Jetpack provides detailed stats and insights about your viewers.',
299
								'jetpack'
300
							);
301
							?>
302
						</p>
303
304
						<p>
305
							<?php
306
							esc_html_e(
307
								'This helps you make informed decisions about your content and drive more traffic to your site with our related posts, social, and enhanced distribution features.',
308
								'jetpack'
309
							);
310
							?>
311
						</p>
312
313
						<p>
314
							<?php
315
							esc_html_e(
316
								'Professional Plan customers get access to advanced SEO tools.',
317
								'jetpack'
318
							);
319
							?>
320
						</p>
321
322
						<p class="jp-banner__button-container">
323
							<a href="<?php echo esc_url( $this->build_connect_url_for_slide( '44', 2 ) ); ?>" class="dops-button is-primary">
324
								<?php esc_html_e( 'Connect to WordPress.com', 'jetpack' ); ?>
325
							</a>
326
							<a href="#" class="dops-button next-feature" title="<?php esc_attr_e( 'Jetpack Tour: Next Feature', 'jetpack' ); ?>">
327
								<?php esc_html_e( 'Next feature', 'jetpack' ); ?>
328
							</a>
329
							<span class="jp-banner__tos-blurb">
330
								<?php jetpack_render_tos_blurb(); ?>
331
							</span>
332
						</p>
333
					</div> <!-- end slide 2 -->
334
335
					<!-- slide 3: security -->
336
					<div class="jp-wpcom-connect__slide jp-wpcom-connect__slide-three">
337
						<h2><?php esc_html_e( 'Multiple security tools to give you peace of mind', 'jetpack' ) ?></h2>
338
339
						<div class="jp-wpcom-connect__content-icon jp-connect-illo">
340
							<img src="<?php echo plugins_url( 'jetpack/images/security.svg', dirname( __FILE__ ) ); ?>" alt="<?php 
341
									esc_attr_e( 
342
										'Your site is automatically protected from brute force attacks, plus you can use single sign-on for extra security', 
343
									'jetpack' 
344
								); ?>" height="auto" width="250" />
345
						</div>
346
347
						<p>
348
							<?php
349
							esc_html_e(
350
								'Jetpack protects your site against brute force attacks and unauthorized logins. We also monitor your site for downtime and keep your plugins updated.',
351
								'jetpack'
352
							);
353
							?>
354
						</p>
355
356
						<p>
357
							<?php
358
							esc_html_e(
359
								'Customers on paid plans also benefit from unlimited backups of your entire site, spam protection, malware scanning, and automated fixes.',
360
								'jetpack'
361
							);
362
							?>
363
						</p>
364
365
						<p>
366
							<?php
367
							esc_html_e(
368
								'We also offer free support to all users, and priority assistance to paid customers.',
369
								'jetpack'
370
							);
371
							?>
372
						</p>
373
374
						<p class="jp-banner__button-container">
375
							<a
376
								href="<?php echo esc_url( $this->build_connect_url_for_slide( '44', 3 ) ); ?>"
377
								class="dops-button is-primary">
378
								<?php esc_html_e( 'Connect to WordPress.com', 'jetpack' ); ?>
379
							</a>
380
							<a href="#" class="dops-button next-feature" title="<?php esc_attr_e( 'Jetpack Tour: Next Feature', 'jetpack' ); ?>">
381
								<?php esc_html_e( 'Next feature', 'jetpack' ); ?>
382
							</a>
383
							<span class="jp-banner__tos-blurb">
384
								<?php jetpack_render_tos_blurb(); ?>
385
							</span>
386
						</p>
387
					</div> <!-- end slide 3 -->
388
389
					<!-- slide 3A: themes -->
390
					<div class="jp-wpcom-connect__slide jp-wpcom-connect__slide-three-a">
391
						<h2><?php esc_html_e( 'Hundreds of beautiful themes to choose from', 'jetpack' ) ?></h2>
392
393
						<div class="jp-wpcom-connect__content-icon jp-connect-illo">
394
							<img src="<?php echo plugins_url( 'jetpack/images/customize-theme.svg', dirname( __FILE__ ) ); ?>" alt="<?php 
395
									esc_attr_e( 
396
										'Choosing a design for your site is essential. It defines your brand, your layout, and your visitors’ reading experience', 
397
									'jetpack' 
398
								); ?>" height="auto" width="250" />
399
						</div>
400
401
						<p>
402
							<?php
403
							esc_html_e(
404
								'Choosing a design for your site is essential. It defines your brand, your layout, and your visitors’ reading experience.',
405
								'jetpack'
406
							);
407
							?>
408
						</p>
409
410
						<p>
411
							<?php
412
							esc_html_e(
413
								'Jetpack reduces complexity and makes this previously difficult process a breeze. Browse hundreds of themes in our showcase, or search by theme, name, style, color, or type.',
414
								'jetpack'
415
							);
416
							?>
417
						</p>
418
419
						<p>
420
							<?php
421
							esc_html_e(
422
								'Preview, install, and activate with one-click, then use our suite of design tools to make it look just as you need it to.',
423
								'jetpack'
424
							);
425
							?>
426
						</p>
427
428
						<p class="jp-banner__button-container">
429
							<a
430
								href="<?php echo esc_url( $this->build_connect_url_for_slide( '44', '3a' ) ); ?>"
431
								class="dops-button is-primary">
432
								<?php esc_html_e( 'Connect to WordPress.com', 'jetpack' ); ?>
433
							</a>
434
							<a href="#" class="dops-button next-feature" title="<?php esc_attr_e( 'Jetpack Tour: Next Feature', 'jetpack' ); ?>">
435
								<?php esc_html_e( 'Next feature', 'jetpack' ); ?>
436
							</a>
437
							<span class="jp-banner__tos-blurb">
438
								<?php jetpack_render_tos_blurb(); ?>
439
							</span>
440
						</p>
441
					</div> <!-- end slide 3A -->
442
443
444
					<!-- slide 4: Performance -->
445
					<div class="jp-wpcom-connect__slide jp-wpcom-connect__slide-four">
446
						<h2><?php esc_html_e( 'Faster site speeds through the WordPress.com CDN', 'jetpack' ) ?></h2>
447
448
						<div class="jp-wpcom-connect__content-icon jp-connect-illo">
449
							<img src="<?php echo plugins_url( 'jetpack/images/cloud-based.svg', dirname( __FILE__ ) ); ?>" alt="<?php 
450
									esc_attr_e( 
451
										'Jetpack automatically optimizes and speeds up images using the global WordPress.com Content Delivery Network (CDN)', 
452
									'jetpack' 
453
								); ?>" height="auto" width="225" />
454
						</div>
455
456
						<p>
457
							<?php
458
							esc_html_e(
459
								'Jetpack automatically optimizes and speeds up images using the global WordPress.com Content Delivery Network (CDN). Let us do the heavy lifting for you by reducing bandwidth usage which could potentially lower your hosting costs.',
460
								'jetpack'
461
							);
462
							?>
463
						</p>
464
465
						<p>
466
							<?php
467
							esc_html_e(
468
								'Use of our CDN is unlimited and scales with your site for free. You can also use it for your theme images to further speed up your site.',
469
								'jetpack'
470
							);
471
							?>
472
						</p>
473
474
						<p class="jp-banner__button-container">
475
							<a href="<?php echo esc_url( $this->build_connect_url_for_slide( '44', 4 ) ); ?>" class="dops-button is-primary">
476
								<?php esc_html_e( 'Connect to WordPress.com', 'jetpack' ); ?>
477
							</a>
478
							<a href="#" class="dops-button next-feature" title="<?php esc_attr_e( 'Jetpack Tour: Next Feature', 'jetpack' ); ?>">
479
								<?php esc_html_e( 'Next feature', 'jetpack' ); ?>
480
							</a>
481
							<span class="jp-banner__tos-blurb">
482
								<?php jetpack_render_tos_blurb(); ?>
483
							</span>
484
						</p>
485
					</div> <!-- end slide 4 -->
486
487
					<!-- slide 5: Apps -->
488
					<div class="jp-wpcom-connect__slide jp-wpcom-connect__slide-five">
489
						<h2><?php esc_html_e( 'Free WordPress apps to manage your site(s) from any device', 'jetpack' ) ?></h2>
490
491
						<div class="jp-wpcom-connect__content-icon jp-connect-illo">
492
							<img src="<?php echo plugins_url( 'jetpack/images/apps.svg', dirname( __FILE__ ) ); ?>" alt="<?php 
493
									esc_attr_e( 
494
										'Our mobile and desktop apps are free and available to you on Apple or Android devices once Jetpack is connected to WordPress.com', 
495
									'jetpack' 
496
								); ?>" height="auto" width="225" />
497
						</div>
498
499
						<p>
500
							<?php
501
							esc_html_e(
502
								'Publish content, track stats, moderate comments and so much more from anywhere in the world. Our mobile and desktop apps are free and available to you on Apple or Android devices once Jetpack is connected to WordPress.com.',
503
								'jetpack'
504
							);
505
							?>
506
						</p>
507
508
						<p>
509
							<?php
510
							esc_html_e(
511
								'When Jetpack is connected to WordPress.com, head over to the Apps tab within Jetpack for direct links to the mobile and desktop apps.',
512
								'jetpack'
513
							);
514
							?>
515
						</p>
516
517
						<p class="jp-banner__button-container">
518
							<a href="<?php echo esc_url( $this->build_connect_url_for_slide( '44', 5 ) ); ?>" class="dops-button is-primary">
519
								<?php esc_html_e( 'Connect to WordPress.com', 'jetpack' ); ?>
520
							</a>
521
							<a href="#" class="dops-button next-feature" title="<?php esc_attr_e( 'Jetpack Tour: Next Feature', 'jetpack' ); ?>">
522
								<?php esc_html_e( 'Next feature', 'jetpack' ); ?>
523
							</a>
524
							<span class="jp-banner__tos-blurb">
525
								<?php jetpack_render_tos_blurb(); ?>
526
							</span>
527
						</p>
528
					</div> <!-- end slide 5 -->
529
530
					<!-- slide 6: more features -->
531
					<div class="jp-wpcom-connect__slide jp-wpcom-connect__slide-six">
532
						<h2><?php esc_html_e( 'More Jetpack features our users love', 'jetpack' ) ?></h2>
533
534
						<div class="jp-wpcom-connect__content-icon jp-connect-illo">
535
							<img src="<?php echo plugins_url( 'jetpack/images/customize-theme-2.svg', dirname( __FILE__ ) ); ?>" alt="<?php 
536
									esc_attr_e( 
537
										'Jetpack includes other features that help you customize your site', 
538
									'jetpack' 
539
								); ?>" height="auto" width="225" />
540
						</div>
541
542
						<p>
543
							<?php
544
							esc_html_e(  'Jetpack includes other features that help you customize your site including Custom CSS, Contact Forms, Galleries and Carousels, Notifications and Subscriptions, Configurable Widgets, and many more.',
545
								'jetpack'
546
							);
547
							?>
548
						</p>
549
550
						<p>
551
							<?php
552
							esc_html_e(  'Connect to WordPress.com to get started',
553
								'jetpack'
554
							);
555
							?>
556
							<a href="https://jetpack.com/features" target="_blank">
557
								<?php esc_html_e( 'or visit our site for the full feature list.', 'jetpack' ); ?>
558
							</a>
559
						</p>
560
561
						<p class="jp-banner__button-container">
562
							<a
563
								href="<?php echo esc_url( $this->build_connect_url_for_slide( '44', 6 ) ); ?>"
564
								class="dops-button is-primary">
565
								<?php esc_html_e( 'Connect to WordPress.com', 'jetpack' ); ?>
566
							</a>
567
							<span class="jp-banner__tos-blurb">
568
								<?php jetpack_render_tos_blurb(); ?>
569
							</span>
570
						</p>
571
					</div> <!-- end slide 6 -->
572
				</div>
573
			</div>
574
		</div>
575
		<?php
576
	}
577
578
	/**
579
	 * Renders a split-test banner as of 5.3.0.
580
	 *
581
	 * @since 5.3.0
582
	 */
583
	function render_banner_b() { ?>
584
		<div id="message" class="updated jp-wpcom-connect__container">
585
			<div class="jp-wpcom-connect__inner-container">
586
				<span
587
					class="notice-dismiss connection-banner-dismiss"
588
					title="<?php esc_attr_e( 'Dismiss this notice', 'jetpack' ); ?>">
589
				</span>
590
591
				<div class="jp-wpcom-connect__vertical-nav">
592
					<div class="jp-wpcom-connect__vertical-nav-container">
593
						<div class="vertical-menu__feature-item jp-feature-intro vertical-menu__feature-item-is-selected">
594
							<div class="vertical-menu__feature-item-icon">
595
								<svg class="jp-wpcom-connect__svg-jetpack" xmlns="http://www.w3.org/2000/svg" width="20" height="20" viewBox="0 1 20 20" version="1.1"><path d="M14.4 11.3L10.5 18.1 10.5 8.7 13.7 9.5C14.5 9.7 14.9 10.6 14.4 11.3L14.4 11.3ZM9.6 13.3L6.5 12.5C5.7 12.3 5.3 11.4 5.7 10.7L9.6 3.9 9.6 13.3ZM10 1C4.5 1 0 5.5 0 11 0 16.5 4.5 21 10 21 15.5 21 20 16.5 20 11 20 5.5 15.5 1 10 1L10 1Z" /></svg>
596
							</div>
597
							<span class="vertical-menu__feature-item-label"><?php esc_html_e( 'Welcome to Jetpack', 'jetpack' ); ?></span>
598
						</div>
599
						<div class="vertical-menu__feature-item">
600
							<div class="vertical-menu__feature-item-icon">
601
								<svg xmlns="http://www.w3.org/2000/svg" width="20" height="20" viewBox="0 2 20 20" version="1.1"><path d="M6 4L6 10.3 9 7 13.9 12.4 14.5 11.7C15.3 10.8 16.7 10.8 17.5 11.7L18 12.2 18 4 6 4ZM20 4L20 16C20 17.1 19.1 18 18 18L6 18C4.9 18 4 17.1 4 16L4 4C4 2.9 4.9 2 6 2L18 2C19.1 2 20 2.9 20 4L20 4ZM2 20L16 20 16 20C16 21.1 15.1 22 14 22L2 22C0.9 22 0 21.1 0 20L0 8C0 6.9 0.9 6 2 6L2 6 2 20ZM13 7.5C13 6.7 13.7 6 14.5 6 15.3 6 16 6.7 16 7.5 16 8.3 15.3 9 14.5 9 13.7 9 13 8.3 13 7.5L13 7.5Z" /></svg>
602
							</div>
603
							<span class="vertical-menu__feature-item-label"><?php esc_html_e( 'Create Your Site', 'jetpack' ); ?></span>
604
						</div>
605
						<div class="vertical-menu__feature-item">
606
							<div class="vertical-menu__feature-item-icon">
607
								<svg xmlns="http://www.w3.org/2000/svg" width="20" height="20" viewBox="0 2 20 20" version="1.1"><path d="M7.8 17.6L12.2 17.6 12.2 2 7.8 2 7.8 17.6ZM14.4 17.6L18.9 17.6 18.9 5.3 14.4 5.3 14.4 17.6ZM1.1 17.6L5.6 17.6 5.6 9.8 1.1 9.8 1.1 17.6ZM0 22L20 22 20 19.8 0 19.8 0 22Z" /></svg>
608
							</div>
609
							<span class="vertical-menu__feature-item-label"><?php esc_html_e( 'Make It Successful', 'jetpack' ); ?></span>
610
						</div>
611
						<div class="vertical-menu__feature-item">
612
							<div class="vertical-menu__feature-item-icon">
613
								<svg xmlns="http://www.w3.org/2000/svg" width="16" height="20" viewBox="0 1 16 20" version="1.1"><defs><polygon points="16 10 16 0 0 0 0 10 0 20 16 20"/></defs><g stroke="none" stroke-width="1" transform="translate(0.000000, 1.000000)"><mask fill="white"/><path d="M9 13.7L9 16 7 16 7 13.7C6.4 13.4 6 12.7 6 12 6 10.9 6.9 10 8 10 9.1 10 10 10.9 10 12 10 12.7 9.6 13.4 9 13.7L9 13.7ZM5 5C5 3.3 6.3 2 8 2 9.7 2 11 3.3 11 5L11 6 5 6 5 5ZM14 6L13 6 13 5C13 2.2 10.8 0 8 0 5.2 0 3 2.2 3 5L3 6 2 6C0.9 6 0 6.9 0 8L0 18C0 19.1 0.9 20 2 20L14 20C15.1 20 16 19.1 16 18L16 8C16 6.9 15.1 6 14 6L14 6Z" mask="url(#mask-2)"/></g></svg>
614
							</div>
615
							<span class="vertical-menu__feature-item-label"><?php esc_html_e( 'Keep It Safe', 'jetpack' ); ?></span>
616
						</div>
617
					</div>
618
				</div>
619
				<div class="jp-wpcom-connect__content-container">
620
621
					<!-- slide 1: intro -->
622
					<div class="jp-wpcom-connect__slide jp-wpcom-connect__slide-one jp__slide-is-active">
623
						<h2><?php esc_html_e( 'Welcome to Jetpack', 'jetpack' ) ?></h2>
624
625
						<div class="jp-wpcom-connect__content-icon jp-connect-illo">
626
							<img src="<?php echo plugins_url( 'jetpack/images/jetpack-welcome.svg', dirname( __FILE__ ) ); ?>" alt="Your site is automatically protected from brute force attacks, plus you can use single sign-on for extra security." height="auto" width="250" />
627
						</div>
628
629
						<p>
630
							<?php
631
							esc_html_e(
632
								'Jetpack is the best way to experience WordPress, whether your site is brand new or already well established.',
633
								'jetpack'
634
							);
635
							?>
636
						</p>
637
638
						<p>
639
							<?php
640
							esc_html_e(
641
								'You get themes and tools to design your site, marketing services to make it successful, and state-of-the-art security.',
642
								'jetpack'
643
							);
644
							?>
645
						</p>
646
647
						<p>
648
							<?php
649
							esc_html_e(
650
								'Connect to WordPress.com (free) to get started.',
651
								'jetpack'
652
							);
653
							?>
654
						</p>
655
656
						<p class="jp-banner__button-container">
657
							<a
658
								href="<?php echo esc_url( $this->build_connect_url_for_slide( '53', 1 ) ); ?>"
659
								class="dops-button is-primary">
660
								<?php esc_html_e( 'Connect to WordPress.com', 'jetpack' ); ?>
661
							</a>
662
							<a
663
								href="#"
664
								class="dops-button next-feature"
665
								title="<?php
666
								esc_attr_e(
667
									'Start tour to Learn about the benefits you receive when you connect Jetpack to WordPress.com',
668
									'jetpack'
669
								);
670
								?>">
671
								<?php esc_html_e( 'Start quick tour', 'jetpack' ); ?>
672
							</a>
673
							<span class="jp-banner__tos-blurb">
674
								<?php jetpack_render_tos_blurb(); ?>
675
							</span>
676
						</p>
677
					</div> <!-- end slide 1 -->
678
679
					<!-- slide 2: design -->
680
					<div class="jp-wpcom-connect__slide jp-wpcom-connect__slide-two">
681
						<h2><?php esc_html_e( 'Code-Free Design and Publishing', 'jetpack' ) ?></h2>
682
683
						<div class="jp-wpcom-connect__content-icon jp-connect-illo">
684
							<img src="<?php echo plugins_url( 'jetpack/images/customize-theme.svg', dirname( __FILE__ ) ); ?>" alt="Customization tools and widgets help you make your site look great without writing any code" height="auto" width="225" />
685
						</div>
686
687
						<p>
688
							<?php
689
							esc_html_e(
690
								'Jetpack gives you access to more than 100 free and 200 premium WordPress themes.',
691
								'jetpack'
692
							);
693
							?>
694
						</p>
695
696
						<p>
697
							<?php
698
							esc_html_e(
699
								'Customization tools and widgets help you make your site look great without writing any code, and our CDN speeds up your images.',
700
								'jetpack'
701
							);
702
							?>
703
						</p>
704
705
						<p>
706
							<?php
707
							esc_html_e(
708
								'Publish with ease using WordPress.com or the official WordPress mobile apps.',
709
								'jetpack'
710
							);
711
							?>
712
						</p>
713
714
						<p class="jp-banner__button-container">
715
							<a href="<?php echo esc_url( $this->build_connect_url_for_slide( '53', 2 ) ); ?>" class="dops-button is-primary">
716
								<?php esc_html_e( 'Connect to WordPress.com', 'jetpack' ); ?>
717
							</a>
718
							<a href="#" class="dops-button next-feature" title="<?php esc_attr_e( 'Jetpack Tour: Next Feature', 'jetpack' ); ?>">
719
								<?php esc_html_e( 'Next feature', 'jetpack' ); ?>
720
							</a>
721
							<span class="jp-banner__tos-blurb">
722
								<?php jetpack_render_tos_blurb(); ?>
723
							</span>
724
						</p>
725
					</div> <!-- end slide 2 -->
726
727
					<!-- slide 3: marketing -->
728
					<div class="jp-wpcom-connect__slide jp-wpcom-connect__slide-three">
729
						<h2><?php esc_html_e( 'Get The Traffic You Deserve', 'jetpack' ) ?></h2>
730
731
						<div class="jp-wpcom-connect__content-icon jp-connect-illo">
732
							<img src="<?php echo plugins_url( 'jetpack/images/stats-people.svg', dirname( __FILE__ ) ); ?>" alt="Get clear and concise stats and analytics about your visitors." height="auto" width="265" />
733
						</div>
734
735
						<p>
736
							<?php
737
							esc_html_e(
738
								'A site without traffic is like a car without gas. Jetpack helps you fill up so that you can achieve your goals.',
739
								'jetpack'
740
							);
741
							?>
742
						</p>
743
744
						<p>
745
							<?php
746
							esc_html_e(
747
								'Kickstart your marketing with social media automation tools, related content, email subscriptions, and sharing tools.',
748
								'jetpack'
749
							);
750
							?>
751
						</p>
752
753
						<p>
754
							<?php
755
							esc_html_e(
756
								'You also get clear and concise stats and analytics about your visitors.',
757
								'jetpack'
758
							);
759
							?>
760
						</p>
761
762
						<p class="jp-banner__button-container">
763
							<a
764
								href="<?php echo esc_url( $this->build_connect_url_for_slide( '53', 3 ) ); ?>"
765
								class="dops-button is-primary">
766
								<?php esc_html_e( 'Connect to WordPress.com', 'jetpack' ); ?>
767
							</a>
768
							<a href="#" class="dops-button next-feature" title="<?php esc_attr_e( 'Jetpack Tour: Next Feature', 'jetpack' ); ?>">
769
								<?php esc_html_e( 'Next feature', 'jetpack' ); ?>
770
							</a>
771
							<span class="jp-banner__tos-blurb">
772
								<?php jetpack_render_tos_blurb(); ?>
773
							</span>
774
						</p>
775
					</div> <!-- end slide 3 -->
776
777
					<!-- slide 4: security -->
778
					<div class="jp-wpcom-connect__slide jp-wpcom-connect__slide-four">
779
						<h2><?php esc_html_e( 'Make Sure Your Site Is Always Online', 'jetpack' ) ?></h2>
780
781
						<div class="jp-wpcom-connect__content-icon jp-connect-illo">
782
							<img src="<?php echo plugins_url( 'jetpack/images/security.svg', dirname( __FILE__ ) ); ?>" alt="Your site is automatically protected from brute force attacks, plus you can use single sign-on for extra security." height="auto" width="250" />
783
						</div>
784
785
						<p>
786
							<?php
787
							esc_html_e(  'Jetpack checks your site every few minutes, and if it\'s offline we\'ll notify you instantly.',
788
								'jetpack'
789
							);
790
							?>
791
						</p>
792
793
						<p>
794
							<?php
795
							esc_html_e(  'Your site is automatically protected from brute force attacks, plus you can use single sign-on for extra security.',
796
								'jetpack'
797
							);
798
							?>
799
						</p>
800
801
						<p>
802
							<?php
803
							esc_html_e(  'Paying customers also benefit from automated backups, malware scans, and priority support.',
804
								'jetpack'
805
							);
806
							?>
807
						</p>
808
809
						<p class="jp-banner__button-container">
810
							<a
811
								href="<?php echo esc_url( $this->build_connect_url_for_slide( '53', 4 ) ); ?>"
812
								class="dops-button is-primary">
813
								<?php esc_html_e( 'Connect to WordPress.com', 'jetpack' ); ?>
814
							</a>
815
							<span class="jp-banner__tos-blurb">
816
								<?php jetpack_render_tos_blurb(); ?>
817
							</span>
818
						</p>
819
					</div> <!-- end slide 4 -->
820
				</div>
821
			</div>
822
		</div>
823
		<?php
824
	}
825
826
	/**
827
	 * Renders the full-screen connection prompt.  Only shown once and on plugin activation.
828
	 */
829
	function render_connect_prompt_full_screen() {
830
		?>
831
		<div class="jp-connect-full__container">
832
833
			<?php // planet + star svgs ?>
834
835
			<svg class="jp-connect-full__svg-stars" xmlns="http://www.w3.org/2000/svg" width="56" height="54" viewBox="0 0 56 54" version="1.1"><g stroke="none" stroke-width="1" fill="none" fill-rule="evenodd" opacity="0.95"><g transform="translate(-268.000000, -101.000000)" fill="#C8D7E1"><g transform="translate(160.000000, 32.000000)"><g transform="translate(104.000000, 69.000000)"><polyline points="53.6 10.3 59.3 8 53.6 5.7 51.3 0 49 5.7 43.3 8 49 10.3 51.3 16 53.6 10.3"/><polyline transform="translate(8.757724, 49.487494) rotate(315.000000) translate(-8.757724, -49.487494) " points="10.5 51.2 14.8 49.5 10.5 47.8 8.8 43.5 7 47.8 2.8 49.5 7 51.2 8.8 55.5 10.5 51.2"/></g></g></g></g></svg>
836
837
			<svg class="jp-connect-full__svg-jupiter" xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink" width="50" height="100" viewBox="0 0 50 100" version="1.1"><defs><path d="M0.95 40.37C-4.37 67.46 13.27 93.73 40.37 99.05 67.46 104.37 93.73 86.73 99.05 59.63 104.37 32.54 86.73 6.27 59.63 0.95 32.54-4.37 6.27 13.27 0.95 40.37" id="path-1"/></defs><g id="Welcome" stroke="none" stroke-width="1" fill="none" fill-rule="evenodd" opacity="0.5"><g id="v1.2" transform="translate(-1215.000000, -93.000000)"><g id="lrg-planet-+-jupiter-Mask" transform="translate(160.000000, 32.000000)"><g id="jupiter" transform="translate(1055.000000, 61.000000)"><path d="M0.94 40.19C-4.36 67.16 13.22 93.32 40.19 98.62 67.16 103.92 93.32 86.35 98.62 59.37 103.92 32.4 86.35 6.24 59.37 0.94 32.4-4.36 6.24 13.22 0.94 40.19" id="jupFill-1" fill="#C8D7E1"/><g id="jupGroup-17"><mask id="mask-jup" fill="white"><use xlink:href="#path-1"/></mask><g id="jupClip-3"/><path d="M49.59 38.06C51.29 29.39 59.7 23.73 68.38 25.44 77.05 27.14 82.7 35.55 81 44.23 79.3 52.9 70.88 58.55 62.21 56.85 53.53 55.15 47.88 46.73 49.59 38.06" id="jupFill-2" fill="#E9EFF3" mask="url(#mask-jup)"/><path d="M53.93 52.41C48.66 47.1 42.15 43.21 34.98 41.08L37.21 29.74C44.64 30.48 52.15 29.34 59.03 26.41L53.93 52.41" id="jupFill-4" fill="#E9EFF3" mask="url(#mask-jup)"/><path d="M30.93 34.4C31.55 31.25 34.6 29.2 37.75 29.82 40.89 30.43 42.94 33.49 42.32 36.63 41.71 39.78 38.65 41.83 35.51 41.21 32.36 40.59 30.31 37.54 30.93 34.4" id="jupFill-5" fill="#E9EFF3" mask="url(#mask-jup)"/><polyline id="jupFill-9" fill="#E9EFF3" mask="url(#mask-jup)" points="35.54 41.22 -14.22 31.44 -11.99 20.08 37.77 29.85 35.54 41.22"/><path d="M30.34 67.29C31.4 61.93 36.59 58.44 41.95 59.49 47.31 60.54 50.8 65.74 49.75 71.1 48.69 76.46 43.5 79.95 38.14 78.89 32.78 77.84 29.29 72.65 30.34 67.29" id="jupFill-10" fill="#E9EFF3" mask="url(#mask-jup)"/><path d="M33.02 76.15C29.77 72.87 25.75 70.47 21.32 69.15L22.7 62.15C27.29 62.61 31.93 61.9 36.18 60.09L33.02 76.15" id="jupFill-11" fill="#E9EFF3" mask="url(#mask-jup)"/><path d="M18.82 65.02C19.2 63.08 21.09 61.82 23.03 62.2 24.97 62.58 26.24 64.46 25.86 66.41 25.48 68.35 23.59 69.62 21.65 69.23 19.7 68.85 18.44 66.97 18.82 65.02" id="jupFill-12" fill="#E9EFF3" mask="url(#mask-jup)"/><path d="M43.91 78.29C48.16 76.49 52.8 75.78 57.39 76.24L58.77 69.23C54.34 67.92 50.32 65.51 47.07 62.23L43.91 78.29" id="jupFill-13" fill="#E9EFF3" mask="url(#mask-jup)"/><polyline id="jupFill-16" fill="#E9EFF3" mask="url(#mask-jup)" points="21.67 69.24 -67.61 51.7 -66.23 44.68 23.05 62.22 21.67 69.24"/></g><path d="M35.02 68.89C35.07 65.99 37.47 63.68 40.37 63.74 43.28 63.79 45.58 66.19 45.53 69.09 45.47 72 43.07 74.3 40.17 74.25 37.27 74.19 34.96 71.79 35.02 68.89" id="jupFill-18" fill="#E9EFF3"/></g></g></g></g></svg>
838
839
840
			<div class="jp-connect-full__dismiss">
841
				<svg class="jp-connect-full__svg-dismiss" xmlns="http://www.w3.org/2000/svg" width="24" height="24" viewBox="0 0 24 24"><title>Dismiss Jetpack Connection Window</title><rect x="0" fill="none" /><g><path d="M17.705 7.705l-1.41-1.41L12 10.59 7.705 6.295l-1.41 1.41L10.59 12l-4.295 4.295 1.41 1.41L12 13.41l4.295 4.295 1.41-1.41L13.41 12l4.295-4.295z"/></g></svg>
842
			</div>
843
844
			<div class="jp-connect-full__step-header">
845
				<div class="jp-connect-full__step-header-logos">
846
847
					<svg class="jp-connect-full__svg-jetpack" xmlns="http://www.w3.org/2000/svg" width="60" height="60" viewBox="0 1 20 20" version="1.1"><path d="M14.4 11.3L10.5 18.1 10.5 8.7 13.7 9.5C14.5 9.7 14.9 10.6 14.4 11.3L14.4 11.3ZM9.6 13.3L6.5 12.5C5.7 12.3 5.3 11.4 5.7 10.7L9.6 3.9 9.6 13.3ZM10 1C4.5 1 0 5.5 0 11 0 16.5 4.5 21 10 21 15.5 21 20 16.5 20 11 20 5.5 15.5 1 10 1L10 1Z" /></svg>
848
849
					<svg class="jp-connect-full__svg-sync" xmlns="http://www.w3.org/2000/svg" width="24" height="24" viewBox="0 0 24 24"><title>Connect Jetpack to WordPress.com</title><rect x="0" fill="none" /><g><path d="M23.5 13.5l-3.086 3.086L19 18l-4.5-4.5 1.414-1.414L18 14.172V12c0-3.308-2.692-6-6-6V4c4.418 0 8 3.582 8 8v2.172l2.086-2.086L23.5 13.5zM6 12V9.828l2.086 2.086L9.5 10.5 5 6 3.586 7.414.5 10.5l1.414 1.414L4 9.828V12c0 4.418 3.582 8 8 8v-2c-3.308 0-6-2.692-6-6z"/></g></svg>
850
851
					<svg class="jp-connect-full__svg-wpcom" xmlns="http://www.w3.org/2000/svg" width="60" height="60" viewBox="0 2 20 20" version="1.1"><defs><polygon points="0 20 20 20 20 0 0 0 0 20"/></defs><g stroke="none" stroke-width="1" fill="none" fill-rule="evenodd" transform="translate(0.000000, 2.000000)"><mask fill="white"/><path d="M14.3 17.3L16.9 9.8C17.4 8.6 17.5 7.7 17.5 6.8 17.5 6.5 17.5 6.2 17.5 5.9 18.1 7.1 18.5 8.5 18.5 10 18.5 13.1 16.8 15.9 14.3 17.3L14.3 17.3ZM11.2 6C11.7 6 12.1 5.9 12.1 5.9 12.6 5.9 12.5 5.2 12.1 5.2 12.1 5.2 10.7 5.3 9.8 5.3 9 5.3 7.6 5.2 7.6 5.2 7.1 5.2 7.1 5.9 7.5 5.9 7.5 5.9 8 6 8.4 6L9.7 9.6 7.9 15.2 4.8 6C5.3 6 5.8 5.9 5.8 5.9 6.2 5.9 6.2 5.2 5.7 5.2 5.7 5.2 4.3 5.3 3.4 5.3 3.3 5.3 3.1 5.3 2.9 5.3 4.4 3 7 1.5 10 1.5 12.2 1.5 14.2 2.3 15.7 3.7 15.7 3.7 15.7 3.7 15.6 3.7 14.8 3.7 14.2 4.5 14.2 5.2 14.2 5.9 14.6 6.5 15 7.2 15.4 7.8 15.7 8.5 15.7 9.6 15.7 10.3 15.5 11.1 15.1 12.3L14.2 15.2 11.2 6ZM10 18.5C9.2 18.5 8.4 18.4 7.6 18.2L10.1 10.7 12.8 17.9C12.8 17.9 12.8 18 12.8 18 11.9 18.3 11 18.5 10 18.5L10 18.5ZM1.5 10C1.5 8.8 1.8 7.6 2.2 6.5L6.3 17.7C3.5 16.3 1.5 13.4 1.5 10L1.5 10ZM10 0C4.5 0 0 4.5 0 10 0 15.5 4.5 20 10 20 15.5 20 20 15.5 20 10 20 4.5 15.5 0 10 0L10 0Z" fill="#86A6BD" mask="url(#mask-2)"/></g></svg>
852
853
				</div>
854
				<h2 class="jp-connect-full__step-header-title"><?php esc_html_e( 'Connect Jetpack to WordPress.com', 'jetpack' ) ?></h2>
855
			</div>
856
857
			<div class="jp-connect-full__card">
858
				<div class="jp-connect-full__card-inner">
859
					<p class="jp-connect-full__card-description">
860
						<?php
861
						esc_html_e(
862
							'Get detailed visitor stats, state-of-the-art security services, image performance upgrades, traffic generation tools, and more. Connect to WordPress.com to get started!',
863
							'jetpack'
864
						);
865
						?>
866
					</p>
867
				</div>
868
				<div class="jp-connect-full__card-footer">
869
					<p class="jp-connect-full__tos-blurb">
870
						<?php jetpack_render_tos_blurb(); ?>
871
					</p>
872
					<p class="jp-connect-full__button-container">
873
						<a href="<?php echo esc_url( Jetpack::init()->build_connect_url( true, false, 'full-screen-prompt' ) ); ?>" class="dops-button is-primary">
874
							<?php esc_html_e( 'Connect to WordPress.com', 'jetpack' ); ?>
875
						</a>
876
					</p>
877
				</div>
878
			</div>
879
			<a class="jp-connect-full__help-button" href="https://jetpack.com/contact-support" target="_blank">
880
				<svg class="gridicon gridicons-help-outline" height="18" width="18" xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24"><g><path d="M12 4c4.41 0 8 3.59 8 8s-3.59 8-8 8-8-3.59-8-8 3.59-8 8-8m0-2C6.477 2 2 6.477 2 12s4.477 10 10 10 10-4.477 10-10S17.523 2 12 2zm4 8c0-2.21-1.79-4-4-4s-4 1.79-4 4h2c0-1.103.897-2 2-2s2 .897 2 2-.897 2-2 2c-.552 0-1 .448-1 1v2h2v-1.14c1.722-.447 3-1.998 3-3.86zm-3 6h-2v2h2v-2z"></path></g></svg>
881
				<?php esc_html_e( 'Get help connecting your site', 'jetpack' ); ?>
882
			</a>
883
		</div>
884
		<?php
885
	}
886
887
	/**
888
	 * Renders the legacy network connection banner.
889
	 */
890
	function network_connect_notice() {
891
		?>
892
		<div id="message" class="updated jetpack-message">
893
			<div class="squeezer">
894
				<h2>
895
					<?php
896
						echo wp_kses(
897
							__(
898
								'<strong>Jetpack is activated!</strong> Each site on your network must be connected individually by an admin on that site.',
899
								'jetpack'
900
							),
901
							array( 'strong' => array() )
902
						);
903
					?>
904
				</h2>
905
			</div>
906
		</div>
907
		<?php
908
	}
909
}
910