Created
January 12, 2017 06:09
-
-
Save sourovroy/d4f0b65ff437d2bf8005b1f6c54d1621 to your computer and use it in GitHub Desktop.
Add new tab in woocommerce my acccount page
This file contains hidden or bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
| <?php | |
| class My_Custom_My_Account_Endpoint { | |
| /** | |
| * Custom endpoint name. | |
| * | |
| * @var string | |
| */ | |
| public static $endpoint = 'my-custom-endpoint'; | |
| /** | |
| * 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 = __( 'My Custom Endpoint', '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 ] = __( 'My Custom Endpoint', 'woocommerce' ); | |
| // Insert back the logout item. | |
| $items['customer-logout'] = $logout; | |
| return $items; | |
| } | |
| /** | |
| * Endpoint HTML content. | |
| */ | |
| public function endpoint_content() { | |
| echo '<p>Hello World!</p>'; | |
| } | |
| } | |
| new My_Custom_My_Account_Endpoint(); | |
Sign up for free
to join this conversation on GitHub.
Already have an account?
Sign in to comment