관리-도구
편집 파일: activator.php
<?php defined( 'ABSPATH' ) || die( "Can't access directly" ); /** * This file represents an example of the code that themes would use to register * the required plugins. * * It is expected that theme authors would copy and paste this code into their * functions.php file, and amend to suit. * * @see http://tgmpluginactivation.com/configuration/ for detailed documentation. * * @package TGM-Plugin-Activation * @subpackage Example * @version 2.6.1 for parent theme Arcade Theme * @author Thomas Griffin, Gary Jones, Juliette Reinders Folmer * @copyright Copyright (c) 2011, Thomas Griffin * @license http://opensource.org/licenses/gpl-2.0.php GPL v2 or later * @link https://github.com/TGMPA/TGM-Plugin-Activation */ /** * Include the TGM_Plugin_Activation class. * * Depending on your implementation, you may want to change the include call: * * Parent Theme: * require_once get_template_directory() . '/path/to/class-tgm-plugin-activation.php'; * * Child Theme: * require_once get_stylesheet_directory() . '/path/to/class-tgm-plugin-activation.php'; * * Plugin: * require_once dirname( __FILE__ ) . '/path/to/class-tgm-plugin-activation.php'; */ require_once get_template_directory() . '/inc/tgm-plugin-activation/class-tgm-plugin-activation.php'; add_action( 'tgmpa_register', 'at__register_required_plugins' ); /** * Register the required plugins for this theme. * * In this example, we register five plugins: * - one included with the TGMPA library * - two from an external source, one from an arbitrary source, one from a GitHub repository * - two from the .org repo, where one demonstrates the use of the `is_callable` argument * * The variables passed to the `tgmpa()` function should be: * - an array of plugin arrays; * - optionally a configuration array. * If you are not changing anything in the configuration array, you can remove the array and remove the * variable from the function call: `tgmpa( $plugins );`. * In that case, the TGMPA default settings will be used. * * This function is hooked into `tgmpa_register`, which is fired on the WP `init` action on priority 10. */ function at__register_required_plugins() { /* * Array of plugin arrays. Required keys are name and slug. * If the source is NOT from the .org repo, then source is also required. */ $plugins = array( // This is an example of how to include a plugin from the WordPress Plugin Repository. array( 'name' => 'Kirki', 'slug' => 'kirki', 'required' => true, 'force_activation' => true, // If true, plugin is activated upon theme activation and cannot be deactivated until theme switch. //'is_callable' => 'wpseo_init', ), array( 'name' => 'Font Awesome', 'slug' => 'font-awesome', 'required' => true, 'force_activation' => true, // If true, plugin is activated upon theme activation and cannot be deactivated until theme switch. //'is_callable' => 'wpseo_init', ), array( 'name' => 'YARPP', 'slug' => 'yet-another-related-posts-plugin', 'required' => true, 'force_activation' => true, // If true, plugin is activated upon theme activation and cannot be deactivated until theme switch. //'is_callable' => 'wpseo_init', ), ); /* * Array of configuration settings. Amend each line as needed. * * TGMPA will start providing localized text strings soon. If you already have translations of our standard * strings available, please help us make TGMPA even better by giving us access to these translations or by * sending in a pull-request with .po file(s) with the translations. * * Only uncomment the strings in the config array if you want to customize the strings. */ $config = array( 'id' => 'arcade_theme', // Unique ID for hashing notices for multiple instances of TGMPA. 'default_path' => '', // Default absolute path to bundled plugins. 'menu' => 'tgmpa-install-plugins', // Menu slug. 'parent_slug' => 'themes.php', // Parent menu slug. 'capability' => 'edit_theme_options', // Capability needed to view plugin install page, should be a capability associated with the parent menu used. 'has_notices' => true, // Show admin notices or not. 'dismissable' => false, // If false, a user cannot dismiss the nag message. 'dismiss_msg' => '', // If 'dismissable' is false, this message will be output at top of nag. 'is_automatic' => false, // Automatically activate plugins after installation or not. 'message' => '', // Message to output right before the plugins table. /* 'strings' => array( 'page_title' => __( 'Install Required Plugins', 'arcade_theme' ), 'menu_title' => __( 'Install Plugins', 'arcade_theme' ), /* translators: %s: plugin name. * / 'installing' => __( 'Installing Plugin: %s', 'arcade_theme' ), /* translators: %s: plugin name. * / 'updating' => __( 'Updating Plugin: %s', 'arcade_theme' ), 'oops' => __( 'Something went wrong with the plugin API.', 'arcade_theme' ), 'notice_can_install_required' => _n_noop( /* translators: 1: plugin name(s). * / 'This theme requires the following plugin: %1$s.', 'This theme requires the following plugins: %1$s.', 'arcade_theme' ), 'notice_can_install_recommended' => _n_noop( /* translators: 1: plugin name(s). * / 'This theme recommends the following plugin: %1$s.', 'This theme recommends the following plugins: %1$s.', 'arcade_theme' ), 'notice_ask_to_update' => _n_noop( /* translators: 1: plugin name(s). * / 'The following plugin needs to be updated to its latest version to ensure maximum compatibility with this theme: %1$s.', 'The following plugins need to be updated to their latest version to ensure maximum compatibility with this theme: %1$s.', 'arcade_theme' ), 'notice_ask_to_update_maybe' => _n_noop( /* translators: 1: plugin name(s). * / 'There is an update available for: %1$s.', 'There are updates available for the following plugins: %1$s.', 'arcade_theme' ), 'notice_can_activate_required' => _n_noop( /* translators: 1: plugin name(s). * / 'The following required plugin is currently inactive: %1$s.', 'The following required plugins are currently inactive: %1$s.', 'arcade_theme' ), 'notice_can_activate_recommended' => _n_noop( /* translators: 1: plugin name(s). * / 'The following recommended plugin is currently inactive: %1$s.', 'The following recommended plugins are currently inactive: %1$s.', 'arcade_theme' ), 'install_link' => _n_noop( 'Begin installing plugin', 'Begin installing plugins', 'arcade_theme' ), 'update_link' => _n_noop( 'Begin updating plugin', 'Begin updating plugins', 'arcade_theme' ), 'activate_link' => _n_noop( 'Begin activating plugin', 'Begin activating plugins', 'arcade_theme' ), 'return' => __( 'Return to Required Plugins Installer', 'arcade_theme' ), 'plugin_activated' => __( 'Plugin activated successfully.', 'arcade_theme' ), 'activated_successfully' => __( 'The following plugin was activated successfully:', 'arcade_theme' ), /* translators: 1: plugin name. * / 'plugin_already_active' => __( 'No action taken. Plugin %1$s was already active.', 'arcade_theme' ), /* translators: 1: plugin name. * / 'plugin_needs_higher_version' => __( 'Plugin not activated. A higher version of %s is needed for this theme. Please update the plugin.', 'arcade_theme' ), /* translators: 1: dashboard link. * / 'complete' => __( 'All plugins installed and activated successfully. %1$s', 'arcade_theme' ), 'dismiss' => __( 'Dismiss this notice', 'arcade_theme' ), 'notice_cannot_install_activate' => __( 'There are one or more required or recommended plugins to install, update or activate.', 'arcade_theme' ), 'contact_admin' => __( 'Please contact the administrator of this site for help.', 'arcade_theme' ), 'nag_type' => '', // Determines admin notice type - can only be one of the typical WP notice classes, such as 'updated', 'update-nag', 'notice-warning', 'notice-info' or 'error'. Some of which may not work as expected in older WP versions. ), */ ); tgmpa( $plugins, $config ); }