You cannot select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
166 lines
3.7 KiB
PHP
166 lines
3.7 KiB
PHP
<?php
|
|
/**
|
|
* Code Snippets library.
|
|
*
|
|
* Registers post types to be used in the "Code Snippets" library.
|
|
*
|
|
* @link https://github.com/elegantthemes/Divi/issues/26232
|
|
*
|
|
* @package Divi
|
|
* @subpackage Builder
|
|
* @since 4.19.0
|
|
*/
|
|
|
|
/**
|
|
* Core class used to implement "Code Snippets" library.
|
|
*
|
|
* Register post types & taxonomies to be used in "Code Snippets" library.
|
|
*/
|
|
class ET_Builder_Code_Snippets_Library {
|
|
|
|
/**
|
|
* Instance of `ET_Builder_Code_Snippets_Library`.
|
|
*
|
|
* @var ET_Builder_Code_Snippets_Library
|
|
*/
|
|
private static $_instance;
|
|
|
|
/**
|
|
* Instance of `ET_Core_Data_Utils`.
|
|
*
|
|
* @var ET_Core_Data_Utils
|
|
*/
|
|
protected static $_;
|
|
|
|
/**
|
|
* List of i18n strings.
|
|
*
|
|
* @var mixed[]
|
|
*/
|
|
protected static $_i18n;
|
|
|
|
/**
|
|
* ET_Builder_Post_Taxonomy_LayoutCategory instance.
|
|
*
|
|
* Shall be used for querying `et_code_snippet` taxonomy.
|
|
*
|
|
* @var ET_Builder_Post_Taxonomy_LayoutCategory
|
|
*/
|
|
public $code_snippet_categories;
|
|
|
|
/**
|
|
* ET_Builder_Post_Taxonomy_LayoutTag instance.
|
|
*
|
|
* Shall be used for querying `et_code_snippet` taxonomy .
|
|
*
|
|
* @var ET_Builder_Post_Taxonomy_LayoutTag
|
|
*/
|
|
public $code_snippet_tags;
|
|
|
|
/**
|
|
* ET_Builder_Post_Taxonomy_CodeSnippetType instance.
|
|
*
|
|
* Shall be used for querying `et_code_snippet` taxonomy .
|
|
*
|
|
* @var ET_Builder_Post_Taxonomy_CodeSnippetType
|
|
*/
|
|
public $code_snippet_types;
|
|
|
|
/**
|
|
* ET_Builder_Post_Type_TBItem instance.
|
|
*
|
|
* Shall be used for querying `et_tb_item` posts .
|
|
*
|
|
* @var ET_Builder_Post_Type_TBItem
|
|
*/
|
|
public $code_snippets;
|
|
|
|
/**
|
|
* ET_Builder_Post_Taxonomy_LayoutCategory instance.
|
|
*
|
|
* Shall be used for querying `et_tb_layout_category` taxonomy .
|
|
*
|
|
* @var ET_Builder_Post_Taxonomy_LayoutCategory
|
|
*/
|
|
public $code_snippets_categories;
|
|
|
|
/**
|
|
* ET_Builder_Post_Taxonomy_LayoutTag instance.
|
|
*
|
|
* Shall be used for querying `et_tb_layout_tag` taxonomy .
|
|
*
|
|
* @var ET_Builder_Post_Taxonomy_LayoutTag
|
|
*/
|
|
public $code_snippets_tags;
|
|
|
|
/**
|
|
* ET_Builder_Post_Taxonomy_CodeSnippetType instance.
|
|
*
|
|
* Shall be used for querying `et_tb_layout_type` taxonomy .
|
|
*
|
|
* @var ET_Builder_Post_Taxonomy_CodeSnippetType
|
|
*/
|
|
public $code_snippets_type;
|
|
|
|
/**
|
|
* Class constructor.
|
|
*/
|
|
public function __construct() {
|
|
$this->_instance_check();
|
|
$this->_register_cpt_and_taxonomies();
|
|
}
|
|
|
|
/**
|
|
* Dies if an instance already exists.
|
|
*/
|
|
protected function _instance_check() {
|
|
if ( self::$_instance ) {
|
|
et_error( 'Multiple instances are not allowed!' );
|
|
wp_die();
|
|
}
|
|
}
|
|
|
|
/**
|
|
* Registers the Theme Builder Library's custom post type and its taxonomies.
|
|
*/
|
|
protected function _register_cpt_and_taxonomies() {
|
|
$files = [
|
|
ET_CODE_SNIPPETS_DIR . 'post/type/CodeSnippet.php',
|
|
ET_CODE_SNIPPETS_DIR . 'post/taxonomy/CodeSnippetType.php',
|
|
];
|
|
|
|
if ( ! $files ) {
|
|
return;
|
|
}
|
|
|
|
foreach ( $files as $file ) {
|
|
require_once $file;
|
|
}
|
|
|
|
$this->code_snippets = ET_Builder_Post_Type_Code_Snippet::instance();
|
|
$this->code_snippets_categories = ET_Builder_Post_Taxonomy_LayoutCategory::instance();
|
|
$this->code_snippets_tags = ET_Builder_Post_Taxonomy_LayoutTag::instance();
|
|
$this->code_snippets_type = ET_Builder_Post_Taxonomy_CodeSnippetType::instance();
|
|
|
|
// We manually call register_all() now to ensure the CPT and taxonomies are registered
|
|
// at exactly the same point during the request that they were in prior releases.
|
|
ET_Builder_Post_Type_TBItem::register_all( 'builder' );
|
|
}
|
|
|
|
/**
|
|
* Returns the ET_Builder_TBItem_Library instance.
|
|
*
|
|
* @return ET_Builder_TBItem_Library
|
|
*/
|
|
public static function instance() {
|
|
if ( ! self::$_instance ) {
|
|
self::$_instance = new self();
|
|
}
|
|
|
|
return self::$_instance;
|
|
}
|
|
|
|
}
|
|
|
|
ET_Builder_Code_Snippets_Library::instance();
|