botframework-webchat-component
Version:
React component of botframework-webchat
91 lines (90 loc) • 17.7 kB
JavaScript
function _typeof(obj) { "@babel/helpers - typeof"; return _typeof = "function" == typeof Symbol && "symbol" == typeof Symbol.iterator ? function (obj) { return typeof obj; } : function (obj) { return obj && "function" == typeof Symbol && obj.constructor === Symbol && obj !== Symbol.prototype ? "symbol" : typeof obj; }, _typeof(obj); }
Object.defineProperty(exports, "__esModule", {
value: true
});
exports.default = void 0;
var _propTypes = _interopRequireDefault(require("prop-types"));
var _react = _interopRequireWildcard(require("react"));
var _Context = _interopRequireDefault(require("./Context"));
var _getTabIndex = _interopRequireDefault(require("./getTabIndex"));
var _inputtableKey = _interopRequireDefault(require("./inputtableKey"));
var _excluded = ["children", "disabled", "onKeyDownCapture", "sendFocusRef"]; // This is for defaultProps: { children: undefined }
/* eslint no-undefined: "off" */
function _getRequireWildcardCache(nodeInterop) { if (typeof WeakMap !== "function") return null; var cacheBabelInterop = new WeakMap(); var cacheNodeInterop = new WeakMap(); return (_getRequireWildcardCache = function _getRequireWildcardCache(nodeInterop) { return nodeInterop ? cacheNodeInterop : cacheBabelInterop; })(nodeInterop); }
function _interopRequireWildcard(obj, nodeInterop) { if (!nodeInterop && obj && obj.__esModule) { return obj; } if (obj === null || _typeof(obj) !== "object" && typeof obj !== "function") { return { default: obj }; } var cache = _getRequireWildcardCache(nodeInterop); if (cache && cache.has(obj)) { return cache.get(obj); } var newObj = {}; var hasPropertyDescriptor = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var key in obj) { if (key !== "default" && 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 ? 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 _objectWithoutProperties(source, excluded) { if (source == null) return {}; var target = _objectWithoutPropertiesLoose(source, excluded); var key, i; if (Object.getOwnPropertySymbols) { var sourceSymbolKeys = Object.getOwnPropertySymbols(source); for (i = 0; i < sourceSymbolKeys.length; i++) { key = sourceSymbolKeys[i]; if (excluded.indexOf(key) >= 0) continue; if (!Object.prototype.propertyIsEnumerable.call(source, key)) continue; target[key] = source[key]; } } return target; }
function _objectWithoutPropertiesLoose(source, excluded) { if (source == null) return {}; var target = {}; var sourceKeys = Object.keys(source); var key, i; for (i = 0; i < sourceKeys.length; i++) { key = sourceKeys[i]; if (excluded.indexOf(key) >= 0) continue; target[key] = source[key]; } return target; }
var DEFAULT_STYLE = {
outline: 0
};
var BaseFocusBox = function BaseFocusBox(_ref, ref) {
var children = _ref.children,
disabled = _ref.disabled,
onKeyDownCapture = _ref.onKeyDownCapture,
sendFocusRefProp = _ref.sendFocusRef,
otherProps = _objectWithoutProperties(_ref, _excluded);
var sendFocusRefPersist = (0, _react.useRef)(null);
var patchedSendFocusRef = (0, _react.useMemo)(function () {
return sendFocusRefProp || sendFocusRefPersist;
}, [sendFocusRefPersist, sendFocusRefProp]);
var context = (0, _react.useMemo)(function () {
return {
sendFocusRef: patchedSendFocusRef
};
}, [patchedSendFocusRef]);
var focus = (0, _react.useCallback)(function () {
var current = patchedSendFocusRef.current;
current && current.focus();
}, [patchedSendFocusRef]);
var handleKeyDownCapture = (0, _react.useCallback)(function (event) {
onKeyDownCapture && onKeyDownCapture(event);
var altKey = event.altKey,
ctrlKey = event.ctrlKey,
key = event.key,
metaKey = event.metaKey,
target = event.target;
var tabIndex = (0, _getTabIndex.default)(target);
if (altKey || ctrlKey && key !== 'v' || metaKey || !(0, _inputtableKey.default)(key) && key !== 'Backspace') {
// Ignore if one of the utility key (except SHIFT) is pressed
// E.g. CTRL-C on a link in one of the message should not jump to chat box
// E.g. "A" or "Backspace" should jump to chat box
return;
}
if (typeof tabIndex !== 'number' || tabIndex < 0 || target.getAttribute('aria-disabled') === 'true') {
event.stopPropagation();
focus();
}
}, [focus, onKeyDownCapture]);
return /*#__PURE__*/_react.default.createElement(_Context.default.Provider, {
value: context
}, /*#__PURE__*/_react.default.createElement("div", _extends({}, otherProps, {
onKeyDownCapture: disabled ? undefined : handleKeyDownCapture,
ref: ref,
style: DEFAULT_STYLE,
tabIndex: -1
}), typeof children === 'function' ? children({
focus: focus
}) : children));
};
var FocusBox = /*#__PURE__*/(0, _react.forwardRef)(BaseFocusBox);
FocusBox.defaultProps = BaseFocusBox.defaultProps = {
children: undefined,
disabled: false,
onKeyDownCapture: undefined
};
FocusBox.propTypes = BaseFocusBox.propTypes = {
children: _propTypes.default.any,
disabled: _propTypes.default.bool,
onKeyDownCapture: _propTypes.default.func,
sendFocusRef: _propTypes.default.shape({
current: _propTypes.default.shape({
focus: _propTypes.default.func
})
}).isRequired
};
var _default = FocusBox;
exports.default = _default;
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_propTypes","_interopRequireDefault","require","_react","_interopRequireWildcard","_Context","_getTabIndex","_inputtableKey","_excluded","_getRequireWildcardCache","nodeInterop","WeakMap","cacheBabelInterop","cacheNodeInterop","obj","__esModule","_typeof","default","cache","has","get","newObj","hasPropertyDescriptor","Object","defineProperty","getOwnPropertyDescriptor","key","prototype","hasOwnProperty","call","desc","set","_extends","assign","bind","target","i","arguments","length","source","apply","_objectWithoutProperties","excluded","_objectWithoutPropertiesLoose","getOwnPropertySymbols","sourceSymbolKeys","indexOf","propertyIsEnumerable","sourceKeys","keys","DEFAULT_STYLE","outline","BaseFocusBox","_ref","ref","children","disabled","onKeyDownCapture","sendFocusRefProp","sendFocusRef","otherProps","sendFocusRefPersist","useRef","patchedSendFocusRef","useMemo","context","focus","useCallback","current","handleKeyDownCapture","event","altKey","ctrlKey","metaKey","tabIndex","getTabIndex","inputtableKey","getAttribute","stopPropagation","createElement","Provider","value","undefined","style","FocusBox","forwardRef","defaultProps","propTypes","PropTypes","any","bool","func","shape","isRequired","_default","exports"],"sourceRoot":"component:///","sources":["../../../src/Utils/TypeFocusSink/FocusBox.js"],"sourcesContent":["// This is for defaultProps: { children: undefined }\n/* eslint no-undefined: \"off\" */\n\nimport PropTypes from 'prop-types';\nimport React, { forwardRef, useCallback, useMemo, useRef } from 'react';\n\nimport Context from './Context';\nimport getTabIndex from './getTabIndex';\nimport inputtableKey from './inputtableKey';\n\nconst DEFAULT_STYLE = { outline: 0 };\n\nconst BaseFocusBox = ({ children, disabled, onKeyDownCapture, sendFocusRef: sendFocusRefProp, ...otherProps }, ref) => {\n  const sendFocusRefPersist = useRef(null);\n  const patchedSendFocusRef = useMemo(\n    () => sendFocusRefProp || sendFocusRefPersist,\n    [sendFocusRefPersist, sendFocusRefProp]\n  );\n\n  const context = useMemo(\n    () => ({\n      sendFocusRef: patchedSendFocusRef\n    }),\n    [patchedSendFocusRef]\n  );\n\n  const focus = useCallback(() => {\n    const { current } = patchedSendFocusRef;\n\n    current && current.focus();\n  }, [patchedSendFocusRef]);\n\n  const handleKeyDownCapture = useCallback(\n    event => {\n      onKeyDownCapture && onKeyDownCapture(event);\n\n      const { altKey, ctrlKey, key, metaKey, target } = event;\n      const tabIndex = getTabIndex(target);\n\n      if (altKey || (ctrlKey && key !== 'v') || metaKey || (!inputtableKey(key) && key !== 'Backspace')) {\n        // Ignore if one of the utility key (except SHIFT) is pressed\n        // E.g. CTRL-C on a link in one of the message should not jump to chat box\n        // E.g. \"A\" or \"Backspace\" should jump to chat box\n        return;\n      }\n\n      if (typeof tabIndex !== 'number' || tabIndex < 0 || target.getAttribute('aria-disabled') === 'true') {\n        event.stopPropagation();\n\n        focus();\n      }\n    },\n    [focus, onKeyDownCapture]\n  );\n\n  return (\n    <Context.Provider value={context}>\n      <div\n        {...otherProps}\n        onKeyDownCapture={disabled ? undefined : handleKeyDownCapture}\n        ref={ref}\n        style={DEFAULT_STYLE}\n        tabIndex={-1}\n      >\n        {typeof children === 'function' ? children({ focus }) : children}\n      </div>\n    </Context.Provider>\n  );\n};\n\nconst FocusBox = forwardRef(BaseFocusBox);\n\nFocusBox.defaultProps = BaseFocusBox.defaultProps = {\n  children: undefined,\n  disabled: false,\n  onKeyDownCapture: undefined\n};\n\nFocusBox.propTypes = BaseFocusBox.propTypes = {\n  children: PropTypes.any,\n  disabled: PropTypes.bool,\n  onKeyDownCapture: PropTypes.func,\n  sendFocusRef: PropTypes.shape({\n    current: PropTypes.shape({\n      focus: PropTypes.func\n    })\n  }).isRequired\n};\n\nexport default FocusBox;\n"],"mappings":"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"}
;