Skip to content

Instantly share code, notes, and snippets.

@humayunahmed8
Created March 5, 2022 11:48
Show Gist options
  • Star 0 You must be signed in to star a gist
  • Fork 0 You must be signed in to fork a gist
  • Save humayunahmed8/c4c2df8255f2aefd0a5e0d254136f2c0 to your computer and use it in GitHub Desktop.
Save humayunahmed8/c4c2df8255f2aefd0a5e0d254136f2c0 to your computer and use it in GitHub Desktop.
Kirki installer class
<?php
/**
* This file adds a custom section in the customizer that recommends the installation of the Kirki plugin.
* It can be used as-is in themes (drop-in).
*
* @package kirki-helpers
*/
if ( ! function_exists( 'kirki_installer_register' ) ) {
/**
* Registers the section, setting & control for the kirki installer.
*
* @param object $wp_customize The main customizer object.
*/
function kirki_installer_register( $wp_customize ) {
// Early exit if Kirki exists.
if ( class_exists( 'Kirki' ) ) {
return;
}
if ( class_exists( 'WP_Customize_Section' ) && ! class_exists( 'Kirki_Installer_Section' ) ) {
/**
* Recommend the installation of Kirki using a custom section.
*
* @see WP_Customize_Section
*/
class Kirki_Installer_Section extends WP_Customize_Section {
/**
* Customize section type.
*
* @access public
* @var string
*/
public $type = 'kirki_installer';
/**
* The plugin install URL.
*
* @access private
* @var string
*/
public $plugin_install_url;
/**
* Render the section.
*
* @access protected
*/
protected function render() {
// Don't proceed any further if the user has dismissed this.
if ( $this->is_dismissed() ) {
return;
}
// Determine if the plugin is not installed, or just inactive.
$plugins = get_plugins();
$installed = false;
foreach ( $plugins as $plugin ) {
if ( 'Kirki' === $plugin['Name'] || 'Kirki Toolkit' === $plugin['Name'] ) {
$installed = true;
}
}
$plugin_install_url = $this->get_plugin_install_url();
$classes = 'cannot-expand accordion-section control-section control-section-themes control-section-' . $this->type;
?>
<li id="accordion-section-<?php echo esc_attr( $this->id ); ?>" class="<?php echo esc_attr( $classes ); ?>" style="border-top:none;border-bottom:1px solid #ddd;padding:7px 14px 16px 14px;text-align:right;">
<?php if ( ! $installed ) : ?>
<?php $this->install_button(); ?>
<?php else : ?>
<?php $this->activate_button(); ?>
<?php endif; ?>
<?php $this->dismiss_button(); ?>
</li>
<?php
}
/**
* Check if the user has chosen to hide this.
*
* @static
* @access public
* @since 1.0.0
* @return bool
*/
public static function is_dismissed() {
// Get the user-meta.
$user_id = get_current_user_id();
$user_meta = get_user_meta( $user_id, 'dismiss-kirki-recommendation', true );
return ( true === $user_meta || '1' === $user_meta || 1 === $user_meta );
}
/**
* Adds the install button.
*
* @since 1.0.0
* @return void
*/
protected function install_button() {
?>
<p style="text-align:left;margin-top:0;">
<?php esc_html_e( 'Please install the Kirki plugin to take full advantage of this themes customizer capabilities', 'kirki' ); ?>
</p>
<a class="install-now button-primary button" data-slug="kirki" href="<?php echo esc_url_raw( $this->get_plugin_install_url() ); ?>" aria-label="<?php esc_attr_e( 'Install Kirki Toolkit now', 'kirki' ); ?>" data-name="Kirki Toolkit">
<?php esc_html_e( 'Install Now', 'kirki' ); ?>
</a>
<?php
}
/**
* Adds the install button.
*
* @since 1.0.0
* @return void
*/
protected function activate_button() {
?>
<p style="text-align:left;margin-top:0;">
<?php esc_html_e( 'You have installed Kirki. Activate it to take advantage of this theme\'s features in the customizer.', 'kirki' ); ?>
</p>
<a class="activate-now button-primary button" data-slug="kirki" href="<?php echo esc_url_raw( self_admin_url( 'plugins.php' ) ); ?>" aria-label="<?php esc_attr_e( 'Activate Kirki Toolkit now', 'kirki' ); ?>" data-name="Kirki Toolkit">
<?php esc_html_e( 'Activate Now', 'kirki' ); ?>
</a>
<?php
}
/**
* Adds the dismiss button and script.
*
* @since 1.0.0
* @return void
*/
protected function dismiss_button() {
// Create the nonce.
$ajax_nonce = wp_create_nonce( 'dismiss-kirki-recommendation' );
// Show confirmation dialog on dismiss?
$show_confirm = true;
?>
<a class="kirki-installer-dismiss button-secondary button" data-slug="kirki" href="#" aria-label="<?php esc_attr_e( 'Don\'t show this again', 'kirki' ); ?>" data-name="<?php esc_attr_e( 'Dismiss', 'kirki' ); ?>">
<?php esc_html_e( 'Don\'t show this again', 'kirki' ); ?>
</a>
<script type="text/javascript">
jQuery( document ).ready( function() {
jQuery( '.kirki-installer-dismiss' ).on( 'click', function( event ) {
event.preventDefault();
<?php if ( $show_confirm ) : ?>
if ( ! confirm( '<?php esc_html_e( 'Are you sure? Dismissing this message will hide the installation recommendation and you will have to manually install and activate the plugin in the future.', 'kirki' ); ?>' ) ) {
return;
}
<?php endif; ?>
jQuery.post( ajaxurl, {
action: 'kirki_installer_dismiss',
security: '<?php echo esc_html( $ajax_nonce ); ?>',
}, function( response ) {
jQuery( '#accordion-section-kirki_installer' ).remove();
} );
} );
} );
</script>
<?php
}
/**
* Get the plugin install URL.
*
* @access private
* @return string
*/
private function get_plugin_install_url() {
if ( ! $this->plugin_install_url ) {
// Get the plugin-installation URL.
$this->plugin_install_url = add_query_arg(
array(
'action' => 'install-plugin',
'plugin' => 'kirki',
),
self_admin_url( 'update.php' )
);
$this->plugin_install_url = wp_nonce_url( $this->plugin_install_url, 'install-plugin_kirki' );
}
return $this->plugin_install_url;
}
}
}
// Early exit if the user has dismissed the notice.
if ( is_callable( array( 'Kirki_Installer_Section', 'is_dismissed' ) ) && Kirki_Installer_Section::is_dismissed() ) {
return;
}
$wp_customize->add_section(
new Kirki_Installer_Section(
$wp_customize,
'kirki_installer',
array(
'title' => '',
'capability' => 'install_plugins',
'priority' => 0,
)
)
);
$wp_customize->add_setting(
'kirki_installer_setting',
array(
'sanitize_callback' => '__return_true',
)
);
$wp_customize->add_control(
'kirki_installer_control',
array(
'section' => 'kirki_installer',
'settings' => 'kirki_installer_setting',
)
);
}
}
add_action( 'customize_register', 'kirki_installer_register', 999 );
if ( ! function_exists( 'kirki_installer_dismiss' ) ) {
/**
* Handles dismissing the plgin-install/activate recommendation.
* If the user clicks the "Don't show this again" button, save as user-meta.
*
* @since 1.0.0
* @return void
*/
function kirki_installer_dismiss() {
check_ajax_referer( 'dismiss-kirki-recommendation', 'security' );
$user_id = get_current_user_id();
if ( update_user_meta( $user_id, 'dismiss-kirki-recommendation', true ) ) {
echo 'success! :-)';
wp_die();
}
echo 'failed :-(';
wp_die();
}
}
add_action( 'wp_ajax_kirki_installer_dismiss', 'kirki_installer_dismiss' );
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment