/** * Flatsome functions and definitions * * @package flatsome */ /** * Set the content width based on the theme's design and stylesheet. */ if ( ! isset( $content_width ) ) $content_width = 1000; /* pixels */ /* Add WooCommerce support */ add_theme_support( 'woocommerce' ); add_theme_support( 'yellow-pencil' ); /* Check if WooCommerce is active */ function ux_is_woocommerce_active(){ if ( in_array( 'woocommerce/woocommerce.php', apply_filters( 'active_plugins', get_option( 'active_plugins' ) ) ) ) { return true; } } /* Add theme option panel */ require_once('admin/index.php'); // load theme option panel global $flatsome_opt; $flatsome_opt = $smof_data; /* Global Flatsome Option */ function flatsome_opt( $option ) { global $flatsome_opt; if( ! empty( $flatsome_opt[$option] ) ) { return $flatsome_opt[$option]; } } /************ Plugin recommendations **********/ require_once ('inc/class-tgm-plugin-activation.php'); add_action( 'tgmpa_register', 'flatsome_register_required_plugins' ); function flatsome_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( array( 'name' => 'WooCommerce', // The plugin name 'slug' => 'woocommerce', // The plugin slug (typically the folder name) //'source' => get_template_directory() . '/inc/plugins/woocommerce.zip', // The plugin source 'required' => false, // If false, the plugin is only 'recommended' instead of required 'version' => '2.2.8', // E.g. 1.0.0. If set, the active plugin must be this version or higher, otherwise a notice is presented 'force_activation' => false, // If true, plugin is activated upon theme activation and cannot be deactivated until theme switch 'force_deactivation' => false, // If true, plugin is deactivated upon theme switch, useful for theme-specific plugins 'external_url' => 'http://wordpress.org/plugins/woocommerce/', // If set, overrides default API URL and points to an external URL ), array( 'name' => 'Ninja Forms', // The plugin name 'slug' => 'ninja-forms', // The plugin slug (typically the folder name) //'source' => get_template_directory() . '/inc/plugins/ninja-forms.zip', // The plugin source 'required' => false, // If false, the plugin is only 'recommended' instead of required 'version' => '2.8.10', // E.g. 1.0.0. If set, the active plugin must be this version or higher, otherwise a notice is presented 'force_activation' => false, // If true, plugin is activated upon theme activation and cannot be deactivated until theme switch 'force_deactivation' => false, // If true, plugin is deactivated upon theme switch, useful for theme-specific plugins 'external_url' => 'https://wordpress.org/plugins/ninja-forms/', // If set, overrides default API URL and points to an external URL ), array( 'name' => 'Regenerate Thumbnails', // The plugin name 'slug' => 'regenerate-thumbnails', // The plugin slug (typically the folder name) //'source' => get_template_directory() . '/inc/plugins/regenerate-thumbnails.zip', // The plugin source 'required' => false, // If false, the plugin is only 'recommended' instead of required 'version' => '2.2.4', // E.g. 1.0.0. If set, the active plugin must be this version or higher, otherwise a notice is presented 'force_activation' => false, // If true, plugin is activated upon theme activation and cannot be deactivated until theme switch 'force_deactivation' => false, // If true, plugin is deactivated upon theme switch, useful for theme-specific plugins 'external_url' => 'https://wordpress.org/plugins/regenerate-thumbnails/', // If set, overrides default API URL and points to an external URL ), array( 'name' => 'Taxonomy Metadata', // The plugin name 'slug' => 'taxonomy-metadata', // The plugin slug (typically the folder name) //'source' => get_template_directory() . '/inc/plugins/taxonomy-metadata.zip', // The plugin source 'required' => true, // If false, the plugin is only 'recommended' instead of required 'version' => '0.4', // E.g. 1.0.0. If set, the active plugin must be this version or higher, otherwise a notice is presented 'force_activation' => true, // If true, plugin is activated upon theme activation and cannot be deactivated until theme switch 'force_deactivation' => false, // If true, plugin is deactivated upon theme switch, useful for theme-specific plugins 'external_url' => 'https://wordpress.org/plugins/taxonomy-metadata/', // If set, overrides default API URL and points to an external URL ), array( 'name' => 'Unlimited Sidebars Woosidebars', // The plugin name 'slug' => 'woosidebars', // The plugin slug (typically the folder name) //'source' => get_template_directory() . '/inc/plugins/woosidebars.zip', // The plugin source 'required' => false, // If false, the plugin is only 'recommended' instead of required 'version' => '1.3.1', // E.g. 1.0.0. If set, the active plugin must be this version or higher, otherwise a notice is presented 'force_activation' => false, // If true, plugin is activated upon theme activation and cannot be deactivated until theme switch 'force_deactivation' => false, // If true, plugin is deactivated upon theme switch, useful for theme-specific plugins 'external_url' => 'https://wordpress.org/plugins/woosidebars/', // If set, overrides default API URL and points to an external URL ), array( 'name' => 'YITH WooCommerce Ajax Search', // The plugin name 'slug' => 'yith-woocommerce-ajax-search', // The plugin slug (typically the folder name) //'source' => get_template_directory() . '/inc/plugins/yith-woocommerce-ajax-search.zip', // The plugin source 'required' => false, // If false, the plugin is only 'recommended' instead of required 'version' => '1.2.2', // E.g. 1.0.0. If set, the active plugin must be this version or higher, otherwise a notice is presented 'force_activation' => false, // If true, plugin is activated upon theme activation and cannot be deactivated until theme switch 'force_deactivation' => false, // If true, plugin is deactivated upon theme switch, useful for theme-specific plugins 'external_url' => 'https://wordpress.org/plugins/yith-woocommerce-ajax-search/', // If set, overrides default API URL and points to an external URL ), array( 'name' => 'YITH WooCommerce Wishlist', // The plugin name 'slug' => 'yith-woocommerce-wishlist', // The plugin slug (typically the folder name) //'source' => get_template_directory() . '/inc/plugins/yith-woocommerce-wishlist.zip', // The plugin source 'required' => false, // If false, the plugin is only 'recommended' instead of required 'version' => '2.0', // E.g. 1.0.0. If set, the active plugin must be this version or higher, otherwise a notice is presented 'force_activation' => false, // If true, plugin is activated upon theme activation and cannot be deactivated until theme switch 'force_deactivation' => false, // If true, plugin is deactivated upon theme switch, useful for theme-specific plugins 'external_url' => 'https://wordpress.org/plugins/yith-woocommerce-wishlist/', // If set, overrides default API URL and points to an external URL ), array( 'name' => 'Nextend Facebook Connect', // The plugin name 'slug' => 'nextend-facebook-connect', // The plugin slug (typically the folder name) //'source' => get_template_directory() . '/inc/plugins/nextend-facebook-connect.zip', // The plugin source 'required' => false, // If false, the plugin is only 'recommended' instead of required 'version' => '1.5.3', // E.g. 1.0.0. If set, the active plugin must be this version or higher, otherwise a notice is presented 'force_activation' => false, // If true, plugin is activated upon theme activation and cannot be deactivated until theme switch 'force_deactivation' => false, // If true, plugin is deactivated upon theme switch, useful for theme-specific plugins 'external_url' => 'https://wordpress.org/plugins/nextend-facebook-connect/', // If set, overrides default API URL and points to an external URL ) ); /** * Array of configuration settings. Amend each line as needed. * If you want the default strings to be available under your own theme domain, * leave the strings uncommented. * Some of the strings are added into a sprintf, so see the comments at the * end of each line for what each argument will be. */ $config = array( 'default_path' => '', // Default absolute path to pre-packaged plugins. 'menu' => 'tgmpa-install-plugins', // Menu slug. 'has_notices' => true, // Show admin notices or not. 'dismissable' => true, // 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', 'tgmpa' ), 'menu_title' => __( 'Install Plugins', 'tgmpa' ), 'installing' => __( 'Installing Plugin: %s', 'tgmpa' ), // %s = plugin name. 'oops' => __( 'Something went wrong with the plugin API.', 'tgmpa' ), 'notice_can_install_required' => _n_noop( 'This theme requires the following plugin: %1$s.', 'This theme requires the following plugins: %1$s.' ), // %1$s = plugin name(s). 'notice_can_install_recommended' => _n_noop( 'This theme recommends the following plugin: %1$s.', 'This theme recommends the following plugins: %1$s.' ), // %1$s = plugin name(s). 'notice_cannot_install' => _n_noop( 'Sorry, but you do not have the correct permissions to install the %s plugin. Contact the administrator of this site for help on getting the plugin installed.', 'Sorry, but you do not have the correct permissions to install the %s plugins. Contact the administrator of this site for help on getting the plugins installed.' ), // %1$s = plugin name(s). 'notice_can_activate_required' => _n_noop( 'The following required plugin is currently inactive: %1$s.', 'The following required plugins are currently inactive: %1$s.' ), // %1$s = plugin name(s). 'notice_can_activate_recommended' => _n_noop( 'The following recommended plugin is currently inactive: %1$s.', 'The following recommended plugins are currently inactive: %1$s.' ), // %1$s = plugin name(s). 'notice_cannot_activate' => _n_noop( 'Sorry, but you do not have the correct permissions to activate the %s plugin. Contact the administrator of this site for help on getting the plugin activated.', 'Sorry, but you do not have the correct permissions to activate the %s plugins. Contact the administrator of this site for help on getting the plugins activated.' ), // %1$s = plugin name(s). 'notice_ask_to_update' => _n_noop( '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.' ), // %1$s = plugin name(s). 'notice_cannot_update' => _n_noop( 'Sorry, but you do not have the correct permissions to update the %s plugin. Contact the administrator of this site for help on getting the plugin updated.', 'Sorry, but you do not have the correct permissions to update the %s plugins. Contact the administrator of this site for help on getting the plugins updated.' ), // %1$s = plugin name(s). 'install_link' => _n_noop( 'Begin installing plugin', 'Begin installing plugins' ), 'activate_link' => _n_noop( 'Begin activating plugin', 'Begin activating plugins' ), 'return' => __( 'Return to Required Plugins Installer', 'tgmpa' ), 'plugin_activated' => __( 'Plugin activated successfully.', 'tgmpa' ), 'complete' => __( 'All plugins installed and activated successfully. %s', 'tgmpa' ), // %s = dashboard link. 'nag_type' => 'updated' // Determines admin notice type - can only be 'updated', 'update-nag' or 'error'. ) ); tgmpa( $plugins, $config ); } if ( ! function_exists( 'flatsome_setup' ) ) : function flatsome_setup() { /* Custom CSS */ require( get_template_directory() . '/inc/custom-css.php' ); /* Template tags */ require( get_template_directory() . '/inc/template-tags.php' ); /* Admin helpers */ if (current_user_can('edit_pages') && !is_admin()) { require( get_template_directory() . '/inc/helpers.php' ); } /* Custom functions that act independently of the theme templates */ require( get_template_directory() . '/inc/extras.php' ); /* load theme languages */ load_theme_textdomain( 'flatsome', get_template_directory() . '/languages' ); /* Add default posts and comments RSS feed links to head */ add_theme_support( 'automatic-feed-links' ); /* Add support for post thumbnails */ add_theme_support( 'post-thumbnails' ); /* Registrer menus. */ register_nav_menus( array( 'primary' => __( 'Main Menu', 'flatsome' ), 'primary_mobile' => __( 'Main Menu - Mobile', 'flatsome' ), 'footer' => __( 'Footer Menu', 'flatsome' ), 'top_bar_nav' => __( 'Top bar Menu', 'flatsome' ), 'my_account' => __( 'My Account Menu', 'flatsome' ), ) ); /* Enable support for Post Formats */ //add_theme_support( 'post-formats', array( 'aside', 'image', 'video', 'quote', 'link' ) ); } endif; // flatsome_setup add_action( 'after_setup_theme', 'flatsome_setup' ); /** * Register widgetized area and update sidebar with default widgets */ function flatsome_widgets_init() { global $flatsome_opt; register_sidebar( array( 'name' => __( 'Sidebar', 'flatsome' ), 'id' => 'sidebar-main', 'before_widget' => '', 'before_title' => '