Code Coverage |
||||||||||
Lines |
Functions and Methods |
Classes and Traits |
||||||||
Total | |
94.12% |
16 / 17 |
|
50.00% |
1 / 2 |
CRAP | |
0.00% |
0 / 1 |
Templates | |
94.12% |
16 / 17 |
|
50.00% |
1 / 2 |
6.01 | |
0.00% |
0 / 1 |
__construct | |
100.00% |
1 / 1 |
|
100.00% |
1 / 1 |
1 | |||
load_bitcoin_templates | |
93.75% |
15 / 16 |
|
0.00% |
0 / 1 |
5.01 |
1 | <?php |
2 | /** |
3 | * Register the `bitcoin-paid.php` and `bitcoin-unpaid.php` templates so they can be found with `wc_get_template()`. |
4 | * |
5 | * These templates are used on the Thank You page, Emails, and the My Account page to display payment instructions |
6 | * and details. |
7 | * |
8 | * @package brianhenryie/bh-wp-bitcoin-gateway |
9 | */ |
10 | |
11 | namespace BrianHenryIE\WP_Bitcoin_Gateway\WooCommerce; |
12 | |
13 | use BrianHenryIE\WP_Bitcoin_Gateway\Settings_Interface; |
14 | |
15 | /** |
16 | * Hooks into the wc_get_template filter called inside `wc_get_template()` to return templates inside this plugin |
17 | * if they have not already been provided by the theme or another plugin. |
18 | */ |
19 | class Templates { |
20 | |
21 | const BITCOIN_UNPAID_TEMPLATE_NAME = 'bitcoin-unpaid.php'; |
22 | const BITCOIN_PAID_TEMPLATE_NAME = 'bitcoin-paid.php'; |
23 | |
24 | /** |
25 | * Used to get the plugin directory URL. |
26 | */ |
27 | protected Settings_Interface $settings; |
28 | |
29 | /** |
30 | * Constructor. |
31 | * |
32 | * @param Settings_Interface $settings The plugin settings. |
33 | */ |
34 | public function __construct( Settings_Interface $settings ) { |
35 | $this->settings = $settings; |
36 | } |
37 | |
38 | /** |
39 | * Returns the full template path for templates defined within this plugin. |
40 | * If a template has already been specified on this filter, that is returned. |
41 | * If the template exists within the current theme, that is returned. |
42 | * |
43 | * `wc_get_template( 'bitcoin-paid.php', $formatted_order_details_array );`. |
44 | * |
45 | * @see woocommerce_locate_template |
46 | * @see https://wphave.com/include-woocommerce-templates-from-plugin/ |
47 | * |
48 | * @hooked wc_get_template |
49 | * |
50 | * @param string $template The full path to the template. Usually an incorrect (!file_exists()) path before this function runs. |
51 | * @param string $template_name The template name, i.e. the relative filename from the theme or theme/woocommerce directory. |
52 | * @param array<mixed> $args Array of values to be exploded and made available to the included template. |
53 | * @param string $template_path I'm not sure is there a difference between `$template` and `$template_path`. |
54 | * @param string $default_path Optional default path, which seems to be empty in WooCommerce core. |
55 | * |
56 | * @return string |
57 | */ |
58 | public function load_bitcoin_templates( string $template, string $template_name, array $args, string $template_path, string $default_path ): string { |
59 | |
60 | $templates = array( |
61 | self::BITCOIN_UNPAID_TEMPLATE_NAME, |
62 | self::BITCOIN_PAID_TEMPLATE_NAME, |
63 | Email::TEMPLATE_NAME, |
64 | My_Account_View_Order::TEMPLATE_NAME, |
65 | Thank_You::TEMPLATE_NAME, |
66 | Admin_Order_UI::TEMPLATE_NAME, |
67 | ); |
68 | |
69 | // Unrelated to us, leave early. |
70 | if ( ! in_array( $template_name, $templates, true ) ) { |
71 | return $template; |
72 | } |
73 | |
74 | // It will default to a string suggesting the template exists under the WooCommerce plugin directory, which will not exist. |
75 | // Or could be already set by an earlier filter, where it probably will exist. |
76 | if ( ! empty( $template ) && file_exists( $template ) ) { |
77 | return $template; |
78 | } |
79 | |
80 | // Check does it exist inside the theme. |
81 | $theme_template = locate_template( array( '/woocommerce/' . $template_name, $template_name ) ); |
82 | |
83 | if ( $theme_template ) { |
84 | return $theme_template; |
85 | } |
86 | |
87 | return $this->settings->get_plugin_dir() . 'templates/' . $template_name; |
88 | } |
89 | } |