Update WP and plugins
This commit is contained in:
parent
10a4713229
commit
1fb77fc4ff
864 changed files with 101724 additions and 78262 deletions
|
@ -18,7 +18,7 @@
|
|||
class WP_Themes_List_Table extends WP_List_Table {
|
||||
|
||||
protected $search_terms = array();
|
||||
public $features = array();
|
||||
public $features = array();
|
||||
|
||||
/**
|
||||
* Constructor.
|
||||
|
@ -30,14 +30,15 @@ class WP_Themes_List_Table extends WP_List_Table {
|
|||
* @param array $args An associative array of arguments.
|
||||
*/
|
||||
public function __construct( $args = array() ) {
|
||||
parent::__construct( array(
|
||||
'ajax' => true,
|
||||
'screen' => isset( $args['screen'] ) ? $args['screen'] : null,
|
||||
) );
|
||||
parent::__construct(
|
||||
array(
|
||||
'ajax' => true,
|
||||
'screen' => isset( $args['screen'] ) ? $args['screen'] : null,
|
||||
)
|
||||
);
|
||||
}
|
||||
|
||||
/**
|
||||
*
|
||||
* @return bool
|
||||
*/
|
||||
public function ajax_user_can() {
|
||||
|
@ -50,16 +51,19 @@ class WP_Themes_List_Table extends WP_List_Table {
|
|||
public function prepare_items() {
|
||||
$themes = wp_get_themes( array( 'allowed' => true ) );
|
||||
|
||||
if ( ! empty( $_REQUEST['s'] ) )
|
||||
if ( ! empty( $_REQUEST['s'] ) ) {
|
||||
$this->search_terms = array_unique( array_filter( array_map( 'trim', explode( ',', strtolower( wp_unslash( $_REQUEST['s'] ) ) ) ) ) );
|
||||
}
|
||||
|
||||
if ( ! empty( $_REQUEST['features'] ) )
|
||||
if ( ! empty( $_REQUEST['features'] ) ) {
|
||||
$this->features = $_REQUEST['features'];
|
||||
}
|
||||
|
||||
if ( $this->search_terms || $this->features ) {
|
||||
foreach ( $themes as $key => $theme ) {
|
||||
if ( ! $this->search_theme( $theme ) )
|
||||
if ( ! $this->search_theme( $theme ) ) {
|
||||
unset( $themes[ $key ] );
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
|
@ -67,17 +71,19 @@ class WP_Themes_List_Table extends WP_List_Table {
|
|||
WP_Theme::sort_by_name( $themes );
|
||||
|
||||
$per_page = 36;
|
||||
$page = $this->get_pagenum();
|
||||
$page = $this->get_pagenum();
|
||||
|
||||
$start = ( $page - 1 ) * $per_page;
|
||||
|
||||
$this->items = array_slice( $themes, $start, $per_page, true );
|
||||
|
||||
$this->set_pagination_args( array(
|
||||
'total_items' => count( $themes ),
|
||||
'per_page' => $per_page,
|
||||
'infinite_scroll' => true,
|
||||
) );
|
||||
$this->set_pagination_args(
|
||||
array(
|
||||
'total_items' => count( $themes ),
|
||||
'per_page' => $per_page,
|
||||
'infinite_scroll' => true,
|
||||
)
|
||||
);
|
||||
}
|
||||
|
||||
/**
|
||||
|
@ -115,8 +121,9 @@ class WP_Themes_List_Table extends WP_List_Table {
|
|||
* @param string $which
|
||||
*/
|
||||
public function tablenav( $which = 'top' ) {
|
||||
if ( $this->get_pagination_arg( 'total_pages' ) <= 1 )
|
||||
if ( $this->get_pagination_arg( 'total_pages' ) <= 1 ) {
|
||||
return;
|
||||
}
|
||||
?>
|
||||
<div class="tablenav themes <?php echo $which; ?>">
|
||||
<?php $this->pagination( $which ); ?>
|
||||
|
@ -129,8 +136,8 @@ class WP_Themes_List_Table extends WP_List_Table {
|
|||
/**
|
||||
*/
|
||||
public function display() {
|
||||
wp_nonce_field( "fetch-list-" . get_class( $this ), '_ajax_fetch_list_nonce' );
|
||||
?>
|
||||
wp_nonce_field( 'fetch-list-' . get_class( $this ), '_ajax_fetch_list_nonce' );
|
||||
?>
|
||||
<?php $this->tablenav( 'top' ); ?>
|
||||
|
||||
<div id="availablethemes">
|
||||
|
@ -138,11 +145,10 @@ class WP_Themes_List_Table extends WP_List_Table {
|
|||
</div>
|
||||
|
||||
<?php $this->tablenav( 'bottom' ); ?>
|
||||
<?php
|
||||
<?php
|
||||
}
|
||||
|
||||
/**
|
||||
*
|
||||
* @return array
|
||||
*/
|
||||
public function get_columns() {
|
||||
|
@ -166,18 +172,20 @@ class WP_Themes_List_Table extends WP_List_Table {
|
|||
public function display_rows() {
|
||||
$themes = $this->items;
|
||||
|
||||
foreach ( $themes as $theme ):
|
||||
?><div class="available-theme"><?php
|
||||
foreach ( $themes as $theme ) :
|
||||
?>
|
||||
<div class="available-theme">
|
||||
<?php
|
||||
|
||||
$template = $theme->get_template();
|
||||
$stylesheet = $theme->get_stylesheet();
|
||||
$title = $theme->display('Name');
|
||||
$version = $theme->display('Version');
|
||||
$author = $theme->display('Author');
|
||||
$title = $theme->display( 'Name' );
|
||||
$version = $theme->display( 'Version' );
|
||||
$author = $theme->display( 'Author' );
|
||||
|
||||
$activate_link = wp_nonce_url( "themes.php?action=activate&template=" . urlencode( $template ) . "&stylesheet=" . urlencode( $stylesheet ), 'switch-theme_' . $stylesheet );
|
||||
$activate_link = wp_nonce_url( 'themes.php?action=activate&template=' . urlencode( $template ) . '&stylesheet=' . urlencode( $stylesheet ), 'switch-theme_' . $stylesheet );
|
||||
|
||||
$actions = array();
|
||||
$actions = array();
|
||||
$actions['activate'] = '<a href="' . $activate_link . '" class="activatelink" title="'
|
||||
. esc_attr( sprintf( __( 'Activate “%s”' ), $title ) ) . '">' . __( 'Activate' ) . '</a>';
|
||||
|
||||
|
@ -186,13 +194,14 @@ class WP_Themes_List_Table extends WP_List_Table {
|
|||
. __( 'Live Preview' ) . '</a>';
|
||||
}
|
||||
|
||||
if ( ! is_multisite() && current_user_can( 'delete_themes' ) )
|
||||
if ( ! is_multisite() && current_user_can( 'delete_themes' ) ) {
|
||||
$actions['delete'] = '<a class="submitdelete deletion" href="' . wp_nonce_url( 'themes.php?action=delete&stylesheet=' . urlencode( $stylesheet ), 'delete-theme_' . $stylesheet )
|
||||
. '" onclick="' . "return confirm( '" . esc_js( sprintf( __( "You are about to delete this theme '%s'\n 'Cancel' to stop, 'OK' to delete." ), $title ) )
|
||||
. "' );" . '">' . __( 'Delete' ) . '</a>';
|
||||
}
|
||||
|
||||
/** This filter is documented in wp-admin/includes/class-wp-ms-themes-list-table.php */
|
||||
$actions = apply_filters( 'theme_action_links', $actions, $theme, 'all' );
|
||||
$actions = apply_filters( 'theme_action_links', $actions, $theme, 'all' );
|
||||
|
||||
/** This filter is documented in wp-admin/includes/class-wp-ms-themes-list-table.php */
|
||||
$actions = apply_filters( "theme_action_links_$stylesheet", $actions, $theme, 'all' );
|
||||
|
@ -216,10 +225,10 @@ class WP_Themes_List_Table extends WP_List_Table {
|
|||
<div class="theme-author"><?php printf( __( 'By %s' ), $author ); ?></div>
|
||||
<div class="action-links">
|
||||
<ul>
|
||||
<?php foreach ( $actions as $action ): ?>
|
||||
<?php foreach ( $actions as $action ) : ?>
|
||||
<li><?php echo $action; ?></li>
|
||||
<?php endforeach; ?>
|
||||
<li class="hide-if-no-js"><a href="#" class="theme-detail"><?php _e('Details') ?></a></li>
|
||||
<li class="hide-if-no-js"><a href="#" class="theme-detail"><?php _e( 'Details' ); ?></a></li>
|
||||
</ul>
|
||||
<?php echo $delete_action; ?>
|
||||
|
||||
|
@ -227,17 +236,21 @@ class WP_Themes_List_Table extends WP_List_Table {
|
|||
</div>
|
||||
|
||||
<div class="themedetaildiv hide-if-js">
|
||||
<p><strong><?php _e('Version:'); ?></strong> <?php echo $version; ?></p>
|
||||
<p><?php echo $theme->display('Description'); ?></p>
|
||||
<?php if ( $theme->parent() ) {
|
||||
printf( ' <p class="howto">' . __( 'This <a href="%1$s">child theme</a> requires its parent theme, %2$s.' ) . '</p>',
|
||||
<p><strong><?php _e( 'Version:' ); ?></strong> <?php echo $version; ?></p>
|
||||
<p><?php echo $theme->display( 'Description' ); ?></p>
|
||||
<?php
|
||||
if ( $theme->parent() ) {
|
||||
printf(
|
||||
' <p class="howto">' . __( 'This <a href="%1$s">child theme</a> requires its parent theme, %2$s.' ) . '</p>',
|
||||
__( 'https://codex.wordpress.org/Child_Themes' ),
|
||||
$theme->parent()->display( 'Name' ) );
|
||||
} ?>
|
||||
$theme->parent()->display( 'Name' )
|
||||
);
|
||||
}
|
||||
?>
|
||||
</div>
|
||||
|
||||
</div>
|
||||
<?php
|
||||
<?php
|
||||
endforeach;
|
||||
}
|
||||
|
||||
|
@ -248,14 +261,16 @@ class WP_Themes_List_Table extends WP_List_Table {
|
|||
public function search_theme( $theme ) {
|
||||
// Search the features
|
||||
foreach ( $this->features as $word ) {
|
||||
if ( ! in_array( $word, $theme->get('Tags') ) )
|
||||
if ( ! in_array( $word, $theme->get( 'Tags' ) ) ) {
|
||||
return false;
|
||||
}
|
||||
}
|
||||
|
||||
// Match all phrases
|
||||
foreach ( $this->search_terms as $word ) {
|
||||
if ( in_array( $word, $theme->get('Tags') ) )
|
||||
if ( in_array( $word, $theme->get( 'Tags' ) ) ) {
|
||||
continue;
|
||||
}
|
||||
|
||||
foreach ( array( 'Name', 'Description', 'Author', 'AuthorURI' ) as $header ) {
|
||||
// Don't mark up; Do translate.
|
||||
|
@ -264,11 +279,13 @@ class WP_Themes_List_Table extends WP_List_Table {
|
|||
}
|
||||
}
|
||||
|
||||
if ( false !== stripos( $theme->get_stylesheet(), $word ) )
|
||||
if ( false !== stripos( $theme->get_stylesheet(), $word ) ) {
|
||||
continue;
|
||||
}
|
||||
|
||||
if ( false !== stripos( $theme->get_template(), $word ) )
|
||||
if ( false !== stripos( $theme->get_template(), $word ) ) {
|
||||
continue;
|
||||
}
|
||||
|
||||
return false;
|
||||
}
|
||||
|
@ -287,14 +304,15 @@ class WP_Themes_List_Table extends WP_List_Table {
|
|||
$search_string = isset( $_REQUEST['s'] ) ? esc_attr( wp_unslash( $_REQUEST['s'] ) ) : '';
|
||||
|
||||
$args = array(
|
||||
'search' => $search_string,
|
||||
'features' => $this->features,
|
||||
'paged' => $this->get_pagenum(),
|
||||
'search' => $search_string,
|
||||
'features' => $this->features,
|
||||
'paged' => $this->get_pagenum(),
|
||||
'total_pages' => ! empty( $this->_pagination_args['total_pages'] ) ? $this->_pagination_args['total_pages'] : 1,
|
||||
);
|
||||
|
||||
if ( is_array( $extra_args ) )
|
||||
if ( is_array( $extra_args ) ) {
|
||||
$args = array_merge( $args, $extra_args );
|
||||
}
|
||||
|
||||
printf( "<script type='text/javascript'>var theme_list_args = %s;</script>\n", wp_json_encode( $args ) );
|
||||
parent::_js_vars();
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue