UNPKG

@ezbot-ai/javascript-sdk

Version:

The easiest way to interact with ezbot via JS (node and browser)

236 lines 17.7 kB
/* 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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"}