WordPress 4.0
[autoinstalls/wordpress.git] / wp-admin / revision.php
1 <?php
2 /**
3  * Revisions administration panel
4  *
5  * Requires wp-admin/includes/revision.php.
6  *
7  * @package WordPress
8  * @subpackage Administration
9  * @since 2.6.0
10  *
11  * @param int    revision Optional. The revision ID.
12  * @param string action   The action to take.
13  *                        Accepts 'restore', 'view' or 'edit'.
14  * @param int    from     The revision to compare from.
15  * @param int    to       Optional, required if revision missing. The revision to compare to.
16  */
17
18 /** WordPress Administration Bootstrap */
19 require_once( dirname( __FILE__ ) . '/admin.php' );
20
21 require ABSPATH . 'wp-admin/includes/revision.php';
22
23 wp_reset_vars( array( 'revision', 'action', 'from', 'to' ) );
24
25 $revision_id = absint( $revision );
26
27 $from = is_numeric( $from ) ? absint( $from ) : null;
28 if ( ! $revision_id )
29         $revision_id = absint( $to );
30 $redirect = 'edit.php';
31
32 switch ( $action ) {
33 case 'restore' :
34         if ( ! $revision = wp_get_post_revision( $revision_id ) )
35                 break;
36
37         if ( ! current_user_can( 'edit_post', $revision->post_parent ) )
38                 break;
39
40         if ( ! $post = get_post( $revision->post_parent ) )
41                 break;
42
43         // Revisions disabled (previously checked autosaves && ! wp_is_post_autosave( $revision ))
44         if ( ! wp_revisions_enabled( $post ) ) {
45                 $redirect = 'edit.php?post_type=' . $post->post_type;
46                 break;
47         }
48
49         // Don't allow revision restore when post is locked
50         if ( wp_check_post_lock( $post->ID ) )
51                 break;
52
53         check_admin_referer( "restore-post_{$revision->ID}" );
54
55         wp_restore_post_revision( $revision->ID );
56         $redirect = add_query_arg( array( 'message' => 5, 'revision' => $revision->ID ), get_edit_post_link( $post->ID, 'url' ) );
57         break;
58 case 'view' :
59 case 'edit' :
60 default :
61         if ( ! $revision = wp_get_post_revision( $revision_id ) )
62                 break;
63         if ( ! $post = get_post( $revision->post_parent ) )
64                 break;
65
66         if ( ! current_user_can( 'read_post', $revision->ID ) || ! current_user_can( 'read_post', $post->ID ) )
67                 break;
68
69         // Revisions disabled and we're not looking at an autosave
70         if ( ! wp_revisions_enabled( $post ) && ! wp_is_post_autosave( $revision ) ) {
71                 $redirect = 'edit.php?post_type=' . $post->post_type;
72                 break;
73         }
74
75         $post_edit_link = get_edit_post_link();
76         $post_title     = '<a href="' . $post_edit_link . '">' . _draft_or_post_title() . '</a>';
77         $h2             = sprintf( __( 'Compare Revisions of &#8220;%1$s&#8221;' ), $post_title );
78         $return_to_post = '<a href="' . $post_edit_link . '">' . __( '&larr; Return to post editor' ) . '</a>';
79         $title          = __( 'Revisions' );
80
81         $redirect = false;
82         break;
83 }
84
85 // Empty post_type means either malformed object found, or no valid parent was found.
86 if ( ! $redirect && empty( $post->post_type ) )
87         $redirect = 'edit.php';
88
89 if ( ! empty( $redirect ) ) {
90         wp_redirect( $redirect );
91         exit;
92 }
93
94 // This is so that the correct "Edit" menu item is selected.
95 if ( ! empty( $post->post_type ) && 'post' != $post->post_type )
96         $parent_file = $submenu_file = 'edit.php?post_type=' . $post->post_type;
97 else
98         $parent_file = $submenu_file = 'edit.php';
99
100 wp_enqueue_script( 'revisions' );
101 wp_localize_script( 'revisions', '_wpRevisionsSettings', wp_prepare_revisions_for_js( $post, $revision_id, $from ) );
102
103 /* Revisions Help Tab */
104
105 $revisions_overview  = '<p>' . __( 'This screen is used for managing your content revisions.' ) . '</p>';
106 $revisions_overview .= '<p>' . __( 'Revisions are saved copies of your post or page, which are periodically created as you update your content. The red text on the left shows the content that was removed. The green text on the right shows the content that was added.' ) . '</p>';
107 $revisions_overview .= '<p>' . __( 'From this screen you can review, compare, and restore revisions:' ) . '</p>';
108 $revisions_overview .= '<ul><li>' . __( 'To navigate between revisions, <strong>drag the slider handle left or right</strong> or <strong>use the Previous or Next buttons</strong>.' ) . '</li>';
109 $revisions_overview .= '<li>' . __( 'Compare two different revisions by <strong>selecting the &#8220;Compare any two revisions&#8221; box</strong> to the side.' ) . '</li>';
110 $revisions_overview .= '<li>' . __( 'To restore a revision, <strong>click Restore This Revision</strong>.' ) . '</li></ul>';
111
112 get_current_screen()->add_help_tab( array(
113         'id'      => 'revisions-overview',
114         'title'   => __( 'Overview' ),
115         'content' => $revisions_overview
116 ) );
117
118 $revisions_sidebar  = '<p><strong>' . __( 'For more information:' ) . '</strong></p>';
119 $revisions_sidebar .= '<p>' . __( '<a href="http://codex.wordpress.org/Revision_Management" target="_blank">Revisions Management</a>' ) . '</p>';
120 $revisions_sidebar .= '<p>' . __( '<a href="https://wordpress.org/support/" target="_blank">Support Forums</a>' ) . '</p>';
121
122 get_current_screen()->set_help_sidebar( $revisions_sidebar );
123
124 require_once( ABSPATH . 'wp-admin/admin-header.php' );
125
126 ?>
127
128 <div class="wrap">
129         <h2 class="long-header"><?php echo $h2; ?></h2>
130         <?php echo $return_to_post; ?>
131 </div>
132
133 <script id="tmpl-revisions-frame" type="text/html">
134         <div class="revisions-control-frame"></div>
135         <div class="revisions-diff-frame"></div>
136 </script>
137
138 <script id="tmpl-revisions-buttons" type="text/html">
139         <div class="revisions-previous">
140                 <input class="button" type="button" value="<?php echo esc_attr_x( 'Previous', 'Button label for a previous revision' ); ?>" />
141         </div>
142
143         <div class="revisions-next">
144                 <input class="button" type="button" value="<?php echo esc_attr_x( 'Next', 'Button label for a next revision' ); ?>" />
145         </div>
146 </script>
147
148 <script id="tmpl-revisions-checkbox" type="text/html">
149         <div class="revision-toggle-compare-mode">
150                 <label>
151                         <input type="checkbox" class="compare-two-revisions"
152                         <#
153                         if ( 'undefined' !== typeof data && data.model.attributes.compareTwoMode ) {
154                                 #> checked="checked"<#
155                         }
156                         #>
157                         />
158                         <?php esc_attr_e( 'Compare any two revisions' ); ?>
159                 </label>
160         </div>
161 </script>
162
163 <script id="tmpl-revisions-meta" type="text/html">
164         <# if ( ! _.isUndefined( data.attributes ) ) { #>
165                 <div class="diff-title">
166                         <# if ( 'from' === data.type ) { #>
167                                 <strong><?php _ex( 'From:', 'Followed by post revision info' ); ?></strong>
168                         <# } else if ( 'to' === data.type ) { #>
169                                 <strong><?php _ex( 'To:', 'Followed by post revision info' ); ?></strong>
170                         <# } #>
171                         <div class="author-card<# if ( data.attributes.autosave ) { #> autosave<# } #>">
172                                 {{{ data.attributes.author.avatar }}}
173                                 <div class="author-info">
174                                 <# if ( data.attributes.autosave ) { #>
175                                         <span class="byline"><?php printf( __( 'Autosave by %s' ),
176                                                 '<span class="author-name">{{ data.attributes.author.name }}</span>' ); ?></span>
177                                 <# } else if ( data.attributes.current ) { #>
178                                         <span class="byline"><?php printf( __( 'Current Revision by %s' ),
179                                                 '<span class="author-name">{{ data.attributes.author.name }}</span>' ); ?></span>
180                                 <# } else { #>
181                                         <span class="byline"><?php printf( __( 'Revision by %s' ),
182                                                 '<span class="author-name">{{ data.attributes.author.name }}</span>' ); ?></span>
183                                 <# } #>
184                                         <span class="time-ago">{{ data.attributes.timeAgo }}</span>
185                                         <span class="date">({{ data.attributes.dateShort }})</span>
186                                 </div>
187                         <# if ( 'to' === data.type && data.attributes.restoreUrl ) { #>
188                                 <input  <?php if ( wp_check_post_lock( $post->ID ) ) { ?>
189                                         disabled="disabled"
190                                 <?php } else { ?>
191                                         <# if ( data.attributes.current ) { #>
192                                                 disabled="disabled"
193                                         <# } #>
194                                 <?php } ?>
195                                 <# if ( data.attributes.autosave ) { #>
196                                         type="button" class="restore-revision button button-primary" value="<?php esc_attr_e( 'Restore This Autosave' ); ?>" />
197                                 <# } else { #>
198                                         type="button" class="restore-revision button button-primary" value="<?php esc_attr_e( 'Restore This Revision' ); ?>" />
199                                 <# } #>
200                         <# } #>
201                 </div>
202         <# if ( 'tooltip' === data.type ) { #>
203                 <div class="revisions-tooltip-arrow"><span></span></div>
204         <# } #>
205 <# } #>
206 </script>
207
208 <script id="tmpl-revisions-diff" type="text/html">
209         <div class="loading-indicator"><span class="spinner"></span></div>
210         <div class="diff-error"><?php _e( 'Sorry, something went wrong. The requested comparison could not be loaded.' ); ?></div>
211         <div class="diff">
212         <# _.each( data.fields, function( field ) { #>
213                 <h3>{{ field.name }}</h3>
214                 {{{ field.diff }}}
215         <# }); #>
216         </div>
217 </script>
218
219
220 <?php
221 require_once( ABSPATH . 'wp-admin/admin-footer.php' );