Automattic\WooCommerce\Internal\Admin\Settings
PaymentsController::add_menu()
Adds the Payments top-level menu item.
Метод класса: PaymentsController{}
Хуков нет.
Возвращает
null
. Ничего (null).
Использование
$PaymentsController = new PaymentsController(); $PaymentsController->add_menu();
Код 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; } } } }