Файловый менеджер - Редактировать - /var/www/xthruster/html/wp-content/plugins/duplicate-post/src/ui/classic-editor.php
Назад
<?php namespace Yoast\WP\Duplicate_Post\UI; use WP_Post; use Yoast\WP\Duplicate_Post\Permissions_Helper; use Yoast\WP\Duplicate_Post\Utils; /** * Duplicate Post class to manage the classic editor UI. */ class Classic_Editor { /** * Holds the object to create the action link to duplicate. * * @var Link_Builder */ protected $link_builder; /** * Holds the permissions helper. * * @var Permissions_Helper */ protected $permissions_helper; /** * Holds the asset manager. * * @var Asset_Manager */ protected $asset_manager; /** * Initializes the class. * * @param Link_Builder $link_builder The link builder. * @param Permissions_Helper $permissions_helper The permissions helper. * @param Asset_Manager $asset_manager The asset manager. */ public function __construct( Link_Builder $link_builder, Permissions_Helper $permissions_helper, Asset_Manager $asset_manager ) { $this->link_builder = $link_builder; $this->permissions_helper = $permissions_helper; $this->asset_manager = $asset_manager; } /** * Adds hooks to integrate with WordPress. * * @return void */ public function register_hooks() { \add_action( 'post_submitbox_misc_actions', [ $this, 'add_check_changes_link' ], 90 ); if ( \intval( Utils::get_option( 'duplicate_post_show_link_in', 'submitbox' ) ) === 1 ) { if ( \intval( Utils::get_option( 'duplicate_post_show_link', 'new_draft' ) ) === 1 ) { \add_action( 'post_submitbox_start', [ $this, 'add_new_draft_post_button' ] ); } if ( \intval( Utils::get_option( 'duplicate_post_show_link', 'rewrite_republish' ) ) === 1 ) { \add_action( 'post_submitbox_start', [ $this, 'add_rewrite_and_republish_post_button' ] ); } } \add_action( 'load-post.php', [ $this, 'hook_translations' ] ); \add_filter( 'post_updated_messages', [ $this, 'change_scheduled_notice_classic_editor' ] ); \add_action( 'admin_enqueue_scripts', [ $this, 'enqueue_classic_editor_scripts' ] ); if ( \intval( Utils::get_option( 'duplicate_post_show_link_in', 'submitbox' ) ) === 1 ) { if ( \intval( Utils::get_option( 'duplicate_post_show_link', 'new_draft' ) ) === 1 || \intval( Utils::get_option( 'duplicate_post_show_link', 'rewrite_republish' ) ) === 1 ) { \add_action( 'admin_enqueue_scripts', [ $this, 'enqueue_classic_editor_styles' ] ); } } // Remove slug editing from Classic Editor. \add_action( 'add_meta_boxes', [ $this, 'remove_slug_meta_box' ], 10, 2 ); \add_filter( 'get_sample_permalink_html', [ $this, 'remove_sample_permalink_slug_editor' ], 10, 5 ); } /** * Hooks the functions to change the translations. * * @return void */ public function hook_translations() { \add_filter( 'gettext', [ $this, 'change_republish_strings_classic_editor' ], 10, 3 ); \add_filter( 'gettext_with_context', [ $this, 'change_schedule_strings_classic_editor' ], 10, 4 ); } /** * Enqueues the necessary JavaScript code for the Classic editor. * * @return void */ public function enqueue_classic_editor_scripts() { if ( $this->permissions_helper->is_classic_editor() && isset( $_GET['post'] ) ) { $id = \intval( \wp_unslash( $_GET['post'] ) ); $post = \get_post( $id ); if ( ! \is_null( $post ) && $this->permissions_helper->is_rewrite_and_republish_copy( $post ) ) { $this->asset_manager->enqueue_strings_script(); } } } /** * Enqueues the necessary styles for the Classic editor. * * @return void */ public function enqueue_classic_editor_styles() { if ( $this->permissions_helper->is_classic_editor() && isset( $_GET['post'] ) ) { $id = \intval( \wp_unslash( $_GET['post'] ) ); $post = \get_post( $id ); if ( ! \is_null( $post ) && $this->permissions_helper->should_links_be_displayed( $post ) ) { $this->asset_manager->enqueue_styles(); } } } /** * Adds a button in the post/page edit screen to create a clone * * @param WP_Post|null $post The post object that's being edited. * * @return void */ public function add_new_draft_post_button( $post = null ) { if ( \is_null( $post ) ) { if ( isset( $_GET['post'] ) ) { $id = \intval( \wp_unslash( $_GET['post'] ) ); $post = \get_post( $id ); } } if ( $post instanceof WP_Post && $this->permissions_helper->should_links_be_displayed( $post ) ) { ?> <div id="duplicate-action"> <a class="submitduplicate duplication" href="<?php echo \esc_url( $this->link_builder->build_new_draft_link( $post ) ); ?>"><?php \esc_html_e( 'Copy to a new draft', 'duplicate-post' ); ?> </a> </div> <?php } } /** * Adds a button in the post/page edit screen to create a clone for Rewrite & Republish. * * @param WP_Post|null $post The post object that's being edited. * * @return void */ public function add_rewrite_and_republish_post_button( $post = null ) { if ( \is_null( $post ) ) { if ( isset( $_GET['post'] ) ) { $id = \intval( \wp_unslash( $_GET['post'] ) ); $post = \get_post( $id ); } } if ( $post instanceof WP_Post && $this->permissions_helper->should_rewrite_and_republish_be_allowed( $post ) && $this->permissions_helper->should_links_be_displayed( $post ) ) { ?> <div id="rewrite-republish-action"> <a class="submitduplicate duplication" href="<?php echo \esc_url( $this->link_builder->build_rewrite_and_republish_link( $post ) ); ?>"><?php \esc_html_e( 'Rewrite & Republish', 'duplicate-post' ); ?> </a> </div> <?php } } /** * Adds a message in the post/page edit screen to create a clone for Rewrite & Republish. * * @param WP_Post|null $post The post object that's being edited. * * @return void */ public function add_check_changes_link( $post = null ) { if ( \is_null( $post ) ) { if ( isset( $_GET['post'] ) ) { $id = \intval( \wp_unslash( $_GET['post'] ) ); $post = \get_post( $id ); } } if ( $post instanceof WP_Post && $this->permissions_helper->is_rewrite_and_republish_copy( $post ) ) { ?> <div id="check-changes-action" class="misc-pub-section"> <?php \esc_html_e( 'Do you want to compare your changes with the original version before merging? Please save any changes first.', 'duplicate-post' ); ?> <br><br> <a class='button' href=<?php echo \esc_url( $this->link_builder->build_check_link( $post ) ); ?>> <?php \esc_html_e( 'Compare', 'duplicate-post' ); ?> </a> </div> <?php } } /** * Changes the 'Publish' copies in the submitbox to 'Republish' if a post is intended for republishing. * * @param string $translation The translated text. * @param string $text The text to translate. * @param string $domain The translation domain. * * @return string The to-be-used copy of the text. */ public function change_republish_strings_classic_editor( $translation, $text, $domain ) { if ( $domain !== 'default' ) { return $translation; } if ( $text === 'Publish' && $this->should_change_rewrite_republish_copy( \get_post() ) ) { return \__( 'Republish', 'duplicate-post' ); } elseif ( $text === 'Publish on: %s' && $this->should_change_rewrite_republish_copy( \get_post() ) ) { /* translators: %s: Date on which the post is to be republished. */ return \__( 'Republish on: %s', 'duplicate-post' ); } return $translation; } /** * Changes the 'Schedule' copy in the submitbox to 'Schedule republish' if a post is intended for republishing. * * @param string $translation The translated text. * @param string $text The text to translate. * @param string $context The translation context. * @param string $domain The translation domain. * * @return string The to-be-used copy of the text. */ public function change_schedule_strings_classic_editor( $translation, $text, $context, $domain ) { if ( $domain !== 'default' || $context !== 'post action/button label' ) { return $translation; } if ( $text === 'Schedule' && $this->should_change_rewrite_republish_copy( \get_post() ) ) { return \__( 'Schedule republish', 'duplicate-post' ); } return $translation; } /** * Changes the post-scheduled notice when a post or page intended for republishing is scheduled. * * @param array[] $messages Post updated messaged. * * @return array[] The to-be-used messages. */ public function change_scheduled_notice_classic_editor( $messages ) { $post = \get_post(); if ( ! $this->should_change_rewrite_republish_copy( $post ) ) { return $messages; } $permalink = \get_permalink( $post->ID ); $scheduled_date = \get_the_time( \get_option( 'date_format' ), $post ); $scheduled_time = \get_the_time( \get_option( 'time_format' ), $post ); if ( $post->post_type === 'post' ) { $messages['post'][9] = \sprintf( /* translators: 1: The post title with a link to the frontend page, 2: The scheduled date and time. */ \esc_html__( 'This rewritten post %1$s is now scheduled to replace the original post. It will be published on %2$s.', 'duplicate-post' ), '<a href="' . $permalink . '">' . $post->post_title . '</a>', '<strong>' . $scheduled_date . ' ' . $scheduled_time . '</strong>' ); return $messages; } if ( $post->post_type === 'page' ) { $messages['page'][9] = \sprintf( /* translators: 1: The page title with a link to the frontend page, 2: The scheduled date and time. */ \esc_html__( 'This rewritten page %1$s is now scheduled to replace the original page. It will be published on %2$s.', 'duplicate-post' ), '<a href="' . $permalink . '">' . $post->post_title . '</a>', '<strong>' . $scheduled_date . ' ' . $scheduled_time . '</strong>' ); } return $messages; } /** * Determines if the Rewrite & Republish copies for the post should be used. * * @param WP_Post $post The current post object. * * @return bool True if the Rewrite & Republish copies should be used. */ public function should_change_rewrite_republish_copy( $post ) { global $pagenow; if ( ! \in_array( $pagenow, [ 'post.php', 'post-new.php' ], true ) ) { return false; } if ( ! $post instanceof WP_Post ) { return false; } return $this->permissions_helper->is_rewrite_and_republish_copy( $post ); } /** * Removes the slug meta box in the Classic Editor when the post is a Rewrite & Republish copy. * * @param string $post_type Post type. * @param WP_Post $post Post object. * * @return void */ public function remove_slug_meta_box( $post_type, $post ) { if ( $post instanceof WP_Post && $this->permissions_helper->is_rewrite_and_republish_copy( $post ) ) { \remove_meta_box( 'slugdiv', $post_type, 'normal' ); } } /** * Removes the sample permalink slug editor in the Classic Editor when the post is a Rewrite & Republish copy. * * @param string $html Sample permalink HTML markup. * @param int $post_id Post ID. * @param string $new_title New sample permalink title. * @param string $new_slug New sample permalink slug. * @param WP_Post $post Post object. * * @return string The filtered HTML of the sample permalink slug editor. */ public function remove_sample_permalink_slug_editor( $html, $post_id, $new_title, $new_slug, $post ) { if ( ! $post instanceof WP_Post ) { return $html; } if ( $this->permissions_helper->is_rewrite_and_republish_copy( $post ) ) { return ''; } return $html; } }
| ver. 1.4 |
Github
|
.
| PHP 7.4.3-4ubuntu2.24 | Генерация страницы: 0 |
proxy
|
phpinfo
|
Настройка