开源即时聊天、电子邮件支持、全方位服务台。可替代 Intercom、Zendesk、Salesforce Service Cloud 等。🔥💬
Go to file
Sojan Jose b981ba766f
feat: support bulk label removal (#14534)
Adds bulk label removal alongside the existing assign-label action for
conversations and contacts, so teams can clean up labels across selected
records without opening each item individually.

For conversations, the remove dropdown is scoped to labels that are
actually applied across the current selection — so agents no longer see
(or accidentally "remove") labels that aren't on any of the selected
items. For contacts, the dropdown still lists all account labels for
now; label data isn't carried on the contact list payload today, so
scoping the contact remove menu cleanly is being tracked as a follow-up.

## Closes

N/A

## How to test

- Open the conversation list, select multiple conversations, open
**Remove labels**, and confirm the dropdown only lists labels that are
applied to at least one selected conversation. Pick a label and confirm
it's removed from the selection.
- Open Contacts, select multiple contacts, use **Remove Labels**, choose
a label, and confirm the selected contacts are refreshed without that
label.
- Verify **Assign Labels** still works for conversations and contacts,
and continues to show every available label.

## What changed

- Adds an `action` prop to the shared `BulkLabelActions` dropdown so it
can render in `assign` or `remove` mode.
- Wires conversation bulk remove to the existing `labels.remove` backend
path and filters the dropdown to the union of labels applied across the
selected conversations.
- Adds contact bulk remove support through
`Contacts::BulkRemoveLabelsService`, routed by
`Contacts::BulkActionService`.
- Raises contact label save failures instead of reporting a successful
bulk action when a contact update is invalid.

## Follow-ups

- Scope the contact remove dropdown to applied labels (needs a
lightweight endpoint, or eventually `cached_label_list` on `Contact`).

## Verification

Conversation bulk remove selector:

<img width="1680" height="1050" alt="Conversation bulk remove label
selector"
src="https://github.com/user-attachments/assets/2dba4a06-c497-45e1-85b0-e700164b6b2f"
/>

Contact bulk remove selector:

<img width="1680" height="1050" alt="Contact bulk remove label selector"
src="https://github.com/user-attachments/assets/b3b89959-5978-4064-b5f9-82b1a3e571dc"
/>

Video proof:


https://github.com/user-attachments/assets/fffafe19-4e1c-4e2a-a135-c7182c06bb4d

---------

Co-authored-by: Sivin Varghese <64252451+iamsivin@users.noreply.github.com>
Co-authored-by: iamsivin <iamsivin@gmail.com>
2026-05-26 15:23:51 +05:30
__mocks__ Feature: Agent Profile Update with avatar (#449) 2020-02-16 17:20:38 +05:30
.circleci chore(deps): bump net-imap from 0.4.20 to 0.4.24 (#14361) 2026-05-14 19:51:01 -07:00
.dependabot Add Dependabot config (#217) 2019-11-25 09:48:11 +05:30
.devcontainer chore: upgrade node to v24.13 (#13291) 2026-01-15 20:28:13 -08:00
.github fix: use a dedicated PAT for ghsa linear sync gh action (#14364) 2026-05-05 17:20:22 +05:30
.husky fix: Update pre-commit hook to handle staged deleted files (#11357) 2025-04-24 16:54:53 +05:30
.qlty feat: Add Pinia support and relocate store factory (#12854) 2025-11-28 16:31:59 +05:30
.vscode feat: Add the option for consent form (#6511) 2023-02-28 13:57:05 +05:30
.windsurf/rules chore: Add development guidelines documentation for AI Agents (#11243) 2025-05-16 19:23:10 -07:00
app feat: support bulk label removal (#14534) 2026-05-26 15:23:51 +05:30
bin chore: Update translations, add pnpm sync:i18n command (#10893) 2025-02-12 17:43:46 -08:00
clevercloud feat: Add support for Clever cloud deployments (#1703) 2021-01-29 17:08:40 +05:30
config fix(whatsapp): store and surface unavailable coexistence messages (CW-7166) (#14547) 2026-05-25 18:13:59 +05:30
db fix: firecrawl long external link (#14566) 2026-05-26 14:07:07 +05:30
deployment fix: raise open file descriptor limit to prevent EMFILE errors (#13895) 2026-03-24 17:37:07 -07:00
docker Revert "chore: Upgrade Rails to 7.2.2 and update Gemfile dependencies (#11037)" 2026-02-03 21:09:42 -08:00
enterprise fix: firecrawl long external link (#14566) 2026-05-26 14:07:07 +05:30
lib fix: make zadd function optimised to stay in rubocop limits (#14520) 2026-05-21 17:24:51 +05:30
log Initial Commit 2019-08-14 15:18:44 +05:30
public feat: Add labels to contact import/export (#13313) 2026-05-06 18:46:36 +05:30
rubocop fix: stream attachment handling in workers (#12870) 2025-12-05 13:02:53 -08:00
script chore: add script to throttle bulkreindex job creation and increase meta timeouts(#12626) 2025-10-13 16:21:45 +05:30
spec feat: support bulk label removal (#14534) 2026-05-26 15:23:51 +05:30
swagger fix(openapi): document webhook secret in API schema (#14199) 2026-05-22 16:10:17 +05:30
tests/playwright chore(deps-dev): bump uuid from 13.0.0 to 14.0.0 in /tests/playwright (#14294) 2026-04-29 22:03:50 +05:30
theme feat: support bulk label removal (#14534) 2026-05-26 15:23:51 +05:30
tmp Initial Commit 2019-08-14 15:18:44 +05:30
vendor feat: Sentiment model download and upload to vendor (#7526) 2023-07-18 12:17:50 +05:30
.all-contributorsrc [docs] Move contributors section to docs (#120) 2019-10-06 09:23:24 +05:30
.annotaterb.yml fix: Annotaterb model annotation incomplete migration (#13132) 2026-03-25 17:51:06 -07:00
.browserslistrc Initial Commit 2019-08-14 15:18:44 +05:30
.bundler-audit.yml fix: [CW-7141] fix gem audit issue for sidekiq-cron and devise (#14497) 2026-05-19 20:39:40 +05:30
.dockerignore chore: add build id to settings page (#6873) 2023-04-18 00:35:35 +05:30
.editorconfig fix: Update .editorconfig to fix spaces and indent_style (#5612) 2022-10-12 14:00:42 -07:00
.env.example feat: add timeout for imap email job and skip problematic emails (#11981) 2026-05-25 15:16:52 +05:30
.eslintrc.js chore: Add "Coming Soon" overlay to voice channel selector (#11835) 2025-06-30 14:30:09 +05:30
.gitignore chore: ignore .claude directory in gitignore (#13584) 2026-02-19 13:55:15 +05:30
.nvmrc chore: upgrade node to v24.13 (#13291) 2026-01-15 20:28:13 -08:00
.prettierrc chore: Execute campaigns based on matching URL (#2254) 2021-05-17 21:38:35 +05:30
.rspec Fix url in emails, add frontendURL helper (#19) 2019-08-25 19:59:28 +05:30
.rubocop.yml Revert "chore: Upgrade Rails to 7.2.2 and update Gemfile dependencies (#11037)" 2026-02-03 21:09:42 -08:00
.ruby-version chore: upgrade ruby version to 3.4.4 (#11524) 2025-05-21 19:40:07 +05:30
.scss-lint.yml feat(apps): Shopify Integration (#11101) 2025-03-19 15:37:55 -07:00
.slugignore chore: Upgrade to Rails 7 (#6719) 2023-05-06 10:44:52 +05:30
AGENTS.md feat: allow agent bots to toggle typing status (#13705) 2026-03-05 08:13:52 -08:00
app.json fix: update omniauth to latest to resolve heroku deployment issues (#12749) 2025-10-29 08:54:29 -07:00
Capfile 🚨Fix Rubocop lint errors 2019-10-20 14:17:26 +05:30
CLAUDE.md chore: Add development guidelines documentation for AI Agents (#11243) 2025-05-16 19:23:10 -07:00
CODE_OF_CONDUCT.md General updates and add CODEOWNERS (#3685) 2022-01-05 12:37:22 +05:30
config.ru Initial Commit 2019-08-14 15:18:44 +05:30
CONTRIBUTING.md General updates and add CODEOWNERS (#3685) 2022-01-05 12:37:22 +05:30
crowdin.yml chore: Update Crowdin Config (#7375) 2023-06-23 23:02:55 +05:30
docker-compose.production.yaml fix: add named volumes for storage, postgres, and redis (#11465) 2025-05-12 17:32:12 +05:30
docker-compose.test.yaml feat: switch to postgres docker images with pgvector support (v4.0) (#10658) 2025-01-14 19:45:42 +05:30
docker-compose.yaml feat: switch to postgres docker images with pgvector support (v4.0) (#10658) 2025-01-14 19:45:42 +05:30
Gemfile feat: generate Help Center for Onboarding (#14370) 2026-05-21 16:25:01 +05:30
Gemfile.lock feat: generate Help Center for Onboarding (#14370) 2026-05-21 16:25:01 +05:30
histoire.config.ts chore(dev): Update histoire config for deployment (#12374) 2025-09-11 13:05:54 +05:30
LICENSE chore: Update year in LICENSE (#8835) 2024-02-01 15:37:05 +05:30
Makefile chore(dev): add cleanup flow to force_run in Makefile (#13093) 2026-03-04 17:56:55 -08:00
package.json chore: support PFX filetype in attachment uploads (#14456) 2026-05-22 11:09:27 +05:30
pnpm-lock.yaml chore: support PFX filetype in attachment uploads (#14456) 2026-05-22 11:09:27 +05:30
postcss.config.js feat: Vite + vue 3 💚 (#10047) 2024-10-02 00:36:30 -07:00
Procfile chore: add build id to settings page (#6873) 2023-04-18 00:35:35 +05:30
Procfile.dev feat: Vite + vue 3 💚 (#10047) 2024-10-02 00:36:30 -07:00
Procfile.test feat: Vite + vue 3 💚 (#10047) 2024-10-02 00:36:30 -07:00
Procfile.tunnel chore: Improvements for codespace (#11667) 2025-06-04 00:21:23 -05:00
Rakefile fix: Search rake task causing Rails boot error (#12416) 2025-09-15 22:21:59 +05:30
README.md chore: Update copyright year in README.md to 2026 (#13195) 2026-01-07 17:42:41 -08:00
SECURITY.md chore: Update SECURITY.md (#10705) 2025-01-16 10:59:33 -08:00
semantic.yml Chore: Update copy on Signup page (#1023) 2020-07-09 16:28:09 +05:30
tailwind.config.js feat: Add a documentation layout design for public help center portal (#14403) 2026-05-18 12:30:08 -07:00
VERSION_CW Bump version to 4.14.0 2026-05-18 21:53:43 +05:30
VERSION_CWCTL chore: upgrade node to 24.x LTS (#13004) 2026-01-12 18:10:23 +05:30
vite.config.ts chore: resolve sass and vue compiler deprecation warnings (#13794) 2026-05-22 12:16:43 +05:30
vitest.setup.js chore: Update buttons in dashboard (#11145) 2025-03-31 17:21:32 -07:00
workbox-config.js [Feature] Add PWA support (#157) 2019-10-18 12:37:09 +05:30

Header light mode Header dark mode

Chatwoot

The modern customer support platform, an open-source alternative to Intercom, Zendesk, Salesforce Service Cloud etc.

CircleCI Badge Docker Pull Badge Docker Build Badge Commits-per-month Discord uptime response time Artifact HUB

Deploy Deploy to DO

Chat dashboard dark mode Chat dashboard

Chatwoot is the modern, open-source, and self-hosted customer support platform designed to help businesses deliver exceptional customer support experience. Built for scale and flexibility, Chatwoot gives you full control over your customer data while providing powerful tools to manage conversations across channels.

Captain AI Agent for Support

Supercharge your support with Captain, Chatwoots AI agent. Captain helps automate responses, handle common queries, and reduce agent workload—ensuring customers get instant, accurate answers. With Captain, your team can focus on complex conversations while routine questions are resolved automatically. Read more about Captain here.

💬 Omnichannel Support Desk

Chatwoot centralizes all customer conversations into one powerful inbox, no matter where your customers reach out from. It supports live chat on your website, email, Facebook, Instagram, Twitter, WhatsApp, Telegram, Line, SMS etc.

📚 Help center portal

Publish help articles, FAQs, and guides through the built-in Help Center Portal. Enable customers to find answers on their own, reduce repetitive queries, and keep your support team focused on more complex issues.

🗂️ Other features

Collaboration & Productivity

  • Private Notes and @mentions for internal team discussions.
  • Labels to organize and categorize conversations.
  • Keyboard Shortcuts and a Command Bar for quick navigation.
  • Canned Responses to reply faster to frequently asked questions.
  • Auto-Assignment to route conversations based on agent availability.
  • Multi-lingual Support to serve customers in multiple languages.
  • Custom Views and Filters for better inbox organization.
  • Business Hours and Auto-Responders to manage response expectations.
  • Teams and Automation tools for scaling support workflows.
  • Agent Capacity Management to balance workload across the team.

Customer Data & Segmentation

  • Contact Management with profiles and interaction history.
  • Contact Segments and Notes for targeted communication.
  • Campaigns to proactively engage customers.
  • Custom Attributes for storing additional customer data.
  • Pre-Chat Forms to collect user information before starting conversations.

Integrations

  • Slack Integration to manage conversations directly from Slack.
  • Dialogflow Integration for chatbot automation.
  • Dashboard Apps to embed internal tools within Chatwoot.
  • Shopify Integration to view and manage customer orders right within Chatwoot.
  • Use Google Translate to translate messages from your customers in realtime.
  • Create and manage Linear tickets within Chatwoot.

Reports & Insights

  • Live View of ongoing conversations for real-time monitoring.
  • Conversation, Agent, Inbox, Label, and Team Reports for operational visibility.
  • CSAT Reports to measure customer satisfaction.
  • Downloadable Reports for offline analysis and reporting.

Documentation

Detailed documentation is available at chatwoot.com/help-center.

Translation process

The translation process for Chatwoot web and mobile app is managed at https://translate.chatwoot.com using Crowdin. Please read the translation guide for contributing to Chatwoot.

Branching model

We use the git-flow branching model. The base branch is develop. If you are looking for a stable version, please use the master or tags labelled as v1.x.x.

Deployment

Heroku one-click deploy

Deploying Chatwoot to Heroku is a breeze. It's as simple as clicking this button:

Deploy

Follow this link to understand setting the correct environment variables for the app to work with all the features. There might be breakages if you do not set the relevant environment variables.

DigitalOcean 1-Click Kubernetes deployment

Chatwoot now supports 1-Click deployment to DigitalOcean as a kubernetes app.

Deploy to DO

Other deployment options

For other supported options, checkout our deployment page.

Security

Looking to report a vulnerability? Please refer our SECURITY.md file.

Community

If you need help or just want to hang out, come, say hi on our Discord server.

Contributors

Thanks goes to all these wonderful people:

Chatwoot © 2017-2026, Chatwoot Inc - Released under the MIT License.