File Editor
Directories:
.. (Back)
Admin
Ajax
Asset
Context
Customizer
Debug_Bar
Dialog
Documentation
Duplicate
Editor
Image
JSON_LD
Languages
Log
Meta
Models
Onboarding
PUE
Process
Promoter
REST
Repository
Service_Providers
Shortcode
Support
Tabbed_View
Tooltip
Traits
Utils
Validator
Values
Widget
Files:
Abstract_Deactivation.php
Abstract_Plugin_Register.php
App_Shop.php
Assets.php
Assets_Pipeline.php
Autoloader.php
Cache.php
Cache_Listener.php
Changelog_Reader.php
Container.php
Context.php
Cost_Utils.php
Credits.php
Customizer.php
DB_Lock.php
Data.php
Date_Utils.php
Db.php
Debug.php
Dependency.php
Deprecation.php
Editor.php
Error.php
Exception.php
Extension.php
Extension_Loader.php
Feature_Detection.php
Field.php
Field_Conditional.php
Log.php
Main.php
Notices.php
Plugin_Meta_Links.php
Plugins.php
Plugins_API.php
Post_History.php
Post_Transient.php
Promise.php
Repository.php
Rewrite.php
Settings.php
Settings_Manager.php
Settings_Tab.php
Simple_Table.php
Support.php
Tabbed_View.php
Template.php
Template_Part_Cache.php
Templates.php
Terms.php
Timezones.php
Tracker.php
Updater.php
Validate.php
View_Helpers.php
Create New File
Create
Edit File: Plugins.php
<?php // Don't load directly defined( 'WPINC' ) or die; if ( ! class_exists( 'Tribe__Plugins' ) ) { /** * A list of Tribe's major plugins. Useful when encouraging users to download one of these. */ class Tribe__Plugins { /** * A list of tribe plugin's details in this array format: * * [ * 'short_name' => Common name for the plugin, used in places such as WP Admin messages * 'class' => Main plugin class * 'thickbox_url' => Download or purchase URL for plugin from within /wp-admin/ thickbox * ] */ private $tribe_plugins = [ [ 'short_name' => 'Event Tickets', 'class' => 'Tribe__Tickets__Main', 'thickbox_url' => 'plugin-install.php?tab=plugin-information&plugin=event-tickets&TB_iframe=true', ], [ 'short_name' => 'Event Tickets Plus', 'class' => 'Tribe__Tickets_Plus__Main', 'thickbox_url' => 'https://theeventscalendar.com/product/wordpress-event-tickets-plus/?TB_iframe=true', ], [ 'short_name' => 'The Events Calendar', 'class' => 'Tribe__Events__Main', 'thickbox_url' => 'plugin-install.php?tab=plugin-information&plugin=the-events-calendar&TB_iframe=true', ], [ 'short_name' => 'Events Calendar Pro', 'class' => 'Tribe__Events__Pro__Main', 'thickbox_url' => 'https://theeventscalendar.com/product/wordpress-events-calendar-pro/?TB_iframe=true', ], [ 'short_name' => 'Community', 'class' => 'Tribe__Events__Community__Main', 'thickbox_url' => 'https://theeventscalendar.com/product/wordpress-community-events/?TB_iframe=true', ], [ 'short_name' => 'Community Tickets', 'class' => 'Tribe__Events__Community__Tickets__Main', 'thickbox_url' => 'https://theeventscalendar.com/product/community-tickets/?TB_iframe=true', ], [ 'short_name' => 'Filter Bar', 'class' => 'Tribe__Events__Filterbar__View', 'thickbox_url' => 'https://theeventscalendar.com/product/wordpress-events-filterbar/?TB_iframe=true', ], [ 'short_name' => 'Eventbrite Tickets', 'class' => 'Tribe__Events__Tickets__Eventbrite__Main', 'thickbox_url' => 'https://theeventscalendar.com/product/wordpress-eventbrite-tickets/?TB_iframe=true', ], [ 'short_name' => 'Advanced Post Manager', 'class' => 'Tribe_APM', 'thickbox_url' => 'plugin-install.php?tab=plugin-information&plugin=advanced-post-manager&TB_iframe=true', ], ]; /** * Searches the plugin list for key/value pair and return the full details for that plugin * * @param string $search_key The array key this value will appear in * @param string $search_val The value itself * * @return array|null */ public function get_plugin_by_key( $search_key, $search_val ) { foreach ( $this->get_list() as $plugin ) { if ( isset( $plugin[ $search_key ] ) && $plugin[ $search_key ] === $search_val ) { return $plugin; } } return null; } /** * Retrieves plugins details by plugin name * * @param string $name Common name for the plugin, not necessarily the lengthy name in the WP Admin Plugins list * * @return array|null */ public function get_plugin_by_name( $name ) { return $this->get_plugin_by_key( 'short_name', $name ); } /** * Retrieves plugins details by class name * * @param string $main_class Main/base class for this plugin * * @return array|null */ public function get_plugin_by_class( $main_class ) { return $this->get_plugin_by_key( 'class', $main_class ); } /** * Retrieves the entire list * * @return array */ public function get_list() { /** * Gives an opportunity to filter the list of tribe plugins * * @since 4.7.18 * * @param array Contains a list of all tribe plugins */ return apply_filters( 'tribe_plugins_get_list', $this->tribe_plugins ); } /** * Checks if given plugin is active. Usually a The Events Calendar plugin. * * @param string $plugin_name The name of the plugin. Each plugin defines their name upon hooking on the filter. * * @since 4.12.1 * * @return bool True if plugin is active. False if plugin is not active. */ public static function is_active( $plugin_name ) { if ( ! did_action( "plugins_loaded" ) ) { _doing_it_wrong( __METHOD__, __( 'Using this function before "plugins_loaded" action has fired can return unreliable results.', 'tribe-common' ), '4.12.6' ); } /** * Filters the array that each Tribe plugin overrides to * set itself as active when this function is called. * * @example [ 'the-events-calendar' => true, 'event-tickets' => true ] * * @since 4.12.1 * * @return array Plugin slugs as keys and bool as value for whether it's active or not. */ $plugins = apply_filters( 'tribe_active_plugins', [] ); return isset( $plugins[ $plugin_name ] ) && tribe_is_truthy( $plugins[ $plugin_name ] ); } /** * Retrieves a list of active plugins. * * @since 5.1.3 * * @return array List of active plugins. */ public function get_active_plugins() { $plugins = $this->get_list(); $plugins = array_filter( $plugins, function ( $plugin ) { return self::is_active( $plugin['short_name'] ); } ); return $plugins; } } }
Save Changes
Rename File
Rename