X-Git-Url: https://scripts.mit.edu/gitweb/autoinstalls/wordpress.git/blobdiff_plain/542cf06a610bc430421351ace7a2cc45f393b990..245e789b234afa4525862e7a6e5e3c2e7a52ef20:/wp-admin/includes/dashboard.php
diff --git a/wp-admin/includes/dashboard.php b/wp-admin/includes/dashboard.php
index 8486581b..fb50197e 100644
--- a/wp-admin/includes/dashboard.php
+++ b/wp-admin/includes/dashboard.php
@@ -1,6 +1,6 @@
5,
- );
- }
- $recent_comments_title = __( 'Recent Comments' );
- wp_add_dashboard_widget( 'dashboard_recent_comments', $recent_comments_title, 'wp_dashboard_recent_comments', 'wp_dashboard_recent_comments_control' );
-
- // Incoming Links Widget
- if ( !isset( $widget_options['dashboard_incoming_links'] ) || !isset( $widget_options['dashboard_incoming_links']['home'] ) || $widget_options['dashboard_incoming_links']['home'] != get_option('home') ) {
- $update = true;
- $num_items = isset($widget_options['dashboard_incoming_links']['items']) ? $widget_options['dashboard_incoming_links']['items'] : 10;
- $widget_options['dashboard_incoming_links'] = array(
- 'home' => get_option('home'),
- 'link' => apply_filters( 'dashboard_incoming_links_link', 'http://blogsearch.google.com/blogsearch?scoring=d&partner=wordpress&q=link:' . trailingslashit( get_option('home') ) ),
- 'url' => isset($widget_options['dashboard_incoming_links']['url']) ? apply_filters( 'dashboard_incoming_links_feed', $widget_options['dashboard_incoming_links']['url'] ) : apply_filters( 'dashboard_incoming_links_feed', 'http://blogsearch.google.com/blogsearch_feeds?scoring=d&ie=utf-8&num=' . $num_items . '&output=rss&partner=wordpress&q=link:' . trailingslashit( get_option('home') ) ),
- 'items' => $num_items,
- 'show_date' => isset($widget_options['dashboard_incoming_links']['show_date']) ? $widget_options['dashboard_incoming_links']['show_date'] : false
- );
+ if ( $response && $response['upgrade'] ) {
+ add_filter( 'postbox_classes_dashboard_dashboard_browser_nag', 'dashboard_browser_nag_class' );
+ if ( $response['insecure'] )
+ wp_add_dashboard_widget( 'dashboard_browser_nag', __( 'You are using an insecure browser!' ), 'wp_dashboard_browser_nag' );
+ else
+ wp_add_dashboard_widget( 'dashboard_browser_nag', __( 'Your browser is out of date!' ), 'wp_dashboard_browser_nag' );
}
- wp_add_dashboard_widget( 'dashboard_incoming_links', __( 'Incoming Links' ), 'wp_dashboard_incoming_links', 'wp_dashboard_incoming_links_control' );
- // WP Plugins Widget
- if ( current_user_can( 'install_plugins' ) )
- wp_add_dashboard_widget( 'dashboard_plugins', __( 'Plugins' ), 'wp_dashboard_plugins' );
+ // Right Now
+ if ( is_blog_admin() && current_user_can('edit_posts') )
+ wp_add_dashboard_widget( 'dashboard_right_now', __( 'At a Glance' ), 'wp_dashboard_right_now' );
- // QuickPress Widget
- if ( current_user_can('edit_posts') )
- wp_add_dashboard_widget( 'dashboard_quick_press', __( 'QuickPress' ), 'wp_dashboard_quick_press' );
-
- // Recent Drafts
- if ( current_user_can('edit_posts') )
- wp_add_dashboard_widget( 'dashboard_recent_drafts', __('Recent Drafts'), 'wp_dashboard_recent_drafts' );
-
- // Primary feed (Dev Blog) Widget
- if ( !isset( $widget_options['dashboard_primary'] ) ) {
- $update = true;
- $widget_options['dashboard_primary'] = array(
- 'link' => apply_filters( 'dashboard_primary_link', __( 'http://wordpress.org/news/' ) ),
- 'url' => apply_filters( 'dashboard_primary_feed', __( 'http://wordpress.org/news/feed/' ) ),
- 'title' => apply_filters( 'dashboard_primary_title', __( 'WordPress Blog' ) ),
- 'items' => 2,
- 'show_summary' => 1,
- 'show_author' => 0,
- 'show_date' => 1,
- );
+ if ( is_network_admin() )
+ wp_add_dashboard_widget( 'network_dashboard_right_now', __( 'Right Now' ), 'wp_network_dashboard_right_now' );
+
+ // Activity Widget
+ if ( is_blog_admin() ) {
+ wp_add_dashboard_widget( 'dashboard_activity', __( 'Activity' ), 'wp_dashboard_site_activity' );
}
- wp_add_dashboard_widget( 'dashboard_primary', $widget_options['dashboard_primary']['title'], 'wp_dashboard_primary', 'wp_dashboard_primary_control' );
-
- // Secondary Feed (Planet) Widget
- if ( !isset( $widget_options['dashboard_secondary'] ) ) {
- $update = true;
- $widget_options['dashboard_secondary'] = array(
- 'link' => apply_filters( 'dashboard_secondary_link', __( 'http://planet.wordpress.org/' ) ),
- 'url' => apply_filters( 'dashboard_secondary_feed', __( 'http://planet.wordpress.org/feed/' ) ),
- 'title' => apply_filters( 'dashboard_secondary_title', __( 'Other WordPress News' ) ),
- 'items' => 5,
- 'show_summary' => 0,
- 'show_author' => 0,
- 'show_date' => 0,
- );
+
+ // QuickPress Widget
+ if ( is_blog_admin() && current_user_can( 'edit_posts' ) ) {
+ $quick_draft_title = sprintf( '%1$s %2$s', __( 'Quick Draft' ), __( 'Drafts' ) );
+ wp_add_dashboard_widget( 'dashboard_quick_press', $quick_draft_title, 'wp_dashboard_quick_press' );
}
- wp_add_dashboard_widget( 'dashboard_secondary', $widget_options['dashboard_secondary']['title'], 'wp_dashboard_secondary', 'wp_dashboard_secondary_control' );
- // Hook to register new widgets
- do_action( 'wp_dashboard_setup' );
+ // WordPress News
+ wp_add_dashboard_widget( 'dashboard_primary', __( 'WordPress News' ), 'wp_dashboard_primary' );
+
+ if ( is_network_admin() ) {
+
+ /**
+ * Fires after core widgets for the Network Admin dashboard have been registered.
+ *
+ * @since 3.1.0
+ */
+ do_action( 'wp_network_dashboard_setup' );
+
+ /**
+ * Filter the list of widgets to load for the Network Admin dashboard.
+ *
+ * @since 3.1.0
+ *
+ * @param array $dashboard_widgets An array of dashboard widgets.
+ */
+ $dashboard_widgets = apply_filters( 'wp_network_dashboard_widgets', array() );
+ } elseif ( is_user_admin() ) {
+
+ /**
+ * Fires after core widgets for the User Admin dashboard have been registered.
+ *
+ * @since 3.1.0
+ */
+ do_action( 'wp_user_dashboard_setup' );
+
+ /**
+ * Filter the list of widgets to load for the User Admin dashboard.
+ *
+ * @since 3.1.0
+ *
+ * @param array $dashboard_widgets An array of dashboard widgets.
+ */
+ $dashboard_widgets = apply_filters( 'wp_user_dashboard_widgets', array() );
+ } else {
- // Filter widget order
- $dashboard_widgets = apply_filters( 'wp_dashboard_widgets', array() );
+ /**
+ * Fires after core widgets for the admin dashboard have been registered.
+ *
+ * @since 2.5.0
+ */
+ do_action( 'wp_dashboard_setup' );
+
+ /**
+ * Filter the list of widgets to load for the admin dashboard.
+ *
+ * @since 2.5.0
+ *
+ * @param array $dashboard_widgets An array of dashboard widgets.
+ */
+ $dashboard_widgets = apply_filters( 'wp_dashboard_widgets', array() );
+ }
foreach ( $dashboard_widgets as $widget_id ) {
$name = empty( $wp_registered_widgets[$widget_id]['all_link'] ) ? $wp_registered_widgets[$widget_id]['name'] : $wp_registered_widgets[$widget_id]['name'] . " " . __('View all') . '';
@@ -105,6 +115,7 @@ function wp_dashboard_setup() {
}
if ( 'POST' == $_SERVER['REQUEST_METHOD'] && isset($_POST['widget_id']) ) {
+ check_admin_referer( 'edit-dashboard-widget_' . $_POST['widget_id'], 'dashboard-widget-nonce' );
ob_start(); // hack - but the same hack wp-admin/widgets.php uses
wp_dashboard_trigger_widget_control( $_POST['widget_id'] );
ob_end_clean();
@@ -115,478 +126,424 @@ function wp_dashboard_setup() {
if ( $update )
update_option( 'dashboard_widget_options', $widget_options );
- do_action('do_meta_boxes', 'dashboard', 'normal', '');
- do_action('do_meta_boxes', 'dashboard', 'side', '');
+ /** This action is documented in wp-admin/edit-form-advanced.php */
+ do_action( 'do_meta_boxes', $screen->id, 'normal', '' );
+
+ /** This action is documented in wp-admin/edit-form-advanced.php */
+ do_action( 'do_meta_boxes', $screen->id, 'side', '' );
}
-function wp_add_dashboard_widget( $widget_id, $widget_name, $callback, $control_callback = null ) {
+function wp_add_dashboard_widget( $widget_id, $widget_name, $callback, $control_callback = null, $callback_args = null ) {
+ $screen = get_current_screen();
global $wp_dashboard_control_callbacks;
+
if ( $control_callback && current_user_can( 'edit_dashboard' ) && is_callable( $control_callback ) ) {
$wp_dashboard_control_callbacks[$widget_id] = $control_callback;
if ( isset( $_GET['edit'] ) && $widget_id == $_GET['edit'] ) {
list($url) = explode( '#', add_query_arg( 'edit', false ), 2 );
$widget_name .= ' ' . __( 'Cancel' ) . '';
- add_meta_box( $widget_id, $widget_name, '_wp_dashboard_control_callback', 'dashboard', 'normal', 'core' );
- return;
+ $callback = '_wp_dashboard_control_callback';
+ } else {
+ list($url) = explode( '#', add_query_arg( 'edit', $widget_id ), 2 );
+ $widget_name .= ' ' . __( 'Configure' ) . '';
}
- list($url) = explode( '#', add_query_arg( 'edit', $widget_id ), 2 );
- $widget_name .= ' ' . __( 'Configure' ) . '';
}
- $side_widgets = array('dashboard_quick_press', 'dashboard_recent_drafts', 'dashboard_primary', 'dashboard_secondary');
+
+ $side_widgets = array( 'dashboard_quick_press', 'dashboard_primary' );
+
$location = 'normal';
if ( in_array($widget_id, $side_widgets) )
$location = 'side';
- add_meta_box( $widget_id, $widget_name , $callback, 'dashboard', $location, 'core' );
+
+ $priority = 'core';
+ if ( 'dashboard_browser_nag' === $widget_id )
+ $priority = 'high';
+
+ add_meta_box( $widget_id, $widget_name, $callback, $screen, $location, $priority, $callback_args );
}
function _wp_dashboard_control_callback( $dashboard, $meta_box ) {
echo '
';
}
/**
* Displays the dashboard.
*
- * @since unknown
+ * @since 2.5.0
*/
function wp_dashboard() {
- global $screen_layout_columns;
-
- $hide2 = $hide3 = $hide4 = '';
- switch ( $screen_layout_columns ) {
- case 4:
- $width = 'width:24.5%;';
- break;
- case 3:
- $width = 'width:32.67%;';
- $hide4 = 'display:none;';
- break;
- case 2:
- $width = 'width:49%;';
- $hide3 = $hide4 = 'display:none;';
- break;
- default:
- $width = 'width:98%;';
- $hide2 = $hide3 = $hide4 = 'display:none;';
+ $screen = get_current_screen();
+ $columns = absint( $screen->get_columns() );
+ $columns_css = '';
+ if ( $columns ) {
+ $columns_css = " columns-$columns";
}
-?>
-
-\n";
- do_meta_boxes( 'dashboard', 'normal', '' );
- echo "\t
\n";
- do_meta_boxes( 'dashboard', 'side', '' );
-
- echo "\t
\n";
- do_meta_boxes( 'dashboard', 'column3', '' );
-
- echo "\t
\n";
- do_meta_boxes( 'dashboard', 'column4', '' );
?>
-
+
-
-';
- echo "\n\t".'' . __('Content') . '
'."\n\t".'';
- echo "\n\t".'';
-
- // Posts
- $num = number_format_i18n( $num_posts->publish );
- $text = _n( 'Post', 'Posts', intval($num_posts->publish) );
- if ( current_user_can( 'edit_posts' ) ) {
- $num = "$num";
- $text = "$text";
- }
- echo '' . $num . ' | ';
- echo '' . $text . ' | ';
+ $theme = wp_get_theme();
+ if ( current_user_can( 'switch_themes' ) )
+ $theme_name = sprintf( '%1$s', $theme->display('Name') );
+ else
+ $theme_name = $theme->display('Name');
+?>
+
+
+ publish ) {
+ if ( 'post' == $post_type ) {
+ $text = _n( '%s Post', '%s Posts', $num_posts->publish );
+ } else {
+ $text = _n( '%s Page', '%s Pages', $num_posts->publish );
+ }
+ $text = sprintf( $text, number_format_i18n( $num_posts->publish ) );
+ $post_type_object = get_post_type_object( $post_type );
+ if ( $post_type_object && current_user_can( $post_type_object->cap->edit_posts ) ) {
+ printf( '- %2$s
', $post_type, $text );
+ } else {
+ printf( '- %2$s
', $post_type, $text );
+ }
- echo '
';
- /* TODO: Show status breakdown on hover
- if ( $can_edit_pages && !empty($num_pages->publish) ) { // how many pages is not exposed in feeds. Don't show if !current_user_can
- $post_type_texts[] = ''.sprintf( _n( '%s page', '%s pages', $num_pages->publish ), number_format_i18n( $num_pages->publish ) ).'';
- }
- if ( $can_edit_posts && !empty($num_posts->draft) ) {
- $post_type_texts[] = ''.sprintf( _n( '%s draft', '%s drafts', $num_posts->draft ), number_format_i18n( $num_posts->draft ) ).'';
- }
- if ( $can_edit_posts && !empty($num_posts->future) ) {
- $post_type_texts[] = ''.sprintf( _n( '%s scheduled post', '%s scheduled posts', $num_posts->future ), number_format_i18n( $num_posts->future ) ).'';
- }
- if ( current_user_can('publish_posts') && !empty($num_posts->pending) ) {
- $pending_text = sprintf( _n( 'There is %2$s post pending your review.', 'There are %2$s posts pending your review.', $num_posts->pending ), 'edit.php?post_status=pending', number_format_i18n( $num_posts->pending ) );
- } else {
- $pending_text = '';
+ }
}
- */
-
- // Pages
- $num = number_format_i18n( $num_pages->publish );
- $text = _n( 'Page', 'Pages', $num_pages->publish );
- if ( current_user_can( 'edit_pages' ) ) {
- $num = "$num";
- $text = "$text";
+ // Comments
+ $num_comm = wp_count_comments();
+ if ( $num_comm && $num_comm->total_comments ) {
+ $text = sprintf( _n( '%s Comment', '%s Comments', $num_comm->total_comments ), number_format_i18n( $num_comm->total_comments ) );
+ ?>
+
+ moderated ) {
+ /* translators: Number of comments in moderation */
+ $text = sprintf( _nx( '%s in moderation', '%s in moderation', $num_comm->moderated, 'comments' ), number_format_i18n( $num_comm->moderated ) );
+ ?>
+
+ ' . $num . '';
- echo '' . $text . ' | ';
- echo '
';
-
- // Categories
- $num = number_format_i18n( $num_cats );
- $text = _n( 'Category', 'Categories', $num_cats );
- if ( current_user_can( 'manage_categories' ) ) {
- $num = "$num";
- $text = "$text";
+ /**
+ * Filter the array of extra elements to list in the 'At a Glance'
+ * dashboard widget.
+ *
+ * Prior to 3.8.0, the widget was named 'Right Now'. Each element
+ * is wrapped in list-item tags on output.
+ *
+ * @since 3.8.0
+ *
+ * @param array $items Array of extra 'At a Glance' widget items.
+ */
+ $elements = apply_filters( 'dashboard_glance_items', array() );
+
+ if ( $elements ) {
+ echo '' . implode( "\n", $elements ) . "\n";
}
- echo '' . $num . ' | ';
- echo '' . $text . ' | ';
- echo '
';
+ ?>
+
+ $num";
- $text = "$text";
+ // Check if search engines are asked not to index this site.
+ if ( ! is_network_admin() && ! is_user_admin() && current_user_can( 'manage_options' ) && '1' != get_option( 'blog_public' ) ) {
+
+ /**
+ * Filter the link title attribute for the 'Search Engines Discouraged'
+ * message displayed in the 'At a Glance' dashboard widget.
+ *
+ * Prior to 3.8.0, the widget was named 'Right Now'.
+ *
+ * @since 3.0.0
+ *
+ * @param string $title Default attribute text.
+ */
+ $title = apply_filters( 'privacy_on_link_title', __( 'Your site is asking search engines not to index its content' ) );
+
+ /**
+ * Filter the link label for the 'Search Engines Discouraged' message
+ * displayed in the 'At a Glance' dashboard widget.
+ *
+ * Prior to 3.8.0, the widget was named 'Right Now'.
+ *
+ * @since 3.0.0
+ *
+ * @param string $content Default text.
+ */
+ $content = apply_filters( 'privacy_on_link_text' , __( 'Search Engines Discouraged' ) );
+
+ echo "$content
";
}
- echo '' . $num . ' | ';
- echo '' . $text . ' | ';
-
- echo "
";
- do_action('right_now_content_table_end');
- echo "\n\t
\n\t";
-
+ ?>
+
+ ';
- echo "\n\t".'' . __('Discussion') . '
'."\n\t".'';
- echo "\n\t".'';
+ /**
+ * Fires at the end of the 'At a Glance' dashboard widget.
+ *
+ * Prior to 3.8.0, the widget was named 'Right Now'.
+ *
+ * @since 2.0.0
+ */
+ do_action( 'activity_box_end' );
- // Total Comments
- $num = '' . number_format_i18n($num_comm->total_comments) . '';
- $text = _n( 'Comment', 'Comments', $num_comm->total_comments );
- if ( current_user_can( 'moderate_comments' ) ) {
- $num = '' . $num . '';
- $text = '' . $text . '';
- }
- echo '';
- echo '';
+ $actions = ob_get_clean();
- echo '
';
+ if ( !empty( $actions ) ) : ?>
+
+
+
+ ' . number_format_i18n($num_comm->approved) . '';
- $text = _nx( 'Approved', 'Approved', $num_comm->approved, 'Right Now' );
- if ( current_user_can( 'moderate_comments' ) ) {
- $num = "$num";
- $text = "$text";
- }
- echo '' . $num . ' | ';
- echo '' . $text . ' | ';
+function wp_network_dashboard_right_now() {
+ $actions = array();
+ if ( current_user_can('create_sites') )
+ $actions['create-site'] = '' . __( 'Create a New Site' ) . '';
+ if ( current_user_can('create_users') )
+ $actions['create-user'] = '' . __( 'Create a New User' ) . '';
- echo "
\n\t";
+ $c_users = get_user_count();
+ $c_blogs = get_blog_count();
- // Pending Comments
- $num = '' . number_format_i18n($num_comm->moderated) . '';
- $text = _n( 'Pending', 'Pending', $num_comm->moderated );
- if ( current_user_can( 'moderate_comments' ) ) {
- $num = "$num";
- $text = "$text";
- }
- echo '' . $num . ' | ';
- echo '' . $text . ' | ';
+ $user_text = sprintf( _n( '%s user', '%s users', $c_users ), number_format_i18n( $c_users ) );
+ $blog_text = sprintf( _n( '%s site', '%s sites', $c_blogs ), number_format_i18n( $c_blogs ) );
- echo "
\n\t";
+ $sentence = sprintf( __( 'You have %1$s and %2$s.' ), $blog_text, $user_text );
- // Spam Comments
- $num = number_format_i18n($num_comm->spam);
- $text = _nx( 'Spam', 'Spam', $num_comm->spam, 'comment' );
- if ( current_user_can( 'moderate_comments' ) ) {
- $num = "$num";
- $text = "$text";
- }
- echo '' . $num . ' | ';
- echo '' . $text . ' | ';
-
- echo "
";
- do_action('right_now_table_end');
- do_action('right_now_discussion_table_end');
- echo "\n\t
\n\t";
-
- echo "\n\t".'';
- $ct = current_theme_info();
-
- echo "\n\t
";
- if ( !empty($wp_registered_sidebars) ) {
- $sidebars_widgets = wp_get_sidebars_widgets();
- $num_widgets = 0;
- foreach ( (array) $sidebars_widgets as $k => $v ) {
- if ( 'wp_inactive_widgets' == $k )
- continue;
- if ( is_array($v) )
- $num_widgets = $num_widgets + count($v);
- }
- $num = number_format_i18n( $num_widgets );
-
- $switch_themes = $ct->title;
- if ( current_user_can( 'switch_themes') ) {
- echo '' . __('Change Theme') . '';
- $switch_themes = '' . $switch_themes . '';
- }
- if ( current_user_can( 'edit_theme_options' ) ) {
- printf(_n('Theme %1$s with %2$s Widget', 'Theme %1$s with %2$s Widgets', $num_widgets), $switch_themes, $num);
- } else {
- printf(_n('Theme %1$s with %2$s Widget', 'Theme %1$s with %2$s Widgets', $num_widgets), $switch_themes, $num);
- }
- } else {
- if ( current_user_can( 'switch_themes' ) ) {
- echo '' . __('Change Theme') . '';
- printf( __('Theme %1$s'), $ct->title );
- } else {
- printf( __('Theme %1$s'), $ct->title );
+ if ( $actions ) {
+ echo '
';
+ foreach ( $actions as $class => $action ) {
+ $actions[ $class ] = "\t- $action";
}
+ echo implode( " |
\n", $actions ) . "\n";
+ echo '
';
}
- echo '';
-
- update_right_now_message();
+?>
+
+
+
+
+
+
+
+
- echo "\n\t".'
';
- do_action( 'rightnow_end' );
- do_action( 'activity_box_end' );
+
+' . __( 'Post published. View post | Edit post' ) . '
', esc_url( $view ), $edit );
- else
- printf( '', esc_url( add_query_arg( 'preview', 1, $view ) ), $edit );
- } else {
- printf( '', esc_url( add_query_arg( 'preview', 1, $view ) ), $edit );
- $drafts_query = new WP_Query( array(
- 'post_type' => 'post',
- 'post_status' => 'draft',
- 'author' => $GLOBALS['current_user']->ID,
- 'posts_per_page' => 1,
- 'orderby' => 'modified',
- 'order' => 'DESC'
- ) );
-
- if ( $drafts_query->posts )
- $drafts =& $drafts_query->posts;
- }
- printf('' . __('You can also try %s, easy blogging from anywhere on the Web.') . '
', '' . __('Press This') . '' );
- $_REQUEST = array(); // hack for get_default_post_to_edit()
- }
-
/* Check if a new auto-draft (= no new post_ID) is needed or if the old can be used */
$last_post_id = (int) get_user_option( 'dashboard_quick_press_last_post_id' ); // Get the last post_ID
if ( $last_post_id ) {
$post = get_post( $last_post_id );
if ( empty( $post ) || $post->post_status != 'auto-draft' ) { // auto-draft doesn't exists anymore
- $post = get_default_post_to_edit('post', true);
- update_user_option( (int) $GLOBALS['current_user']->ID, 'dashboard_quick_press_last_post_id', (int) $post->ID ); // Save post_ID
+ $post = get_default_post_to_edit( 'post', true );
+ update_user_option( get_current_user_id(), 'dashboard_quick_press_last_post_id', (int) $post->ID ); // Save post_ID
} else {
$post->post_title = ''; // Remove the auto draft title
}
} else {
- $post = get_default_post_to_edit('post', true);
- update_user_option( (int) $GLOBALS['current_user']->ID, 'dashboard_quick_press_last_post_id', (int) $post->ID ); // Save post_ID
+ $post = get_default_post_to_edit( 'post' , true);
+ $user_id = get_current_user_id();
+ // Don't create an option if this is a super admin who does not belong to this site.
+ if ( ! ( is_super_admin( $user_id ) && ! in_array( get_current_blog_id(), array_keys( get_blogs_of_user( $user_id ) ) ) ) )
+ update_user_option( $user_id, 'dashboard_quick_press_last_post_id', (int) $post->ID ); // Save post_ID
}
$post_ID = (int) $post->ID;
?>
-