Files
chatwoot/app/javascript/widget/router.js
Sivin Varghese 3a693947b5 feat: Add RTL Support to Widget (#11022)
This PR adds RTL support to the web widget for improved right-to-left language compatibility, updates colors, and cleans up code.

Fixes https://linear.app/chatwoot/issue/CW-4089/rtl-issues-on-widget

https://github.com/chatwoot/chatwoot/issues/9791

Other PR: https://github.com/chatwoot/chatwoot/pull/11016
2025-03-21 09:39:03 -07:00

84 lines
2.2 KiB
JavaScript
Executable File

import { createRouter, createWebHashHistory } from 'vue-router';
import ViewWithHeader from './components/layouts/ViewWithHeader.vue';
import UnreadMessages from './views/UnreadMessages.vue';
import Campaigns from './views/Campaigns.vue';
import Home from './views/Home.vue';
import PreChatForm from './views/PreChatForm.vue';
import Messages from './views/Messages.vue';
import ArticleViewer from './views/ArticleViewer.vue';
import store from './store';
const router = createRouter({
history: createWebHashHistory(),
routes: [
{
path: '/unread-messages',
name: 'unread-messages',
component: UnreadMessages,
},
{
path: '/campaigns',
name: 'campaigns',
component: Campaigns,
},
{
path: '/',
component: ViewWithHeader,
children: [
{
path: '',
name: 'home',
component: Home,
},
{
path: '/prechat-form',
name: 'prechat-form',
component: PreChatForm,
},
{
path: '/messages',
name: 'messages',
component: Messages,
},
{
path: '/article',
name: 'article-viewer',
component: ArticleViewer,
},
],
},
],
});
/**
* Navigation Guards to Handle Route Transitions
*
* Purpose:
* Prevents duplicate form submissions and API calls during route transitions,
* especially important in high-latency scenarios.
*
* Flow:
* 1. beforeEach: Sets isUpdatingRoute to true at start of navigation
* 2. Component buttons/actions check this flag to prevent duplicate actions
* 3. afterEach: Resets the flag once navigation is complete
*
* Implementation note:
* Handling it globally, so that we can use it across all components
* to ensure consistent UI behavior during all route transitions.
*
* @see https://github.com/chatwoot/chatwoot/issues/10736
*/
router.beforeEach(async (to, from, next) => {
// Prevent any user interactions during route transition
await store.dispatch('appConfig/setRouteTransitionState', true);
next();
});
router.afterEach(() => {
// Re-enable user interactions after navigation is complete
store.dispatch('appConfig/setRouteTransitionState', false);
});
export default router;