botframework-webchat-component
Version:
React component of botframework-webchat
79 lines (75 loc) • 15.5 kB
JavaScript
;
Object.defineProperty(exports, "__esModule", {
value: true
});
exports.default = activityAltText;
var _textFormatToContentType = _interopRequireDefault(require("./textFormatToContentType"));
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
function _toConsumableArray(arr) { return _arrayWithoutHoles(arr) || _iterableToArray(arr) || _unsupportedIterableToArray(arr) || _nonIterableSpread(); }
function _nonIterableSpread() { throw new TypeError("Invalid attempt to spread non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method."); }
function _unsupportedIterableToArray(o, minLen) { if (!o) return; if (typeof o === "string") return _arrayLikeToArray(o, minLen); var n = Object.prototype.toString.call(o).slice(8, -1); if (n === "Object" && o.constructor) n = o.constructor.name; if (n === "Map" || n === "Set") return Array.from(o); if (n === "Arguments" || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n)) return _arrayLikeToArray(o, minLen); }
function _iterableToArray(iter) { if (typeof Symbol !== "undefined" && iter[Symbol.iterator] != null || iter["@@iterator"] != null) return Array.from(iter); }
function _arrayWithoutHoles(arr) { if (Array.isArray(arr)) return _arrayLikeToArray(arr); }
function _arrayLikeToArray(arr, len) { if (len == null || len > arr.length) len = arr.length; for (var i = 0, arr2 = new Array(len); i < len; i++) { arr2[i] = arr[i]; } return arr2; }
function walk(document, walker) {
var nodes = [].slice.call(document.childNodes);
var results = [];
while (nodes.length) {
var _node = nodes.shift();
var childNodes = _node.childNodes;
results.push.apply(results, _toConsumableArray(walker(_node) || []));
nodes.unshift.apply(nodes, _toConsumableArray([].slice.call(childNodes)));
}
return results;
}
// From https://developer.mozilla.org/en-US/docs/Web/HTML/Inline_elements
var HTML_INLINE_TAGS = ['A', 'ABBR', 'ACRONYM', 'AUDIO', 'B', 'BDI', 'BDO', 'BIG', 'BR', 'BUTTON', 'CANVAS', 'CITE', 'CODE', 'DATA', 'DATALIST', 'DEL', 'DFN', 'EM', 'EMBED', 'I', 'IFRAME', 'IMG', 'INPUT', 'INS', 'KBD', 'LABEL', 'MAP', 'MARK', 'METER', 'NOSCRIPT', 'OBJECT', 'OUTPUT', 'PICTURE', 'PROGRESS', 'Q', 'RUBY', 'S', 'SAMP', 'SCRIPT', 'SELECT', 'SLOT', 'SMALL', 'SPAN', 'STRONG', 'SUB', 'SUP', 'SVG', 'TEMPLATE', 'TEXTAREA', 'TIME', 'U', 'TT', 'VAR', 'VIDEO', 'WBR'];
/**
* Computes all text from a given HTML document as flattened array. This is best-effort.
*
* @param {Document} document - HTML document to computes texts from.
*/
function htmlTextAlternatives(document) {
// TODO: [P2] #3923 Revisit this logic with W3C standard, we could do a better text alternatives computation.
// For example, <abbr title="..."> is not computed.
// https://www.w3.org/TR/accname-1.1/#mapping_additional_nd_name
return walk(document, function (node) {
var nodeType = node.nodeType,
tagName = node.tagName,
textContent = node.textContent;
if (nodeType === Node.TEXT_NODE) {
return [textContent];
} else if (tagName === 'IMG') {
return [node.getAttribute('alt')];
} else if (!HTML_INLINE_TAGS.includes(tagName)) {
return ['\n'];
}
});
}
/**
* Returns the text alternatives for a message activity.
*
* @param {object} activity - Activity to compute the text alternatives.
* @param {function} renderMarkdownAsHTML - Callback function to render Markdown as HTML string.
*/
function activityAltText(activity, renderMarkdownAsHTML) {
var _activity$channelData, _activity$channelData2, _activity$channelData3;
if (activity.type !== 'message') {
return false;
}
var fallbackText = activity === null || activity === void 0 ? void 0 : (_activity$channelData = activity.channelData) === null || _activity$channelData === void 0 ? void 0 : _activity$channelData['webchat:fallback-text'];
if (typeof fallbackText === 'string') {
// If `fallbackText` is an empty string, we will treat the activity as presentational and skip narrating it (return false).
return fallbackText || false;
}
var text = (activity === null || activity === void 0 ? void 0 : (_activity$channelData2 = activity.channelData) === null || _activity$channelData2 === void 0 ? void 0 : (_activity$channelData3 = _activity$channelData2.messageBack) === null || _activity$channelData3 === void 0 ? void 0 : _activity$channelData3.displayText) || activity.text;
if (!text) {
// We will continue to narrate the activity, as empty.
return '';
}
if (renderMarkdownAsHTML && (0, _textFormatToContentType.default)(activity.textFormat) === 'text/markdown') {
return htmlTextAlternatives(new DOMParser().parseFromString(renderMarkdownAsHTML(text), 'text/html')).join('').replace(/\n{2,}/g, '\n').trim();
}
return text;
}
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_textFormatToContentType","_interopRequireDefault","require","obj","__esModule","default","_toConsumableArray","arr","_arrayWithoutHoles","_iterableToArray","_unsupportedIterableToArray","_nonIterableSpread","TypeError","o","minLen","_arrayLikeToArray","n","Object","prototype","toString","call","slice","constructor","name","Array","from","test","iter","Symbol","iterator","isArray","len","length","i","arr2","walk","document","walker","nodes","childNodes","results","node","shift","push","apply","unshift","HTML_INLINE_TAGS","htmlTextAlternatives","nodeType","tagName","textContent","Node","TEXT_NODE","getAttribute","includes","activityAltText","activity","renderMarkdownAsHTML","_activity$channelData","_activity$channelData2","_activity$channelData3","type","fallbackText","channelData","text","messageBack","displayText","textFormatToContentType","textFormat","DOMParser","parseFromString","join","replace","trim"],"sourceRoot":"component:///","sources":["../../src/Utils/activityAltText.ts"],"sourcesContent":["import textFormatToContentType from './textFormatToContentType';\n\nfunction walk<T extends Node>(document: Document, walker: (node: T) => string[]): string[] {\n  const nodes: T[] = [].slice.call(document.childNodes);\n  const results: string[] = [];\n\n  while (nodes.length) {\n    const node = nodes.shift();\n    const { childNodes } = node;\n\n    results.push(...(walker(node) || []));\n    nodes.unshift(...[].slice.call(childNodes));\n  }\n\n  return results;\n}\n\n// From https://developer.mozilla.org/en-US/docs/Web/HTML/Inline_elements\nconst HTML_INLINE_TAGS = [\n  'A',\n  'ABBR',\n  'ACRONYM',\n  'AUDIO',\n  'B',\n  'BDI',\n  'BDO',\n  'BIG',\n  'BR',\n  'BUTTON',\n  'CANVAS',\n  'CITE',\n  'CODE',\n  'DATA',\n  'DATALIST',\n  'DEL',\n  'DFN',\n  'EM',\n  'EMBED',\n  'I',\n  'IFRAME',\n  'IMG',\n  'INPUT',\n  'INS',\n  'KBD',\n  'LABEL',\n  'MAP',\n  'MARK',\n  'METER',\n  'NOSCRIPT',\n  'OBJECT',\n  'OUTPUT',\n  'PICTURE',\n  'PROGRESS',\n  'Q',\n  'RUBY',\n  'S',\n  'SAMP',\n  'SCRIPT',\n  'SELECT',\n  'SLOT',\n  'SMALL',\n  'SPAN',\n  'STRONG',\n  'SUB',\n  'SUP',\n  'SVG',\n  'TEMPLATE',\n  'TEXTAREA',\n  'TIME',\n  'U',\n  'TT',\n  'VAR',\n  'VIDEO',\n  'WBR'\n];\n\n/**\n * Computes all text from a given HTML document as flattened array. This is best-effort.\n *\n * @param {Document} document - HTML document to computes texts from.\n */\nfunction htmlTextAlternatives(document: Document): string[] {\n  // TODO: [P2] #3923 Revisit this logic with W3C standard, we could do a better text alternatives computation.\n  //       For example, <abbr title=\"...\"> is not computed.\n  //       https://www.w3.org/TR/accname-1.1/#mapping_additional_nd_name\n  return walk<HTMLElement>(document, node => {\n    const { nodeType, tagName, textContent } = node;\n\n    if (nodeType === Node.TEXT_NODE) {\n      return [textContent];\n    } else if (tagName === 'IMG') {\n      return [node.getAttribute('alt')];\n    } else if (!HTML_INLINE_TAGS.includes(tagName)) {\n      return ['\\n'];\n    }\n  });\n}\n\n/**\n * Returns the text alternatives for a message activity.\n *\n * @param {object} activity - Activity to compute the text alternatives.\n * @param {function} renderMarkdownAsHTML - Callback function to render Markdown as HTML string.\n */\nexport default function activityAltText(\n  activity: any,\n  renderMarkdownAsHTML?: (markdown: string) => string\n): false | string {\n  if (activity.type !== 'message') {\n    return false;\n  }\n\n  const fallbackText = activity?.channelData?.['webchat:fallback-text'];\n\n  if (typeof fallbackText === 'string') {\n    // If `fallbackText` is an empty string, we will treat the activity as presentational and skip narrating it (return false).\n    return fallbackText || false;\n  }\n\n  const text = activity?.channelData?.messageBack?.displayText || activity.text;\n\n  if (!text) {\n    // We will continue to narrate the activity, as empty.\n    return '';\n  }\n\n  if (renderMarkdownAsHTML && textFormatToContentType(activity.textFormat) === 'text/markdown') {\n    return htmlTextAlternatives(new DOMParser().parseFromString(renderMarkdownAsHTML(text), 'text/html'))\n      .join('')\n      .replace(/\\n{2,}/gu, '\\n')\n      .trim();\n  }\n\n  return text;\n}\n"],"mappings":"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"}