~canonical-sysadmins/wordpress/4.8.1

« back to all changes in this revision

Viewing changes to wp-admin/includes/class-plugin-upgrader-skin.php

  • Committer: Barry Price
  • Date: 2016-08-17 04:49:28 UTC
  • mto: This revision was merged to the branch mainline in revision 22.
  • Revision ID: barry.price@canonical.com-20160817044928-viijiwb4tl8jwzmp
new upstream release 4.6

Show diffs side-by-side

added added

removed removed

Lines of Context:
 
1
<?php
 
2
/**
 
3
 * Upgrader API: Plugin_Upgrader_Skin class
 
4
 *
 
5
 * @package WordPress
 
6
 * @subpackage Upgrader
 
7
 * @since 4.6.0
 
8
 */
 
9
 
 
10
/**
 
11
 * Plugin Upgrader Skin for WordPress Plugin Upgrades.
 
12
 *
 
13
 * @since 2.8.0
 
14
 * @since 4.6.0 Moved to its own file from wp-admin/includes/class-wp-upgrader-skins.php.
 
15
 *
 
16
 * @see WP_Upgrader_Skin
 
17
 */
 
18
class Plugin_Upgrader_Skin extends WP_Upgrader_Skin {
 
19
        public $plugin = '';
 
20
        public $plugin_active = false;
 
21
        public $plugin_network_active = false;
 
22
 
 
23
        /**
 
24
         *
 
25
         * @param array $args
 
26
         */
 
27
        public function __construct( $args = array() ) {
 
28
                $defaults = array( 'url' => '', 'plugin' => '', 'nonce' => '', 'title' => __('Update Plugin') );
 
29
                $args = wp_parse_args($args, $defaults);
 
30
 
 
31
                $this->plugin = $args['plugin'];
 
32
 
 
33
                $this->plugin_active = is_plugin_active( $this->plugin );
 
34
                $this->plugin_network_active = is_plugin_active_for_network( $this->plugin );
 
35
 
 
36
                parent::__construct($args);
 
37
        }
 
38
 
 
39
        /**
 
40
         * @access public
 
41
         */
 
42
        public function after() {
 
43
                $this->plugin = $this->upgrader->plugin_info();
 
44
                if ( !empty($this->plugin) && !is_wp_error($this->result) && $this->plugin_active ){
 
45
                        // Currently used only when JS is off for a single plugin update?
 
46
                        echo '<iframe title="' . esc_attr__( 'Update progress' ) . '" style="border:0;overflow:hidden" width="100%" height="170" src="' . wp_nonce_url( 'update.php?action=activate-plugin&networkwide=' . $this->plugin_network_active . '&plugin=' . urlencode( $this->plugin ), 'activate-plugin_' . $this->plugin ) . '"></iframe>';
 
47
                }
 
48
 
 
49
                $this->decrement_update_count( 'plugin' );
 
50
 
 
51
                $update_actions =  array(
 
52
                        'activate_plugin' => '<a href="' . wp_nonce_url( 'plugins.php?action=activate&amp;plugin=' . urlencode( $this->plugin ), 'activate-plugin_' . $this->plugin) . '" target="_parent">' . __( 'Activate Plugin' ) . '</a>',
 
53
                        'plugins_page' => '<a href="' . self_admin_url( 'plugins.php' ) . '" target="_parent">' . __( 'Return to Plugins page' ) . '</a>'
 
54
                );
 
55
                if ( $this->plugin_active || ! $this->result || is_wp_error( $this->result ) || ! current_user_can( 'activate_plugins' ) )
 
56
                        unset( $update_actions['activate_plugin'] );
 
57
 
 
58
                /**
 
59
                 * Filters the list of action links available following a single plugin update.
 
60
                 *
 
61
                 * @since 2.7.0
 
62
                 *
 
63
                 * @param array  $update_actions Array of plugin action links.
 
64
                 * @param string $plugin         Path to the plugin file.
 
65
                 */
 
66
                $update_actions = apply_filters( 'update_plugin_complete_actions', $update_actions, $this->plugin );
 
67
 
 
68
                if ( ! empty($update_actions) )
 
69
                        $this->feedback(implode(' | ', (array)$update_actions));
 
70
        }
 
71
}