Submit
Path:
~
/
home
/
caidadmin
/
dev2.sca-caid.org.old
/
wp-admin
/
includes
/
File Content:
revision.php
<?php /** * WordPress Administration Revisions API * * @package WordPress * @subpackage Administration * @since 3.6.0 */ /** * Get the revision UI diff. * * @since 3.6.0 * * @param object|int $post The post object. Also accepts a post ID. * @param int $compare_from The revision ID to compare from. * @param int $compare_to The revision ID to come to. * * @return array|bool Associative array of a post's revisioned fields and their diffs. * Or, false on failure. */ function wp_get_revision_ui_diff( $post, $compare_from, $compare_to ) { if ( ! $post = get_post( $post ) ) return false; if ( $compare_from ) { if ( ! $compare_from = get_post( $compare_from ) ) return false; } else { // If we're dealing with the first revision... $compare_from = false; } if ( ! $compare_to = get_post( $compare_to ) ) return false; // If comparing revisions, make sure we're dealing with the right post parent. // The parent post may be a 'revision' when revisions are disabled and we're looking at autosaves. if ( $compare_from && $compare_from->post_parent !== $post->ID && $compare_from->ID !== $post->ID ) return false; if ( $compare_to->post_parent !== $post->ID && $compare_to->ID !== $post->ID ) return false; if ( $compare_from && strtotime( $compare_from->post_date_gmt ) > strtotime( $compare_to->post_date_gmt ) ) { $temp = $compare_from; $compare_from = $compare_to; $compare_to = $temp; } // Add default title if title field is empty if ( $compare_from && empty( $compare_from->post_title ) ) $compare_from->post_title = __( '(no title)' ); if ( empty( $compare_to->post_title ) ) $compare_to->post_title = __( '(no title)' ); $return = array(); foreach ( _wp_post_revision_fields( $post ) as $field => $name ) { /** * Contextually filter a post revision field. * * The dynamic portion of the hook name, `$field`, corresponds to each of the post * fields of the revision object being iterated over in a foreach statement. * * @since 3.6.0 * * @param string $compare_from->$field The current revision field to compare to or from. * @param string $field The current revision field. * @param WP_Post $compare_from The revision post object to compare to or from. * @param string null The context of whether the current revision is the old * or the new one. Values are 'to' or 'from'. */ $content_from = $compare_from ? apply_filters( "_wp_post_revision_field_{$field}", $compare_from->$field, $field, $compare_from, 'from' ) : ''; /** This filter is documented in wp-admin/includes/revision.php */ $content_to = apply_filters( "_wp_post_revision_field_{$field}", $compare_to->$field, $field, $compare_to, 'to' ); $args = array( 'show_split_view' => true ); /** * Filters revisions text diff options. * * Filters the options passed to wp_text_diff() when viewing a post revision. * * @since 4.1.0 * * @param array $args { * Associative array of options to pass to wp_text_diff(). * * @type bool $show_split_view True for split view (two columns), false for * un-split view (single column). Default true. * } * @param string $field The current revision field. * @param WP_Post $compare_from The revision post to compare from. * @param WP_Post $compare_to The revision post to compare to. */ $args = apply_filters( 'revision_text_diff_options', $args, $field, $compare_from, $compare_to ); $diff = wp_text_diff( $content_from, $content_to, $args ); if ( ! $diff && 'post_title' === $field ) { // It's a better user experience to still show the Title, even if it didn't change. // No, you didn't see this. $diff = '<table class="diff"><colgroup><col class="content diffsplit left"><col class="content diffsplit middle"><col class="content diffsplit right"></colgroup><tbody><tr>'; $diff .= '<td>' . esc_html( $compare_from->post_title ) . '</td><td></td><td>' . esc_html( $compare_to->post_title ) . '</td>'; $diff .= '</tr></tbody>'; $diff .= '</table>'; } if ( $diff ) { $return[] = array( 'id' => $field, 'name' => $name, 'diff' => $diff, ); } } /** * Filters the fields displayed in the post revision diff UI. * * @since 4.1.0 * * @param array $return Revision UI fields. Each item is an array of id, name and diff. * @param WP_Post $compare_from The revision post to compare from. * @param WP_Post $compare_to The revision post to compare to. */ return apply_filters( 'wp_get_revision_ui_diff', $return, $compare_from, $compare_to ); } /** * Prepare revisions for JavaScript. * * @since 3.6.0 * * @param object|int $post The post object. Also accepts a post ID. * @param int $selected_revision_id The selected revision ID. * @param int $from Optional. The revision ID to compare from. * * @return array An associative array of revision data and related settings. */ function wp_prepare_revisions_for_js( $post, $selected_revision_id, $from = null ) { $post = get_post( $post ); $authors = array(); $now_gmt = time(); $revisions = wp_get_post_revisions( $post->ID, array( 'order' => 'ASC', 'check_enabled' => false ) ); // If revisions are disabled, we only want autosaves and the current post. if ( ! wp_revisions_enabled( $post ) ) { foreach ( $revisions as $revision_id => $revision ) { if ( ! wp_is_post_autosave( $revision ) ) unset( $revisions[ $revision_id ] ); } $revisions = array( $post->ID => $post ) + $revisions; } $show_avatars = get_option( 'show_avatars' ); cache_users( wp_list_pluck( $revisions, 'post_author' ) ); $can_restore = current_user_can( 'edit_post', $post->ID ); $current_id = false; foreach ( $revisions as $revision ) { $modified = strtotime( $revision->post_modified ); $modified_gmt = strtotime( $revision->post_modified_gmt . ' +0000' ); if ( $can_restore ) { $restore_link = str_replace( '&', '&', wp_nonce_url( add_query_arg( array( 'revision' => $revision->ID, 'action' => 'restore' ), admin_url( 'revision.php' ) ), "restore-post_{$revision->ID}" ) ); } if ( ! isset( $authors[ $revision->post_author ] ) ) { $authors[ $revision->post_author ] = array( 'id' => (int) $revision->post_author, 'avatar' => $show_avatars ? get_avatar( $revision->post_author, 32 ) : '', 'name' => get_the_author_meta( 'display_name', $revision->post_author ), ); } $autosave = (bool) wp_is_post_autosave( $revision ); $current = ! $autosave && $revision->post_modified_gmt === $post->post_modified_gmt; if ( $current && ! empty( $current_id ) ) { // If multiple revisions have the same post_modified_gmt, highest ID is current. if ( $current_id < $revision->ID ) { $revisions[ $current_id ]['current'] = false; $current_id = $revision->ID; } else { $current = false; } } elseif ( $current ) { $current_id = $revision->ID; } $revisions_data = array( 'id' => $revision->ID, 'title' => get_the_title( $post->ID ), 'author' => $authors[ $revision->post_author ], 'date' => date_i18n( __( 'M j, Y @ H:i' ), $modified ), 'dateShort' => date_i18n( _x( 'j M @ H:i', 'revision date short format' ), $modified ), 'timeAgo' => sprintf( __( '%s ago' ), human_time_diff( $modified_gmt, $now_gmt ) ), 'autosave' => $autosave, 'current' => $current, 'restoreUrl' => $can_restore ? $restore_link : false, ); /** * Filters the array of revisions used on the revisions screen. * * @since 4.4.0 * * @param array $revisions_data { * The bootstrapped data for the revisions screen. * * @type int $id Revision ID. * @type string $title Title for the revision's parent WP_Post object. * @type int $author Revision post author ID. * @type string $date Date the revision was modified. * @type string $dateShort Short-form version of the date the revision was modified. * @type string $timeAgo GMT-aware amount of time ago the revision was modified. * @type bool $autosave Whether the revision is an autosave. * @type bool $current Whether the revision is both not an autosave and the post * modified date matches the revision modified date (GMT-aware). * @type bool|false $restoreUrl URL if the revision can be restored, false otherwise. * } * @param WP_Post $revision The revision's WP_Post object. * @param WP_Post $post The revision's parent WP_Post object. */ $revisions[ $revision->ID ] = apply_filters( 'wp_prepare_revision_for_js', $revisions_data, $revision, $post ); } /** * If we only have one revision, the initial revision is missing; This happens * when we have an autsosave and the user has clicked 'View the Autosave' */ if ( 1 === sizeof( $revisions ) ) { $revisions[ $post->ID ] = array( 'id' => $post->ID, 'title' => get_the_title( $post->ID ), 'author' => $authors[ $post->post_author ], 'date' => date_i18n( __( 'M j, Y @ H:i' ), strtotime( $post->post_modified ) ), 'dateShort' => date_i18n( _x( 'j M @ H:i', 'revision date short format' ), strtotime( $post->post_modified ) ), 'timeAgo' => sprintf( __( '%s ago' ), human_time_diff( strtotime( $post->post_modified_gmt ), $now_gmt ) ), 'autosave' => false, 'current' => true, 'restoreUrl' => false, ); $current_id = $post->ID; } /* * If a post has been saved since the last revision (no revisioned fields * were changed), we may not have a "current" revision. Mark the latest * revision as "current". */ if ( empty( $current_id ) ) { if ( $revisions[ $revision->ID ]['autosave'] ) { $revision = end( $revisions ); while ( $revision['autosave'] ) { $revision = prev( $revisions ); } $current_id = $revision['id']; } else { $current_id = $revision->ID; } $revisions[ $current_id ]['current'] = true; } // Now, grab the initial diff. $compare_two_mode = is_numeric( $from ); if ( ! $compare_two_mode ) { $found = array_search( $selected_revision_id, array_keys( $revisions ) ); if ( $found ) { $from = array_keys( array_slice( $revisions, $found - 1, 1, true ) ); $from = reset( $from ); } else { $from = 0; } } $from = absint( $from ); $diffs = array( array( 'id' => $from . ':' . $selected_revision_id, 'fields' => wp_get_revision_ui_diff( $post->ID, $from, $selected_revision_id ), )); return array( 'postId' => $post->ID, 'nonce' => wp_create_nonce( 'revisions-ajax-nonce' ), 'revisionData' => array_values( $revisions ), 'to' => $selected_revision_id, 'from' => $from, 'diffData' => $diffs, 'baseUrl' => parse_url( admin_url( 'revision.php' ), PHP_URL_PATH ), 'compareTwoMode' => absint( $compare_two_mode ), // Apparently booleans are not allowed 'revisionIds' => array_keys( $revisions ), ); } /** * Print JavaScript templates required for the revisions experience. * * @since 4.1.0 * * @global WP_Post $post The global `$post` object. */ function wp_print_revision_templates() { global $post; ?><script id="tmpl-revisions-frame" type="text/html"> <div class="revisions-control-frame"></div> <div class="revisions-diff-frame"></div> </script> <script id="tmpl-revisions-buttons" type="text/html"> <div class="revisions-previous"> <input class="button" type="button" value="<?php echo esc_attr_x( 'Previous', 'Button label for a previous revision' ); ?>" /> </div> <div class="revisions-next"> <input class="button" type="button" value="<?php echo esc_attr_x( 'Next', 'Button label for a next revision' ); ?>" /> </div> </script> <script id="tmpl-revisions-checkbox" type="text/html"> <div class="revision-toggle-compare-mode"> <label> <input type="checkbox" class="compare-two-revisions" <# if ( 'undefined' !== typeof data && data.model.attributes.compareTwoMode ) { #> checked="checked"<# } #> /> <?php esc_html_e( 'Compare any two revisions' ); ?> </label> </div> </script> <script id="tmpl-revisions-meta" type="text/html"> <# if ( ! _.isUndefined( data.attributes ) ) { #> <div class="diff-title"> <# if ( 'from' === data.type ) { #> <strong><?php _ex( 'From:', 'Followed by post revision info' ); ?></strong> <# } else if ( 'to' === data.type ) { #> <strong><?php _ex( 'To:', 'Followed by post revision info' ); ?></strong> <# } #> <div class="author-card<# if ( data.attributes.autosave ) { #> autosave<# } #>"> {{{ data.attributes.author.avatar }}} <div class="author-info"> <# if ( data.attributes.autosave ) { #> <span class="byline"><?php printf( __( 'Autosave by %s' ), '<span class="author-name">{{ data.attributes.author.name }}</span>' ); ?></span> <# } else if ( data.attributes.current ) { #> <span class="byline"><?php printf( __( 'Current Revision by %s' ), '<span class="author-name">{{ data.attributes.author.name }}</span>' ); ?></span> <# } else { #> <span class="byline"><?php printf( __( 'Revision by %s' ), '<span class="author-name">{{ data.attributes.author.name }}</span>' ); ?></span> <# } #> <span class="time-ago">{{ data.attributes.timeAgo }}</span> <span class="date">({{ data.attributes.dateShort }})</span> </div> <# if ( 'to' === data.type && data.attributes.restoreUrl ) { #> <input <?php if ( wp_check_post_lock( $post->ID ) ) { ?> disabled="disabled" <?php } else { ?> <# if ( data.attributes.current ) { #> disabled="disabled" <# } #> <?php } ?> <# if ( data.attributes.autosave ) { #> type="button" class="restore-revision button button-primary" value="<?php esc_attr_e( 'Restore This Autosave' ); ?>" /> <# } else { #> type="button" class="restore-revision button button-primary" value="<?php esc_attr_e( 'Restore This Revision' ); ?>" /> <# } #> <# } #> </div> <# if ( 'tooltip' === data.type ) { #> <div class="revisions-tooltip-arrow"><span></span></div> <# } #> <# } #> </script> <script id="tmpl-revisions-diff" type="text/html"> <div class="loading-indicator"><span class="spinner"></span></div> <div class="diff-error"><?php _e( 'Sorry, something went wrong. The requested comparison could not be loaded.' ); ?></div> <div class="diff"> <# _.each( data.fields, function( field ) { #> <h3>{{ field.name }}</h3> {{{ field.diff }}} <# }); #> </div> </script><?php }
Submit
FILE
FOLDER
Name
Size
Permission
Action
admin-filters.php
7177 bytes
0644
admin.php
2948 bytes
0644
ajax-actions.php
128972 bytes
0644
bookmark.php
9098 bytes
0644
class-automatic-upgrader-skin.php
3100 bytes
0644
class-bulk-plugin-upgrader-skin.php
1896 bytes
0644
class-bulk-theme-upgrader-skin.php
1940 bytes
0644
class-bulk-upgrader-skin.php
5200 bytes
0644
class-core-upgrader.php
13385 bytes
0644
class-file-upload-upgrader.php
3257 bytes
0644
class-ftp-pure.php
5399 bytes
0644
class-ftp-sockets.php
8448 bytes
0644
class-ftp.php
27097 bytes
0644
class-language-pack-upgrader-skin.php
2184 bytes
0644
class-language-pack-upgrader.php
11065 bytes
0644
class-pclzip.php
195795 bytes
0644
class-plugin-installer-skin.php
4306 bytes
0644
class-plugin-upgrader-skin.php
2556 bytes
0644
class-plugin-upgrader.php
14663 bytes
0644
class-theme-installer-skin.php
4081 bytes
0644
class-theme-upgrader-skin.php
3424 bytes
0644
class-theme-upgrader.php
19500 bytes
0644
class-walker-category-checklist.php
4214 bytes
0644
class-walker-nav-menu-checklist.php
4929 bytes
0644
class-walker-nav-menu-edit.php
11204 bytes
0644
class-wp-ajax-upgrader-skin.php
3074 bytes
0644
class-wp-automatic-updater.php
34032 bytes
0644
class-wp-comments-list-table.php
25638 bytes
0644
class-wp-community-events.php
15926 bytes
0644
class-wp-filesystem-base.php
22184 bytes
0644
class-wp-filesystem-direct.php
11222 bytes
0644
class-wp-filesystem-ftpext.php
13465 bytes
0644
class-wp-filesystem-ftpsockets.php
10586 bytes
0644
class-wp-filesystem-ssh2.php
14963 bytes
0644
class-wp-importer.php
7342 bytes
0644
class-wp-internal-pointers.php
5521 bytes
0644
class-wp-links-list-table.php
7602 bytes
0644
class-wp-list-table-compat.php
1068 bytes
0644
class-wp-list-table.php
37340 bytes
0644
class-wp-media-list-table.php
22641 bytes
0644
class-wp-ms-sites-list-table.php
15556 bytes
0644
class-wp-ms-themes-list-table.php
20232 bytes
0644
class-wp-ms-users-list-table.php
12842 bytes
0644
class-wp-plugin-install-list-table.php
19348 bytes
0644
class-wp-plugins-list-table.php
32818 bytes
0644
class-wp-post-comments-list-table.php
1472 bytes
0644
class-wp-posts-list-table.php
52715 bytes
0644
class-wp-screen.php
35535 bytes
0644
class-wp-site-icon.php
6043 bytes
0644
class-wp-terms-list-table.php
17957 bytes
0644
class-wp-theme-install-list-table.php
14524 bytes
0644
class-wp-themes-list-table.php
9267 bytes
0644
class-wp-upgrader-skin.php
5061 bytes
0644
class-wp-upgrader-skins.php
1456 bytes
0644
class-wp-upgrader.php
33913 bytes
0644
class-wp-users-list-table.php
17282 bytes
0644
comment.php
5726 bytes
0644
continents-cities.php
19684 bytes
0644
credits.php
2192 bytes
0644
dashboard.php
63568 bytes
0644
deprecated.php
39173 bytes
0644
edit-tag-messages.php
1411 bytes
0644
export.php
22966 bytes
0644
file.php
82178 bytes
0644
image-edit.php
33553 bytes
0644
image.php
22097 bytes
0644
import.php
6246 bytes
0644
list-table.php
2648 bytes
0644
media.php
106323 bytes
0644
menu.php
8715 bytes
0644
meta-boxes.php
52225 bytes
0644
misc.php
64266 bytes
0644
ms-admin-filters.php
1387 bytes
0644
ms-deprecated.php
2860 bytes
0644
ms.php
35406 bytes
0644
nav-menu.php
42469 bytes
0644
network.php
23879 bytes
0644
noop.php
1222 bytes
0644
options.php
3832 bytes
0644
plugin-install.php
31700 bytes
0644
plugin.php
68668 bytes
0644
post.php
60833 bytes
0644
revision.php
14947 bytes
0644
schema.php
36233 bytes
0644
screen.php
6148 bytes
0644
taxonomy.php
7727 bytes
0644
template.php
80420 bytes
0644
theme-install.php
6286 bytes
0644
theme.php
28334 bytes
0644
translation-install.php
8551 bytes
0644
update-core.php
55770 bytes
0644
update.php
25873 bytes
0644
upgrade.php
95880 bytes
0644
user.php
50052 bytes
0644
widgets.php
10001 bytes
0644
N4ST4R_ID | Naxtarrr