Lexington has been awarded a grant from Astro, to celebrate. Get a 30% discount. Apply code LEXINGTON30 at checkout.
Yesterday I was asked to create a chat bubble with alpinejs despite. So here it is.
A chat bubble is a small bubble that appears on the screen when this one is toggled, normally with a button that says “Chat”, “Help”, or “Contact”. This one is normally on the bottom right of the screen and it contains a form and inputs that allows the user to send a message to another person.
This is the structure of the project: Understanding the code:
x-show="open"
: This is the condition that determines whether the chat bubble is visible or not.absolute
: This is the positioning of the icons. So they can change once is toggled.x-show="!open"
: This is the condition that determines whether the first icon is visible or not.x-transition:enter-start="opacity-0 -rotate-45 scale-75"
: This is the transition that starts when the chat bubble is opened.x-transition:enter="transition duration-200 transform ease"
: This is the transition that animates the chat bubble when it is opened.x-transition:leave="transition duration-100 transform ease"
: This is the transition that animates the chat bubble when it is closed.x-transition:leave-end="opacity-0 -rotate-45"
: This is the transition that ends when the chat bubble is closed. x-show="open"
: This is the condition that determines whether the second icon is visible or not.x-transition:enter-start="opacity-0 rotate-45 scale-75"
: This is the transition that starts when the chat bubble is opened.x-transition:enter="transition duration-200 transform ease"
: This is the transition that animates the chat bubble when it is opened.x-transition:leave="transition duration-100 transform ease"
: This is the transition that animates the chat bubble when it is closed.x-transition:leave-end="opacity-0 -rotate-45"
: This is the transition that ends when the chat bubble is closed.Classes and irrelevant content are removed for brevity, but I’ll keep those classes relevant to the tutorial.
<!-- toggle buttons -->
<button
@click="open = !open">
<svg
class="absolute"
x-show="!open"
x-transition:enter-start="opacity-0 -rotate-45 scale-75"
x-transition:enter="transition duration-200 transform ease"
x-transition:leave="transition duration-100 transform ease"
x-transition:leave-end="opacity-0 -rotate-45">
<!-- SVG Content goes here -->
</svg>
<svg
class="absolute"
x-show="open"
x-transition:enter-start="opacity-0 rotate-45 scale-75"
x-transition:enter="transition duration-200 transform ease"
x-transition:leave="transition duration-100 transform ease"
x-transition:leave-end="opacity-0 rotate-45">
<!-- SVG Content goes here -->
</svg>
</button>
</div>
x-data="{ open: false }"
: This is the data object that holds the open state of the chat bubble.x-show="open"
: This is the condition that determines whether the chat bubble is visible or not.x-transition:enter-start="opacity-0 translate-y-5"
: This is the transition that starts when the chat bubble is opened.x-transition:enter="transition duration-200 transform ease"
: This is the transition that animates the chat bubble when it is opened.x-transition:leave="transition duration-200 transform ease"
: This is the transition that animates the chat bubble when it is closed.x-transition:leave-end="opacity-0 translate-y-5"
: This is the transition that ends when the chat bubble is closed.@click.away="open = false"
: This is the event listener that closes the chat bubble when the user clicks outside of it.Classes and irrelevant content are removed for brevity, but I’ll keep those classes relevant to the tutorial.
<div
x-data="{ open: false }">
<div
id="#"
x-show="open"
x-transition:enter-start="opacity-0 translate-y-5"
x-transition:enter="transition duration-200 transform ease"
x-transition:leave="transition duration-200 transform ease"
x-transition:leave-end="opacity-0 translate-y-5"
@click.away="open = false"
class="fixed flex flex-col z-50 bottom-[100px] top-0 ring-0 left-0 sm:top-auto sm:right-5 sm:left-auto h-[calc(100%-95px)] w-full sm:w-[350px] overflow-auto min-h-[250px] sm:h-[600px] ">
<!-- Chat Bubble goes here -->
</div>
This is a simple chat bubble that uses Tailwind CSS and Alpinejs. It’s a great starting point for building more complex chat bubbles and checkout the other tutorials for more advanced examples. Remember to add validation and error handling to make sure the chat bubble is always up-to-date, accurate, secure and accessible.
Something good to know is that there is already companies that offer chat bubbles, so you can use them as a starting point and avoid all the hustle of building your own.
Hope you enjoyed this tutorial and have a great day!
/Michael Andreuzza
Get access to all themes
Unlock all themes for $199 for forever! Includes lifetime updates,
new themes, unlimited projects, and support
— No subscription
needed.