botframework-webchat 4.15.8-main.20230406.9f00e6c → 4.15.8-main.20230412.960a5a5
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.
- package/dist/webchat-es5.js +1 -1
- package/dist/webchat-minimal.js +1 -1
- package/dist/webchat.js +1 -1
- package/lib/adaptiveCards/Attachment/AdaptiveCardHacks/useRoleModEffect.d.ts +28 -0
- package/lib/adaptiveCards/Attachment/AdaptiveCardHacks/useRoleModEffect.d.ts.map +1 -0
- package/lib/adaptiveCards/Attachment/AdaptiveCardHacks/useRoleModEffect.js +50 -0
- package/lib/adaptiveCards/Attachment/AdaptiveCardRenderer.d.ts.map +1 -1
- package/lib/adaptiveCards/Attachment/AdaptiveCardRenderer.js +12 -3
- package/lib/adaptiveCards/AttachmentForScreenReader/AdaptiveCardAttachment.js +16 -13
- package/lib/adaptiveCards/Styles/StyleSet/AdaptiveCardRenderer.js +5 -5
- package/lib/adaptiveCards/defaultStyleOptions.js +2 -2
- package/lib/addVersion.js +1 -1
- package/package.json +7 -7
- package/src/adaptiveCards/Attachment/AdaptiveCardHacks/useRoleModEffect.ts +52 -0
- package/src/adaptiveCards/Attachment/AdaptiveCardRenderer.tsx +7 -1
- package/src/adaptiveCards/AttachmentForScreenReader/AdaptiveCardAttachment.js +23 -13
- package/src/adaptiveCards/Styles/StyleSet/AdaptiveCardRenderer.ts +4 -4
- package/src/adaptiveCards/defaultStyleOptions.ts +1 -1
|
@@ -0,0 +1,28 @@
|
|
|
1
|
+
import type { AdaptiveCard } from 'adaptivecards';
|
|
2
|
+
/**
|
|
3
|
+
* Accessibility: "role" attribute must be set if "aria-label" is set.
|
|
4
|
+
*
|
|
5
|
+
* It is possible to render an Adaptive Card with empty content but "aria-label" attribute. The Adaptive Cards JSON looks like:
|
|
6
|
+
*
|
|
7
|
+
* ```json
|
|
8
|
+
* {
|
|
9
|
+
* "type": "AdaptiveCard",
|
|
10
|
+
* "speak": "Hello, World!",
|
|
11
|
+
* "body": [],
|
|
12
|
+
* "$schema": "http://adaptivecards.io/schemas/adaptive-card.json",
|
|
13
|
+
* "version": "1.5"
|
|
14
|
+
* }
|
|
15
|
+
* ```
|
|
16
|
+
*
|
|
17
|
+
* The HTML output will be:
|
|
18
|
+
*
|
|
19
|
+
* ```html
|
|
20
|
+
* <div class="ac-adaptiveCard" aria-label="Hello, World!"></div>
|
|
21
|
+
* ```
|
|
22
|
+
*
|
|
23
|
+
* This violates WAI-ARIA because "aria-label" must not be set on an element without a "role".
|
|
24
|
+
*
|
|
25
|
+
* We need to set "role" attribute to "form" if the card has any input fields and is valid as a "form" role, otherwise, "figure".
|
|
26
|
+
*/
|
|
27
|
+
export default function useRoleModEffect(adaptiveCard: AdaptiveCard): readonly [(cardElement: HTMLElement) => void, () => void];
|
|
28
|
+
//# sourceMappingURL=useRoleModEffect.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"useRoleModEffect.d.ts","sourceRoot":"","sources":["../../../../src/adaptiveCards/Attachment/AdaptiveCardHacks/useRoleModEffect.ts"],"names":[],"mappings":"AAKA,OAAO,KAAK,EAAE,YAAY,EAAE,MAAM,eAAe,CAAC;AAElD;;;;;;;;;;;;;;;;;;;;;;;;GAwBG;AACH,MAAM,CAAC,OAAO,UAAU,gBAAgB,CACtC,YAAY,EAAE,YAAY,GACzB,SAAS,CAAC,CAAC,WAAW,EAAE,WAAW,KAAK,IAAI,EAAE,MAAM,IAAI,CAAC,CAiB3D"}
|
|
@@ -0,0 +1,50 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
|
|
3
|
+
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
|
|
4
|
+
|
|
5
|
+
Object.defineProperty(exports, "__esModule", {
|
|
6
|
+
value: true
|
|
7
|
+
});
|
|
8
|
+
exports.default = useRoleModEffect;
|
|
9
|
+
|
|
10
|
+
var _react = require("react");
|
|
11
|
+
|
|
12
|
+
var _setOrRemoveAttributeIfFalseWithUndo = _interopRequireDefault(require("../../DOMManipulationWithUndo/setOrRemoveAttributeIfFalseWithUndo"));
|
|
13
|
+
|
|
14
|
+
var _useAdaptiveCardModEffect = _interopRequireDefault(require("./private/useAdaptiveCardModEffect"));
|
|
15
|
+
|
|
16
|
+
/**
|
|
17
|
+
* Accessibility: "role" attribute must be set if "aria-label" is set.
|
|
18
|
+
*
|
|
19
|
+
* It is possible to render an Adaptive Card with empty content but "aria-label" attribute. The Adaptive Cards JSON looks like:
|
|
20
|
+
*
|
|
21
|
+
* ```json
|
|
22
|
+
* {
|
|
23
|
+
* "type": "AdaptiveCard",
|
|
24
|
+
* "speak": "Hello, World!",
|
|
25
|
+
* "body": [],
|
|
26
|
+
* "$schema": "http://adaptivecards.io/schemas/adaptive-card.json",
|
|
27
|
+
* "version": "1.5"
|
|
28
|
+
* }
|
|
29
|
+
* ```
|
|
30
|
+
*
|
|
31
|
+
* The HTML output will be:
|
|
32
|
+
*
|
|
33
|
+
* ```html
|
|
34
|
+
* <div class="ac-adaptiveCard" aria-label="Hello, World!"></div>
|
|
35
|
+
* ```
|
|
36
|
+
*
|
|
37
|
+
* This violates WAI-ARIA because "aria-label" must not be set on an element without a "role".
|
|
38
|
+
*
|
|
39
|
+
* We need to set "role" attribute to "form" if the card has any input fields and is valid as a "form" role, otherwise, "figure".
|
|
40
|
+
*/
|
|
41
|
+
function useRoleModEffect(adaptiveCard) {
|
|
42
|
+
var modder = (0, _react.useMemo)(function () {
|
|
43
|
+
return function (_, cardElement) {
|
|
44
|
+
return (0, _setOrRemoveAttributeIfFalseWithUndo.default)(cardElement, 'role', // "form" role requires either "aria-label", "aria-labelledby", or "title".
|
|
45
|
+
cardElement.querySelector('button, input, select, textarea') && cardElement.getAttribute('aria-label') || cardElement.getAttribute('aria-labelledby') || cardElement.getAttribute('title') ? 'form' : 'figure');
|
|
46
|
+
};
|
|
47
|
+
}, []);
|
|
48
|
+
return (0, _useAdaptiveCardModEffect.default)(modder, adaptiveCard);
|
|
49
|
+
}
|
|
50
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJ1c2VSb2xlTW9kRWZmZWN0IiwiYWRhcHRpdmVDYXJkIiwibW9kZGVyIiwidXNlTWVtbyIsIl8iLCJjYXJkRWxlbWVudCIsInNldE9yUmVtb3ZlQXR0cmlidXRlSWZGYWxzZVdpdGhVbmRvIiwicXVlcnlTZWxlY3RvciIsImdldEF0dHJpYnV0ZSIsInVzZUFkYXB0aXZlQ2FyZE1vZEVmZmVjdCJdLCJzb3VyY2VSb290IjoiYnVuZGxlOi8vLyIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vc3JjL2FkYXB0aXZlQ2FyZHMvQXR0YWNobWVudC9BZGFwdGl2ZUNhcmRIYWNrcy91c2VSb2xlTW9kRWZmZWN0LnRzIl0sInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IHVzZU1lbW8gfSBmcm9tICdyZWFjdCc7XG5cbmltcG9ydCBzZXRPclJlbW92ZUF0dHJpYnV0ZUlmRmFsc2VXaXRoVW5kbyBmcm9tICcuLi8uLi9ET01NYW5pcHVsYXRpb25XaXRoVW5kby9zZXRPclJlbW92ZUF0dHJpYnV0ZUlmRmFsc2VXaXRoVW5kbyc7XG5pbXBvcnQgdXNlQWRhcHRpdmVDYXJkTW9kRWZmZWN0IGZyb20gJy4vcHJpdmF0ZS91c2VBZGFwdGl2ZUNhcmRNb2RFZmZlY3QnO1xuXG5pbXBvcnQgdHlwZSB7IEFkYXB0aXZlQ2FyZCB9IGZyb20gJ2FkYXB0aXZlY2FyZHMnO1xuXG4vKipcbiAqIEFjY2Vzc2liaWxpdHk6IFwicm9sZVwiIGF0dHJpYnV0ZSBtdXN0IGJlIHNldCBpZiBcImFyaWEtbGFiZWxcIiBpcyBzZXQuXG4gKlxuICogSXQgaXMgcG9zc2libGUgdG8gcmVuZGVyIGFuIEFkYXB0aXZlIENhcmQgd2l0aCBlbXB0eSBjb250ZW50IGJ1dCBcImFyaWEtbGFiZWxcIiBhdHRyaWJ1dGUuIFRoZSBBZGFwdGl2ZSBDYXJkcyBKU09OIGxvb2tzIGxpa2U6XG4gKlxuICogYGBganNvblxuICoge1xuICogICBcInR5cGVcIjogXCJBZGFwdGl2ZUNhcmRcIixcbiAqICAgXCJzcGVha1wiOiBcIkhlbGxvLCBXb3JsZCFcIixcbiAqICAgXCJib2R5XCI6IFtdLFxuICogICBcIiRzY2hlbWFcIjogXCJodHRwOi8vYWRhcHRpdmVjYXJkcy5pby9zY2hlbWFzL2FkYXB0aXZlLWNhcmQuanNvblwiLFxuICogICBcInZlcnNpb25cIjogXCIxLjVcIlxuICogfVxuICogYGBgXG4gKlxuICogVGhlIEhUTUwgb3V0cHV0IHdpbGwgYmU6XG4gKlxuICogYGBgaHRtbFxuICogPGRpdiBjbGFzcz1cImFjLWFkYXB0aXZlQ2FyZFwiIGFyaWEtbGFiZWw9XCJIZWxsbywgV29ybGQhXCI+PC9kaXY+XG4gKiBgYGBcbiAqXG4gKiBUaGlzIHZpb2xhdGVzIFdBSS1BUklBIGJlY2F1c2UgXCJhcmlhLWxhYmVsXCIgbXVzdCBub3QgYmUgc2V0IG9uIGFuIGVsZW1lbnQgd2l0aG91dCBhIFwicm9sZVwiLlxuICpcbiAqIFdlIG5lZWQgdG8gc2V0IFwicm9sZVwiIGF0dHJpYnV0ZSB0byBcImZvcm1cIiBpZiB0aGUgY2FyZCBoYXMgYW55IGlucHV0IGZpZWxkcyBhbmQgaXMgdmFsaWQgYXMgYSBcImZvcm1cIiByb2xlLCBvdGhlcndpc2UsIFwiZmlndXJlXCIuXG4gKi9cbmV4cG9ydCBkZWZhdWx0IGZ1bmN0aW9uIHVzZVJvbGVNb2RFZmZlY3QoXG4gIGFkYXB0aXZlQ2FyZDogQWRhcHRpdmVDYXJkXG4pOiByZWFkb25seSBbKGNhcmRFbGVtZW50OiBIVE1MRWxlbWVudCkgPT4gdm9pZCwgKCkgPT4gdm9pZF0ge1xuICBjb25zdCBtb2RkZXIgPSB1c2VNZW1vKFxuICAgICgpID0+IChfLCBjYXJkRWxlbWVudDogSFRNTEVsZW1lbnQpID0+XG4gICAgICBzZXRPclJlbW92ZUF0dHJpYnV0ZUlmRmFsc2VXaXRoVW5kbyhcbiAgICAgICAgY2FyZEVsZW1lbnQsXG4gICAgICAgICdyb2xlJyxcbiAgICAgICAgLy8gXCJmb3JtXCIgcm9sZSByZXF1aXJlcyBlaXRoZXIgXCJhcmlhLWxhYmVsXCIsIFwiYXJpYS1sYWJlbGxlZGJ5XCIsIG9yIFwidGl0bGVcIi5cbiAgICAgICAgKGNhcmRFbGVtZW50LnF1ZXJ5U2VsZWN0b3IoJ2J1dHRvbiwgaW5wdXQsIHNlbGVjdCwgdGV4dGFyZWEnKSAmJiBjYXJkRWxlbWVudC5nZXRBdHRyaWJ1dGUoJ2FyaWEtbGFiZWwnKSkgfHxcbiAgICAgICAgICBjYXJkRWxlbWVudC5nZXRBdHRyaWJ1dGUoJ2FyaWEtbGFiZWxsZWRieScpIHx8XG4gICAgICAgICAgY2FyZEVsZW1lbnQuZ2V0QXR0cmlidXRlKCd0aXRsZScpXG4gICAgICAgICAgPyAnZm9ybSdcbiAgICAgICAgICA6ICdmaWd1cmUnXG4gICAgICApLFxuICAgIFtdXG4gICk7XG5cbiAgcmV0dXJuIHVzZUFkYXB0aXZlQ2FyZE1vZEVmZmVjdChtb2RkZXIsIGFkYXB0aXZlQ2FyZCk7XG59XG4iXSwibWFwcGluZ3MiOiI7Ozs7Ozs7OztBQUFBOztBQUVBOztBQUNBOztBQUlBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ2UsU0FBU0EsZ0JBQVQsQ0FDYkMsWUFEYSxFQUU4QztFQUMzRCxJQUFNQyxNQUFNLEdBQUcsSUFBQUMsY0FBQSxFQUNiO0lBQUEsT0FBTSxVQUFDQyxDQUFELEVBQUlDLFdBQUo7TUFBQSxPQUNKLElBQUFDLDRDQUFBLEVBQ0VELFdBREYsRUFFRSxNQUZGLEVBR0U7TUFDQ0EsV0FBVyxDQUFDRSxhQUFaLENBQTBCLGlDQUExQixLQUFnRUYsV0FBVyxDQUFDRyxZQUFaLENBQXlCLFlBQXpCLENBQWpFLElBQ0VILFdBQVcsQ0FBQ0csWUFBWixDQUF5QixpQkFBekIsQ0FERixJQUVFSCxXQUFXLENBQUNHLFlBQVosQ0FBeUIsT0FBekIsQ0FGRixHQUdJLE1BSEosR0FJSSxRQVJOLENBREk7SUFBQSxDQUFOO0VBQUEsQ0FEYSxFQVliLEVBWmEsQ0FBZjtFQWVBLE9BQU8sSUFBQUMsaUNBQUEsRUFBeUJQLE1BQXpCLEVBQWlDRCxZQUFqQyxDQUFQO0FBQ0QifQ==
|
|
@@ -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;
|
|
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;AAmBtE,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,CAkNxD,CAAC;AAuBF,eAAe,oBAAoB,CAAC"}
|
|
@@ -35,6 +35,8 @@ var _useDisabledModEffect3 = _interopRequireDefault(require("./AdaptiveCardHacks
|
|
|
35
35
|
|
|
36
36
|
var _usePersistValuesModEffect = _interopRequireDefault(require("./AdaptiveCardHacks/usePersistValuesModEffect"));
|
|
37
37
|
|
|
38
|
+
var _useRoleModEffect3 = _interopRequireDefault(require("./AdaptiveCardHacks/useRoleModEffect"));
|
|
39
|
+
|
|
38
40
|
var _useValueRef = _interopRequireDefault(require("./AdaptiveCardHacks/private/useValueRef"));
|
|
39
41
|
|
|
40
42
|
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); }
|
|
@@ -202,12 +204,18 @@ var AdaptiveCardRenderer = function AdaptiveCardRenderer(_ref) {
|
|
|
202
204
|
applyPersistValuesMod = _usePersistValuesModE2[0],
|
|
203
205
|
undoPersistValuesMod = _usePersistValuesModE2[1];
|
|
204
206
|
|
|
207
|
+
var _useRoleModEffect = (0, _useRoleModEffect3.default)(adaptiveCard),
|
|
208
|
+
_useRoleModEffect2 = (0, _slicedToArray2.default)(_useRoleModEffect, 2),
|
|
209
|
+
applyRoleMod = _useRoleModEffect2[0],
|
|
210
|
+
undoRoleMod = _useRoleModEffect2[1];
|
|
211
|
+
|
|
205
212
|
var _useMemo = (0, _react.useMemo)(function () {
|
|
206
213
|
undoActionShouldBePushButtonMod();
|
|
207
214
|
undoActionSetShouldNotBeMenuBarMod();
|
|
208
215
|
undoActiveElementMod();
|
|
209
216
|
undoDisabledMod();
|
|
210
217
|
undoPersistValuesMod();
|
|
218
|
+
undoRoleMod();
|
|
211
219
|
return (0, _renderAdaptiveCard.default)(adaptiveCard, {
|
|
212
220
|
adaptiveCardsHostConfig: adaptiveCardsHostConfig,
|
|
213
221
|
adaptiveCardsPackage: {
|
|
@@ -217,7 +225,7 @@ var AdaptiveCardRenderer = function AdaptiveCardRenderer(_ref) {
|
|
|
217
225
|
renderMarkdownAsHTML: renderMarkdownAsHTML,
|
|
218
226
|
setTabIndexAtCardRoot: setTabIndexAtCardRoot
|
|
219
227
|
});
|
|
220
|
-
}, [adaptiveCard, adaptiveCardsHostConfig, GlobalSettings, HostConfig, renderMarkdownAsHTML, setTabIndexAtCardRoot, undoActionShouldBePushButtonMod, undoActionSetShouldNotBeMenuBarMod, undoActiveElementMod, undoDisabledMod, undoPersistValuesMod]),
|
|
228
|
+
}, [adaptiveCard, adaptiveCardsHostConfig, GlobalSettings, HostConfig, renderMarkdownAsHTML, setTabIndexAtCardRoot, undoActionShouldBePushButtonMod, undoActionSetShouldNotBeMenuBarMod, undoActiveElementMod, undoDisabledMod, undoPersistValuesMod, undoRoleMod]),
|
|
221
229
|
element = _useMemo.element,
|
|
222
230
|
errors = _useMemo.errors;
|
|
223
231
|
|
|
@@ -239,7 +247,8 @@ var AdaptiveCardRenderer = function AdaptiveCardRenderer(_ref) {
|
|
|
239
247
|
applyActiveElementMod(element);
|
|
240
248
|
applyDisabledMod(element, disabled);
|
|
241
249
|
applyPersistValuesMod(element);
|
|
242
|
-
|
|
250
|
+
applyRoleMod(element);
|
|
251
|
+
}, [actionPerformedClassName, applyActionShouldBePushButtonMod, applyActionSetShouldNotBeMenuBarMod, applyActiveElementMod, applyDisabledMod, applyPersistValuesMod, applyRoleMod, disabled, element]);
|
|
243
252
|
return errors !== null && errors !== void 0 && errors.length ? node_env === 'development' && /*#__PURE__*/_react.default.createElement(ErrorBox, {
|
|
244
253
|
error: errors[0],
|
|
245
254
|
type: localize('ADAPTIVE_CARD_ERROR_BOX_TITLE_RENDER')
|
|
@@ -271,4 +280,4 @@ AdaptiveCardRenderer.propTypes = {
|
|
|
271
280
|
};
|
|
272
281
|
var _default = AdaptiveCardRenderer;
|
|
273
282
|
exports.default = _default;
|
|
274
|
-
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["ErrorBox","Components","useDisabled","hooks","useLocalizer","usePerformCardAction","useRenderMarkdownAsHTML","useScrollToEnd","useStyleSet","node_env","AdaptiveCardRenderer","actionPerformedClassName","adaptiveCard","disabledFromProps","disabled","tapAction","adaptiveCardRendererStyleSet","adaptiveCardRenderer","useAdaptiveCardsPackage","GlobalSettings","HostConfig","useAdaptiveCardsHostConfig","adaptiveCardsHostConfig","disabledFromComposer","contentRef","useRef","localize","performCardAction","renderMarkdownAsHTML","scrollToEnd","tapActionRef","useValueRef","disabledRef","handleClickAndKeyPress","useCallback","event","key","type","target","current","adaptiveCardRoot","querySelector","console","warn","preventDefault","tabIndex","getTabIndex","handleClickAndKeyPressForTapAction","undefined","handleExecuteAction","action","actionTypeName","getJsonTypeName","image","iconUrl","title","value","url","data","__isBotFrameworkCardAction","cardAction","error","setTabIndexAtCardRoot","useActionShouldBePushButtonModEffect","applyActionShouldBePushButtonMod","undoActionShouldBePushButtonMod","useActionSetShouldNotBeMenuBarModEffect","applyActionSetShouldNotBeMenuBarMod","undoActionSetShouldNotBeMenuBarMod","useActiveElementModEffect","applyActiveElementMod","undoActiveElementMod","useDisabledModEffect","applyDisabledMod","undoDisabledMod","usePersistValuesModEffect","applyPersistValuesMod","undoPersistValuesMod","useMemo","renderAdaptiveCard","adaptiveCardsPackage","element","errors","onExecuteAction","useLayoutEffect","appendChild","removeChild","length","classNames","defaultProps","propTypes","PropTypes","string","any","isRequired","bool","shape"],"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 useValueRef from './AdaptiveCardHacks/private/useValueRef';\n\nconst { ErrorBox } = Components;\nconst { useDisabled, useLocalizer, usePerformCardAction, useRenderMarkdownAsHTML, useScrollToEnd, useStyleSet } = 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\n  const { element, errors }: { element?: HTMLElement; errors?: Error[] } = useMemo(() => {\n    undoActionShouldBePushButtonMod();\n    undoActionSetShouldNotBeMenuBarMod();\n    undoActiveElementMod();\n    undoDisabledMod();\n    undoPersistValuesMod();\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  ]);\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    applyActionShouldBePushButtonMod(element, actionPerformedClassName);\n    applyActionSetShouldNotBeMenuBarMod(element);\n    applyActiveElementMod(element);\n    applyDisabledMod(element, disabled);\n    applyPersistValuesMod(element);\n  }, [\n    actionPerformedClassName,\n    applyActionShouldBePushButtonMod,\n    applyActionSetShouldNotBeMenuBarMod,\n    applyActiveElementMod,\n    applyDisabledMod,\n    applyPersistValuesMod,\n    disabled,\n    element\n  ]);\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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"}
|
|
283
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["ErrorBox","Components","useDisabled","hooks","useLocalizer","usePerformCardAction","useRenderMarkdownAsHTML","useScrollToEnd","useStyleSet","node_env","AdaptiveCardRenderer","actionPerformedClassName","adaptiveCard","disabledFromProps","disabled","tapAction","adaptiveCardRendererStyleSet","adaptiveCardRenderer","useAdaptiveCardsPackage","GlobalSettings","HostConfig","useAdaptiveCardsHostConfig","adaptiveCardsHostConfig","disabledFromComposer","contentRef","useRef","localize","performCardAction","renderMarkdownAsHTML","scrollToEnd","tapActionRef","useValueRef","disabledRef","handleClickAndKeyPress","useCallback","event","key","type","target","current","adaptiveCardRoot","querySelector","console","warn","preventDefault","tabIndex","getTabIndex","handleClickAndKeyPressForTapAction","undefined","handleExecuteAction","action","actionTypeName","getJsonTypeName","image","iconUrl","title","value","url","data","__isBotFrameworkCardAction","cardAction","error","setTabIndexAtCardRoot","useActionShouldBePushButtonModEffect","applyActionShouldBePushButtonMod","undoActionShouldBePushButtonMod","useActionSetShouldNotBeMenuBarModEffect","applyActionSetShouldNotBeMenuBarMod","undoActionSetShouldNotBeMenuBarMod","useActiveElementModEffect","applyActiveElementMod","undoActiveElementMod","useDisabledModEffect","applyDisabledMod","undoDisabledMod","usePersistValuesModEffect","applyPersistValuesMod","undoPersistValuesMod","useRoleModEffect","applyRoleMod","undoRoleMod","useMemo","renderAdaptiveCard","adaptiveCardsPackage","element","errors","onExecuteAction","useLayoutEffect","appendChild","removeChild","length","classNames","defaultProps","propTypes","PropTypes","string","any","isRequired","bool","shape"],"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 useValueRef from './AdaptiveCardHacks/private/useValueRef';\n\nconst { ErrorBox } = Components;\nconst { useDisabled, useLocalizer, usePerformCardAction, useRenderMarkdownAsHTML, useScrollToEnd, useStyleSet } = 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    applyActionShouldBePushButtonMod(element, actionPerformedClassName);\n    applyActionSetShouldNotBeMenuBarMod(element);\n    applyActiveElementMod(element);\n    applyDisabledMod(element, disabled);\n    applyPersistValuesMod(element);\n    applyRoleMod(element);\n  }, [\n    actionPerformedClassName,\n    applyActionShouldBePushButtonMod,\n    applyActionSetShouldNotBeMenuBarMod,\n    applyActiveElementMod,\n    applyDisabledMod,\n    applyPersistValuesMod,\n    applyRoleMod,\n    disabled,\n    element\n  ]);\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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"}
|
|
@@ -51,19 +51,21 @@ function walkAllItems(node, fn) {
|
|
|
51
51
|
var AdaptiveCardChoiceSetInput = function AdaptiveCardChoiceSetInput(_ref) {
|
|
52
52
|
var _ref$input = _ref.input,
|
|
53
53
|
choices = _ref$input.choices,
|
|
54
|
-
defaultValue = _ref$input.defaultValue
|
|
54
|
+
defaultValue = _ref$input.defaultValue,
|
|
55
|
+
label = _ref$input.label;
|
|
55
56
|
var labelId = (0, _useUniqueId.default)('webchat__id');
|
|
56
57
|
var defaultChoice = choices.find(function (_ref2) {
|
|
57
58
|
var value = _ref2.value;
|
|
58
59
|
return defaultValue === value || !defaultValue && !value;
|
|
59
60
|
});
|
|
60
61
|
return /*#__PURE__*/_react.default.createElement("div", null, /*#__PURE__*/_react.default.createElement("select", {
|
|
61
|
-
"aria-
|
|
62
|
+
"aria-label": label,
|
|
63
|
+
"aria-labelledby": !label && defaultChoice ? labelId : undefined,
|
|
62
64
|
defaultValue: defaultValue,
|
|
63
65
|
tabIndex: -1
|
|
64
66
|
}, choices.map(function (choice) {
|
|
65
67
|
return /*#__PURE__*/_react.default.createElement("option", {
|
|
66
|
-
id: choice === defaultChoice ? labelId : undefined,
|
|
68
|
+
id: !label && choice === defaultChoice ? labelId : undefined,
|
|
67
69
|
key: choice.value,
|
|
68
70
|
value: choice.value
|
|
69
71
|
}, choice.title);
|
|
@@ -77,6 +79,7 @@ AdaptiveCardChoiceSetInput.propTypes = {
|
|
|
77
79
|
value: _propTypes.default.any
|
|
78
80
|
})),
|
|
79
81
|
defaultValue: _propTypes.default.any,
|
|
82
|
+
label: _propTypes.default.string,
|
|
80
83
|
value: _propTypes.default.any
|
|
81
84
|
}).isRequired
|
|
82
85
|
};
|
|
@@ -118,15 +121,15 @@ var AdaptiveCardAttachment = function AdaptiveCardAttachment(_ref3) {
|
|
|
118
121
|
return input instanceof ChoiceSetInput ? /*#__PURE__*/_react.default.createElement(AdaptiveCardChoiceSetInput, {
|
|
119
122
|
input: input,
|
|
120
123
|
key: index
|
|
121
|
-
}) : input instanceof DateInput ? /*#__PURE__*/_react.default.createElement("
|
|
124
|
+
}) : input instanceof DateInput ? /*#__PURE__*/_react.default.createElement("label", {
|
|
122
125
|
key: index
|
|
123
|
-
}, /*#__PURE__*/_react.default.createElement("input", {
|
|
126
|
+
}, input.title, /*#__PURE__*/_react.default.createElement("input", {
|
|
124
127
|
placeholder: input.placeholder,
|
|
125
128
|
tabIndex: -1,
|
|
126
129
|
type: "date"
|
|
127
|
-
})) : input instanceof NumberInput ? /*#__PURE__*/_react.default.createElement("
|
|
130
|
+
})) : input instanceof NumberInput ? /*#__PURE__*/_react.default.createElement("label", {
|
|
128
131
|
key: index
|
|
129
|
-
}, /*#__PURE__*/_react.default.createElement("input", {
|
|
132
|
+
}, input.title, /*#__PURE__*/_react.default.createElement("input", {
|
|
130
133
|
placeholder: input.placeholder,
|
|
131
134
|
tabIndex: -1,
|
|
132
135
|
type: "number"
|
|
@@ -135,19 +138,19 @@ var AdaptiveCardAttachment = function AdaptiveCardAttachment(_ref3) {
|
|
|
135
138
|
}, /*#__PURE__*/_react.default.createElement("button", {
|
|
136
139
|
tabIndex: -1,
|
|
137
140
|
type: "button"
|
|
138
|
-
}, input.title)) : input instanceof TextInput ? /*#__PURE__*/_react.default.createElement("
|
|
141
|
+
}, input.title)) : input instanceof TextInput ? /*#__PURE__*/_react.default.createElement("label", {
|
|
139
142
|
key: index
|
|
140
|
-
}, /*#__PURE__*/_react.default.createElement("input", {
|
|
143
|
+
}, input.title, /*#__PURE__*/_react.default.createElement("input", {
|
|
141
144
|
placeholder: input.placeholder,
|
|
142
145
|
tabIndex: -1,
|
|
143
146
|
type: "text"
|
|
144
|
-
})) : input instanceof TimeInput ? /*#__PURE__*/_react.default.createElement("
|
|
147
|
+
})) : input instanceof TimeInput ? /*#__PURE__*/_react.default.createElement("label", {
|
|
145
148
|
key: index
|
|
146
|
-
}, /*#__PURE__*/_react.default.createElement("input", {
|
|
149
|
+
}, input.title, /*#__PURE__*/_react.default.createElement("input", {
|
|
147
150
|
placeholder: input.placeholder,
|
|
148
151
|
tabIndex: -1,
|
|
149
152
|
type: "time"
|
|
150
|
-
})) : input instanceof ToggleInput ? /*#__PURE__*/_react.default.createElement("
|
|
153
|
+
})) : input instanceof ToggleInput ? /*#__PURE__*/_react.default.createElement("label", {
|
|
151
154
|
key: index
|
|
152
155
|
}, input.title, /*#__PURE__*/_react.default.createElement("input", {
|
|
153
156
|
defaultChecked: input.value === input.valueOn,
|
|
@@ -162,4 +165,4 @@ AdaptiveCardAttachment.propTypes = {
|
|
|
162
165
|
};
|
|
163
166
|
var _default = AdaptiveCardAttachment;
|
|
164
167
|
exports.default = _default;
|
|
165
|
-
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["useLocalizer","hooks","walkAllItems","node","fn","getItemAt","getItemCount","count","index","getActionAt","getActionCount","AdaptiveCardChoiceSetInput","input","choices","defaultValue","labelId","useUniqueId","defaultChoice","find","value","undefined","map","choice","title","propTypes","PropTypes","shape","arrayOf","string","any","isRequired","AdaptiveCardAttachment","content","localize","parseAdaptiveCardJSON","useParseAdaptiveCardJSON","useAdaptiveCardsPackage","ChoiceSetInput","DateInput","NumberInput","OpenUrlAction","ShowCardAction","SubmitAction","TextInput","TimeInput","ToggleInput","card","useMemo","ignoreErrors","inputs","push","cardLabel","speak","placeholder","valueOn"],"sourceRoot":"bundle:///","sources":["../../../src/adaptiveCards/AttachmentForScreenReader/AdaptiveCardAttachment.js"],"sourcesContent":["/* eslint-disable react/no-array-index-key */\n/* eslint-disable react/forbid-dom-props */\nimport { hooks } from 'botframework-webchat-component';\nimport PropTypes from 'prop-types';\nimport React, { useMemo } from 'react';\n\nimport useAdaptiveCardsPackage from '../hooks/useAdaptiveCardsPackage';\nimport useParseAdaptiveCardJSON from '../hooks/internal/useParseAdaptiveCardJSON';\nimport useUniqueId from '../hooks/internal/useUniqueId';\n\nconst { useLocalizer } = hooks;\n\n// Perform a depth-first search of the Adaptive Card tree.\nfunction walkAllItems(node, fn) {\n  fn(node);\n\n  if (node.getItemAt && node.getItemCount) {\n    for (let count = node.getItemCount(), index = 0; index < count; index++) {\n      walkAllItems(node.getItemAt(index), fn);\n    }\n  }\n\n  if (node.getActionAt && node.getActionCount) {\n    for (let count = node.getActionCount(), index = 0; index < count; index++) {\n      fn(node.getActionAt(index));\n    }\n  }\n}\n\nconst AdaptiveCardChoiceSetInput = ({ input: { choices, defaultValue } }) => {\n  const labelId = useUniqueId('webchat__id');\n  const defaultChoice = choices.find(({ value }) => defaultValue === value || (!defaultValue && !value));\n\n  return (\n    <div>\n      <select aria-labelledby={defaultChoice ? labelId : undefined} defaultValue={defaultValue} tabIndex={-1}>\n        {choices.map(choice => (\n          <option id={choice === defaultChoice ? labelId : undefined} key={choice.value} value={choice.value}>\n            {choice.title}\n          </option>\n        ))}\n      </select>\n    </div>\n  );\n};\n\nAdaptiveCardChoiceSetInput.propTypes = {\n  input: PropTypes.shape({\n    choices: PropTypes.arrayOf(\n      PropTypes.shape({\n        title: PropTypes.string,\n        value: PropTypes.any\n      })\n    ),\n    defaultValue: PropTypes.any,\n    value: PropTypes.any\n  }).isRequired\n};\n\nconst AdaptiveCardAttachment = ({ content }) => {\n  const localize = useLocalizer();\n  const parseAdaptiveCardJSON = useParseAdaptiveCardJSON();\n  const [\n    {\n      ChoiceSetInput,\n      DateInput,\n      NumberInput,\n      OpenUrlAction,\n      ShowCardAction,\n      SubmitAction,\n      TextInput,\n      TimeInput,\n      ToggleInput\n    }\n  ] = useAdaptiveCardsPackage();\n\n  const card = useMemo(() => parseAdaptiveCardJSON(content, { ignoreErrors: true }), [content, parseAdaptiveCardJSON]);\n  const inputs = useMemo(() => {\n    const inputs = [];\n\n    walkAllItems(card, node => {\n      if (\n        node instanceof ChoiceSetInput ||\n        node instanceof DateInput ||\n        node instanceof NumberInput ||\n        node instanceof OpenUrlAction ||\n        node instanceof ShowCardAction ||\n        node instanceof SubmitAction ||\n        node instanceof TextInput ||\n        node instanceof TimeInput ||\n        node instanceof ToggleInput\n      ) {\n        inputs.push(node);\n      }\n    });\n\n    return inputs;\n  }, [\n    card,\n    ChoiceSetInput,\n    DateInput,\n    NumberInput,\n    OpenUrlAction,\n    ShowCardAction,\n    SubmitAction,\n    TextInput,\n    TimeInput,\n    ToggleInput\n  ]);\n\n  const cardLabel = localize('ATTACHMENT_CARD', card.speak || '', '', '');\n\n  return (\n    <article>\n      <div>{cardLabel}</div>\n      {inputs.map((input, index) =>\n        input instanceof ChoiceSetInput ? (\n          <AdaptiveCardChoiceSetInput input={input} key={index} />\n        ) : input instanceof DateInput ? (\n          <div key={index}>\n            <input placeholder={input.placeholder} tabIndex={-1} type=\"date\" />\n          </div>\n        ) : input instanceof NumberInput ? (\n          <div key={index}>\n            <input placeholder={input.placeholder} tabIndex={-1} type=\"number\" />\n          </div>\n        ) : input instanceof OpenUrlAction || input instanceof ShowCardAction || input instanceof SubmitAction ? (\n          <div key={index}>\n            <button tabIndex={-1} type=\"button\">\n              {input.title}\n            </button>\n          </div>\n        ) : input instanceof TextInput ? (\n          <div key={index}>\n            <input placeholder={input.placeholder} tabIndex={-1} type=\"text\" />\n          </div>\n        ) : input instanceof TimeInput ? (\n          <div key={index}>\n            <input placeholder={input.placeholder} tabIndex={-1} type=\"time\" />\n          </div>\n        ) : input instanceof ToggleInput ? (\n          <div key={index}>\n            {input.title}\n            <input defaultChecked={input.value === input.valueOn} tabIndex={-1} type=\"checkbox\" />\n          </div>\n        ) : (\n          false\n        )\n      )}\n    </article>\n  );\n};\n\nAdaptiveCardAttachment.propTypes = {\n  content: PropTypes.any.isRequired\n};\n\nexport default AdaptiveCardAttachment;\n"],"mappings":"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"}
|
|
168
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["useLocalizer","hooks","walkAllItems","node","fn","getItemAt","getItemCount","count","index","getActionAt","getActionCount","AdaptiveCardChoiceSetInput","input","choices","defaultValue","label","labelId","useUniqueId","defaultChoice","find","value","undefined","map","choice","title","propTypes","PropTypes","shape","arrayOf","string","any","isRequired","AdaptiveCardAttachment","content","localize","parseAdaptiveCardJSON","useParseAdaptiveCardJSON","useAdaptiveCardsPackage","ChoiceSetInput","DateInput","NumberInput","OpenUrlAction","ShowCardAction","SubmitAction","TextInput","TimeInput","ToggleInput","card","useMemo","ignoreErrors","inputs","push","cardLabel","speak","placeholder","valueOn"],"sourceRoot":"bundle:///","sources":["../../../src/adaptiveCards/AttachmentForScreenReader/AdaptiveCardAttachment.js"],"sourcesContent":["/* eslint-disable react/no-array-index-key */\n/* eslint-disable react/forbid-dom-props */\nimport { hooks } from 'botframework-webchat-component';\nimport PropTypes from 'prop-types';\nimport React, { useMemo } from 'react';\n\nimport useAdaptiveCardsPackage from '../hooks/useAdaptiveCardsPackage';\nimport useParseAdaptiveCardJSON from '../hooks/internal/useParseAdaptiveCardJSON';\nimport useUniqueId from '../hooks/internal/useUniqueId';\n\nconst { useLocalizer } = hooks;\n\n// Perform a depth-first search of the Adaptive Card tree.\nfunction walkAllItems(node, fn) {\n  fn(node);\n\n  if (node.getItemAt && node.getItemCount) {\n    for (let count = node.getItemCount(), index = 0; index < count; index++) {\n      walkAllItems(node.getItemAt(index), fn);\n    }\n  }\n\n  if (node.getActionAt && node.getActionCount) {\n    for (let count = node.getActionCount(), index = 0; index < count; index++) {\n      fn(node.getActionAt(index));\n    }\n  }\n}\n\nconst AdaptiveCardChoiceSetInput = ({ input: { choices, defaultValue, label } }) => {\n  const labelId = useUniqueId('webchat__id');\n  const defaultChoice = choices.find(({ value }) => defaultValue === value || (!defaultValue && !value));\n\n  return (\n    <div>\n      <select\n        aria-label={label}\n        aria-labelledby={!label && defaultChoice ? labelId : undefined}\n        defaultValue={defaultValue}\n        tabIndex={-1}\n      >\n        {choices.map(choice => (\n          <option id={!label && choice === defaultChoice ? labelId : undefined} key={choice.value} value={choice.value}>\n            {choice.title}\n          </option>\n        ))}\n      </select>\n    </div>\n  );\n};\n\nAdaptiveCardChoiceSetInput.propTypes = {\n  input: PropTypes.shape({\n    choices: PropTypes.arrayOf(\n      PropTypes.shape({\n        title: PropTypes.string,\n        value: PropTypes.any\n      })\n    ),\n    defaultValue: PropTypes.any,\n    label: PropTypes.string,\n    value: PropTypes.any\n  }).isRequired\n};\n\nconst AdaptiveCardAttachment = ({ content }) => {\n  const localize = useLocalizer();\n  const parseAdaptiveCardJSON = useParseAdaptiveCardJSON();\n  const [\n    {\n      ChoiceSetInput,\n      DateInput,\n      NumberInput,\n      OpenUrlAction,\n      ShowCardAction,\n      SubmitAction,\n      TextInput,\n      TimeInput,\n      ToggleInput\n    }\n  ] = useAdaptiveCardsPackage();\n\n  const card = useMemo(() => parseAdaptiveCardJSON(content, { ignoreErrors: true }), [content, parseAdaptiveCardJSON]);\n  const inputs = useMemo(() => {\n    const inputs = [];\n\n    walkAllItems(card, node => {\n      if (\n        node instanceof ChoiceSetInput ||\n        node instanceof DateInput ||\n        node instanceof NumberInput ||\n        node instanceof OpenUrlAction ||\n        node instanceof ShowCardAction ||\n        node instanceof SubmitAction ||\n        node instanceof TextInput ||\n        node instanceof TimeInput ||\n        node instanceof ToggleInput\n      ) {\n        inputs.push(node);\n      }\n    });\n\n    return inputs;\n  }, [\n    card,\n    ChoiceSetInput,\n    DateInput,\n    NumberInput,\n    OpenUrlAction,\n    ShowCardAction,\n    SubmitAction,\n    TextInput,\n    TimeInput,\n    ToggleInput\n  ]);\n\n  const cardLabel = localize('ATTACHMENT_CARD', card.speak || '', '', '');\n\n  return (\n    <article>\n      <div>{cardLabel}</div>\n      {inputs.map((input, index) =>\n        input instanceof ChoiceSetInput ? (\n          <AdaptiveCardChoiceSetInput input={input} key={index} />\n        ) : input instanceof DateInput ? (\n          <label key={index}>\n            {input.title}\n            <input placeholder={input.placeholder} tabIndex={-1} type=\"date\" />\n          </label>\n        ) : input instanceof NumberInput ? (\n          <label key={index}>\n            {input.title}\n            <input placeholder={input.placeholder} tabIndex={-1} type=\"number\" />\n          </label>\n        ) : input instanceof OpenUrlAction || input instanceof ShowCardAction || input instanceof SubmitAction ? (\n          <div key={index}>\n            <button tabIndex={-1} type=\"button\">\n              {input.title}\n            </button>\n          </div>\n        ) : input instanceof TextInput ? (\n          <label key={index}>\n            {input.title}\n            <input placeholder={input.placeholder} tabIndex={-1} type=\"text\" />\n          </label>\n        ) : input instanceof TimeInput ? (\n          <label key={index}>\n            {input.title}\n            <input placeholder={input.placeholder} tabIndex={-1} type=\"time\" />\n          </label>\n        ) : input instanceof ToggleInput ? (\n          <label key={index}>\n            {input.title}\n            <input defaultChecked={input.value === input.valueOn} tabIndex={-1} type=\"checkbox\" />\n          </label>\n        ) : (\n          false\n        )\n      )}\n    </article>\n  );\n};\n\nAdaptiveCardAttachment.propTypes = {\n  content: PropTypes.any.isRequired\n};\n\nexport default AdaptiveCardAttachment;\n"],"mappings":"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"}
|
|
@@ -52,16 +52,16 @@ function _default(_ref) {
|
|
|
52
52
|
// The following styles are copied from :disabled via Chromium.
|
|
53
53
|
'& .ac-pushButton, & input, & select, & textarea': {
|
|
54
54
|
'&[aria-disabled="true"]': {
|
|
55
|
-
backgroundColor: '
|
|
56
|
-
borderColor: '
|
|
55
|
+
backgroundColor: 'rgba(239, 239, 239, 0.3)',
|
|
56
|
+
borderColor: 'rgba(118, 118, 118, 0.3)',
|
|
57
57
|
borderStyle: 'solid',
|
|
58
58
|
borderWidth: 1,
|
|
59
59
|
color: '#545454'
|
|
60
60
|
}
|
|
61
61
|
},
|
|
62
62
|
'& .ac-pushButton[aria-disabled="true"]': {
|
|
63
|
-
backgroundColor: '#
|
|
64
|
-
color: '#
|
|
63
|
+
backgroundColor: '#EEE',
|
|
64
|
+
color: '#4F4F4F'
|
|
65
65
|
},
|
|
66
66
|
'& .ac-pushButton[aria-pressed="true"]': {
|
|
67
67
|
backgroundColor: cardPushButtonBackgroundColor,
|
|
@@ -74,4 +74,4 @@ function _default(_ref) {
|
|
|
74
74
|
}
|
|
75
75
|
};
|
|
76
76
|
}
|
|
77
|
-
//# sourceMappingURL=data:application/json;charset=utf-8;base64,
|
|
77
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJjYXJkUHVzaEJ1dHRvbkJhY2tncm91bmRDb2xvciIsImNhcmRQdXNoQnV0dG9uVGV4dENvbG9yIiwiYWNjZW50IiwicGFkZGluZ1JlZ3VsYXIiLCJwcmltYXJ5Rm9udCIsImJveFNpemluZyIsImZvbnRGYW1pbHkiLCJwYWRkaW5nIiwiYXBwZWFyYW5jZSIsImJhY2tncm91bmRDb2xvciIsImJvcmRlclN0eWxlIiwiYm9yZGVyV2lkdGgiLCJjb2xvciIsImZvbnRXZWlnaHQiLCJib3JkZXJDb2xvciJdLCJzb3VyY2VSb290IjoiYnVuZGxlOi8vLyIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vc3JjL2FkYXB0aXZlQ2FyZHMvU3R5bGVzL1N0eWxlU2V0L0FkYXB0aXZlQ2FyZFJlbmRlcmVyLnRzIl0sInNvdXJjZXNDb250ZW50IjpbImltcG9ydCBGdWxsQnVuZGxlU3R5bGVPcHRpb25zIGZyb20gJy4uLy4uLy4uL3R5cGVzL0Z1bGxCdW5kbGVTdHlsZU9wdGlvbnMnO1xuXG5leHBvcnQgZGVmYXVsdCBmdW5jdGlvbiAoe1xuICBjYXJkUHVzaEJ1dHRvbkJhY2tncm91bmRDb2xvcixcbiAgY2FyZFB1c2hCdXR0b25UZXh0Q29sb3IsXG4gIGFjY2VudCxcbiAgcGFkZGluZ1JlZ3VsYXIsXG4gIHByaW1hcnlGb250XG59OiBGdWxsQnVuZGxlU3R5bGVPcHRpb25zKSB7XG4gIHJldHVybiB7XG4gICAgJyYud2ViY2hhdF9fYWRhcHRpdmUtY2FyZC1yZW5kZXJlcic6IHtcbiAgICAgIC8vIFJlbGF0ZWQgdG8gIzQwNzUuXG4gICAgICAvLyBBZGFwdGl2ZSBDYXJkcyBhc3N1bWUgaXRzIGhvc3QgaXMgaW4gXCJmb3JjZWQgYm9yZGVyLWJveFwiIG1vZGUuXG4gICAgICAvLyBJbiBDU1MsIHRoZSBkZWZhdWx0IGlzIFwiY29udGVudC1ib3hcIiBtb2RlLlxuICAgICAgLy8gaHR0cHM6Ly9kZXZlbG9wZXIubW96aWxsYS5vcmcvZW4tVVMvZG9jcy9XZWIvQ1NTL2JveC1zaXppbmcjdmFsdWVzXG4gICAgICAnJiAqJzoge1xuICAgICAgICBib3hTaXppbmc6ICdib3JkZXItYm94J1xuICAgICAgfSxcblxuICAgICAgJyYgLmFjLWlucHV0LCAmIC5hYy1pbmxpbmVBY3Rpb25CdXR0b24sICYgLmFjLXF1aWNrQWN0aW9uQnV0dG9uJzoge1xuICAgICAgICBmb250RmFtaWx5OiBwcmltYXJ5Rm9udFxuICAgICAgfSxcblxuICAgICAgJyYgLmFjLW11bHRpY2hvaWNlSW5wdXQnOiB7XG4gICAgICAgIHBhZGRpbmc6IHBhZGRpbmdSZWd1bGFyXG4gICAgICB9LFxuXG4gICAgICAnJiAuYWMtcHVzaEJ1dHRvbic6IHtcbiAgICAgICAgYXBwZWFyYW5jZTogJ25vbmUnLFxuICAgICAgICBiYWNrZ3JvdW5kQ29sb3I6ICdXaGl0ZScsXG4gICAgICAgIGJvcmRlclN0eWxlOiAnc29saWQnLFxuICAgICAgICBib3JkZXJXaWR0aDogMSxcbiAgICAgICAgY29sb3I6IGFjY2VudCxcbiAgICAgICAgZm9udFdlaWdodDogNjAwLFxuICAgICAgICBwYWRkaW5nOiBwYWRkaW5nUmVndWxhclxuICAgICAgfSxcblxuICAgICAgJyYgLmFjLXB1c2hCdXR0b24uc3R5bGUtZGVzdHJ1Y3RpdmUnOiB7XG4gICAgICAgIGJhY2tncm91bmRDb2xvcjogJyNFNTAwMDAnLFxuICAgICAgICBjb2xvcjogJ3doaXRlJ1xuICAgICAgfSxcblxuICAgICAgJyYgLmFjLXB1c2hCdXR0b24uc3R5bGUtZGVzdHJ1Y3RpdmU6aG92ZXIsICYgLmFjLXB1c2hCdXR0b24uc3R5bGUtZGVzdHJ1Y3RpdmU6YWN0aXZlJzoge1xuICAgICAgICBiYWNrZ3JvdW5kQ29sb3I6ICcjQkYwMDAwJ1xuICAgICAgfSxcblxuICAgICAgJyYgLmFjLXB1c2hCdXR0b24uc3R5bGUtcG9zaXRpdmUnOiB7XG4gICAgICAgIGJhY2tncm91bmRDb2xvcjogJyMwMDc4RDcnLFxuICAgICAgICBjb2xvcjogJ3doaXRlJ1xuICAgICAgfSxcblxuICAgICAgJyYgLmFjLXB1c2hCdXR0b24uc3R5bGUtcG9zaXRpdmU6aG92ZXIsICYgLmFjLXB1c2hCdXR0b24uc3R5bGUtcG9zaXRpdmU6YWN0aXZlJzoge1xuICAgICAgICBiYWNrZ3JvdW5kQ29sb3I6ICcjMDA2QUJDJ1xuICAgICAgfSxcblxuICAgICAgLy8gVGhlIGZvbGxvd2luZyBzdHlsZXMgYXJlIGNvcGllZCBmcm9tIDpkaXNhYmxlZCB2aWEgQ2hyb21pdW0uXG5cbiAgICAgICcmIC5hYy1wdXNoQnV0dG9uLCAmIGlucHV0LCAmIHNlbGVjdCwgJiB0ZXh0YXJlYSc6IHtcbiAgICAgICAgJyZbYXJpYS1kaXNhYmxlZD1cInRydWVcIl0nOiB7XG4gICAgICAgICAgYmFja2dyb3VuZENvbG9yOiAncmdiYSgyMzksIDIzOSwgMjM5LCAwLjMpJyxcbiAgICAgICAgICBib3JkZXJDb2xvcjogJ3JnYmEoMTE4LCAxMTgsIDExOCwgMC4zKScsXG4gICAgICAgICAgYm9yZGVyU3R5bGU6ICdzb2xpZCcsXG4gICAgICAgICAgYm9yZGVyV2lkdGg6IDEsXG4gICAgICAgICAgY29sb3I6ICcjNTQ1NDU0J1xuICAgICAgICB9XG4gICAgICB9LFxuXG4gICAgICAnJiAuYWMtcHVzaEJ1dHRvblthcmlhLWRpc2FibGVkPVwidHJ1ZVwiXSc6IHtcbiAgICAgICAgYmFja2dyb3VuZENvbG9yOiAnI0VFRScsXG4gICAgICAgIGNvbG9yOiAnIzRGNEY0RidcbiAgICAgIH0sXG5cbiAgICAgICcmIC5hYy1wdXNoQnV0dG9uW2FyaWEtcHJlc3NlZD1cInRydWVcIl0nOiB7XG4gICAgICAgIGJhY2tncm91bmRDb2xvcjogY2FyZFB1c2hCdXR0b25CYWNrZ3JvdW5kQ29sb3IsXG4gICAgICAgIGJvcmRlckNvbG9yOiBjYXJkUHVzaEJ1dHRvbkJhY2tncm91bmRDb2xvcixcbiAgICAgICAgY29sb3I6IGNhcmRQdXNoQnV0dG9uVGV4dENvbG9yXG4gICAgICB9LFxuXG4gICAgICAnJiBpbnB1dFthcmlhLWRpc2FibGVkPVwidHJ1ZVwiXSc6IHtcbiAgICAgICAgcGFkZGluZzogJzJweCAxcHgnXG4gICAgICB9XG4gICAgfVxuICB9O1xufVxuIl0sIm1hcHBpbmdzIjoiOzs7Ozs7O0FBRWUsd0JBTVk7RUFBQSxJQUx6QkEsNkJBS3lCLFFBTHpCQSw2QkFLeUI7RUFBQSxJQUp6QkMsdUJBSXlCLFFBSnpCQSx1QkFJeUI7RUFBQSxJQUh6QkMsTUFHeUIsUUFIekJBLE1BR3lCO0VBQUEsSUFGekJDLGNBRXlCLFFBRnpCQSxjQUV5QjtFQUFBLElBRHpCQyxXQUN5QixRQUR6QkEsV0FDeUI7RUFDekIsT0FBTztJQUNMLHFDQUFxQztNQUNuQztNQUNBO01BQ0E7TUFDQTtNQUNBLE9BQU87UUFDTEMsU0FBUyxFQUFFO01BRE4sQ0FMNEI7TUFTbkMsa0VBQWtFO1FBQ2hFQyxVQUFVLEVBQUVGO01BRG9ELENBVC9CO01BYW5DLDBCQUEwQjtRQUN4QkcsT0FBTyxFQUFFSjtNQURlLENBYlM7TUFpQm5DLG9CQUFvQjtRQUNsQkssVUFBVSxFQUFFLE1BRE07UUFFbEJDLGVBQWUsRUFBRSxPQUZDO1FBR2xCQyxXQUFXLEVBQUUsT0FISztRQUlsQkMsV0FBVyxFQUFFLENBSks7UUFLbEJDLEtBQUssRUFBRVYsTUFMVztRQU1sQlcsVUFBVSxFQUFFLEdBTk07UUFPbEJOLE9BQU8sRUFBRUo7TUFQUyxDQWpCZTtNQTJCbkMsc0NBQXNDO1FBQ3BDTSxlQUFlLEVBQUUsU0FEbUI7UUFFcENHLEtBQUssRUFBRTtNQUY2QixDQTNCSDtNQWdDbkMsdUZBQXVGO1FBQ3JGSCxlQUFlLEVBQUU7TUFEb0UsQ0FoQ3BEO01Bb0NuQyxtQ0FBbUM7UUFDakNBLGVBQWUsRUFBRSxTQURnQjtRQUVqQ0csS0FBSyxFQUFFO01BRjBCLENBcENBO01BeUNuQyxpRkFBaUY7UUFDL0VILGVBQWUsRUFBRTtNQUQ4RCxDQXpDOUM7TUE2Q25DO01BRUEsbURBQW1EO1FBQ2pELDJCQUEyQjtVQUN6QkEsZUFBZSxFQUFFLDBCQURRO1VBRXpCSyxXQUFXLEVBQUUsMEJBRlk7VUFHekJKLFdBQVcsRUFBRSxPQUhZO1VBSXpCQyxXQUFXLEVBQUUsQ0FKWTtVQUt6QkMsS0FBSyxFQUFFO1FBTGtCO01BRHNCLENBL0NoQjtNQXlEbkMsMENBQTBDO1FBQ3hDSCxlQUFlLEVBQUUsTUFEdUI7UUFFeENHLEtBQUssRUFBRTtNQUZpQyxDQXpEUDtNQThEbkMseUNBQXlDO1FBQ3ZDSCxlQUFlLEVBQUVULDZCQURzQjtRQUV2Q2MsV0FBVyxFQUFFZCw2QkFGMEI7UUFHdkNZLEtBQUssRUFBRVg7TUFIZ0MsQ0E5RE47TUFvRW5DLGlDQUFpQztRQUMvQk0sT0FBTyxFQUFFO01BRHNCO0lBcEVFO0VBRGhDLENBQVA7QUEwRUQifQ==
|
|
@@ -6,11 +6,11 @@ Object.defineProperty(exports, "__esModule", {
|
|
|
6
6
|
exports.default = void 0;
|
|
7
7
|
var ADAPTIVE_CARDS_DEFAULT_STYLE_OPTIONS = {
|
|
8
8
|
adaptiveCardsParserMaxVersion: undefined,
|
|
9
|
-
cardEmphasisBackgroundColor: '#
|
|
9
|
+
cardEmphasisBackgroundColor: '#F9F9F9',
|
|
10
10
|
cardPushButtonBackgroundColor: '#0063B1',
|
|
11
11
|
cardPushButtonTextColor: 'White',
|
|
12
12
|
richCardWrapTitle: false
|
|
13
13
|
};
|
|
14
14
|
var _default = ADAPTIVE_CARDS_DEFAULT_STYLE_OPTIONS;
|
|
15
15
|
exports.default = _default;
|
|
16
|
-
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJBREFQVElWRV9DQVJEU19ERUZBVUxUX1NUWUxFX09QVElPTlMiLCJhZGFwdGl2ZUNhcmRzUGFyc2VyTWF4VmVyc2lvbiIsInVuZGVmaW5lZCIsImNhcmRFbXBoYXNpc0JhY2tncm91bmRDb2xvciIsImNhcmRQdXNoQnV0dG9uQmFja2dyb3VuZENvbG9yIiwiY2FyZFB1c2hCdXR0b25UZXh0Q29sb3IiLCJyaWNoQ2FyZFdyYXBUaXRsZSJdLCJzb3VyY2VSb290IjoiYnVuZGxlOi8vLyIsInNvdXJjZXMiOlsiLi4vLi4vc3JjL2FkYXB0aXZlQ2FyZHMvZGVmYXVsdFN0eWxlT3B0aW9ucy50cyJdLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgQWRhcHRpdmVDYXJkc1N0eWxlT3B0aW9ucyBmcm9tICcuL0FkYXB0aXZlQ2FyZHNTdHlsZU9wdGlvbnMnO1xuXG5jb25zdCBBREFQVElWRV9DQVJEU19ERUZBVUxUX1NUWUxFX09QVElPTlM6IFJlcXVpcmVkPEFkYXB0aXZlQ2FyZHNTdHlsZU9wdGlvbnM+
|
|
16
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJBREFQVElWRV9DQVJEU19ERUZBVUxUX1NUWUxFX09QVElPTlMiLCJhZGFwdGl2ZUNhcmRzUGFyc2VyTWF4VmVyc2lvbiIsInVuZGVmaW5lZCIsImNhcmRFbXBoYXNpc0JhY2tncm91bmRDb2xvciIsImNhcmRQdXNoQnV0dG9uQmFja2dyb3VuZENvbG9yIiwiY2FyZFB1c2hCdXR0b25UZXh0Q29sb3IiLCJyaWNoQ2FyZFdyYXBUaXRsZSJdLCJzb3VyY2VSb290IjoiYnVuZGxlOi8vLyIsInNvdXJjZXMiOlsiLi4vLi4vc3JjL2FkYXB0aXZlQ2FyZHMvZGVmYXVsdFN0eWxlT3B0aW9ucy50cyJdLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgQWRhcHRpdmVDYXJkc1N0eWxlT3B0aW9ucyBmcm9tICcuL0FkYXB0aXZlQ2FyZHNTdHlsZU9wdGlvbnMnO1xuXG5jb25zdCBBREFQVElWRV9DQVJEU19ERUZBVUxUX1NUWUxFX09QVElPTlM6IFJlcXVpcmVkPEFkYXB0aXZlQ2FyZHNTdHlsZU9wdGlvbnM+ID0ge1xuICBhZGFwdGl2ZUNhcmRzUGFyc2VyTWF4VmVyc2lvbjogdW5kZWZpbmVkLFxuICBjYXJkRW1waGFzaXNCYWNrZ3JvdW5kQ29sb3I6ICcjRjlGOUY5JyxcbiAgY2FyZFB1c2hCdXR0b25CYWNrZ3JvdW5kQ29sb3I6ICcjMDA2M0IxJyxcbiAgY2FyZFB1c2hCdXR0b25UZXh0Q29sb3I6ICdXaGl0ZScsXG4gIHJpY2hDYXJkV3JhcFRpdGxlOiBmYWxzZVxufTtcblxuZXhwb3J0IGRlZmF1bHQgQURBUFRJVkVfQ0FSRFNfREVGQVVMVF9TVFlMRV9PUFRJT05TO1xuIl0sIm1hcHBpbmdzIjoiOzs7Ozs7QUFFQSxJQUFNQSxvQ0FBeUUsR0FBRztFQUNoRkMsNkJBQTZCLEVBQUVDLFNBRGlEO0VBRWhGQywyQkFBMkIsRUFBRSxTQUZtRDtFQUdoRkMsNkJBQTZCLEVBQUUsU0FIaUQ7RUFJaEZDLHVCQUF1QixFQUFFLE9BSnVEO0VBS2hGQyxpQkFBaUIsRUFBRTtBQUw2RCxDQUFsRjtlQVFlTixvQyJ9
|
package/lib/addVersion.js
CHANGED
|
@@ -28,7 +28,7 @@ function setMetaTag(name, content) {
|
|
|
28
28
|
|
|
29
29
|
function addVersion(variant) {
|
|
30
30
|
setMetaTag('botframework-webchat:bundle:variant', variant);
|
|
31
|
-
setMetaTag('botframework-webchat:bundle:version', "4.15.8-main.
|
|
31
|
+
setMetaTag('botframework-webchat:bundle:version', "4.15.8-main.20230412.960a5a5");
|
|
32
32
|
setMetaTag('botframework-webchat:core:version', _botframeworkWebchatCore.version);
|
|
33
33
|
setMetaTag('botframework-webchat:ui:version', _botframeworkWebchatComponent.version);
|
|
34
34
|
}
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "botframework-webchat",
|
|
3
|
-
"version": "4.15.8-main.
|
|
3
|
+
"version": "4.15.8-main.20230412.960a5a5",
|
|
4
4
|
"description": "A highly-customizable web-based chat client for Azure Bot Services.",
|
|
5
5
|
"main": "lib/index.js",
|
|
6
6
|
"typings": "lib/index.d.ts",
|
|
@@ -92,10 +92,10 @@
|
|
|
92
92
|
"@babel/runtime": "7.19.0",
|
|
93
93
|
"adaptivecards": "2.11.1",
|
|
94
94
|
"botframework-directlinejs": "0.15.1",
|
|
95
|
-
"botframework-directlinespeech-sdk": "4.15.8-main.
|
|
96
|
-
"botframework-webchat-api": "4.15.8-main.
|
|
97
|
-
"botframework-webchat-component": "4.15.8-main.
|
|
98
|
-
"botframework-webchat-core": "4.15.8-main.
|
|
95
|
+
"botframework-directlinespeech-sdk": "4.15.8-main.20230412.960a5a5",
|
|
96
|
+
"botframework-webchat-api": "4.15.8-main.20230412.960a5a5",
|
|
97
|
+
"botframework-webchat-component": "4.15.8-main.20230412.960a5a5",
|
|
98
|
+
"botframework-webchat-core": "4.15.8-main.20230412.960a5a5",
|
|
99
99
|
"classnames": "2.3.2",
|
|
100
100
|
"core-js": "3.28.0",
|
|
101
101
|
"markdown-it": "13.0.1",
|
|
@@ -126,8 +126,8 @@
|
|
|
126
126
|
"babel-plugin-transform-inline-environment-variables": "^0.4.4",
|
|
127
127
|
"concurrently": "^7.6.0",
|
|
128
128
|
"esbuild": "^0.17.10",
|
|
129
|
-
"isomorphic-react": "4.15.8-main.
|
|
130
|
-
"isomorphic-react-dom": "4.15.8-main.
|
|
129
|
+
"isomorphic-react": "4.15.8-main.20230412.960a5a5",
|
|
130
|
+
"isomorphic-react-dom": "4.15.8-main.20230412.960a5a5",
|
|
131
131
|
"source-map-loader": "^4.0.1",
|
|
132
132
|
"terser-webpack-plugin": "^5.3.6",
|
|
133
133
|
"typescript": "^4.9.5",
|
|
@@ -0,0 +1,52 @@
|
|
|
1
|
+
import { useMemo } from 'react';
|
|
2
|
+
|
|
3
|
+
import setOrRemoveAttributeIfFalseWithUndo from '../../DOMManipulationWithUndo/setOrRemoveAttributeIfFalseWithUndo';
|
|
4
|
+
import useAdaptiveCardModEffect from './private/useAdaptiveCardModEffect';
|
|
5
|
+
|
|
6
|
+
import type { AdaptiveCard } from 'adaptivecards';
|
|
7
|
+
|
|
8
|
+
/**
|
|
9
|
+
* Accessibility: "role" attribute must be set if "aria-label" is set.
|
|
10
|
+
*
|
|
11
|
+
* It is possible to render an Adaptive Card with empty content but "aria-label" attribute. The Adaptive Cards JSON looks like:
|
|
12
|
+
*
|
|
13
|
+
* ```json
|
|
14
|
+
* {
|
|
15
|
+
* "type": "AdaptiveCard",
|
|
16
|
+
* "speak": "Hello, World!",
|
|
17
|
+
* "body": [],
|
|
18
|
+
* "$schema": "http://adaptivecards.io/schemas/adaptive-card.json",
|
|
19
|
+
* "version": "1.5"
|
|
20
|
+
* }
|
|
21
|
+
* ```
|
|
22
|
+
*
|
|
23
|
+
* The HTML output will be:
|
|
24
|
+
*
|
|
25
|
+
* ```html
|
|
26
|
+
* <div class="ac-adaptiveCard" aria-label="Hello, World!"></div>
|
|
27
|
+
* ```
|
|
28
|
+
*
|
|
29
|
+
* This violates WAI-ARIA because "aria-label" must not be set on an element without a "role".
|
|
30
|
+
*
|
|
31
|
+
* We need to set "role" attribute to "form" if the card has any input fields and is valid as a "form" role, otherwise, "figure".
|
|
32
|
+
*/
|
|
33
|
+
export default function useRoleModEffect(
|
|
34
|
+
adaptiveCard: AdaptiveCard
|
|
35
|
+
): readonly [(cardElement: HTMLElement) => void, () => void] {
|
|
36
|
+
const modder = useMemo(
|
|
37
|
+
() => (_, cardElement: HTMLElement) =>
|
|
38
|
+
setOrRemoveAttributeIfFalseWithUndo(
|
|
39
|
+
cardElement,
|
|
40
|
+
'role',
|
|
41
|
+
// "form" role requires either "aria-label", "aria-labelledby", or "title".
|
|
42
|
+
(cardElement.querySelector('button, input, select, textarea') && cardElement.getAttribute('aria-label')) ||
|
|
43
|
+
cardElement.getAttribute('aria-labelledby') ||
|
|
44
|
+
cardElement.getAttribute('title')
|
|
45
|
+
? 'form'
|
|
46
|
+
: 'figure'
|
|
47
|
+
),
|
|
48
|
+
[]
|
|
49
|
+
);
|
|
50
|
+
|
|
51
|
+
return useAdaptiveCardModEffect(modder, adaptiveCard);
|
|
52
|
+
}
|
|
@@ -24,6 +24,7 @@ import useAdaptiveCardsHostConfig from '../hooks/useAdaptiveCardsHostConfig';
|
|
|
24
24
|
import useAdaptiveCardsPackage from '../hooks/useAdaptiveCardsPackage';
|
|
25
25
|
import useDisabledModEffect from './AdaptiveCardHacks/useDisabledModEffect';
|
|
26
26
|
import usePersistValuesModEffect from './AdaptiveCardHacks/usePersistValuesModEffect';
|
|
27
|
+
import useRoleModEffect from './AdaptiveCardHacks/useRoleModEffect';
|
|
27
28
|
import useValueRef from './AdaptiveCardHacks/private/useValueRef';
|
|
28
29
|
|
|
29
30
|
const { ErrorBox } = Components;
|
|
@@ -172,6 +173,7 @@ const AdaptiveCardRenderer: VFC<AdaptiveCardRendererProps> = ({
|
|
|
172
173
|
const [applyActiveElementMod, undoActiveElementMod] = useActiveElementModEffect(adaptiveCard);
|
|
173
174
|
const [applyDisabledMod, undoDisabledMod] = useDisabledModEffect(adaptiveCard);
|
|
174
175
|
const [applyPersistValuesMod, undoPersistValuesMod] = usePersistValuesModEffect(adaptiveCard);
|
|
176
|
+
const [applyRoleMod, undoRoleMod] = useRoleModEffect(adaptiveCard);
|
|
175
177
|
|
|
176
178
|
const { element, errors }: { element?: HTMLElement; errors?: Error[] } = useMemo(() => {
|
|
177
179
|
undoActionShouldBePushButtonMod();
|
|
@@ -179,6 +181,7 @@ const AdaptiveCardRenderer: VFC<AdaptiveCardRendererProps> = ({
|
|
|
179
181
|
undoActiveElementMod();
|
|
180
182
|
undoDisabledMod();
|
|
181
183
|
undoPersistValuesMod();
|
|
184
|
+
undoRoleMod();
|
|
182
185
|
|
|
183
186
|
return renderAdaptiveCard(adaptiveCard, {
|
|
184
187
|
adaptiveCardsHostConfig,
|
|
@@ -197,7 +200,8 @@ const AdaptiveCardRenderer: VFC<AdaptiveCardRendererProps> = ({
|
|
|
197
200
|
undoActionSetShouldNotBeMenuBarMod,
|
|
198
201
|
undoActiveElementMod,
|
|
199
202
|
undoDisabledMod,
|
|
200
|
-
undoPersistValuesMod
|
|
203
|
+
undoPersistValuesMod,
|
|
204
|
+
undoRoleMod
|
|
201
205
|
]);
|
|
202
206
|
|
|
203
207
|
useMemo(() => {
|
|
@@ -222,6 +226,7 @@ const AdaptiveCardRenderer: VFC<AdaptiveCardRendererProps> = ({
|
|
|
222
226
|
applyActiveElementMod(element);
|
|
223
227
|
applyDisabledMod(element, disabled);
|
|
224
228
|
applyPersistValuesMod(element);
|
|
229
|
+
applyRoleMod(element);
|
|
225
230
|
}, [
|
|
226
231
|
actionPerformedClassName,
|
|
227
232
|
applyActionShouldBePushButtonMod,
|
|
@@ -229,6 +234,7 @@ const AdaptiveCardRenderer: VFC<AdaptiveCardRendererProps> = ({
|
|
|
229
234
|
applyActiveElementMod,
|
|
230
235
|
applyDisabledMod,
|
|
231
236
|
applyPersistValuesMod,
|
|
237
|
+
applyRoleMod,
|
|
232
238
|
disabled,
|
|
233
239
|
element
|
|
234
240
|
]);
|