botframework-webchat-component
Version:
React component of botframework-webchat
211 lines (171 loc) • 22.9 kB
JavaScript
function _typeof(obj) { "@babel/helpers - typeof"; if (typeof Symbol === "function" && typeof Symbol.iterator === "symbol") { _typeof = function _typeof(obj) { return typeof obj; }; } else { _typeof = function _typeof(obj) { return obj && typeof Symbol === "function" && obj.constructor === Symbol && obj !== Symbol.prototype ? "symbol" : typeof obj; }; } return _typeof(obj); }
Object.defineProperty(exports, "__esModule", {
value: true
});
exports.connectSuggestedAction = exports.default = void 0;
var _botframeworkWebchatApi = require("botframework-webchat-api");
var _classnames = _interopRequireDefault(require("classnames"));
var _propTypes = _interopRequireDefault(require("prop-types"));
var _react = _interopRequireWildcard(require("react"));
var _AccessibleButton = _interopRequireDefault(require("../Utils/AccessibleButton"));
var _connectToWebChat = _interopRequireDefault(require("../connectToWebChat"));
var _useFocus = _interopRequireDefault(require("../hooks/useFocus"));
var _useFocusAccessKeyEffect = _interopRequireDefault(require("../Utils/AccessKeySink/useFocusAccessKeyEffect"));
var _useLocalizeAccessKey = _interopRequireDefault(require("../hooks/internal/useLocalizeAccessKey"));
var _useScrollToEnd = _interopRequireDefault(require("../hooks/useScrollToEnd"));
var _useSuggestedActionsAccessKey = _interopRequireDefault(require("../hooks/internal/useSuggestedActionsAccessKey"));
var _useStyleSet3 = _interopRequireDefault(require("../hooks/useStyleSet"));
var _useStyleToEmotionObject = _interopRequireDefault(require("../hooks/internal/useStyleToEmotionObject"));
function _getRequireWildcardCache() { if (typeof WeakMap !== "function") return null; var cache = new WeakMap(); _getRequireWildcardCache = function _getRequireWildcardCache() { return cache; }; return cache; }
function _interopRequireWildcard(obj) { if (obj && obj.__esModule) { return obj; } if (obj === null || _typeof(obj) !== "object" && typeof obj !== "function") { return { default: obj }; } var cache = _getRequireWildcardCache(); if (cache && cache.has(obj)) { return cache.get(obj); } var newObj = {}; var hasPropertyDescriptor = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var key in obj) { if (Object.prototype.hasOwnProperty.call(obj, key)) { var desc = hasPropertyDescriptor ? Object.getOwnPropertyDescriptor(obj, key) : null; if (desc && (desc.get || desc.set)) { Object.defineProperty(newObj, key, desc); } else { newObj[key] = obj[key]; } } } newObj.default = obj; if (cache) { cache.set(obj, newObj); } return newObj; }
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
function _extends() { _extends = Object.assign || 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 _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 _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 _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 _iterableToArrayLimit(arr, i) { if (typeof Symbol === "undefined" || !(Symbol.iterator in Object(arr))) return; var _arr = []; var _n = true; var _d = false; var _e = undefined; try { for (var _i = arr[Symbol.iterator](), _s; !(_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; }
var useDirection = _botframeworkWebchatApi.hooks.useDirection,
useDisabled = _botframeworkWebchatApi.hooks.useDisabled,
usePerformCardAction = _botframeworkWebchatApi.hooks.usePerformCardAction,
useStyleOptions = _botframeworkWebchatApi.hooks.useStyleOptions,
useSuggestedActions = _botframeworkWebchatApi.hooks.useSuggestedActions;
var ROOT_STYLE = {
'&.webchat__suggested-action': {
'& .webchat__suggested-action__button': {
display: 'flex',
overflow: 'hidden' // Prevent image from leaking; object-fit does not work with IE11
}
}
};
var connectSuggestedAction = function connectSuggestedAction() {
for (var _len = arguments.length, selectors = new Array(_len), _key = 0; _key < _len; _key++) {
selectors[_key] = arguments[_key];
}
return _connectToWebChat.default.apply(void 0, [function (_ref, _ref2) {
var clearSuggestedActions = _ref.clearSuggestedActions,
disabled = _ref.disabled,
language = _ref.language,
onCardAction = _ref.onCardAction;
var displayText = _ref2.displayText,
text = _ref2.text,
type = _ref2.type,
value = _ref2.value;
return {
click: function click() {
onCardAction({
displayText: displayText,
text: text,
type: type,
value: value
});
type === 'openUrl' && clearSuggestedActions();
},
disabled: disabled,
language: language
};
}].concat(selectors));
};
exports.connectSuggestedAction = connectSuggestedAction;
var SuggestedAction = function SuggestedAction(_ref3) {
var ariaHidden = _ref3['aria-hidden'],
buttonText = _ref3.buttonText,
className = _ref3.className,
displayText = _ref3.displayText,
image = _ref3.image,
imageAlt = _ref3.imageAlt,
text = _ref3.text,
textClassName = _ref3.textClassName,
type = _ref3.type,
value = _ref3.value;
var _useSuggestedActions = useSuggestedActions(),
_useSuggestedActions2 = _slicedToArray(_useSuggestedActions, 2),
_ = _useSuggestedActions2[0],
setSuggestedActions = _useSuggestedActions2[1];
var _useStyleOptions = useStyleOptions(),
_useStyleOptions2 = _slicedToArray(_useStyleOptions, 1),
suggestedActionsStackedLayoutButtonTextWrap = _useStyleOptions2[0].suggestedActionsStackedLayoutButtonTextWrap;
var _useStyleSet = (0, _useStyleSet3.default)(),
_useStyleSet2 = _slicedToArray(_useStyleSet, 1),
suggestedActionStyleSet = _useStyleSet2[0].suggestedAction;
var _useSuggestedActionsA = (0, _useSuggestedActionsAccessKey.default)(),
_useSuggestedActionsA2 = _slicedToArray(_useSuggestedActionsA, 1),
accessKey = _useSuggestedActionsA2[0];
var _useDirection = useDirection(),
_useDirection2 = _slicedToArray(_useDirection, 1),
direction = _useDirection2[0];
var _useDisabled = useDisabled(),
_useDisabled2 = _slicedToArray(_useDisabled, 1),
disabled = _useDisabled2[0];
var focus = (0, _useFocus.default)();
var focusRef = (0, _react.useRef)();
var localizeAccessKey = (0, _useLocalizeAccessKey.default)();
var performCardAction = usePerformCardAction();
var scrollToEnd = (0, _useScrollToEnd.default)();
var rootClassName = (0, _useStyleToEmotionObject.default)()(ROOT_STYLE) + '';
var handleClick = (0, _react.useCallback)(function (_ref4) {
var target = _ref4.target;
performCardAction({
displayText: displayText,
text: text,
type: type,
value: value
}, {
target: target
}); // Since "openUrl" action do not submit, the suggested action buttons do not hide after click.
type === 'openUrl' && setSuggestedActions([]);
focus('sendBoxWithoutKeyboard');
scrollToEnd();
}, [displayText, focus, performCardAction, scrollToEnd, setSuggestedActions, text, type, value]);
(0, _useFocusAccessKeyEffect.default)(accessKey, focusRef);
return /*#__PURE__*/_react.default.createElement("div", {
"aria-hidden": ariaHidden,
className: (0, _classnames.default)('webchat__suggested-action', {
'webchat__suggested-action--rtl': direction === 'rtl'
}, rootClassName, suggestedActionStyleSet + '', (className || '') + '')
}, /*#__PURE__*/_react.default.createElement(_AccessibleButton.default, _extends({}, accessKey ? {
'aria-keyshortcuts': localizeAccessKey(accessKey)
} : {}, {
className: (0, _classnames.default)('webchat__suggested-action__button', {
'webchat__suggested-action--wrapping': suggestedActionsStackedLayoutButtonTextWrap
}),
disabled: disabled,
onClick: handleClick,
ref: focusRef,
type: "button"
}), image && /*#__PURE__*/_react.default.createElement("img", {
alt: imageAlt,
className: (0, _classnames.default)('webchat__suggested-action__image', direction === 'rtl' && 'webchat__suggested-action__image--rtl'),
src: image
}), /*#__PURE__*/_react.default.createElement("span", {
className: (0, _classnames.default)('webchat__suggested-action__text', (textClassName || '') + '')
}, buttonText)));
};
SuggestedAction.defaultProps = {
'aria-hidden': false,
className: '',
displayText: '',
image: '',
imageAlt: undefined,
text: '',
textClassName: '',
type: '',
value: undefined
};
SuggestedAction.propTypes = {
'aria-hidden': _propTypes.default.bool,
buttonText: _propTypes.default.string.isRequired,
className: _propTypes.default.string,
displayText: _propTypes.default.string,
image: _propTypes.default.string,
imageAlt: _propTypes.default.string,
text: _propTypes.default.string,
textClassName: _propTypes.default.string,
type: _propTypes.default.string,
value: _propTypes.default.any
};
var _default = SuggestedAction;
exports.default = _default;
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/SendBox/SuggestedAction.js"],"names":["useDirection","hooks","useDisabled","usePerformCardAction","useStyleOptions","useSuggestedActions","ROOT_STYLE","display","overflow","connectSuggestedAction","selectors","connectToWebChat","clearSuggestedActions","disabled","language","onCardAction","displayText","text","type","value","click","SuggestedAction","ariaHidden","buttonText","className","image","imageAlt","textClassName","_","setSuggestedActions","suggestedActionsStackedLayoutButtonTextWrap","suggestedActionStyleSet","suggestedAction","accessKey","direction","focus","focusRef","localizeAccessKey","performCardAction","scrollToEnd","rootClassName","handleClick","target","defaultProps","undefined","propTypes","PropTypes","bool","string","isRequired","any"],"mappings":"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","sourceRoot":"component:///","sourcesContent":["import { hooks } from 'botframework-webchat-api';\nimport classNames from 'classnames';\nimport PropTypes from 'prop-types';\nimport React, { useCallback, useRef } from 'react';\n\nimport AccessibleButton from '../Utils/AccessibleButton';\nimport connectToWebChat from '../connectToWebChat';\nimport useFocus from '../hooks/useFocus';\nimport useFocusAccessKeyEffect from '../Utils/AccessKeySink/useFocusAccessKeyEffect';\nimport useLocalizeAccessKey from '../hooks/internal/useLocalizeAccessKey';\nimport useScrollToEnd from '../hooks/useScrollToEnd';\nimport useSuggestedActionsAccessKey from '../hooks/internal/useSuggestedActionsAccessKey';\nimport useStyleSet from '../hooks/useStyleSet';\nimport useStyleToEmotionObject from '../hooks/internal/useStyleToEmotionObject';\n\nconst { useDirection, useDisabled, usePerformCardAction, useStyleOptions, useSuggestedActions } = hooks;\n\nconst ROOT_STYLE = {\n  '&.webchat__suggested-action': {\n    '& .webchat__suggested-action__button': {\n      display: 'flex',\n      overflow: 'hidden' // Prevent image from leaking; object-fit does not work with IE11\n    }\n  }\n};\n\nconst connectSuggestedAction = (...selectors) =>\n  connectToWebChat(\n    ({ clearSuggestedActions, disabled, language, onCardAction }, { displayText, text, type, value }) => ({\n      click: () => {\n        onCardAction({ displayText, text, type, value });\n        type === 'openUrl' && clearSuggestedActions();\n      },\n      disabled,\n      language\n    }),\n    ...selectors\n  );\n\nconst SuggestedAction = ({\n  'aria-hidden': ariaHidden,\n  buttonText,\n  className,\n  displayText,\n  image,\n  imageAlt,\n  text,\n  textClassName,\n  type,\n  value\n}) => {\n  const [_, setSuggestedActions] = useSuggestedActions();\n  const [{ suggestedActionsStackedLayoutButtonTextWrap }] = useStyleOptions();\n  const [{ suggestedAction: suggestedActionStyleSet }] = useStyleSet();\n  const [accessKey] = useSuggestedActionsAccessKey();\n  const [direction] = useDirection();\n  const [disabled] = useDisabled();\n  const focus = useFocus();\n  const focusRef = useRef();\n  const localizeAccessKey = useLocalizeAccessKey();\n  const performCardAction = usePerformCardAction();\n  const scrollToEnd = useScrollToEnd();\n  const rootClassName = useStyleToEmotionObject()(ROOT_STYLE) + '';\n\n  const handleClick = useCallback(\n    ({ target }) => {\n      performCardAction({ displayText, text, type, value }, { target });\n\n      // Since \"openUrl\" action do not submit, the suggested action buttons do not hide after click.\n      type === 'openUrl' && setSuggestedActions([]);\n\n      focus('sendBoxWithoutKeyboard');\n      scrollToEnd();\n    },\n    [displayText, focus, performCardAction, scrollToEnd, setSuggestedActions, text, type, value]\n  );\n\n  useFocusAccessKeyEffect(accessKey, focusRef);\n\n  return (\n    <div\n      aria-hidden={ariaHidden}\n      className={classNames(\n        'webchat__suggested-action',\n        { 'webchat__suggested-action--rtl': direction === 'rtl' },\n        rootClassName,\n        suggestedActionStyleSet + '',\n        (className || '') + ''\n      )}\n    >\n      <AccessibleButton\n        {...(accessKey ? { 'aria-keyshortcuts': localizeAccessKey(accessKey) } : {})}\n        className={classNames('webchat__suggested-action__button', {\n          'webchat__suggested-action--wrapping': suggestedActionsStackedLayoutButtonTextWrap\n        })}\n        disabled={disabled}\n        onClick={handleClick}\n        ref={focusRef}\n        type=\"button\"\n      >\n        {image && (\n          <img\n            alt={imageAlt}\n            className={classNames(\n              'webchat__suggested-action__image',\n              direction === 'rtl' && 'webchat__suggested-action__image--rtl'\n            )}\n            src={image}\n          />\n        )}\n        <span className={classNames('webchat__suggested-action__text', (textClassName || '') + '')}>{buttonText}</span>\n      </AccessibleButton>\n    </div>\n  );\n};\n\nSuggestedAction.defaultProps = {\n  'aria-hidden': false,\n  className: '',\n  displayText: '',\n  image: '',\n  imageAlt: undefined,\n  text: '',\n  textClassName: '',\n  type: '',\n  value: undefined\n};\n\nSuggestedAction.propTypes = {\n  'aria-hidden': PropTypes.bool,\n  buttonText: PropTypes.string.isRequired,\n  className: PropTypes.string,\n  displayText: PropTypes.string,\n  image: PropTypes.string,\n  imageAlt: PropTypes.string,\n  text: PropTypes.string,\n  textClassName: PropTypes.string,\n  type: PropTypes.string,\n  value: PropTypes.any\n};\n\nexport default SuggestedAction;\n\nexport { connectSuggestedAction };\n"]}
;