WhatsApp, Messenger, Telegram, Phone call⦠capture users through their favorite Apps and turn into clients
π Chat with your website visitors through their favorite chat applications. Place a floating button at the bottom of your site and give the best support to your customers.
The best WordPress plugin for WhatsApp, with more than 700,000 installations worldwide.
Documentation | Premium | Support
Set your βWhatsAppβ or βWhatsApp Businessβ number and let your visitors contact you easily:
𧩠WhatsApp Contact Button Block with optional QR Code
π± On mobile, launch WhatsApp mobile app
π» On desktop, launch WhatsApp desktop app or WhatsApp Web
π€³ On desktop, show QR Code to scan from phone
Customize your logo, profile picture or even an animated gif.
Define in which pages or zones it should appear, the delay time, if you want it to the right or to the left, only on mobile phones or also on the desktop.
You can define a tooltip or a call to action to capture the user’s interest, the limit is set by your creativity.
You can change main settings on every Post, Page, Product or CPT and for Tag or Category archive pages.
Editing your posts in the right side in the Joinchat metabox or editing your tags or categories in the Joinchat section, you can modify Phone, CTA, Start Message and Visibility options.
Use a balloon on the button to get the visitor’s attention.
In this way, you ensure that you do not miss any important message you want to give them, surprise them in a less intrusive way.
To get users to start the chat, use custom CTAs on each page, product or section.
Welcome them, help them and offer them offers or promotions. Read more
Set the first message so that the visitor can start the conversation immediately.
Use our “Dynamic Variables” and you will know what page the visitor is coming from or what product they are looking at when they start the chat.
Opt-in is a users’ consent to receive messages from a business.
Write a text with the conditions under which the visitor contacts you (or other info that you consider important).
You can make it mandatory and disable contact until the user accepts it.
Define CTAs and Custom Start Messages for shop page, product pages and for products on sale.
Add a WhatsApp Contact Button directly on your product page next to the “Add to cart” button or choose the best position, even on products without a price.
Add beautiful and customizable WhatsApp contact buttons in the Block Editor.
Ready to use patterns with different styles are also included.
Enable QR Code on desktop to allow your visitors to scan it and start messaging from their phone.
You can define phone and initial message of the button or use the post/general Joinchat settings (ideal for Reusable Blocks).
Use variables in your CTAs and Start Messages that change dynamically for each page:
{SITE} β‘ Website title
{TITLE} β‘ Current page title
{URL} β‘ Current page url
{HREF} β‘ Current page url (full with query params)
{PRODUCT} β‘ Product name (Woo)
{SKU} β‘ Product SKU (Woo)
{REGULAR} β‘ Product regular price (Woo)
{PRICE} β‘ Product current price (Woo)
{DISCOUNT} β‘ Product percent discount when is on sale (Woo)
Automatically send events to Google Analytics, Google Tag Manager and Facebook Pixel when the user opens WhatsApp.
Now can send events to multiple destinations on Google Tag!
Google Analytics 4 integration with the recommended "generate_lead"
event.
Google Ads conversion, just add your Conversion ID and Conversion Label.
You can also create your own custom events or add event parameters. View FAQs / Read more
Any element in your page can be a chat trigger, eg: it can launch WhatsApp from a link or show the Joinchat CTA when the user scrolls to the footer.
On page load (by url):
joinchat
to show chat window. Can set delay in seconds, default is 0 (e.g. example.com/page/?joinchat=5)#joinchat
to show chat window (e.g. example.com/page/#joinchat)On click:
"joinchat_app"
direct launch WhatsApp"joinchat_open"
opens Joinchat CTA"#whatsapp"
direct launch WhatsApp"#joinchat"
opens Joinchat CTASet custom phone and initial message for direct WhatsApp triggers:
data-phone="99999999"
data-message="Only for this trigger message"
.On scroll (when element appears on screen):
"joinchat_show"
opens Joinchat CTA (first time)"joinchat_force_show"
opens Joinchat CTA (always)To be able to support all your users, wherever they are. Our plugin is compatible with WPML and Polylang and also RTL languages are supported.
Direct link to edit translations when a translatable field is changed.
You choose a color and we customize the entire visual theme of the widget. With Dark Mode display the chat window with dark colors and white text. From settings you can activate it or leave it automatic and detects devices’ configuration.
Only load what need when needed. Joinchat is lightweight and follow best coding practices. See tests report
Joinchat integrates with all major Visual Editors and Page Builders and will not appear when editing a page.
Supported editors: Beaver Builder, Brizy Page Builder, Elementor, Oxygen Builder, Page Builder by SiteOrigin, Thrive Architect, Visual Composer and WP Page Builder.
Joinchat can be used without any cookies. But to automatically display the CTA, two cookies are necessary. They are first-party cookies and don’t collect personal data.
Joinchat integrates with WordPress’s Privacy Policy Guide and suggests the necessary text.
Fully extensible, with lots of filters and actions to extend its functionality or change behavior.
Extend Joinchat with awesome features:
Simple funnels like a messaging chatbot. Create lead capture, qualification or support funnels by simulating conversations with a chatbot.
NEW! Capture input fields and send webhooks to better lead generation and endless possibilities.
Contact buttons for each agent with availability times. Manage multiple WhatsApp accounts with their name, department and working hours. Your visitors will be able to contact the agent of their choice and know how long it will be until the agents are available.
A contact button with multiple WhatsApp numbers. Avoid collapsing your support, pre-sales or orders chat. Add as many WhatsApp numbers as you have support or sales staff. Your customers will randomly access each of them distributing the workload evenly.
Add more contact channels. Allows you to add more contact channels (from more than 10 apps) in addition to WhatsApp. Now you can add Telegram, Facebook Messenger, Tiktok, Snapchat, SMS, phone calls, Skype, FaceTime and more.
Enhance your Calls to Action. Create more engaging content in the chat window for better conversion. Add links, videos, images, animated GIFs, buttons or even embedded content from other platforms such as Calendly, surveys, formsβ¦
Business Chat is a versatile WordPress theme designed for businesses seeking a professional online presence. It offers a fully responsive design, built-in SEO tools, extensive customization options, and a chat integration through Joinchat. It’s compatible with popular page builders and backed by dedicated customer support. Also it’s the ultimate solution for a high-performing, user-friendly business website.
Business Chat offers both a free and a premium version, catering to businesses with varying budgets and requirements. This flexibility makes it an ideal choice for businesses looking for a comprehensive and versatile solution to establish their online presence.
creame-whatsapp-me
folder to the /wp-content/plugins/
directory.You can change the position of the button so that nothing covers it by adding this CSS in Joinchat Settings > Advanced > Custom CSS:
.joinchat { z-index:999999; }
Higher values of z-index are above, the default value is 9000.
If you need to move up:
/* always */ .joinchat { --bottom: 60px; } /* mobile only */ @media (max-width: 480px), (orientation: landscape) and (max-height: 480px) { .joinchat { --bottom: 60px; } }
You can change the button size by adding this CSS in Joinchat Settings > Advanced > Custom CSS:
/* always */ .joinchat { --s: 50px; } /* mobile only */ @media (max-width: 480px), (orientation: landscape) and (max-height: 480px) { .joinchat { --s: 40px; } }
For WooCommerce Product Button you can change size with:
.joinchat__woo-btn { --s: 50px; }
Joinchat does not provide any shortcodes, but you can easily link to WhatsApp in two ways:
#whatsapp
(open WhastApp directly) or #joinchat
(show chat window).#whatsapp
joinchat_app
(open WhastApp directly) or joinchat_open
(show chat window).<img src="contact.jpg" class="joinchat_open" alt="Contact">
This works with your phone settings and message with dynamic variables, even on pages without Joinchat visible.
For custom direct WhatsApp links you can add data-phone
and data-message
attributes.
e.g.: <a href="#whatsapp" data-phone="99999999" data-message="I want to chat">Chat now!</a>
Joinchat uses International Telephone Input library to facilitate and validate the introduction of the phone number in the format of each country. If you have problems with your phone number or you want to write it directly without any changes you can disable it with this filter (remember follow WhatsApp guidelines):
add_filter( 'joinchat_enhanced_phone', '__return_false' );
By default Joinchat settings can only be edited by users with manage_options
capability (administrator).
You can change the required capability with the filter "joinchat_capability"
.
// e.g. allow shop managers: add_filter( 'joinchat_capability', function(){ return 'manage_woocommerce'; } ); // e.g. allow editors: add_filter( 'joinchat_capability', function(){ return 'edit_pages'; } );
Since v4.4 Joinchat menu is placed as direct menu in your wp-admin but you can change it with the filter "joinchat_submenu"
:
// Show as submenu under Settings (also require "manage_options" capability) add_filter( 'joinchat_submenu', '__return_true' );
The block editor evolves quickly and errors can occur that we have not anticipated.
If you have any errors with Gutenberg and Joinchat or simply prefer the old Joinchat metabox you can use this filter:
add_filter( 'joinchat_gutenberg_sidebar', '__return_false' );
Joinchat settings are saved in your site’s main language. For other languages translation go to WPML/Polylang Settings > String translations, filter strings group by “Joinchat” and update the strings for each language.
Joinchat since 5.1 can detect multiple destinations in Google Tag and send events to all of them.
Joinchat sends a custom event when user launch WhatsApp.
If Google Analytics 4 (gtag.js) is detected, use the recommended 'generate_lead'
event:
gtag('event', 'generate_lead', { event_category: 'JoinChat', event_action: 'whatsapp: 99999999999', event_label: destination_url, chat_channel: 'whatsapp', chat_id: '99999999999', is_mobile: 'yes' | 'no', });
If your site don’t have standard names for data layer (‘dataLayer’) you can set your custom names with this PHP filter. Also can set a different event name for GA4:
add_filter( 'joinchat_get_settings', function( $settings ){ $settings['ga_event'] = 'myGA4Event'; $settings['data_layer'] = 'dataLayerCustom'; return $settings; } );
Joinchat is compatible with plugins MonsterInsights β Google Analytics Dashboard for WordPress and Google Tag Manager for WordPress custom names.
Joinchat sends a 'JoinChat'
event if GTM is detected when user launch WhatsApp:
dataLayer.push({ event: 'JoinChat', event_action: 'whatsapp: 99999999999', event_label: destination_url, chat_channel: 'whatsapp', chat_id: '99999999999', is_mobile: 'yes' | 'no', page_location: current_url, page_title: page_title, });
Joinchat sends a 'JoinChat'
custom event if Facebook Pixel is detected when user launch WhatsApp:
fbq('trackCustom', 'JoinChat', { event_action: 'whatsapp: 99999999999', event_label: destination_url, chat_channel: 'whatsapp', chat_id: '99999999999', is_mobile: 'yes' | 'no', page_location: current_url, page_title: page_title, });
Joinchat triggers custom events before launch WhatsApp 'joinchat:open'
and before send analytics events 'joinchat:event'
.
You can use them to extend them to your needs, add extra functions, cancel events or add extra parameters.
// e.g.: Send webhook to Zapier jQuery(document).on('joinchat:event', function (event, params) { jQuery.post('https://hooks.zapier.com/hooks/catch/123456/xxxxxx/', params ); }); // e.g.: Add user_is_logged param for GA4/GTM event jQuery(document).on('joinchat:event', function (event, params) { params.user_is_logged = document.body.classList.contains('logged-in') ? 'yes' : 'no'; });
Joinchat can be used without any cookies.
Depending on your Joinchat settings, two cookies may be needed. They are first-party cookies and don’t collect personal data.
joinchat_views
is a visits counter to control when to show chat window.joinchat_hashes
saves when a user has interacted with a CTA to prevent automatically show that CTA again.You can view in your Settings > Privacy > Policy Guide the suggested text by Joinchat.
#joinchat
or query param ?joinchat
.See changelog.txt for older changelog