botframework-webchat 4.16.1-main.20240328.82ad15e → 4.16.1-main.20240401.512cc60

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -1,6 +1,6 @@
1
1
  import { AdaptiveCard } from 'adaptivecards';
2
- import { VFC } from 'react';
3
2
  import type { DirectLineCardAction } from 'botframework-webchat-core';
3
+ import { VFC } from 'react';
4
4
  type AdaptiveCardRendererProps = {
5
5
  actionPerformedClassName?: string;
6
6
  adaptiveCard: AdaptiveCard;
@@ -1 +1 @@
1
- {"version":3,"file":"AdaptiveCardRenderer.d.ts","sourceRoot":"","sources":["../../../src/adaptiveCards/Attachment/AdaptiveCardRenderer.tsx"],"names":[],"mappings":"AAEA,OAAO,EAAgC,YAAY,EAA+B,MAAM,eAAe,CAAC;AAIxG,OAAc,EAOZ,GAAG,EACJ,MAAM,OAAO,CAAC;AACf,OAAO,KAAK,EAAE,oBAAoB,EAAE,MAAM,2BAA2B,CAAC;AAoBtE,KAAK,yBAAyB,GAAG;IAC/B,wBAAwB,CAAC,EAAE,MAAM,CAAC;IAClC,YAAY,EAAE,YAAY,CAAC;IAC3B,QAAQ,CAAC,EAAE,OAAO,CAAC;IACnB,SAAS,CAAC,EAAE,oBAAoB,CAAC;CAClC,CAAC;AAEF,QAAA,MAAM,oBAAoB,EAAE,GAAG,CAAC,yBAAyB,CAsNxD,CAAC;AAuBF,eAAe,oBAAoB,CAAC"}
1
+ {"version":3,"file":"AdaptiveCardRenderer.d.ts","sourceRoot":"","sources":["../../../src/adaptiveCards/Attachment/AdaptiveCardRenderer.tsx"],"names":[],"mappings":"AAEA,OAAO,EAAE,YAAY,EAA6D,MAAM,eAAe,CAAC;AAExG,OAAO,KAAK,EAAE,oBAAoB,EAAE,MAAM,2BAA2B,CAAC;AAGtE,OAAc,EAGZ,GAAG,EAKJ,MAAM,OAAO,CAAC;AAmBf,KAAK,yBAAyB,GAAG;IAC/B,wBAAwB,CAAC,EAAE,MAAM,CAAC;IAClC,YAAY,EAAE,YAAY,CAAC;IAC3B,QAAQ,CAAC,EAAE,OAAO,CAAC;IACnB,SAAS,CAAC,EAAE,oBAAoB,CAAC;CAClC,CAAC;AAEF,QAAA,MAAM,oBAAoB,EAAE,GAAG,CAAC,yBAAyB,CAgNxD,CAAC;AAuBF,eAAe,oBAAoB,CAAC"}
@@ -11,17 +11,16 @@ var _botframeworkWebchatComponent = require("botframework-webchat-component");
11
11
  var _classnames = _interopRequireDefault(require("classnames"));
12
12
  var _propTypes = _interopRequireDefault(require("prop-types"));
13
13
  var _react = _interopRequireWildcard(require("react"));
14
- var _renderAdaptiveCard = _interopRequireDefault(require("./private/renderAdaptiveCard"));
15
- var _useActionSetShouldNotBeMenuBarModEffect = _interopRequireDefault(require("./AdaptiveCardHacks/useActionSetShouldNotBeMenuBarModEffect"));
16
- var _useActionShouldBePushButtonModEffect = _interopRequireDefault(require("./AdaptiveCardHacks/useActionShouldBePushButtonModEffect"));
17
- var _useActiveElementModEffect = _interopRequireDefault(require("./AdaptiveCardHacks/useActiveElementModEffect"));
14
+ var _useStyleSet3 = _interopRequireDefault(require("../../hooks/useStyleSet"));
18
15
  var _useAdaptiveCardsHostConfig = _interopRequireDefault(require("../hooks/useAdaptiveCardsHostConfig"));
19
16
  var _useAdaptiveCardsPackage = _interopRequireDefault(require("../hooks/useAdaptiveCardsPackage"));
17
+ var _useValueRef = _interopRequireDefault(require("./AdaptiveCardHacks/private/useValueRef"));
18
+ var _useActionShouldBePushButtonModEffect = _interopRequireDefault(require("./AdaptiveCardHacks/useActionShouldBePushButtonModEffect"));
19
+ var _useActiveElementModEffect = _interopRequireDefault(require("./AdaptiveCardHacks/useActiveElementModEffect"));
20
20
  var _useDisabledModEffect3 = _interopRequireDefault(require("./AdaptiveCardHacks/useDisabledModEffect"));
21
21
  var _usePersistValuesModEffect = _interopRequireDefault(require("./AdaptiveCardHacks/usePersistValuesModEffect"));
22
22
  var _useRoleModEffect3 = _interopRequireDefault(require("./AdaptiveCardHacks/useRoleModEffect"));
23
- var _useStyleSet3 = _interopRequireDefault(require("../../hooks/useStyleSet"));
24
- var _useValueRef = _interopRequireDefault(require("./AdaptiveCardHacks/private/useValueRef"));
23
+ var _renderAdaptiveCard = _interopRequireDefault(require("./private/renderAdaptiveCard"));
25
24
  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); }
26
25
  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; }
27
26
  /* eslint no-magic-numbers: ["error", { "ignore": [-1, 0, 2] }] */
@@ -157,10 +156,6 @@ var AdaptiveCardRenderer = function AdaptiveCardRenderer(_ref) {
157
156
  _useActionShouldBePus2 = (0, _slicedToArray2.default)(_useActionShouldBePus, 2),
158
157
  applyActionShouldBePushButtonMod = _useActionShouldBePus2[0],
159
158
  undoActionShouldBePushButtonMod = _useActionShouldBePus2[1];
160
- var _useActionSetShouldNo = (0, _useActionSetShouldNotBeMenuBarModEffect.default)(adaptiveCard),
161
- _useActionSetShouldNo2 = (0, _slicedToArray2.default)(_useActionSetShouldNo, 2),
162
- applyActionSetShouldNotBeMenuBarMod = _useActionSetShouldNo2[0],
163
- undoActionSetShouldNotBeMenuBarMod = _useActionSetShouldNo2[1];
164
159
  var _useActiveElementModE = (0, _useActiveElementModEffect.default)(adaptiveCard),
165
160
  _useActiveElementModE2 = (0, _slicedToArray2.default)(_useActiveElementModE, 2),
166
161
  applyActiveElementMod = _useActiveElementModE2[0],
@@ -179,7 +174,6 @@ var AdaptiveCardRenderer = function AdaptiveCardRenderer(_ref) {
179
174
  undoRoleMod = _useRoleModEffect2[1];
180
175
  var _useMemo = (0, _react.useMemo)(function () {
181
176
  undoActionShouldBePushButtonMod();
182
- undoActionSetShouldNotBeMenuBarMod();
183
177
  undoActiveElementMod();
184
178
  undoDisabledMod();
185
179
  undoPersistValuesMod();
@@ -193,7 +187,7 @@ var AdaptiveCardRenderer = function AdaptiveCardRenderer(_ref) {
193
187
  renderMarkdownAsHTML: renderMarkdownAsHTML,
194
188
  setTabIndexAtCardRoot: setTabIndexAtCardRoot
195
189
  });
196
- }, [adaptiveCard, adaptiveCardsHostConfig, GlobalSettings, HostConfig, renderMarkdownAsHTML, setTabIndexAtCardRoot, undoActionShouldBePushButtonMod, undoActionSetShouldNotBeMenuBarMod, undoActiveElementMod, undoDisabledMod, undoPersistValuesMod, undoRoleMod]),
190
+ }, [adaptiveCard, adaptiveCardsHostConfig, GlobalSettings, HostConfig, renderMarkdownAsHTML, setTabIndexAtCardRoot, undoActionShouldBePushButtonMod, undoActiveElementMod, undoDisabledMod, undoPersistValuesMod, undoRoleMod]),
197
191
  element = _useMemo.element,
198
192
  errors = _useMemo.errors;
199
193
  (0, _react.useMemo)(function () {
@@ -212,13 +206,12 @@ var AdaptiveCardRenderer = function AdaptiveCardRenderer(_ref) {
212
206
  (0, _react.useLayoutEffect)(function () {
213
207
  if (element) {
214
208
  applyActionShouldBePushButtonMod(element, actionPerformedClassName);
215
- applyActionSetShouldNotBeMenuBarMod(element);
216
209
  applyActiveElementMod(element);
217
210
  applyDisabledMod(element, disabled);
218
211
  applyPersistValuesMod(element);
219
212
  applyRoleMod(element);
220
213
  }
221
- }, [actionPerformedClassName, applyActionShouldBePushButtonMod, applyActionSetShouldNotBeMenuBarMod, applyActiveElementMod, applyDisabledMod, applyPersistValuesMod, applyRoleMod, disabled, element]);
214
+ }, [actionPerformedClassName, applyActionShouldBePushButtonMod, applyActiveElementMod, applyDisabledMod, applyPersistValuesMod, applyRoleMod, disabled, element]);
222
215
  (errors === null || errors === void 0 ? void 0 : errors.length) && console.warn('botframework-webchat: Failed to render Adaptive Cards.', errors);
223
216
  return errors !== null && errors !== void 0 && errors.length ? node_env === 'development' && /*#__PURE__*/_react.default.createElement(ErrorBox, {
224
217
  error: errors[0],
@@ -250,4 +243,4 @@ AdaptiveCardRenderer.propTypes = {
250
243
  };
251
244
  var _default = AdaptiveCardRenderer;
252
245
  exports.default = _default;
253
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_botframeworkWebchatComponent","require","_classnames","_interopRequireDefault","_propTypes","_react","_interopRequireWildcard","_renderAdaptiveCard","_useActionSetShouldNotBeMenuBarModEffect","_useActionShouldBePushButtonModEffect","_useActiveElementModEffect","_useAdaptiveCardsHostConfig","_useAdaptiveCardsPackage","_useDisabledModEffect3","_usePersistValuesModEffect","_useRoleModEffect3","_useStyleSet3","_useValueRef","_getRequireWildcardCache","nodeInterop","WeakMap","cacheBabelInterop","cacheNodeInterop","obj","__esModule","_typeof","default","cache","has","get","newObj","hasPropertyDescriptor","Object","defineProperty","getOwnPropertyDescriptor","key","prototype","hasOwnProperty","call","desc","set","ErrorBox","Components","useDisabled","hooks","useLocalizer","usePerformCardAction","useRenderMarkdownAsHTML","useScrollToEnd","node_env","undefined","AdaptiveCardRenderer","_ref","actionPerformedClassName","adaptiveCard","disabledFromProps","disabled","tapAction","_useStyleSet","useStyleSet","_useStyleSet2","_slicedToArray2","adaptiveCardRendererStyleSet","adaptiveCardRenderer","_useAdaptiveCardsPack","useAdaptiveCardsPackage","_useAdaptiveCardsPack2","_useAdaptiveCardsPack3","GlobalSettings","HostConfig","_useAdaptiveCardsHost","useAdaptiveCardsHostConfig","_useAdaptiveCardsHost2","adaptiveCardsHostConfig","_useDisabled","_useDisabled2","disabledFromComposer","contentRef","useRef","localize","performCardAction","renderMarkdownAsHTML","scrollToEnd","tapActionRef","useValueRef","disabledRef","handleClickAndKeyPress","useCallback","event","_ref2","type","target","current","adaptiveCardRoot","querySelector","console","warn","preventDefault","tabIndex","getTabIndex","handleClickAndKeyPressForTapAction","handleExecuteAction","action","actionTypeName","getJsonTypeName","image","iconUrl","title","_ref3","value","url","_ref4","data","__isBotFrameworkCardAction","cardAction","error","setTabIndexAtCardRoot","_useActionShouldBePus","useActionShouldBePushButtonModEffect","_useActionShouldBePus2","applyActionShouldBePushButtonMod","undoActionShouldBePushButtonMod","_useActionSetShouldNo","useActionSetShouldNotBeMenuBarModEffect","_useActionSetShouldNo2","applyActionSetShouldNotBeMenuBarMod","undoActionSetShouldNotBeMenuBarMod","_useActiveElementModE","useActiveElementModEffect","_useActiveElementModE2","applyActiveElementMod","undoActiveElementMod","_useDisabledModEffect","useDisabledModEffect","_useDisabledModEffect2","applyDisabledMod","undoDisabledMod","_usePersistValuesModE","usePersistValuesModEffect","_usePersistValuesModE2","applyPersistValuesMod","undoPersistValuesMod","_useRoleModEffect","useRoleModEffect","_useRoleModEffect2","applyRoleMod","undoRoleMod","_useMemo","useMemo","renderAdaptiveCard","adaptiveCardsPackage","element","errors","onExecuteAction","useLayoutEffect","appendChild","removeChild","length","createElement","className","classNames","onClick","onKeyPress","ref","defaultProps","propTypes","PropTypes","string","any","isRequired","bool","shape","_default","exports"],"sourceRoot":"bundle:///","sources":["../../../src/adaptiveCards/Attachment/AdaptiveCardRenderer.tsx"],"sourcesContent":["/* eslint no-magic-numbers: [\"error\", { \"ignore\": [-1, 0, 2] }] */\n\nimport { Action as AdaptiveCardAction, AdaptiveCard, OpenUrlAction, SubmitAction } from 'adaptivecards';\nimport { Components, getTabIndex, hooks } from 'botframework-webchat-component';\nimport classNames from 'classnames';\nimport PropTypes from 'prop-types';\nimport React, {\n  KeyboardEventHandler,\n  MouseEventHandler,\n  useCallback,\n  useLayoutEffect,\n  useMemo,\n  useRef,\n  VFC\n} from 'react';\nimport type { DirectLineCardAction } from 'botframework-webchat-core';\n\nimport { BotFrameworkCardAction } from './AdaptiveCardBuilder';\nimport renderAdaptiveCard from './private/renderAdaptiveCard';\nimport useActionSetShouldNotBeMenuBarModEffect from './AdaptiveCardHacks/useActionSetShouldNotBeMenuBarModEffect';\nimport useActionShouldBePushButtonModEffect from './AdaptiveCardHacks/useActionShouldBePushButtonModEffect';\nimport useActiveElementModEffect from './AdaptiveCardHacks/useActiveElementModEffect';\nimport useAdaptiveCardsHostConfig from '../hooks/useAdaptiveCardsHostConfig';\nimport useAdaptiveCardsPackage from '../hooks/useAdaptiveCardsPackage';\nimport useDisabledModEffect from './AdaptiveCardHacks/useDisabledModEffect';\nimport usePersistValuesModEffect from './AdaptiveCardHacks/usePersistValuesModEffect';\nimport useRoleModEffect from './AdaptiveCardHacks/useRoleModEffect';\nimport useStyleSet from '../../hooks/useStyleSet';\nimport useValueRef from './AdaptiveCardHacks/private/useValueRef';\n\nconst { ErrorBox } = Components;\nconst { useDisabled, useLocalizer, usePerformCardAction, useRenderMarkdownAsHTML, useScrollToEnd } = hooks;\n\nconst node_env = process.env.node_env || process.env.NODE_ENV;\n\ntype AdaptiveCardRendererProps = {\n  actionPerformedClassName?: string;\n  adaptiveCard: AdaptiveCard;\n  disabled?: boolean;\n  tapAction?: DirectLineCardAction;\n};\n\nconst AdaptiveCardRenderer: VFC<AdaptiveCardRendererProps> = ({\n  actionPerformedClassName,\n  adaptiveCard,\n  disabled: disabledFromProps,\n  tapAction\n}) => {\n  const [{ adaptiveCardRenderer: adaptiveCardRendererStyleSet }] = useStyleSet();\n  const [{ GlobalSettings, HostConfig }] = useAdaptiveCardsPackage();\n  const [adaptiveCardsHostConfig] = useAdaptiveCardsHostConfig();\n  const [disabledFromComposer] = useDisabled();\n  const contentRef = useRef<HTMLDivElement>();\n  const localize = useLocalizer();\n  const performCardAction = usePerformCardAction();\n  const renderMarkdownAsHTML = useRenderMarkdownAsHTML();\n  const scrollToEnd = useScrollToEnd();\n\n  const disabled = disabledFromComposer || disabledFromProps;\n  const tapActionRef = useValueRef(tapAction);\n\n  const disabledRef = useValueRef(disabled);\n\n  // TODO: [P2] #3199 We should consider using `adaptiveCard.selectAction` instead.\n  // The null check for \"tapAction\" is in \"handleClickAndKeyPressForTapAction\".\n  const handleClickAndKeyPress = useCallback<KeyboardEventHandler<HTMLDivElement> | MouseEventHandler<HTMLDivElement>>(\n    (event): void => {\n      const { key, type } = event as KeyboardEvent;\n      const target = event.target as HTMLDivElement;\n\n      // Some items, e.g. tappable text, cannot be disabled thru DOM attributes\n      const { current } = contentRef;\n      const adaptiveCardRoot = current.querySelector('.ac-adaptiveCard[tabindex=\"0\"]');\n\n      if (!adaptiveCardRoot) {\n        return console.warn(\n          'botframework-webchat: No Adaptive Card root container can be found; the card is probably on an unsupported Adaptive Card version.'\n        );\n      }\n\n      // For \"keypress\" event, we only listen to ENTER and SPACEBAR key.\n      if (type === 'keypress') {\n        if (key !== 'Enter' && key !== ' ') {\n          return;\n        }\n\n        event.preventDefault();\n      }\n\n      // We will call performCardAction if either:\n      // 1. We are on the target, or\n      // 2. The event-dispatching element is not interactive\n      if (target !== adaptiveCardRoot) {\n        const tabIndex = getTabIndex(target);\n\n        // If the user is clicking on something that is already clickable, do not allow them to click the card.\n        // E.g. a hero card can be tappable, and image and buttons inside the hero card can also be tappable.\n        if (typeof tabIndex === 'number' && tabIndex >= 0) {\n          return;\n        }\n      }\n\n      performCardAction(tapActionRef.current);\n      scrollToEnd();\n    },\n    [contentRef, performCardAction, scrollToEnd, tapActionRef]\n  );\n\n  // Only listen to event if it is not disabled and have \"tapAction\" prop.\n  const handleClickAndKeyPressForTapAction = !disabled && tapAction ? handleClickAndKeyPress : undefined;\n\n  const handleExecuteAction = useCallback(\n    (action: AdaptiveCardAction): void => {\n      // Some items, e.g. tappable image, cannot be disabled thru DOM attributes\n      if (disabledRef.current) {\n        return;\n      }\n\n      const actionTypeName = action.getJsonTypeName();\n      const { iconUrl: image, title } = action;\n\n      // We cannot use \"instanceof\" check here, because web devs may bring their own version of Adaptive Cards package.\n      // We need to check using \"getJsonTypeName()\" instead.\n      if (actionTypeName === 'Action.OpenUrl') {\n        const { url: value } = action as OpenUrlAction;\n\n        performCardAction({\n          image,\n          title,\n          type: 'openUrl',\n          value\n        });\n      } else if (actionTypeName === 'Action.Submit') {\n        const { data } = action as SubmitAction as {\n          data: string | BotFrameworkCardAction;\n        };\n\n        if (typeof data !== 'undefined') {\n          if (typeof data === 'string') {\n            performCardAction({\n              image,\n              title,\n              type: 'imBack',\n              value: data\n            });\n          } else if (data.__isBotFrameworkCardAction) {\n            performCardAction(data.cardAction);\n          } else {\n            performCardAction({\n              image,\n              title,\n              type: 'postBack',\n              value: data\n            });\n          }\n        }\n\n        scrollToEnd();\n      } else {\n        console.error(`Web Chat: received unknown action from Adaptive Cards`);\n        console.error(action);\n      }\n    },\n    [disabledRef, performCardAction, scrollToEnd]\n  );\n\n  // For accessibility issue #1340, `tabindex=\"0\"` must not be set for the root container if it is not interactive.\n  const setTabIndexAtCardRoot = !!tapAction;\n\n  const [applyActionShouldBePushButtonMod, undoActionShouldBePushButtonMod] =\n    useActionShouldBePushButtonModEffect(adaptiveCard);\n  const [applyActionSetShouldNotBeMenuBarMod, undoActionSetShouldNotBeMenuBarMod] =\n    useActionSetShouldNotBeMenuBarModEffect(adaptiveCard);\n  const [applyActiveElementMod, undoActiveElementMod] = useActiveElementModEffect(adaptiveCard);\n  const [applyDisabledMod, undoDisabledMod] = useDisabledModEffect(adaptiveCard);\n  const [applyPersistValuesMod, undoPersistValuesMod] = usePersistValuesModEffect(adaptiveCard);\n  const [applyRoleMod, undoRoleMod] = useRoleModEffect(adaptiveCard);\n\n  const { element, errors }: { element?: HTMLElement; errors?: Error[] } = useMemo(() => {\n    undoActionShouldBePushButtonMod();\n    undoActionSetShouldNotBeMenuBarMod();\n    undoActiveElementMod();\n    undoDisabledMod();\n    undoPersistValuesMod();\n    undoRoleMod();\n\n    return renderAdaptiveCard(adaptiveCard, {\n      adaptiveCardsHostConfig,\n      adaptiveCardsPackage: { GlobalSettings, HostConfig },\n      renderMarkdownAsHTML,\n      setTabIndexAtCardRoot\n    });\n  }, [\n    adaptiveCard,\n    adaptiveCardsHostConfig,\n    GlobalSettings,\n    HostConfig,\n    renderMarkdownAsHTML,\n    setTabIndexAtCardRoot,\n    undoActionShouldBePushButtonMod,\n    undoActionSetShouldNotBeMenuBarMod,\n    undoActiveElementMod,\n    undoDisabledMod,\n    undoPersistValuesMod,\n    undoRoleMod\n  ]);\n\n  useMemo(() => {\n    adaptiveCard.onExecuteAction = handleExecuteAction;\n  }, [adaptiveCard, handleExecuteAction]);\n\n  useLayoutEffect(() => {\n    const { current } = contentRef;\n\n    current?.appendChild(element);\n\n    return () => {\n      current?.removeChild(element);\n    };\n  }, [contentRef, element]);\n\n  // Apply all mods regardless whether the element changed or not.\n  // This is because we have undoed mods when we call the `useXXXModEffect` hook.\n  useLayoutEffect(() => {\n    if (element) {\n      applyActionShouldBePushButtonMod(element, actionPerformedClassName);\n      applyActionSetShouldNotBeMenuBarMod(element);\n      applyActiveElementMod(element);\n      applyDisabledMod(element, disabled);\n      applyPersistValuesMod(element);\n      applyRoleMod(element);\n    }\n  }, [\n    actionPerformedClassName,\n    applyActionShouldBePushButtonMod,\n    applyActionSetShouldNotBeMenuBarMod,\n    applyActiveElementMod,\n    applyDisabledMod,\n    applyPersistValuesMod,\n    applyRoleMod,\n    disabled,\n    element\n  ]);\n\n  errors?.length && console.warn('botframework-webchat: Failed to render Adaptive Cards.', errors);\n\n  return errors?.length ? (\n    node_env === 'development' && <ErrorBox error={errors[0]} type={localize('ADAPTIVE_CARD_ERROR_BOX_TITLE_RENDER')} />\n  ) : (\n    <div\n      className={classNames(adaptiveCardRendererStyleSet + '', 'webchat__adaptive-card-renderer')}\n      onClick={handleClickAndKeyPressForTapAction as MouseEventHandler<HTMLDivElement>}\n      onKeyPress={handleClickAndKeyPressForTapAction as KeyboardEventHandler<HTMLDivElement>}\n      ref={contentRef}\n    />\n  );\n};\n\nAdaptiveCardRenderer.defaultProps = {\n  actionPerformedClassName: '',\n  disabled: undefined,\n  tapAction: undefined\n};\n\nAdaptiveCardRenderer.propTypes = {\n  actionPerformedClassName: PropTypes.string,\n  adaptiveCard: PropTypes.any.isRequired,\n  disabled: PropTypes.bool,\n\n  // TypeScript class is not mappable to PropTypes.func\n  // @ts-ignore\n  tapAction: PropTypes.shape({\n    image: PropTypes.string,\n    title: PropTypes.string,\n    type: PropTypes.string.isRequired,\n    value: PropTypes.string\n  })\n};\n\nexport default AdaptiveCardRenderer;\n"],"mappings":"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"}
246
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_botframeworkWebchatComponent","require","_classnames","_interopRequireDefault","_propTypes","_react","_interopRequireWildcard","_useStyleSet3","_useAdaptiveCardsHostConfig","_useAdaptiveCardsPackage","_useValueRef","_useActionShouldBePushButtonModEffect","_useActiveElementModEffect","_useDisabledModEffect3","_usePersistValuesModEffect","_useRoleModEffect3","_renderAdaptiveCard","_getRequireWildcardCache","nodeInterop","WeakMap","cacheBabelInterop","cacheNodeInterop","obj","__esModule","_typeof","default","cache","has","get","newObj","hasPropertyDescriptor","Object","defineProperty","getOwnPropertyDescriptor","key","prototype","hasOwnProperty","call","desc","set","ErrorBox","Components","useDisabled","hooks","useLocalizer","usePerformCardAction","useRenderMarkdownAsHTML","useScrollToEnd","node_env","undefined","AdaptiveCardRenderer","_ref","actionPerformedClassName","adaptiveCard","disabledFromProps","disabled","tapAction","_useStyleSet","useStyleSet","_useStyleSet2","_slicedToArray2","adaptiveCardRendererStyleSet","adaptiveCardRenderer","_useAdaptiveCardsPack","useAdaptiveCardsPackage","_useAdaptiveCardsPack2","_useAdaptiveCardsPack3","GlobalSettings","HostConfig","_useAdaptiveCardsHost","useAdaptiveCardsHostConfig","_useAdaptiveCardsHost2","adaptiveCardsHostConfig","_useDisabled","_useDisabled2","disabledFromComposer","contentRef","useRef","localize","performCardAction","renderMarkdownAsHTML","scrollToEnd","tapActionRef","useValueRef","disabledRef","handleClickAndKeyPress","useCallback","event","_ref2","type","target","current","adaptiveCardRoot","querySelector","console","warn","preventDefault","tabIndex","getTabIndex","handleClickAndKeyPressForTapAction","handleExecuteAction","action","actionTypeName","getJsonTypeName","image","iconUrl","title","_ref3","value","url","_ref4","data","__isBotFrameworkCardAction","cardAction","error","setTabIndexAtCardRoot","_useActionShouldBePus","useActionShouldBePushButtonModEffect","_useActionShouldBePus2","applyActionShouldBePushButtonMod","undoActionShouldBePushButtonMod","_useActiveElementModE","useActiveElementModEffect","_useActiveElementModE2","applyActiveElementMod","undoActiveElementMod","_useDisabledModEffect","useDisabledModEffect","_useDisabledModEffect2","applyDisabledMod","undoDisabledMod","_usePersistValuesModE","usePersistValuesModEffect","_usePersistValuesModE2","applyPersistValuesMod","undoPersistValuesMod","_useRoleModEffect","useRoleModEffect","_useRoleModEffect2","applyRoleMod","undoRoleMod","_useMemo","useMemo","renderAdaptiveCard","adaptiveCardsPackage","element","errors","onExecuteAction","useLayoutEffect","appendChild","removeChild","length","createElement","className","classNames","onClick","onKeyPress","ref","defaultProps","propTypes","PropTypes","string","any","isRequired","bool","shape","_default","exports"],"sourceRoot":"bundle:///","sources":["../../../src/adaptiveCards/Attachment/AdaptiveCardRenderer.tsx"],"sourcesContent":["/* eslint no-magic-numbers: [\"error\", { \"ignore\": [-1, 0, 2] }] */\n\nimport { AdaptiveCard, Action as AdaptiveCardAction, OpenUrlAction, SubmitAction } from 'adaptivecards';\nimport { Components, getTabIndex, hooks } from 'botframework-webchat-component';\nimport type { DirectLineCardAction } from 'botframework-webchat-core';\nimport classNames from 'classnames';\nimport PropTypes from 'prop-types';\nimport React, {\n  KeyboardEventHandler,\n  MouseEventHandler,\n  VFC,\n  useCallback,\n  useLayoutEffect,\n  useMemo,\n  useRef\n} from 'react';\n\nimport useStyleSet from '../../hooks/useStyleSet';\nimport useAdaptiveCardsHostConfig from '../hooks/useAdaptiveCardsHostConfig';\nimport useAdaptiveCardsPackage from '../hooks/useAdaptiveCardsPackage';\nimport { BotFrameworkCardAction } from './AdaptiveCardBuilder';\nimport useValueRef from './AdaptiveCardHacks/private/useValueRef';\nimport useActionShouldBePushButtonModEffect from './AdaptiveCardHacks/useActionShouldBePushButtonModEffect';\nimport useActiveElementModEffect from './AdaptiveCardHacks/useActiveElementModEffect';\nimport useDisabledModEffect from './AdaptiveCardHacks/useDisabledModEffect';\nimport usePersistValuesModEffect from './AdaptiveCardHacks/usePersistValuesModEffect';\nimport useRoleModEffect from './AdaptiveCardHacks/useRoleModEffect';\nimport renderAdaptiveCard from './private/renderAdaptiveCard';\n\nconst { ErrorBox } = Components;\nconst { useDisabled, useLocalizer, usePerformCardAction, useRenderMarkdownAsHTML, useScrollToEnd } = hooks;\n\nconst node_env = process.env.node_env || process.env.NODE_ENV;\n\ntype AdaptiveCardRendererProps = {\n  actionPerformedClassName?: string;\n  adaptiveCard: AdaptiveCard;\n  disabled?: boolean;\n  tapAction?: DirectLineCardAction;\n};\n\nconst AdaptiveCardRenderer: VFC<AdaptiveCardRendererProps> = ({\n  actionPerformedClassName,\n  adaptiveCard,\n  disabled: disabledFromProps,\n  tapAction\n}) => {\n  const [{ adaptiveCardRenderer: adaptiveCardRendererStyleSet }] = useStyleSet();\n  const [{ GlobalSettings, HostConfig }] = useAdaptiveCardsPackage();\n  const [adaptiveCardsHostConfig] = useAdaptiveCardsHostConfig();\n  const [disabledFromComposer] = useDisabled();\n  const contentRef = useRef<HTMLDivElement>();\n  const localize = useLocalizer();\n  const performCardAction = usePerformCardAction();\n  const renderMarkdownAsHTML = useRenderMarkdownAsHTML();\n  const scrollToEnd = useScrollToEnd();\n\n  const disabled = disabledFromComposer || disabledFromProps;\n  const tapActionRef = useValueRef(tapAction);\n\n  const disabledRef = useValueRef(disabled);\n\n  // TODO: [P2] #3199 We should consider using `adaptiveCard.selectAction` instead.\n  // The null check for \"tapAction\" is in \"handleClickAndKeyPressForTapAction\".\n  const handleClickAndKeyPress = useCallback<KeyboardEventHandler<HTMLDivElement> | MouseEventHandler<HTMLDivElement>>(\n    (event): void => {\n      const { key, type } = event as KeyboardEvent;\n      const target = event.target as HTMLDivElement;\n\n      // Some items, e.g. tappable text, cannot be disabled thru DOM attributes\n      const { current } = contentRef;\n      const adaptiveCardRoot = current.querySelector('.ac-adaptiveCard[tabindex=\"0\"]');\n\n      if (!adaptiveCardRoot) {\n        return console.warn(\n          'botframework-webchat: No Adaptive Card root container can be found; the card is probably on an unsupported Adaptive Card version.'\n        );\n      }\n\n      // For \"keypress\" event, we only listen to ENTER and SPACEBAR key.\n      if (type === 'keypress') {\n        if (key !== 'Enter' && key !== ' ') {\n          return;\n        }\n\n        event.preventDefault();\n      }\n\n      // We will call performCardAction if either:\n      // 1. We are on the target, or\n      // 2. The event-dispatching element is not interactive\n      if (target !== adaptiveCardRoot) {\n        const tabIndex = getTabIndex(target);\n\n        // If the user is clicking on something that is already clickable, do not allow them to click the card.\n        // E.g. a hero card can be tappable, and image and buttons inside the hero card can also be tappable.\n        if (typeof tabIndex === 'number' && tabIndex >= 0) {\n          return;\n        }\n      }\n\n      performCardAction(tapActionRef.current);\n      scrollToEnd();\n    },\n    [contentRef, performCardAction, scrollToEnd, tapActionRef]\n  );\n\n  // Only listen to event if it is not disabled and have \"tapAction\" prop.\n  const handleClickAndKeyPressForTapAction = !disabled && tapAction ? handleClickAndKeyPress : undefined;\n\n  const handleExecuteAction = useCallback(\n    (action: AdaptiveCardAction): void => {\n      // Some items, e.g. tappable image, cannot be disabled thru DOM attributes\n      if (disabledRef.current) {\n        return;\n      }\n\n      const actionTypeName = action.getJsonTypeName();\n      const { iconUrl: image, title } = action;\n\n      // We cannot use \"instanceof\" check here, because web devs may bring their own version of Adaptive Cards package.\n      // We need to check using \"getJsonTypeName()\" instead.\n      if (actionTypeName === 'Action.OpenUrl') {\n        const { url: value } = action as OpenUrlAction;\n\n        performCardAction({\n          image,\n          title,\n          type: 'openUrl',\n          value\n        });\n      } else if (actionTypeName === 'Action.Submit') {\n        const { data } = action as SubmitAction as {\n          data: string | BotFrameworkCardAction;\n        };\n\n        if (typeof data !== 'undefined') {\n          if (typeof data === 'string') {\n            performCardAction({\n              image,\n              title,\n              type: 'imBack',\n              value: data\n            });\n          } else if (data.__isBotFrameworkCardAction) {\n            performCardAction(data.cardAction);\n          } else {\n            performCardAction({\n              image,\n              title,\n              type: 'postBack',\n              value: data\n            });\n          }\n        }\n\n        scrollToEnd();\n      } else {\n        console.error(`Web Chat: received unknown action from Adaptive Cards`);\n        console.error(action);\n      }\n    },\n    [disabledRef, performCardAction, scrollToEnd]\n  );\n\n  // For accessibility issue #1340, `tabindex=\"0\"` must not be set for the root container if it is not interactive.\n  const setTabIndexAtCardRoot = !!tapAction;\n\n  const [applyActionShouldBePushButtonMod, undoActionShouldBePushButtonMod] =\n    useActionShouldBePushButtonModEffect(adaptiveCard);\n  const [applyActiveElementMod, undoActiveElementMod] = useActiveElementModEffect(adaptiveCard);\n  const [applyDisabledMod, undoDisabledMod] = useDisabledModEffect(adaptiveCard);\n  const [applyPersistValuesMod, undoPersistValuesMod] = usePersistValuesModEffect(adaptiveCard);\n  const [applyRoleMod, undoRoleMod] = useRoleModEffect(adaptiveCard);\n\n  const { element, errors }: { element?: HTMLElement; errors?: Error[] } = useMemo(() => {\n    undoActionShouldBePushButtonMod();\n    undoActiveElementMod();\n    undoDisabledMod();\n    undoPersistValuesMod();\n    undoRoleMod();\n\n    return renderAdaptiveCard(adaptiveCard, {\n      adaptiveCardsHostConfig,\n      adaptiveCardsPackage: { GlobalSettings, HostConfig },\n      renderMarkdownAsHTML,\n      setTabIndexAtCardRoot\n    });\n  }, [\n    adaptiveCard,\n    adaptiveCardsHostConfig,\n    GlobalSettings,\n    HostConfig,\n    renderMarkdownAsHTML,\n    setTabIndexAtCardRoot,\n    undoActionShouldBePushButtonMod,\n    undoActiveElementMod,\n    undoDisabledMod,\n    undoPersistValuesMod,\n    undoRoleMod\n  ]);\n\n  useMemo(() => {\n    adaptiveCard.onExecuteAction = handleExecuteAction;\n  }, [adaptiveCard, handleExecuteAction]);\n\n  useLayoutEffect(() => {\n    const { current } = contentRef;\n\n    current?.appendChild(element);\n\n    return () => {\n      current?.removeChild(element);\n    };\n  }, [contentRef, element]);\n\n  // Apply all mods regardless whether the element changed or not.\n  // This is because we have undoed mods when we call the `useXXXModEffect` hook.\n  useLayoutEffect(() => {\n    if (element) {\n      applyActionShouldBePushButtonMod(element, actionPerformedClassName);\n      applyActiveElementMod(element);\n      applyDisabledMod(element, disabled);\n      applyPersistValuesMod(element);\n      applyRoleMod(element);\n    }\n  }, [\n    actionPerformedClassName,\n    applyActionShouldBePushButtonMod,\n    applyActiveElementMod,\n    applyDisabledMod,\n    applyPersistValuesMod,\n    applyRoleMod,\n    disabled,\n    element\n  ]);\n\n  errors?.length && console.warn('botframework-webchat: Failed to render Adaptive Cards.', errors);\n\n  return errors?.length ? (\n    node_env === 'development' && <ErrorBox error={errors[0]} type={localize('ADAPTIVE_CARD_ERROR_BOX_TITLE_RENDER')} />\n  ) : (\n    <div\n      className={classNames(adaptiveCardRendererStyleSet + '', 'webchat__adaptive-card-renderer')}\n      onClick={handleClickAndKeyPressForTapAction as MouseEventHandler<HTMLDivElement>}\n      onKeyPress={handleClickAndKeyPressForTapAction as KeyboardEventHandler<HTMLDivElement>}\n      ref={contentRef}\n    />\n  );\n};\n\nAdaptiveCardRenderer.defaultProps = {\n  actionPerformedClassName: '',\n  disabled: undefined,\n  tapAction: undefined\n};\n\nAdaptiveCardRenderer.propTypes = {\n  actionPerformedClassName: PropTypes.string,\n  adaptiveCard: PropTypes.any.isRequired,\n  disabled: PropTypes.bool,\n\n  // TypeScript class is not mappable to PropTypes.func\n  // @ts-ignore\n  tapAction: PropTypes.shape({\n    image: PropTypes.string,\n    title: PropTypes.string,\n    type: PropTypes.string.isRequired,\n    value: PropTypes.string\n  })\n};\n\nexport default AdaptiveCardRenderer;\n"],"mappings":"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"}
package/lib/addVersion.js CHANGED
@@ -23,7 +23,7 @@ function setMetaTag(name, content) {
23
23
  }
24
24
  function addVersion(variant) {
25
25
  setMetaTag('botframework-webchat:bundle:variant', variant);
26
- setMetaTag('botframework-webchat:bundle:version', "4.16.1-main.20240328.82ad15e");
26
+ setMetaTag('botframework-webchat:bundle:version', "4.16.1-main.20240401.512cc60");
27
27
  setMetaTag('botframework-webchat:core:version', _botframeworkWebchatCore.version);
28
28
  setMetaTag('botframework-webchat:ui:version', _botframeworkWebchatComponent.version);
29
29
  }
@@ -548,7 +548,7 @@ export default function createFullStyleSet(options: FullBundleStyleOptions): {
548
548
  readonly sendBoxBorderTop: string | number;
549
549
  readonly sendBoxPlaceholderColor: string;
550
550
  readonly sendBoxTextWrap: boolean;
551
- readonly sendBoxButtonAlignment: "stretch" | "bottom" | "top";
551
+ readonly sendBoxButtonAlignment: "bottom" | "top" | "stretch";
552
552
  readonly showSpokenText: boolean;
553
553
  readonly spinnerAnimationBackgroundImage: string;
554
554
  readonly spinnerAnimationHeight: string | number;
@@ -602,7 +602,7 @@ export default function createFullStyleSet(options: FullBundleStyleOptions): {
602
602
  readonly suggestedActionsCarouselFlipperSize: number;
603
603
  readonly suggestedActionsFlowMaxHeight: undefined;
604
604
  readonly suggestedActionsStackedHeight: number | "auto";
605
- readonly suggestedActionsStackedOverflow: "auto" | "scroll" | "hidden" | "visible";
605
+ readonly suggestedActionsStackedOverflow: "auto" | "hidden" | "scroll" | "visible";
606
606
  readonly suggestedActionsStackedLayoutButtonMaxHeight: string | number;
607
607
  readonly suggestedActionsStackedLayoutButtonTextWrap: boolean;
608
608
  readonly suggestedActionsVisualKeyboardIndicatorColor: string;
@@ -1108,7 +1108,7 @@ export default function createFullStyleSet(options: FullBundleStyleOptions): {
1108
1108
  '&.webchat__suggested-actions--stacked-layout': {
1109
1109
  '& .webchat__suggested-actions__stack': {
1110
1110
  maxHeight: number | "auto";
1111
- overflowY: "auto" | "scroll" | "hidden" | "visible";
1111
+ overflowY: "auto" | "hidden" | "scroll" | "visible";
1112
1112
  paddingBottom: number;
1113
1113
  paddingLeft: number;
1114
1114
  paddingRight: number;
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "botframework-webchat",
3
- "version": "4.16.1-main.20240328.82ad15e",
3
+ "version": "4.16.1-main.20240401.512cc60",
4
4
  "description": "A highly-customizable web-based chat client for Azure Bot Services.",
5
5
  "main": "lib/index.js",
6
6
  "types": "lib/index.d.ts",
@@ -87,13 +87,17 @@
87
87
  "@babel/*@7.21 is causing out-of-memory (OOM) issues"
88
88
  ],
89
89
  "adaptivecards": [
90
- "2.11.1",
90
+ "3.0.2",
91
91
  "needs to bump manually"
92
92
  ],
93
93
  "microsoft-cognitiveservices-speech-sdk": [
94
94
  "1.17.0",
95
95
  "needs to bump manually"
96
96
  ],
97
+ "swiper": [
98
+ "^8.2.6",
99
+ "required by Adaptive Cards but they forget to include in adaptivecards@3.0.2"
100
+ ],
97
101
  "uuid": [
98
102
  "8",
99
103
  "uuid@9 emit non-ES5 build because of default parameters"
@@ -101,12 +105,12 @@
101
105
  },
102
106
  "dependencies": {
103
107
  "@babel/runtime": "7.19.0",
104
- "adaptivecards": "2.11.1",
108
+ "adaptivecards": "3.0.2",
105
109
  "botframework-directlinejs": "0.15.5",
106
- "botframework-directlinespeech-sdk": "4.16.1-main.20240328.82ad15e",
107
- "botframework-webchat-api": "4.16.1-main.20240328.82ad15e",
108
- "botframework-webchat-component": "4.16.1-main.20240328.82ad15e",
109
- "botframework-webchat-core": "4.16.1-main.20240328.82ad15e",
110
+ "botframework-directlinespeech-sdk": "4.16.1-main.20240401.512cc60",
111
+ "botframework-webchat-api": "4.16.1-main.20240401.512cc60",
112
+ "botframework-webchat-component": "4.16.1-main.20240401.512cc60",
113
+ "botframework-webchat-core": "4.16.1-main.20240401.512cc60",
110
114
  "classnames": "2.3.2",
111
115
  "core-js": "3.34.0",
112
116
  "markdown-it": "13.0.2",
@@ -119,6 +123,7 @@
119
123
  "microsoft-cognitiveservices-speech-sdk": "1.17.0",
120
124
  "prop-types": "15.8.1",
121
125
  "sanitize-html": "2.11.0",
126
+ "swiper": "^8.2.6",
122
127
  "url-search-params-polyfill": "8.2.5",
123
128
  "uuid": "8.3.2",
124
129
  "web-speech-cognitive-services": "7.1.3",
@@ -139,8 +144,8 @@
139
144
  "babel-plugin-transform-inline-environment-variables": "^0.4.4",
140
145
  "concurrently": "^8.2.2",
141
146
  "esbuild": "^0.19.8",
142
- "isomorphic-react": "4.16.1-main.20240328.82ad15e",
143
- "isomorphic-react-dom": "4.16.1-main.20240328.82ad15e",
147
+ "isomorphic-react": "4.16.1-main.20240401.512cc60",
148
+ "isomorphic-react-dom": "4.16.1-main.20240401.512cc60",
144
149
  "source-map-loader": "^4.0.1",
145
150
  "terser-webpack-plugin": "^5.3.9",
146
151
  "tsd": "^0.30.3",
@@ -1,32 +1,31 @@
1
1
  /* eslint no-magic-numbers: ["error", { "ignore": [-1, 0, 2] }] */
2
2
 
3
- import { Action as AdaptiveCardAction, AdaptiveCard, OpenUrlAction, SubmitAction } from 'adaptivecards';
3
+ import { AdaptiveCard, Action as AdaptiveCardAction, OpenUrlAction, SubmitAction } from 'adaptivecards';
4
4
  import { Components, getTabIndex, hooks } from 'botframework-webchat-component';
5
+ import type { DirectLineCardAction } from 'botframework-webchat-core';
5
6
  import classNames from 'classnames';
6
7
  import PropTypes from 'prop-types';
7
8
  import React, {
8
9
  KeyboardEventHandler,
9
10
  MouseEventHandler,
11
+ VFC,
10
12
  useCallback,
11
13
  useLayoutEffect,
12
14
  useMemo,
13
- useRef,
14
- VFC
15
+ useRef
15
16
  } from 'react';
16
- import type { DirectLineCardAction } from 'botframework-webchat-core';
17
17
 
18
+ import useStyleSet from '../../hooks/useStyleSet';
19
+ import useAdaptiveCardsHostConfig from '../hooks/useAdaptiveCardsHostConfig';
20
+ import useAdaptiveCardsPackage from '../hooks/useAdaptiveCardsPackage';
18
21
  import { BotFrameworkCardAction } from './AdaptiveCardBuilder';
19
- import renderAdaptiveCard from './private/renderAdaptiveCard';
20
- import useActionSetShouldNotBeMenuBarModEffect from './AdaptiveCardHacks/useActionSetShouldNotBeMenuBarModEffect';
22
+ import useValueRef from './AdaptiveCardHacks/private/useValueRef';
21
23
  import useActionShouldBePushButtonModEffect from './AdaptiveCardHacks/useActionShouldBePushButtonModEffect';
22
24
  import useActiveElementModEffect from './AdaptiveCardHacks/useActiveElementModEffect';
23
- import useAdaptiveCardsHostConfig from '../hooks/useAdaptiveCardsHostConfig';
24
- import useAdaptiveCardsPackage from '../hooks/useAdaptiveCardsPackage';
25
25
  import useDisabledModEffect from './AdaptiveCardHacks/useDisabledModEffect';
26
26
  import usePersistValuesModEffect from './AdaptiveCardHacks/usePersistValuesModEffect';
27
27
  import useRoleModEffect from './AdaptiveCardHacks/useRoleModEffect';
28
- import useStyleSet from '../../hooks/useStyleSet';
29
- import useValueRef from './AdaptiveCardHacks/private/useValueRef';
28
+ import renderAdaptiveCard from './private/renderAdaptiveCard';
30
29
 
31
30
  const { ErrorBox } = Components;
32
31
  const { useDisabled, useLocalizer, usePerformCardAction, useRenderMarkdownAsHTML, useScrollToEnd } = hooks;
@@ -169,8 +168,6 @@ const AdaptiveCardRenderer: VFC<AdaptiveCardRendererProps> = ({
169
168
 
170
169
  const [applyActionShouldBePushButtonMod, undoActionShouldBePushButtonMod] =
171
170
  useActionShouldBePushButtonModEffect(adaptiveCard);
172
- const [applyActionSetShouldNotBeMenuBarMod, undoActionSetShouldNotBeMenuBarMod] =
173
- useActionSetShouldNotBeMenuBarModEffect(adaptiveCard);
174
171
  const [applyActiveElementMod, undoActiveElementMod] = useActiveElementModEffect(adaptiveCard);
175
172
  const [applyDisabledMod, undoDisabledMod] = useDisabledModEffect(adaptiveCard);
176
173
  const [applyPersistValuesMod, undoPersistValuesMod] = usePersistValuesModEffect(adaptiveCard);
@@ -178,7 +175,6 @@ const AdaptiveCardRenderer: VFC<AdaptiveCardRendererProps> = ({
178
175
 
179
176
  const { element, errors }: { element?: HTMLElement; errors?: Error[] } = useMemo(() => {
180
177
  undoActionShouldBePushButtonMod();
181
- undoActionSetShouldNotBeMenuBarMod();
182
178
  undoActiveElementMod();
183
179
  undoDisabledMod();
184
180
  undoPersistValuesMod();
@@ -198,7 +194,6 @@ const AdaptiveCardRenderer: VFC<AdaptiveCardRendererProps> = ({
198
194
  renderMarkdownAsHTML,
199
195
  setTabIndexAtCardRoot,
200
196
  undoActionShouldBePushButtonMod,
201
- undoActionSetShouldNotBeMenuBarMod,
202
197
  undoActiveElementMod,
203
198
  undoDisabledMod,
204
199
  undoPersistValuesMod,
@@ -224,7 +219,6 @@ const AdaptiveCardRenderer: VFC<AdaptiveCardRendererProps> = ({
224
219
  useLayoutEffect(() => {
225
220
  if (element) {
226
221
  applyActionShouldBePushButtonMod(element, actionPerformedClassName);
227
- applyActionSetShouldNotBeMenuBarMod(element);
228
222
  applyActiveElementMod(element);
229
223
  applyDisabledMod(element, disabled);
230
224
  applyPersistValuesMod(element);
@@ -233,7 +227,6 @@ const AdaptiveCardRenderer: VFC<AdaptiveCardRendererProps> = ({
233
227
  }, [
234
228
  actionPerformedClassName,
235
229
  applyActionShouldBePushButtonMod,
236
- applyActionSetShouldNotBeMenuBarMod,
237
230
  applyActiveElementMod,
238
231
  applyDisabledMod,
239
232
  applyPersistValuesMod,
@@ -1,16 +0,0 @@
1
- import type { AdaptiveCard } from 'adaptivecards';
2
- /**
3
- * Accessibility: ActionSet should not be menu bar.
4
- *
5
- * Menu bar is not accessible through screen reader keyboard shortcut keys:
6
- *
7
- * - <kbd>B</kbd> will jump to next button, which the end-user can quickly the chosen action;
8
- * - <kbd>F</kbd> will jump to next form field, which is very similar but also jump to text fields;
9
- * - There are no keyboard shortcut keys for menu.
10
- *
11
- * Marking action button as menu item in a menu bar hurts accessibility. End-user will not be able to jump to buttons quickly.
12
- *
13
- * Thus, ActionSet should not be menu bar.
14
- */
15
- export default function useActionShouldBePushButtonModEffect(adaptiveCard: AdaptiveCard): readonly [(cardElement: HTMLElement) => void, () => void];
16
- //# sourceMappingURL=useActionSetShouldNotBeMenuBarModEffect.d.ts.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"useActionSetShouldNotBeMenuBarModEffect.d.ts","sourceRoot":"","sources":["../../../../src/adaptiveCards/Attachment/AdaptiveCardHacks/useActionSetShouldNotBeMenuBarModEffect.ts"],"names":[],"mappings":"AAMA,OAAO,KAAK,EAAE,YAAY,EAAE,MAAM,eAAe,CAAC;AAElD;;;;;;;;;;;;GAYG;AACH,MAAM,CAAC,OAAO,UAAU,oCAAoC,CAAC,YAAY,EAAE,YAAY,6DAiBtF"}
@@ -1,39 +0,0 @@
1
- "use strict";
2
-
3
- var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
4
- Object.defineProperty(exports, "__esModule", {
5
- value: true
6
- });
7
- exports.default = useActionShouldBePushButtonModEffect;
8
- var _react = require("react");
9
- var _bunchUndos = _interopRequireDefault(require("../../DOMManipulationWithUndo/bunchUndos"));
10
- var _setOrRemoveAttributeIfFalseWithUndo = _interopRequireDefault(require("../../DOMManipulationWithUndo/setOrRemoveAttributeIfFalseWithUndo"));
11
- var _useAdaptiveCardModEffect = _interopRequireDefault(require("./private/useAdaptiveCardModEffect"));
12
- /**
13
- * Accessibility: ActionSet should not be menu bar.
14
- *
15
- * Menu bar is not accessible through screen reader keyboard shortcut keys:
16
- *
17
- * - <kbd>B</kbd> will jump to next button, which the end-user can quickly the chosen action;
18
- * - <kbd>F</kbd> will jump to next form field, which is very similar but also jump to text fields;
19
- * - There are no keyboard shortcut keys for menu.
20
- *
21
- * Marking action button as menu item in a menu bar hurts accessibility. End-user will not be able to jump to buttons quickly.
22
- *
23
- * Thus, ActionSet should not be menu bar.
24
- */
25
- function useActionShouldBePushButtonModEffect(adaptiveCard) {
26
- var modder = (0, _react.useMemo)(function () {
27
- return function (_, cardElement) {
28
- var actionSetElements = Array.from(cardElement.querySelectorAll('.ac-actionSet[role="menubar"]'));
29
- var undoStack = actionSetElements.map(function (actionSetElement) {
30
- return (0, _setOrRemoveAttributeIfFalseWithUndo.default)(actionSetElement, 'role', false);
31
- });
32
- return function () {
33
- return (0, _bunchUndos.default)(undoStack)();
34
- };
35
- };
36
- }, []);
37
- return (0, _useAdaptiveCardModEffect.default)(modder, adaptiveCard);
38
- }
39
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJfcmVhY3QiLCJyZXF1aXJlIiwiX2J1bmNoVW5kb3MiLCJfaW50ZXJvcFJlcXVpcmVEZWZhdWx0IiwiX3NldE9yUmVtb3ZlQXR0cmlidXRlSWZGYWxzZVdpdGhVbmRvIiwiX3VzZUFkYXB0aXZlQ2FyZE1vZEVmZmVjdCIsInVzZUFjdGlvblNob3VsZEJlUHVzaEJ1dHRvbk1vZEVmZmVjdCIsImFkYXB0aXZlQ2FyZCIsIm1vZGRlciIsInVzZU1lbW8iLCJfIiwiY2FyZEVsZW1lbnQiLCJhY3Rpb25TZXRFbGVtZW50cyIsIkFycmF5IiwiZnJvbSIsInF1ZXJ5U2VsZWN0b3JBbGwiLCJ1bmRvU3RhY2siLCJtYXAiLCJhY3Rpb25TZXRFbGVtZW50Iiwic2V0T3JSZW1vdmVBdHRyaWJ1dGVJZkZhbHNlV2l0aFVuZG8iLCJidW5jaFVuZG9zIiwidXNlQWRhcHRpdmVDYXJkTW9kRWZmZWN0Il0sInNvdXJjZVJvb3QiOiJidW5kbGU6Ly8vIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9zcmMvYWRhcHRpdmVDYXJkcy9BdHRhY2htZW50L0FkYXB0aXZlQ2FyZEhhY2tzL3VzZUFjdGlvblNldFNob3VsZE5vdEJlTWVudUJhck1vZEVmZmVjdC50cyJdLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyB1c2VNZW1vIH0gZnJvbSAncmVhY3QnO1xuXG5pbXBvcnQgYnVuY2hVbmRvcyBmcm9tICcuLi8uLi9ET01NYW5pcHVsYXRpb25XaXRoVW5kby9idW5jaFVuZG9zJztcbmltcG9ydCBzZXRPclJlbW92ZUF0dHJpYnV0ZUlmRmFsc2VXaXRoVW5kbyBmcm9tICcuLi8uLi9ET01NYW5pcHVsYXRpb25XaXRoVW5kby9zZXRPclJlbW92ZUF0dHJpYnV0ZUlmRmFsc2VXaXRoVW5kbyc7XG5pbXBvcnQgdXNlQWRhcHRpdmVDYXJkTW9kRWZmZWN0IGZyb20gJy4vcHJpdmF0ZS91c2VBZGFwdGl2ZUNhcmRNb2RFZmZlY3QnO1xuXG5pbXBvcnQgdHlwZSB7IEFkYXB0aXZlQ2FyZCB9IGZyb20gJ2FkYXB0aXZlY2FyZHMnO1xuXG4vKipcbiAqIEFjY2Vzc2liaWxpdHk6IEFjdGlvblNldCBzaG91bGQgbm90IGJlIG1lbnUgYmFyLlxuICpcbiAqIE1lbnUgYmFyIGlzIG5vdCBhY2Nlc3NpYmxlIHRocm91Z2ggc2NyZWVuIHJlYWRlciBrZXlib2FyZCBzaG9ydGN1dCBrZXlzOlxuICpcbiAqIC0gPGtiZD5CPC9rYmQ+IHdpbGwganVtcCB0byBuZXh0IGJ1dHRvbiwgd2hpY2ggdGhlIGVuZC11c2VyIGNhbiBxdWlja2x5IHRoZSBjaG9zZW4gYWN0aW9uO1xuICogLSA8a2JkPkY8L2tiZD4gd2lsbCBqdW1wIHRvIG5leHQgZm9ybSBmaWVsZCwgd2hpY2ggaXMgdmVyeSBzaW1pbGFyIGJ1dCBhbHNvIGp1bXAgdG8gdGV4dCBmaWVsZHM7XG4gKiAtIFRoZXJlIGFyZSBubyBrZXlib2FyZCBzaG9ydGN1dCBrZXlzIGZvciBtZW51LlxuICpcbiAqIE1hcmtpbmcgYWN0aW9uIGJ1dHRvbiBhcyBtZW51IGl0ZW0gaW4gYSBtZW51IGJhciBodXJ0cyBhY2Nlc3NpYmlsaXR5LiBFbmQtdXNlciB3aWxsIG5vdCBiZSBhYmxlIHRvIGp1bXAgdG8gYnV0dG9ucyBxdWlja2x5LlxuICpcbiAqIFRodXMsIEFjdGlvblNldCBzaG91bGQgbm90IGJlIG1lbnUgYmFyLlxuICovXG5leHBvcnQgZGVmYXVsdCBmdW5jdGlvbiB1c2VBY3Rpb25TaG91bGRCZVB1c2hCdXR0b25Nb2RFZmZlY3QoYWRhcHRpdmVDYXJkOiBBZGFwdGl2ZUNhcmQpIHtcbiAgY29uc3QgbW9kZGVyID0gdXNlTWVtbyhcbiAgICAoKSA9PiAoXzogQWRhcHRpdmVDYXJkLCBjYXJkRWxlbWVudDogSFRNTEVsZW1lbnQpID0+IHtcbiAgICAgIGNvbnN0IGFjdGlvblNldEVsZW1lbnRzID0gQXJyYXkuZnJvbShcbiAgICAgICAgY2FyZEVsZW1lbnQucXVlcnlTZWxlY3RvckFsbCgnLmFjLWFjdGlvblNldFtyb2xlPVwibWVudWJhclwiXScpIGFzIE5vZGVMaXN0T2Y8SFRNTEVsZW1lbnQ+XG4gICAgICApO1xuXG4gICAgICBjb25zdCB1bmRvU3RhY2sgPSBhY3Rpb25TZXRFbGVtZW50cy5tYXAoYWN0aW9uU2V0RWxlbWVudCA9PlxuICAgICAgICBzZXRPclJlbW92ZUF0dHJpYnV0ZUlmRmFsc2VXaXRoVW5kbyhhY3Rpb25TZXRFbGVtZW50LCAncm9sZScsIGZhbHNlKVxuICAgICAgKTtcblxuICAgICAgcmV0dXJuICgpID0+IGJ1bmNoVW5kb3ModW5kb1N0YWNrKSgpO1xuICAgIH0sXG4gICAgW11cbiAgKTtcblxuICByZXR1cm4gdXNlQWRhcHRpdmVDYXJkTW9kRWZmZWN0KG1vZGRlciwgYWRhcHRpdmVDYXJkKTtcbn1cbiJdLCJtYXBwaW5ncyI6Ijs7Ozs7OztBQUFBLElBQUFBLE1BQUEsR0FBQUMsT0FBQTtBQUVBLElBQUFDLFdBQUEsR0FBQUMsc0JBQUEsQ0FBQUYsT0FBQTtBQUNBLElBQUFHLG9DQUFBLEdBQUFELHNCQUFBLENBQUFGLE9BQUE7QUFDQSxJQUFBSSx5QkFBQSxHQUFBRixzQkFBQSxDQUFBRixPQUFBO0FBSUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDZSxTQUFTSyxvQ0FBb0NBLENBQUNDLFlBQTBCLEVBQUU7RUFDdkYsSUFBTUMsTUFBTSxHQUFHLElBQUFDLGNBQU8sRUFDcEI7SUFBQSxPQUFNLFVBQUNDLENBQWUsRUFBRUMsV0FBd0IsRUFBSztNQUNuRCxJQUFNQyxpQkFBaUIsR0FBR0MsS0FBSyxDQUFDQyxJQUFJLENBQ2xDSCxXQUFXLENBQUNJLGdCQUFnQixDQUFDLCtCQUErQixDQUM5RCxDQUFDO01BRUQsSUFBTUMsU0FBUyxHQUFHSixpQkFBaUIsQ0FBQ0ssR0FBRyxDQUFDLFVBQUFDLGdCQUFnQjtRQUFBLE9BQ3RELElBQUFDLDRDQUFtQyxFQUFDRCxnQkFBZ0IsRUFBRSxNQUFNLEVBQUUsS0FBSyxDQUFDO01BQUEsQ0FDdEUsQ0FBQztNQUVELE9BQU87UUFBQSxPQUFNLElBQUFFLG1CQUFVLEVBQUNKLFNBQVMsQ0FBQyxDQUFDLENBQUM7TUFBQTtJQUN0QyxDQUFDO0VBQUEsR0FDRCxFQUNGLENBQUM7RUFFRCxPQUFPLElBQUFLLGlDQUF3QixFQUFDYixNQUFNLEVBQUVELFlBQVksQ0FBQztBQUN2RCJ9
@@ -1,39 +0,0 @@
1
- import { useMemo } from 'react';
2
-
3
- import bunchUndos from '../../DOMManipulationWithUndo/bunchUndos';
4
- import setOrRemoveAttributeIfFalseWithUndo from '../../DOMManipulationWithUndo/setOrRemoveAttributeIfFalseWithUndo';
5
- import useAdaptiveCardModEffect from './private/useAdaptiveCardModEffect';
6
-
7
- import type { AdaptiveCard } from 'adaptivecards';
8
-
9
- /**
10
- * Accessibility: ActionSet should not be menu bar.
11
- *
12
- * Menu bar is not accessible through screen reader keyboard shortcut keys:
13
- *
14
- * - <kbd>B</kbd> will jump to next button, which the end-user can quickly the chosen action;
15
- * - <kbd>F</kbd> will jump to next form field, which is very similar but also jump to text fields;
16
- * - There are no keyboard shortcut keys for menu.
17
- *
18
- * Marking action button as menu item in a menu bar hurts accessibility. End-user will not be able to jump to buttons quickly.
19
- *
20
- * Thus, ActionSet should not be menu bar.
21
- */
22
- export default function useActionShouldBePushButtonModEffect(adaptiveCard: AdaptiveCard) {
23
- const modder = useMemo(
24
- () => (_: AdaptiveCard, cardElement: HTMLElement) => {
25
- const actionSetElements = Array.from(
26
- cardElement.querySelectorAll('.ac-actionSet[role="menubar"]') as NodeListOf<HTMLElement>
27
- );
28
-
29
- const undoStack = actionSetElements.map(actionSetElement =>
30
- setOrRemoveAttributeIfFalseWithUndo(actionSetElement, 'role', false)
31
- );
32
-
33
- return () => bunchUndos(undoStack)();
34
- },
35
- []
36
- );
37
-
38
- return useAdaptiveCardModEffect(modder, adaptiveCard);
39
- }