Sindbad~EG File Manager
<?php
/**
* Inspiro functions and definitions
*
* @link https://developer.wordpress.org/themes/basics/theme-functions/
*
* @package Inspiro
* @since Inspiro 1.0.0
*/
if ( ! defined( 'ABSPATH' ) ) {
exit; // Exit if accessed directly.
}
if ( ! class_exists( 'Inspiro_After_Setup_Theme' ) ) {
/**
* Inspiro_After_Setup_Theme initial setup
*
* @since 1.0.0
*/
class Inspiro_After_Setup_Theme {
/**
* Instance
*
* @var $instance
*/
private static $instance;
/**
* Initiator
*
* @since 1.0.0
* @return object
*/
public static function get_instance() {
if ( ! isset( self::$instance ) ) {
self::$instance = new self();
}
return self::$instance;
}
/**
* Constructor
*/
public function __construct() {
add_action( 'after_setup_theme', array( $this, 'theme_setup' ) );
add_action( 'template_redirect', array( $this, 'theme_content_width' ), 0 );
add_action( 'tgmpa_register', array( $this, 'register_required_plugins' ) );
add_action( 'tgmpa_register', array( $this, 'register_required_plugins' ) );
add_filter( 'ocdi/register_plugins', array( $this,'ocdi_register_plugins' ) );
add_filter( 'ocdi/import_files', array( $this,'ocdi_import_files' ) );
add_action( 'ocdi/after_import', array( $this,'ocdi_after_import_setup' ));
}
/**
* Sets up theme defaults and registers support for various WordPress features.
*
* Note that this function is hooked into the after_setup_theme hook, which
* runs before the init hook. The init hook is too late for some features, such
* as indicating support for post thumbnails.
*
* @since 1.0.0
*/
public function theme_setup() {
do_action( 'inspiro_lite_theme_setup' );
/*
* Make theme available for translation.
* Translations can be filed at WordPress.org. See: https://translate.wordpress.org/projects/wp-themes/inspiro-lite
*/
load_theme_textdomain( 'inspiro', INSPIRO_THEME_DIR . '/languages' );
// Add default posts and comments RSS feed links to head.
add_theme_support( 'automatic-feed-links' );
/*
* Let WordPress manage the document title.
* By adding theme support, we declare that this theme does not use a
* hard-coded <title> tag in the document head, and expect WordPress to
* provide it for us.
*/
add_theme_support( 'title-tag' );
/*
* Enable support for Post Thumbnails on posts and pages.
*
* @link https://developer.wordpress.org/themes/functionality/featured-images-post-thumbnails/
*/
add_theme_support( 'post-thumbnails' );
/**
* Register image sizes.
*/
add_image_size( 'inspiro-featured-image', 2000 );
// phpcs:disable
// add_image_size( 'inspiro-recent-thumbnail', 345, 192, true );
// add_image_size( 'inspiro-recent-thumbnail-retina', 690, 384, true );
// add_image_size( 'inspiro-entry-cover', 1800 );
// phpcs:enable
add_image_size( 'inspiro-loop', 950, 320, true );
add_image_size( 'inspiro-loop@2x', 1900, 640, true );
// Set the default content width.
$GLOBALS['content_width'] = 950;
// Register nav menus.
register_nav_menus(
array(
'primary' => __( 'Main Menu', 'inspiro' ),
)
);
/*
* Switch default core markup for search form, comment form, and comments
* to output valid HTML5.
*/
add_theme_support(
'html5',
array(
'comment-form',
'comment-list',
'gallery',
'caption',
'script',
'style',
)
);
/*
* Enable support for Post Formats.
*
* See: https://wordpress.org/support/article/post-formats/
*/
add_theme_support(
'post-formats',
array(
'aside',
'image',
'video',
'quote',
'link',
'gallery',
'audio',
)
);
// Add theme support for Custom Logo.
add_theme_support(
'custom-logo',
array(
'height' => 100,
'width' => 400,
'flex-height' => true,
'flex-width' => true,
)
);
// Add theme support for selective refresh for widgets.
add_theme_support( 'customize-selective-refresh-widgets' );
/*
* This theme styles the visual editor to resemble the theme style,
* specifically font, colors, and column width.
*/
$dir_name = ( SCRIPT_DEBUG ) ? 'unminified' : 'minified';
$file_prefix = ( SCRIPT_DEBUG ) ? '' : '.min';
add_editor_style(
array(
'assets/css/' . $dir_name . '/editor-style' . $file_prefix . '.css',
Inspiro_Fonts_Manager::get_google_font_url(),
)
);
// Load regular editor styles into the new block-based editor.
add_theme_support( 'editor-styles' );
// Load default block styles.
add_theme_support( 'wp-block-styles' );
// Add support for full and wide align images.
add_theme_support( 'align-wide' );
// Add support for responsive embeds.
add_theme_support( 'responsive-embeds' );
/*
* Adds starter content to highlight the theme on fresh sites.
* This is done conditionally to avoid loading the starter content on every
* page load, as it is a one-off operation only needed once in the customizer.
*/
if ( is_customize_preview() ) {
require INSPIRO_THEME_DIR . 'inc/starter-content.php'; // phpcs:ignore WPThemeReview.CoreFunctionality.FileInclude.FileIncludeFound
add_theme_support( 'starter-content', inspiro_get_starter_content() );
}
}
/**
* Set the content width in pixels, based on the theme's design and stylesheet.
*
* Priority 0 to make it available to lower priority callbacks.
*
* @since 1.0.0
*
* @global int $content_width
*/
public function theme_content_width() {
$content_width = $GLOBALS['content_width'];
// Get layout.
$blog_layout = inspiro_get_theme_mod( 'layout_blog_page' );
// Check if layout is full width.
if ( 'full' === $blog_layout ) {
if ( inspiro_is_frontpage() && ! is_active_sidebar( 'blog-sidebar' ) ) {
$content_width = 1200;
} elseif ( is_page() ) {
$content_width = 950;
}
}
// Check if is single post and there is no sidebar.
if ( is_single() && ! is_active_sidebar( 'blog-sidebar' ) ) {
$content_width = 950;
}
/**
* Filters Inspiro content width of the theme.
*
* @since 1.0.0
*
* @param int $content_width Content width in pixels.
*/
$GLOBALS['content_width'] = apply_filters( 'inspiro_content_width', $content_width );
}
public function ocdi_register_plugins( $plugins ) {
$theme_plugins = [
[
'name' => 'WPZOOM Portfolio',
'slug' => 'wpzoom-portfolio',
'required' => true,
],
[
'name' => 'Instagram Widget by WPZOOM',
'slug' => 'instagram-widget-by-wpzoom',
'required' => false,
],
[
'name' => 'Social Icons Widget by WPZOOM',
'slug' => 'social-icons-widget-by-wpzoom',
'required' => false,
],
];
// Check if user is on the theme recommeneded plugins step and a demo was selected.
if (
isset( $_GET['step'] ) &&
$_GET['step'] === 'import' &&
isset( $_GET['import'] )
) {
// Adding one additional plugin for the first demo import ('import' number = 0).
if ( $_GET['import'] === '0' ) {
$theme_plugins[] = [
'name' => 'Elementor',
'slug' => 'elementor',
'required' => true,
];
$theme_plugins[] = [
'name' => 'Elementor Addons by WPZOOM',
'slug' => 'wpzoom-elementor-addons',
'required' => true,
];
}
}
return array_merge( $plugins, $theme_plugins );
}
public function ocdi_import_files() {
return [
[
'import_file_name' => 'Inspiro Lite - Elementor',
'import_file_url' => 'https://www.wpzoom.com/downloads/xml/inspiro-lite.xml',
'import_widget_file_url' => 'https://www.wpzoom.com/downloads/xml/inspiro-lite-widgets.wie',
'import_customizer_file_url' => 'https://www.wpzoom.com/downloads/xml/inspiro-lite-customizer.dat',
'import_preview_image_url' => 'https://www.wpzoom.com/wp-content/uploads/2021/10/inspiro-lite-elementor-1.png',
'preview_url' => 'https://demo.wpzoom.com/inspiro-lite/',
],
[
'import_file_name' => 'Inspiro Lite - Gutenberg',
'import_file_url' => 'https://www.wpzoom.com/downloads/xml/inspiro-lite-blocks.xml',
'import_widget_file_url' => 'https://www.wpzoom.com/downloads/xml/inspiro-lite-widgets.wie',
'import_customizer_file_url' => 'https://www.wpzoom.com/downloads/xml/inspiro-lite-customizer.dat',
'import_preview_image_url' => 'https://www.wpzoom.com/wp-content/uploads/2021/10/inspiro-lite-gutenberg-1.png',
'preview_url' => 'https://demo.wpzoom.com/inspiro-lite-blocks/',
],
];
}
public function ocdi_after_import_setup() {
// Assign menus to their locations.
$main_menu = get_term_by( 'name', 'Main', 'nav_menu' );
set_theme_mod( 'nav_menu_locations', [
'primary' => $main_menu->term_id, // replace 'main-menu' here with the menu location identifier from register_nav_menu() function in your theme.
]
);
// Assign front page and posts page (blog page).
$front_page_id = get_page_by_title( 'Homepage' );
$blog_page_id = get_page_by_title( 'Blog' );
update_option( 'show_on_front', 'page' );
update_option( 'page_on_front', $front_page_id->ID );
update_option( 'page_for_posts', $blog_page_id->ID );
}
/**
* 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.
*
* @since 1.2.3
* @return void
*/
public function 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' => 'One Click Demo Import',
'slug' => 'one-click-demo-import',
'required' => true,
),
array(
'name' => 'Elementor',
'slug' => 'elementor',
'required' => true,
),
array(
'name' => 'Elementor Addons by WPZOOM',
'slug' => 'wpzoom-elementor-addons',
'required' => true,
),
array(
'name' => 'WPZOOM Portfolio',
'slug' => 'wpzoom-portfolio',
'required' => true,
),
array(
'name' => 'Instagram Widget by WPZOOM',
'slug' => 'instagram-widget-by-wpzoom',
'required' => false,
),
array(
'name' => 'Social Icons Widget by WPZOOM',
'slug' => 'social-icons-widget-by-wpzoom',
'required' => false,
),
);
/*
* 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' => 'inspiro_wporg', // Unique ID for hashing notices for multiple instances of TGMPA.
'default_path' => '', // Default absolute path to bundled 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.
);
tgmpa( $plugins, $config );
}
}
}
Inspiro_After_Setup_Theme::get_instance();
Sindbad File Manager Version 1.0, Coded By Sindbad EG ~ The Terrorists