Restructure omni services and add Chatwoot research snapshot
This commit is contained in:
@@ -0,0 +1,7 @@
|
||||
import { email as emailValidator } from '@vuelidate/validators';
|
||||
|
||||
export const validEmailsByComma = value => {
|
||||
if (!value.length) return true;
|
||||
const emails = value.replace(/\s+/g, '').split(',');
|
||||
return emails.every(email => emailValidator.$validator(email));
|
||||
};
|
||||
@@ -0,0 +1,18 @@
|
||||
const totalMessageHeight = (total, element) => {
|
||||
return total + element.scrollHeight;
|
||||
};
|
||||
|
||||
export const calculateScrollTop = (
|
||||
conversationPanelHeight,
|
||||
parentHeight,
|
||||
relevantMessages
|
||||
) => {
|
||||
// add up scrollHeight of a `relevantMessages`
|
||||
let combinedMessageScrollHeight = [...relevantMessages].reduce(
|
||||
totalMessageHeight,
|
||||
0
|
||||
);
|
||||
return (
|
||||
conversationPanelHeight - combinedMessageScrollHeight - parentHeight / 2
|
||||
);
|
||||
};
|
||||
@@ -0,0 +1,16 @@
|
||||
import { validEmailsByComma } from '../emailHeadHelper';
|
||||
|
||||
describe('#validEmailsByComma', () => {
|
||||
it('returns true when empty string is passed', () => {
|
||||
expect(validEmailsByComma('')).toEqual(true);
|
||||
});
|
||||
it('returns true when valid emails separated by comma is passed', () => {
|
||||
expect(validEmailsByComma('ni@njan.com,po@va.da')).toEqual(true);
|
||||
});
|
||||
it('returns false when one of the email passed is invalid', () => {
|
||||
expect(validEmailsByComma('ni@njan.com,pova.da')).toEqual(false);
|
||||
});
|
||||
it('strips spaces between emails before validating', () => {
|
||||
expect(validEmailsByComma('1@test.com , 2@test.com')).toEqual(true);
|
||||
});
|
||||
});
|
||||
@@ -0,0 +1,18 @@
|
||||
import { calculateScrollTop } from '../scrollTopCalculationHelper';
|
||||
|
||||
describe('#calculateScrollTop', () => {
|
||||
it('returns calculated value of the scrollTop property', () => {
|
||||
class DOMElement {
|
||||
constructor(scrollHeight) {
|
||||
this.scrollHeight = scrollHeight;
|
||||
}
|
||||
}
|
||||
let count = 3;
|
||||
let relevantMessages = [];
|
||||
while (count > 0) {
|
||||
relevantMessages.push(new DOMElement(100));
|
||||
count -= 1;
|
||||
}
|
||||
expect(calculateScrollTop(1000, 300, relevantMessages)).toEqual(550);
|
||||
});
|
||||
});
|
||||
Reference in New Issue
Block a user