|
1
|
|
|
<?php |
|
2
|
|
|
|
|
3
|
|
|
declare(strict_types=1); |
|
4
|
|
|
|
|
5
|
|
|
/** |
|
6
|
|
|
* Registration Registrar for Shared Meta Boxes. |
|
7
|
|
|
* |
|
8
|
|
|
* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS |
|
9
|
|
|
* "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT |
|
10
|
|
|
* LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR |
|
11
|
|
|
* A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT |
|
12
|
|
|
* OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, |
|
13
|
|
|
* SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT |
|
14
|
|
|
* LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, |
|
15
|
|
|
* DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY |
|
16
|
|
|
* THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT |
|
17
|
|
|
* (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE |
|
18
|
|
|
* OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. |
|
19
|
|
|
* |
|
20
|
|
|
* @author Glynn Quelch <[email protected]> |
|
21
|
|
|
* @license http://www.opensource.org/licenses/mit-license.html MIT License |
|
22
|
|
|
* @package PinkCrab\Registerables |
|
23
|
|
|
* @since 0.7.0 |
|
24
|
|
|
*/ |
|
25
|
|
|
|
|
26
|
|
|
namespace PinkCrab\Registerables\Registrar; |
|
27
|
|
|
|
|
28
|
|
|
use Exception; |
|
29
|
|
|
use PinkCrab\Registerables\Meta_Data; |
|
30
|
|
|
use PinkCrab\Registerables\Registrar\Registrar; |
|
31
|
|
|
use PinkCrab\Registerables\Shared_Meta_Box_Controller; |
|
32
|
|
|
use PinkCrab\Registerables\Registrar\Meta_Box_Registrar; |
|
33
|
|
|
use PinkCrab\Registerables\Registration_Middleware\Registerable; |
|
34
|
|
|
|
|
35
|
|
|
class Shared_Meta_Box_Registrar implements Registrar { |
|
36
|
|
|
|
|
37
|
|
|
/** |
|
38
|
|
|
* The Meta Box Registrar |
|
39
|
|
|
* |
|
40
|
|
|
* @var Meta_Box_Registrar |
|
41
|
|
|
*/ |
|
42
|
|
|
protected $meta_box_registrar; |
|
43
|
|
|
|
|
44
|
|
|
public function __construct( Meta_Box_Registrar $meta_box_registrar ) { |
|
45
|
|
|
$this->meta_box_registrar = $meta_box_registrar; |
|
46
|
|
|
} |
|
47
|
|
|
|
|
48
|
|
|
/** |
|
49
|
|
|
* Used to register a registerable |
|
50
|
|
|
* |
|
51
|
|
|
* @param \PinkCrab\Registerables\Registration_Middleware\Registerable $registerable |
|
52
|
|
|
* @return void |
|
53
|
|
|
*/ |
|
54
|
|
|
public function register( Registerable $registerable ): void { |
|
55
|
|
|
if ( ! is_a( $registerable, Shared_Meta_Box_Controller::class ) ) { |
|
56
|
|
|
return; |
|
57
|
|
|
} |
|
58
|
|
|
|
|
59
|
|
|
/** @var Shared_Meta_Box_Controller $registerable, Validation call below catches no Shared_Meta_Box_Controller Registerables */ |
|
60
|
|
|
|
|
61
|
|
|
// Get the meta box and meta data. |
|
62
|
|
|
$meta_box = $registerable->meta_box(); |
|
63
|
|
|
$meta_data = $registerable->meta_data( array() ); |
|
64
|
|
|
|
|
65
|
|
|
// Register the meta box. |
|
66
|
|
|
$this->meta_box_registrar->register( $meta_box ); |
|
67
|
|
|
|
|
68
|
|
|
// Register all meta data. |
|
69
|
|
|
foreach ( $this->filter_meta_data( $meta_data ) as $meta_field ) { |
|
70
|
|
|
// Register meta data for each post type. |
|
71
|
|
|
foreach ( $meta_box->screen as $post_type ) { |
|
72
|
|
|
$this->register_meta_data_for_post_type( $meta_field, $post_type ); |
|
73
|
|
|
} |
|
74
|
|
|
} |
|
75
|
|
|
|
|
76
|
|
|
} |
|
77
|
|
|
|
|
78
|
|
|
/** |
|
79
|
|
|
* Filters all non meta data from array. |
|
80
|
|
|
* |
|
81
|
|
|
* @param mixed[] $meta_data |
|
82
|
|
|
* @return Meta_Data[] |
|
83
|
|
|
*/ |
|
84
|
|
|
protected function filter_meta_data( array $meta_data ): array { |
|
85
|
|
|
return array_filter( |
|
86
|
|
|
$meta_data, |
|
87
|
|
|
function( $e ) { |
|
88
|
|
|
return is_a( $e, Meta_Data::class ); |
|
89
|
|
|
} |
|
90
|
|
|
); |
|
91
|
|
|
} |
|
92
|
|
|
|
|
93
|
|
|
/** |
|
94
|
|
|
* Registers the Meta Data for a give post type. |
|
95
|
|
|
* |
|
96
|
|
|
* @param Meta_Data $meta_data |
|
97
|
|
|
* @param string $post_type |
|
98
|
|
|
* @return void |
|
99
|
|
|
*/ |
|
100
|
|
|
protected function register_meta_data_for_post_type( Meta_Data $meta_data, string $post_type ): void { |
|
101
|
|
|
// Clone and set the post type, while enforcing it as a post meta. |
|
102
|
|
|
$meta_data = clone $meta_data; |
|
103
|
|
|
$meta_data->object_subtype( $post_type ); |
|
104
|
|
|
$meta_data->meta_type( 'post' ); |
|
105
|
|
|
$result = register_meta( $meta_data->get_meta_type(), $meta_data->get_meta_key(), $meta_data->parse_args() ); |
|
106
|
|
|
if ( ! $result ) { |
|
107
|
|
|
throw new \Exception( "Failed to register {$meta_data->get_meta_key()} (meta) for {$post_type} post type" ); |
|
108
|
|
|
} |
|
109
|
|
|
} |
|
110
|
|
|
|
|
111
|
|
|
|
|
112
|
|
|
} |
|
113
|
|
|
|