UNPKG

botframework-webchat-component

Version:
78 lines (75 loc) 15.7 kB
"use strict"; 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 _excluded = ["aria-hidden", "children", "disabled", "onClick", "tabIndex"]; /* eslint no-magic-numbers: ["error", { "ignore": [-1] }] */ 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 PREVENT_DEFAULT_HANDLER = function PREVENT_DEFAULT_HANDLER(event) { return event.preventDefault(); }; // Differences between <button> and <AccessibleButton>: // - Disable behavior // - When the widget is disabled // - Set "aria-disabled" attribute to "true" // - Set "readonly" attribute // - Set "tabIndex" to -1 // - Remove "onClick" handler // - Why this is needed // - Browser compatibility: when the widget is disabled, different browser send focus to different places // - When the widget become disabled, it's reasonable to keep the focus on the same widget for an extended period of time // - When the user presses TAB after the current widget is disabled, it should jump to the next non-disabled widget // Developers using this accessible widget will need to: // - Style the disabled widget themselves, using CSS query `:disabled, [aria-disabled="true"] {}` // - Modify all code that check disabled through "disabled" attribute to use aria-disabled="true" instead // - aria-disabled="true" is the source of truth // - If the widget is contained by a <form>, the developer need to filter out some `onSubmit` event caused by this widget var AccessibleButton = /*#__PURE__*/(0, _react.forwardRef)(function (_ref, forwardedRef) { var ariaHidden = _ref['aria-hidden'], children = _ref.children, disabled = _ref.disabled, onClick = _ref.onClick, tabIndex = _ref.tabIndex, props = _objectWithoutProperties(_ref, _excluded); var targetRef = (0, _react.useRef)(); var ref = forwardedRef || targetRef; return /*#__PURE__*/_react.default.createElement("button", _extends({ "aria-disabled": disabled || undefined, "aria-hidden": ariaHidden, onClick: disabled ? PREVENT_DEFAULT_HANDLER : onClick, ref: ref, tabIndex: disabled ? -1 : tabIndex }, props, { type: "button" }), children); }); AccessibleButton.defaultProps = { 'aria-hidden': undefined, children: undefined, disabled: undefined, onClick: undefined, tabIndex: undefined }; AccessibleButton.displayName = 'AccessibleButton'; AccessibleButton.propTypes = { 'aria-hidden': _propTypes.default.bool, children: _propTypes.default.any, disabled: _propTypes.default.bool, onClick: _propTypes.default.func, tabIndex: _propTypes.default.number, // TypeScript class is not mappable to PropTypes.oneOf(['button']) // @ts-ignore type: _propTypes.default.oneOf(['button']).isRequired }; var _default = AccessibleButton; exports.default = _default; //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_propTypes","_interopRequireDefault","require","_react","_interopRequireWildcard","_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","PREVENT_DEFAULT_HANDLER","event","preventDefault","AccessibleButton","forwardRef","_ref","forwardedRef","ariaHidden","children","disabled","onClick","tabIndex","props","targetRef","useRef","ref","createElement","undefined","type","defaultProps","displayName","propTypes","PropTypes","bool","any","func","number","oneOf","isRequired","_default","exports"],"sourceRoot":"component:///","sources":["../../src/Utils/AccessibleButton.tsx"],"sourcesContent":["/* eslint no-magic-numbers: [\"error\", { \"ignore\": [-1] }] */\n\nimport PropTypes from 'prop-types';\nimport React, { forwardRef, MouseEventHandler, ReactNode, useRef } from 'react';\n\nconst PREVENT_DEFAULT_HANDLER = event => event.preventDefault();\n\ntype AccessibleButtonProps = {\n  'aria-hidden'?: boolean;\n  children?: ReactNode;\n  disabled?: boolean;\n  onClick?: MouseEventHandler<HTMLButtonElement>;\n  tabIndex?: number;\n  type: 'button';\n} & React.ButtonHTMLAttributes<HTMLButtonElement>;\n\n// Differences between <button> and <AccessibleButton>:\n// - Disable behavior\n//   - When the widget is disabled\n//     - Set \"aria-disabled\" attribute to \"true\"\n//     - Set \"readonly\" attribute\n//     - Set \"tabIndex\" to -1\n//     - Remove \"onClick\" handler\n//   - Why this is needed\n//     - Browser compatibility: when the widget is disabled, different browser send focus to different places\n//     - When the widget become disabled, it's reasonable to keep the focus on the same widget for an extended period of time\n//       - When the user presses TAB after the current widget is disabled, it should jump to the next non-disabled widget\n\n// Developers using this accessible widget will need to:\n// - Style the disabled widget themselves, using CSS query `:disabled, [aria-disabled=\"true\"] {}`\n// - Modify all code that check disabled through \"disabled\" attribute to use aria-disabled=\"true\" instead\n//   - aria-disabled=\"true\" is the source of truth\n// - If the widget is contained by a <form>, the developer need to filter out some `onSubmit` event caused by this widget\n\nconst AccessibleButton = forwardRef<HTMLButtonElement, AccessibleButtonProps>(\n  ({ 'aria-hidden': ariaHidden, children, disabled, onClick, tabIndex, ...props }, forwardedRef) => {\n    const targetRef = useRef();\n\n    const ref = forwardedRef || targetRef;\n\n    return (\n      <button\n        aria-disabled={disabled || undefined}\n        aria-hidden={ariaHidden}\n        onClick={disabled ? PREVENT_DEFAULT_HANDLER : onClick}\n        ref={ref}\n        tabIndex={disabled ? -1 : tabIndex}\n        {...props}\n        type=\"button\"\n      >\n        {children}\n      </button>\n    );\n  }\n);\n\nAccessibleButton.defaultProps = {\n  'aria-hidden': undefined,\n  children: undefined,\n  disabled: undefined,\n  onClick: undefined,\n  tabIndex: undefined\n};\n\nAccessibleButton.displayName = 'AccessibleButton';\n\nAccessibleButton.propTypes = {\n  'aria-hidden': PropTypes.bool,\n  children: PropTypes.any,\n  disabled: PropTypes.bool,\n  onClick: PropTypes.func,\n  tabIndex: PropTypes.number,\n  // TypeScript class is not mappable to PropTypes.oneOf(['button'])\n  // @ts-ignore\n  type: PropTypes.oneOf(['button']).isRequired\n};\n\nexport default AccessibleButton;\n"],"mappings":"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"}