0adbc346df
* feat: Add a new design for chat bubble Signed-off-by: Pranav Raj Sreepuram <pranavrajs@gmail.com> * Add i18n * Fix stye issues * Set fixed font-size * Update docs for bubble
71 lines
2.9 KiB
JavaScript
71 lines
2.9 KiB
JavaScript
import { addClass, toggleClass, wootOn } from './DOMHelpers';
|
|
import { IFrameHelper } from './IFrameHelper';
|
|
import { BUBBLE_DESIGN } from './constants';
|
|
|
|
export const bubbleImg =
|
|
'';
|
|
|
|
export const body = document.getElementsByTagName('body')[0];
|
|
export const widgetHolder = document.createElement('div');
|
|
|
|
export const bubbleHolder = document.createElement('div');
|
|
export const chatBubble = document.createElement('div');
|
|
export const closeBubble = document.createElement('div');
|
|
export const notificationBubble = document.createElement('span');
|
|
|
|
export const getBubbleView = type =>
|
|
BUBBLE_DESIGN.includes(type) ? type : BUBBLE_DESIGN[0];
|
|
export const isExpandedView = type => getBubbleView(type) === BUBBLE_DESIGN[1];
|
|
|
|
export const setBubbleText = bubbleText => {
|
|
if (isExpandedView(window.$chatwoot.type)) {
|
|
const textNode = document.getElementById('woot-widget--expanded__text');
|
|
textNode.innerHTML = bubbleText;
|
|
}
|
|
};
|
|
|
|
export const createBubbleIcon = ({ className, src, target }) => {
|
|
let bubbleClassName = `${className} woot-elements--${window.$chatwoot.position}`;
|
|
const bubbleIcon = document.createElement('img');
|
|
bubbleIcon.src = src;
|
|
target.appendChild(bubbleIcon);
|
|
|
|
if (isExpandedView(window.$chatwoot.type)) {
|
|
const textNode = document.createElement('div');
|
|
textNode.id = 'woot-widget--expanded__text';
|
|
textNode.innerHTML = '';
|
|
target.appendChild(textNode);
|
|
bubbleClassName += ' woot-widget--expanded';
|
|
}
|
|
|
|
target.className = bubbleClassName;
|
|
return target;
|
|
};
|
|
|
|
export const createBubbleHolder = () => {
|
|
addClass(bubbleHolder, 'woot--bubble-holder');
|
|
body.appendChild(bubbleHolder);
|
|
};
|
|
|
|
export const createNotificationBubble = () => {
|
|
addClass(notificationBubble, 'woot--notification');
|
|
return notificationBubble;
|
|
};
|
|
|
|
export const onBubbleClick = (props = {}) => {
|
|
const { toggleValue } = props;
|
|
const { isOpen } = window.$chatwoot;
|
|
if (isOpen !== toggleValue) {
|
|
const newIsOpen = toggleValue === undefined ? !isOpen : toggleValue;
|
|
window.$chatwoot.isOpen = newIsOpen;
|
|
|
|
toggleClass(chatBubble, 'woot--hide');
|
|
toggleClass(closeBubble, 'woot--hide');
|
|
toggleClass(widgetHolder, 'woot--hide');
|
|
IFrameHelper.events.onBubbleToggle(newIsOpen);
|
|
}
|
|
};
|
|
|
|
export const onClickChatBubble = () => {
|
|
wootOn(bubbleHolder, 'click', onBubbleClick);
|
|
};
|