@atlaskit/renderer
Version:
Renderer component
55 lines (51 loc) • 2.26 kB
JavaScript
import _createClass from "@babel/runtime/helpers/createClass";
import _classCallCheck from "@babel/runtime/helpers/classCallCheck";
/* eslint-disable @atlaskit/editor/no-re-export */
// Entry file in package.json
import { defaultSchema } from '@atlaskit/adf-schema/schema-default';
import { JSONTransformer } from '@atlaskit/editor-json-transformer';
// Ignored via go/ees005
// eslint-disable-next-line @typescript-eslint/no-explicit-any
function createEncoder(parser, encoder) {
return function (value) {
return encoder.encode(parser.parse(value));
};
}
export var ADFEncoder = /*#__PURE__*/_createClass(
// Ignored via go/ees005
// eslint-disable-next-line @typescript-eslint/no-explicit-any
function ADFEncoder(createTransformerWithSchema) {
_classCallCheck(this, ADFEncoder);
var transformer = createTransformerWithSchema(defaultSchema);
this.encode = createEncoder(transformer, new JSONTransformer());
});
export var getText = function getText(node) {
return node.text || node.attrs && (node.attrs.text || node.attrs.shortName) || "[".concat(typeof node.type === 'string' ? node.type : node.type.name, "]");
};
export var getEventHandler = function getEventHandler(eventHandlers, type) {
var eventName = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : 'onClick';
// Ignored via go/ees005
// eslint-disable-next-line @typescript-eslint/no-explicit-any
return eventHandlers && type && eventHandlers[type] && eventHandlers[type][eventName];
};
/**
* Traverse through parent elements of element. Return element for which evaluate(element) returns
* true. If topElement is reached before evaluate returns true, return false. Does not run evaluate
* on topElement.
* @param element Starting HTMLElement
* @param topElement HTMLElement to end search at. evaluate is not called on this element
* @param evaluate Function which returns true or false based on the given element. eg: Checks if
* element has desired classname.
*/
export function findInTree(element, topElement, evaluate) {
if (element === topElement) {
return false;
}
if (evaluate(element)) {
return true;
}
if (!element.parentElement) {
return false;
}
return findInTree(element.parentElement, topElement, evaluate);
}