Grazie per la risposta ragazzi. Sebbene entrambe le risposte mi abbiano messo sulla strada giusta, nessuna ha funzionato immediatamente. Quindi sto condividendo le mie soluzioni di seguito.
Metodo 1 - Utilizzo di register_activation_hook:
Crea il plugin Parent in plugin / parent-plugin / parent-plugin.php:
<?php
/*
Plugin Name: Parent Plugin
Description: Demo plugin with a dependent child plugin.
Version: 1.0.0
*/
Crea il plugin figlio in plugin / child-plugin / child-plugin.php:
<?php
/*
Plugin Name: Child Plugin
Description: Parent Plugin should be installed and active to use this plugin.
Version: 1.0.0
*/
register_activation_hook( __FILE__, 'child_plugin_activate' );
function child_plugin_activate(){
// Require parent plugin
if ( ! is_plugin_active( 'parent-plugin/parent-plugin.php' ) and current_user_can( 'activate_plugins' ) ) {
// Stop activation redirect and show error
wp_die('Sorry, but this plugin requires the Parent Plugin to be installed and active. <br><a href="' . admin_url( 'plugins.php' ) . '">« Return to Plugins</a>');
}
}
Si noti che non sto usando deactivate_plugins( $plugin );
perché per qualche motivo non funziona. Quindi ho usato wp_die per annullare il reindirizzamento di attivazione e informare l'utente.
Vantaggio:
- Soluzione semplice e non comporta ulteriori riscontri db rispetto al metodo 2
svantaggi:
- Lo schermo di wp_die è brutto
- La schermata di wp_die verrà ANCORA visualizzata se hai attivato il Plugin principale e il Plugin secondario contemporaneamente utilizzando le caselle di controllo nella schermata di amministrazione dei plug-in.
Metodo 2: utilizzo di admin_init e admin_notices
Crea il plugin Parent in plugin / parent-plugin / parent-plugin.php:
<?php
/*
Plugin Name: Parent Plugin
Description: Demo plugin with a dependent child plugin.
Version: 1.0.0
*/
Crea il plugin figlio in plugin / child-plugin / child-plugin.php:
<?php
/*
Plugin Name: Child Plugin
Description: Parent Plugin should be installed and active to use this plugin.
Version: 1.0.0
*/
add_action( 'admin_init', 'child_plugin_has_parent_plugin' );
function child_plugin_has_parent_plugin() {
if ( is_admin() && current_user_can( 'activate_plugins' ) && !is_plugin_active( 'parent-plugin/parent-plugin.php' ) ) {
add_action( 'admin_notices', 'child_plugin_notice' );
deactivate_plugins( plugin_basename( __FILE__ ) );
if ( isset( $_GET['activate'] ) ) {
unset( $_GET['activate'] );
}
}
}
function child_plugin_notice(){
?><div class="error"><p>Sorry, but Child Plugin requires the Parent plugin to be installed and active.</p></div><?php
}
Vantaggio:
- Funziona quando attivi il plug-in Parent e Child contemporaneamente usando le caselle di controllo
Svantaggio:
- Incrementa ulteriori hit db poiché il plug-in viene inizialmente attivato e disattivato una volta eseguito admin_init.
Per quanto riguarda la mia domanda sulla disabilitazione del link di attivazione, potrei usare:
add_filter( 'plugin_action_links', 'disable_child_link', 10, 2 );
function disable_child_link( $links, $file ) {
if ( 'child-plugin/child-plugin.php' == $file and isset($links['activate']) )
$links['activate'] = '<span>Activate</span>';
return $links;
}
Tuttavia, si è rivelato estremamente poco pratico in quanto NON esiste un posto dove inserire questo codice. Non sono riuscito a inserirlo nel plug-in parent poiché il plug-in parent dovrebbe essere attivo per l'esecuzione di questo codice. Certamente non appartiene a plugin figlio o funzioni.php. Quindi sto eliminando questa idea.
if (is_plugin_active('path/to/plugin.php')) { // Do something }