Automattic\WooCommerce\Internal\Admin\Settings

PaymentsController::add_menu()publicWC 1.0

Adds the Payments top-level menu item.

Метод класса: PaymentsController{}

Хуков нет.

Возвращает

null. Ничего (null).

Использование

$PaymentsController = new PaymentsController();
$PaymentsController->add_menu();

Код PaymentsController::add_menu() WC 9.6.1

public function add_menu() {
	global $menu;

	// The WooPayments plugin must not be active.
	// When active, WooPayments will own the Payments menu item since it is the native Woo payments solution.
	if ( $this->is_woopayments_active() ) {
		return;
	}

	$menu_title = esc_html__( 'Payments', 'woocommerce' );
	$menu_icon  = '';
	// Link to the Payments settings page.
	$menu_path = 'admin.php?page=wc-settings&tab=checkout';

	add_menu_page(
		$menu_title,
		$menu_title,
		'manage_woocommerce', // Capability required to see the menu item.
		$menu_path,
		null,
		$menu_icon,
		56, // Position after WooCommerce Product menu item.
	);

	// If the store doesn't have any enabled gateways or providers need action, add a notice badge to the Payments menu item.
	if ( ! $this->store_has_enabled_gateways() || $this->store_has_providers_with_action() ) {
		$badge = ' <span class="wcpay-menu-badge awaiting-mod count-1"><span class="plugin-count">1</span></span>';
		foreach ( $menu as $index => $menu_item ) {
			// Only add the badge markup if not already present and the menu item is the Payments menu item.
			if ( 0 === strpos( $menu_item[0], $menu_title )
				&& $menu_path === $menu_item[2]
				&& false === strpos( $menu_item[0], $badge ) ) {

				$menu[ $index ][0] .= $badge; // phpcs:ignore WordPress.WP.GlobalVariablesOverride.Prohibited

				// One menu item with a badge is more than enough.
				break;
			}
		}
	}
}