File "link-builder.php"
Full Path: /home/siazco/grocery.siazco.se/wp-content/plugins/duplicate-post/src/ui/link-builder.php
File size: 2.78 KB
MIME-type: text/x-php
Charset: utf-8
<?php
namespace Yoast\WP\Duplicate_Post\UI;
use WP_Post;
/**
* Duplicate Post link builder.
*/
class Link_Builder {
/**
* Builds URL for duplication action for the Rewrite & Republish feature.
*
* @param int|WP_Post $post The post object or ID.
* @param string $context The context in which the URL will be used.
*
* @return string The URL for the link.
*/
public function build_rewrite_and_republish_link( $post, $context = 'display' ) {
return $this->build_link( $post, $context, 'duplicate_post_rewrite' );
}
/**
* Builds URL for the "Clone" action.
*
* @param int|WP_Post $post The post object or ID.
* @param string $context The context in which the URL will be used.
*
* @return string The URL for the link.
*/
public function build_clone_link( $post, $context = 'display' ) {
return $this->build_link( $post, $context, 'duplicate_post_clone' );
}
/**
* Builds URL for the "Copy to a new draft" action.
*
* @param int|WP_Post $post The post object or ID.
* @param string $context The context in which the URL will be used.
*
* @return string The URL for the link.
*/
public function build_new_draft_link( $post, $context = 'display' ) {
return $this->build_link( $post, $context, 'duplicate_post_new_draft' );
}
/**
* Builds URL for the "Check Changes" action.
*
* @param int|WP_Post $post The post object or ID.
* @param string $context The context in which the URL will be used.
*
* @return string The URL for the link.
*/
public function build_check_link( $post, $context = 'display' ) {
return $this->build_link( $post, $context, 'duplicate_post_check_changes' );
}
/**
* Builds URL for duplication action.
*
* @param int|WP_Post $post The post object or ID.
* @param string $context The context in which the URL will be used.
* @param string $action_name The action for the URL.
*
* @return string The URL for the link.
*/
public function build_link( $post, $context, $action_name ) {
$post = \get_post( $post );
if ( ! $post instanceof WP_Post ) {
return '';
}
if ( $context === 'display' ) {
$action = '?action=' . $action_name . '&post=' . $post->ID;
}
else {
$action = '?action=' . $action_name . '&post=' . $post->ID;
}
return \wp_nonce_url(
/**
* Filter on the URL of the clone link
*
* @param string $url The URL of the clone link.
* @param int $ID The ID of the post
* @param string $context The context in which the URL is used.
* @param string $action_name The action name.
*
* @return string
*/
\apply_filters( 'duplicate_post_get_clone_post_link', \admin_url( 'admin.php' . $action ), $post->ID, $context, $action_name ),
$action_name . '_' . $post->ID
);
}
}