DEV Community

Cover image for How to Add an Announcement Banner to your React Navbar
Hrushi M
Hrushi M

Posted on • Originally published at blog.superflows.dev

How to Add an Announcement Banner to your React Navbar

Introduction

This article shows you how to add an announcement banner to your react navbar. It shows you how to show / hide the banner, how to customize the texts, how to listen to handle callbacks, how to do further styling and how to inject your own components.

Prerequisites

This article assumes that you have read the previous navbar tutorials. In case you haven't you will find a consolidated list in the reference links section. This article assumes that you have installed the Superflows library, have the default navigation bar up and running, have added your brand information, have also customised your menu, have added the search input, have configured the sign in button, have understood how to insert user profile information into the navbar, have seen how to add a back button to the navbar and have also understood how to add notifications to it. This tutorial takes it forward from there.

Step 1 - Display the Banner Section

By default banner is not visible. To show it, set the showBanner prop to true. You will see that a default banner is now visible. It has four customizable elements - (1) container, (2) text message, (3) call-to-action button and (4) dismiss button.

function Apps(props) {

    return (
        <div>
            <SfNav showBanner={true}/>
        </div>
    );
}
Enter fullscreen mode Exit fullscreen mode

It renders as follows:

visible

visible mobile

Step 2 - Customize the Banner Text Message

To change the banner text, set the intended string value to the bannerText property. For mobile screens, a separate (optional) prop bannerTextMobile has also been provided, which you can use as well!

function Apps(props) {

    return (
        <div>
            <SfNav showBanner={true} bannerText={"30% OFF On Select Products πŸ’°"} bannerTextMobile={"30% OFF πŸ’°"} />
        </div>
    );
}
Enter fullscreen mode Exit fullscreen mode

It renders as follows:

banner_text

banner_text_mobile

Step 3 - Customize the Call-to-action Button

To change the text of the call-to-action button, set the intended string value to the bannerCta property. For mobile screens, a separate (optional) prop bannerCtaMobile has also been provided, which you can use as well!

function Apps(props) {

    return (
        <div>
            <SfNav showBanner={true} bannerText={"30% Summer Discount πŸ’°"} bannerTextMobile={"30% OFF πŸ’°"} bannerCta={"Buy Now"} bannerCtaMobile={"Buy"} />
        </div>
    );
}
Enter fullscreen mode Exit fullscreen mode

It renders as follows:

banner_cta

banner_cta_mobile

Step 4- Handle the Call-to-action Callback

You can subscribe to the onBannerCtaPressed prop to listen to get a callback after the user clicks on the call-to-action button. As follows:

function Apps(props) {

    return (
        <div>
            <SfNav showBanner={true} showBanner={true} bannerText={"30% Summer Discount πŸ’°"} bannerTextMobile={"30% OFF πŸ’°"} bannerCta={"Buy Now"} bannerCtaMobile={"Buy"} onBannerCtaPressed={() => {alert('clicked on cta');}} />
        </div>
    );
}
Enter fullscreen mode Exit fullscreen mode

Step 5 - Show / Hide the Dismiss Button

By default, the dismiss button is visible. When the user clicks on it, the banner gets dismissed (hidden). You can also choose to make the banner permanent, by hiding the dismiss button. Set the bannerEnableDismiss prop to false.

function Apps(props) {

    return (
        <div>
            <SfNav showBanner={true} bannerEnableDismiss={false} />
        </div>
    );
}
Enter fullscreen mode Exit fullscreen mode

It renders as follows:

dismiss

dismiss_mobile

Step 5 - Advanced Customization

If you need full control over the look and feel of the banner section, you can utilize inline css. Just use any of the banner related style properties. Showing an example below:

function Apps(props) {

    return (
        <div>
            <SfNav showBanner={true} showBanner={true} bannerText={"30% Summer Discount πŸ’°"} bannerTextMobile={"30% OFF πŸ’°"} bannerCta={"Buy Now"} bannerCtaMobile={"Buy"} stylesBannerContainer={{backgroundColor: 'black', paddingTop: '10px', paddingBottom: '10px'}} stylesBannerCta={{backgroundColor: 'white', color: 'black', fontSize: '120%'}} stylesBannerText={{fontSize: '120%'}} />
        </div>
    );
}
Enter fullscreen mode Exit fullscreen mode

It renders as follows:

advanced

advanced_mobile

Step 6 - Inject Your Custom Component

You can also replace the existing banner with your own custom component. Simply assign your custom component to the bannerComponent prop. You can also set an optional custom component differently for mobiles, use the bannerComponentMobile prop. An example is shown below:

function Apps(props) {

    return (
        <div>
            <SfNav showBanner={true} bannerComponent={<div style={{backgroundColor: 'black', height: '50px', display: 'flex', justifyContent: 'center', alignItems: 'center', color: 'white'}}><div>We will be down for maintenance tomorrow 13:00 - 13:30 hrs</div><img src="https://www.route66sodas.com/wp-content/uploads/2019/01/Alert.gif" style={{width: '30px', height: '30px', marginBottom: '5px', marginLeft: '10px'}}/></div>} bannerComponentMobile={<div style={{backgroundColor: 'black', height: '50px', display: 'flex', justifyContent: 'center', alignItems: 'center', color: 'white'}}><div>Maintenance tomorrow 13:00 hrs</div><img src="https://www.route66sodas.com/wp-content/uploads/2019/01/Alert.gif" style={{width: '30px', height: '30px', marginBottom: '5px', marginLeft: '10px'}}/></div>} />
        </div>
    );
}
Enter fullscreen mode Exit fullscreen mode

It renders as follows:

inject

inject

Reference Links

Documentation

This link

Demo Project For This Tutorial

This link

Previous Tutorials of Navbar

YouTube Channel

This link

Discord Community

This link

Example Projects Collection

This link

Video Tutorial

Conclusion

You have already seen how to get started with the navigation bar, how to insert brand information into it, how to customise the menu and now, how to configure the search input, how to use the sign in button, how to insert profile information into it, how to add a back button, how to add notifications to it and now, how to add an announcement banner.

Top comments (4)

Collapse
 
alvimutmex profile image
alvimutmex

To add an announcement banner to your React navbar, create a new component for the banner with a state to manage its visibility and message content. Include the banner component above your navbar in your app layout to ensure it is displayed at the top. Use conditional rendering to show or hide the banner based on your state. Style the banner with CSS to match your branding and make the announcement stand out. Consider using vinyl banners for inspiration to create visually appealing and durable designs. Ensure the announcement banner is responsive for a consistent user experience across devices.

Collapse
 
jasurkurbanov profile image
Jasur Kurbanov

Hi Hrushi can you share your email address. I have question which is private to you regarding consulting company

Collapse
 
superflowsdev profile image
Hrushi M

DM me on twitter @hrushi

Collapse
 
jasurkurbanov profile image
Jasur Kurbanov

Can't DM to you on twitter.