mirror of
https://github.com/lingble/chatwoot.git
synced 2025-11-02 12:08:01 +00:00
* feat: Add vue-router to widget Co-authored-by: Pranav <pranav@chatwoot.com> * Move to dynamic imports * Move to routerMixin * Fix popup button display * Remove unnecessary import * router -> route * Fix open state * Fix issues * Remove used CSS * Fix specs * Fix specs * Fix widgetColor specs * Fix mutation specs * Fixes broken lint errors * Fixes issues with widget flow Co-authored-by: Nithin <nithin@chatwoot.com> Co-authored-by: Nithin David <1277421+nithindavid@users.noreply.github.com> Co-authored-by: Muhsin Keloth <muhsinkeramam@gmail.com>
71 lines
1.8 KiB
JavaScript
71 lines
1.8 KiB
JavaScript
import {
|
|
SET_REFERRER_HOST,
|
|
SET_WIDGET_APP_CONFIG,
|
|
SET_WIDGET_COLOR,
|
|
TOGGLE_WIDGET_OPEN,
|
|
} from '../types';
|
|
|
|
const state = {
|
|
showPopoutButton: false,
|
|
hideMessageBubble: false,
|
|
position: 'right',
|
|
isWebWidgetTriggered: false,
|
|
isCampaignViewClicked: false,
|
|
isWidgetOpen: false,
|
|
widgetColor: '',
|
|
referrerHost: '',
|
|
};
|
|
|
|
export const getters = {
|
|
getAppConfig: $state => $state,
|
|
isRightAligned: $state => $state.position === 'right',
|
|
getHideMessageBubble: $state => $state.hideMessageBubble,
|
|
getIsWidgetOpen: $state => $state.isWidgetOpen,
|
|
getWidgetColor: $state => $state.widgetColor,
|
|
getReferrerHost: $state => $state.referrerHost,
|
|
};
|
|
|
|
export const actions = {
|
|
setAppConfig({ commit }, { showPopoutButton, position, hideMessageBubble }) {
|
|
commit(SET_WIDGET_APP_CONFIG, {
|
|
showPopoutButton: !!showPopoutButton,
|
|
position: position || 'right',
|
|
hideMessageBubble: !!hideMessageBubble,
|
|
});
|
|
},
|
|
toggleWidgetOpen({ commit }, isWidgetOpen) {
|
|
commit(TOGGLE_WIDGET_OPEN, isWidgetOpen);
|
|
},
|
|
setWidgetColor({ commit }, widgetColor) {
|
|
commit(SET_WIDGET_COLOR, widgetColor);
|
|
},
|
|
setReferrerHost({ commit }, referrerHost) {
|
|
commit(SET_REFERRER_HOST, referrerHost);
|
|
},
|
|
};
|
|
|
|
export const mutations = {
|
|
[SET_WIDGET_APP_CONFIG]($state, data) {
|
|
$state.showPopoutButton = data.showPopoutButton;
|
|
$state.position = data.position;
|
|
$state.hideMessageBubble = data.hideMessageBubble;
|
|
},
|
|
[TOGGLE_WIDGET_OPEN]($state, isWidgetOpen) {
|
|
$state.isWidgetOpen = isWidgetOpen;
|
|
},
|
|
[SET_WIDGET_COLOR]($state, widgetColor) {
|
|
$state.widgetColor = widgetColor;
|
|
},
|
|
[SET_REFERRER_HOST]($state, referrerHost) {
|
|
$state.referrerHost = referrerHost;
|
|
},
|
|
};
|
|
|
|
export default {
|
|
namespaced: true,
|
|
state,
|
|
getters,
|
|
actions,
|
|
mutations,
|
|
};
|