144 lines
3.9 KiB
PHP
Executable File
144 lines
3.9 KiB
PHP
Executable File
<?php
|
|
/**
|
|
* Mobile Menu icon
|
|
*
|
|
* @package OceanWP WordPress theme
|
|
*/
|
|
|
|
// Exit if accessed directly.
|
|
if ( ! defined( 'ABSPATH' ) ) {
|
|
exit;
|
|
}
|
|
|
|
// Return if disabled.
|
|
if ( ! oceanwp_display_navigation() ) {
|
|
return;
|
|
}
|
|
|
|
// Menu Location.
|
|
$menu_location = apply_filters( 'ocean_main_menu_location', 'main_menu' );
|
|
|
|
// Multisite global menu.
|
|
$ms_global_menu = apply_filters( 'ocean_ms_global_menu', false );
|
|
|
|
// Menu data attributes.
|
|
$toggle_menu_attrs = apply_filters( 'oceanwp_menu_toggle_data_attrs', '' );
|
|
|
|
// Display if menu is defined.
|
|
if ( has_nav_menu( $menu_location ) || $ms_global_menu ) :
|
|
|
|
// Get menu icon.
|
|
$icon = get_theme_mod( 'ocean_mobile_menu_open_icon', 'fa fa-bars' );
|
|
$icon = apply_filters( 'ocean_mobile_menu_navbar_open_icon', $icon );
|
|
|
|
// Custom hamburger button.
|
|
$btn = get_theme_mod( 'ocean_mobile_menu_open_hamburger', 'default' );
|
|
|
|
// Get menu text.
|
|
$text = get_theme_mod( 'ocean_mobile_menu_text' );
|
|
$text = oceanwp_tm_translation( 'ocean_mobile_menu_text', $text );
|
|
$text = $text ? $text : esc_html__( 'Menu', 'oceanwp' );
|
|
|
|
// Get close menu text.
|
|
$close_text = get_theme_mod( 'ocean_mobile_menu_close_text' );
|
|
$close_text = oceanwp_tm_translation( 'ocean_mobile_menu_close_text', $close_text );
|
|
$close_text = $close_text ? $close_text : esc_html__( 'Close', 'oceanwp' );
|
|
|
|
if ( OCEANWP_WOOCOMMERCE_ACTIVE ) {
|
|
|
|
// Get cart icon.
|
|
$woo_icon = get_theme_mod( 'ocean_woo_menu_icon', 'icon_handbag' );
|
|
$woo_icon = in_array( $woo_icon, oceanwp_get_cart_icons() ) && $woo_icon ? $woo_icon : 'icon_handbag';
|
|
|
|
// If has custom cart icon.
|
|
$custom_icon = get_theme_mod( 'ocean_woo_menu_custom_icon' );
|
|
if ( '' !== $custom_icon ) {
|
|
$woo_icon = $custom_icon;
|
|
}
|
|
|
|
if ( '' !== $custom_icon ) {
|
|
$cart_icon = '<i class="' . esc_attr( $woo_icon ) . '" aria-hidden="true"></i>';
|
|
} else {
|
|
$cart_icon = oceanwp_icon( $woo_icon, false );
|
|
}
|
|
|
|
// Cart Icon.
|
|
$cart_icon = apply_filters( 'ocean_menu_cart_icon_html', $cart_icon );
|
|
|
|
}
|
|
|
|
// Classes.
|
|
$classes = array( 'oceanwp-mobile-menu-icon', 'clr' );
|
|
|
|
// Position.
|
|
if ( 'three' === get_theme_mod( 'ocean_mobile_elements_positioning', 'one' ) ) {
|
|
$classes[] = 'mobile-left';
|
|
} else {
|
|
$classes[] = 'mobile-right';
|
|
}
|
|
|
|
// Turn classes into space seperated string.
|
|
$classes = implode( ' ', $classes ); ?>
|
|
|
|
<?php do_action( 'ocean_mobile_menu_icon_before' ); ?>
|
|
|
|
<div class="<?php echo esc_attr( $classes ); ?>">
|
|
|
|
<?php do_action( 'ocean_before_mobile_icon' ); ?>
|
|
|
|
<?php
|
|
// If big header style.
|
|
if ( 'big' === oceanwp_header_style() ) {
|
|
?>
|
|
<div class="container clr">
|
|
<?php
|
|
}
|
|
?>
|
|
|
|
<?php do_action( 'ocean_before_mobile_icon_inner' ); ?>
|
|
|
|
<a href="#" class="mobile-menu" <?php echo $toggle_menu_attrs; // phpcs:ignore WordPress.Security.EscapeOutput.OutputNotEscaped ?> aria-label="<?php esc_attr_e( 'Mobile Menu', 'oceanwp' ); ?>">
|
|
<?php
|
|
if ( 'default' !== $btn ) {
|
|
?>
|
|
<div class="hamburger hamburger--<?php echo esc_attr( $btn ); ?>" aria-expanded="false" role="navigation">
|
|
<div class="hamburger-box">
|
|
<div class="hamburger-inner"></div>
|
|
</div>
|
|
</div>
|
|
<?php
|
|
} else {
|
|
?>
|
|
<i class="<?php echo esc_attr( $icon ); ?>" aria-hidden="true"></i>
|
|
<?php
|
|
}
|
|
|
|
// Mobile menu text.
|
|
if ( get_theme_mod( 'ocean_mobile_menu_display_opening_text', true ) ) {
|
|
?>
|
|
<span class="oceanwp-text"><?php echo do_shortcode( $text ); ?></span>
|
|
<span class="oceanwp-close-text"><?php echo do_shortcode( $close_text ); ?></span>
|
|
<?php
|
|
}
|
|
?>
|
|
</a>
|
|
|
|
<?php do_action( 'ocean_after_mobile_icon_inner' ); ?>
|
|
|
|
<?php
|
|
// If big header style.
|
|
if ( 'big' === oceanwp_header_style() ) {
|
|
?>
|
|
</div>
|
|
<?php
|
|
}
|
|
?>
|
|
|
|
<?php do_action( 'ocean_after_mobile_icon' ); ?>
|
|
|
|
</div><!-- #oceanwp-mobile-menu-navbar -->
|
|
|
|
<?php do_action( 'ocean_mobile_menu_icon_after' ); ?>
|
|
|
|
<?php endif; ?>
|