WooCommerce: Assigning an endpoint to a custom template in my account pages

后端 未结 4 1501
情深已故
情深已故 2020-11-27 21:11

This function adds a tab named \"Special Page\" into \"My Account\" tab list:

add_filter( \'woocommerce_account_menu_items\' , \'jc_menu_panel_nav\' );

func         


        
4条回答
  •  慢半拍i
    慢半拍i (楼主)
    2020-11-27 21:38

    You can add this code to your theme's function.php:

    class My_Custom_My_Account_Endpoint {
    /**
     * Custom endpoint name.
     *
     * @var string
     */
    public static $endpoint = 'special-page';
    /**
     * Plugin actions.
     */
    public function __construct() {
        // Actions used to insert a new endpoint in the WordPress.
        add_action( 'init', array( $this, 'add_endpoints' ) );
        add_filter( 'query_vars', array( $this, 'add_query_vars' ), 0 );
        // Change the My Accout page title.
        add_filter( 'the_title', array( $this, 'endpoint_title' ) );
        // Insering your new tab/page into the My Account page.
        add_filter( 'woocommerce_account_menu_items', array( $this, 'new_menu_items' ) );
        add_action( 'woocommerce_account_' . self::$endpoint .  '_endpoint', array( $this, 'endpoint_content' ) );
    }
    /**
     * Register new endpoint to use inside My Account page.
     *
     * @see https://developer.wordpress.org/reference/functions/add_rewrite_endpoint/
     */
    public function add_endpoints() {
        add_rewrite_endpoint( self::$endpoint, EP_ROOT | EP_PAGES );
    }
    /**
     * Add new query var.
     *
     * @param array $vars
     * @return array
     */
    public function add_query_vars( $vars ) {
        $vars[] = self::$endpoint;
        return $vars;
    }
    /**
     * Set endpoint title.
     *
     * @param string $title
     * @return string
     */
    public function endpoint_title( $title ) {
        global $wp_query;
        $is_endpoint = isset( $wp_query->query_vars[ self::$endpoint ] );
        if ( $is_endpoint && ! is_admin() && is_main_query() && in_the_loop() && is_account_page() ) {
            // New page title.
            $title = __( 'Special Page', 'woocommerce' );
            remove_filter( 'the_title', array( $this, 'endpoint_title' ) );
        }
        return $title;
    }
    /**
     * Insert the new endpoint into the My Account menu.
     *
     * @param array $items
     * @return array
     */
    public function new_menu_items( $items ) {
        // Remove the logout menu item.
        $logout = $items['customer-logout'];
        unset( $items['customer-logout'] );
        // Insert your custom endpoint.
        $items[ self::$endpoint ] = __( 'Special Page', 'woocommerce' );
        // Insert back the logout item.
        $items['customer-logout'] = $logout;
        return $items;
    }
    /**
     * Endpoint HTML content.
     */
    public function endpoint_content() {
        include('woocommerce/myaccount/special-page.php');
    }
    /**
     * Plugin install action.
     * Flush rewrite rules to make our custom endpoint available.
     */
    public static function install() {
        flush_rewrite_rules();
    }
    }
    new My_Custom_My_Account_Endpoint();
    // Flush rewrite rules on plugin activation.
    register_activation_hook( __FILE__, array( 'My_Custom_My_Account_Endpoint', 'install' ) );
    

    If you don't know where is your theme's function.php:

    1.Log in to the WordPress Admin interface
    2.In the left sidebar, hover over Appearances, then click Theme Editor
    3.In the right sidebar, click functions.php

提交回复
热议问题