UNPKG

botframework-webchat-component

Version:
95 lines (88 loc) 18.5 kB
"use strict"; Object.defineProperty(exports, "__esModule", { value: true }); exports.default = createCoreMiddleware; var _react = _interopRequireDefault(require("react")); var _CarouselLayout = _interopRequireDefault(require("../../Activity/CarouselLayout")); var _StackedLayout = _interopRequireDefault(require("../../Activity/StackedLayout")); function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } function _extends() { _extends = Object.assign ? Object.assign.bind() : function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; return _extends.apply(this, arguments); } function ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); enumerableOnly && (symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; })), keys.push.apply(keys, symbols); } return keys; } function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? ownKeys(Object(source), !0).forEach(function (key) { _defineProperty(target, key, source[key]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)) : ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } return target; } function _defineProperty(obj, key, value) { if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; } function createCoreMiddleware() { return [function () { return function (next) { return function () { for (var _len = arguments.length, args = new Array(_len), _key = 0; _key < _len; _key++) { args[_key] = arguments[_key]; } var activity = args[0].activity; // TODO: [P4] Can we simplify these if-statement to something more readable? var type = activity.type; if (type === 'typing') { if (!('text' in activity && typeof activity.text === 'string' && activity.channelData.streamType !== 'informative')) { // If it is an informative message, hide it until we have a design for informative message. return false; } // Should show if this is useActiveTyping()[0][*].firstActivity, and render it with the content of lastActivity. return function renderStackedLayout(renderAttachment, props) { typeof props === 'undefined' && console.warn('botframework-webchat: One or more arguments were missing after passing through the activity middleware. Please check your custom activity middleware to make sure it passes all arguments.'); return /*#__PURE__*/_react.default.createElement(_StackedLayout.default, _extends({ activity: _objectSpread(_objectSpread({}, activity), {}, { type: 'message' }), renderAttachment: renderAttachment }, props)); }; } // Filter out activities that should not be visible if (type === 'conversationUpdate' || type === 'event' || type === 'invoke') { return false; } else if (type === 'message') { var attachments = activity.attachments, channelData = activity.channelData, text = activity.text; if ( // Do not show postback channelData !== null && channelData !== void 0 && channelData.postBack || // Do not show messageBack if displayText is undefined channelData !== null && channelData !== void 0 && channelData.messageBack && !channelData.messageBack.displayText || // Do not show empty bubbles (no text and attachments, and not "typing") !(text || attachments !== null && attachments !== void 0 && attachments.length)) { return false; } } if (type === 'message' || type === 'typing') { var _activity$attachments; if (type === 'message' && (((_activity$attachments = activity.attachments) === null || _activity$attachments === void 0 ? void 0 : _activity$attachments.length) || 0) > 1 && activity.attachmentLayout === 'carousel') { // The following line is not a React functional component, it's a render function called by useCreateActivityRenderer() hook. // The function signature need to be compatible with older version of activity middleware, which was: // // renderActivity( // renderAttachment: ({ activity, attachment }) => React.Element // ) => React.Element return function renderCarouselLayout(renderAttachment, props) { typeof props === 'undefined' && console.warn('botframework-webchat: One or more arguments were missing after passing through the activity middleware. Please check your custom activity middleware to make sure it passes all arguments.'); return /*#__PURE__*/_react.default.createElement(_CarouselLayout.default, _extends({ activity: activity, renderAttachment: renderAttachment }, props)); }; } // The following line is not a React functional component, it's a render function called by useCreateActivityRenderer() hook. return function renderStackedLayout(renderAttachment, props) { typeof props === 'undefined' && console.warn('botframework-webchat: One or more arguments were missing after passing through the activity middleware. Please check your custom activity middleware to make sure it passes all arguments.'); return /*#__PURE__*/_react.default.createElement(_StackedLayout.default, _extends({ activity: activity, renderAttachment: renderAttachment }, props)); }; } return next.apply(void 0, args); }; }; }]; } //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_react","_interopRequireDefault","require","_CarouselLayout","_StackedLayout","obj","__esModule","default","_extends","Object","assign","bind","target","i","arguments","length","source","key","prototype","hasOwnProperty","call","apply","ownKeys","object","enumerableOnly","keys","getOwnPropertySymbols","symbols","filter","sym","getOwnPropertyDescriptor","enumerable","push","_objectSpread","forEach","_defineProperty","getOwnPropertyDescriptors","defineProperties","defineProperty","value","configurable","writable","createCoreMiddleware","next","_len","args","Array","_key","activity","type","text","channelData","streamType","renderStackedLayout","renderAttachment","props","console","warn","createElement","attachments","postBack","messageBack","displayText","_activity$attachments","attachmentLayout","renderCarouselLayout"],"sourceRoot":"component:///","sources":["../../../src/Middleware/Activity/createCoreMiddleware.tsx"],"sourcesContent":["import { ActivityMiddleware } from 'botframework-webchat-api';\nimport React from 'react';\n\nimport CarouselLayout from '../../Activity/CarouselLayout';\nimport StackedLayout from '../../Activity/StackedLayout';\n\nexport default function createCoreMiddleware(): ActivityMiddleware[] {\n  return [\n    () =>\n      next =>\n      (...args) => {\n        const [{ activity }] = args;\n\n        // TODO: [P4] Can we simplify these if-statement to something more readable?\n\n        const { type } = activity;\n\n        if (type === 'typing') {\n          if (\n            !(\n              'text' in activity &&\n              typeof activity.text === 'string' &&\n              activity.channelData.streamType !== 'informative'\n            )\n          ) {\n            // If it is an informative message, hide it until we have a design for informative message.\n            return false;\n          }\n\n          // Should show if this is useActiveTyping()[0][*].firstActivity, and render it with the content of lastActivity.\n          return function renderStackedLayout(renderAttachment, props) {\n            typeof props === 'undefined' &&\n              console.warn(\n                'botframework-webchat: One or more arguments were missing after passing through the activity middleware. Please check your custom activity middleware to make sure it passes all arguments.'\n              );\n\n            return (\n              <StackedLayout\n                activity={{ ...activity, type: 'message' } as any}\n                renderAttachment={renderAttachment}\n                {...props}\n              />\n            );\n          };\n        }\n\n        // Filter out activities that should not be visible\n        if (type === 'conversationUpdate' || type === 'event' || type === 'invoke') {\n          return false;\n        } else if (type === 'message') {\n          const { attachments, channelData, text } = activity;\n\n          if (\n            // Do not show postback\n            channelData?.postBack ||\n            // Do not show messageBack if displayText is undefined\n            (channelData?.messageBack && !channelData.messageBack.displayText) ||\n            // Do not show empty bubbles (no text and attachments, and not \"typing\")\n            !(text || attachments?.length)\n          ) {\n            return false;\n          }\n        }\n\n        if (type === 'message' || type === 'typing') {\n          if (\n            type === 'message' &&\n            (activity.attachments?.length || 0) > 1 &&\n            activity.attachmentLayout === 'carousel'\n          ) {\n            // The following line is not a React functional component, it's a render function called by useCreateActivityRenderer() hook.\n            // The function signature need to be compatible with older version of activity middleware, which was:\n            //\n            // renderActivity(\n            //   renderAttachment: ({ activity, attachment }) => React.Element\n            // ) => React.Element\n\n            return function renderCarouselLayout(renderAttachment, props) {\n              typeof props === 'undefined' &&\n                console.warn(\n                  'botframework-webchat: One or more arguments were missing after passing through the activity middleware. Please check your custom activity middleware to make sure it passes all arguments.'\n                );\n\n              return <CarouselLayout activity={activity} renderAttachment={renderAttachment} {...props} />;\n            };\n          }\n\n          // The following line is not a React functional component, it's a render function called by useCreateActivityRenderer() hook.\n          return function renderStackedLayout(renderAttachment, props) {\n            typeof props === 'undefined' &&\n              console.warn(\n                'botframework-webchat: One or more arguments were missing after passing through the activity middleware. Please check your custom activity middleware to make sure it passes all arguments.'\n              );\n\n            return <StackedLayout activity={activity} renderAttachment={renderAttachment} {...props} />;\n          };\n        }\n\n        return next(...args);\n      }\n  ];\n}\n"],"mappings":"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"}