Astra_Ext_Extension
Provide Extension related data.
Description
Source
File: classes/class-astra-ext-extension.php
final class Astra_Ext_Extension { /** * Default Extensions * * @since 1.4.8 * @return array */ public static function get_default_addons() { return apply_filters( 'astra_ext_default_addons', array( 'advanced-search' => 'advanced-search', ) ); } /** * Provide Extension array(). * * @return array() * @since 1.0 */ public static function get_addons() { $extensions = array( 'advanced-hooks' => array(), 'blog-pro' => array(), 'colors-and-background' => array(), 'advanced-footer' => array(), 'mobile-header' => array(), 'header-sections' => array(), 'lifterlms' => array(), 'learndash' => array(), 'advanced-headers' => array(), 'site-layouts' => array(), 'spacing' => array(), 'sticky-header' => array(), 'scroll-to-top' => array(), 'transparent-header' => array(), 'typography' => array(), 'woocommerce' => array(), 'edd' => array(), 'nav-menu' => array(), ); return apply_filters( 'astra_get_addons', $extensions ); } /** * Provide Enable Extension array(). * * @return array() * @since 1.0 */ public static function get_enabled_addons() { $enabled_data = array(); $extensions = self::get_addons(); $enabled_extensions = Astra_Admin_Helper::get_admin_settings_option( '_astra_ext_enabled_extensions' ); if ( empty( $enabled_extensions ) ) { foreach ( $extensions as $slug => $data ) { $enabled_data[ $slug ] = ( isset( $data['default'] ) ) ? $data['default'] : false; } $enabled_data['all'] = 'all'; } else { $enabled_data = $enabled_extensions; if ( isset( $enabled_extensions['all'] ) && false != $enabled_extensions['all'] ) { // add new key. foreach ( $extensions as $slug => $data ) { if ( ! array_key_exists( $slug, $enabled_extensions ) ) { $enabled_data[ $slug ] = ( isset( $data['default'] ) ) ? $data['default'] : false; } } } } return apply_filters( 'astra_ext_enabled_extensions', $enabled_data ); } /** * Check extension status * * @param string $key Key to find in Extensions Array. * @param boolean $default Default if Key not exist in Extensions Array. * @return boolean * @since 1.0 */ public static function is_active( $key, $default = false ) { $extensions = array_merge( self::get_enabled_addons(), self::get_default_addons() ); if ( array_key_exists( $key, $extensions ) && $extensions[ $key ] ) { return true; } else { return $default; } } /** * Provide Custom 404 array(). * * @return array() * @since 1.0 */ public static function get_custom_404() { $custom_404_default = array( 'enable_404' => false, 'page_404' => '', 'page_404_id' => '', ); $custom_404 = Astra_Admin_Helper::get_admin_settings_option( '_astra_ext_custom_404' ); if ( empty( $custom_404 ) ) { $custom_404 = $custom_404_default; } $custom_404 = apply_filters( 'astra_custom_404_options', $custom_404_default ); return $custom_404; } }
Expand full source code Collapse full source code View on Trac
Changelog
Version | Description |
---|---|
1.0 | Introduced. |
Methods
- activate_extension — Activates the specified extension.
- get_addons — Provide Extension array().
- get_custom_404 — Provide Custom 404 array().
- get_default_addons — Default Extensions
- get_enabled_addons — Provide Enable Extension array().
- is_active — Check extension status