botframework-webchat-component
Version:
React component of botframework-webchat
157 lines (128 loc) • 17.6 kB
JavaScript
Object.defineProperty(exports, "__esModule", {
value: true
});
exports.default = void 0;
var _botframeworkWebchatApi = require("botframework-webchat-api");
var _classnames = _interopRequireDefault(require("classnames"));
var _propTypes = _interopRequireDefault(require("prop-types"));
var _react = _interopRequireDefault(require("react"));
var _isZeroOrPositive = _interopRequireDefault(require("../Utils/isZeroOrPositive"));
var _useStyleSet3 = _interopRequireDefault(require("../hooks/useStyleSet"));
var _useStyleToEmotionObject = _interopRequireDefault(require("../hooks/internal/useStyleToEmotionObject"));
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 _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,
useStyleOptions = _botframeworkWebchatApi.hooks.useStyleOptions;
var ROOT_STYLE = {
'&.webchat__bubble': {
display: 'flex',
position: 'relative',
'& .webchat__bubble__nub-pad': {
flexShrink: 0
},
'& .webchat__bubble__content': {
flexGrow: 1,
// This is for hiding content outside of the bubble, for example, content outside of border radius
overflow: 'hidden'
}
}
};
function acuteNubSVG(nubSize, strokeWidth, side) {
var upSideDown = arguments.length > 3 && arguments[3] !== undefined ? arguments[3] : false;
if (typeof nubSize !== 'number') {
return false;
}
var halfNubSize = nubSize / 2;
var halfStrokeWidth = strokeWidth / 2; // Horizontally mirror the nub if it is from user
var horizontalTransform = side === 'bot' ? '' : "translate(".concat(halfNubSize, " 0) scale(-1 1) translate(").concat(-halfNubSize, " 0)"); // Vertically mirror the nub if it is up-side-down
var verticalTransform = upSideDown ? "translate(0 ".concat(halfNubSize, ") scale(1 -1) translate(0 ").concat(-halfNubSize, ")") : '';
var p1 = [nubSize, halfStrokeWidth].join(' ');
var p2 = [strokeWidth, halfStrokeWidth].join(' ');
var p3 = [nubSize + strokeWidth, nubSize + halfStrokeWidth].join(' ');
return /*#__PURE__*/_react.default.createElement("svg", {
className: "webchat__bubble__nub",
version: "1.1",
viewBox: "0 0 ".concat(nubSize, " ").concat(nubSize),
xmlns: "http://www.w3.org/2000/svg"
}, /*#__PURE__*/_react.default.createElement("g", {
transform: "".concat(horizontalTransform, " ").concat(verticalTransform)
}, /*#__PURE__*/_react.default.createElement("path", {
className: "webchat__bubble__nub-outline",
d: "M".concat(p1, " L").concat(p2, " L").concat(p3)
})));
}
var Bubble = function Bubble(_ref) {
var ariaHidden = _ref['aria-hidden'],
children = _ref.children,
className = _ref.className,
fromUser = _ref.fromUser,
nub = _ref.nub;
var _useStyleSet = (0, _useStyleSet3.default)(),
_useStyleSet2 = _slicedToArray(_useStyleSet, 1),
bubbleStyleSet = _useStyleSet2[0].bubble;
var _useDirection = useDirection(),
_useDirection2 = _slicedToArray(_useDirection, 1),
direction = _useDirection2[0];
var _useStyleOptions = useStyleOptions(),
_useStyleOptions2 = _slicedToArray(_useStyleOptions, 1),
_useStyleOptions2$ = _useStyleOptions2[0],
bubbleBorderWidth = _useStyleOptions2$.bubbleBorderWidth,
bubbleFromUserBorderWidth = _useStyleOptions2$.bubbleFromUserBorderWidth,
bubbleFromUserNubSize = _useStyleOptions2$.bubbleFromUserNubSize,
bubbleNubSize = _useStyleOptions2$.bubbleNubSize,
bubbleNubOffset = _useStyleOptions2$.bubbleNubOffset,
bubbleFromUserNubOffset = _useStyleOptions2$.bubbleFromUserNubOffset;
var rootClassName = (0, _useStyleToEmotionObject.default)()(ROOT_STYLE) + '';
var _ref2 = fromUser ? {
borderWidth: bubbleFromUserBorderWidth,
nubOffset: bubbleFromUserNubOffset,
nubSize: bubbleFromUserNubSize,
side: 'user'
} : {
borderWidth: bubbleBorderWidth,
nubOffset: bubbleNubOffset,
nubSize: bubbleNubSize,
side: 'bot'
},
borderWidth = _ref2.borderWidth,
nubOffset = _ref2.nubOffset,
nubSize = _ref2.nubSize,
side = _ref2.side;
return /*#__PURE__*/_react.default.createElement("div", {
"aria-hidden": ariaHidden,
className: (0, _classnames.default)('webchat__bubble', {
'webchat__bubble--from-user': fromUser,
'webchat__bubble--hide-nub': nub !== true && nub !== false,
'webchat__bubble--nub-on-top': (0, _isZeroOrPositive.default)(nubOffset),
'webchat__bubble--rtl': direction === 'rtl',
'webchat__bubble--show-nub': nub === true
}, rootClassName, bubbleStyleSet + '', (className || '') + '')
}, /*#__PURE__*/_react.default.createElement("div", {
className: "webchat__bubble__nub-pad"
}), /*#__PURE__*/_react.default.createElement("div", {
className: "webchat__bubble__content"
}, children), nub === true && acuteNubSVG(nubSize, borderWidth, side, !(0, _isZeroOrPositive.default)(nubOffset)));
};
Bubble.defaultProps = {
'aria-hidden': undefined,
children: undefined,
className: '',
fromUser: false,
nub: false
};
Bubble.propTypes = {
'aria-hidden': _propTypes.default.bool,
children: _propTypes.default.any,
className: _propTypes.default.string,
fromUser: _propTypes.default.bool,
nub: _propTypes.default.oneOf([true, false, 'hidden'])
};
var _default = Bubble;
exports.default = _default;
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/Activity/Bubble.js"],"names":["useDirection","hooks","useStyleOptions","ROOT_STYLE","display","position","flexShrink","flexGrow","overflow","acuteNubSVG","nubSize","strokeWidth","side","upSideDown","halfNubSize","halfStrokeWidth","horizontalTransform","verticalTransform","p1","join","p2","p3","Bubble","ariaHidden","children","className","fromUser","nub","bubbleStyleSet","bubble","direction","bubbleBorderWidth","bubbleFromUserBorderWidth","bubbleFromUserNubSize","bubbleNubSize","bubbleNubOffset","bubbleFromUserNubOffset","rootClassName","borderWidth","nubOffset","defaultProps","undefined","propTypes","PropTypes","bool","any","string","oneOf"],"mappings":"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","sourceRoot":"component:///","sourcesContent":["/* eslint no-magic-numbers: [\"error\", { \"ignore\": [-1, 0, 1, 2, 10] }] */\n\nimport { hooks } from 'botframework-webchat-api';\nimport classNames from 'classnames';\nimport PropTypes from 'prop-types';\nimport React from 'react';\n\nimport isZeroOrPositive from '../Utils/isZeroOrPositive';\nimport useStyleSet from '../hooks/useStyleSet';\nimport useStyleToEmotionObject from '../hooks/internal/useStyleToEmotionObject';\n\nconst { useDirection, useStyleOptions } = hooks;\n\nconst ROOT_STYLE = {\n  '&.webchat__bubble': {\n    display: 'flex',\n    position: 'relative',\n\n    '& .webchat__bubble__nub-pad': {\n      flexShrink: 0\n    },\n\n    '& .webchat__bubble__content': {\n      flexGrow: 1,\n\n      // This is for hiding content outside of the bubble, for example, content outside of border radius\n      overflow: 'hidden'\n    }\n  }\n};\n\nfunction acuteNubSVG(nubSize, strokeWidth, side, upSideDown = false) {\n  if (typeof nubSize !== 'number') {\n    return false;\n  }\n\n  const halfNubSize = nubSize / 2;\n  const halfStrokeWidth = strokeWidth / 2;\n\n  // Horizontally mirror the nub if it is from user\n  const horizontalTransform =\n    side === 'bot' ? '' : `translate(${halfNubSize} 0) scale(-1 1) translate(${-halfNubSize} 0)`;\n\n  // Vertically mirror the nub if it is up-side-down\n  const verticalTransform = upSideDown ? `translate(0 ${halfNubSize}) scale(1 -1) translate(0 ${-halfNubSize})` : '';\n\n  const p1 = [nubSize, halfStrokeWidth].join(' ');\n  const p2 = [strokeWidth, halfStrokeWidth].join(' ');\n  const p3 = [nubSize + strokeWidth, nubSize + halfStrokeWidth].join(' ');\n\n  return (\n    <svg\n      className=\"webchat__bubble__nub\"\n      version=\"1.1\"\n      viewBox={`0 0 ${nubSize} ${nubSize}`}\n      xmlns=\"http://www.w3.org/2000/svg\"\n    >\n      <g transform={`${horizontalTransform} ${verticalTransform}`}>\n        <path className=\"webchat__bubble__nub-outline\" d={`M${p1} L${p2} L${p3}`} />\n      </g>\n    </svg>\n  );\n}\n\nconst Bubble = ({ 'aria-hidden': ariaHidden, children, className, fromUser, nub }) => {\n  const [{ bubble: bubbleStyleSet }] = useStyleSet();\n  const [direction] = useDirection();\n  const [\n    {\n      bubbleBorderWidth,\n      bubbleFromUserBorderWidth,\n      bubbleFromUserNubSize,\n      bubbleNubSize,\n      bubbleNubOffset,\n      bubbleFromUserNubOffset\n    }\n  ] = useStyleOptions();\n  const rootClassName = useStyleToEmotionObject()(ROOT_STYLE) + '';\n\n  const { borderWidth, nubOffset, nubSize, side } = fromUser\n    ? {\n        borderWidth: bubbleFromUserBorderWidth,\n        nubOffset: bubbleFromUserNubOffset,\n        nubSize: bubbleFromUserNubSize,\n        side: 'user'\n      }\n    : {\n        borderWidth: bubbleBorderWidth,\n        nubOffset: bubbleNubOffset,\n        nubSize: bubbleNubSize,\n        side: 'bot'\n      };\n\n  return (\n    <div\n      aria-hidden={ariaHidden}\n      className={classNames(\n        'webchat__bubble',\n        {\n          'webchat__bubble--from-user': fromUser,\n          'webchat__bubble--hide-nub': nub !== true && nub !== false,\n          'webchat__bubble--nub-on-top': isZeroOrPositive(nubOffset),\n          'webchat__bubble--rtl': direction === 'rtl',\n          'webchat__bubble--show-nub': nub === true\n        },\n        rootClassName,\n        bubbleStyleSet + '',\n        (className || '') + ''\n      )}\n    >\n      <div className=\"webchat__bubble__nub-pad\" />\n      <div className=\"webchat__bubble__content\">{children}</div>\n      {nub === true && acuteNubSVG(nubSize, borderWidth, side, !isZeroOrPositive(nubOffset))}\n    </div>\n  );\n};\n\nBubble.defaultProps = {\n  'aria-hidden': undefined,\n  children: undefined,\n  className: '',\n  fromUser: false,\n  nub: false\n};\n\nBubble.propTypes = {\n  'aria-hidden': PropTypes.bool,\n  children: PropTypes.any,\n  className: PropTypes.string,\n  fromUser: PropTypes.bool,\n  nub: PropTypes.oneOf([true, false, 'hidden'])\n};\n\nexport default Bubble;\n"]}
;