123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181 |
- <?php
- /**
- * Upgrader API: Bulk_Upgrader_Skin class
- *
- * @package WordPress
- * @subpackage Upgrader
- * @since 4.6.0
- */
- /**
- * Generic Bulk Upgrader Skin for WordPress Upgrades.
- *
- * @since 3.0.0
- * @since 4.6.0 Moved to its own file from wp-admin/includes/class-wp-upgrader-skins.php.
- *
- * @see WP_Upgrader_Skin
- */
- class Bulk_Upgrader_Skin extends WP_Upgrader_Skin {
- public $in_loop = false;
- /**
- * @var string|false
- */
- public $error = false;
- /**
- * @param array $args
- */
- public function __construct( $args = array() ) {
- $defaults = array(
- 'url' => '',
- 'nonce' => '',
- );
- $args = wp_parse_args( $args, $defaults );
- parent::__construct( $args );
- }
- /**
- */
- public function add_strings() {
- $this->upgrader->strings['skin_upgrade_start'] = __( 'The update process is starting. This process may take a while on some hosts, so please be patient.' );
- /* translators: 1: Title of an update, 2: Error message. */
- $this->upgrader->strings['skin_update_failed_error'] = __( 'An error occurred while updating %1$s: %2$s' );
- /* translators: %s: Title of an update. */
- $this->upgrader->strings['skin_update_failed'] = __( 'The update of %s failed.' );
- /* translators: %s: Title of an update. */
- $this->upgrader->strings['skin_update_successful'] = __( '%s updated successfully.' );
- $this->upgrader->strings['skin_upgrade_end'] = __( 'All updates have been completed.' );
- }
- /**
- * @since 5.9.0 Renamed `$string` (a PHP reserved keyword) to `$feedback` for PHP 8 named parameter support.
- *
- * @param string $feedback Message data.
- * @param mixed ...$args Optional text replacements.
- */
- public function feedback( $feedback, ...$args ) {
- if ( isset( $this->upgrader->strings[ $feedback ] ) ) {
- $feedback = $this->upgrader->strings[ $feedback ];
- }
- if ( strpos( $feedback, '%' ) !== false ) {
- if ( $args ) {
- $args = array_map( 'strip_tags', $args );
- $args = array_map( 'esc_html', $args );
- $feedback = vsprintf( $feedback, $args );
- }
- }
- if ( empty( $feedback ) ) {
- return;
- }
- if ( $this->in_loop ) {
- echo "$feedback<br />\n";
- } else {
- echo "<p>$feedback</p>\n";
- }
- }
- /**
- */
- public function header() {
- // Nothing, This will be displayed within a iframe.
- }
- /**
- */
- public function footer() {
- // Nothing, This will be displayed within a iframe.
- }
- /**
- * @since 5.9.0 Renamed `$error` to `$errors` for PHP 8 named parameter support.
- *
- * @param string|WP_Error $errors Errors.
- */
- public function error( $errors ) {
- if ( is_string( $errors ) && isset( $this->upgrader->strings[ $errors ] ) ) {
- $this->error = $this->upgrader->strings[ $errors ];
- }
- if ( is_wp_error( $errors ) ) {
- $messages = array();
- foreach ( $errors->get_error_messages() as $emessage ) {
- if ( $errors->get_error_data() && is_string( $errors->get_error_data() ) ) {
- $messages[] = $emessage . ' ' . esc_html( strip_tags( $errors->get_error_data() ) );
- } else {
- $messages[] = $emessage;
- }
- }
- $this->error = implode( ', ', $messages );
- }
- echo '<script type="text/javascript">jQuery(\'.waiting-' . esc_js( $this->upgrader->update_current ) . '\').hide();</script>';
- }
- /**
- */
- public function bulk_header() {
- $this->feedback( 'skin_upgrade_start' );
- }
- /**
- */
- public function bulk_footer() {
- $this->feedback( 'skin_upgrade_end' );
- }
- /**
- * @param string $title
- */
- public function before( $title = '' ) {
- $this->in_loop = true;
- printf( '<h2>' . $this->upgrader->strings['skin_before_update_header'] . ' <span class="spinner waiting-' . $this->upgrader->update_current . '"></span></h2>', $title, $this->upgrader->update_current, $this->upgrader->update_count );
- echo '<script type="text/javascript">jQuery(\'.waiting-' . esc_js( $this->upgrader->update_current ) . '\').css("display", "inline-block");</script>';
- // This progress messages div gets moved via JavaScript when clicking on "Show details.".
- echo '<div class="update-messages hide-if-js" id="progress-' . esc_attr( $this->upgrader->update_current ) . '"><p>';
- $this->flush_output();
- }
- /**
- * @param string $title
- */
- public function after( $title = '' ) {
- echo '</p></div>';
- if ( $this->error || ! $this->result ) {
- if ( $this->error ) {
- echo '<div class="error"><p>' . sprintf( $this->upgrader->strings['skin_update_failed_error'], $title, '<strong>' . $this->error . '</strong>' ) . '</p></div>';
- } else {
- echo '<div class="error"><p>' . sprintf( $this->upgrader->strings['skin_update_failed'], $title ) . '</p></div>';
- }
- echo '<script type="text/javascript">jQuery(\'#progress-' . esc_js( $this->upgrader->update_current ) . '\').show();</script>';
- }
- if ( $this->result && ! is_wp_error( $this->result ) ) {
- if ( ! $this->error ) {
- echo '<div class="updated js-update-details" data-update-details="progress-' . esc_attr( $this->upgrader->update_current ) . '">' .
- '<p>' . sprintf( $this->upgrader->strings['skin_update_successful'], $title ) .
- ' <button type="button" class="hide-if-no-js button-link js-update-details-toggle" aria-expanded="false">' . __( 'Show details.' ) . '</button>' .
- '</p></div>';
- }
- echo '<script type="text/javascript">jQuery(\'.waiting-' . esc_js( $this->upgrader->update_current ) . '\').hide();</script>';
- }
- $this->reset();
- $this->flush_output();
- }
- /**
- */
- public function reset() {
- $this->in_loop = false;
- $this->error = false;
- }
- /**
- */
- public function flush_output() {
- wp_ob_end_flush_all();
- flush();
- }
- }
|