Files
doitinpoland.com/wp-content/plugins/sitepress-multilingual-cms/classes/menu/translation-services/Section.php
2023-09-12 21:41:04 +02:00

112 lines
2.3 KiB
PHP

<?php
namespace WPML\TM\Menu\TranslationServices;
class Section implements \IWPML_TM_Admin_Section {
const SLUG = 'translators';
/**
* The SitePress instance.
*
* @var \SitePress
*/
private $sitepress;
/**
* The WPML_WP_API instance.
*
* @var \WPML_WP_API
*/
private $wp_api;
/**
* The template to use.
*
* @var mixed $template
*/
private $template;
/**
* WPML_TM_Translation_Services_Admin_Section constructor.
*
* @param \SitePress $sitepress The SitePress instance.
* @param callable $template The template to use.
*/
public function __construct(
\SitePress $sitepress,
$template
) {
$this->sitepress = $sitepress;
$this->wp_api = $sitepress->get_wp_api();
$this->template = $template;
}
/**
* Returns a value which will be used for sorting the sections.
*
* @return int
*/
public function get_order() {
return 400;
}
/**
* Outputs the content of the section.
*/
public function render() {
call_user_func( $this->template );
}
/**
* Used to extend the logic for displaying/hiding the section.
*
* @return bool
*/
public function is_visible() {
return ! $this->wp_api->constant( 'ICL_HIDE_TRANSLATION_SERVICES' ) && ( $this->wp_api->constant( 'WPML_BYPASS_TS_CHECK' ) || ! $this->sitepress->get_setting( 'translation_service_plugin_activated' ) );
}
/**
* Returns the unique slug of the sections which is used to build the URL for opening this section.
*
* @return string
*/
public function get_slug() {
return self::SLUG;
}
/**
* Returns one or more capabilities required to display this section.
*
* @return string|array
*/
public function get_capabilities() {
return [ \WPML_Manage_Translations_Role::CAPABILITY, 'manage_options' ];
}
/**
* Returns the caption to display in the section.
*
* @return string
*/
public function get_caption() {
return __( 'Translation Services', 'wpml-translation-management' );
}
/**
* Returns the callback responsible for rendering the content of the section.
*
* @return callable
*/
public function get_callback() {
return array( $this, 'render' );
}
/**
* This method is hooked to the `admin_enqueue_scripts` action.
*
* @param string $hook The current page.
*/
public function admin_enqueue_scripts( $hook ) {}
}