author | ymh <ymh.work@gmail.com> |
Mon, 08 Sep 2025 19:44:41 +0200 | |
changeset 23 | 417f20492bf7 |
parent 22 | 8c2e4d02f4ef |
permissions | -rw-r--r-- |
0 | 1 |
<?php |
2 |
/** |
|
3 |
* Template WordPress Administration API. |
|
4 |
* |
|
5 |
* A Big Mess. Also some neat functions that are nicely written. |
|
6 |
* |
|
7 |
* @package WordPress |
|
8 |
* @subpackage Administration |
|
9 |
*/ |
|
10 |
||
7
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
11 |
/** Walker_Category_Checklist class */ |
16 | 12 |
require_once ABSPATH . 'wp-admin/includes/class-walker-category-checklist.php'; |
7
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
13 |
|
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
14 |
/** WP_Internal_Pointers class */ |
16 | 15 |
require_once ABSPATH . 'wp-admin/includes/class-wp-internal-pointers.php'; |
7
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
16 |
|
0 | 17 |
// |
16 | 18 |
// Category Checklists. |
0 | 19 |
// |
20 |
||
21 |
/** |
|
19 | 22 |
* Outputs an unordered list of checkbox input elements labeled with category names. |
0 | 23 |
* |
24 |
* @since 2.5.1 |
|
25 |
* |
|
5 | 26 |
* @see wp_terms_checklist() |
27 |
* |
|
18 | 28 |
* @param int $post_id Optional. Post to generate a categories checklist for. Default 0. |
29 |
* $selected_cats must not be an array. Default 0. |
|
30 |
* @param int $descendants_and_self Optional. ID of the category to output along with its descendants. |
|
31 |
* Default 0. |
|
32 |
* @param int[]|false $selected_cats Optional. Array of category IDs to mark as checked. Default false. |
|
33 |
* @param int[]|false $popular_cats Optional. Array of category IDs to receive the "popular-category" class. |
|
34 |
* Default false. |
|
35 |
* @param Walker $walker Optional. Walker object to use to build the output. |
|
36 |
* Default is a Walker_Category_Checklist instance. |
|
37 |
* @param bool $checked_ontop Optional. Whether to move checked items out of the hierarchy and to |
|
38 |
* the top of the list. Default true. |
|
0 | 39 |
*/ |
40 |
function wp_category_checklist( $post_id = 0, $descendants_and_self = 0, $selected_cats = false, $popular_cats = false, $walker = null, $checked_ontop = true ) { |
|
9 | 41 |
wp_terms_checklist( |
42 |
$post_id, |
|
43 |
array( |
|
44 |
'taxonomy' => 'category', |
|
45 |
'descendants_and_self' => $descendants_and_self, |
|
46 |
'selected_cats' => $selected_cats, |
|
47 |
'popular_cats' => $popular_cats, |
|
48 |
'walker' => $walker, |
|
49 |
'checked_ontop' => $checked_ontop, |
|
50 |
) |
|
51 |
); |
|
0 | 52 |
} |
53 |
||
54 |
/** |
|
19 | 55 |
* Outputs an unordered list of checkbox input elements labelled with term names. |
5 | 56 |
* |
57 |
* Taxonomy-independent version of wp_category_checklist(). |
|
0 | 58 |
* |
59 |
* @since 3.0.0 |
|
7
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
60 |
* @since 4.4.0 Introduced the `$echo` argument. |
0 | 61 |
* |
5 | 62 |
* @param int $post_id Optional. Post ID. Default 0. |
63 |
* @param array|string $args { |
|
64 |
* Optional. Array or string of arguments for generating a terms checklist. Default empty array. |
|
65 |
* |
|
66 |
* @type int $descendants_and_self ID of the category to output along with its descendants. |
|
67 |
* Default 0. |
|
9 | 68 |
* @type int[] $selected_cats Array of category IDs to mark as checked. Default false. |
69 |
* @type int[] $popular_cats Array of category IDs to receive the "popular-category" class. |
|
5 | 70 |
* Default false. |
19 | 71 |
* @type Walker $walker Walker object to use to build the output. Default empty which |
72 |
* results in a Walker_Category_Checklist instance being used. |
|
5 | 73 |
* @type string $taxonomy Taxonomy to generate the checklist for. Default 'category'. |
74 |
* @type bool $checked_ontop Whether to move checked items out of the hierarchy and to |
|
75 |
* the top of the list. Default true. |
|
7
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
76 |
* @type bool $echo Whether to echo the generated markup. False to return the markup instead |
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
77 |
* of echoing it. Default true. |
5 | 78 |
* } |
16 | 79 |
* @return string HTML list of input elements. |
0 | 80 |
*/ |
5 | 81 |
function wp_terms_checklist( $post_id = 0, $args = array() ) { |
9 | 82 |
$defaults = array( |
0 | 83 |
'descendants_and_self' => 0, |
9 | 84 |
'selected_cats' => false, |
85 |
'popular_cats' => false, |
|
86 |
'walker' => null, |
|
87 |
'taxonomy' => 'category', |
|
88 |
'checked_ontop' => true, |
|
89 |
'echo' => true, |
|
0 | 90 |
); |
91 |
||
5 | 92 |
/** |
7
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
93 |
* Filters the taxonomy terms checklist arguments. |
5 | 94 |
* |
95 |
* @since 3.4.0 |
|
96 |
* |
|
97 |
* @see wp_terms_checklist() |
|
98 |
* |
|
19 | 99 |
* @param array|string $args An array or string of arguments. |
100 |
* @param int $post_id The post ID. |
|
5 | 101 |
*/ |
102 |
$params = apply_filters( 'wp_terms_checklist_args', $args, $post_id ); |
|
0 | 103 |
|
16 | 104 |
$parsed_args = wp_parse_args( $params, $defaults ); |
0 | 105 |
|
16 | 106 |
if ( empty( $parsed_args['walker'] ) || ! ( $parsed_args['walker'] instanceof Walker ) ) { |
21
48c4eec2b7e6
Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents:
19
diff
changeset
|
107 |
$walker = new Walker_Category_Checklist(); |
5 | 108 |
} else { |
16 | 109 |
$walker = $parsed_args['walker']; |
5 | 110 |
} |
0 | 111 |
|
16 | 112 |
$taxonomy = $parsed_args['taxonomy']; |
113 |
$descendants_and_self = (int) $parsed_args['descendants_and_self']; |
|
5 | 114 |
|
115 |
$args = array( 'taxonomy' => $taxonomy ); |
|
0 | 116 |
|
9 | 117 |
$tax = get_taxonomy( $taxonomy ); |
5 | 118 |
$args['disabled'] = ! current_user_can( $tax->cap->assign_terms ); |
119 |
||
16 | 120 |
$args['list_only'] = ! empty( $parsed_args['list_only'] ); |
0 | 121 |
|
16 | 122 |
if ( is_array( $parsed_args['selected_cats'] ) ) { |
123 |
$args['selected_cats'] = array_map( 'intval', $parsed_args['selected_cats'] ); |
|
5 | 124 |
} elseif ( $post_id ) { |
125 |
$args['selected_cats'] = wp_get_object_terms( $post_id, $taxonomy, array_merge( $args, array( 'fields' => 'ids' ) ) ); |
|
126 |
} else { |
|
127 |
$args['selected_cats'] = array(); |
|
128 |
} |
|
16 | 129 |
|
130 |
if ( is_array( $parsed_args['popular_cats'] ) ) { |
|
131 |
$args['popular_cats'] = array_map( 'intval', $parsed_args['popular_cats'] ); |
|
5 | 132 |
} else { |
9 | 133 |
$args['popular_cats'] = get_terms( |
134 |
array( |
|
16 | 135 |
'taxonomy' => $taxonomy, |
9 | 136 |
'fields' => 'ids', |
137 |
'orderby' => 'count', |
|
138 |
'order' => 'DESC', |
|
139 |
'number' => 10, |
|
140 |
'hierarchical' => false, |
|
141 |
) |
|
142 |
); |
|
5 | 143 |
} |
16 | 144 |
|
0 | 145 |
if ( $descendants_and_self ) { |
9 | 146 |
$categories = (array) get_terms( |
147 |
array( |
|
16 | 148 |
'taxonomy' => $taxonomy, |
9 | 149 |
'child_of' => $descendants_and_self, |
150 |
'hierarchical' => 0, |
|
151 |
'hide_empty' => 0, |
|
152 |
) |
|
153 |
); |
|
154 |
$self = get_term( $descendants_and_self, $taxonomy ); |
|
0 | 155 |
array_unshift( $categories, $self ); |
156 |
} else { |
|
16 | 157 |
$categories = (array) get_terms( |
158 |
array( |
|
159 |
'taxonomy' => $taxonomy, |
|
160 |
'get' => 'all', |
|
161 |
) |
|
162 |
); |
|
0 | 163 |
} |
164 |
||
7
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
165 |
$output = ''; |
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
166 |
|
16 | 167 |
if ( $parsed_args['checked_ontop'] ) { |
21
48c4eec2b7e6
Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents:
19
diff
changeset
|
168 |
/* |
48c4eec2b7e6
Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents:
19
diff
changeset
|
169 |
* Post-process $categories rather than adding an exclude to the get_terms() query |
48c4eec2b7e6
Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents:
19
diff
changeset
|
170 |
* to keep the query the same across all posts (for any query cache). |
48c4eec2b7e6
Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents:
19
diff
changeset
|
171 |
*/ |
0 | 172 |
$checked_categories = array(); |
9 | 173 |
$keys = array_keys( $categories ); |
0 | 174 |
|
7
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
175 |
foreach ( $keys as $k ) { |
16 | 176 |
if ( in_array( $categories[ $k ]->term_id, $args['selected_cats'], true ) ) { |
9 | 177 |
$checked_categories[] = $categories[ $k ]; |
178 |
unset( $categories[ $k ] ); |
|
0 | 179 |
} |
180 |
} |
|
181 |
||
16 | 182 |
// Put checked categories on top. |
183 |
$output .= $walker->walk( $checked_categories, 0, $args ); |
|
0 | 184 |
} |
16 | 185 |
// Then the rest of them. |
186 |
$output .= $walker->walk( $categories, 0, $args ); |
|
7
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
187 |
|
16 | 188 |
if ( $parsed_args['echo'] ) { |
7
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
189 |
echo $output; |
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
190 |
} |
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
191 |
|
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
192 |
return $output; |
0 | 193 |
} |
194 |
||
195 |
/** |
|
19 | 196 |
* Retrieves a list of the most popular terms from the specified taxonomy. |
0 | 197 |
* |
19 | 198 |
* If the `$display` argument is true then the elements for a list of checkbox |
5 | 199 |
* `<input>` elements labelled with the names of the selected terms is output. |
19 | 200 |
* If the `$post_ID` global is not empty then the terms associated with that |
0 | 201 |
* post will be marked as checked. |
202 |
* |
|
203 |
* @since 2.5.0 |
|
204 |
* |
|
19 | 205 |
* @param string $taxonomy Taxonomy to retrieve terms from. |
206 |
* @param int $default_term Optional. Not used. |
|
207 |
* @param int $number Optional. Number of terms to retrieve. Default 10. |
|
208 |
* @param bool $display Optional. Whether to display the list as well. Default true. |
|
16 | 209 |
* @return int[] Array of popular term IDs. |
0 | 210 |
*/ |
19 | 211 |
function wp_popular_terms_checklist( $taxonomy, $default_term = 0, $number = 10, $display = true ) { |
0 | 212 |
$post = get_post(); |
213 |
||
9 | 214 |
if ( $post && $post->ID ) { |
215 |
$checked_terms = wp_get_object_terms( $post->ID, $taxonomy, array( 'fields' => 'ids' ) ); |
|
216 |
} else { |
|
0 | 217 |
$checked_terms = array(); |
9 | 218 |
} |
0 | 219 |
|
9 | 220 |
$terms = get_terms( |
221 |
array( |
|
16 | 222 |
'taxonomy' => $taxonomy, |
9 | 223 |
'orderby' => 'count', |
224 |
'order' => 'DESC', |
|
225 |
'number' => $number, |
|
226 |
'hierarchical' => false, |
|
227 |
) |
|
228 |
); |
|
0 | 229 |
|
9 | 230 |
$tax = get_taxonomy( $taxonomy ); |
0 | 231 |
|
232 |
$popular_ids = array(); |
|
16 | 233 |
|
0 | 234 |
foreach ( (array) $terms as $term ) { |
235 |
$popular_ids[] = $term->term_id; |
|
19 | 236 |
|
237 |
if ( ! $display ) { // Hack for Ajax use. |
|
0 | 238 |
continue; |
9 | 239 |
} |
19 | 240 |
|
9 | 241 |
$id = "popular-$taxonomy-$term->term_id"; |
16 | 242 |
$checked = in_array( $term->term_id, $checked_terms, true ) ? 'checked="checked"' : ''; |
0 | 243 |
?> |
244 |
||
245 |
<li id="<?php echo $id; ?>" class="popular-category"> |
|
246 |
<label class="selectit"> |
|
5 | 247 |
<input id="in-<?php echo $id; ?>" type="checkbox" <?php echo $checked; ?> value="<?php echo (int) $term->term_id; ?>" <?php disabled( ! current_user_can( $tax->cap->assign_terms ) ); ?> /> |
248 |
<?php |
|
249 |
/** This filter is documented in wp-includes/category-template.php */ |
|
7
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
250 |
echo esc_html( apply_filters( 'the_category', $term->name, '', '' ) ); |
5 | 251 |
?> |
0 | 252 |
</label> |
253 |
</li> |
|
254 |
||
255 |
<?php |
|
256 |
} |
|
257 |
return $popular_ids; |
|
258 |
} |
|
259 |
||
260 |
/** |
|
7
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
261 |
* Outputs a link category checklist element. |
0 | 262 |
* |
263 |
* @since 2.5.1 |
|
264 |
* |
|
21
48c4eec2b7e6
Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents:
19
diff
changeset
|
265 |
* @param int $link_id Optional. The link ID. Default 0. |
0 | 266 |
*/ |
267 |
function wp_link_category_checklist( $link_id = 0 ) { |
|
268 |
$default = 1; |
|
269 |
||
5 | 270 |
$checked_categories = array(); |
271 |
||
0 | 272 |
if ( $link_id ) { |
273 |
$checked_categories = wp_get_link_cats( $link_id ); |
|
16 | 274 |
// No selected categories, strange. |
5 | 275 |
if ( ! count( $checked_categories ) ) { |
0 | 276 |
$checked_categories[] = $default; |
5 | 277 |
} |
0 | 278 |
} else { |
279 |
$checked_categories[] = $default; |
|
280 |
} |
|
281 |
||
9 | 282 |
$categories = get_terms( |
283 |
array( |
|
16 | 284 |
'taxonomy' => 'link_category', |
9 | 285 |
'orderby' => 'name', |
286 |
'hide_empty' => 0, |
|
287 |
) |
|
288 |
); |
|
0 | 289 |
|
9 | 290 |
if ( empty( $categories ) ) { |
0 | 291 |
return; |
9 | 292 |
} |
0 | 293 |
|
294 |
foreach ( $categories as $category ) { |
|
295 |
$cat_id = $category->term_id; |
|
5 | 296 |
|
297 |
/** This filter is documented in wp-includes/category-template.php */ |
|
9 | 298 |
$name = esc_html( apply_filters( 'the_category', $category->name, '', '' ) ); |
16 | 299 |
$checked = in_array( $cat_id, $checked_categories, true ) ? ' checked="checked"' : ''; |
9 | 300 |
echo '<li id="link-category-', $cat_id, '"><label for="in-link-category-', $cat_id, '" class="selectit"><input value="', $cat_id, '" type="checkbox" name="link_category[]" id="in-link-category-', $cat_id, '"', $checked, '/> ', $name, '</label></li>'; |
0 | 301 |
} |
302 |
} |
|
303 |
||
304 |
/** |
|
5 | 305 |
* Adds hidden fields with the data for use in the inline editor for posts and pages. |
0 | 306 |
* |
307 |
* @since 2.7.0 |
|
308 |
* |
|
5 | 309 |
* @param WP_Post $post Post object. |
0 | 310 |
*/ |
9 | 311 |
function get_inline_data( $post ) { |
312 |
$post_type_object = get_post_type_object( $post->post_type ); |
|
313 |
if ( ! current_user_can( 'edit_post', $post->ID ) ) { |
|
0 | 314 |
return; |
9 | 315 |
} |
0 | 316 |
|
317 |
$title = esc_textarea( trim( $post->post_title ) ); |
|
318 |
||
319 |
echo ' |
|
320 |
<div class="hidden" id="inline_' . $post->ID . '"> |
|
7
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
321 |
<div class="post_title">' . $title . '</div>' . |
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
322 |
/** This filter is documented in wp-admin/edit-tag-form.php */ |
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
323 |
'<div class="post_name">' . apply_filters( 'editable_slug', $post->post_name, $post ) . '</div> |
0 | 324 |
<div class="post_author">' . $post->post_author . '</div> |
325 |
<div class="comment_status">' . esc_html( $post->comment_status ) . '</div> |
|
326 |
<div class="ping_status">' . esc_html( $post->ping_status ) . '</div> |
|
327 |
<div class="_status">' . esc_html( $post->post_status ) . '</div> |
|
328 |
<div class="jj">' . mysql2date( 'd', $post->post_date, false ) . '</div> |
|
329 |
<div class="mm">' . mysql2date( 'm', $post->post_date, false ) . '</div> |
|
330 |
<div class="aa">' . mysql2date( 'Y', $post->post_date, false ) . '</div> |
|
331 |
<div class="hh">' . mysql2date( 'H', $post->post_date, false ) . '</div> |
|
332 |
<div class="mn">' . mysql2date( 'i', $post->post_date, false ) . '</div> |
|
333 |
<div class="ss">' . mysql2date( 's', $post->post_date, false ) . '</div> |
|
334 |
<div class="post_password">' . esc_html( $post->post_password ) . '</div>'; |
|
335 |
||
7
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
336 |
if ( $post_type_object->hierarchical ) { |
0 | 337 |
echo '<div class="post_parent">' . $post->post_parent . '</div>'; |
7
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
338 |
} |
0 | 339 |
|
7
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
340 |
echo '<div class="page_template">' . ( $post->page_template ? esc_html( $post->page_template ) : 'default' ) . '</div>'; |
0 | 341 |
|
7
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
342 |
if ( post_type_supports( $post->post_type, 'page-attributes' ) ) { |
0 | 343 |
echo '<div class="menu_order">' . $post->menu_order . '</div>'; |
7
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
344 |
} |
0 | 345 |
|
346 |
$taxonomy_names = get_object_taxonomies( $post->post_type ); |
|
16 | 347 |
|
9 | 348 |
foreach ( $taxonomy_names as $taxonomy_name ) { |
0 | 349 |
$taxonomy = get_taxonomy( $taxonomy_name ); |
350 |
||
19 | 351 |
if ( ! $taxonomy->show_in_quick_edit ) { |
352 |
continue; |
|
353 |
} |
|
354 |
||
355 |
if ( $taxonomy->hierarchical ) { |
|
5 | 356 |
|
357 |
$terms = get_object_term_cache( $post->ID, $taxonomy_name ); |
|
358 |
if ( false === $terms ) { |
|
359 |
$terms = wp_get_object_terms( $post->ID, $taxonomy_name ); |
|
7
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
360 |
wp_cache_add( $post->ID, wp_list_pluck( $terms, 'term_id' ), $taxonomy_name . '_relationships' ); |
5 | 361 |
} |
362 |
$term_ids = empty( $terms ) ? array() : wp_list_pluck( $terms, 'term_id' ); |
|
363 |
||
364 |
echo '<div class="post_category" id="' . $taxonomy_name . '_' . $post->ID . '">' . implode( ',', $term_ids ) . '</div>'; |
|
365 |
||
19 | 366 |
} else { |
5 | 367 |
|
7
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
368 |
$terms_to_edit = get_terms_to_edit( $post->ID, $taxonomy_name ); |
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
369 |
if ( ! is_string( $terms_to_edit ) ) { |
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
370 |
$terms_to_edit = ''; |
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
371 |
} |
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
372 |
|
9 | 373 |
echo '<div class="tags_input" id="' . $taxonomy_name . '_' . $post->ID . '">' |
7
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
374 |
. esc_html( str_replace( ',', ', ', $terms_to_edit ) ) . '</div>'; |
5 | 375 |
|
0 | 376 |
} |
377 |
} |
|
378 |
||
9 | 379 |
if ( ! $post_type_object->hierarchical ) { |
380 |
echo '<div class="sticky">' . ( is_sticky( $post->ID ) ? 'sticky' : '' ) . '</div>'; |
|
381 |
} |
|
0 | 382 |
|
9 | 383 |
if ( post_type_supports( $post->post_type, 'post-formats' ) ) { |
0 | 384 |
echo '<div class="post_format">' . esc_html( get_post_format( $post->ID ) ) . '</div>'; |
9 | 385 |
} |
0 | 386 |
|
7
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
387 |
/** |
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
388 |
* Fires after outputting the fields for the inline editor for posts and pages. |
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
389 |
* |
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
390 |
* @since 4.9.8 |
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
391 |
* |
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
392 |
* @param WP_Post $post The current post object. |
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
393 |
* @param WP_Post_Type $post_type_object The current post's post type object. |
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
394 |
*/ |
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
395 |
do_action( 'add_inline_data', $post, $post_type_object ); |
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
396 |
|
0 | 397 |
echo '</div>'; |
398 |
} |
|
399 |
||
400 |
/** |
|
7
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
401 |
* Outputs the in-line comment reply-to form in the Comments list table. |
0 | 402 |
* |
403 |
* @since 2.7.0 |
|
404 |
* |
|
7
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
405 |
* @global WP_List_Table $wp_list_table |
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
406 |
* |
21
48c4eec2b7e6
Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents:
19
diff
changeset
|
407 |
* @param int $position Optional. The value of the 'position' input field. Default 1. |
48c4eec2b7e6
Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents:
19
diff
changeset
|
408 |
* @param bool $checkbox Optional. The value of the 'checkbox' input field. Default false. |
48c4eec2b7e6
Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents:
19
diff
changeset
|
409 |
* @param string $mode Optional. If set to 'single', will use WP_Post_Comments_List_Table, |
48c4eec2b7e6
Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents:
19
diff
changeset
|
410 |
* otherwise WP_Comments_List_Table. Default 'single'. |
48c4eec2b7e6
Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents:
19
diff
changeset
|
411 |
* @param bool $table_row Optional. Whether to use a table instead of a div element. Default true. |
0 | 412 |
*/ |
5 | 413 |
function wp_comment_reply( $position = 1, $checkbox = false, $mode = 'single', $table_row = true ) { |
414 |
global $wp_list_table; |
|
415 |
/** |
|
7
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
416 |
* Filters the in-line comment reply-to form output in the Comments |
5 | 417 |
* list table. |
418 |
* |
|
419 |
* Returning a non-empty value here will short-circuit display |
|
420 |
* of the in-line comment-reply form in the Comments list table, |
|
421 |
* echoing the returned value instead. |
|
422 |
* |
|
423 |
* @since 2.7.0 |
|
424 |
* |
|
425 |
* @see wp_comment_reply() |
|
426 |
* |
|
427 |
* @param string $content The reply-to form content. |
|
428 |
* @param array $args An array of default args. |
|
429 |
*/ |
|
9 | 430 |
$content = apply_filters( |
431 |
'wp_comment_reply', |
|
432 |
'', |
|
433 |
array( |
|
434 |
'position' => $position, |
|
435 |
'checkbox' => $checkbox, |
|
436 |
'mode' => $mode, |
|
437 |
) |
|
438 |
); |
|
0 | 439 |
|
9 | 440 |
if ( ! empty( $content ) ) { |
0 | 441 |
echo $content; |
442 |
return; |
|
443 |
} |
|
444 |
||
5 | 445 |
if ( ! $wp_list_table ) { |
16 | 446 |
if ( 'single' === $mode ) { |
9 | 447 |
$wp_list_table = _get_list_table( 'WP_Post_Comments_List_Table' ); |
5 | 448 |
} else { |
9 | 449 |
$wp_list_table = _get_list_table( 'WP_Comments_List_Table' ); |
5 | 450 |
} |
0 | 451 |
} |
452 |
||
9 | 453 |
?> |
5 | 454 |
<form method="get"> |
9 | 455 |
<?php if ( $table_row ) : ?> |
7
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
456 |
<table style="display:none;"><tbody id="com-reply"><tr id="replyrow" class="inline-edit-row" style="display:none;"><td colspan="<?php echo $wp_list_table->get_column_count(); ?>" class="colspanchange"> |
0 | 457 |
<?php else : ?> |
458 |
<div id="com-reply" style="display:none;"><div id="replyrow" style="display:none;"> |
|
459 |
<?php endif; ?> |
|
7
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
460 |
<fieldset class="comment-reply"> |
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
461 |
<legend> |
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
462 |
<span class="hidden" id="editlegend"><?php _e( 'Edit Comment' ); ?></span> |
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
463 |
<span class="hidden" id="replyhead"><?php _e( 'Reply to Comment' ); ?></span> |
22
8c2e4d02f4ef
Update WordPress to latest version (6.7)
ymh <ymh.work@gmail.com>
parents:
21
diff
changeset
|
464 |
<span class="hidden" id="addhead"><?php _e( 'Add Comment' ); ?></span> |
7
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
465 |
</legend> |
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
466 |
|
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
467 |
<div id="replycontainer"> |
21
48c4eec2b7e6
Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents:
19
diff
changeset
|
468 |
<label for="replycontent" class="screen-reader-text"> |
48c4eec2b7e6
Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents:
19
diff
changeset
|
469 |
<?php |
48c4eec2b7e6
Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents:
19
diff
changeset
|
470 |
/* translators: Hidden accessibility text. */ |
48c4eec2b7e6
Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents:
19
diff
changeset
|
471 |
_e( 'Comment' ); |
48c4eec2b7e6
Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents:
19
diff
changeset
|
472 |
?> |
48c4eec2b7e6
Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents:
19
diff
changeset
|
473 |
</label> |
7
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
474 |
<?php |
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
475 |
$quicktags_settings = array( 'buttons' => 'strong,em,link,block,del,ins,img,ul,ol,li,code,close' ); |
9 | 476 |
wp_editor( |
477 |
'', |
|
478 |
'replycontent', |
|
479 |
array( |
|
480 |
'media_buttons' => false, |
|
481 |
'tinymce' => false, |
|
482 |
'quicktags' => $quicktags_settings, |
|
483 |
) |
|
484 |
); |
|
7
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
485 |
?> |
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
486 |
</div> |
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
487 |
|
0 | 488 |
<div id="edithead" style="display:none;"> |
489 |
<div class="inside"> |
|
9 | 490 |
<label for="author-name"><?php _e( 'Name' ); ?></label> |
7
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
491 |
<input type="text" name="newcomment_author" size="50" value="" id="author-name" /> |
0 | 492 |
</div> |
493 |
||
494 |
<div class="inside"> |
|
9 | 495 |
<label for="author-email"><?php _e( 'Email' ); ?></label> |
0 | 496 |
<input type="text" name="newcomment_author_email" size="50" value="" id="author-email" /> |
497 |
</div> |
|
498 |
||
499 |
<div class="inside"> |
|
9 | 500 |
<label for="author-url"><?php _e( 'URL' ); ?></label> |
5 | 501 |
<input type="text" id="author-url" name="newcomment_author_url" class="code" size="103" value="" /> |
0 | 502 |
</div> |
503 |
</div> |
|
504 |
||
7
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
505 |
<div id="replysubmit" class="submit"> |
9 | 506 |
<p class="reply-submit-buttons"> |
507 |
<button type="button" class="save button button-primary"> |
|
7
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
508 |
<span id="addbtn" style="display: none;"><?php _e( 'Add Comment' ); ?></span> |
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
509 |
<span id="savebtn" style="display: none;"><?php _e( 'Update Comment' ); ?></span> |
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
510 |
<span id="replybtn" style="display: none;"><?php _e( 'Submit Reply' ); ?></span> |
9 | 511 |
</button> |
512 |
<button type="button" class="cancel button"><?php _e( 'Cancel' ); ?></button> |
|
7
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
513 |
<span class="waiting spinner"></span> |
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
514 |
</p> |
21
48c4eec2b7e6
Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents:
19
diff
changeset
|
515 |
<?php |
48c4eec2b7e6
Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents:
19
diff
changeset
|
516 |
wp_admin_notice( |
48c4eec2b7e6
Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents:
19
diff
changeset
|
517 |
'<p class="error"></p>', |
48c4eec2b7e6
Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents:
19
diff
changeset
|
518 |
array( |
48c4eec2b7e6
Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents:
19
diff
changeset
|
519 |
'type' => 'error', |
48c4eec2b7e6
Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents:
19
diff
changeset
|
520 |
'additional_classes' => array( 'notice-alt', 'inline', 'hidden' ), |
48c4eec2b7e6
Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents:
19
diff
changeset
|
521 |
'paragraph_wrap' => false, |
48c4eec2b7e6
Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents:
19
diff
changeset
|
522 |
) |
48c4eec2b7e6
Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents:
19
diff
changeset
|
523 |
); |
48c4eec2b7e6
Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents:
19
diff
changeset
|
524 |
?> |
7
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
525 |
</div> |
0 | 526 |
|
527 |
<input type="hidden" name="action" id="action" value="" /> |
|
528 |
<input type="hidden" name="comment_ID" id="comment_ID" value="" /> |
|
529 |
<input type="hidden" name="comment_post_ID" id="comment_post_ID" value="" /> |
|
530 |
<input type="hidden" name="status" id="status" value="" /> |
|
531 |
<input type="hidden" name="position" id="position" value="<?php echo $position; ?>" /> |
|
532 |
<input type="hidden" name="checkbox" id="checkbox" value="<?php echo $checkbox ? 1 : 0; ?>" /> |
|
9 | 533 |
<input type="hidden" name="mode" id="mode" value="<?php echo esc_attr( $mode ); ?>" /> |
0 | 534 |
<?php |
535 |
wp_nonce_field( 'replyto-comment', '_ajax_nonce-replyto-comment', false ); |
|
9 | 536 |
if ( current_user_can( 'unfiltered_html' ) ) { |
537 |
wp_nonce_field( 'unfiltered-html-comment', '_wp_unfiltered_html_comment', false ); |
|
538 |
} |
|
0 | 539 |
?> |
7
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
540 |
</fieldset> |
9 | 541 |
<?php if ( $table_row ) : ?> |
0 | 542 |
</td></tr></tbody></table> |
9 | 543 |
<?php else : ?> |
0 | 544 |
</div></div> |
9 | 545 |
<?php endif; ?> |
0 | 546 |
</form> |
9 | 547 |
<?php |
0 | 548 |
} |
549 |
||
550 |
/** |
|
19 | 551 |
* Outputs 'undo move to Trash' text for comments. |
0 | 552 |
* |
553 |
* @since 2.9.0 |
|
554 |
*/ |
|
555 |
function wp_comment_trashnotice() { |
|
9 | 556 |
?> |
0 | 557 |
<div class="hidden" id="trash-undo-holder"> |
16 | 558 |
<div class="trash-undo-inside"> |
559 |
<?php |
|
560 |
/* translators: %s: Comment author, filled by Ajax. */ |
|
561 |
printf( __( 'Comment by %s moved to the Trash.' ), '<strong></strong>' ); |
|
562 |
?> |
|
563 |
<span class="undo untrash"><a href="#"><?php _e( 'Undo' ); ?></a></span> |
|
564 |
</div> |
|
0 | 565 |
</div> |
566 |
<div class="hidden" id="spam-undo-holder"> |
|
16 | 567 |
<div class="spam-undo-inside"> |
568 |
<?php |
|
569 |
/* translators: %s: Comment author, filled by Ajax. */ |
|
570 |
printf( __( 'Comment by %s marked as spam.' ), '<strong></strong>' ); |
|
571 |
?> |
|
572 |
<span class="undo unspam"><a href="#"><?php _e( 'Undo' ); ?></a></span> |
|
573 |
</div> |
|
0 | 574 |
</div> |
9 | 575 |
<?php |
0 | 576 |
} |
577 |
||
578 |
/** |
|
7
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
579 |
* Outputs a post's public meta data in the Custom Fields meta box. |
0 | 580 |
* |
581 |
* @since 1.2.0 |
|
582 |
* |
|
21
48c4eec2b7e6
Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents:
19
diff
changeset
|
583 |
* @param array[] $meta An array of meta data arrays keyed on 'meta_key' and 'meta_value'. |
0 | 584 |
*/ |
585 |
function list_meta( $meta ) { |
|
16 | 586 |
// Exit if no meta. |
0 | 587 |
if ( ! $meta ) { |
588 |
echo ' |
|
589 |
<table id="list-table" style="display: none;"> |
|
590 |
<thead> |
|
591 |
<tr> |
|
592 |
<th class="left">' . _x( 'Name', 'meta name' ) . '</th> |
|
593 |
<th>' . __( 'Value' ) . '</th> |
|
594 |
</tr> |
|
595 |
</thead> |
|
596 |
<tbody id="the-list" data-wp-lists="list:meta"> |
|
597 |
<tr><td></td></tr> |
|
598 |
</tbody> |
|
16 | 599 |
</table>'; // TBODY needed for list-manipulation JS. |
0 | 600 |
return; |
601 |
} |
|
602 |
$count = 0; |
|
9 | 603 |
?> |
0 | 604 |
<table id="list-table"> |
605 |
<thead> |
|
606 |
<tr> |
|
9 | 607 |
<th class="left"><?php _ex( 'Name', 'meta name' ); ?></th> |
608 |
<th><?php _e( 'Value' ); ?></th> |
|
0 | 609 |
</tr> |
610 |
</thead> |
|
611 |
<tbody id='the-list' data-wp-lists='list:meta'> |
|
9 | 612 |
<?php |
613 |
foreach ( $meta as $entry ) { |
|
0 | 614 |
echo _list_meta_row( $entry, $count ); |
9 | 615 |
} |
616 |
?> |
|
0 | 617 |
</tbody> |
618 |
</table> |
|
9 | 619 |
<?php |
0 | 620 |
} |
621 |
||
622 |
/** |
|
7
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
623 |
* Outputs a single row of public meta data in the Custom Fields meta box. |
0 | 624 |
* |
625 |
* @since 2.5.0 |
|
626 |
* |
|
21
48c4eec2b7e6
Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents:
19
diff
changeset
|
627 |
* @param array $entry An array of meta data keyed on 'meta_key' and 'meta_value'. |
48c4eec2b7e6
Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents:
19
diff
changeset
|
628 |
* @param int $count Reference to the row number. |
48c4eec2b7e6
Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents:
19
diff
changeset
|
629 |
* @return string A single row of public meta data. |
0 | 630 |
*/ |
631 |
function _list_meta_row( $entry, &$count ) { |
|
7
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
632 |
static $update_nonce = ''; |
0 | 633 |
|
9 | 634 |
if ( is_protected_meta( $entry['meta_key'], 'post' ) ) { |
5 | 635 |
return ''; |
9 | 636 |
} |
0 | 637 |
|
9 | 638 |
if ( ! $update_nonce ) { |
0 | 639 |
$update_nonce = wp_create_nonce( 'add-meta' ); |
9 | 640 |
} |
0 | 641 |
|
642 |
$r = ''; |
|
21
48c4eec2b7e6
Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents:
19
diff
changeset
|
643 |
++$count; |
0 | 644 |
|
645 |
if ( is_serialized( $entry['meta_value'] ) ) { |
|
646 |
if ( is_serialized_string( $entry['meta_value'] ) ) { |
|
5 | 647 |
// This is a serialized string, so we should display it. |
0 | 648 |
$entry['meta_value'] = maybe_unserialize( $entry['meta_value'] ); |
649 |
} else { |
|
5 | 650 |
// This is a serialized array/object so we should NOT display it. |
0 | 651 |
--$count; |
5 | 652 |
return ''; |
0 | 653 |
} |
654 |
} |
|
655 |
||
9 | 656 |
$entry['meta_key'] = esc_attr( $entry['meta_key'] ); |
16 | 657 |
$entry['meta_value'] = esc_textarea( $entry['meta_value'] ); // Using a <textarea />. |
9 | 658 |
$entry['meta_id'] = (int) $entry['meta_id']; |
0 | 659 |
|
660 |
$delete_nonce = wp_create_nonce( 'delete-meta_' . $entry['meta_id'] ); |
|
661 |
||
5 | 662 |
$r .= "\n\t<tr id='meta-{$entry['meta_id']}'>"; |
21
48c4eec2b7e6
Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents:
19
diff
changeset
|
663 |
$r .= "\n\t\t<td class='left'><label class='screen-reader-text' for='meta-{$entry['meta_id']}-key'>" . |
48c4eec2b7e6
Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents:
19
diff
changeset
|
664 |
/* translators: Hidden accessibility text. */ |
48c4eec2b7e6
Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents:
19
diff
changeset
|
665 |
__( 'Key' ) . |
48c4eec2b7e6
Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents:
19
diff
changeset
|
666 |
"</label><input name='meta[{$entry['meta_id']}][key]' id='meta-{$entry['meta_id']}-key' type='text' size='20' value='{$entry['meta_key']}' />"; |
0 | 667 |
|
668 |
$r .= "\n\t\t<div class='submit'>"; |
|
669 |
$r .= get_submit_button( __( 'Delete' ), 'deletemeta small', "deletemeta[{$entry['meta_id']}]", false, array( 'data-wp-lists' => "delete:the-list:meta-{$entry['meta_id']}::_ajax_nonce=$delete_nonce" ) ); |
|
670 |
$r .= "\n\t\t"; |
|
671 |
$r .= get_submit_button( __( 'Update' ), 'updatemeta small', "meta-{$entry['meta_id']}-submit", false, array( 'data-wp-lists' => "add:the-list:meta-{$entry['meta_id']}::_ajax_nonce-add-meta=$update_nonce" ) ); |
|
9 | 672 |
$r .= '</div>'; |
0 | 673 |
$r .= wp_nonce_field( 'change-meta', '_ajax_nonce', false, false ); |
9 | 674 |
$r .= '</td>'; |
0 | 675 |
|
21
48c4eec2b7e6
Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents:
19
diff
changeset
|
676 |
$r .= "\n\t\t<td><label class='screen-reader-text' for='meta-{$entry['meta_id']}-value'>" . |
48c4eec2b7e6
Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents:
19
diff
changeset
|
677 |
/* translators: Hidden accessibility text. */ |
48c4eec2b7e6
Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents:
19
diff
changeset
|
678 |
__( 'Value' ) . |
48c4eec2b7e6
Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents:
19
diff
changeset
|
679 |
"</label><textarea name='meta[{$entry['meta_id']}][value]' id='meta-{$entry['meta_id']}-value' rows='2' cols='30'>{$entry['meta_value']}</textarea></td>\n\t</tr>"; |
0 | 680 |
return $r; |
681 |
} |
|
682 |
||
683 |
/** |
|
684 |
* Prints the form in the Custom Fields meta box. |
|
685 |
* |
|
686 |
* @since 1.2.0 |
|
687 |
* |
|
7
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
688 |
* @global wpdb $wpdb WordPress database abstraction object. |
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
689 |
* |
0 | 690 |
* @param WP_Post $post Optional. The post being edited. |
691 |
*/ |
|
692 |
function meta_form( $post = null ) { |
|
693 |
global $wpdb; |
|
694 |
$post = get_post( $post ); |
|
5 | 695 |
|
696 |
/** |
|
7
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
697 |
* Filters values for the meta key dropdown in the Custom Fields meta box. |
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
698 |
* |
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
699 |
* Returning a non-null value will effectively short-circuit and avoid a |
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
700 |
* potentially expensive query against postmeta. |
5 | 701 |
* |
7
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
702 |
* @since 4.4.0 |
5 | 703 |
* |
7
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
704 |
* @param array|null $keys Pre-defined meta keys to be used in place of a postmeta query. Default null. |
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
705 |
* @param WP_Post $post The current post object. |
5 | 706 |
*/ |
7
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
707 |
$keys = apply_filters( 'postmeta_form_keys', null, $post ); |
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
708 |
|
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
709 |
if ( null === $keys ) { |
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
710 |
/** |
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
711 |
* Filters the number of custom fields to retrieve for the drop-down |
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
712 |
* in the Custom Fields meta box. |
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
713 |
* |
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
714 |
* @since 2.1.0 |
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
715 |
* |
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
716 |
* @param int $limit Number of custom fields to retrieve. Default 30. |
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
717 |
*/ |
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
718 |
$limit = apply_filters( 'postmeta_form_limit', 30 ); |
16 | 719 |
|
720 |
$keys = $wpdb->get_col( |
|
721 |
$wpdb->prepare( |
|
722 |
"SELECT DISTINCT meta_key |
|
723 |
FROM $wpdb->postmeta |
|
724 |
WHERE meta_key NOT BETWEEN '_' AND '_z' |
|
725 |
HAVING meta_key NOT LIKE %s |
|
726 |
ORDER BY meta_key |
|
727 |
LIMIT %d", |
|
728 |
$wpdb->esc_like( '_' ) . '%', |
|
729 |
$limit |
|
730 |
) |
|
731 |
); |
|
7
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
732 |
} |
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
733 |
|
5 | 734 |
if ( $keys ) { |
735 |
natcasesort( $keys ); |
|
736 |
} |
|
9 | 737 |
?> |
22
8c2e4d02f4ef
Update WordPress to latest version (6.7)
ymh <ymh.work@gmail.com>
parents:
21
diff
changeset
|
738 |
<p><strong><?php _e( 'Add Custom Field:' ); ?></strong></p> |
0 | 739 |
<table id="newmeta"> |
740 |
<thead> |
|
741 |
<tr> |
|
21
48c4eec2b7e6
Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents:
19
diff
changeset
|
742 |
<th class="left"><label for="metakeyselect"><?php _ex( 'Name', 'meta name' ); ?></label></th> |
9 | 743 |
<th><label for="metavalue"><?php _e( 'Value' ); ?></label></th> |
0 | 744 |
</tr> |
745 |
</thead> |
|
746 |
||
747 |
<tbody> |
|
748 |
<tr> |
|
749 |
<td id="newmetaleft" class="left"> |
|
9 | 750 |
<?php if ( $keys ) { ?> |
0 | 751 |
<select id="metakeyselect" name="metakeyselect"> |
752 |
<option value="#NONE#"><?php _e( '— Select —' ); ?></option> |
|
9 | 753 |
<?php |
754 |
foreach ( $keys as $key ) { |
|
755 |
if ( is_protected_meta( $key, 'post' ) || ! current_user_can( 'add_post_meta', $post->ID, $key ) ) { |
|
756 |
continue; |
|
757 |
} |
|
758 |
echo "\n<option value='" . esc_attr( $key ) . "'>" . esc_html( $key ) . '</option>'; |
|
759 |
} |
|
760 |
?> |
|
0 | 761 |
</select> |
21
48c4eec2b7e6
Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents:
19
diff
changeset
|
762 |
<input class="hidden" type="text" id="metakeyinput" name="metakeyinput" value="" aria-label="<?php _e( 'New custom field name' ); ?>" /> |
48c4eec2b7e6
Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents:
19
diff
changeset
|
763 |
<button type="button" id="newmeta-button" class="button button-small hide-if-no-js" onclick="jQuery('#metakeyinput, #metakeyselect, #enternew, #cancelnew').toggleClass('hidden');jQuery('#metakeyinput, #metakeyselect').filter(':visible').trigger('focus');"> |
9 | 764 |
<span id="enternew"><?php _e( 'Enter new' ); ?></span> |
21
48c4eec2b7e6
Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents:
19
diff
changeset
|
765 |
<span id="cancelnew" class="hidden"><?php _e( 'Cancel' ); ?></span></button> |
0 | 766 |
<?php } else { ?> |
767 |
<input type="text" id="metakeyinput" name="metakeyinput" value="" /> |
|
768 |
<?php } ?> |
|
769 |
</td> |
|
21
48c4eec2b7e6
Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents:
19
diff
changeset
|
770 |
<td><textarea id="metavalue" name="metavalue" rows="2" cols="25"></textarea> |
48c4eec2b7e6
Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents:
19
diff
changeset
|
771 |
<?php wp_nonce_field( 'add-meta', '_ajax_nonce-add-meta', false ); ?> |
48c4eec2b7e6
Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents:
19
diff
changeset
|
772 |
</td> |
0 | 773 |
</tr> |
21
48c4eec2b7e6
Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents:
19
diff
changeset
|
774 |
</tbody> |
48c4eec2b7e6
Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents:
19
diff
changeset
|
775 |
</table> |
48c4eec2b7e6
Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents:
19
diff
changeset
|
776 |
<div class="submit add-custom-field"> |
9 | 777 |
<?php |
778 |
submit_button( |
|
779 |
__( 'Add Custom Field' ), |
|
780 |
'', |
|
781 |
'addmeta', |
|
782 |
false, |
|
783 |
array( |
|
784 |
'id' => 'newmeta-submit', |
|
785 |
'data-wp-lists' => 'add:the-list:newmeta', |
|
786 |
) |
|
787 |
); |
|
788 |
?> |
|
0 | 789 |
</div> |
9 | 790 |
<?php |
0 | 791 |
} |
792 |
||
793 |
/** |
|
19 | 794 |
* Prints out HTML form date elements for editing post or comment publish date. |
0 | 795 |
* |
796 |
* @since 0.71 |
|
7
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
797 |
* @since 4.4.0 Converted to use get_comment() instead of the global `$comment`. |
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
798 |
* |
16 | 799 |
* @global WP_Locale $wp_locale WordPress date and time locale object. |
0 | 800 |
* |
5 | 801 |
* @param int|bool $edit Accepts 1|true for editing the date, 0|false for adding the date. |
802 |
* @param int|bool $for_post Accepts 1|true for applying the date to a post, 0|false for a comment. |
|
803 |
* @param int $tab_index The tabindex attribute to add. Default 0. |
|
804 |
* @param int|bool $multi Optional. Whether the additional fields and buttons should be added. |
|
805 |
* Default 0|false. |
|
0 | 806 |
*/ |
807 |
function touch_time( $edit = 1, $for_post = 1, $tab_index = 0, $multi = 0 ) { |
|
7
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
808 |
global $wp_locale; |
0 | 809 |
$post = get_post(); |
810 |
||
9 | 811 |
if ( $for_post ) { |
16 | 812 |
$edit = ! ( in_array( $post->post_status, array( 'draft', 'pending' ), true ) && ( ! $post->post_date_gmt || '0000-00-00 00:00:00' === $post->post_date_gmt ) ); |
9 | 813 |
} |
0 | 814 |
|
815 |
$tab_index_attribute = ''; |
|
9 | 816 |
if ( (int) $tab_index > 0 ) { |
0 | 817 |
$tab_index_attribute = " tabindex=\"$tab_index\""; |
9 | 818 |
} |
0 | 819 |
|
16 | 820 |
// @todo Remove this? |
0 | 821 |
// echo '<label for="timestamp" style="display: block;"><input type="checkbox" class="checkbox" name="edit_date" value="1" id="timestamp"'.$tab_index_attribute.' /> '.__( 'Edit timestamp' ).'</label><br />'; |
822 |
||
9 | 823 |
$post_date = ( $for_post ) ? $post->post_date : get_comment()->comment_date; |
824 |
$jj = ( $edit ) ? mysql2date( 'd', $post_date, false ) : current_time( 'd' ); |
|
825 |
$mm = ( $edit ) ? mysql2date( 'm', $post_date, false ) : current_time( 'm' ); |
|
826 |
$aa = ( $edit ) ? mysql2date( 'Y', $post_date, false ) : current_time( 'Y' ); |
|
827 |
$hh = ( $edit ) ? mysql2date( 'H', $post_date, false ) : current_time( 'H' ); |
|
828 |
$mn = ( $edit ) ? mysql2date( 'i', $post_date, false ) : current_time( 'i' ); |
|
829 |
$ss = ( $edit ) ? mysql2date( 's', $post_date, false ) : current_time( 's' ); |
|
0 | 830 |
|
9 | 831 |
$cur_jj = current_time( 'd' ); |
832 |
$cur_mm = current_time( 'm' ); |
|
833 |
$cur_aa = current_time( 'Y' ); |
|
834 |
$cur_hh = current_time( 'H' ); |
|
835 |
$cur_mn = current_time( 'i' ); |
|
0 | 836 |
|
21
48c4eec2b7e6
Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents:
19
diff
changeset
|
837 |
$month = '<label><span class="screen-reader-text">' . |
48c4eec2b7e6
Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents:
19
diff
changeset
|
838 |
/* translators: Hidden accessibility text. */ |
48c4eec2b7e6
Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents:
19
diff
changeset
|
839 |
__( 'Month' ) . |
48c4eec2b7e6
Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents:
19
diff
changeset
|
840 |
'</span><select class="form-required" ' . ( $multi ? '' : 'id="mm" ' ) . 'name="mm"' . $tab_index_attribute . ">\n"; |
9 | 841 |
for ( $i = 1; $i < 13; $i = $i + 1 ) { |
842 |
$monthnum = zeroise( $i, 2 ); |
|
7
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
843 |
$monthtext = $wp_locale->get_month_abbrev( $wp_locale->get_month( $i ) ); |
9 | 844 |
$month .= "\t\t\t" . '<option value="' . $monthnum . '" data-text="' . $monthtext . '" ' . selected( $monthnum, $mm, false ) . '>'; |
16 | 845 |
/* translators: 1: Month number (01, 02, etc.), 2: Month abbreviation. */ |
7
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
846 |
$month .= sprintf( __( '%1$s-%2$s' ), $monthnum, $monthtext ) . "</option>\n"; |
0 | 847 |
} |
7
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
848 |
$month .= '</select></label>'; |
0 | 849 |
|
21
48c4eec2b7e6
Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents:
19
diff
changeset
|
850 |
$day = '<label><span class="screen-reader-text">' . |
48c4eec2b7e6
Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents:
19
diff
changeset
|
851 |
/* translators: Hidden accessibility text. */ |
48c4eec2b7e6
Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents:
19
diff
changeset
|
852 |
__( 'Day' ) . |
22
8c2e4d02f4ef
Update WordPress to latest version (6.7)
ymh <ymh.work@gmail.com>
parents:
21
diff
changeset
|
853 |
'</span><input type="text" ' . ( $multi ? '' : 'id="jj" ' ) . 'name="jj" value="' . $jj . '" size="2" maxlength="2"' . $tab_index_attribute . ' autocomplete="off" class="form-required" inputmode="numeric" /></label>'; |
21
48c4eec2b7e6
Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents:
19
diff
changeset
|
854 |
$year = '<label><span class="screen-reader-text">' . |
48c4eec2b7e6
Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents:
19
diff
changeset
|
855 |
/* translators: Hidden accessibility text. */ |
48c4eec2b7e6
Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents:
19
diff
changeset
|
856 |
__( 'Year' ) . |
22
8c2e4d02f4ef
Update WordPress to latest version (6.7)
ymh <ymh.work@gmail.com>
parents:
21
diff
changeset
|
857 |
'</span><input type="text" ' . ( $multi ? '' : 'id="aa" ' ) . 'name="aa" value="' . $aa . '" size="4" maxlength="4"' . $tab_index_attribute . ' autocomplete="off" class="form-required" inputmode="numeric" /></label>'; |
21
48c4eec2b7e6
Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents:
19
diff
changeset
|
858 |
$hour = '<label><span class="screen-reader-text">' . |
48c4eec2b7e6
Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents:
19
diff
changeset
|
859 |
/* translators: Hidden accessibility text. */ |
48c4eec2b7e6
Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents:
19
diff
changeset
|
860 |
__( 'Hour' ) . |
22
8c2e4d02f4ef
Update WordPress to latest version (6.7)
ymh <ymh.work@gmail.com>
parents:
21
diff
changeset
|
861 |
'</span><input type="text" ' . ( $multi ? '' : 'id="hh" ' ) . 'name="hh" value="' . $hh . '" size="2" maxlength="2"' . $tab_index_attribute . ' autocomplete="off" class="form-required" inputmode="numeric" /></label>'; |
21
48c4eec2b7e6
Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents:
19
diff
changeset
|
862 |
$minute = '<label><span class="screen-reader-text">' . |
48c4eec2b7e6
Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents:
19
diff
changeset
|
863 |
/* translators: Hidden accessibility text. */ |
48c4eec2b7e6
Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents:
19
diff
changeset
|
864 |
__( 'Minute' ) . |
22
8c2e4d02f4ef
Update WordPress to latest version (6.7)
ymh <ymh.work@gmail.com>
parents:
21
diff
changeset
|
865 |
'</span><input type="text" ' . ( $multi ? '' : 'id="mn" ' ) . 'name="mn" value="' . $mn . '" size="2" maxlength="2"' . $tab_index_attribute . ' autocomplete="off" class="form-required" inputmode="numeric" /></label>'; |
0 | 866 |
|
867 |
echo '<div class="timestamp-wrap">'; |
|
16 | 868 |
/* translators: 1: Month, 2: Day, 3: Year, 4: Hour, 5: Minute. */ |
869 |
printf( __( '%1$s %2$s, %3$s at %4$s:%5$s' ), $month, $day, $year, $hour, $minute ); |
|
0 | 870 |
|
871 |
echo '</div><input type="hidden" id="ss" name="ss" value="' . $ss . '" />'; |
|
872 |
||
9 | 873 |
if ( $multi ) { |
874 |
return; |
|
875 |
} |
|
0 | 876 |
|
877 |
echo "\n\n"; |
|
16 | 878 |
|
5 | 879 |
$map = array( |
880 |
'mm' => array( $mm, $cur_mm ), |
|
881 |
'jj' => array( $jj, $cur_jj ), |
|
882 |
'aa' => array( $aa, $cur_aa ), |
|
883 |
'hh' => array( $hh, $cur_hh ), |
|
884 |
'mn' => array( $mn, $cur_mn ), |
|
885 |
); |
|
16 | 886 |
|
5 | 887 |
foreach ( $map as $timeunit => $value ) { |
888 |
list( $unit, $curr ) = $value; |
|
889 |
||
890 |
echo '<input type="hidden" id="hidden_' . $timeunit . '" name="hidden_' . $timeunit . '" value="' . $unit . '" />' . "\n"; |
|
0 | 891 |
$cur_timeunit = 'cur_' . $timeunit; |
5 | 892 |
echo '<input type="hidden" id="' . $cur_timeunit . '" name="' . $cur_timeunit . '" value="' . $curr . '" />' . "\n"; |
0 | 893 |
} |
9 | 894 |
?> |
0 | 895 |
|
896 |
<p> |
|
9 | 897 |
<a href="#edit_timestamp" class="save-timestamp hide-if-no-js button"><?php _e( 'OK' ); ?></a> |
898 |
<a href="#edit_timestamp" class="cancel-timestamp hide-if-no-js button-cancel"><?php _e( 'Cancel' ); ?></a> |
|
0 | 899 |
</p> |
9 | 900 |
<?php |
0 | 901 |
} |
902 |
||
903 |
/** |
|
19 | 904 |
* Prints out option HTML elements for the page templates drop-down. |
0 | 905 |
* |
906 |
* @since 1.5.0 |
|
7
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
907 |
* @since 4.7.0 Added the `$post_type` parameter. |
0 | 908 |
* |
19 | 909 |
* @param string $default_template Optional. The template file name. Default empty. |
21
48c4eec2b7e6
Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents:
19
diff
changeset
|
910 |
* @param string $post_type Optional. Post type to get templates for. Default 'page'. |
0 | 911 |
*/ |
19 | 912 |
function page_template_dropdown( $default_template = '', $post_type = 'page' ) { |
7
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
913 |
$templates = get_page_templates( null, $post_type ); |
16 | 914 |
|
0 | 915 |
ksort( $templates ); |
16 | 916 |
|
5 | 917 |
foreach ( array_keys( $templates ) as $template ) { |
19 | 918 |
$selected = selected( $default_template, $templates[ $template ], false ); |
9 | 919 |
echo "\n\t<option value='" . esc_attr( $templates[ $template ] ) . "' $selected>" . esc_html( $template ) . '</option>'; |
5 | 920 |
} |
0 | 921 |
} |
922 |
||
923 |
/** |
|
19 | 924 |
* Prints out option HTML elements for the page parents drop-down. |
0 | 925 |
* |
926 |
* @since 1.5.0 |
|
7
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
927 |
* @since 4.4.0 `$post` argument was added. |
0 | 928 |
* |
7
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
929 |
* @global wpdb $wpdb WordPress database abstraction object. |
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
930 |
* |
19 | 931 |
* @param int $default_page Optional. The default page ID to be pre-selected. Default 0. |
21
48c4eec2b7e6
Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents:
19
diff
changeset
|
932 |
* @param int $parent_page Optional. The parent page ID. Default 0. |
19 | 933 |
* @param int $level Optional. Page depth level. Default 0. |
934 |
* @param int|WP_Post $post Post ID or WP_Post object. |
|
16 | 935 |
* @return void|false Void on success, false if the page has no children. |
0 | 936 |
*/ |
21
48c4eec2b7e6
Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents:
19
diff
changeset
|
937 |
function parent_dropdown( $default_page = 0, $parent_page = 0, $level = 0, $post = null ) { |
0 | 938 |
global $wpdb; |
16 | 939 |
|
9 | 940 |
$post = get_post( $post ); |
21
48c4eec2b7e6
Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents:
19
diff
changeset
|
941 |
$items = $wpdb->get_results( |
48c4eec2b7e6
Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents:
19
diff
changeset
|
942 |
$wpdb->prepare( |
48c4eec2b7e6
Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents:
19
diff
changeset
|
943 |
"SELECT ID, post_parent, post_title |
48c4eec2b7e6
Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents:
19
diff
changeset
|
944 |
FROM $wpdb->posts |
48c4eec2b7e6
Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents:
19
diff
changeset
|
945 |
WHERE post_parent = %d AND post_type = 'page' |
48c4eec2b7e6
Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents:
19
diff
changeset
|
946 |
ORDER BY menu_order", |
48c4eec2b7e6
Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents:
19
diff
changeset
|
947 |
$parent_page |
48c4eec2b7e6
Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents:
19
diff
changeset
|
948 |
) |
48c4eec2b7e6
Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents:
19
diff
changeset
|
949 |
); |
0 | 950 |
|
951 |
if ( $items ) { |
|
952 |
foreach ( $items as $item ) { |
|
953 |
// A page cannot be its own parent. |
|
16 | 954 |
if ( $post && $post->ID && (int) $item->ID === $post->ID ) { |
0 | 955 |
continue; |
9 | 956 |
} |
0 | 957 |
|
9 | 958 |
$pad = str_repeat( ' ', $level * 3 ); |
19 | 959 |
$selected = selected( $default_page, $item->ID, false ); |
0 | 960 |
|
9 | 961 |
echo "\n\t<option class='level-$level' value='$item->ID' $selected>$pad " . esc_html( $item->post_title ) . '</option>'; |
19 | 962 |
parent_dropdown( $default_page, $item->ID, $level + 1 ); |
0 | 963 |
} |
964 |
} else { |
|
965 |
return false; |
|
966 |
} |
|
967 |
} |
|
968 |
||
969 |
/** |
|
19 | 970 |
* Prints out option HTML elements for role selectors. |
0 | 971 |
* |
972 |
* @since 2.1.0 |
|
973 |
* |
|
5 | 974 |
* @param string $selected Slug for the role that should be already selected. |
0 | 975 |
*/ |
5 | 976 |
function wp_dropdown_roles( $selected = '' ) { |
0 | 977 |
$r = ''; |
978 |
||
979 |
$editable_roles = array_reverse( get_editable_roles() ); |
|
980 |
||
981 |
foreach ( $editable_roles as $role => $details ) { |
|
9 | 982 |
$name = translate_user_role( $details['name'] ); |
16 | 983 |
// Preselect specified role. |
984 |
if ( $selected === $role ) { |
|
7
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
985 |
$r .= "\n\t<option selected='selected' value='" . esc_attr( $role ) . "'>$name</option>"; |
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
986 |
} else { |
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
987 |
$r .= "\n\t<option value='" . esc_attr( $role ) . "'>$name</option>"; |
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
988 |
} |
0 | 989 |
} |
7
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
990 |
|
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
991 |
echo $r; |
0 | 992 |
} |
993 |
||
994 |
/** |
|
21
48c4eec2b7e6
Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents:
19
diff
changeset
|
995 |
* Outputs the form used by the importers to accept the data to be imported. |
0 | 996 |
* |
997 |
* @since 2.0.0 |
|
998 |
* |
|
999 |
* @param string $action The action attribute for the form. |
|
1000 |
*/ |
|
1001 |
function wp_import_upload_form( $action ) { |
|
5 | 1002 |
|
1003 |
/** |
|
7
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
1004 |
* Filters the maximum allowed upload size for import files. |
5 | 1005 |
* |
1006 |
* @since 2.3.0 |
|
1007 |
* |
|
1008 |
* @see wp_max_upload_size() |
|
1009 |
* |
|
1010 |
* @param int $max_upload_size Allowed upload size. Default 1 MB. |
|
1011 |
*/ |
|
9 | 1012 |
$bytes = apply_filters( 'import_upload_size_limit', wp_max_upload_size() ); |
1013 |
$size = size_format( $bytes ); |
|
0 | 1014 |
$upload_dir = wp_upload_dir(); |
1015 |
if ( ! empty( $upload_dir['error'] ) ) : |
|
21
48c4eec2b7e6
Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents:
19
diff
changeset
|
1016 |
$upload_directory_error = '<p>' . __( 'Before you can upload your import file, you will need to fix the following error:' ) . '</p>'; |
48c4eec2b7e6
Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents:
19
diff
changeset
|
1017 |
$upload_directory_error .= '<p><strong>' . $upload_dir['error'] . '</strong></p>'; |
48c4eec2b7e6
Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents:
19
diff
changeset
|
1018 |
wp_admin_notice( |
48c4eec2b7e6
Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents:
19
diff
changeset
|
1019 |
$upload_directory_error, |
48c4eec2b7e6
Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents:
19
diff
changeset
|
1020 |
array( |
48c4eec2b7e6
Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents:
19
diff
changeset
|
1021 |
'additional_classes' => array( 'error' ), |
48c4eec2b7e6
Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents:
19
diff
changeset
|
1022 |
'paragraph_wrap' => false, |
48c4eec2b7e6
Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents:
19
diff
changeset
|
1023 |
) |
48c4eec2b7e6
Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents:
19
diff
changeset
|
1024 |
); |
0 | 1025 |
else : |
9 | 1026 |
?> |
0 | 1027 |
<form enctype="multipart/form-data" id="import-upload-form" method="post" class="wp-upload-form" action="<?php echo esc_url( wp_nonce_url( $action, 'import-upload' ) ); ?>"> |
1028 |
<p> |
|
16 | 1029 |
<?php |
1030 |
printf( |
|
1031 |
'<label for="upload">%s</label> (%s)', |
|
1032 |
__( 'Choose a file from your computer:' ), |
|
1033 |
/* translators: %s: Maximum allowed file size. */ |
|
1034 |
sprintf( __( 'Maximum size: %s' ), $size ) |
|
1035 |
); |
|
1036 |
?> |
|
0 | 1037 |
<input type="file" id="upload" name="import" size="25" /> |
1038 |
<input type="hidden" name="action" value="save" /> |
|
1039 |
<input type="hidden" name="max_file_size" value="<?php echo $bytes; ?>" /> |
|
1040 |
</p> |
|
9 | 1041 |
<?php submit_button( __( 'Upload file and import' ), 'primary' ); ?> |
0 | 1042 |
</form> |
9 | 1043 |
<?php |
0 | 1044 |
endif; |
1045 |
} |
|
1046 |
||
1047 |
/** |
|
7
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
1048 |
* Adds a meta box to one or more screens. |
0 | 1049 |
* |
1050 |
* @since 2.5.0 |
|
7
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
1051 |
* @since 4.4.0 The `$screen` parameter now accepts an array of screen IDs. |
0 | 1052 |
* |
21
48c4eec2b7e6
Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents:
19
diff
changeset
|
1053 |
* @global array $wp_meta_boxes Global meta box state. |
7
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
1054 |
* |
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
1055 |
* @param string $id Meta box ID (used in the 'id' attribute for the meta box). |
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
1056 |
* @param string $title Title of the meta box. |
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
1057 |
* @param callable $callback Function that fills the box with the desired content. |
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
1058 |
* The function should echo its output. |
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
1059 |
* @param string|array|WP_Screen $screen Optional. The screen or screens on which to show the box |
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
1060 |
* (such as a post type, 'link', or 'comment'). Accepts a single |
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
1061 |
* screen ID, WP_Screen object, or array of screen IDs. Default |
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
1062 |
* is the current screen. If you have used add_menu_page() or |
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
1063 |
* add_submenu_page() to create a new screen (and hence screen_id), |
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
1064 |
* make sure your menu slug conforms to the limits of sanitize_key() |
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
1065 |
* otherwise the 'screen' menu may not correctly render on your page. |
18 | 1066 |
* @param string $context Optional. The context within the screen where the box |
7
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
1067 |
* should display. Available contexts vary from screen to |
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
1068 |
* screen. Post edit screen contexts include 'normal', 'side', |
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
1069 |
* and 'advanced'. Comments screen contexts include 'normal' |
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
1070 |
* and 'side'. Menus meta boxes (accordion sections) all use |
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
1071 |
* the 'side' context. Global default is 'advanced'. |
18 | 1072 |
* @param string $priority Optional. The priority within the context where the box should show. |
1073 |
* Accepts 'high', 'core', 'default', or 'low'. Default 'default'. |
|
7
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
1074 |
* @param array $callback_args Optional. Data that should be set as the $args property |
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
1075 |
* of the box array (which is the second parameter passed |
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
1076 |
* to your callback). Default null. |
0 | 1077 |
*/ |
1078 |
function add_meta_box( $id, $title, $callback, $screen = null, $context = 'advanced', $priority = 'default', $callback_args = null ) { |
|
1079 |
global $wp_meta_boxes; |
|
1080 |
||
7
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
1081 |
if ( empty( $screen ) ) { |
0 | 1082 |
$screen = get_current_screen(); |
7
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
1083 |
} elseif ( is_string( $screen ) ) { |
0 | 1084 |
$screen = convert_to_screen( $screen ); |
7
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
1085 |
} elseif ( is_array( $screen ) ) { |
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
1086 |
foreach ( $screen as $single_screen ) { |
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
1087 |
add_meta_box( $id, $title, $callback, $single_screen, $context, $priority, $callback_args ); |
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
1088 |
} |
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
1089 |
} |
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
1090 |
|
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
1091 |
if ( ! isset( $screen->id ) ) { |
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
1092 |
return; |
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
1093 |
} |
0 | 1094 |
|
1095 |
$page = $screen->id; |
|
1096 |
||
9 | 1097 |
if ( ! isset( $wp_meta_boxes ) ) { |
0 | 1098 |
$wp_meta_boxes = array(); |
9 | 1099 |
} |
1100 |
if ( ! isset( $wp_meta_boxes[ $page ] ) ) { |
|
1101 |
$wp_meta_boxes[ $page ] = array(); |
|
1102 |
} |
|
1103 |
if ( ! isset( $wp_meta_boxes[ $page ][ $context ] ) ) { |
|
1104 |
$wp_meta_boxes[ $page ][ $context ] = array(); |
|
1105 |
} |
|
0 | 1106 |
|
9 | 1107 |
foreach ( array_keys( $wp_meta_boxes[ $page ] ) as $a_context ) { |
1108 |
foreach ( array( 'high', 'core', 'default', 'low' ) as $a_priority ) { |
|
1109 |
if ( ! isset( $wp_meta_boxes[ $page ][ $a_context ][ $a_priority ][ $id ] ) ) { |
|
0 | 1110 |
continue; |
9 | 1111 |
} |
0 | 1112 |
|
16 | 1113 |
// If a core box was previously removed, don't add. |
1114 |
if ( ( 'core' === $priority || 'sorted' === $priority ) |
|
1115 |
&& false === $wp_meta_boxes[ $page ][ $a_context ][ $a_priority ][ $id ] |
|
1116 |
) { |
|
1117 |
return; |
|
1118 |
} |
|
5 | 1119 |
|
16 | 1120 |
// If a core box was previously added by a plugin, don't add. |
1121 |
if ( 'core' === $priority ) { |
|
5 | 1122 |
/* |
16 | 1123 |
* If the box was added with default priority, give it core priority |
1124 |
* to maintain sort order. |
|
5 | 1125 |
*/ |
16 | 1126 |
if ( 'default' === $a_priority ) { |
9 | 1127 |
$wp_meta_boxes[ $page ][ $a_context ]['core'][ $id ] = $wp_meta_boxes[ $page ][ $a_context ]['default'][ $id ]; |
1128 |
unset( $wp_meta_boxes[ $page ][ $a_context ]['default'][ $id ] ); |
|
0 | 1129 |
} |
1130 |
return; |
|
1131 |
} |
|
16 | 1132 |
|
1133 |
// If no priority given and ID already present, use existing priority. |
|
9 | 1134 |
if ( empty( $priority ) ) { |
0 | 1135 |
$priority = $a_priority; |
9 | 1136 |
/* |
16 | 1137 |
* Else, if we're adding to the sorted priority, we don't know the title |
1138 |
* or callback. Grab them from the previously added context/priority. |
|
1139 |
*/ |
|
1140 |
} elseif ( 'sorted' === $priority ) { |
|
9 | 1141 |
$title = $wp_meta_boxes[ $page ][ $a_context ][ $a_priority ][ $id ]['title']; |
1142 |
$callback = $wp_meta_boxes[ $page ][ $a_context ][ $a_priority ][ $id ]['callback']; |
|
1143 |
$callback_args = $wp_meta_boxes[ $page ][ $a_context ][ $a_priority ][ $id ]['args']; |
|
0 | 1144 |
} |
16 | 1145 |
|
1146 |
// An ID can be in only one priority and one context. |
|
1147 |
if ( $priority !== $a_priority || $context !== $a_context ) { |
|
9 | 1148 |
unset( $wp_meta_boxes[ $page ][ $a_context ][ $a_priority ][ $id ] ); |
1149 |
} |
|
0 | 1150 |
} |
1151 |
} |
|
1152 |
||
9 | 1153 |
if ( empty( $priority ) ) { |
0 | 1154 |
$priority = 'low'; |
9 | 1155 |
} |
1156 |
||
1157 |
if ( ! isset( $wp_meta_boxes[ $page ][ $context ][ $priority ] ) ) { |
|
1158 |
$wp_meta_boxes[ $page ][ $context ][ $priority ] = array(); |
|
1159 |
} |
|
1160 |
||
1161 |
$wp_meta_boxes[ $page ][ $context ][ $priority ][ $id ] = array( |
|
1162 |
'id' => $id, |
|
1163 |
'title' => $title, |
|
1164 |
'callback' => $callback, |
|
1165 |
'args' => $callback_args, |
|
1166 |
); |
|
1167 |
} |
|
1168 |
||
0 | 1169 |
|
9 | 1170 |
/** |
19 | 1171 |
* Renders a "fake" meta box with an information message, |
9 | 1172 |
* shown on the block editor, when an incompatible meta box is found. |
1173 |
* |
|
1174 |
* @since 5.0.0 |
|
1175 |
* |
|
19 | 1176 |
* @param mixed $data_object The data object being rendered on this screen. |
1177 |
* @param array $box { |
|
9 | 1178 |
* Custom formats meta box arguments. |
1179 |
* |
|
1180 |
* @type string $id Meta box 'id' attribute. |
|
1181 |
* @type string $title Meta box title. |
|
1182 |
* @type callable $old_callback The original callback for this meta box. |
|
1183 |
* @type array $args Extra meta box arguments. |
|
1184 |
* } |
|
1185 |
*/ |
|
19 | 1186 |
function do_block_editor_incompatible_meta_box( $data_object, $box ) { |
9 | 1187 |
$plugin = _get_plugin_from_callback( $box['old_callback'] ); |
1188 |
$plugins = get_plugins(); |
|
1189 |
echo '<p>'; |
|
1190 |
if ( $plugin ) { |
|
16 | 1191 |
/* translators: %s: The name of the plugin that generated this meta box. */ |
19 | 1192 |
printf( __( 'This meta box, from the %s plugin, is not compatible with the block editor.' ), "<strong>{$plugin['Name']}</strong>" ); |
9 | 1193 |
} else { |
19 | 1194 |
_e( 'This meta box is not compatible with the block editor.' ); |
9 | 1195 |
} |
1196 |
echo '</p>'; |
|
0 | 1197 |
|
9 | 1198 |
if ( empty( $plugins['classic-editor/classic-editor.php'] ) ) { |
1199 |
if ( current_user_can( 'install_plugins' ) ) { |
|
18 | 1200 |
$install_url = wp_nonce_url( |
1201 |
self_admin_url( 'plugin-install.php?tab=favorites&user=wordpressdotorg&save=0' ), |
|
1202 |
'save_wporg_username_' . get_current_user_id() |
|
1203 |
); |
|
1204 |
||
9 | 1205 |
echo '<p>'; |
18 | 1206 |
/* translators: %s: A link to install the Classic Editor plugin. */ |
1207 |
printf( __( 'Please install the <a href="%s">Classic Editor plugin</a> to use this meta box.' ), esc_url( $install_url ) ); |
|
9 | 1208 |
echo '</p>'; |
1209 |
} |
|
1210 |
} elseif ( is_plugin_inactive( 'classic-editor/classic-editor.php' ) ) { |
|
1211 |
if ( current_user_can( 'activate_plugins' ) ) { |
|
18 | 1212 |
$activate_url = wp_nonce_url( |
1213 |
self_admin_url( 'plugins.php?action=activate&plugin=classic-editor/classic-editor.php' ), |
|
1214 |
'activate-plugin_classic-editor/classic-editor.php' |
|
1215 |
); |
|
1216 |
||
9 | 1217 |
echo '<p>'; |
1218 |
/* translators: %s: A link to activate the Classic Editor plugin. */ |
|
1219 |
printf( __( 'Please activate the <a href="%s">Classic Editor plugin</a> to use this meta box.' ), esc_url( $activate_url ) ); |
|
1220 |
echo '</p>'; |
|
1221 |
} |
|
19 | 1222 |
} elseif ( $data_object instanceof WP_Post ) { |
9 | 1223 |
$edit_url = add_query_arg( |
1224 |
array( |
|
1225 |
'classic-editor' => '', |
|
1226 |
'classic-editor__forget' => '', |
|
1227 |
), |
|
19 | 1228 |
get_edit_post_link( $data_object ) |
9 | 1229 |
); |
1230 |
echo '<p>'; |
|
1231 |
/* translators: %s: A link to use the Classic Editor plugin. */ |
|
1232 |
printf( __( 'Please open the <a href="%s">classic editor</a> to use this meta box.' ), esc_url( $edit_url ) ); |
|
1233 |
echo '</p>'; |
|
1234 |
} |
|
0 | 1235 |
} |
1236 |
||
1237 |
/** |
|
9 | 1238 |
* Internal helper function to find the plugin from a meta box callback. |
1239 |
* |
|
1240 |
* @since 5.0.0 |
|
1241 |
* |
|
1242 |
* @access private |
|
1243 |
* |
|
1244 |
* @param callable $callback The callback function to check. |
|
1245 |
* @return array|null The plugin that the callback belongs to, or null if it doesn't belong to a plugin. |
|
1246 |
*/ |
|
1247 |
function _get_plugin_from_callback( $callback ) { |
|
1248 |
try { |
|
1249 |
if ( is_array( $callback ) ) { |
|
1250 |
$reflection = new ReflectionMethod( $callback[0], $callback[1] ); |
|
21
48c4eec2b7e6
Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents:
19
diff
changeset
|
1251 |
} elseif ( is_string( $callback ) && str_contains( $callback, '::' ) ) { |
9 | 1252 |
$reflection = new ReflectionMethod( $callback ); |
1253 |
} else { |
|
1254 |
$reflection = new ReflectionFunction( $callback ); |
|
1255 |
} |
|
1256 |
} catch ( ReflectionException $exception ) { |
|
1257 |
// We could not properly reflect on the callable, so we abort here. |
|
1258 |
return null; |
|
1259 |
} |
|
1260 |
||
1261 |
// Don't show an error if it's an internal PHP function. |
|
1262 |
if ( ! $reflection->isInternal() ) { |
|
1263 |
||
1264 |
// Only show errors if the meta box was registered by a plugin. |
|
1265 |
$filename = wp_normalize_path( $reflection->getFileName() ); |
|
1266 |
$plugin_dir = wp_normalize_path( WP_PLUGIN_DIR ); |
|
16 | 1267 |
|
21
48c4eec2b7e6
Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents:
19
diff
changeset
|
1268 |
if ( str_starts_with( $filename, $plugin_dir ) ) { |
9 | 1269 |
$filename = str_replace( $plugin_dir, '', $filename ); |
1270 |
$filename = preg_replace( '|^/([^/]*/).*$|', '\\1', $filename ); |
|
1271 |
||
1272 |
$plugins = get_plugins(); |
|
16 | 1273 |
|
9 | 1274 |
foreach ( $plugins as $name => $plugin ) { |
21
48c4eec2b7e6
Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents:
19
diff
changeset
|
1275 |
if ( str_starts_with( $name, $filename ) ) { |
9 | 1276 |
return $plugin; |
1277 |
} |
|
1278 |
} |
|
1279 |
} |
|
1280 |
} |
|
1281 |
||
1282 |
return null; |
|
1283 |
} |
|
1284 |
||
1285 |
/** |
|
1286 |
* Meta-Box template function. |
|
0 | 1287 |
* |
1288 |
* @since 2.5.0 |
|
1289 |
* |
|
21
48c4eec2b7e6
Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents:
19
diff
changeset
|
1290 |
* @global array $wp_meta_boxes Global meta box state. |
7
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
1291 |
* |
19 | 1292 |
* @param string|WP_Screen $screen The screen identifier. If you have used add_menu_page() or |
1293 |
* add_submenu_page() to create a new screen (and hence screen_id) |
|
1294 |
* make sure your menu slug conforms to the limits of sanitize_key() |
|
1295 |
* otherwise the 'screen' menu may not correctly render on your page. |
|
1296 |
* @param string $context The screen context for which to display meta boxes. |
|
1297 |
* @param mixed $data_object Gets passed to the meta box callback function as the first parameter. |
|
1298 |
* Often this is the object that's the focus of the current screen, |
|
1299 |
* for example a `WP_Post` or `WP_Comment` object. |
|
16 | 1300 |
* @return int Number of meta_boxes. |
0 | 1301 |
*/ |
19 | 1302 |
function do_meta_boxes( $screen, $context, $data_object ) { |
0 | 1303 |
global $wp_meta_boxes; |
1304 |
static $already_sorted = false; |
|
1305 |
||
9 | 1306 |
if ( empty( $screen ) ) { |
0 | 1307 |
$screen = get_current_screen(); |
9 | 1308 |
} elseif ( is_string( $screen ) ) { |
0 | 1309 |
$screen = convert_to_screen( $screen ); |
9 | 1310 |
} |
0 | 1311 |
|
1312 |
$page = $screen->id; |
|
1313 |
||
1314 |
$hidden = get_hidden_meta_boxes( $screen ); |
|
1315 |
||
7
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
1316 |
printf( '<div id="%s-sortables" class="meta-box-sortables">', esc_attr( $context ) ); |
0 | 1317 |
|
21
48c4eec2b7e6
Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents:
19
diff
changeset
|
1318 |
/* |
48c4eec2b7e6
Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents:
19
diff
changeset
|
1319 |
* Grab the ones the user has manually sorted. |
48c4eec2b7e6
Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents:
19
diff
changeset
|
1320 |
* Pull them out of their previous context/priority and into the one the user chose. |
48c4eec2b7e6
Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents:
19
diff
changeset
|
1321 |
*/ |
16 | 1322 |
$sorted = get_user_option( "meta-box-order_$page" ); |
1323 |
||
1324 |
if ( ! $already_sorted && $sorted ) { |
|
5 | 1325 |
foreach ( $sorted as $box_context => $ids ) { |
1326 |
foreach ( explode( ',', $ids ) as $id ) { |
|
1327 |
if ( $id && 'dashboard_browser_nag' !== $id ) { |
|
1328 |
add_meta_box( $id, null, null, $screen, $box_context, 'sorted' ); |
|
0 | 1329 |
} |
1330 |
} |
|
1331 |
} |
|
5 | 1332 |
} |
1333 |
||
1334 |
$already_sorted = true; |
|
0 | 1335 |
|
5 | 1336 |
$i = 0; |
0 | 1337 |
|
5 | 1338 |
if ( isset( $wp_meta_boxes[ $page ][ $context ] ) ) { |
1339 |
foreach ( array( 'high', 'sorted', 'core', 'default', 'low' ) as $priority ) { |
|
9 | 1340 |
if ( isset( $wp_meta_boxes[ $page ][ $context ][ $priority ] ) ) { |
5 | 1341 |
foreach ( (array) $wp_meta_boxes[ $page ][ $context ][ $priority ] as $box ) { |
16 | 1342 |
if ( false === $box || ! $box['title'] ) { |
0 | 1343 |
continue; |
9 | 1344 |
} |
1345 |
||
1346 |
$block_compatible = true; |
|
1347 |
if ( is_array( $box['args'] ) ) { |
|
1348 |
// If a meta box is just here for back compat, don't show it in the block editor. |
|
1349 |
if ( $screen->is_block_editor() && isset( $box['args']['__back_compat_meta_box'] ) && $box['args']['__back_compat_meta_box'] ) { |
|
1350 |
continue; |
|
1351 |
} |
|
1352 |
||
1353 |
if ( isset( $box['args']['__block_editor_compatible_meta_box'] ) ) { |
|
1354 |
$block_compatible = (bool) $box['args']['__block_editor_compatible_meta_box']; |
|
1355 |
unset( $box['args']['__block_editor_compatible_meta_box'] ); |
|
1356 |
} |
|
1357 |
||
1358 |
// If the meta box is declared as incompatible with the block editor, override the callback function. |
|
1359 |
if ( ! $block_compatible && $screen->is_block_editor() ) { |
|
1360 |
$box['old_callback'] = $box['callback']; |
|
1361 |
$box['callback'] = 'do_block_editor_incompatible_meta_box'; |
|
1362 |
} |
|
1363 |
||
1364 |
if ( isset( $box['args']['__back_compat_meta_box'] ) ) { |
|
1365 |
$block_compatible = $block_compatible || (bool) $box['args']['__back_compat_meta_box']; |
|
1366 |
unset( $box['args']['__back_compat_meta_box'] ); |
|
1367 |
} |
|
1368 |
} |
|
1369 |
||
21
48c4eec2b7e6
Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents:
19
diff
changeset
|
1370 |
++$i; |
9 | 1371 |
// get_hidden_meta_boxes() doesn't apply in the block editor. |
16 | 1372 |
$hidden_class = ( ! $screen->is_block_editor() && in_array( $box['id'], $hidden, true ) ) ? ' hide-if-js' : ''; |
9 | 1373 |
echo '<div id="' . $box['id'] . '" class="postbox ' . postbox_classes( $box['id'], $page ) . $hidden_class . '" ' . '>' . "\n"; |
16 | 1374 |
|
1375 |
echo '<div class="postbox-header">'; |
|
1376 |
echo '<h2 class="hndle">'; |
|
1377 |
if ( 'dashboard_php_nag' === $box['id'] ) { |
|
1378 |
echo '<span aria-hidden="true" class="dashicons dashicons-warning"></span>'; |
|
21
48c4eec2b7e6
Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents:
19
diff
changeset
|
1379 |
echo '<span class="screen-reader-text">' . |
48c4eec2b7e6
Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents:
19
diff
changeset
|
1380 |
/* translators: Hidden accessibility text. */ |
48c4eec2b7e6
Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents:
19
diff
changeset
|
1381 |
__( 'Warning:' ) . |
48c4eec2b7e6
Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents:
19
diff
changeset
|
1382 |
' </span>'; |
16 | 1383 |
} |
18 | 1384 |
echo $box['title']; |
16 | 1385 |
echo "</h2>\n"; |
1386 |
||
1387 |
if ( 'dashboard_browser_nag' !== $box['id'] ) { |
|
9 | 1388 |
$widget_title = $box['title']; |
7
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
1389 |
|
9 | 1390 |
if ( is_array( $box['args'] ) && isset( $box['args']['__widget_basename'] ) ) { |
1391 |
$widget_title = $box['args']['__widget_basename']; |
|
7
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
1392 |
// Do not pass this parameter to the user callback function. |
9 | 1393 |
unset( $box['args']['__widget_basename'] ); |
7
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
1394 |
} |
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
1395 |
|
16 | 1396 |
echo '<div class="handle-actions hide-if-no-js">'; |
1397 |
||
1398 |
echo '<button type="button" class="handle-order-higher" aria-disabled="false" aria-describedby="' . $box['id'] . '-handle-order-higher-description">'; |
|
21
48c4eec2b7e6
Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents:
19
diff
changeset
|
1399 |
echo '<span class="screen-reader-text">' . |
48c4eec2b7e6
Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents:
19
diff
changeset
|
1400 |
/* translators: Hidden accessibility text. */ |
48c4eec2b7e6
Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents:
19
diff
changeset
|
1401 |
__( 'Move up' ) . |
48c4eec2b7e6
Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents:
19
diff
changeset
|
1402 |
'</span>'; |
16 | 1403 |
echo '<span class="order-higher-indicator" aria-hidden="true"></span>'; |
1404 |
echo '</button>'; |
|
1405 |
echo '<span class="hidden" id="' . $box['id'] . '-handle-order-higher-description">' . sprintf( |
|
1406 |
/* translators: %s: Meta box title. */ |
|
1407 |
__( 'Move %s box up' ), |
|
1408 |
$widget_title |
|
1409 |
) . '</span>'; |
|
1410 |
||
1411 |
echo '<button type="button" class="handle-order-lower" aria-disabled="false" aria-describedby="' . $box['id'] . '-handle-order-lower-description">'; |
|
21
48c4eec2b7e6
Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents:
19
diff
changeset
|
1412 |
echo '<span class="screen-reader-text">' . |
48c4eec2b7e6
Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents:
19
diff
changeset
|
1413 |
/* translators: Hidden accessibility text. */ |
48c4eec2b7e6
Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents:
19
diff
changeset
|
1414 |
__( 'Move down' ) . |
48c4eec2b7e6
Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents:
19
diff
changeset
|
1415 |
'</span>'; |
16 | 1416 |
echo '<span class="order-lower-indicator" aria-hidden="true"></span>'; |
1417 |
echo '</button>'; |
|
1418 |
echo '<span class="hidden" id="' . $box['id'] . '-handle-order-lower-description">' . sprintf( |
|
1419 |
/* translators: %s: Meta box title. */ |
|
1420 |
__( 'Move %s box down' ), |
|
1421 |
$widget_title |
|
1422 |
) . '</span>'; |
|
1423 |
||
7
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
1424 |
echo '<button type="button" class="handlediv" aria-expanded="true">'; |
16 | 1425 |
echo '<span class="screen-reader-text">' . sprintf( |
21
48c4eec2b7e6
Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents:
19
diff
changeset
|
1426 |
/* translators: %s: Hidden accessibility text. Meta box title. */ |
16 | 1427 |
__( 'Toggle panel: %s' ), |
1428 |
$widget_title |
|
1429 |
) . '</span>'; |
|
7
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
1430 |
echo '<span class="toggle-indicator" aria-hidden="true"></span>'; |
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
1431 |
echo '</button>'; |
16 | 1432 |
|
1433 |
echo '</div>'; |
|
7
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
1434 |
} |
16 | 1435 |
echo '</div>'; |
1436 |
||
0 | 1437 |
echo '<div class="inside">' . "\n"; |
9 | 1438 |
|
1439 |
if ( WP_DEBUG && ! $block_compatible && 'edit' === $screen->parent_base && ! $screen->is_block_editor() && ! isset( $_GET['meta-box-loader'] ) ) { |
|
1440 |
$plugin = _get_plugin_from_callback( $box['callback'] ); |
|
1441 |
if ( $plugin ) { |
|
21
48c4eec2b7e6
Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents:
19
diff
changeset
|
1442 |
$meta_box_not_compatible_message = sprintf( |
48c4eec2b7e6
Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents:
19
diff
changeset
|
1443 |
/* translators: %s: The name of the plugin that generated this meta box. */ |
48c4eec2b7e6
Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents:
19
diff
changeset
|
1444 |
__( 'This meta box, from the %s plugin, is not compatible with the block editor.' ), |
48c4eec2b7e6
Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents:
19
diff
changeset
|
1445 |
"<strong>{$plugin['Name']}</strong>" |
48c4eec2b7e6
Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents:
19
diff
changeset
|
1446 |
); |
48c4eec2b7e6
Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents:
19
diff
changeset
|
1447 |
wp_admin_notice( |
48c4eec2b7e6
Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents:
19
diff
changeset
|
1448 |
$meta_box_not_compatible_message, |
48c4eec2b7e6
Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents:
19
diff
changeset
|
1449 |
array( |
48c4eec2b7e6
Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents:
19
diff
changeset
|
1450 |
'additional_classes' => array( 'error', 'inline' ), |
48c4eec2b7e6
Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents:
19
diff
changeset
|
1451 |
) |
48c4eec2b7e6
Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents:
19
diff
changeset
|
1452 |
); |
9 | 1453 |
} |
1454 |
} |
|
1455 |
||
19 | 1456 |
call_user_func( $box['callback'], $data_object, $box ); |
0 | 1457 |
echo "</div>\n"; |
1458 |
echo "</div>\n"; |
|
1459 |
} |
|
1460 |
} |
|
1461 |
} |
|
5 | 1462 |
} |
0 | 1463 |
|
9 | 1464 |
echo '</div>'; |
0 | 1465 |
|
1466 |
return $i; |
|
1467 |
} |
|
1468 |
||
1469 |
/** |
|
7
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
1470 |
* Removes a meta box from one or more screens. |
0 | 1471 |
* |
1472 |
* @since 2.6.0 |
|
7
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
1473 |
* @since 4.4.0 The `$screen` parameter now accepts an array of screen IDs. |
0 | 1474 |
* |
21
48c4eec2b7e6
Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents:
19
diff
changeset
|
1475 |
* @global array $wp_meta_boxes Global meta box state. |
7
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
1476 |
* |
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
1477 |
* @param string $id Meta box ID (used in the 'id' attribute for the meta box). |
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
1478 |
* @param string|array|WP_Screen $screen The screen or screens on which the meta box is shown (such as a |
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
1479 |
* post type, 'link', or 'comment'). Accepts a single screen ID, |
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
1480 |
* WP_Screen object, or array of screen IDs. |
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
1481 |
* @param string $context The context within the screen where the box is set to display. |
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
1482 |
* Contexts vary from screen to screen. Post edit screen contexts |
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
1483 |
* include 'normal', 'side', and 'advanced'. Comments screen contexts |
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
1484 |
* include 'normal' and 'side'. Menus meta boxes (accordion sections) |
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
1485 |
* all use the 'side' context. |
0 | 1486 |
*/ |
7
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
1487 |
function remove_meta_box( $id, $screen, $context ) { |
0 | 1488 |
global $wp_meta_boxes; |
1489 |
||
7
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
1490 |
if ( empty( $screen ) ) { |
0 | 1491 |
$screen = get_current_screen(); |
7
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
1492 |
} elseif ( is_string( $screen ) ) { |
0 | 1493 |
$screen = convert_to_screen( $screen ); |
7
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
1494 |
} elseif ( is_array( $screen ) ) { |
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
1495 |
foreach ( $screen as $single_screen ) { |
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
1496 |
remove_meta_box( $id, $single_screen, $context ); |
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
1497 |
} |
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
1498 |
} |
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
1499 |
|
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
1500 |
if ( ! isset( $screen->id ) ) { |
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
1501 |
return; |
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
1502 |
} |
0 | 1503 |
|
1504 |
$page = $screen->id; |
|
1505 |
||
9 | 1506 |
if ( ! isset( $wp_meta_boxes ) ) { |
0 | 1507 |
$wp_meta_boxes = array(); |
9 | 1508 |
} |
1509 |
if ( ! isset( $wp_meta_boxes[ $page ] ) ) { |
|
1510 |
$wp_meta_boxes[ $page ] = array(); |
|
1511 |
} |
|
1512 |
if ( ! isset( $wp_meta_boxes[ $page ][ $context ] ) ) { |
|
1513 |
$wp_meta_boxes[ $page ][ $context ] = array(); |
|
1514 |
} |
|
0 | 1515 |
|
9 | 1516 |
foreach ( array( 'high', 'core', 'default', 'low' ) as $priority ) { |
1517 |
$wp_meta_boxes[ $page ][ $context ][ $priority ][ $id ] = false; |
|
1518 |
} |
|
0 | 1519 |
} |
1520 |
||
1521 |
/** |
|
9 | 1522 |
* Meta Box Accordion Template Function. |
0 | 1523 |
* |
7
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
1524 |
* Largely made up of abstracted code from do_meta_boxes(), this |
0 | 1525 |
* function serves to build meta boxes as list items for display as |
1526 |
* a collapsible accordion. |
|
1527 |
* |
|
1528 |
* @since 3.6.0 |
|
1529 |
* |
|
1530 |
* @uses global $wp_meta_boxes Used to retrieve registered meta boxes. |
|
1531 |
* |
|
19 | 1532 |
* @param string|object $screen The screen identifier. |
1533 |
* @param string $context The screen context for which to display accordion sections. |
|
1534 |
* @param mixed $data_object Gets passed to the section callback function as the first parameter. |
|
16 | 1535 |
* @return int Number of meta boxes as accordion sections. |
0 | 1536 |
*/ |
19 | 1537 |
function do_accordion_sections( $screen, $context, $data_object ) { |
0 | 1538 |
global $wp_meta_boxes; |
1539 |
||
1540 |
wp_enqueue_script( 'accordion' ); |
|
1541 |
||
9 | 1542 |
if ( empty( $screen ) ) { |
0 | 1543 |
$screen = get_current_screen(); |
9 | 1544 |
} elseif ( is_string( $screen ) ) { |
0 | 1545 |
$screen = convert_to_screen( $screen ); |
9 | 1546 |
} |
0 | 1547 |
|
1548 |
$page = $screen->id; |
|
1549 |
||
1550 |
$hidden = get_hidden_meta_boxes( $screen ); |
|
1551 |
?> |
|
1552 |
<div id="side-sortables" class="accordion-container"> |
|
1553 |
<ul class="outer-border"> |
|
1554 |
<?php |
|
9 | 1555 |
$i = 0; |
0 | 1556 |
$first_open = false; |
1557 |
||
5 | 1558 |
if ( isset( $wp_meta_boxes[ $page ][ $context ] ) ) { |
0 | 1559 |
foreach ( array( 'high', 'core', 'default', 'low' ) as $priority ) { |
5 | 1560 |
if ( isset( $wp_meta_boxes[ $page ][ $context ][ $priority ] ) ) { |
1561 |
foreach ( $wp_meta_boxes[ $page ][ $context ][ $priority ] as $box ) { |
|
16 | 1562 |
if ( false === $box || ! $box['title'] ) { |
0 | 1563 |
continue; |
9 | 1564 |
} |
16 | 1565 |
|
21
48c4eec2b7e6
Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents:
19
diff
changeset
|
1566 |
++$i; |
16 | 1567 |
$hidden_class = in_array( $box['id'], $hidden, true ) ? 'hide-if-js' : ''; |
0 | 1568 |
|
22
8c2e4d02f4ef
Update WordPress to latest version (6.7)
ymh <ymh.work@gmail.com>
parents:
21
diff
changeset
|
1569 |
$open_class = ''; |
8c2e4d02f4ef
Update WordPress to latest version (6.7)
ymh <ymh.work@gmail.com>
parents:
21
diff
changeset
|
1570 |
$aria_expanded = 'false'; |
0 | 1571 |
if ( ! $first_open && empty( $hidden_class ) ) { |
22
8c2e4d02f4ef
Update WordPress to latest version (6.7)
ymh <ymh.work@gmail.com>
parents:
21
diff
changeset
|
1572 |
$first_open = true; |
8c2e4d02f4ef
Update WordPress to latest version (6.7)
ymh <ymh.work@gmail.com>
parents:
21
diff
changeset
|
1573 |
$open_class = 'open'; |
8c2e4d02f4ef
Update WordPress to latest version (6.7)
ymh <ymh.work@gmail.com>
parents:
21
diff
changeset
|
1574 |
$aria_expanded = 'true'; |
0 | 1575 |
} |
1576 |
?> |
|
1577 |
<li class="control-section accordion-section <?php echo $hidden_class; ?> <?php echo $open_class; ?> <?php echo esc_attr( $box['id'] ); ?>" id="<?php echo esc_attr( $box['id'] ); ?>"> |
|
22
8c2e4d02f4ef
Update WordPress to latest version (6.7)
ymh <ymh.work@gmail.com>
parents:
21
diff
changeset
|
1578 |
<h3 class="accordion-section-title hndle"> |
8c2e4d02f4ef
Update WordPress to latest version (6.7)
ymh <ymh.work@gmail.com>
parents:
21
diff
changeset
|
1579 |
<button type="button" class="accordion-trigger" aria-expanded="<?php echo $aria_expanded; ?>" aria-controls="<?php echo esc_attr( $box['id'] ); ?>-content"> |
8c2e4d02f4ef
Update WordPress to latest version (6.7)
ymh <ymh.work@gmail.com>
parents:
21
diff
changeset
|
1580 |
<span class="accordion-title"> |
8c2e4d02f4ef
Update WordPress to latest version (6.7)
ymh <ymh.work@gmail.com>
parents:
21
diff
changeset
|
1581 |
<?php echo esc_html( $box['title'] ); ?> |
8c2e4d02f4ef
Update WordPress to latest version (6.7)
ymh <ymh.work@gmail.com>
parents:
21
diff
changeset
|
1582 |
<span class="dashicons dashicons-arrow-down" aria-hidden="true"></span> |
8c2e4d02f4ef
Update WordPress to latest version (6.7)
ymh <ymh.work@gmail.com>
parents:
21
diff
changeset
|
1583 |
</span> |
8c2e4d02f4ef
Update WordPress to latest version (6.7)
ymh <ymh.work@gmail.com>
parents:
21
diff
changeset
|
1584 |
</button> |
5 | 1585 |
</h3> |
22
8c2e4d02f4ef
Update WordPress to latest version (6.7)
ymh <ymh.work@gmail.com>
parents:
21
diff
changeset
|
1586 |
<div class="accordion-section-content <?php postbox_classes( $box['id'], $page ); ?>" id="<?php echo esc_attr( $box['id'] ); ?>-content"> |
0 | 1587 |
<div class="inside"> |
19 | 1588 |
<?php call_user_func( $box['callback'], $data_object, $box ); ?> |
0 | 1589 |
</div><!-- .inside --> |
1590 |
</div><!-- .accordion-section-content --> |
|
1591 |
</li><!-- .accordion-section --> |
|
1592 |
<?php |
|
1593 |
} |
|
1594 |
} |
|
1595 |
} |
|
5 | 1596 |
} |
0 | 1597 |
?> |
1598 |
</ul><!-- .outer-border --> |
|
1599 |
</div><!-- .accordion-container --> |
|
1600 |
<?php |
|
1601 |
return $i; |
|
1602 |
} |
|
1603 |
||
1604 |
/** |
|
19 | 1605 |
* Adds a new section to a settings page. |
0 | 1606 |
* |
1607 |
* Part of the Settings API. Use this to define new settings sections for an admin page. |
|
1608 |
* Show settings sections in your admin page callback function with do_settings_sections(). |
|
9 | 1609 |
* Add settings fields to your section with add_settings_field(). |
0 | 1610 |
* |
1611 |
* The $callback argument should be the name of a function that echoes out any |
|
1612 |
* content you want to show at the top of the settings section before the actual |
|
1613 |
* fields. It can output nothing if you want. |
|
1614 |
* |
|
1615 |
* @since 2.7.0 |
|
21
48c4eec2b7e6
Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents:
19
diff
changeset
|
1616 |
* @since 6.1.0 Added an `$args` parameter for the section's HTML wrapper and class name. |
0 | 1617 |
* |
16 | 1618 |
* @global array $wp_settings_sections Storage array of all settings sections added to admin pages. |
0 | 1619 |
* |
7
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
1620 |
* @param string $id Slug-name to identify the section. Used in the 'id' attribute of tags. |
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
1621 |
* @param string $title Formatted title of the section. Shown as the heading for the section. |
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
1622 |
* @param callable $callback Function that echos out any content at the top of the section (between heading and fields). |
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
1623 |
* @param string $page The slug-name of the settings page on which to show the section. Built-in pages include |
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
1624 |
* 'general', 'reading', 'writing', 'discussion', 'media', etc. Create your own using |
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
1625 |
* add_options_page(); |
21
48c4eec2b7e6
Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents:
19
diff
changeset
|
1626 |
* @param array $args { |
48c4eec2b7e6
Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents:
19
diff
changeset
|
1627 |
* Arguments used to create the settings section. |
48c4eec2b7e6
Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents:
19
diff
changeset
|
1628 |
* |
48c4eec2b7e6
Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents:
19
diff
changeset
|
1629 |
* @type string $before_section HTML content to prepend to the section's HTML output. |
48c4eec2b7e6
Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents:
19
diff
changeset
|
1630 |
* Receives the section's class name as `%s`. Default empty. |
48c4eec2b7e6
Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents:
19
diff
changeset
|
1631 |
* @type string $after_section HTML content to append to the section's HTML output. Default empty. |
48c4eec2b7e6
Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents:
19
diff
changeset
|
1632 |
* @type string $section_class The class name to use for the section. Default empty. |
48c4eec2b7e6
Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents:
19
diff
changeset
|
1633 |
* } |
0 | 1634 |
*/ |
21
48c4eec2b7e6
Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents:
19
diff
changeset
|
1635 |
function add_settings_section( $id, $title, $callback, $page, $args = array() ) { |
0 | 1636 |
global $wp_settings_sections; |
1637 |
||
21
48c4eec2b7e6
Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents:
19
diff
changeset
|
1638 |
$defaults = array( |
48c4eec2b7e6
Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents:
19
diff
changeset
|
1639 |
'id' => $id, |
48c4eec2b7e6
Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents:
19
diff
changeset
|
1640 |
'title' => $title, |
48c4eec2b7e6
Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents:
19
diff
changeset
|
1641 |
'callback' => $callback, |
48c4eec2b7e6
Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents:
19
diff
changeset
|
1642 |
'before_section' => '', |
48c4eec2b7e6
Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents:
19
diff
changeset
|
1643 |
'after_section' => '', |
48c4eec2b7e6
Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents:
19
diff
changeset
|
1644 |
'section_class' => '', |
48c4eec2b7e6
Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents:
19
diff
changeset
|
1645 |
); |
48c4eec2b7e6
Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents:
19
diff
changeset
|
1646 |
|
48c4eec2b7e6
Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents:
19
diff
changeset
|
1647 |
$section = wp_parse_args( $args, $defaults ); |
48c4eec2b7e6
Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents:
19
diff
changeset
|
1648 |
|
16 | 1649 |
if ( 'misc' === $page ) { |
9 | 1650 |
_deprecated_argument( |
1651 |
__FUNCTION__, |
|
1652 |
'3.0.0', |
|
1653 |
sprintf( |
|
16 | 1654 |
/* translators: %s: misc */ |
9 | 1655 |
__( 'The "%s" options group has been removed. Use another settings group.' ), |
7
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
1656 |
'misc' |
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
1657 |
) |
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
1658 |
); |
0 | 1659 |
$page = 'general'; |
1660 |
} |
|
1661 |
||
16 | 1662 |
if ( 'privacy' === $page ) { |
9 | 1663 |
_deprecated_argument( |
1664 |
__FUNCTION__, |
|
1665 |
'3.5.0', |
|
1666 |
sprintf( |
|
16 | 1667 |
/* translators: %s: privacy */ |
9 | 1668 |
__( 'The "%s" options group has been removed. Use another settings group.' ), |
7
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
1669 |
'privacy' |
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
1670 |
) |
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
1671 |
); |
0 | 1672 |
$page = 'reading'; |
1673 |
} |
|
1674 |
||
21
48c4eec2b7e6
Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents:
19
diff
changeset
|
1675 |
$wp_settings_sections[ $page ][ $id ] = $section; |
0 | 1676 |
} |
1677 |
||
1678 |
/** |
|
19 | 1679 |
* Adds a new field to a section of a settings page. |
0 | 1680 |
* |
1681 |
* Part of the Settings API. Use this to define a settings field that will show |
|
1682 |
* as part of a settings section inside a settings page. The fields are shown using |
|
18 | 1683 |
* do_settings_fields() in do_settings_sections(). |
0 | 1684 |
* |
1685 |
* The $callback argument should be the name of a function that echoes out the |
|
16 | 1686 |
* HTML input tags for this setting field. Use get_option() to retrieve existing |
0 | 1687 |
* values to show. |
1688 |
* |
|
1689 |
* @since 2.7.0 |
|
5 | 1690 |
* @since 4.2.0 The `$class` argument was added. |
0 | 1691 |
* |
16 | 1692 |
* @global array $wp_settings_fields Storage array of settings fields and info about their pages/sections. |
0 | 1693 |
* |
7
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
1694 |
* @param string $id Slug-name to identify the field. Used in the 'id' attribute of tags. |
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
1695 |
* @param string $title Formatted title of the field. Shown as the label for the field |
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
1696 |
* during output. |
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
1697 |
* @param callable $callback Function that fills the field with the desired form inputs. The |
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
1698 |
* function should echo its output. |
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
1699 |
* @param string $page The slug-name of the settings page on which to show the section |
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
1700 |
* (general, reading, writing, ...). |
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
1701 |
* @param string $section Optional. The slug-name of the section of the settings page |
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
1702 |
* in which to show the box. Default 'default'. |
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
1703 |
* @param array $args { |
21
48c4eec2b7e6
Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents:
19
diff
changeset
|
1704 |
* Optional. Extra arguments that get passed to the callback function. |
5 | 1705 |
* |
1706 |
* @type string $label_for When supplied, the setting title will be wrapped |
|
1707 |
* in a `<label>` element, its `for` attribute populated |
|
1708 |
* with this value. |
|
1709 |
* @type string $class CSS Class to be added to the `<tr>` element when the |
|
1710 |
* field is output. |
|
1711 |
* } |
|
0 | 1712 |
*/ |
9 | 1713 |
function add_settings_field( $id, $title, $callback, $page, $section = 'default', $args = array() ) { |
0 | 1714 |
global $wp_settings_fields; |
1715 |
||
16 | 1716 |
if ( 'misc' === $page ) { |
9 | 1717 |
_deprecated_argument( |
1718 |
__FUNCTION__, |
|
1719 |
'3.0.0', |
|
1720 |
sprintf( |
|
16 | 1721 |
/* translators: %s: misc */ |
9 | 1722 |
__( 'The "%s" options group has been removed. Use another settings group.' ), |
7
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
1723 |
'misc' |
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
1724 |
) |
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
1725 |
); |
0 | 1726 |
$page = 'general'; |
1727 |
} |
|
1728 |
||
16 | 1729 |
if ( 'privacy' === $page ) { |
9 | 1730 |
_deprecated_argument( |
1731 |
__FUNCTION__, |
|
1732 |
'3.5.0', |
|
1733 |
sprintf( |
|
16 | 1734 |
/* translators: %s: privacy */ |
9 | 1735 |
__( 'The "%s" options group has been removed. Use another settings group.' ), |
7
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
1736 |
'privacy' |
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
1737 |
) |
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
1738 |
); |
0 | 1739 |
$page = 'reading'; |
1740 |
} |
|
1741 |
||
9 | 1742 |
$wp_settings_fields[ $page ][ $section ][ $id ] = array( |
1743 |
'id' => $id, |
|
1744 |
'title' => $title, |
|
1745 |
'callback' => $callback, |
|
1746 |
'args' => $args, |
|
1747 |
); |
|
0 | 1748 |
} |
1749 |
||
1750 |
/** |
|
21
48c4eec2b7e6
Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents:
19
diff
changeset
|
1751 |
* Prints out all settings sections added to a particular settings page. |
0 | 1752 |
* |
1753 |
* Part of the Settings API. Use this in a settings page callback function |
|
1754 |
* to output all the sections and fields that were added to that $page with |
|
1755 |
* add_settings_section() and add_settings_field() |
|
1756 |
* |
|
16 | 1757 |
* @global array $wp_settings_sections Storage array of all settings sections added to admin pages. |
1758 |
* @global array $wp_settings_fields Storage array of settings fields and info about their pages/sections. |
|
0 | 1759 |
* @since 2.7.0 |
1760 |
* |
|
9 | 1761 |
* @param string $page The slug name of the page whose settings sections you want to output. |
0 | 1762 |
*/ |
1763 |
function do_settings_sections( $page ) { |
|
1764 |
global $wp_settings_sections, $wp_settings_fields; |
|
1765 |
||
9 | 1766 |
if ( ! isset( $wp_settings_sections[ $page ] ) ) { |
0 | 1767 |
return; |
9 | 1768 |
} |
0 | 1769 |
|
9 | 1770 |
foreach ( (array) $wp_settings_sections[ $page ] as $section ) { |
21
48c4eec2b7e6
Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents:
19
diff
changeset
|
1771 |
if ( '' !== $section['before_section'] ) { |
48c4eec2b7e6
Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents:
19
diff
changeset
|
1772 |
if ( '' !== $section['section_class'] ) { |
48c4eec2b7e6
Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents:
19
diff
changeset
|
1773 |
echo wp_kses_post( sprintf( $section['before_section'], esc_attr( $section['section_class'] ) ) ); |
48c4eec2b7e6
Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents:
19
diff
changeset
|
1774 |
} else { |
48c4eec2b7e6
Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents:
19
diff
changeset
|
1775 |
echo wp_kses_post( $section['before_section'] ); |
48c4eec2b7e6
Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents:
19
diff
changeset
|
1776 |
} |
48c4eec2b7e6
Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents:
19
diff
changeset
|
1777 |
} |
48c4eec2b7e6
Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents:
19
diff
changeset
|
1778 |
|
9 | 1779 |
if ( $section['title'] ) { |
7
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
1780 |
echo "<h2>{$section['title']}</h2>\n"; |
9 | 1781 |
} |
0 | 1782 |
|
9 | 1783 |
if ( $section['callback'] ) { |
0 | 1784 |
call_user_func( $section['callback'], $section ); |
9 | 1785 |
} |
0 | 1786 |
|
22
8c2e4d02f4ef
Update WordPress to latest version (6.7)
ymh <ymh.work@gmail.com>
parents:
21
diff
changeset
|
1787 |
if ( isset( $wp_settings_fields[ $page ][ $section['id'] ] ) ) { |
8c2e4d02f4ef
Update WordPress to latest version (6.7)
ymh <ymh.work@gmail.com>
parents:
21
diff
changeset
|
1788 |
echo '<table class="form-table" role="presentation">'; |
8c2e4d02f4ef
Update WordPress to latest version (6.7)
ymh <ymh.work@gmail.com>
parents:
21
diff
changeset
|
1789 |
do_settings_fields( $page, $section['id'] ); |
8c2e4d02f4ef
Update WordPress to latest version (6.7)
ymh <ymh.work@gmail.com>
parents:
21
diff
changeset
|
1790 |
echo '</table>'; |
9 | 1791 |
} |
21
48c4eec2b7e6
Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents:
19
diff
changeset
|
1792 |
|
48c4eec2b7e6
Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents:
19
diff
changeset
|
1793 |
if ( '' !== $section['after_section'] ) { |
48c4eec2b7e6
Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents:
19
diff
changeset
|
1794 |
echo wp_kses_post( $section['after_section'] ); |
48c4eec2b7e6
Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents:
19
diff
changeset
|
1795 |
} |
0 | 1796 |
} |
1797 |
} |
|
1798 |
||
1799 |
/** |
|
19 | 1800 |
* Prints out the settings fields for a particular settings section. |
0 | 1801 |
* |
1802 |
* Part of the Settings API. Use this in a settings page to output |
|
1803 |
* a specific section. Should normally be called by do_settings_sections() |
|
1804 |
* rather than directly. |
|
1805 |
* |
|
16 | 1806 |
* @global array $wp_settings_fields Storage array of settings fields and their pages/sections. |
0 | 1807 |
* |
1808 |
* @since 2.7.0 |
|
1809 |
* |
|
9 | 1810 |
* @param string $page Slug title of the admin page whose settings fields you want to show. |
1811 |
* @param string $section Slug title of the settings section whose fields you want to show. |
|
0 | 1812 |
*/ |
9 | 1813 |
function do_settings_fields( $page, $section ) { |
0 | 1814 |
global $wp_settings_fields; |
1815 |
||
9 | 1816 |
if ( ! isset( $wp_settings_fields[ $page ][ $section ] ) ) { |
0 | 1817 |
return; |
9 | 1818 |
} |
0 | 1819 |
|
9 | 1820 |
foreach ( (array) $wp_settings_fields[ $page ][ $section ] as $field ) { |
5 | 1821 |
$class = ''; |
1822 |
||
1823 |
if ( ! empty( $field['args']['class'] ) ) { |
|
1824 |
$class = ' class="' . esc_attr( $field['args']['class'] ) . '"'; |
|
1825 |
} |
|
1826 |
||
1827 |
echo "<tr{$class}>"; |
|
1828 |
||
1829 |
if ( ! empty( $field['args']['label_for'] ) ) { |
|
0 | 1830 |
echo '<th scope="row"><label for="' . esc_attr( $field['args']['label_for'] ) . '">' . $field['title'] . '</label></th>'; |
5 | 1831 |
} else { |
0 | 1832 |
echo '<th scope="row">' . $field['title'] . '</th>'; |
5 | 1833 |
} |
1834 |
||
0 | 1835 |
echo '<td>'; |
9 | 1836 |
call_user_func( $field['callback'], $field['args'] ); |
0 | 1837 |
echo '</td>'; |
1838 |
echo '</tr>'; |
|
1839 |
} |
|
1840 |
} |
|
1841 |
||
1842 |
/** |
|
19 | 1843 |
* Registers a settings error to be displayed to the user. |
0 | 1844 |
* |
1845 |
* Part of the Settings API. Use this to show messages to users about settings validation |
|
1846 |
* problems, missing settings or anything else. |
|
1847 |
* |
|
1848 |
* Settings errors should be added inside the $sanitize_callback function defined in |
|
1849 |
* register_setting() for a given setting to give feedback about the submission. |
|
1850 |
* |
|
1851 |
* By default messages will show immediately after the submission that generated the error. |
|
1852 |
* Additional calls to settings_errors() can be used to show errors even when the settings |
|
1853 |
* page is first accessed. |
|
1854 |
* |
|
1855 |
* @since 3.0.0 |
|
16 | 1856 |
* @since 5.3.0 Added `warning` and `info` as possible values for `$type`. |
0 | 1857 |
* |
21
48c4eec2b7e6
Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents:
19
diff
changeset
|
1858 |
* @global array[] $wp_settings_errors Storage array of errors registered during this pageload |
0 | 1859 |
* |
9 | 1860 |
* @param string $setting Slug title of the setting to which this error applies. |
5 | 1861 |
* @param string $code Slug-name to identify the error. Used as part of 'id' attribute in HTML output. |
1862 |
* @param string $message The formatted message text to display to the user (will be shown inside styled |
|
1863 |
* `<div>` and `<p>` tags). |
|
16 | 1864 |
* @param string $type Optional. Message type, controls HTML class. Possible values include 'error', |
1865 |
* 'success', 'warning', 'info'. Default 'error'. |
|
0 | 1866 |
*/ |
1867 |
function add_settings_error( $setting, $code, $message, $type = 'error' ) { |
|
1868 |
global $wp_settings_errors; |
|
1869 |
||
5 | 1870 |
$wp_settings_errors[] = array( |
0 | 1871 |
'setting' => $setting, |
5 | 1872 |
'code' => $code, |
0 | 1873 |
'message' => $message, |
9 | 1874 |
'type' => $type, |
0 | 1875 |
); |
1876 |
} |
|
1877 |
||
1878 |
/** |
|
19 | 1879 |
* Fetches settings errors registered by add_settings_error(). |
0 | 1880 |
* |
1881 |
* Checks the $wp_settings_errors array for any errors declared during the current |
|
1882 |
* pageload and returns them. |
|
1883 |
* |
|
1884 |
* If changes were just submitted ($_GET['settings-updated']) and settings errors were saved |
|
1885 |
* to the 'settings_errors' transient then those errors will be returned instead. This |
|
1886 |
* is used to pass errors back across pageloads. |
|
1887 |
* |
|
1888 |
* Use the $sanitize argument to manually re-sanitize the option before returning errors. |
|
1889 |
* This is useful if you have errors or notices you want to show even when the user |
|
7
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
1890 |
* hasn't submitted data (i.e. when they first load an options page, or in the {@see 'admin_notices'} |
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
1891 |
* action hook). |
0 | 1892 |
* |
1893 |
* @since 3.0.0 |
|
1894 |
* |
|
21
48c4eec2b7e6
Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents:
19
diff
changeset
|
1895 |
* @global array[] $wp_settings_errors Storage array of errors registered during this pageload |
0 | 1896 |
* |
16 | 1897 |
* @param string $setting Optional. Slug title of a specific setting whose errors you want. |
1898 |
* @param bool $sanitize Optional. Whether to re-sanitize the setting value before returning errors. |
|
21
48c4eec2b7e6
Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents:
19
diff
changeset
|
1899 |
* @return array[] { |
48c4eec2b7e6
Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents:
19
diff
changeset
|
1900 |
* Array of settings error arrays. |
48c4eec2b7e6
Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents:
19
diff
changeset
|
1901 |
* |
48c4eec2b7e6
Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents:
19
diff
changeset
|
1902 |
* @type array ...$0 { |
48c4eec2b7e6
Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents:
19
diff
changeset
|
1903 |
* Associative array of setting error data. |
18 | 1904 |
* |
21
48c4eec2b7e6
Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents:
19
diff
changeset
|
1905 |
* @type string $setting Slug title of the setting to which this error applies. |
48c4eec2b7e6
Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents:
19
diff
changeset
|
1906 |
* @type string $code Slug-name to identify the error. Used as part of 'id' attribute in HTML output. |
48c4eec2b7e6
Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents:
19
diff
changeset
|
1907 |
* @type string $message The formatted message text to display to the user (will be shown inside styled |
48c4eec2b7e6
Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents:
19
diff
changeset
|
1908 |
* `<div>` and `<p>` tags). |
48c4eec2b7e6
Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents:
19
diff
changeset
|
1909 |
* @type string $type Optional. Message type, controls HTML class. Possible values include 'error', |
48c4eec2b7e6
Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents:
19
diff
changeset
|
1910 |
* 'success', 'warning', 'info'. Default 'error'. |
48c4eec2b7e6
Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents:
19
diff
changeset
|
1911 |
* } |
18 | 1912 |
* } |
0 | 1913 |
*/ |
1914 |
function get_settings_errors( $setting = '', $sanitize = false ) { |
|
1915 |
global $wp_settings_errors; |
|
1916 |
||
5 | 1917 |
/* |
1918 |
* If $sanitize is true, manually re-run the sanitization for this option |
|
1919 |
* This allows the $sanitize_callback from register_setting() to run, adding |
|
1920 |
* any settings errors you want to show by default. |
|
1921 |
*/ |
|
9 | 1922 |
if ( $sanitize ) { |
0 | 1923 |
sanitize_option( $setting, get_option( $setting ) ); |
9 | 1924 |
} |
0 | 1925 |
|
5 | 1926 |
// If settings were passed back from options.php then use them. |
0 | 1927 |
if ( isset( $_GET['settings-updated'] ) && $_GET['settings-updated'] && get_transient( 'settings_errors' ) ) { |
1928 |
$wp_settings_errors = array_merge( (array) $wp_settings_errors, get_transient( 'settings_errors' ) ); |
|
1929 |
delete_transient( 'settings_errors' ); |
|
1930 |
} |
|
1931 |
||
5 | 1932 |
// Check global in case errors have been added on this pageload. |
7
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
1933 |
if ( empty( $wp_settings_errors ) ) { |
0 | 1934 |
return array(); |
7
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
1935 |
} |
0 | 1936 |
|
5 | 1937 |
// Filter the results to those of a specific setting if one was set. |
0 | 1938 |
if ( $setting ) { |
1939 |
$setting_errors = array(); |
|
16 | 1940 |
|
0 | 1941 |
foreach ( (array) $wp_settings_errors as $key => $details ) { |
16 | 1942 |
if ( $setting === $details['setting'] ) { |
9 | 1943 |
$setting_errors[] = $wp_settings_errors[ $key ]; |
1944 |
} |
|
0 | 1945 |
} |
16 | 1946 |
|
0 | 1947 |
return $setting_errors; |
1948 |
} |
|
1949 |
||
1950 |
return $wp_settings_errors; |
|
1951 |
} |
|
1952 |
||
1953 |
/** |
|
19 | 1954 |
* Displays settings errors registered by add_settings_error(). |
0 | 1955 |
* |
5 | 1956 |
* Part of the Settings API. Outputs a div for each error retrieved by |
7
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
1957 |
* get_settings_errors(). |
0 | 1958 |
* |
5 | 1959 |
* This is called automatically after a settings page based on the |
1960 |
* Settings API is submitted. Errors should be added during the validation |
|
7
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
1961 |
* callback function for a setting defined in register_setting(). |
0 | 1962 |
* |
7
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
1963 |
* The $sanitize option is passed into get_settings_errors() and will |
5 | 1964 |
* re-run the setting sanitization |
0 | 1965 |
* on its current value. |
1966 |
* |
|
5 | 1967 |
* The $hide_on_update option will cause errors to only show when the settings |
1968 |
* page is first loaded. if the user has already saved new values it will be |
|
1969 |
* hidden to avoid repeating messages already shown in the default error |
|
1970 |
* reporting after submission. This is useful to show general errors like |
|
1971 |
* missing settings when the user arrives at the settings page. |
|
0 | 1972 |
* |
1973 |
* @since 3.0.0 |
|
16 | 1974 |
* @since 5.3.0 Legacy `error` and `updated` CSS classes are mapped to |
1975 |
* `notice-error` and `notice-success`. |
|
0 | 1976 |
* |
9 | 1977 |
* @param string $setting Optional slug title of a specific setting whose errors you want. |
7
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
1978 |
* @param bool $sanitize Whether to re-sanitize the setting value before returning errors. |
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
1979 |
* @param bool $hide_on_update If set to true errors will not be shown if the settings page has |
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
1980 |
* already been submitted. |
0 | 1981 |
*/ |
1982 |
function settings_errors( $setting = '', $sanitize = false, $hide_on_update = false ) { |
|
1983 |
||
9 | 1984 |
if ( $hide_on_update && ! empty( $_GET['settings-updated'] ) ) { |
0 | 1985 |
return; |
9 | 1986 |
} |
0 | 1987 |
|
1988 |
$settings_errors = get_settings_errors( $setting, $sanitize ); |
|
1989 |
||
9 | 1990 |
if ( empty( $settings_errors ) ) { |
0 | 1991 |
return; |
9 | 1992 |
} |
0 | 1993 |
|
1994 |
$output = ''; |
|
16 | 1995 |
|
0 | 1996 |
foreach ( $settings_errors as $key => $details ) { |
16 | 1997 |
if ( 'updated' === $details['type'] ) { |
1998 |
$details['type'] = 'success'; |
|
1999 |
} |
|
2000 |
||
2001 |
if ( in_array( $details['type'], array( 'error', 'success', 'warning', 'info' ), true ) ) { |
|
2002 |
$details['type'] = 'notice-' . $details['type']; |
|
2003 |
} |
|
2004 |
||
2005 |
$css_id = sprintf( |
|
2006 |
'setting-error-%s', |
|
2007 |
esc_attr( $details['code'] ) |
|
2008 |
); |
|
2009 |
$css_class = sprintf( |
|
2010 |
'notice %s settings-error is-dismissible', |
|
2011 |
esc_attr( $details['type'] ) |
|
2012 |
); |
|
2013 |
||
2014 |
$output .= "<div id='$css_id' class='$css_class'> \n"; |
|
2015 |
$output .= "<p><strong>{$details['message']}</strong></p>"; |
|
2016 |
$output .= "</div> \n"; |
|
0 | 2017 |
} |
16 | 2018 |
|
0 | 2019 |
echo $output; |
2020 |
} |
|
2021 |
||
2022 |
/** |
|
7
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
2023 |
* Outputs the modal window used for attaching media to posts or pages in the media-listing screen. |
0 | 2024 |
* |
2025 |
* @since 2.7.0 |
|
2026 |
* |
|
21
48c4eec2b7e6
Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents:
19
diff
changeset
|
2027 |
* @param string $found_action Optional. The value of the 'found_action' input field. Default empty string. |
0 | 2028 |
*/ |
9 | 2029 |
function find_posts_div( $found_action = '' ) { |
2030 |
?> |
|
5 | 2031 |
<div id="find-posts" class="find-box" style="display: none;"> |
2032 |
<div id="find-posts-head" class="find-box-head"> |
|
7
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
2033 |
<?php _e( 'Attach to existing content' ); ?> |
21
48c4eec2b7e6
Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents:
19
diff
changeset
|
2034 |
<button type="button" id="find-posts-close"><span class="screen-reader-text"> |
48c4eec2b7e6
Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents:
19
diff
changeset
|
2035 |
<?php |
48c4eec2b7e6
Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents:
19
diff
changeset
|
2036 |
/* translators: Hidden accessibility text. */ |
48c4eec2b7e6
Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents:
19
diff
changeset
|
2037 |
_e( 'Close media attachment panel' ); |
48c4eec2b7e6
Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents:
19
diff
changeset
|
2038 |
?> |
48c4eec2b7e6
Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents:
19
diff
changeset
|
2039 |
</span></button> |
5 | 2040 |
</div> |
0 | 2041 |
<div class="find-box-inside"> |
2042 |
<div class="find-box-search"> |
|
2043 |
<?php if ( $found_action ) { ?> |
|
9 | 2044 |
<input type="hidden" name="found_action" value="<?php echo esc_attr( $found_action ); ?>" /> |
0 | 2045 |
<?php } ?> |
2046 |
<input type="hidden" name="affected" id="affected" value="" /> |
|
2047 |
<?php wp_nonce_field( 'find-posts', '_ajax_nonce', false ); ?> |
|
21
48c4eec2b7e6
Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents:
19
diff
changeset
|
2048 |
<label class="screen-reader-text" for="find-posts-input"> |
48c4eec2b7e6
Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents:
19
diff
changeset
|
2049 |
<?php |
48c4eec2b7e6
Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents:
19
diff
changeset
|
2050 |
/* translators: Hidden accessibility text. */ |
48c4eec2b7e6
Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents:
19
diff
changeset
|
2051 |
_e( 'Search' ); |
48c4eec2b7e6
Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents:
19
diff
changeset
|
2052 |
?> |
48c4eec2b7e6
Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents:
19
diff
changeset
|
2053 |
</label> |
0 | 2054 |
<input type="text" id="find-posts-input" name="ps" value="" /> |
2055 |
<span class="spinner"></span> |
|
2056 |
<input type="button" id="find-posts-search" value="<?php esc_attr_e( 'Search' ); ?>" class="button" /> |
|
5 | 2057 |
<div class="clear"></div> |
0 | 2058 |
</div> |
2059 |
<div id="find-posts-response"></div> |
|
2060 |
</div> |
|
2061 |
<div class="find-box-buttons"> |
|
7
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
2062 |
<?php submit_button( __( 'Select' ), 'primary alignright', 'find-posts-submit', false ); ?> |
5 | 2063 |
<div class="clear"></div> |
0 | 2064 |
</div> |
2065 |
</div> |
|
9 | 2066 |
<?php |
0 | 2067 |
} |
2068 |
||
2069 |
/** |
|
7
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
2070 |
* Displays the post password. |
0 | 2071 |
* |
16 | 2072 |
* The password is passed through esc_attr() to ensure that it is safe for placing in an HTML attribute. |
0 | 2073 |
* |
2074 |
* @since 2.7.0 |
|
2075 |
*/ |
|
2076 |
function the_post_password() { |
|
2077 |
$post = get_post(); |
|
9 | 2078 |
if ( isset( $post->post_password ) ) { |
0 | 2079 |
echo esc_attr( $post->post_password ); |
9 | 2080 |
} |
0 | 2081 |
} |
2082 |
||
2083 |
/** |
|
19 | 2084 |
* Gets the post title. |
0 | 2085 |
* |
2086 |
* The post title is fetched and if it is blank then a default string is |
|
2087 |
* returned. |
|
2088 |
* |
|
2089 |
* @since 2.7.0 |
|
5 | 2090 |
* |
2091 |
* @param int|WP_Post $post Optional. Post ID or WP_Post object. Default is global $post. |
|
2092 |
* @return string The post title if set. |
|
0 | 2093 |
*/ |
2094 |
function _draft_or_post_title( $post = 0 ) { |
|
2095 |
$title = get_the_title( $post ); |
|
9 | 2096 |
if ( empty( $title ) ) { |
0 | 2097 |
$title = __( '(no title)' ); |
9 | 2098 |
} |
5 | 2099 |
return esc_html( $title ); |
0 | 2100 |
} |
2101 |
||
2102 |
/** |
|
7
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
2103 |
* Displays the search query. |
0 | 2104 |
* |
7
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
2105 |
* A simple wrapper to display the "s" parameter in a `GET` URI. This function |
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
2106 |
* should only be used when the_search_query() cannot. |
0 | 2107 |
* |
2108 |
* @since 2.7.0 |
|
2109 |
*/ |
|
2110 |
function _admin_search_query() { |
|
9 | 2111 |
echo isset( $_REQUEST['s'] ) ? esc_attr( wp_unslash( $_REQUEST['s'] ) ) : ''; |
0 | 2112 |
} |
2113 |
||
2114 |
/** |
|
19 | 2115 |
* Generic Iframe header for use with Thickbox. |
0 | 2116 |
* |
2117 |
* @since 2.7.0 |
|
2118 |
* |
|
7
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
2119 |
* @global string $hook_suffix |
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
2120 |
* @global string $admin_body_class |
21
48c4eec2b7e6
Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents:
19
diff
changeset
|
2121 |
* @global string $body_id |
16 | 2122 |
* @global WP_Locale $wp_locale WordPress date and time locale object. |
7
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
2123 |
* |
5 | 2124 |
* @param string $title Optional. Title of the Iframe page. Default empty. |
2125 |
* @param bool $deprecated Not used. |
|
0 | 2126 |
*/ |
5 | 2127 |
function iframe_header( $title = '', $deprecated = false ) { |
21
48c4eec2b7e6
Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents:
19
diff
changeset
|
2128 |
global $hook_suffix, $admin_body_class, $body_id, $wp_locale; |
48c4eec2b7e6
Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents:
19
diff
changeset
|
2129 |
|
0 | 2130 |
show_admin_bar( false ); |
21
48c4eec2b7e6
Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents:
19
diff
changeset
|
2131 |
|
9 | 2132 |
$admin_body_class = preg_replace( '/[^a-z0-9_-]+/i', '-', $hook_suffix ); |
0 | 2133 |
|
2134 |
$current_screen = get_current_screen(); |
|
2135 |
||
16 | 2136 |
header( 'Content-Type: ' . get_option( 'html_type' ) . '; charset=' . get_option( 'blog_charset' ) ); |
0 | 2137 |
_wp_admin_html_begin(); |
9 | 2138 |
?> |
2139 |
<title><?php bloginfo( 'name' ); ?> › <?php echo $title; ?> — <?php _e( 'WordPress' ); ?></title> |
|
2140 |
<?php |
|
2141 |
wp_enqueue_style( 'colors' ); |
|
2142 |
?> |
|
0 | 2143 |
<script type="text/javascript"> |
19 | 2144 |
addLoadEvent = function(func){if(typeof jQuery!=='undefined')jQuery(function(){func();});else if(typeof wpOnload!=='function'){wpOnload=func;}else{var oldonload=wpOnload;wpOnload=function(){oldonload();func();}}}; |
0 | 2145 |
function tb_close(){var win=window.dialogArguments||opener||parent||top;win.tb_remove();} |
18 | 2146 |
var ajaxurl = '<?php echo esc_js( admin_url( 'admin-ajax.php', 'relative' ) ); ?>', |
2147 |
pagenow = '<?php echo esc_js( $current_screen->id ); ?>', |
|
2148 |
typenow = '<?php echo esc_js( $current_screen->post_type ); ?>', |
|
2149 |
adminpage = '<?php echo esc_js( $admin_body_class ); ?>', |
|
2150 |
thousandsSeparator = '<?php echo esc_js( $wp_locale->number_format['thousands_sep'] ); ?>', |
|
2151 |
decimalPoint = '<?php echo esc_js( $wp_locale->number_format['decimal_point'] ); ?>', |
|
0 | 2152 |
isRtl = <?php echo (int) is_rtl(); ?>; |
2153 |
</script> |
|
9 | 2154 |
<?php |
2155 |
/** This action is documented in wp-admin/admin-header.php */ |
|
2156 |
do_action( 'admin_enqueue_scripts', $hook_suffix ); |
|
5 | 2157 |
|
9 | 2158 |
/** This action is documented in wp-admin/admin-header.php */ |
16 | 2159 |
do_action( "admin_print_styles-{$hook_suffix}" ); // phpcs:ignore WordPress.NamingConventions.ValidHookName.UseUnderscores |
9 | 2160 |
|
2161 |
/** This action is documented in wp-admin/admin-header.php */ |
|
2162 |
do_action( 'admin_print_styles' ); |
|
5 | 2163 |
|
9 | 2164 |
/** This action is documented in wp-admin/admin-header.php */ |
16 | 2165 |
do_action( "admin_print_scripts-{$hook_suffix}" ); // phpcs:ignore WordPress.NamingConventions.ValidHookName.UseUnderscores |
5 | 2166 |
|
9 | 2167 |
/** This action is documented in wp-admin/admin-header.php */ |
2168 |
do_action( 'admin_print_scripts' ); |
|
5 | 2169 |
|
9 | 2170 |
/** This action is documented in wp-admin/admin-header.php */ |
16 | 2171 |
do_action( "admin_head-{$hook_suffix}" ); // phpcs:ignore WordPress.NamingConventions.ValidHookName.UseUnderscores |
5 | 2172 |
|
9 | 2173 |
/** This action is documented in wp-admin/admin-header.php */ |
2174 |
do_action( 'admin_head' ); |
|
5 | 2175 |
|
9 | 2176 |
$admin_body_class .= ' locale-' . sanitize_html_class( strtolower( str_replace( '_', '-', get_user_locale() ) ) ); |
0 | 2177 |
|
9 | 2178 |
if ( is_rtl() ) { |
2179 |
$admin_body_class .= ' rtl'; |
|
2180 |
} |
|
0 | 2181 |
|
9 | 2182 |
?> |
0 | 2183 |
</head> |
9 | 2184 |
<?php |
21
48c4eec2b7e6
Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents:
19
diff
changeset
|
2185 |
$admin_body_id = isset( $body_id ) ? 'id="' . $body_id . '" ' : ''; |
16 | 2186 |
|
9 | 2187 |
/** This filter is documented in wp-admin/admin-header.php */ |
2188 |
$admin_body_classes = apply_filters( 'admin_body_class', '' ); |
|
2189 |
$admin_body_classes = ltrim( $admin_body_classes . ' ' . $admin_body_class ); |
|
2190 |
?> |
|
21
48c4eec2b7e6
Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents:
19
diff
changeset
|
2191 |
<body <?php echo $admin_body_id; ?>class="wp-admin wp-core-ui no-js iframe <?php echo esc_attr( $admin_body_classes ); ?>"> |
0 | 2192 |
<script type="text/javascript"> |
2193 |
(function(){ |
|
2194 |
var c = document.body.className; |
|
2195 |
c = c.replace(/no-js/, 'js'); |
|
2196 |
document.body.className = c; |
|
2197 |
})(); |
|
2198 |
</script> |
|
9 | 2199 |
<?php |
0 | 2200 |
} |
2201 |
||
2202 |
/** |
|
19 | 2203 |
* Generic Iframe footer for use with Thickbox. |
0 | 2204 |
* |
2205 |
* @since 2.7.0 |
|
2206 |
*/ |
|
2207 |
function iframe_footer() { |
|
5 | 2208 |
/* |
2209 |
* We're going to hide any footer output on iFrame pages, |
|
2210 |
* but run the hooks anyway since they output JavaScript |
|
2211 |
* or other needed content. |
|
2212 |
*/ |
|
7
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
2213 |
|
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
2214 |
/** |
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
2215 |
* @global string $hook_suffix |
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
2216 |
*/ |
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
2217 |
global $hook_suffix; |
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
2218 |
?> |
0 | 2219 |
<div class="hidden"> |
9 | 2220 |
<?php |
5 | 2221 |
/** This action is documented in wp-admin/admin-footer.php */ |
7
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
2222 |
do_action( 'admin_footer', $hook_suffix ); |
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
2223 |
|
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
2224 |
/** This action is documented in wp-admin/admin-footer.php */ |
16 | 2225 |
do_action( "admin_print_footer_scripts-{$hook_suffix}" ); // phpcs:ignore WordPress.NamingConventions.ValidHookName.UseUnderscores |
5 | 2226 |
|
2227 |
/** This action is documented in wp-admin/admin-footer.php */ |
|
2228 |
do_action( 'admin_print_footer_scripts' ); |
|
9 | 2229 |
?> |
0 | 2230 |
</div> |
18 | 2231 |
<script type="text/javascript">if(typeof wpOnload==='function')wpOnload();</script> |
0 | 2232 |
</body> |
2233 |
</html> |
|
9 | 2234 |
<?php |
0 | 2235 |
} |
2236 |
||
7
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
2237 |
/** |
19 | 2238 |
* Echoes or returns the post states as HTML. |
16 | 2239 |
* |
2240 |
* @since 2.7.0 |
|
19 | 2241 |
* @since 5.3.0 Added the `$display` parameter and a return value. |
16 | 2242 |
* |
2243 |
* @see get_post_states() |
|
2244 |
* |
|
19 | 2245 |
* @param WP_Post $post The post to retrieve states for. |
2246 |
* @param bool $display Optional. Whether to display the post states as an HTML string. |
|
2247 |
* Default true. |
|
16 | 2248 |
* @return string Post states string. |
7
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
2249 |
*/ |
19 | 2250 |
function _post_states( $post, $display = true ) { |
16 | 2251 |
$post_states = get_post_states( $post ); |
2252 |
$post_states_string = ''; |
|
2253 |
||
2254 |
if ( ! empty( $post_states ) ) { |
|
2255 |
$state_count = count( $post_states ); |
|
19 | 2256 |
|
2257 |
$i = 0; |
|
16 | 2258 |
|
2259 |
$post_states_string .= ' — '; |
|
2260 |
||
2261 |
foreach ( $post_states as $state ) { |
|
19 | 2262 |
++$i; |
2263 |
||
21
48c4eec2b7e6
Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents:
19
diff
changeset
|
2264 |
$separator = ( $i < $state_count ) ? ', ' : ''; |
16 | 2265 |
|
21
48c4eec2b7e6
Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents:
19
diff
changeset
|
2266 |
$post_states_string .= "<span class='post-state'>{$state}{$separator}</span>"; |
16 | 2267 |
} |
2268 |
} |
|
2269 |
||
19 | 2270 |
if ( $display ) { |
16 | 2271 |
echo $post_states_string; |
2272 |
} |
|
2273 |
||
2274 |
return $post_states_string; |
|
2275 |
} |
|
2276 |
||
2277 |
/** |
|
2278 |
* Retrieves an array of post states from a post. |
|
2279 |
* |
|
2280 |
* @since 5.3.0 |
|
2281 |
* |
|
2282 |
* @param WP_Post $post The post to retrieve states for. |
|
2283 |
* @return string[] Array of post state labels keyed by their state. |
|
2284 |
*/ |
|
2285 |
function get_post_states( $post ) { |
|
0 | 2286 |
$post_states = array(); |
16 | 2287 |
|
9 | 2288 |
if ( isset( $_REQUEST['post_status'] ) ) { |
0 | 2289 |
$post_status = $_REQUEST['post_status']; |
9 | 2290 |
} else { |
0 | 2291 |
$post_status = ''; |
9 | 2292 |
} |
0 | 2293 |
|
9 | 2294 |
if ( ! empty( $post->post_password ) ) { |
16 | 2295 |
$post_states['protected'] = _x( 'Password protected', 'post status' ); |
9 | 2296 |
} |
16 | 2297 |
|
2298 |
if ( 'private' === $post->post_status && 'private' !== $post_status ) { |
|
2299 |
$post_states['private'] = _x( 'Private', 'post status' ); |
|
9 | 2300 |
} |
16 | 2301 |
|
7
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
2302 |
if ( 'draft' === $post->post_status ) { |
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
2303 |
if ( get_post_meta( $post->ID, '_customize_changeset_uuid', true ) ) { |
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
2304 |
$post_states[] = __( 'Customization Draft' ); |
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
2305 |
} elseif ( 'draft' !== $post_status ) { |
16 | 2306 |
$post_states['draft'] = _x( 'Draft', 'post status' ); |
7
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
2307 |
} |
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
2308 |
} elseif ( 'trash' === $post->post_status && get_post_meta( $post->ID, '_customize_changeset_uuid', true ) ) { |
16 | 2309 |
$post_states[] = _x( 'Customization Draft', 'post status' ); |
7
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
2310 |
} |
16 | 2311 |
|
2312 |
if ( 'pending' === $post->post_status && 'pending' !== $post_status ) { |
|
9 | 2313 |
$post_states['pending'] = _x( 'Pending', 'post status' ); |
2314 |
} |
|
16 | 2315 |
|
9 | 2316 |
if ( is_sticky( $post->ID ) ) { |
16 | 2317 |
$post_states['sticky'] = _x( 'Sticky', 'post status' ); |
9 | 2318 |
} |
0 | 2319 |
|
7
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
2320 |
if ( 'future' === $post->post_status ) { |
16 | 2321 |
$post_states['scheduled'] = _x( 'Scheduled', 'post status' ); |
5 | 2322 |
} |
2323 |
||
7
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
2324 |
if ( 'page' === get_option( 'show_on_front' ) ) { |
18 | 2325 |
if ( (int) get_option( 'page_on_front' ) === $post->ID ) { |
16 | 2326 |
$post_states['page_on_front'] = _x( 'Front Page', 'page label' ); |
7
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
2327 |
} |
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
2328 |
|
18 | 2329 |
if ( (int) get_option( 'page_for_posts' ) === $post->ID ) { |
16 | 2330 |
$post_states['page_for_posts'] = _x( 'Posts Page', 'page label' ); |
7
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
2331 |
} |
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
2332 |
} |
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
2333 |
|
18 | 2334 |
if ( (int) get_option( 'wp_page_for_privacy_policy' ) === $post->ID ) { |
16 | 2335 |
$post_states['page_for_privacy_policy'] = _x( 'Privacy Policy Page', 'page label' ); |
5 | 2336 |
} |
2337 |
||
2338 |
/** |
|
7
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
2339 |
* Filters the default post display states used in the posts list table. |
5 | 2340 |
* |
2341 |
* @since 2.8.0 |
|
7
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
2342 |
* @since 3.6.0 Added the `$post` parameter. |
16 | 2343 |
* @since 5.5.0 Also applied in the Customizer context. If any admin functions |
2344 |
* are used within the filter, their existence should be checked |
|
2345 |
* with `function_exists()` before being used. |
|
5 | 2346 |
* |
9 | 2347 |
* @param string[] $post_states An array of post display states. |
2348 |
* @param WP_Post $post The current post object. |
|
5 | 2349 |
*/ |
16 | 2350 |
return apply_filters( 'display_post_states', $post_states, $post ); |
0 | 2351 |
} |
2352 |
||
7
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
2353 |
/** |
16 | 2354 |
* Outputs the attachment media states as HTML. |
2355 |
* |
|
2356 |
* @since 3.2.0 |
|
19 | 2357 |
* @since 5.6.0 Added the `$display` parameter and a return value. |
16 | 2358 |
* |
19 | 2359 |
* @param WP_Post $post The attachment post to retrieve states for. |
2360 |
* @param bool $display Optional. Whether to display the post states as an HTML string. |
|
2361 |
* Default true. |
|
18 | 2362 |
* @return string Media states string. |
7
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
2363 |
*/ |
19 | 2364 |
function _media_states( $post, $display = true ) { |
18 | 2365 |
$media_states = get_media_states( $post ); |
2366 |
$media_states_string = ''; |
|
2367 |
||
2368 |
if ( ! empty( $media_states ) ) { |
|
2369 |
$state_count = count( $media_states ); |
|
19 | 2370 |
|
2371 |
$i = 0; |
|
18 | 2372 |
|
2373 |
$media_states_string .= ' — '; |
|
2374 |
||
2375 |
foreach ( $media_states as $state ) { |
|
19 | 2376 |
++$i; |
2377 |
||
21
48c4eec2b7e6
Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents:
19
diff
changeset
|
2378 |
$separator = ( $i < $state_count ) ? ', ' : ''; |
18 | 2379 |
|
21
48c4eec2b7e6
Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents:
19
diff
changeset
|
2380 |
$media_states_string .= "<span class='post-state'>{$state}{$separator}</span>"; |
18 | 2381 |
} |
2382 |
} |
|
2383 |
||
19 | 2384 |
if ( $display ) { |
18 | 2385 |
echo $media_states_string; |
2386 |
} |
|
2387 |
||
2388 |
return $media_states_string; |
|
2389 |
} |
|
2390 |
||
2391 |
/** |
|
2392 |
* Retrieves an array of media states from an attachment. |
|
2393 |
* |
|
2394 |
* @since 5.6.0 |
|
2395 |
* |
|
2396 |
* @param WP_Post $post The attachment to retrieve states for. |
|
2397 |
* @return string[] Array of media state labels keyed by their state. |
|
2398 |
*/ |
|
2399 |
function get_media_states( $post ) { |
|
16 | 2400 |
static $header_images; |
2401 |
||
0 | 2402 |
$media_states = array(); |
9 | 2403 |
$stylesheet = get_option( 'stylesheet' ); |
0 | 2404 |
|
9 | 2405 |
if ( current_theme_supports( 'custom-header' ) ) { |
2406 |
$meta_header = get_post_meta( $post->ID, '_wp_attachment_is_custom_header', true ); |
|
7
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
2407 |
|
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
2408 |
if ( is_random_header_image() ) { |
16 | 2409 |
if ( ! isset( $header_images ) ) { |
2410 |
$header_images = wp_list_pluck( get_uploaded_header_images(), 'attachment_id' ); |
|
2411 |
} |
|
7
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
2412 |
|
16 | 2413 |
if ( $meta_header === $stylesheet && in_array( $post->ID, $header_images, true ) ) { |
7
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
2414 |
$media_states[] = __( 'Header Image' ); |
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
2415 |
} |
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
2416 |
} else { |
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
2417 |
$header_image = get_header_image(); |
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
2418 |
|
16 | 2419 |
// Display "Header Image" if the image was ever used as a header image. |
2420 |
if ( ! empty( $meta_header ) && $meta_header === $stylesheet && wp_get_attachment_url( $post->ID ) !== $header_image ) { |
|
7
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
2421 |
$media_states[] = __( 'Header Image' ); |
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
2422 |
} |
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
2423 |
|
16 | 2424 |
// Display "Current Header Image" if the image is currently the header image. |
2425 |
if ( $header_image && wp_get_attachment_url( $post->ID ) === $header_image ) { |
|
7
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
2426 |
$media_states[] = __( 'Current Header Image' ); |
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
2427 |
} |
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
2428 |
} |
18 | 2429 |
|
2430 |
if ( get_theme_support( 'custom-header', 'video' ) && has_header_video() ) { |
|
2431 |
$mods = get_theme_mods(); |
|
2432 |
if ( isset( $mods['header_video'] ) && $post->ID === $mods['header_video'] ) { |
|
2433 |
$media_states[] = __( 'Current Header Video' ); |
|
2434 |
} |
|
2435 |
} |
|
0 | 2436 |
} |
2437 |
||
9 | 2438 |
if ( current_theme_supports( 'custom-background' ) ) { |
2439 |
$meta_background = get_post_meta( $post->ID, '_wp_attachment_is_custom_background', true ); |
|
7
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
2440 |
|
16 | 2441 |
if ( ! empty( $meta_background ) && $meta_background === $stylesheet ) { |
0 | 2442 |
$media_states[] = __( 'Background Image' ); |
7
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
2443 |
|
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
2444 |
$background_image = get_background_image(); |
16 | 2445 |
if ( $background_image && wp_get_attachment_url( $post->ID ) === $background_image ) { |
7
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
2446 |
$media_states[] = __( 'Current Background Image' ); |
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
2447 |
} |
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
2448 |
} |
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
2449 |
} |
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
2450 |
|
16 | 2451 |
if ( (int) get_option( 'site_icon' ) === $post->ID ) { |
7
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
2452 |
$media_states[] = __( 'Site Icon' ); |
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
2453 |
} |
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
2454 |
|
16 | 2455 |
if ( (int) get_theme_mod( 'custom_logo' ) === $post->ID ) { |
7
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
2456 |
$media_states[] = __( 'Logo' ); |
0 | 2457 |
} |
2458 |
||
5 | 2459 |
/** |
7
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
2460 |
* Filters the default media display states for items in the Media list table. |
5 | 2461 |
* |
2462 |
* @since 3.2.0 |
|
7
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
2463 |
* @since 4.8.0 Added the `$post` parameter. |
5 | 2464 |
* |
9 | 2465 |
* @param string[] $media_states An array of media states. Default 'Header Image', |
2466 |
* 'Background Image', 'Site Icon', 'Logo'. |
|
2467 |
* @param WP_Post $post The current attachment object. |
|
5 | 2468 |
*/ |
18 | 2469 |
return apply_filters( 'display_media_states', $media_states, $post ); |
0 | 2470 |
} |
2471 |
||
2472 |
/** |
|
19 | 2473 |
* Tests support for compressing JavaScript from PHP. |
0 | 2474 |
* |
2475 |
* Outputs JavaScript that tests if compression from PHP works as expected |
|
2476 |
* and sets an option with the result. Has no effect when the current user |
|
2477 |
* is not an administrator. To run the test again the option 'can_compress_scripts' |
|
2478 |
* has to be deleted. |
|
2479 |
* |
|
2480 |
* @since 2.8.0 |
|
2481 |
*/ |
|
2482 |
function compression_test() { |
|
9 | 2483 |
?> |
0 | 2484 |
<script type="text/javascript"> |
7
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
2485 |
var compressionNonce = <?php echo wp_json_encode( wp_create_nonce( 'update_can_compress_scripts' ) ); ?>; |
0 | 2486 |
var testCompression = { |
2487 |
get : function(test) { |
|
2488 |
var x; |
|
2489 |
if ( window.XMLHttpRequest ) { |
|
2490 |
x = new XMLHttpRequest(); |
|
2491 |
} else { |
|
2492 |
try{x=new ActiveXObject('Msxml2.XMLHTTP');}catch(e){try{x=new ActiveXObject('Microsoft.XMLHTTP');}catch(e){};} |
|
2493 |
} |
|
2494 |
||
2495 |
if (x) { |
|
2496 |
x.onreadystatechange = function() { |
|
2497 |
var r, h; |
|
2498 |
if ( x.readyState == 4 ) { |
|
2499 |
r = x.responseText.substr(0, 18); |
|
2500 |
h = x.getResponseHeader('Content-Encoding'); |
|
2501 |
testCompression.check(r, h, test); |
|
2502 |
} |
|
5 | 2503 |
}; |
0 | 2504 |
|
7
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
2505 |
x.open('GET', ajaxurl + '?action=wp-compression-test&test='+test+'&_ajax_nonce='+compressionNonce+'&'+(new Date()).getTime(), true); |
0 | 2506 |
x.send(''); |
2507 |
} |
|
2508 |
}, |
|
2509 |
||
2510 |
check : function(r, h, test) { |
|
2511 |
if ( ! r && ! test ) |
|
2512 |
this.get(1); |
|
2513 |
||
2514 |
if ( 1 == test ) { |
|
2515 |
if ( h && ( h.match(/deflate/i) || h.match(/gzip/i) ) ) |
|
2516 |
this.get('no'); |
|
2517 |
else |
|
2518 |
this.get(2); |
|
2519 |
||
2520 |
return; |
|
2521 |
} |
|
2522 |
||
2523 |
if ( 2 == test ) { |
|
16 | 2524 |
if ( '"wpCompressionTest' === r ) |
0 | 2525 |
this.get('yes'); |
2526 |
else |
|
2527 |
this.get('no'); |
|
2528 |
} |
|
2529 |
} |
|
2530 |
}; |
|
2531 |
testCompression.check(); |
|
2532 |
</script> |
|
9 | 2533 |
<?php |
0 | 2534 |
} |
2535 |
||
2536 |
/** |
|
5 | 2537 |
* Echoes a submit button, with provided text and appropriate class(es). |
0 | 2538 |
* |
2539 |
* @since 3.1.0 |
|
2540 |
* |
|
5 | 2541 |
* @see get_submit_button() |
2542 |
* |
|
21
48c4eec2b7e6
Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents:
19
diff
changeset
|
2543 |
* @param string $text Optional. The text of the button. Defaults to 'Save Changes'. |
5 | 2544 |
* @param string $type Optional. The type and CSS class(es) of the button. Core values |
7
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
2545 |
* include 'primary', 'small', and 'large'. Default 'primary'. |
21
48c4eec2b7e6
Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents:
19
diff
changeset
|
2546 |
* @param string $name Optional. The HTML name of the submit button. If no `id` attribute |
48c4eec2b7e6
Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents:
19
diff
changeset
|
2547 |
* is given in the `$other_attributes` parameter, `$name` will be used |
48c4eec2b7e6
Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents:
19
diff
changeset
|
2548 |
* as the button's `id`. Default 'submit'. |
48c4eec2b7e6
Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents:
19
diff
changeset
|
2549 |
* @param bool $wrap Optional. True if the output button should be wrapped in a paragraph tag, |
48c4eec2b7e6
Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents:
19
diff
changeset
|
2550 |
* false otherwise. Default true. |
48c4eec2b7e6
Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents:
19
diff
changeset
|
2551 |
* @param array|string $other_attributes Optional. Other attributes that should be output with the button, |
48c4eec2b7e6
Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents:
19
diff
changeset
|
2552 |
* mapping attributes to their values, e.g. `array( 'id' => 'search-submit' )`. |
48c4eec2b7e6
Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents:
19
diff
changeset
|
2553 |
* These key/value attribute pairs will be output as `attribute="value"`, |
48c4eec2b7e6
Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents:
19
diff
changeset
|
2554 |
* where attribute is the key. Attributes can also be provided as a string, |
48c4eec2b7e6
Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents:
19
diff
changeset
|
2555 |
* e.g. `id="search-submit"`, though the array format is generally preferred. |
48c4eec2b7e6
Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents:
19
diff
changeset
|
2556 |
* Default empty string. |
0 | 2557 |
*/ |
21
48c4eec2b7e6
Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents:
19
diff
changeset
|
2558 |
function submit_button( $text = '', $type = 'primary', $name = 'submit', $wrap = true, $other_attributes = '' ) { |
0 | 2559 |
echo get_submit_button( $text, $type, $name, $wrap, $other_attributes ); |
2560 |
} |
|
2561 |
||
2562 |
/** |
|
19 | 2563 |
* Returns a submit button, with provided text and appropriate class. |
0 | 2564 |
* |
2565 |
* @since 3.1.0 |
|
2566 |
* |
|
21
48c4eec2b7e6
Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents:
19
diff
changeset
|
2567 |
* @param string $text Optional. The text of the button. Defaults to 'Save Changes'. |
7
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
2568 |
* @param string $type Optional. The type and CSS class(es) of the button. Core values |
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
2569 |
* include 'primary', 'small', and 'large'. Default 'primary large'. |
21
48c4eec2b7e6
Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents:
19
diff
changeset
|
2570 |
* @param string $name Optional. The HTML name of the submit button. If no `id` attribute |
48c4eec2b7e6
Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents:
19
diff
changeset
|
2571 |
* is given in the `$other_attributes` parameter, `$name` will be used |
48c4eec2b7e6
Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents:
19
diff
changeset
|
2572 |
* as the button's `id`. Default 'submit'. |
48c4eec2b7e6
Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents:
19
diff
changeset
|
2573 |
* @param bool $wrap Optional. True if the output button should be wrapped in a paragraph tag, |
48c4eec2b7e6
Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents:
19
diff
changeset
|
2574 |
* false otherwise. Default true. |
5 | 2575 |
* @param array|string $other_attributes Optional. Other attributes that should be output with the button, |
21
48c4eec2b7e6
Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents:
19
diff
changeset
|
2576 |
* mapping attributes to their values, e.g. `array( 'id' => 'search-submit' )`. |
48c4eec2b7e6
Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents:
19
diff
changeset
|
2577 |
* These key/value attribute pairs will be output as `attribute="value"`, |
48c4eec2b7e6
Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents:
19
diff
changeset
|
2578 |
* where attribute is the key. Attributes can also be provided as a string, |
48c4eec2b7e6
Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents:
19
diff
changeset
|
2579 |
* e.g. `id="search-submit"`, though the array format is generally preferred. |
48c4eec2b7e6
Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents:
19
diff
changeset
|
2580 |
* Default empty string. |
5 | 2581 |
* @return string Submit button HTML. |
0 | 2582 |
*/ |
5 | 2583 |
function get_submit_button( $text = '', $type = 'primary large', $name = 'submit', $wrap = true, $other_attributes = '' ) { |
9 | 2584 |
if ( ! is_array( $type ) ) { |
0 | 2585 |
$type = explode( ' ', $type ); |
9 | 2586 |
} |
0 | 2587 |
|
2588 |
$button_shorthand = array( 'primary', 'small', 'large' ); |
|
9 | 2589 |
$classes = array( 'button' ); |
16 | 2590 |
|
0 | 2591 |
foreach ( $type as $t ) { |
9 | 2592 |
if ( 'secondary' === $t || 'button-secondary' === $t ) { |
0 | 2593 |
continue; |
9 | 2594 |
} |
16 | 2595 |
|
2596 |
$classes[] = in_array( $t, $button_shorthand, true ) ? 'button-' . $t : $t; |
|
0 | 2597 |
} |
16 | 2598 |
|
7
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
2599 |
// Remove empty items, remove duplicate items, and finally build a string. |
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
2600 |
$class = implode( ' ', array_unique( array_filter( $classes ) ) ); |
0 | 2601 |
|
2602 |
$text = $text ? $text : __( 'Save Changes' ); |
|
2603 |
||
16 | 2604 |
// Default the id attribute to $name unless an id was specifically provided in $other_attributes. |
0 | 2605 |
$id = $name; |
2606 |
if ( is_array( $other_attributes ) && isset( $other_attributes['id'] ) ) { |
|
2607 |
$id = $other_attributes['id']; |
|
2608 |
unset( $other_attributes['id'] ); |
|
2609 |
} |
|
2610 |
||
2611 |
$attributes = ''; |
|
2612 |
if ( is_array( $other_attributes ) ) { |
|
2613 |
foreach ( $other_attributes as $attribute => $value ) { |
|
16 | 2614 |
$attributes .= $attribute . '="' . esc_attr( $value ) . '" '; // Trailing space is important. |
0 | 2615 |
} |
16 | 2616 |
} elseif ( ! empty( $other_attributes ) ) { // Attributes provided as a string. |
0 | 2617 |
$attributes = $other_attributes; |
2618 |
} |
|
2619 |
||
5 | 2620 |
// Don't output empty name and id attributes. |
2621 |
$name_attr = $name ? ' name="' . esc_attr( $name ) . '"' : ''; |
|
9 | 2622 |
$id_attr = $id ? ' id="' . esc_attr( $id ) . '"' : ''; |
5 | 2623 |
|
9 | 2624 |
$button = '<input type="submit"' . $name_attr . $id_attr . ' class="' . esc_attr( $class ); |
2625 |
$button .= '" value="' . esc_attr( $text ) . '" ' . $attributes . ' />'; |
|
0 | 2626 |
|
2627 |
if ( $wrap ) { |
|
2628 |
$button = '<p class="submit">' . $button . '</p>'; |
|
2629 |
} |
|
2630 |
||
2631 |
return $button; |
|
2632 |
} |
|
2633 |
||
7
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
2634 |
/** |
21
48c4eec2b7e6
Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents:
19
diff
changeset
|
2635 |
* Prints out the beginning of the admin HTML header. |
48c4eec2b7e6
Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents:
19
diff
changeset
|
2636 |
* |
7
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
2637 |
* @global bool $is_IE |
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
2638 |
*/ |
0 | 2639 |
function _wp_admin_html_begin() { |
5 | 2640 |
global $is_IE; |
2641 |
||
0 | 2642 |
$admin_html_class = ( is_admin_bar_showing() ) ? 'wp-toolbar' : ''; |
5 | 2643 |
|
9 | 2644 |
if ( $is_IE ) { |
16 | 2645 |
header( 'X-UA-Compatible: IE=edge' ); |
9 | 2646 |
} |
5 | 2647 |
|
9 | 2648 |
?> |
0 | 2649 |
<!DOCTYPE html> |
16 | 2650 |
<html class="<?php echo $admin_html_class; ?>" |
9 | 2651 |
<?php |
5 | 2652 |
/** |
2653 |
* Fires inside the HTML tag in the admin header. |
|
2654 |
* |
|
2655 |
* @since 2.2.0 |
|
2656 |
*/ |
|
2657 |
do_action( 'admin_xml_ns' ); |
|
9 | 2658 |
|
2659 |
language_attributes(); |
|
2660 |
?> |
|
16 | 2661 |
> |
0 | 2662 |
<head> |
9 | 2663 |
<meta http-equiv="Content-Type" content="<?php bloginfo( 'html_type' ); ?>; charset=<?php echo get_option( 'blog_charset' ); ?>" /> |
2664 |
<?php |
|
0 | 2665 |
} |
2666 |
||
2667 |
/** |
|
19 | 2668 |
* Converts a screen string to a screen object. |
0 | 2669 |
* |
2670 |
* @since 3.0.0 |
|
2671 |
* |
|
2672 |
* @param string $hook_name The hook name (also known as the hook suffix) used to determine the screen. |
|
2673 |
* @return WP_Screen Screen object. |
|
2674 |
*/ |
|
2675 |
function convert_to_screen( $hook_name ) { |
|
2676 |
if ( ! class_exists( 'WP_Screen' ) ) { |
|
7
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
2677 |
_doing_it_wrong( |
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
2678 |
'convert_to_screen(), add_meta_box()', |
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
2679 |
sprintf( |
9 | 2680 |
/* translators: 1: wp-admin/includes/template.php, 2: add_meta_box(), 3: add_meta_boxes */ |
7
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
2681 |
__( 'Likely direct inclusion of %1$s in order to use %2$s. This is very wrong. Hook the %2$s call into the %3$s action instead.' ), |
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
2682 |
'<code>wp-admin/includes/template.php</code>', |
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
2683 |
'<code>add_meta_box()</code>', |
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
2684 |
'<code>add_meta_boxes</code>' |
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
2685 |
), |
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
2686 |
'3.3.0' |
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
2687 |
); |
9 | 2688 |
return (object) array( |
2689 |
'id' => '_invalid', |
|
2690 |
'base' => '_are_belong_to_us', |
|
2691 |
); |
|
0 | 2692 |
} |
2693 |
||
2694 |
return WP_Screen::get( $hook_name ); |
|
2695 |
} |
|
2696 |
||
2697 |
/** |
|
21
48c4eec2b7e6
Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents:
19
diff
changeset
|
2698 |
* Outputs the HTML for restoring the post data from DOM storage |
0 | 2699 |
* |
5 | 2700 |
* @since 3.6.0 |
0 | 2701 |
* @access private |
2702 |
*/ |
|
2703 |
function _local_storage_notice() { |
|
21
48c4eec2b7e6
Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents:
19
diff
changeset
|
2704 |
$local_storage_message = '<p class="local-restore">'; |
48c4eec2b7e6
Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents:
19
diff
changeset
|
2705 |
$local_storage_message .= __( 'The backup of this post in your browser is different from the version below.' ); |
48c4eec2b7e6
Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents:
19
diff
changeset
|
2706 |
$local_storage_message .= '<button type="button" class="button restore-backup">' . __( 'Restore the backup' ) . '</button></p>'; |
48c4eec2b7e6
Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents:
19
diff
changeset
|
2707 |
$local_storage_message .= '<p class="help">'; |
48c4eec2b7e6
Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents:
19
diff
changeset
|
2708 |
$local_storage_message .= __( 'This will replace the current editor content with the last backup version. You can use undo and redo in the editor to get the old content back or to return to the restored version.' ); |
48c4eec2b7e6
Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents:
19
diff
changeset
|
2709 |
$local_storage_message .= '</p>'; |
48c4eec2b7e6
Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents:
19
diff
changeset
|
2710 |
|
48c4eec2b7e6
Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents:
19
diff
changeset
|
2711 |
wp_admin_notice( |
48c4eec2b7e6
Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents:
19
diff
changeset
|
2712 |
$local_storage_message, |
48c4eec2b7e6
Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents:
19
diff
changeset
|
2713 |
array( |
48c4eec2b7e6
Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents:
19
diff
changeset
|
2714 |
'id' => 'local-storage-notice', |
48c4eec2b7e6
Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents:
19
diff
changeset
|
2715 |
'additional_classes' => array( 'hidden' ), |
48c4eec2b7e6
Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents:
19
diff
changeset
|
2716 |
'dismissible' => true, |
48c4eec2b7e6
Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents:
19
diff
changeset
|
2717 |
'paragraph_wrap' => false, |
48c4eec2b7e6
Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents:
19
diff
changeset
|
2718 |
) |
48c4eec2b7e6
Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents:
19
diff
changeset
|
2719 |
); |
0 | 2720 |
} |
5 | 2721 |
|
2722 |
/** |
|
19 | 2723 |
* Outputs a HTML element with a star rating for a given rating. |
5 | 2724 |
* |
2725 |
* Outputs a HTML element with the star rating exposed on a 0..5 scale in |
|
2726 |
* half star increments (ie. 1, 1.5, 2 stars). Optionally, if specified, the |
|
2727 |
* number of ratings may also be displayed by passing the $number parameter. |
|
2728 |
* |
|
2729 |
* @since 3.8.0 |
|
7
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
2730 |
* @since 4.4.0 Introduced the `echo` parameter. |
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
2731 |
* |
5 | 2732 |
* @param array $args { |
2733 |
* Optional. Array of star ratings arguments. |
|
2734 |
* |
|
7
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
2735 |
* @type int|float $rating The rating to display, expressed in either a 0.5 rating increment, |
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
2736 |
* or percentage. Default 0. |
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
2737 |
* @type string $type Format that the $rating is in. Valid values are 'rating' (default), |
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
2738 |
* or, 'percent'. Default 'rating'. |
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
2739 |
* @type int $number The number of ratings that makes up this rating. Default 0. |
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
2740 |
* @type bool $echo Whether to echo the generated markup. False to return the markup instead |
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
2741 |
* of echoing it. Default true. |
5 | 2742 |
* } |
7
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
2743 |
* @return string Star rating HTML. |
5 | 2744 |
*/ |
2745 |
function wp_star_rating( $args = array() ) { |
|
16 | 2746 |
$defaults = array( |
5 | 2747 |
'rating' => 0, |
7
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
2748 |
'type' => 'rating', |
5 | 2749 |
'number' => 0, |
7
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
2750 |
'echo' => true, |
5 | 2751 |
); |
16 | 2752 |
$parsed_args = wp_parse_args( $args, $defaults ); |
5 | 2753 |
|
16 | 2754 |
// Non-English decimal places when the $rating is coming from a string. |
2755 |
$rating = (float) str_replace( ',', '.', $parsed_args['rating'] ); |
|
5 | 2756 |
|
16 | 2757 |
// Convert percentage to star rating, 0..5 in .5 increments. |
2758 |
if ( 'percent' === $parsed_args['type'] ) { |
|
5 | 2759 |
$rating = round( $rating / 10, 0 ) / 2; |
2760 |
} |
|
2761 |
||
16 | 2762 |
// Calculate the number of each type of star needed. |
9 | 2763 |
$full_stars = floor( $rating ); |
2764 |
$half_stars = ceil( $rating - $full_stars ); |
|
5 | 2765 |
$empty_stars = 5 - $full_stars - $half_stars; |
2766 |
||
16 | 2767 |
if ( $parsed_args['number'] ) { |
21
48c4eec2b7e6
Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents:
19
diff
changeset
|
2768 |
/* translators: Hidden accessibility text. 1: The rating, 2: The number of ratings. */ |
16 | 2769 |
$format = _n( '%1$s rating based on %2$s rating', '%1$s rating based on %2$s ratings', $parsed_args['number'] ); |
2770 |
$title = sprintf( $format, number_format_i18n( $rating, 1 ), number_format_i18n( $parsed_args['number'] ) ); |
|
5 | 2771 |
} else { |
21
48c4eec2b7e6
Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents:
19
diff
changeset
|
2772 |
/* translators: Hidden accessibility text. %s: The rating. */ |
5 | 2773 |
$title = sprintf( __( '%s rating' ), number_format_i18n( $rating, 1 ) ); |
2774 |
} |
|
2775 |
||
9 | 2776 |
$output = '<div class="star-rating">'; |
7
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
2777 |
$output .= '<span class="screen-reader-text">' . $title . '</span>'; |
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
2778 |
$output .= str_repeat( '<div class="star star-full" aria-hidden="true"></div>', $full_stars ); |
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
2779 |
$output .= str_repeat( '<div class="star star-half" aria-hidden="true"></div>', $half_stars ); |
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
2780 |
$output .= str_repeat( '<div class="star star-empty" aria-hidden="true"></div>', $empty_stars ); |
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
2781 |
$output .= '</div>'; |
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
2782 |
|
16 | 2783 |
if ( $parsed_args['echo'] ) { |
7
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
2784 |
echo $output; |
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
2785 |
} |
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
2786 |
|
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
2787 |
return $output; |
5 | 2788 |
} |
2789 |
||
2790 |
/** |
|
18 | 2791 |
* Outputs a notice when editing the page for posts (internal use only). |
5 | 2792 |
* |
2793 |
* @ignore |
|
2794 |
* @since 4.2.0 |
|
2795 |
*/ |
|
2796 |
function _wp_posts_page_notice() { |
|
21
48c4eec2b7e6
Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents:
19
diff
changeset
|
2797 |
wp_admin_notice( |
48c4eec2b7e6
Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents:
19
diff
changeset
|
2798 |
__( 'You are currently editing the page that shows your latest posts.' ), |
48c4eec2b7e6
Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents:
19
diff
changeset
|
2799 |
array( |
48c4eec2b7e6
Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents:
19
diff
changeset
|
2800 |
'type' => 'warning', |
48c4eec2b7e6
Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents:
19
diff
changeset
|
2801 |
'additional_classes' => array( 'inline' ), |
48c4eec2b7e6
Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents:
19
diff
changeset
|
2802 |
) |
18 | 2803 |
); |
5 | 2804 |
} |
18 | 2805 |
|
2806 |
/** |
|
2807 |
* Outputs a notice when editing the page for posts in the block editor (internal use only). |
|
2808 |
* |
|
2809 |
* @ignore |
|
2810 |
* @since 5.8.0 |
|
2811 |
*/ |
|
2812 |
function _wp_block_editor_posts_page_notice() { |
|
2813 |
wp_add_inline_script( |
|
2814 |
'wp-notices', |
|
2815 |
sprintf( |
|
2816 |
'wp.data.dispatch( "core/notices" ).createWarningNotice( "%s", { isDismissible: false } )', |
|
2817 |
__( 'You are currently editing the page that shows your latest posts.' ) |
|
2818 |
), |
|
2819 |
'after' |
|
2820 |
); |
|
2821 |
} |