botframework-webchat-component
Version:
React component of botframework-webchat
147 lines (137 loc) • 24.1 kB
JavaScript
Object.defineProperty(exports, "__esModule", {
value: true
});
exports.default = void 0;
var _botframeworkWebchatApi = require("botframework-webchat-api");
var _react = require("react");
var _intersectionOf = _interopRequireDefault(require("../../../Utils/intersectionOf"));
var _removeInline = _interopRequireDefault(require("../../../Utils/removeInline"));
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
function _slicedToArray(arr, i) { return _arrayWithHoles(arr) || _iterableToArrayLimit(arr, i) || _unsupportedIterableToArray(arr, i) || _nonIterableRest(); }
function _nonIterableRest() { throw new TypeError("Invalid attempt to destructure non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method."); }
function _iterableToArrayLimit(arr, i) { var _i = arr == null ? null : typeof Symbol !== "undefined" && arr[Symbol.iterator] || arr["@@iterator"]; if (_i == null) return; var _arr = []; var _n = true; var _d = false; var _s, _e; try { for (_i = _i.call(arr); !(_n = (_s = _i.next()).done); _n = true) { _arr.push(_s.value); if (i && _arr.length === i) break; } } catch (err) { _d = true; _e = err; } finally { try { if (!_n && _i["return"] != null) _i["return"](); } finally { if (_d) throw _e; } } return _arr; }
function _arrayWithHoles(arr) { if (Array.isArray(arr)) return arr; }
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; }
var useGroupActivities = _botframeworkWebchatApi.hooks.useGroupActivities;
function validateAllEntriesTagged(entries, bins) {
return entries.every(function (entry) {
return bins.some(function (bin) {
return bin.includes(entry);
});
});
}
// Activity tree is a multidimensional array, while activities is a 1D array.
// - The first dimension of the array contains activities with same sender;
// - The second dimension of the array contains activities with same status.
// [
// [
// // Both messages are from bot and is sent as a batch, we will group them as an array.
// 'Bot: Hello!'
// 'Bot: What can I help today?'
// ],
// [
// 'User: What is the weather?'
// ],
// [
// 'Bot: Let me look it up... hold on.'
// ],
// [
// // This message is in a different group because it is more than a few seconds apart from the previous message.
// 'Bot: Here is the weather forecast.'
// ]
// ]
function useActivityTreeWithRenderer(entries) {
var groupActivities = useGroupActivities();
var entryMap = (0, _react.useMemo)(function () {
return new Map(entries.map(function (entry) {
return [entry.activity, entry];
}));
}, [entries]);
// We bin activities in 2 different ways:
// - `activitiesBySender` is a 2D array containing activities with same sender
// - `activitiesByStatus` is a 2D array containing activities with same status
// Both arrays should contains all activities.
var _useMemo = (0, _react.useMemo)(function () {
var visibleActivities = _toConsumableArray(entryMap.keys());
var groupActivitiesResult = groupActivities({
activities: visibleActivities
});
var activitiesBySender = (groupActivitiesResult === null || groupActivitiesResult === void 0 ? void 0 : groupActivitiesResult.sender) || [];
var activitiesByStatus = (groupActivitiesResult === null || groupActivitiesResult === void 0 ? void 0 : groupActivitiesResult.status) || [];
var _map = [activitiesBySender, activitiesByStatus].map(function (bins) {
return bins.map(function (bin) {
return bin.map(function (activity) {
return entryMap.get(activity);
});
});
}),
_map2 = _slicedToArray(_map, 2),
entriesBySender = _map2[0],
entriesByStatus = _map2[1];
if (!validateAllEntriesTagged(visibleActivities, activitiesBySender)) {
console.warn('botframework-webchat: Not every activities are grouped in the "sender" property. Please fix "groupActivitiesMiddleware" and group every activities.');
}
if (!validateAllEntriesTagged(visibleActivities, activitiesByStatus)) {
console.warn('botframework-webchat: Not every activities are grouped in the "status" property. Please fix "groupActivitiesMiddleware" and group every activities.');
}
return {
entriesBySender: entriesBySender,
entriesByStatus: entriesByStatus
};
}, [entryMap, groupActivities]),
entriesBySender = _useMemo.entriesBySender,
entriesByStatus = _useMemo.entriesByStatus;
// Create a tree of activities with 2 dimensions: sender, followed by status.
var activityTree = (0, _react.useMemo)(function () {
var entriesPendingGrouping = _toConsumableArray(entries);
var activityTree = [];
var _loop = function _loop() {
var found = void 0;
var entriesWithSameSender = entriesBySender.find(function (bin) {
return bin.includes(entriesPendingGrouping[0]);
});
var senderTree = [];
entriesWithSameSender === null || entriesWithSameSender === void 0 ? void 0 : entriesWithSameSender.forEach(function (entry) {
var entriesWithSameStatus = entriesByStatus.find(function (bin) {
return bin.includes(entry);
});
var entriesWithSameSenderAndStatus = (0, _intersectionOf.default)(entriesPendingGrouping, entriesWithSameSender, entriesWithSameStatus);
if (entriesWithSameSenderAndStatus.length) {
senderTree.push(Object.freeze(entriesWithSameSenderAndStatus));
_removeInline.default.apply(void 0, [entriesPendingGrouping].concat(_toConsumableArray(entriesWithSameSenderAndStatus)));
found = true;
}
});
// If the entry is not grouped by the middleware, just put the entry in its own bin.
found || senderTree.push(Object.freeze([entriesPendingGrouping.shift()]));
activityTree.push(Object.freeze(senderTree));
};
while (entriesPendingGrouping.length) {
_loop();
}
// Assertion: All entries must be assigned to the activityTree.
if (!entries.every(function (activity) {
return activityTree.some(function (activitiesWithSameSender) {
return activitiesWithSameSender.some(function (activitiesWithSameSenderAndStatus) {
return activitiesWithSameSenderAndStatus.includes(activity);
});
});
})) {
console.warn('botframework-webchat internal: Not all visible activities are grouped in the activityTree.', {
entries: entries,
activityTree: activityTree
});
}
return Object.freeze(activityTree);
}, [entriesBySender, entriesByStatus, entries]);
return activityTree;
}
var _default = useActivityTreeWithRenderer;
exports.default = _default;
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_botframeworkWebchatApi","require","_react","_intersectionOf","_interopRequireDefault","_removeInline","obj","__esModule","default","_slicedToArray","arr","i","_arrayWithHoles","_iterableToArrayLimit","_unsupportedIterableToArray","_nonIterableRest","TypeError","_i","Symbol","iterator","_arr","_n","_d","_s","_e","call","next","done","push","value","length","err","Array","isArray","_toConsumableArray","_arrayWithoutHoles","_iterableToArray","_nonIterableSpread","o","minLen","_arrayLikeToArray","n","Object","prototype","toString","slice","constructor","name","from","test","iter","len","arr2","useGroupActivities","hooks","validateAllEntriesTagged","entries","bins","every","entry","some","bin","includes","useActivityTreeWithRenderer","groupActivities","entryMap","useMemo","Map","map","activity","_useMemo","visibleActivities","keys","groupActivitiesResult","activities","activitiesBySender","sender","activitiesByStatus","status","_map","get","_map2","entriesBySender","entriesByStatus","console","warn","activityTree","entriesPendingGrouping","_loop","found","entriesWithSameSender","find","senderTree","forEach","entriesWithSameStatus","entriesWithSameSenderAndStatus","intersectionOf","freeze","removeInline","apply","concat","shift","activitiesWithSameSender","activitiesWithSameSenderAndStatus","_default","exports"],"sourceRoot":"component:///","sources":["../../../../src/providers/ActivityTree/private/useActivityTreeWithRenderer.ts"],"sourcesContent":["import { hooks } from 'botframework-webchat-api';\nimport { useMemo } from 'react';\n\nimport type { WebChatActivity } from 'botframework-webchat-core';\nimport intersectionOf from '../../../Utils/intersectionOf';\nimport removeInline from '../../../Utils/removeInline';\nimport type { ActivityWithRenderer, ReadonlyActivityTree } from './types';\n\nconst { useGroupActivities } = hooks;\n\nfunction validateAllEntriesTagged<T>(entries: readonly T[], bins: readonly (readonly T[])[]): boolean {\n  return entries.every(entry => bins.some(bin => bin.includes(entry)));\n}\n\n// Activity tree is a multidimensional array, while activities is a 1D array.\n// - The first dimension of the array contains activities with same sender;\n// - The second dimension of the array contains activities with same status.\n\n// [\n//   [\n//     // Both messages are from bot and is sent as a batch, we will group them as an array.\n//     'Bot: Hello!'\n//     'Bot: What can I help today?'\n//   ],\n//   [\n//     'User: What is the weather?'\n//   ],\n//   [\n//     'Bot: Let me look it up... hold on.'\n//   ],\n//   [\n//     // This message is in a different group because it is more than a few seconds apart from the previous message.\n//     'Bot: Here is the weather forecast.'\n//   ]\n// ]\n\nfunction useActivityTreeWithRenderer(entries: readonly ActivityWithRenderer[]): ReadonlyActivityTree {\n  const groupActivities = useGroupActivities();\n  const entryMap: Map<WebChatActivity, ActivityWithRenderer> = useMemo(\n    () => new Map(entries.map(entry => [entry.activity, entry])),\n    [entries]\n  );\n\n  // We bin activities in 2 different ways:\n  // - `activitiesBySender` is a 2D array containing activities with same sender\n  // - `activitiesByStatus` is a 2D array containing activities with same status\n  // Both arrays should contains all activities.\n\n  const { entriesBySender, entriesByStatus } = useMemo<{\n    entriesBySender: readonly (readonly ActivityWithRenderer[])[];\n    entriesByStatus: readonly (readonly ActivityWithRenderer[])[];\n  }>(() => {\n    const visibleActivities = [...entryMap.keys()];\n\n    const groupActivitiesResult = groupActivities({ activities: visibleActivities });\n\n    const activitiesBySender = groupActivitiesResult?.sender || [];\n    const activitiesByStatus = groupActivitiesResult?.status || [];\n\n    const [entriesBySender, entriesByStatus] = [activitiesBySender, activitiesByStatus].map(bins =>\n      bins.map(bin => bin.map(activity => entryMap.get(activity)))\n    );\n\n    if (!validateAllEntriesTagged(visibleActivities, activitiesBySender)) {\n      console.warn(\n        'botframework-webchat: Not every activities are grouped in the \"sender\" property. Please fix \"groupActivitiesMiddleware\" and group every activities.'\n      );\n    }\n\n    if (!validateAllEntriesTagged(visibleActivities, activitiesByStatus)) {\n      console.warn(\n        'botframework-webchat: Not every activities are grouped in the \"status\" property. Please fix \"groupActivitiesMiddleware\" and group every activities.'\n      );\n    }\n\n    return {\n      entriesBySender,\n      entriesByStatus\n    };\n  }, [entryMap, groupActivities]);\n\n  // Create a tree of activities with 2 dimensions: sender, followed by status.\n\n  const activityTree: ReadonlyActivityTree = useMemo(() => {\n    const entriesPendingGrouping = [...entries];\n    const activityTree: (readonly (readonly ActivityWithRenderer[])[])[] = [];\n\n    while (entriesPendingGrouping.length) {\n      let found: boolean;\n      const entriesWithSameSender = entriesBySender.find(bin => bin.includes(entriesPendingGrouping[0]));\n      const senderTree: (readonly ActivityWithRenderer[])[] = [];\n\n      entriesWithSameSender?.forEach(entry => {\n        const entriesWithSameStatus = entriesByStatus.find(bin => bin.includes(entry));\n\n        const entriesWithSameSenderAndStatus = intersectionOf<ActivityWithRenderer>(\n          entriesPendingGrouping,\n          entriesWithSameSender,\n          entriesWithSameStatus\n        );\n\n        if (entriesWithSameSenderAndStatus.length) {\n          senderTree.push(Object.freeze(entriesWithSameSenderAndStatus));\n          removeInline(entriesPendingGrouping, ...entriesWithSameSenderAndStatus);\n\n          found = true;\n        }\n      });\n\n      // If the entry is not grouped by the middleware, just put the entry in its own bin.\n      found || senderTree.push(Object.freeze([entriesPendingGrouping.shift()]));\n\n      activityTree.push(Object.freeze(senderTree));\n    }\n\n    // Assertion: All entries must be assigned to the activityTree.\n    if (\n      !entries.every(activity =>\n        activityTree.some(activitiesWithSameSender =>\n          activitiesWithSameSender.some(activitiesWithSameSenderAndStatus =>\n            activitiesWithSameSenderAndStatus.includes(activity)\n          )\n        )\n      )\n    ) {\n      console.warn('botframework-webchat internal: Not all visible activities are grouped in the activityTree.', {\n        entries,\n        activityTree\n      });\n    }\n\n    return Object.freeze(activityTree);\n  }, [entriesBySender, entriesByStatus, entries]);\n\n  return activityTree;\n}\n\nexport type { ActivityWithRenderer };\n\nexport default useActivityTreeWithRenderer;\n"],"mappings":"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"}
;