1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
|
<?php namespace Automattic\WooCommerce\Internal\ComingSoon;
use Automattic\WooCommerce\Admin\WCAdminHelper;
/** * Provides helper methods for coming soon functionality. */ class ComingSoonHelper {
/** * Returns true when the entire site is live. */ public function is_site_live(): bool { return 'yes' !== get_option( 'woocommerce_coming_soon' ); }
/** * Returns true when the entire site is coming soon mode. */ public function is_site_coming_soon(): bool { return 'yes' === get_option( 'woocommerce_coming_soon' ) && 'yes' !== get_option( 'woocommerce_store_pages_only' ); }
/** * Returns true when only the store pages are in coming soon mode. */ public function is_store_coming_soon(): bool { return 'yes' === get_option( 'woocommerce_coming_soon' ) && 'yes' === get_option( 'woocommerce_store_pages_only' ); }
/** * Returns true when the provided URL is behind a coming soon screen. * * @param string $url The URL to check. */ public function is_url_coming_soon( string $url ): bool { // Early exit if coming soon mode not active. if ( $this->is_site_live() ) { return false; }
if ( $this->is_site_coming_soon() ) { return true; }
// Check the URL is a store page when in "store coming soon" mode. if ( $this->is_store_coming_soon() && WCAdminHelper::is_store_page( $url ) ) { return true; }
// Default to false. return false; }
/** * Builds the relative URL from the WP instance. * * @internal * @link https://wordpress.stackexchange.com/a/274572 * @param \WP $wp WordPress environment instance. */ public function get_url_from_wp( \WP $wp ) { return home_url( add_query_arg( $wp->query_vars, $wp->request ) ); } }
|