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
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
|
<?php /** * The post field which allows users to select existing posts. * * @package Meta Box */
/** * Post field class. */ class RWMB_Post_Field extends RWMB_Object_Choice_Field { /** * Normalize parameters for field. * * @param array $field Field parameters. * @return array */ public static function normalize( $field ) { // Set default field args. $field = parent::normalize( $field ); $field = wp_parse_args( $field, array( 'post_type' => 'post', 'parent' => false, ) );
if ( ! isset( $field['query_args']['post_type'] ) ) { $field['query_args']['post_type'] = $field['post_type']; }
/** * Set default placeholder. * - If multiple post types: show 'Select a post'. * - If single post type: show 'Select a %post_type_name%'. */ if ( empty( $field['placeholder'] ) ) { $field['placeholder'] = __( 'Select a post', 'meta-box' ); if ( is_string( $field['query_args']['post_type'] ) && post_type_exists( $field['query_args']['post_type'] ) ) { $post_type_object = get_post_type_object( $field['query_args']['post_type'] );
// Translators: %s is the post type singular label. $field['placeholder'] = sprintf( __( 'Select a %s', 'meta-box' ), $post_type_object->labels->singular_name ); } }
// Set parent option, which will change field name to `parent_id` to save as post parent. if ( $field['parent'] ) { $field['multiple'] = false; $field['field_name'] = 'parent_id'; }
// Set default query args. $field['query_args'] = wp_parse_args( $field['query_args'], array( 'post_status' => 'publish', 'posts_per_page' => - 1, ) );
return $field; }
/** * Get field names of object to be used by walker. * * @return array */ public static function get_db_fields() { return array( 'parent' => 'post_parent', 'id' => 'ID', 'label' => 'post_title', ); }
/** * Get meta value. * If field is cloneable, value is saved as a single entry in DB. * Otherwise value is saved as multiple entries (for backward compatibility). * * @see "save" method for better understanding * * @param int $post_id Post ID. * @param bool $saved Is the meta box saved. * @param array $field Field parameters. * * @return mixed */ public static function meta( $post_id, $saved, $field ) { if ( isset( $field['parent'] ) && $field['parent'] ) { $post = get_post( $post_id ); return $post->post_parent; }
return parent::meta( $post_id, $saved, $field ); }
/** * Get options for walker. * * @param array $field Field parameters. * @return array */ public static function get_options( $field ) { $query = new WP_Query( $field['query_args'] ); return $query->have_posts() ? $query->posts : array(); }
/** * Get option label. * * @param array $field Field parameters. * @param string $value Option value. * * @return string */ public static function get_option_label( $field, $value ) { return sprintf( '<a href="%s" title="%s">%s</a>', esc_url( get_permalink( $value ) ), the_title_attribute( array( 'post' => $value, 'echo' => false, ) ), get_the_title( $value ) ); } }
|