WordPress.org

Make WordPress Core

Ticket #35191: 35191.4.patch

File 35191.4.patch, 8.5 KB (added by afercia, 2 years ago)
  • src/wp-admin/css/common.css

     
    22762276
    22772277.importers td {
    22782278        padding-right: 14px;
     2279        line-height: 1.5em;
    22792280}
    22802281
    22812282.importers {
     
    22832284        width: auto;
    22842285}
    22852286
     2287.importer-title,
     2288.importer-desc,
     2289.importer-status,
     2290.importer-action {
     2291        display: block;
     2292}
     2293
     2294.importer-action {
     2295        margin-bottom: 1em;
     2296        color: #ddd;
     2297}
     2298
    22862299#post-body #post-body-content #namediv h3, /* Back-compat for pre-4.4 */
    22872300#post-body #post-body-content #namediv h2 {
    22882301        margin-top: 0;
  • src/wp-admin/import.php

     
    2929        '<p>' . __('<a href="https://wordpress.org/support/" target="_blank">Support Forums</a>') . '</p>'
    3030);
    3131
    32 if ( current_user_can( 'install_plugins' ) )
     32if ( current_user_can( 'install_plugins' ) ) {
     33        // List of popular importer plugins from the WordPress.org API.
    3334        $popular_importers = wp_get_popular_importers();
    34 else
    35         $popular_importers = array();
     35} else {
     36        $popular_importers = array();
     37}
    3638
    3739// Detect and redirect invalid importers like 'movabletype', which is registered as 'mt'
    3840if ( ! empty( $_GET['invalid'] ) && isset( $popular_importers[ $_GET['invalid'] ] ) ) {
     
    6567<p><?php _e('If you have posts or comments in another system, WordPress can import those into this site. To get started, choose a system to import from below:'); ?></p>
    6668
    6769<?php
    68 
     70// Registered (already installed) importers. They're stored in the global $wp_importers.
    6971$importers = get_importers();
    7072
    7173// If a popular importer is not registered, create a dummy registration that links to the plugin installer.
     
    7476                continue;
    7577        if ( isset( $importers[ $pop_data['importer-id'] ] ) )
    7678                continue;
     79
     80        // Merge the importers from the WordPress.org API in the array of registered (already installed) importers.
    7781        $importers[ $pop_data['importer-id'] ] = array( $pop_data['name'], $pop_data['description'], 'install' => $pop_data['plugin-slug'] );
    7882}
    7983
     
    8690
    8791<?php
    8892        foreach ($importers as $importer_id => $data) {
    89                 $action = '';
     93                $action = $status = $status_class = '';
     94
    9095                if ( isset( $data['install'] ) ) {
    9196                        $plugin_slug = $data['install'];
    9297                        if ( file_exists( WP_PLUGIN_DIR . '/' . $plugin_slug ) ) {
    93                                 // Looks like Importer is installed, But not active
     98                                // Looks like an importer is installed, but not active.
    9499                                $plugins = get_plugins( '/' . $plugin_slug );
    95100                                if ( !empty($plugins) ) {
    96101                                        $keys = array_keys($plugins);
    97102                                        $plugin_file = $plugin_slug . '/' . $keys[0];
    98                                         $action = '<a href="' . esc_url(wp_nonce_url(admin_url('plugins.php?action=activate&plugin=' . $plugin_file . '&from=import'), 'activate-plugin_' . $plugin_file)) .
    99                                                                                         '"title="' . esc_attr__('Activate importer') . '"">' . $data[0] . '</a>';
     103                                        $status = _x( 'Installed and not activated', 'importer plugin' );
     104                                        $status_class = ' importer-inactive';
     105                                        $action = '<a href="' . esc_url( wp_nonce_url( admin_url( 'plugins.php?action=activate&plugin=' . $plugin_file .
     106                                                '&from=import' ), 'activate-plugin_' . $plugin_file ) ) . '">' . __( 'Activate and run' ) . '</a>';
    100107                                }
    101108                        }
    102109                        if ( empty($action) ) {
    103110                                if ( is_main_site() ) {
    104                                         $action = '<a href="' . esc_url( network_admin_url( 'plugin-install.php?tab=plugin-information&plugin=' . $plugin_slug .
    105                                                                                 '&from=import&TB_iframe=true&width=600&height=550' ) ) . '" class="thickbox open-plugin-details-modal" title="' .
    106                                                                                 esc_attr__('Install importer') . '">' . $data[0] . '</a>';
     111                                        $url = esc_url( wp_nonce_url( add_query_arg( 'from', 'import', self_admin_url( 'update.php?action=install-plugin&plugin=' . $plugin_slug ) ), 'install-plugin_' . $plugin_slug ) );
     112                                        $action = '<a class="" href="' . $url . '">' . __( 'Install' ) . '</a>';
    107113                                } else {
    108                                         $action = $data[0];
    109                                         $data[1] = sprintf( __( 'This importer is not installed. Please install importers from <a href="%s">the main site</a>.' ), get_admin_url( $current_site->blog_id, 'import.php' ) );
     114                                        $action = sprintf( __( 'This importer is not installed. Please install importers from <a href="%s">the main site</a>.' ),
     115                                                get_admin_url( $current_site->blog_id, 'import.php' )
     116                                        );
    110117                                }
     118                                $status = _x( 'Not installed', 'importer plugin' );
    111119                        }
    112120                } else {
    113                         $action = "<a href='" . esc_url( "admin.php?import=$importer_id" ) . "' title='" . esc_attr( wptexturize( strip_tags( $data[1] ) ) ) ."'>{$data[0]}</a>";
     121                        $action = '<a href="' . esc_url( 'admin.php?import=$importer_id' ) . '">' . __( 'Run the importer' ) . '</a>';
     122                        $status = _x( 'Installed and activated', 'importer plugin' );
     123                        $status_class = ' importer-active';
    114124                }
    115125
     126                $action .= ' | <a href="' . esc_url( network_admin_url( 'plugin-install.php?tab=plugin-information&plugin=' . $plugin_slug .
     127                        '&from=import&TB_iframe=true&width=600&height=550' ) ) . '" class="thickbox">' . __( 'Details' ) . '</a>';
     128
    116129                echo "
    117                         <tr>
    118                                 <td class='import-system row-title'>$action</td>
    119                                 <td class='desc'>{$data[1]}</td>
     130                        <tr class='importer-item{$status_class}'>
     131                                <td class='import-system'>
     132                                        <span class='importer-title row-title'>{$data[0]}</span>
     133                                        <span class='importer-action'>{$action}</span>
     134                                </td>
     135                                <td class='desc'>
     136                                        <span class='importer-status'>{$status}</span>
     137                                        <span class='importer-desc'>{$data[1]}</span>
     138                                </td>
    120139                        </tr>";
    121140        }
    122141?>
  • src/wp-admin/includes/import.php

     
    157157                // slug => name, description, plugin slug, and register_importer() slug
    158158                'blogger' => array(
    159159                        'name' => __( 'Blogger' ),
    160                         'description' => __( 'Install the Blogger importer to import posts, comments, and users from a Blogger blog.' ),
     160                        'description' => __( 'Import posts, comments, and users from a Blogger blog.' ),
    161161                        'plugin-slug' => 'blogger-importer',
    162162                        'importer-id' => 'blogger',
    163163                ),
    164164                'wpcat2tag' => array(
    165165                        'name' => __( 'Categories and Tags Converter' ),
    166                         'description' => __( 'Install the category/tag converter to convert existing categories to tags or tags to categories, selectively.' ),
     166                        'description' => __( 'Convert existing categories to tags or tags to categories, selectively.' ),
    167167                        'plugin-slug' => 'wpcat2tag-importer',
    168168                        'importer-id' => 'wp-cat2tag',
    169169                ),
    170170                'livejournal' => array(
    171171                        'name' => __( 'LiveJournal' ),
    172                         'description' => __( 'Install the LiveJournal importer to import posts from LiveJournal using their API.' ),
     172                        'description' => __( 'Import posts from LiveJournal using their API.' ),
    173173                        'plugin-slug' => 'livejournal-importer',
    174174                        'importer-id' => 'livejournal',
    175175                ),
    176176                'movabletype' => array(
    177177                        'name' => __( 'Movable Type and TypePad' ),
    178                         'description' => __( 'Install the Movable Type importer to import posts and comments from a Movable Type or TypePad blog.' ),
     178                        'description' => __( 'Import posts and comments from a Movable Type or TypePad blog.' ),
    179179                        'plugin-slug' => 'movabletype-importer',
    180180                        'importer-id' => 'mt',
    181181                ),
    182182                'opml' => array(
    183183                        'name' => __( 'Blogroll' ),
    184                         'description' => __( 'Install the blogroll importer to import links in OPML format.' ),
     184                        'description' => __( 'Import links in OPML format.' ),
    185185                        'plugin-slug' => 'opml-importer',
    186186                        'importer-id' => 'opml',
    187187                ),
    188188                'rss' => array(
    189189                        'name' => __( 'RSS' ),
    190                         'description' => __( 'Install the RSS importer to import posts from an RSS feed.' ),
     190                        'description' => __( 'Import posts from an RSS feed.' ),
    191191                        'plugin-slug' => 'rss-importer',
    192192                        'importer-id' => 'rss',
    193193                ),
    194194                'tumblr' => array(
    195195                        'name' => __( 'Tumblr' ),
    196                         'description' => __( 'Install the Tumblr importer to import posts &amp; media from Tumblr using their API.' ),
     196                        'description' => __( 'Import posts &amp; media from Tumblr using their API.' ),
    197197                        'plugin-slug' => 'tumblr-importer',
    198198                        'importer-id' => 'tumblr',
    199199                ),
    200200                'wordpress' => array(
    201201                        'name' => 'WordPress',
    202                         'description' => __( 'Install the WordPress importer to import posts, pages, comments, custom fields, categories, and tags from a WordPress export file.' ),
     202                        'description' => __( 'Import posts, pages, comments, custom fields, categories, and tags from a WordPress export file.' ),
    203203                        'plugin-slug' => 'wordpress-importer',
    204204                        'importer-id' => 'wordpress',
    205205                ),