@ezbot-ai/javascript-sdk
Version:
The easiest way to interact with ezbot via JS (node and browser)
236 lines • 17.7 kB
JavaScript
/* eslint-disable functional/no-return-void */
/* eslint-disable functional/immutable-data */
/* eslint-disable functional/prefer-immutable-types */
import { globalVisualChanges } from './constants';
import * as utils from './utils';
import { logInfo } from './utils';
function setElementText(element, text) {
element.textContent = text;
}
function setElementInnerHTML(element, innerHTML) {
element.innerHTML = innerHTML;
}
function setElementAttribute(element, attribute, value) {
element.setAttribute(attribute, value);
}
function addClassesToElement(element, classes) {
if (classes.length === 0) {
utils.logInfo(`No classes to add to element.`);
return;
}
classes.forEach((className) => {
element.classList.add(className);
});
}
function removeClassesFromElement(element, classes) {
if (classes.length === 0) {
utils.logInfo(`No classes to remove from element.`);
return;
}
classes.forEach((className) => {
element.classList.remove(className);
});
}
function setElementStyle(element, value) {
setElementAttribute(element, 'style', value);
}
function setElementHref(element, href) {
setElementAttribute(element, 'href', href);
}
function setElementSrc(element, src) {
setElementAttribute(element, 'src', src);
}
function hideElement(element) {
element.style.display = 'none';
element.style.visibility = 'hidden';
}
function showElement(element) {
element.style.display = 'block';
element.style.visibility = 'visible';
}
function setElementOuterHTML(element, value) {
element.outerHTML = value;
}
function addGlobalCSS(key, value) {
const head = document.head;
if (!head) {
logInfo('No document head found: unable to add global css');
return;
}
const newStyleElement = document.createElement('style');
newStyleElement.innerText = value;
newStyleElement.id = 'ezbot-global-css-' + key;
head.appendChild(newStyleElement);
}
function validateVisualPrediction(prediction) {
if (prediction.config == null) {
return `No config found for prediction with key: ${prediction.key}. Skipping its visual change.`;
}
if (prediction.config.action === 'addGlobalCSS') {
return null;
}
if (!prediction.config.selector) {
return `No selector found for prediction with key: ${prediction.key}. Skipping its visual change.`;
}
if (!prediction.config.action) {
return `No action found for prediction with key: ${prediction.key}. Skipping its visual change.`;
}
return null;
}
function parseCommaSeparatedList(list) {
// if list is empty, return an empty array
if (list.length === 0) {
return [];
}
// if list has no commas, return it as an array
if (list.indexOf(',') === -1) {
return [list];
}
const listArray = list.split(',').map((item) => item.trim());
return listArray;
}
function makeGlobalVisualChange(prediction) {
const action = prediction.config?.action;
switch (action) {
case 'addGlobalCSS':
addGlobalCSS(prediction.key, prediction.value);
break;
default:
utils.logInfo(`Unsupported action for prediction with key: ${prediction.key}. Skipping its global change.`);
}
}
function makeVisualChange(prediction) {
if (!prediction.config) {
utils.logInfo(`No config found for prediction with key: ${prediction.key}. Skipping its visual change.`);
return;
}
const selector = prediction.config.selector;
if (!selector) {
utils.logInfo(`No selector found for prediction with key: ${prediction.key}. Skipping its visual change.`);
return;
}
const element = utils.safeQuerySelector(selector);
if (!element || !(element instanceof HTMLElement)) {
utils.logInfo(`No HTML element found for prediction with key: ${prediction.key}. Skipping its visual change.`);
return;
}
const action = prediction.config.action;
switch (action) {
case 'setText':
setElementText(element, prediction.value);
break;
case 'setInnerHTML':
setElementInnerHTML(element, prediction.value);
break;
case 'setAttribute':
if (!prediction.config.attribute) {
utils.logInfo(`No attribute found for prediction with key: ${prediction.key}. Skipping its visual change.`);
return;
}
setElementAttribute(element, prediction.config.attribute, prediction.value);
break;
case 'addClasses':
addClassesToElement(element, parseCommaSeparatedList(prediction.value));
break;
case 'removeClasses':
removeClassesFromElement(element, parseCommaSeparatedList(prediction.value));
break;
case 'setHref':
if (element instanceof HTMLAnchorElement) {
setElementHref(element, prediction.value);
}
else {
utils.logInfo(`Element with selector: ${prediction.config.selector} is not an anchor element. Skipping its visual change.`);
}
break;
case 'setStyle':
setElementStyle(element, prediction.value);
break;
case 'setSrc':
if (element instanceof HTMLImageElement) {
setElementSrc(element, prediction.value);
}
else {
utils.logInfo(`Element with selector: ${prediction.config.selector} is not an image element. Skipping its visual change.`);
}
break;
case 'hide':
hideElement(element);
break;
case 'show':
showElement(element);
break;
case 'setFontSize':
setElementStyle(element, `font-size: ${prediction.value}`);
break;
case 'setFontColor':
setElementStyle(element, `color: ${prediction.value}`);
break;
case 'setBackgroundColor':
setElementStyle(element, `background-color: ${prediction.value}`);
break;
case 'setVisibility':
// eslint-disable-next-line no-case-declarations
const val = prediction.value.toLowerCase();
if (val === 'hide') {
hideElement(element);
break;
}
else if (val === 'show') {
showElement(element);
break;
}
utils.logInfo("unsupported value for 'setVisibility' action", prediction.value);
break;
case 'setOuterHTML':
setElementOuterHTML(element, prediction.value);
break;
default:
utils.logInfo(`Unsupported action for prediction with key: ${prediction.key}. Skipping its visual change.`);
}
}
function makeVisualChanges() {
const predictions = window.ezbot?.predictions;
if (!predictions) {
utils.logInfo('No predictions found. Skipping visual changes.');
return;
}
predictions.forEach((prediction) => {
if (prediction.type != 'visual') {
return;
}
const validationError = validateVisualPrediction(prediction);
if (validationError != null) {
utils.logInfo(validationError);
return;
}
if (prediction.config &&
globalVisualChanges.includes(prediction.config.action)) {
makeGlobalVisualChange(prediction);
return;
}
makeVisualChange(prediction);
});
}
const visualUtils = {
validateVisualPrediction,
parseCommaSeparatedList,
};
const visualChanges = {
setElementText,
setElementInnerHTML,
setElementAttribute,
addGlobalCSS,
setElementHref,
setElementSrc,
addClassesToElement,
removeClassesFromElement,
setElementStyle,
hideElement,
showElement,
makeVisualChange,
makeVisualChanges,
makeGlobalVisualChange,
};
export { visualUtils, visualChanges, setElementText, setElementInnerHTML, setElementAttribute, addGlobalCSS, setElementHref, setElementSrc, addClassesToElement, removeClassesFromElement, setElementStyle, hideElement, showElement, validateVisualPrediction, makeVisualChange, makeVisualChanges, parseCommaSeparatedList, makeGlobalVisualChange, };
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"visualChanges.js","sourceRoot":"","sources":["../../../src/lib/visualChanges.ts"],"names":[],"mappings":"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"}