botframework-webchat 4.15.3-main.20220706.75d867c → 4.15.3-main.20220728.008aa26
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/private/closest.d.ts +2 -0
- package/lib/adaptiveCards/Attachment/AdaptiveCardHacks/private/closest.d.ts.map +1 -0
- package/lib/adaptiveCards/Attachment/AdaptiveCardHacks/private/closest.js +25 -0
- package/lib/adaptiveCards/Attachment/AdaptiveCardHacks/private/findDOMNodeOwner.d.ts +3 -0
- package/lib/adaptiveCards/Attachment/AdaptiveCardHacks/private/findDOMNodeOwner.d.ts.map +1 -0
- package/lib/adaptiveCards/Attachment/AdaptiveCardHacks/private/findDOMNodeOwner.js +32 -0
- package/lib/adaptiveCards/Attachment/AdaptiveCardHacks/private/useAdaptiveCardModEffect.d.ts +13 -0
- package/lib/adaptiveCards/Attachment/AdaptiveCardHacks/private/useAdaptiveCardModEffect.d.ts.map +1 -0
- package/lib/adaptiveCards/Attachment/AdaptiveCardHacks/private/useAdaptiveCardModEffect.js +132 -0
- package/lib/adaptiveCards/Attachment/AdaptiveCardHacks/private/useLazyRef.d.ts +3 -0
- package/lib/adaptiveCards/Attachment/AdaptiveCardHacks/private/useLazyRef.d.ts.map +1 -0
- package/lib/adaptiveCards/Attachment/AdaptiveCardHacks/private/useLazyRef.js +21 -0
- package/lib/adaptiveCards/Attachment/AdaptiveCardHacks/private/usePrevious.d.ts +2 -0
- package/lib/adaptiveCards/Attachment/AdaptiveCardHacks/private/usePrevious.d.ts.map +1 -0
- package/lib/adaptiveCards/Attachment/AdaptiveCardHacks/private/usePrevious.js +18 -0
- package/lib/adaptiveCards/Attachment/AdaptiveCardHacks/private/useValueRef.d.ts +3 -0
- package/lib/adaptiveCards/Attachment/AdaptiveCardHacks/private/useValueRef.d.ts.map +1 -0
- package/lib/adaptiveCards/Attachment/AdaptiveCardHacks/private/useValueRef.js +15 -0
- package/lib/adaptiveCards/Attachment/AdaptiveCardHacks/useActionSetShouldNotBeMenuBarModEffect.d.ts +16 -0
- package/lib/adaptiveCards/Attachment/AdaptiveCardHacks/useActionSetShouldNotBeMenuBarModEffect.d.ts.map +1 -0
- package/lib/adaptiveCards/Attachment/AdaptiveCardHacks/useActionSetShouldNotBeMenuBarModEffect.js +45 -0
- package/lib/adaptiveCards/Attachment/AdaptiveCardHacks/useActionShouldBePushButtonModEffect.d.ts +15 -0
- package/lib/adaptiveCards/Attachment/AdaptiveCardHacks/useActionShouldBePushButtonModEffect.d.ts.map +1 -0
- package/lib/adaptiveCards/Attachment/AdaptiveCardHacks/useActionShouldBePushButtonModEffect.js +93 -0
- package/lib/adaptiveCards/Attachment/AdaptiveCardHacks/useActiveElementModEffect.d.ts +6 -0
- package/lib/adaptiveCards/Attachment/AdaptiveCardHacks/useActiveElementModEffect.d.ts.map +1 -0
- package/lib/adaptiveCards/Attachment/AdaptiveCardHacks/useActiveElementModEffect.js +44 -0
- package/lib/adaptiveCards/Attachment/AdaptiveCardHacks/useDisabledModEffect.d.ts +9 -0
- package/lib/adaptiveCards/Attachment/AdaptiveCardHacks/useDisabledModEffect.d.ts.map +1 -0
- package/lib/adaptiveCards/Attachment/AdaptiveCardHacks/useDisabledModEffect.js +50 -0
- package/lib/adaptiveCards/Attachment/AdaptiveCardHacks/usePersistValuesModEffect.d.ts +6 -0
- package/lib/adaptiveCards/Attachment/AdaptiveCardHacks/usePersistValuesModEffect.d.ts.map +1 -0
- package/lib/adaptiveCards/Attachment/AdaptiveCardHacks/usePersistValuesModEffect.js +103 -0
- package/lib/adaptiveCards/Attachment/AdaptiveCardRenderer.d.ts.map +1 -1
- package/lib/adaptiveCards/Attachment/AdaptiveCardRenderer.js +97 -557
- package/lib/adaptiveCards/Attachment/private/renderAdaptiveCard.d.ts +15 -0
- package/lib/adaptiveCards/Attachment/private/renderAdaptiveCard.d.ts.map +1 -0
- package/lib/adaptiveCards/Attachment/private/renderAdaptiveCard.js +79 -0
- package/lib/adaptiveCards/DOMManipulationWithUndo/addEventListenerWithUndo.d.ts +6 -0
- package/lib/adaptiveCards/DOMManipulationWithUndo/addEventListenerWithUndo.d.ts.map +1 -0
- package/lib/adaptiveCards/DOMManipulationWithUndo/addEventListenerWithUndo.js +25 -0
- package/lib/adaptiveCards/DOMManipulationWithUndo/bunchUndos.d.ts +3 -0
- package/lib/adaptiveCards/DOMManipulationWithUndo/bunchUndos.d.ts.map +1 -0
- package/lib/adaptiveCards/DOMManipulationWithUndo/bunchUndos.js +23 -0
- package/lib/adaptiveCards/DOMManipulationWithUndo/durableAddClassWithUndo.d.ts +8 -0
- package/lib/adaptiveCards/DOMManipulationWithUndo/durableAddClassWithUndo.d.ts.map +1 -0
- package/lib/adaptiveCards/DOMManipulationWithUndo/durableAddClassWithUndo.js +38 -0
- package/lib/adaptiveCards/DOMManipulationWithUndo/durableDisableInputElementAccessiblyWithUndo.d.ts +22 -0
- package/lib/adaptiveCards/DOMManipulationWithUndo/durableDisableInputElementAccessiblyWithUndo.d.ts.map +1 -0
- package/lib/adaptiveCards/DOMManipulationWithUndo/durableDisableInputElementAccessiblyWithUndo.js +96 -0
- package/lib/adaptiveCards/DOMManipulationWithUndo/private/addClass.d.ts +5 -0
- package/lib/adaptiveCards/DOMManipulationWithUndo/private/addClass.d.ts.map +1 -0
- package/lib/adaptiveCards/DOMManipulationWithUndo/private/addClass.js +19 -0
- package/lib/adaptiveCards/DOMManipulationWithUndo/private/getAttributeOrFalse.d.ts +7 -0
- package/lib/adaptiveCards/DOMManipulationWithUndo/private/getAttributeOrFalse.d.ts.map +1 -0
- package/lib/adaptiveCards/DOMManipulationWithUndo/private/getAttributeOrFalse.js +16 -0
- package/lib/adaptiveCards/DOMManipulationWithUndo/private/noOp.d.ts +3 -0
- package/lib/adaptiveCards/DOMManipulationWithUndo/private/noOp.d.ts.map +1 -0
- package/lib/adaptiveCards/DOMManipulationWithUndo/private/noOp.js +14 -0
- package/lib/adaptiveCards/DOMManipulationWithUndo/private/setOrRemoveAttributeIfFalse.d.ts +9 -0
- package/lib/adaptiveCards/DOMManipulationWithUndo/private/setOrRemoveAttributeIfFalse.d.ts.map +1 -0
- package/lib/adaptiveCards/DOMManipulationWithUndo/private/setOrRemoveAttributeIfFalse.js +22 -0
- package/lib/adaptiveCards/DOMManipulationWithUndo/setOrRemoveAttributeIfFalseWithUndo.d.ts +12 -0
- package/lib/adaptiveCards/DOMManipulationWithUndo/setOrRemoveAttributeIfFalseWithUndo.d.ts.map +1 -0
- package/lib/adaptiveCards/DOMManipulationWithUndo/setOrRemoveAttributeIfFalseWithUndo.js +41 -0
- package/lib/adaptiveCards/DOMManipulationWithUndo/types/UndoFunction.d.ts +3 -0
- package/lib/adaptiveCards/DOMManipulationWithUndo/types/UndoFunction.d.ts.map +1 -0
- package/lib/adaptiveCards/DOMManipulationWithUndo/types/UndoFunction.js +2 -0
- package/lib/addVersion.js +1 -1
- package/lib/createFullStyleSet.d.ts +2 -2
- package/package.json +7 -7
- package/src/adaptiveCards/Attachment/AdaptiveCardHacks/private/closest.ts +17 -0
- package/src/adaptiveCards/Attachment/AdaptiveCardHacks/private/findDOMNodeOwner.ts +25 -0
- package/src/adaptiveCards/Attachment/AdaptiveCardHacks/private/useAdaptiveCardModEffect.ts +93 -0
- package/src/adaptiveCards/Attachment/AdaptiveCardHacks/private/useLazyRef.ts +15 -0
- package/src/adaptiveCards/Attachment/AdaptiveCardHacks/private/usePrevious.ts +12 -0
- package/src/adaptiveCards/Attachment/AdaptiveCardHacks/private/useValueRef.ts +11 -0
- package/src/adaptiveCards/Attachment/AdaptiveCardHacks/useActionSetShouldNotBeMenuBarModEffect.ts +39 -0
- package/src/adaptiveCards/Attachment/AdaptiveCardHacks/useActionShouldBePushButtonModEffect.ts +105 -0
- package/src/adaptiveCards/Attachment/AdaptiveCardHacks/useActiveElementModEffect.ts +35 -0
- package/src/adaptiveCards/Attachment/AdaptiveCardHacks/useDisabledModEffect.ts +45 -0
- package/src/adaptiveCards/Attachment/AdaptiveCardHacks/usePersistValuesModEffect.ts +110 -0
- package/src/adaptiveCards/Attachment/AdaptiveCardRenderer.tsx +83 -582
- package/src/adaptiveCards/Attachment/private/renderAdaptiveCard.ts +75 -0
- package/src/adaptiveCards/DOMManipulationWithUndo/addEventListenerWithUndo.ts +21 -0
- package/src/adaptiveCards/DOMManipulationWithUndo/bunchUndos.tsx +12 -0
- package/src/adaptiveCards/DOMManipulationWithUndo/durableAddClassWithUndo.ts +28 -0
- package/src/adaptiveCards/DOMManipulationWithUndo/durableDisableInputElementAccessiblyWithUndo.ts +84 -0
- package/src/adaptiveCards/DOMManipulationWithUndo/private/addClass.tsx +13 -0
- package/src/adaptiveCards/DOMManipulationWithUndo/private/getAttributeOrFalse.ts +8 -0
- package/src/adaptiveCards/DOMManipulationWithUndo/private/noOp.ts +5 -0
- package/src/adaptiveCards/DOMManipulationWithUndo/private/setOrRemoveAttributeIfFalse.ts +18 -0
- package/src/adaptiveCards/DOMManipulationWithUndo/setOrRemoveAttributeIfFalseWithUndo.ts +34 -0
- package/src/adaptiveCards/DOMManipulationWithUndo/types/UndoFunction.ts +3 -0
|
@@ -11,8 +11,6 @@ exports.default = void 0;
|
|
|
11
11
|
|
|
12
12
|
var _slicedToArray2 = _interopRequireDefault(require("@babel/runtime/helpers/slicedToArray"));
|
|
13
13
|
|
|
14
|
-
var _toConsumableArray2 = _interopRequireDefault(require("@babel/runtime/helpers/toConsumableArray"));
|
|
15
|
-
|
|
16
14
|
var _botframeworkWebchatComponent = require("botframework-webchat-component");
|
|
17
15
|
|
|
18
16
|
var _classnames = _interopRequireDefault(require("classnames"));
|
|
@@ -21,10 +19,24 @@ var _propTypes = _interopRequireDefault(require("prop-types"));
|
|
|
21
19
|
|
|
22
20
|
var _react = _interopRequireWildcard(require("react"));
|
|
23
21
|
|
|
22
|
+
var _renderAdaptiveCard = _interopRequireDefault(require("./private/renderAdaptiveCard"));
|
|
23
|
+
|
|
24
|
+
var _useActionSetShouldNotBeMenuBarModEffect = _interopRequireDefault(require("./AdaptiveCardHacks/useActionSetShouldNotBeMenuBarModEffect"));
|
|
25
|
+
|
|
26
|
+
var _useActionShouldBePushButtonModEffect = _interopRequireDefault(require("./AdaptiveCardHacks/useActionShouldBePushButtonModEffect"));
|
|
27
|
+
|
|
28
|
+
var _useActiveElementModEffect = _interopRequireDefault(require("./AdaptiveCardHacks/useActiveElementModEffect"));
|
|
29
|
+
|
|
24
30
|
var _useAdaptiveCardsHostConfig = _interopRequireDefault(require("../hooks/useAdaptiveCardsHostConfig"));
|
|
25
31
|
|
|
26
32
|
var _useAdaptiveCardsPackage = _interopRequireDefault(require("../hooks/useAdaptiveCardsPackage"));
|
|
27
33
|
|
|
34
|
+
var _useDisabledModEffect3 = _interopRequireDefault(require("./AdaptiveCardHacks/useDisabledModEffect"));
|
|
35
|
+
|
|
36
|
+
var _usePersistValuesModEffect = _interopRequireDefault(require("./AdaptiveCardHacks/usePersistValuesModEffect"));
|
|
37
|
+
|
|
38
|
+
var _useValueRef = _interopRequireDefault(require("./AdaptiveCardHacks/private/useValueRef"));
|
|
39
|
+
|
|
28
40
|
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); }
|
|
29
41
|
|
|
30
42
|
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; }
|
|
@@ -39,437 +51,11 @@ var useDisabled = _botframeworkWebchatComponent.hooks.useDisabled,
|
|
|
39
51
|
useStyleSet = _botframeworkWebchatComponent.hooks.useStyleSet;
|
|
40
52
|
var node_env = undefined || "production";
|
|
41
53
|
|
|
42
|
-
function
|
|
43
|
-
|
|
44
|
-
|
|
45
|
-
|
|
46
|
-
|
|
47
|
-
return function () {
|
|
48
|
-
return fns.forEach(function (fn) {
|
|
49
|
-
return fn === null || fn === void 0 ? void 0 : fn();
|
|
50
|
-
});
|
|
51
|
-
};
|
|
52
|
-
}
|
|
53
|
-
/**
|
|
54
|
-
* Adds a class to the `HTMLElement`. Returns `true` if the class is added, otherwise, `undefined`.
|
|
55
|
-
*/
|
|
56
|
-
|
|
57
|
-
|
|
58
|
-
function addClass(element, className) {
|
|
59
|
-
var classList = element.classList;
|
|
60
|
-
|
|
61
|
-
if (!classList.contains(className)) {
|
|
62
|
-
classList.add(className);
|
|
63
|
-
return true;
|
|
64
|
-
}
|
|
65
|
-
}
|
|
66
|
-
/**
|
|
67
|
-
* Adds a class to the `HTMLElement` and re-add on mutations.
|
|
68
|
-
*
|
|
69
|
-
* @returns {function} A function, when called, will restore to previous state.
|
|
70
|
-
*/
|
|
71
|
-
|
|
72
|
-
|
|
73
|
-
function addPersistentClassWithUndo(element, className) {
|
|
74
|
-
if (!element) {
|
|
75
|
-
return;
|
|
76
|
-
}
|
|
77
|
-
|
|
78
|
-
if (addClass(element, className)) {
|
|
79
|
-
// After we add the class, keep observing the element to make sure the class is not removed.
|
|
80
|
-
var observer = new MutationObserver(function () {
|
|
81
|
-
return addClass(element, className);
|
|
82
|
-
});
|
|
83
|
-
observer.observe(element, {
|
|
84
|
-
attributes: true,
|
|
85
|
-
attributeFilter: ['class']
|
|
86
|
-
});
|
|
87
|
-
return function () {
|
|
88
|
-
var classNames = new Set(element.className.split(' '));
|
|
89
|
-
classNames.delete(className);
|
|
90
|
-
element.className = Array.from(classNames).join(' ');
|
|
91
|
-
observer.disconnect();
|
|
92
|
-
};
|
|
93
|
-
}
|
|
94
|
-
}
|
|
95
|
-
/**
|
|
96
|
-
* Returns `true`, if the object is a plain object and not a class, otherwise, `false`.
|
|
97
|
-
*/
|
|
98
|
-
|
|
99
|
-
|
|
100
|
-
function isPlainObject(obj) {
|
|
101
|
-
return Object.getPrototypeOf(obj) === Object.prototype;
|
|
102
|
-
}
|
|
103
|
-
/**
|
|
104
|
-
* Sets an attribute.
|
|
105
|
-
*
|
|
106
|
-
* @returns {function} A function, when called, will restore to previous state.
|
|
107
|
-
*/
|
|
108
|
-
|
|
109
|
-
|
|
110
|
-
function setAttributeWithUndo(element, qualifiedName, nextValue) {
|
|
111
|
-
if (!element) {
|
|
112
|
-
return;
|
|
113
|
-
}
|
|
114
|
-
|
|
115
|
-
var value = element.getAttribute(qualifiedName);
|
|
116
|
-
|
|
117
|
-
if (value !== nextValue) {
|
|
118
|
-
element.setAttribute(qualifiedName, nextValue);
|
|
119
|
-
return function () {
|
|
120
|
-
return value ? element.setAttribute(qualifiedName, value) : element.removeAttribute(qualifiedName);
|
|
121
|
-
};
|
|
122
|
-
}
|
|
123
|
-
}
|
|
124
|
-
/**
|
|
125
|
-
* An event handler for disabling event bubbling and propagation.
|
|
126
|
-
*/
|
|
127
|
-
|
|
128
|
-
|
|
129
|
-
var disabledHandler = function disabledHandler(event) {
|
|
130
|
-
event.preventDefault();
|
|
131
|
-
event.stopImmediatePropagation();
|
|
132
|
-
event.stopPropagation();
|
|
133
|
-
};
|
|
134
|
-
/**
|
|
135
|
-
* Listens to event once. Returns a function, when called, will stop listening.
|
|
136
|
-
*/
|
|
137
|
-
|
|
138
|
-
|
|
139
|
-
function addEventListenerOnceWithUndo(element, name, handler) {
|
|
140
|
-
if (!element) {
|
|
141
|
-
return;
|
|
142
|
-
}
|
|
143
|
-
/* eslint-disable-next-line prefer-const */
|
|
144
|
-
|
|
145
|
-
|
|
146
|
-
var detach;
|
|
147
|
-
|
|
148
|
-
var detachingHandler = function detachingHandler(event) {
|
|
149
|
-
try {
|
|
150
|
-
handler(event);
|
|
151
|
-
} finally {
|
|
152
|
-
// IE11 does not support { once: true }, so we need to detach manually.
|
|
153
|
-
detach();
|
|
154
|
-
}
|
|
155
|
-
};
|
|
156
|
-
|
|
157
|
-
detach = function detach() {
|
|
158
|
-
return element.removeEventListener(name, detachingHandler);
|
|
159
|
-
};
|
|
160
|
-
|
|
161
|
-
element.addEventListener(name, detachingHandler, {
|
|
162
|
-
once: true
|
|
163
|
-
});
|
|
164
|
-
return detach;
|
|
165
|
-
}
|
|
166
|
-
/**
|
|
167
|
-
* Listens to event. Returns a function, when called, will stop listening.
|
|
168
|
-
*/
|
|
169
|
-
|
|
170
|
-
|
|
171
|
-
function addEventListenerWithUndo(element, name, handler) {
|
|
172
|
-
if (!element) {
|
|
173
|
-
return;
|
|
174
|
-
}
|
|
175
|
-
|
|
176
|
-
element.addEventListener(name, handler);
|
|
177
|
-
return function () {
|
|
178
|
-
return element.removeEventListener(name, handler);
|
|
179
|
-
};
|
|
180
|
-
}
|
|
181
|
-
/**
|
|
182
|
-
* Disables an element with undo function.
|
|
183
|
-
*
|
|
184
|
-
* @returns {function} A function, when called, will restore to previous state.
|
|
185
|
-
*/
|
|
186
|
-
|
|
187
|
-
|
|
188
|
-
function disableElementWithUndo(element) {
|
|
189
|
-
if (!element) {
|
|
190
|
-
return;
|
|
191
|
-
}
|
|
192
|
-
|
|
193
|
-
var undoStack = [];
|
|
194
|
-
var isActive = element === document.activeElement;
|
|
195
|
-
var tag = element.nodeName.toLowerCase();
|
|
196
|
-
/* eslint-disable-next-line default-case */
|
|
197
|
-
|
|
198
|
-
switch (tag) {
|
|
199
|
-
case 'button':
|
|
200
|
-
case 'input':
|
|
201
|
-
case 'select':
|
|
202
|
-
case 'textarea':
|
|
203
|
-
undoStack.push(setAttributeWithUndo(element, 'aria-disabled', 'true'));
|
|
204
|
-
|
|
205
|
-
if (isActive) {
|
|
206
|
-
undoStack.push(addEventListenerOnceWithUndo(element, 'blur', function () {
|
|
207
|
-
return undoStack.push(setAttributeWithUndo(element, 'disabled', 'disabled'));
|
|
208
|
-
}));
|
|
209
|
-
} else {
|
|
210
|
-
undoStack.push(setAttributeWithUndo(element, 'disabled', 'disabled'));
|
|
211
|
-
}
|
|
212
|
-
|
|
213
|
-
if (tag === 'input' || tag === 'textarea') {
|
|
214
|
-
undoStack.push(addEventListenerWithUndo(element, 'click', disabledHandler));
|
|
215
|
-
undoStack.push(setAttributeWithUndo(element, 'readonly', 'readonly'));
|
|
216
|
-
} else if (tag === 'select') {
|
|
217
|
-
undoStack.push.apply(undoStack, (0, _toConsumableArray2.default)([].map.call(element.querySelectorAll('option'), function (option) {
|
|
218
|
-
return setAttributeWithUndo(option, 'disabled', 'disabled');
|
|
219
|
-
})));
|
|
220
|
-
}
|
|
221
|
-
|
|
222
|
-
break;
|
|
223
|
-
}
|
|
224
|
-
|
|
225
|
-
return bunchUndos.apply(void 0, undoStack);
|
|
226
|
-
}
|
|
227
|
-
/**
|
|
228
|
-
* Disables all inputtable descendants.
|
|
229
|
-
*
|
|
230
|
-
* @param {HTMLElement | undefined} element Container element to start looking for inputtable descendants.
|
|
231
|
-
* @param {boolean} observeSubtree `true` to applies to all future inputtable descendants, otherwise, `false`.
|
|
232
|
-
*
|
|
233
|
-
* @returns {function} A function, when called, will restore to previous state.
|
|
234
|
-
*/
|
|
235
|
-
|
|
236
|
-
|
|
237
|
-
function disableInputElementsWithUndo(element) {
|
|
238
|
-
var observeSubtree = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : true;
|
|
239
|
-
|
|
240
|
-
if (!element) {
|
|
241
|
-
return;
|
|
242
|
-
}
|
|
243
|
-
|
|
244
|
-
var undoStack = [].map.call(element.querySelectorAll('button, input, select, textarea'), function (element) {
|
|
245
|
-
return disableElementWithUndo(element);
|
|
246
|
-
});
|
|
247
|
-
var tag = element.nodeName.toLowerCase(); // Only set tabindex="-1" on focusable element. Otherwise, we will make <div> focusable by mouse.
|
|
248
|
-
|
|
249
|
-
(tag === 'a' || tag === 'button' || tag === 'input' || tag === 'select' || tag === 'textarea') && undoStack.push(setAttributeWithUndo(element, 'tabindex', '-1'));
|
|
250
|
-
|
|
251
|
-
if (observeSubtree) {
|
|
252
|
-
var observer = new MutationObserver(function (mutations) {
|
|
253
|
-
return mutations.forEach(function (_ref) {
|
|
254
|
-
var addedNodes = _ref.addedNodes;
|
|
255
|
-
return undoStack.push.apply(undoStack, (0, _toConsumableArray2.default)([].map.call(addedNodes, function (addedNode) {
|
|
256
|
-
return disableInputElementsWithUndo(addedNode, false);
|
|
257
|
-
})));
|
|
258
|
-
});
|
|
259
|
-
});
|
|
260
|
-
observer.observe(element, {
|
|
261
|
-
childList: true,
|
|
262
|
-
subtree: true
|
|
263
|
-
});
|
|
264
|
-
undoStack.push(function () {
|
|
265
|
-
return observer.disconnect();
|
|
266
|
-
});
|
|
267
|
-
}
|
|
268
|
-
|
|
269
|
-
return bunchUndos.apply(void 0, (0, _toConsumableArray2.default)(undoStack));
|
|
270
|
-
}
|
|
271
|
-
/**
|
|
272
|
-
* Gets the value of an attribute from an element.
|
|
273
|
-
*
|
|
274
|
-
* @returns {false | string} The value of the attribute. `false` if the attribute was not set.
|
|
275
|
-
*/
|
|
276
|
-
|
|
277
|
-
|
|
278
|
-
function getAttribute(element, qualifiedName) {
|
|
279
|
-
return !!element && element.hasAttribute(qualifiedName) && (element.getAttribute(qualifiedName) || '');
|
|
280
|
-
}
|
|
281
|
-
/**
|
|
282
|
-
* Sets or removes an attribute from an element.
|
|
283
|
-
*
|
|
284
|
-
* @param {HTMLElement} element - The element to set or remove attribute from.
|
|
285
|
-
* @param {string} qualifiedName - The name of the attribute.
|
|
286
|
-
* @param {false | string} value - The value of the attribute. When passing `false`, remove the attribute.
|
|
287
|
-
*/
|
|
288
|
-
|
|
289
|
-
|
|
290
|
-
function setOrRemoveAttribute(element, qualifiedName, value) {
|
|
291
|
-
if (value === false) {
|
|
292
|
-
element === null || element === void 0 ? void 0 : element.removeAttribute(qualifiedName);
|
|
293
|
-
} else {
|
|
294
|
-
element === null || element === void 0 ? void 0 : element.setAttribute(qualifiedName, value);
|
|
295
|
-
}
|
|
296
|
-
}
|
|
297
|
-
/**
|
|
298
|
-
* Sets or removes an attribute from an element with an undo function.
|
|
299
|
-
*
|
|
300
|
-
* @param {HTMLElement} element - The element to set or remove attribute from.
|
|
301
|
-
* @param {string} qualifiedName - The name of the attribute.
|
|
302
|
-
* @param {false | string} value - The value of the attribute. When passing `false`, remove the attribute.
|
|
303
|
-
*
|
|
304
|
-
* @returns {() => void} The undo function, when called, will undo all manipulations by restoring values recorded at the time of the function call.
|
|
305
|
-
*/
|
|
306
|
-
|
|
307
|
-
|
|
308
|
-
function setOrRemoveAttributeWithUndo(element, qualifiedName, value) {
|
|
309
|
-
if (!element) {
|
|
310
|
-
return;
|
|
311
|
-
}
|
|
312
|
-
|
|
313
|
-
var prevValue = getAttribute(element, qualifiedName);
|
|
314
|
-
setOrRemoveAttribute(element, qualifiedName, value);
|
|
315
|
-
return function () {
|
|
316
|
-
return setOrRemoveAttribute(element, qualifiedName, prevValue);
|
|
317
|
-
};
|
|
318
|
-
}
|
|
319
|
-
/**
|
|
320
|
-
* Finds the first ancestor that fulfill the predicate.
|
|
321
|
-
*
|
|
322
|
-
* @param {HTMLElement} element - The starting element. This element will not be checked against the predicate.
|
|
323
|
-
* @param {(ancestor: HTMLElement) => boolean} predicate - The predicate to fulfill.
|
|
324
|
-
*
|
|
325
|
-
* @returns {HTMLElement | undefined} The first ancestor that fulfill the predicate, otherwise, `undefined`.
|
|
326
|
-
*/
|
|
327
|
-
|
|
328
|
-
|
|
329
|
-
function findAncestor(element, predicate) {
|
|
330
|
-
var current = element;
|
|
331
|
-
|
|
332
|
-
while (current = current.parentElement) {
|
|
333
|
-
if (predicate.call(element, current)) {
|
|
334
|
-
return current;
|
|
335
|
-
}
|
|
336
|
-
}
|
|
337
|
-
}
|
|
338
|
-
/**
|
|
339
|
-
* Indicates the action selected by performing a series of manipulations, with undo:
|
|
340
|
-
*
|
|
341
|
-
* - Accessibility: set `aria-pressed` to `true`
|
|
342
|
-
* - Applies `styleOptions.actionPerformedClassName`
|
|
343
|
-
*
|
|
344
|
-
* @param {HTMLElement[]} selectedActionElements - An array of elements that are representing the action and is selected.
|
|
345
|
-
* @param {string?} actionPerformedClassName - The name of the class to apply to all elements.
|
|
346
|
-
*
|
|
347
|
-
* @returns {() => void} The undo function, when called, will undo all manipulations by restoring values recorded at the time of the function call.
|
|
348
|
-
*/
|
|
349
|
-
|
|
350
|
-
|
|
351
|
-
function indicateActionSelectionWithUndo(selectedActionElements, actionPerformedClassName) {
|
|
352
|
-
if (!(selectedActionElements !== null && selectedActionElements !== void 0 && selectedActionElements.length)) {
|
|
353
|
-
return;
|
|
354
|
-
} // Verify all input elements are "ac-pushButton", could belongs to ActionSet or "card actions".
|
|
355
|
-
|
|
356
|
-
|
|
357
|
-
if (selectedActionElements.some(function (actionElement) {
|
|
358
|
-
return !actionElement.classList.contains('ac-pushButton');
|
|
359
|
-
})) {
|
|
360
|
-
console.warn('botframework-webchat: Cannot mark selected action in the card, some elements are not an "ac-pushButton".');
|
|
361
|
-
return;
|
|
362
|
-
} // A distinct set of action set containers which has selections, excluding containers without actions.
|
|
363
|
-
// Multiple submission in an Adaptive Card is still a vague area and TBD.
|
|
364
|
-
// We might want to disable the whole card, just buttons in same container, or do nothing (today).
|
|
365
|
-
|
|
366
|
-
|
|
367
|
-
var actionSetElements = new Set();
|
|
368
|
-
selectedActionElements.forEach(function (selectedActionElement) {
|
|
369
|
-
var actionSetElement = findAncestor(selectedActionElement, function (ancestor) {
|
|
370
|
-
return ancestor.getAttribute('role') === 'menubar';
|
|
371
|
-
});
|
|
372
|
-
actionSetElement && actionSetElements.add(actionSetElement);
|
|
373
|
-
});
|
|
374
|
-
var undoStack = [];
|
|
375
|
-
actionSetElements.forEach(function (actionSetElement) {
|
|
376
|
-
// Remove "role" from every "ac-actionSet" container.
|
|
377
|
-
undoStack.push(setOrRemoveAttributeWithUndo(actionSetElement, 'role', false)); // Modify "role" of every actions in the container.
|
|
378
|
-
|
|
379
|
-
Array.from(actionSetElement.querySelectorAll('.ac-pushButton')).forEach(function (actionElement) {
|
|
380
|
-
if (selectedActionElements.includes(actionElement)) {
|
|
381
|
-
// Add "aria-pressed" and set "role" attribute to "button" (which is required by "aria-pressed").
|
|
382
|
-
undoStack.push(setOrRemoveAttributeWithUndo(actionElement, 'aria-pressed', 'true'));
|
|
383
|
-
undoStack.push(setOrRemoveAttributeWithUndo(actionElement, 'role', 'button')); // Highlight actions by applying `styleOptions.actionPerformedClassName`.
|
|
384
|
-
|
|
385
|
-
actionPerformedClassName && undoStack.push(addPersistentClassWithUndo(actionElement, actionPerformedClassName));
|
|
386
|
-
} else {
|
|
387
|
-
// We removed "role=menubar" from the container, we must remove "role=menuitem" from unselected actions.
|
|
388
|
-
undoStack.push(setOrRemoveAttributeWithUndo(actionElement, 'role', false));
|
|
389
|
-
}
|
|
390
|
-
});
|
|
391
|
-
});
|
|
392
|
-
return bunchUndos.apply(void 0, undoStack);
|
|
393
|
-
}
|
|
394
|
-
/**
|
|
395
|
-
* Fixes accessibility issues from Adaptive Card, with undo.
|
|
396
|
-
*
|
|
397
|
-
* @returns {() => void} The undo function, when called, will undo all manipulations by restoring values recorded at the time of the function call.
|
|
398
|
-
*/
|
|
399
|
-
|
|
400
|
-
|
|
401
|
-
function fixAccessibilityIssuesWithUndo(element) {
|
|
402
|
-
if (!element) {
|
|
403
|
-
return;
|
|
404
|
-
} // These hacks should be done in Adaptive Cards library instead.
|
|
405
|
-
// Related to #3949: All action buttons inside role="menubar" should be role="menuitem".
|
|
406
|
-
|
|
407
|
-
|
|
408
|
-
var undoStack = Array.from(element.querySelectorAll('.ac-actionSet[role="menubar"] [role="button"]')).map(function (actionButton) {
|
|
409
|
-
return setAttributeWithUndo(actionButton, 'role', 'menuitem');
|
|
410
|
-
});
|
|
411
|
-
return function () {
|
|
412
|
-
return undoStack.forEach(function (undo) {
|
|
413
|
-
return undo === null || undo === void 0 ? void 0 : undo();
|
|
414
|
-
});
|
|
415
|
-
};
|
|
416
|
-
}
|
|
417
|
-
|
|
418
|
-
function getFocusableElements(element) {
|
|
419
|
-
return [].filter.call(element.querySelectorAll(['a', 'body', 'button', 'frame', 'iframe', 'img', 'input', 'isindex', 'object', 'select', 'textarea', '[tabindex]'].join(', ')), function (element) {
|
|
420
|
-
var tabIndex = (0, _botframeworkWebchatComponent.getTabIndex)(element);
|
|
421
|
-
return typeof tabIndex === 'number' && tabIndex >= 0;
|
|
422
|
-
});
|
|
423
|
-
}
|
|
424
|
-
|
|
425
|
-
function restoreActiveElementIndex(element, activeElementIndex) {
|
|
426
|
-
var _getFocusableElements;
|
|
427
|
-
|
|
428
|
-
(_getFocusableElements = getFocusableElements(element)[+activeElementIndex]) === null || _getFocusableElements === void 0 ? void 0 : _getFocusableElements.focus();
|
|
429
|
-
}
|
|
430
|
-
|
|
431
|
-
function saveActiveElementIndex(element) {
|
|
432
|
-
return getFocusableElements(element).indexOf(document.activeElement);
|
|
433
|
-
}
|
|
434
|
-
|
|
435
|
-
function restoreInputValues(element, inputValues) {
|
|
436
|
-
var inputs = element.querySelectorAll('input, select, textarea');
|
|
437
|
-
[].forEach.call(inputs, function (input, index) {
|
|
438
|
-
var value = inputValues[+index];
|
|
439
|
-
|
|
440
|
-
if (typeof value !== 'undefined') {
|
|
441
|
-
var tagName = input.tagName,
|
|
442
|
-
type = input.type;
|
|
443
|
-
|
|
444
|
-
if (tagName === 'INPUT' && (type === 'checkbox' || type === 'radio')) {
|
|
445
|
-
if (typeof value === 'boolean') {
|
|
446
|
-
input.checked = value;
|
|
447
|
-
}
|
|
448
|
-
} else if (typeof value === 'string') {
|
|
449
|
-
input.value = value;
|
|
450
|
-
}
|
|
451
|
-
}
|
|
452
|
-
});
|
|
453
|
-
}
|
|
454
|
-
|
|
455
|
-
function saveInputValues(element) {
|
|
456
|
-
var inputs = element.querySelectorAll('input, select, textarea');
|
|
457
|
-
return [].map.call(inputs, function (input) {
|
|
458
|
-
var type = input.type;
|
|
459
|
-
|
|
460
|
-
if (input.tagName === 'INPUT' && (type === 'checkbox' || type === 'radio')) {
|
|
461
|
-
return input.checked;
|
|
462
|
-
}
|
|
463
|
-
|
|
464
|
-
return input.value;
|
|
465
|
-
});
|
|
466
|
-
}
|
|
467
|
-
|
|
468
|
-
var AdaptiveCardRenderer = function AdaptiveCardRenderer(_ref2) {
|
|
469
|
-
var actionPerformedClassName = _ref2.actionPerformedClassName,
|
|
470
|
-
adaptiveCard = _ref2.adaptiveCard,
|
|
471
|
-
disabledFromProps = _ref2.disabled,
|
|
472
|
-
tapAction = _ref2.tapAction;
|
|
54
|
+
var AdaptiveCardRenderer = function AdaptiveCardRenderer(_ref) {
|
|
55
|
+
var actionPerformedClassName = _ref.actionPerformedClassName,
|
|
56
|
+
adaptiveCard = _ref.adaptiveCard,
|
|
57
|
+
disabledFromProps = _ref.disabled,
|
|
58
|
+
tapAction = _ref.tapAction;
|
|
473
59
|
|
|
474
60
|
var _useStyleSet = useStyleSet(),
|
|
475
61
|
_useStyleSet2 = (0, _slicedToArray2.default)(_useStyleSet, 1),
|
|
@@ -481,11 +67,6 @@ var AdaptiveCardRenderer = function AdaptiveCardRenderer(_ref2) {
|
|
|
481
67
|
GlobalSettings = _useAdaptiveCardsPack3.GlobalSettings,
|
|
482
68
|
HostConfig = _useAdaptiveCardsPack3.HostConfig;
|
|
483
69
|
|
|
484
|
-
var _useState = (0, _react.useState)([]),
|
|
485
|
-
_useState2 = (0, _slicedToArray2.default)(_useState, 2),
|
|
486
|
-
actionsPerformed = _useState2[0],
|
|
487
|
-
setActionsPerformed = _useState2[1];
|
|
488
|
-
|
|
489
70
|
var _useAdaptiveCardsHost = (0, _useAdaptiveCardsHostConfig.default)(),
|
|
490
71
|
_useAdaptiveCardsHost2 = (0, _slicedToArray2.default)(_useAdaptiveCardsHost, 1),
|
|
491
72
|
adaptiveCardsHostConfig = _useAdaptiveCardsHost2[0];
|
|
@@ -494,31 +75,20 @@ var AdaptiveCardRenderer = function AdaptiveCardRenderer(_ref2) {
|
|
|
494
75
|
_useDisabled2 = (0, _slicedToArray2.default)(_useDisabled, 1),
|
|
495
76
|
disabledFromComposer = _useDisabled2[0];
|
|
496
77
|
|
|
497
|
-
var _useState3 = (0, _react.useState)([]),
|
|
498
|
-
_useState4 = (0, _slicedToArray2.default)(_useState3, 2),
|
|
499
|
-
errors = _useState4[0],
|
|
500
|
-
setErrors = _useState4[1];
|
|
501
|
-
|
|
502
|
-
var _useState5 = (0, _react.useState)(0),
|
|
503
|
-
_useState6 = (0, _slicedToArray2.default)(_useState5, 2),
|
|
504
|
-
lastRender = _useState6[0],
|
|
505
|
-
setLastRender = _useState6[1];
|
|
506
|
-
|
|
507
|
-
var activeElementIndexRef = (0, _react.useRef)(-1);
|
|
508
|
-
var adaptiveCardElementRef = (0, _react.useRef)();
|
|
509
78
|
var contentRef = (0, _react.useRef)();
|
|
510
|
-
var inputValuesRef = (0, _react.useRef)([]);
|
|
511
79
|
var localize = useLocalizer();
|
|
512
80
|
var performCardAction = usePerformCardAction();
|
|
513
81
|
var renderMarkdownAsHTML = useRenderMarkdownAsHTML();
|
|
514
82
|
var scrollToEnd = useScrollToEnd();
|
|
515
|
-
var disabled = disabledFromComposer || disabledFromProps;
|
|
83
|
+
var disabled = disabledFromComposer || disabledFromProps;
|
|
84
|
+
var tapActionRef = (0, _useValueRef.default)(tapAction);
|
|
85
|
+
var disabledRef = (0, _useValueRef.default)(disabled); // TODO: [P2] #3199 We should consider using `adaptiveCard.selectAction` instead.
|
|
516
86
|
// The null check for "tapAction" is in "handleClickAndKeyPressForTapAction".
|
|
517
87
|
|
|
518
88
|
var handleClickAndKeyPress = (0, _react.useCallback)(function (event) {
|
|
519
|
-
var
|
|
520
|
-
key =
|
|
521
|
-
type =
|
|
89
|
+
var _ref2 = event,
|
|
90
|
+
key = _ref2.key,
|
|
91
|
+
type = _ref2.type;
|
|
522
92
|
var target = event.target; // Some items, e.g. tappable text, cannot be disabled thru DOM attributes
|
|
523
93
|
|
|
524
94
|
var current = contentRef.current;
|
|
@@ -549,29 +119,25 @@ var AdaptiveCardRenderer = function AdaptiveCardRenderer(_ref2) {
|
|
|
549
119
|
}
|
|
550
120
|
}
|
|
551
121
|
|
|
552
|
-
performCardAction(
|
|
122
|
+
performCardAction(tapActionRef.current);
|
|
553
123
|
scrollToEnd();
|
|
554
|
-
}, [contentRef, performCardAction, scrollToEnd,
|
|
124
|
+
}, [contentRef, performCardAction, scrollToEnd, tapActionRef]); // Only listen to event if it is not disabled and have "tapAction" prop.
|
|
555
125
|
|
|
556
126
|
var handleClickAndKeyPressForTapAction = !disabled && tapAction ? handleClickAndKeyPress : undefined;
|
|
557
|
-
var addActionsPerformed = (0, _react.useCallback)(function (action) {
|
|
558
|
-
return !~actionsPerformed.indexOf(action) && setActionsPerformed([].concat((0, _toConsumableArray2.default)(actionsPerformed), [action]));
|
|
559
|
-
}, [actionsPerformed, setActionsPerformed]);
|
|
560
127
|
var handleExecuteAction = (0, _react.useCallback)(function (action) {
|
|
561
128
|
// Some items, e.g. tappable image, cannot be disabled thru DOM attributes
|
|
562
|
-
if (
|
|
129
|
+
if (disabledRef.current) {
|
|
563
130
|
return;
|
|
564
131
|
}
|
|
565
132
|
|
|
566
|
-
addActionsPerformed(action);
|
|
567
133
|
var actionTypeName = action.getJsonTypeName();
|
|
568
134
|
var image = action.iconUrl,
|
|
569
135
|
title = action.title; // We cannot use "instanceof" check here, because web devs may bring their own version of Adaptive Cards package.
|
|
570
136
|
// We need to check using "getJsonTypeName()" instead.
|
|
571
137
|
|
|
572
138
|
if (actionTypeName === 'Action.OpenUrl') {
|
|
573
|
-
var
|
|
574
|
-
value =
|
|
139
|
+
var _ref3 = action,
|
|
140
|
+
value = _ref3.url;
|
|
575
141
|
performCardAction({
|
|
576
142
|
image: image,
|
|
577
143
|
title: title,
|
|
@@ -579,8 +145,8 @@ var AdaptiveCardRenderer = function AdaptiveCardRenderer(_ref2) {
|
|
|
579
145
|
value: value
|
|
580
146
|
});
|
|
581
147
|
} else if (actionTypeName === 'Action.Submit') {
|
|
582
|
-
var
|
|
583
|
-
data =
|
|
148
|
+
var _ref4 = action,
|
|
149
|
+
data = _ref4.data;
|
|
584
150
|
|
|
585
151
|
if (typeof data !== 'undefined') {
|
|
586
152
|
if (typeof data === 'string') {
|
|
@@ -607,100 +173,74 @@ var AdaptiveCardRenderer = function AdaptiveCardRenderer(_ref2) {
|
|
|
607
173
|
console.error("Web Chat: received unknown action from Adaptive Cards");
|
|
608
174
|
console.error(action);
|
|
609
175
|
}
|
|
610
|
-
}, [
|
|
176
|
+
}, [disabledRef, performCardAction, scrollToEnd]); // For accessibility issue #1340, `tabindex="0"` must not be set for the root container if it is not interactive.
|
|
177
|
+
|
|
178
|
+
var setTabIndexAtCardRoot = !!tapAction;
|
|
179
|
+
|
|
180
|
+
var _useActionShouldBePus = (0, _useActionShouldBePushButtonModEffect.default)(adaptiveCard),
|
|
181
|
+
_useActionShouldBePus2 = (0, _slicedToArray2.default)(_useActionShouldBePus, 2),
|
|
182
|
+
applyActionShouldBePushButtonMod = _useActionShouldBePus2[0],
|
|
183
|
+
undoActionShouldBePushButtonMod = _useActionShouldBePus2[1];
|
|
184
|
+
|
|
185
|
+
var _useActionSetShouldNo = (0, _useActionSetShouldNotBeMenuBarModEffect.default)(adaptiveCard),
|
|
186
|
+
_useActionSetShouldNo2 = (0, _slicedToArray2.default)(_useActionSetShouldNo, 2),
|
|
187
|
+
applyActionSetShouldNotBeMenuBarMod = _useActionSetShouldNo2[0],
|
|
188
|
+
undoActionSetShouldNotBeMenuBarMod = _useActionSetShouldNo2[1];
|
|
189
|
+
|
|
190
|
+
var _useActiveElementModE = (0, _useActiveElementModEffect.default)(adaptiveCard),
|
|
191
|
+
_useActiveElementModE2 = (0, _slicedToArray2.default)(_useActiveElementModE, 2),
|
|
192
|
+
applyActiveElementMod = _useActiveElementModE2[0],
|
|
193
|
+
undoActiveElementMod = _useActiveElementModE2[1];
|
|
194
|
+
|
|
195
|
+
var _useDisabledModEffect = (0, _useDisabledModEffect3.default)(adaptiveCard),
|
|
196
|
+
_useDisabledModEffect2 = (0, _slicedToArray2.default)(_useDisabledModEffect, 2),
|
|
197
|
+
applyDisabledMod = _useDisabledModEffect2[0],
|
|
198
|
+
undoDisabledMod = _useDisabledModEffect2[1];
|
|
199
|
+
|
|
200
|
+
var _usePersistValuesModE = (0, _usePersistValuesModEffect.default)(adaptiveCard),
|
|
201
|
+
_usePersistValuesModE2 = (0, _slicedToArray2.default)(_usePersistValuesModE, 2),
|
|
202
|
+
applyPersistValuesMod = _usePersistValuesModE2[0],
|
|
203
|
+
undoPersistValuesMod = _usePersistValuesModE2[1];
|
|
204
|
+
|
|
205
|
+
var _useMemo = (0, _react.useMemo)(function () {
|
|
206
|
+
undoActionShouldBePushButtonMod();
|
|
207
|
+
undoActionSetShouldNotBeMenuBarMod();
|
|
208
|
+
undoActiveElementMod();
|
|
209
|
+
undoDisabledMod();
|
|
210
|
+
undoPersistValuesMod();
|
|
211
|
+
return (0, _renderAdaptiveCard.default)(adaptiveCard, {
|
|
212
|
+
adaptiveCardsHostConfig: adaptiveCardsHostConfig,
|
|
213
|
+
adaptiveCardsPackage: {
|
|
214
|
+
GlobalSettings: GlobalSettings,
|
|
215
|
+
HostConfig: HostConfig
|
|
216
|
+
},
|
|
217
|
+
renderMarkdownAsHTML: renderMarkdownAsHTML,
|
|
218
|
+
setTabIndexAtCardRoot: setTabIndexAtCardRoot
|
|
219
|
+
});
|
|
220
|
+
}, [adaptiveCard, adaptiveCardsHostConfig, GlobalSettings, HostConfig, renderMarkdownAsHTML, setTabIndexAtCardRoot, undoActionShouldBePushButtonMod, undoActionSetShouldNotBeMenuBarMod, undoActiveElementMod, undoDisabledMod, undoPersistValuesMod]),
|
|
221
|
+
element = _useMemo.element,
|
|
222
|
+
errors = _useMemo.errors;
|
|
223
|
+
|
|
224
|
+
(0, _react.useMemo)(function () {
|
|
225
|
+
adaptiveCard.onExecuteAction = handleExecuteAction;
|
|
226
|
+
}, [adaptiveCard, handleExecuteAction]);
|
|
611
227
|
(0, _react.useLayoutEffect)(function () {
|
|
612
228
|
var current = contentRef.current;
|
|
613
|
-
|
|
614
|
-
if (!current || !adaptiveCard) {
|
|
615
|
-
activeElementIndexRef.current = -1;
|
|
616
|
-
inputValuesRef.current = [];
|
|
617
|
-
} // Currently, the only way to set the Markdown engine is to set it thru static member of AdaptiveCard class
|
|
618
|
-
// TODO: [P3] Checks if we could make the "renderMarkdownAsHTML" per card
|
|
619
|
-
// This could be limitations from Adaptive Cards package (not supported as of 1.2.5)
|
|
620
|
-
// Because there could be timing difference between .parse and .render, we could be using wrong Markdown engine
|
|
621
|
-
// "onProcessMarkdown" is a static function but we are trying to scope it to the current object instead.
|
|
622
|
-
// eslint-disable-next-line dot-notation
|
|
623
|
-
|
|
624
|
-
|
|
625
|
-
adaptiveCard.constructor['onProcessMarkdown'] = function (text, result) {
|
|
626
|
-
if (renderMarkdownAsHTML) {
|
|
627
|
-
result.outputHtml = renderMarkdownAsHTML(text);
|
|
628
|
-
result.didProcess = true;
|
|
629
|
-
}
|
|
630
|
-
};
|
|
631
|
-
|
|
632
|
-
if (adaptiveCardsHostConfig) {
|
|
633
|
-
adaptiveCard.hostConfig = isPlainObject(adaptiveCardsHostConfig) ? new HostConfig(adaptiveCardsHostConfig) : adaptiveCardsHostConfig;
|
|
634
|
-
} // For accessibility issue #1340, `tabindex="0"` must not be set for the root container if it is not interactive.
|
|
635
|
-
|
|
636
|
-
|
|
637
|
-
GlobalSettings.setTabIndexAtCardRoot = !!tapAction;
|
|
638
|
-
|
|
639
|
-
var _adaptiveCard$validat = adaptiveCard.validateProperties(),
|
|
640
|
-
validationEvents = _adaptiveCard$validat.validationEvents;
|
|
641
|
-
|
|
642
|
-
if (validationEvents.length) {
|
|
643
|
-
return setErrors(validationEvents.reduce(function (items, _ref6) {
|
|
644
|
-
var message = _ref6.message;
|
|
645
|
-
return [].concat((0, _toConsumableArray2.default)(items), [new Error(message)]);
|
|
646
|
-
}, []));
|
|
647
|
-
}
|
|
648
|
-
|
|
649
|
-
var element;
|
|
650
|
-
|
|
651
|
-
try {
|
|
652
|
-
element = adaptiveCard.render();
|
|
653
|
-
} catch (error) {
|
|
654
|
-
return setErrors([error]);
|
|
655
|
-
}
|
|
656
|
-
|
|
657
|
-
if (!element) {
|
|
658
|
-
return setErrors([new Error('Adaptive Card rendered as empty element')]);
|
|
659
|
-
} // Clear errors on next render
|
|
660
|
-
|
|
661
|
-
|
|
662
|
-
setErrors([]);
|
|
663
|
-
restoreInputValues(element, inputValuesRef.current);
|
|
664
|
-
current.appendChild(element);
|
|
665
|
-
adaptiveCardElementRef.current = element; // Focus can only be restored after the DOM is attached.
|
|
666
|
-
|
|
667
|
-
restoreActiveElementIndex(element, activeElementIndexRef.current);
|
|
668
|
-
setLastRender(Date.now());
|
|
229
|
+
current === null || current === void 0 ? void 0 : current.appendChild(element);
|
|
669
230
|
return function () {
|
|
670
|
-
|
|
671
|
-
inputValuesRef.current = saveInputValues(element);
|
|
672
|
-
current.removeChild(adaptiveCardElementRef.current);
|
|
673
|
-
adaptiveCardElementRef.current = undefined;
|
|
231
|
+
current === null || current === void 0 ? void 0 : current.removeChild(element);
|
|
674
232
|
};
|
|
675
|
-
}, [
|
|
676
|
-
|
|
677
|
-
|
|
678
|
-
|
|
679
|
-
|
|
680
|
-
|
|
681
|
-
|
|
682
|
-
|
|
683
|
-
|
|
684
|
-
|
|
685
|
-
|
|
686
|
-
return disableInputElementsWithUndo(adaptiveCardElementRef.current);
|
|
687
|
-
}
|
|
688
|
-
}, [adaptiveCardElementRef, disabled, lastRender]);
|
|
689
|
-
(0, _react.useEffect)(function () {
|
|
690
|
-
// If the Adaptive Card changed, reset all actions performed.
|
|
691
|
-
setActionsPerformed([]);
|
|
692
|
-
}, [adaptiveCard]);
|
|
693
|
-
(0, _react.useEffect)(function () {
|
|
694
|
-
return indicateActionSelectionWithUndo( // Actions that do not have "renderedElement" means it is the Adaptive Card itself, such as "selectAction" (AC) or "tapAction" (rich cards).
|
|
695
|
-
// We do not need to mark the whole card as performed.
|
|
696
|
-
actionsPerformed.map(function (_ref7) {
|
|
697
|
-
var renderedElement = _ref7.renderedElement;
|
|
698
|
-
return renderedElement;
|
|
699
|
-
}).filter(function (renderedElement) {
|
|
700
|
-
return renderedElement;
|
|
701
|
-
}), actionPerformedClassName);
|
|
702
|
-
}, [actionsPerformed, actionPerformedClassName, lastRender]);
|
|
703
|
-
return errors.length ? node_env === 'development' && /*#__PURE__*/_react.default.createElement(ErrorBox, {
|
|
233
|
+
}, [contentRef, element]); // Apply all mods regardless whether the element changed or not.
|
|
234
|
+
// This is because we have undoed mods when we call the `useXXXModEffect` hook.
|
|
235
|
+
|
|
236
|
+
(0, _react.useLayoutEffect)(function () {
|
|
237
|
+
applyActionShouldBePushButtonMod(element, actionPerformedClassName);
|
|
238
|
+
applyActionSetShouldNotBeMenuBarMod(element);
|
|
239
|
+
applyActiveElementMod(element);
|
|
240
|
+
applyDisabledMod(element, disabled);
|
|
241
|
+
applyPersistValuesMod(element);
|
|
242
|
+
}, [actionPerformedClassName, applyActionShouldBePushButtonMod, applyActionSetShouldNotBeMenuBarMod, applyActiveElementMod, applyDisabledMod, applyPersistValuesMod, disabled, element]);
|
|
243
|
+
return errors !== null && errors !== void 0 && errors.length ? node_env === 'development' && /*#__PURE__*/_react.default.createElement(ErrorBox, {
|
|
704
244
|
error: errors[0],
|
|
705
245
|
type: localize('ADAPTIVE_CARD_ERROR_BOX_TITLE_RENDER')
|
|
706
246
|
}) : /*#__PURE__*/_react.default.createElement("div", {
|
|
@@ -731,4 +271,4 @@ AdaptiveCardRenderer.propTypes = {
|
|
|
731
271
|
};
|
|
732
272
|
var _default = AdaptiveCardRenderer;
|
|
733
273
|
exports.default = _default;
|
|
734
|
-
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../src/adaptiveCards/Attachment/AdaptiveCardRenderer.tsx"],"names":["ErrorBox","Components","useDisabled","hooks","useLocalizer","usePerformCardAction","useRenderMarkdownAsHTML","useScrollToEnd","useStyleSet","node_env","bunchUndos","fns","forEach","fn","addClass","element","className","classList","contains","add","addPersistentClassWithUndo","observer","MutationObserver","observe","attributes","attributeFilter","classNames","Set","split","delete","Array","from","join","disconnect","isPlainObject","obj","Object","getPrototypeOf","prototype","setAttributeWithUndo","qualifiedName","nextValue","value","getAttribute","setAttribute","removeAttribute","disabledHandler","event","preventDefault","stopImmediatePropagation","stopPropagation","addEventListenerOnceWithUndo","name","handler","detach","detachingHandler","removeEventListener","addEventListener","once","addEventListenerWithUndo","disableElementWithUndo","undoStack","isActive","document","activeElement","tag","nodeName","toLowerCase","push","map","call","querySelectorAll","option","disableInputElementsWithUndo","observeSubtree","mutations","addedNodes","addedNode","childList","subtree","hasAttribute","setOrRemoveAttribute","setOrRemoveAttributeWithUndo","prevValue","findAncestor","predicate","current","parentElement","indicateActionSelectionWithUndo","selectedActionElements","actionPerformedClassName","length","some","actionElement","console","warn","actionSetElements","selectedActionElement","actionSetElement","ancestor","includes","fixAccessibilityIssuesWithUndo","actionButton","undo","getFocusableElements","filter","tabIndex","restoreActiveElementIndex","activeElementIndex","focus","saveActiveElementIndex","indexOf","restoreInputValues","inputValues","inputs","input","index","tagName","type","checked","saveInputValues","AdaptiveCardRenderer","adaptiveCard","disabledFromProps","disabled","tapAction","adaptiveCardRendererStyleSet","adaptiveCardRenderer","GlobalSettings","HostConfig","actionsPerformed","setActionsPerformed","adaptiveCardsHostConfig","disabledFromComposer","errors","setErrors","lastRender","setLastRender","activeElementIndexRef","adaptiveCardElementRef","contentRef","inputValuesRef","localize","performCardAction","renderMarkdownAsHTML","scrollToEnd","handleClickAndKeyPress","key","target","adaptiveCardRoot","querySelector","handleClickAndKeyPressForTapAction","undefined","addActionsPerformed","action","handleExecuteAction","actionTypeName","getJsonTypeName","image","iconUrl","title","url","data","__isBotFrameworkCardAction","cardAction","error","constructor","text","result","outputHtml","didProcess","hostConfig","setTabIndexAtCardRoot","validateProperties","validationEvents","reduce","items","message","Error","render","appendChild","Date","now","removeChild","onExecuteAction","renderedElement","defaultProps","propTypes","PropTypes","string","any","isRequired","bool","shape"],"mappings":"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","sourceRoot":"bundle:///","sourcesContent":["/* eslint no-magic-numbers: [\"error\", { \"ignore\": [-1, 0, 2] }] */\n\nimport {\n  Action as AdaptiveCardAction,\n  AdaptiveCard,\n  IMarkdownProcessingResult,\n  OpenUrlAction,\n  SubmitAction\n} 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  useEffect,\n  useLayoutEffect,\n  useRef,\n  useState,\n  VFC\n} from 'react';\nimport type { DirectLineCardAction } from 'botframework-webchat-core';\n\nimport { BotFrameworkCardAction } from './AdaptiveCardBuilder';\nimport useAdaptiveCardsHostConfig from '../hooks/useAdaptiveCardsHostConfig';\nimport useAdaptiveCardsPackage from '../hooks/useAdaptiveCardsPackage';\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 UndoFunction = (() => void) | undefined;\n\nfunction bunchUndos(...fns: UndoFunction[]): UndoFunction {\n  return () => fns.forEach(fn => fn?.());\n}\n\n/**\n * Adds a class to the `HTMLElement`. Returns `true` if the class is added, otherwise, `undefined`.\n */\nfunction addClass(element: HTMLElement, className: string): true | undefined {\n  const { classList } = element;\n\n  if (!classList.contains(className)) {\n    classList.add(className);\n\n    return true;\n  }\n}\n\n/**\n * Adds a class to the `HTMLElement` and re-add on mutations.\n *\n * @returns {function} A function, when called, will restore to previous state.\n */\nfunction addPersistentClassWithUndo(element: HTMLElement | undefined, className: string): UndoFunction {\n  if (!element) {\n    return;\n  }\n\n  if (addClass(element, className)) {\n    // After we add the class, keep observing the element to make sure the class is not removed.\n    const observer = new MutationObserver(() => addClass(element, className));\n\n    observer.observe(element, { attributes: true, attributeFilter: ['class'] });\n\n    return () => {\n      const classNames = new Set(element.className.split(' '));\n\n      classNames.delete(className);\n\n      element.className = Array.from(classNames).join(' ');\n      observer.disconnect();\n    };\n  }\n}\n\n/**\n * Returns `true`, if the object is a plain object and not a class, otherwise, `false`.\n */\nfunction isPlainObject(obj) {\n  return Object.getPrototypeOf(obj) === Object.prototype;\n}\n\n/**\n * Sets an attribute.\n *\n * @returns {function} A function, when called, will restore to previous state.\n */\nfunction setAttributeWithUndo(\n  element: HTMLElement | undefined,\n  qualifiedName: string,\n  nextValue: string\n): UndoFunction {\n  if (!element) {\n    return;\n  }\n\n  const value = element.getAttribute(qualifiedName);\n\n  if (value !== nextValue) {\n    element.setAttribute(qualifiedName, nextValue);\n\n    return () => (value ? element.setAttribute(qualifiedName, value) : element.removeAttribute(qualifiedName));\n  }\n}\n\n/**\n * An event handler for disabling event bubbling and propagation.\n */\nconst disabledHandler = (event: Event) => {\n  event.preventDefault();\n  event.stopImmediatePropagation();\n  event.stopPropagation();\n};\n\n/**\n * Listens to event once. Returns a function, when called, will stop listening.\n */\nfunction addEventListenerOnceWithUndo(\n  element: HTMLElement | undefined,\n  name: string,\n  handler: EventListener\n): UndoFunction {\n  if (!element) {\n    return;\n  }\n\n  /* eslint-disable-next-line prefer-const */\n  let detach: () => void;\n  const detachingHandler = event => {\n    try {\n      handler(event);\n    } finally {\n      // IE11 does not support { once: true }, so we need to detach manually.\n      detach();\n    }\n  };\n\n  detach = () => element.removeEventListener(name, detachingHandler);\n\n  element.addEventListener(name, detachingHandler, { once: true });\n\n  return detach;\n}\n\n/**\n * Listens to event. Returns a function, when called, will stop listening.\n */\nfunction addEventListenerWithUndo(\n  element: HTMLElement | undefined,\n  name: string,\n  handler: EventListener\n): UndoFunction {\n  if (!element) {\n    return;\n  }\n\n  element.addEventListener(name, handler);\n\n  return () => element.removeEventListener(name, handler);\n}\n\n/**\n * Disables an element with undo function.\n *\n * @returns {function} A function, when called, will restore to previous state.\n */\nfunction disableElementWithUndo(element: HTMLElement | undefined): UndoFunction {\n  if (!element) {\n    return;\n  }\n\n  const undoStack: UndoFunction[] = [];\n  const isActive = element === document.activeElement;\n  const tag = element.nodeName.toLowerCase();\n\n  /* eslint-disable-next-line default-case */\n  switch (tag) {\n    case 'button':\n    case 'input':\n    case 'select':\n    case 'textarea':\n      undoStack.push(setAttributeWithUndo(element, 'aria-disabled', 'true'));\n\n      if (isActive) {\n        undoStack.push(\n          addEventListenerOnceWithUndo(element, 'blur', () =>\n            undoStack.push(setAttributeWithUndo(element, 'disabled', 'disabled'))\n          )\n        );\n      } else {\n        undoStack.push(setAttributeWithUndo(element, 'disabled', 'disabled'));\n      }\n\n      if (tag === 'input' || tag === 'textarea') {\n        undoStack.push(addEventListenerWithUndo(element, 'click', disabledHandler));\n        undoStack.push(setAttributeWithUndo(element, 'readonly', 'readonly'));\n      } else if (tag === 'select') {\n        undoStack.push(\n          ...[].map.call(element.querySelectorAll('option'), option =>\n            setAttributeWithUndo(option, 'disabled', 'disabled')\n          )\n        );\n      }\n\n      break;\n  }\n\n  return bunchUndos(...undoStack);\n}\n\n/**\n * Disables all inputtable descendants.\n *\n * @param {HTMLElement | undefined} element Container element to start looking for inputtable descendants.\n * @param {boolean} observeSubtree `true` to applies to all future inputtable descendants, otherwise, `false`.\n *\n * @returns {function} A function, when called, will restore to previous state.\n */\nfunction disableInputElementsWithUndo(element: HTMLElement | undefined, observeSubtree = true): UndoFunction {\n  if (!element) {\n    return;\n  }\n\n  const undoStack: (() => void)[] = [].map.call(element.querySelectorAll('button, input, select, textarea'), element =>\n    disableElementWithUndo(element)\n  );\n\n  const tag = element.nodeName.toLowerCase();\n\n  // Only set tabindex=\"-1\" on focusable element. Otherwise, we will make <div> focusable by mouse.\n  (tag === 'a' || tag === 'button' || tag === 'input' || tag === 'select' || tag === 'textarea') &&\n    undoStack.push(setAttributeWithUndo(element, 'tabindex', '-1'));\n\n  if (observeSubtree) {\n    const observer = new MutationObserver(mutations =>\n      mutations.forEach(({ addedNodes }) =>\n        undoStack.push(...[].map.call(addedNodes, addedNode => disableInputElementsWithUndo(addedNode, false)))\n      )\n    );\n\n    observer.observe(element, { childList: true, subtree: true });\n\n    undoStack.push(() => observer.disconnect());\n  }\n\n  return bunchUndos(...undoStack);\n}\n\n/**\n * Gets the value of an attribute from an element.\n *\n * @returns {false | string} The value of the attribute. `false` if the attribute was not set.\n */\nfunction getAttribute(element: HTMLElement, qualifiedName: string): false | string {\n  return !!element && element.hasAttribute(qualifiedName) && (element.getAttribute(qualifiedName) || '');\n}\n\n/**\n * Sets or removes an attribute from an element.\n *\n * @param {HTMLElement} element - The element to set or remove attribute from.\n * @param {string} qualifiedName - The name of the attribute.\n * @param {false | string} value - The value of the attribute. When passing `false`, remove the attribute.\n */\nfunction setOrRemoveAttribute(element: HTMLElement | undefined, qualifiedName: string, value: false | string): void {\n  if (value === false) {\n    element?.removeAttribute(qualifiedName);\n  } else {\n    element?.setAttribute(qualifiedName, value);\n  }\n}\n\n/**\n * Sets or removes an attribute from an element with an undo function.\n *\n * @param {HTMLElement} element - The element to set or remove attribute from.\n * @param {string} qualifiedName - The name of the attribute.\n * @param {false | string} value - The value of the attribute. When passing `false`, remove the attribute.\n *\n * @returns {() => void} The undo function, when called, will undo all manipulations by restoring values recorded at the time of the function call.\n */\nfunction setOrRemoveAttributeWithUndo(\n  element: HTMLElement | undefined,\n  qualifiedName: string,\n  value: false | string\n): UndoFunction {\n  if (!element) {\n    return;\n  }\n\n  const prevValue = getAttribute(element, qualifiedName);\n\n  setOrRemoveAttribute(element, qualifiedName, value);\n\n  return () => setOrRemoveAttribute(element, qualifiedName, prevValue);\n}\n\n/**\n * Finds the first ancestor that fulfill the predicate.\n *\n * @param {HTMLElement} element - The starting element. This element will not be checked against the predicate.\n * @param {(ancestor: HTMLElement) => boolean} predicate - The predicate to fulfill.\n *\n * @returns {HTMLElement | undefined} The first ancestor that fulfill the predicate, otherwise, `undefined`.\n */\nfunction findAncestor(element: HTMLElement, predicate: (ancestor: HTMLElement) => boolean): HTMLElement | undefined {\n  let current = element;\n\n  while ((current = current.parentElement)) {\n    if (predicate.call(element, current)) {\n      return current;\n    }\n  }\n}\n\n/**\n * Indicates the action selected by performing a series of manipulations, with undo:\n *\n * - Accessibility: set `aria-pressed` to `true`\n * - Applies `styleOptions.actionPerformedClassName`\n *\n * @param {HTMLElement[]} selectedActionElements - An array of elements that are representing the action and is selected.\n * @param {string?} actionPerformedClassName - The name of the class to apply to all elements.\n *\n * @returns {() => void} The undo function, when called, will undo all manipulations by restoring values recorded at the time of the function call.\n */\nfunction indicateActionSelectionWithUndo(\n  selectedActionElements: HTMLElement[] | undefined,\n  actionPerformedClassName?: string\n): UndoFunction {\n  if (!selectedActionElements?.length) {\n    return;\n  }\n\n  // Verify all input elements are \"ac-pushButton\", could belongs to ActionSet or \"card actions\".\n  if (selectedActionElements.some(actionElement => !actionElement.classList.contains('ac-pushButton'))) {\n    console.warn(\n      'botframework-webchat: Cannot mark selected action in the card, some elements are not an \"ac-pushButton\".'\n    );\n\n    return;\n  }\n\n  // A distinct set of action set containers which has selections, excluding containers without actions.\n  // Multiple submission in an Adaptive Card is still a vague area and TBD.\n  // We might want to disable the whole card, just buttons in same container, or do nothing (today).\n  const actionSetElements = new Set<HTMLElement>();\n\n  selectedActionElements.forEach(selectedActionElement => {\n    const actionSetElement = findAncestor(\n      selectedActionElement,\n      ancestor => ancestor.getAttribute('role') === 'menubar'\n    );\n\n    actionSetElement && actionSetElements.add(actionSetElement);\n  });\n\n  const undoStack: (() => void)[] = [];\n\n  actionSetElements.forEach(actionSetElement => {\n    // Remove \"role\" from every \"ac-actionSet\" container.\n    undoStack.push(setOrRemoveAttributeWithUndo(actionSetElement, 'role', false));\n\n    // Modify \"role\" of every actions in the container.\n    Array.from(actionSetElement.querySelectorAll('.ac-pushButton') as NodeListOf<HTMLElement>).forEach(\n      actionElement => {\n        if (selectedActionElements.includes(actionElement)) {\n          // Add \"aria-pressed\" and set \"role\" attribute to \"button\" (which is required by \"aria-pressed\").\n          undoStack.push(setOrRemoveAttributeWithUndo(actionElement, 'aria-pressed', 'true'));\n          undoStack.push(setOrRemoveAttributeWithUndo(actionElement, 'role', 'button'));\n\n          // Highlight actions by applying `styleOptions.actionPerformedClassName`.\n          actionPerformedClassName &&\n            undoStack.push(addPersistentClassWithUndo(actionElement, actionPerformedClassName));\n        } else {\n          // We removed \"role=menubar\" from the container, we must remove \"role=menuitem\" from unselected actions.\n          undoStack.push(setOrRemoveAttributeWithUndo(actionElement, 'role', false));\n        }\n      }\n    );\n  });\n\n  return bunchUndos(...undoStack);\n}\n\n/**\n * Fixes accessibility issues from Adaptive Card, with undo.\n *\n * @returns {() => void} The undo function, when called, will undo all manipulations by restoring values recorded at the time of the function call.\n */\nfunction fixAccessibilityIssuesWithUndo(element: HTMLElement): UndoFunction {\n  if (!element) {\n    return;\n  }\n\n  // These hacks should be done in Adaptive Cards library instead.\n  // Related to #3949: All action buttons inside role=\"menubar\" should be role=\"menuitem\".\n  const undoStack: UndoFunction[] = Array.from(\n    element.querySelectorAll('.ac-actionSet[role=\"menubar\"] [role=\"button\"]') as NodeListOf<HTMLElement>\n  ).map(actionButton => setAttributeWithUndo(actionButton, 'role', 'menuitem'));\n\n  return () => undoStack.forEach(undo => undo?.());\n}\n\nfunction getFocusableElements(element: HTMLElement) {\n  return [].filter.call(\n    element.querySelectorAll(\n      [\n        'a',\n        'body',\n        'button',\n        'frame',\n        'iframe',\n        'img',\n        'input',\n        'isindex',\n        'object',\n        'select',\n        'textarea',\n        '[tabindex]'\n      ].join(', ')\n    ) as NodeListOf<HTMLElement>,\n    element => {\n      const tabIndex = getTabIndex(element);\n\n      return typeof tabIndex === 'number' && tabIndex >= 0;\n    }\n  );\n}\n\nfunction restoreActiveElementIndex(element: HTMLElement, activeElementIndex: number) {\n  getFocusableElements(element)[+activeElementIndex]?.focus();\n}\n\nfunction saveActiveElementIndex(element: HTMLElement) {\n  return getFocusableElements(element).indexOf(document.activeElement);\n}\n\nfunction restoreInputValues(element: HTMLElement, inputValues: (boolean | string)[]) {\n  const inputs = element.querySelectorAll('input, select, textarea') as NodeListOf<\n    HTMLInputElement | HTMLSelectElement | HTMLTextAreaElement\n  >;\n\n  [].forEach.call(inputs, (input: HTMLInputElement | HTMLSelectElement | HTMLTextAreaElement, index: number) => {\n    const value = inputValues[+index];\n\n    if (typeof value !== 'undefined') {\n      const { tagName, type } = input;\n\n      if (tagName === 'INPUT' && (type === 'checkbox' || type === 'radio')) {\n        if (typeof value === 'boolean') {\n          (input as HTMLInputElement).checked = value;\n        }\n      } else if (typeof value === 'string') {\n        input.value = value;\n      }\n    }\n  });\n}\n\nfunction saveInputValues(element: HTMLElement): (boolean | string)[] {\n  const inputs = element.querySelectorAll('input, select, textarea') as NodeListOf<\n    HTMLInputElement | HTMLSelectElement | HTMLTextAreaElement\n  >;\n\n  return [].map.call(inputs, (input: HTMLInputElement | HTMLSelectElement | HTMLTextAreaElement) => {\n    const { type } = input;\n\n    if (input.tagName === 'INPUT' && (type === 'checkbox' || type === 'radio')) {\n      return (input as HTMLInputElement).checked;\n    }\n\n    return input.value;\n  });\n}\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 [actionsPerformed, setActionsPerformed] = useState<AdaptiveCardAction[]>([]);\n  const [adaptiveCardsHostConfig] = useAdaptiveCardsHostConfig();\n  const [disabledFromComposer] = useDisabled();\n  const [errors, setErrors] = useState([]);\n  const [lastRender, setLastRender] = useState(0);\n  const activeElementIndexRef = useRef(-1);\n  const adaptiveCardElementRef = useRef<HTMLElement>();\n  const contentRef = useRef<HTMLDivElement>();\n  const inputValuesRef = useRef<(boolean | string)[]>([]);\n  const localize = useLocalizer();\n  const performCardAction = usePerformCardAction();\n  const renderMarkdownAsHTML = useRenderMarkdownAsHTML();\n  const scrollToEnd = useScrollToEnd();\n\n  const disabled = disabledFromComposer || disabledFromProps;\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(\n    (event: KeyboardEvent | MouseEvent): 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(tapAction);\n      scrollToEnd();\n    },\n    [contentRef, performCardAction, scrollToEnd, tapAction]\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 addActionsPerformed = useCallback(\n    (action: AdaptiveCardAction): void =>\n      !~actionsPerformed.indexOf(action) && setActionsPerformed([...actionsPerformed, action]),\n    [actionsPerformed, setActionsPerformed]\n  );\n\n  const handleExecuteAction = useCallback(\n    (action: AdaptiveCardAction): void => {\n      // Some items, e.g. tappable image, cannot be disabled thru DOM attributes\n      if (disabled) {\n        return;\n      }\n\n      addActionsPerformed(action);\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    [addActionsPerformed, disabled, performCardAction, scrollToEnd]\n  );\n\n  useLayoutEffect(() => {\n    const { current } = contentRef;\n\n    if (!current || !adaptiveCard) {\n      activeElementIndexRef.current = -1;\n      inputValuesRef.current = [];\n    }\n\n    // Currently, the only way to set the Markdown engine is to set it thru static member of AdaptiveCard class\n\n    // TODO: [P3] Checks if we could make the \"renderMarkdownAsHTML\" per card\n    //       This could be limitations from Adaptive Cards package (not supported as of 1.2.5)\n    //       Because there could be timing difference between .parse and .render, we could be using wrong Markdown engine\n\n    // \"onProcessMarkdown\" is a static function but we are trying to scope it to the current object instead.\n    // eslint-disable-next-line dot-notation\n    adaptiveCard.constructor['onProcessMarkdown'] = (text: string, result: IMarkdownProcessingResult) => {\n      if (renderMarkdownAsHTML) {\n        result.outputHtml = renderMarkdownAsHTML(text);\n        result.didProcess = true;\n      }\n    };\n\n    if (adaptiveCardsHostConfig) {\n      adaptiveCard.hostConfig = isPlainObject(adaptiveCardsHostConfig)\n        ? new HostConfig(adaptiveCardsHostConfig)\n        : adaptiveCardsHostConfig;\n    }\n\n    // For accessibility issue #1340, `tabindex=\"0\"` must not be set for the root container if it is not interactive.\n    GlobalSettings.setTabIndexAtCardRoot = !!tapAction;\n\n    const { validationEvents } = adaptiveCard.validateProperties();\n\n    if (validationEvents.length) {\n      return setErrors(validationEvents.reduce((items, { message }) => [...items, new Error(message)], []));\n    }\n\n    let element: HTMLElement;\n\n    try {\n      element = adaptiveCard.render();\n    } catch (error) {\n      return setErrors([error]);\n    }\n\n    if (!element) {\n      return setErrors([new Error('Adaptive Card rendered as empty element')]);\n    }\n\n    // Clear errors on next render\n    setErrors([]);\n\n    restoreInputValues(element, inputValuesRef.current);\n\n    current.appendChild(element);\n    adaptiveCardElementRef.current = element;\n\n    // Focus can only be restored after the DOM is attached.\n    restoreActiveElementIndex(element, activeElementIndexRef.current);\n\n    setLastRender(Date.now());\n\n    return () => {\n      activeElementIndexRef.current = saveActiveElementIndex(element);\n      inputValuesRef.current = saveInputValues(element);\n\n      current.removeChild(adaptiveCardElementRef.current);\n\n      adaptiveCardElementRef.current = undefined;\n    };\n  }, [\n    adaptiveCard,\n    adaptiveCardsHostConfig,\n    contentRef,\n    GlobalSettings,\n    HostConfig,\n    renderMarkdownAsHTML,\n    setErrors,\n    tapAction\n  ]);\n\n  useEffect(() => {\n    // Set onExecuteAction without causing unnecessary re-render.\n    adaptiveCard.onExecuteAction = disabled ? undefined : handleExecuteAction;\n  }, [adaptiveCard, disabled, handleExecuteAction]);\n\n  useEffect(() => fixAccessibilityIssuesWithUndo(adaptiveCardElementRef.current), [adaptiveCardElementRef, lastRender]);\n\n  useEffect(() => {\n    // If the Adaptive Card get re-rendered, re-disable elements as needed.\n    if (disabled) {\n      return disableInputElementsWithUndo(adaptiveCardElementRef.current);\n    }\n  }, [adaptiveCardElementRef, disabled, lastRender]);\n\n  useEffect(() => {\n    // If the Adaptive Card changed, reset all actions performed.\n    setActionsPerformed([]);\n  }, [adaptiveCard]);\n\n  useEffect(\n    () =>\n      indicateActionSelectionWithUndo(\n        // Actions that do not have \"renderedElement\" means it is the Adaptive Card itself, such as \"selectAction\" (AC) or \"tapAction\" (rich cards).\n        // We do not need to mark the whole card as performed.\n        actionsPerformed.map(({ renderedElement }) => renderedElement).filter(renderedElement => renderedElement),\n        actionPerformedClassName\n      ),\n    [actionsPerformed, actionPerformedClassName, lastRender]\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 unknown as MouseEventHandler<HTMLDivElement>}\n      onKeyPress={handleClickAndKeyPressForTapAction as unknown 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"]}
|
|
274
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../src/adaptiveCards/Attachment/AdaptiveCardRenderer.tsx"],"names":["ErrorBox","Components","useDisabled","hooks","useLocalizer","usePerformCardAction","useRenderMarkdownAsHTML","useScrollToEnd","useStyleSet","node_env","AdaptiveCardRenderer","actionPerformedClassName","adaptiveCard","disabledFromProps","disabled","tapAction","adaptiveCardRendererStyleSet","adaptiveCardRenderer","GlobalSettings","HostConfig","adaptiveCardsHostConfig","disabledFromComposer","contentRef","localize","performCardAction","renderMarkdownAsHTML","scrollToEnd","tapActionRef","disabledRef","handleClickAndKeyPress","event","key","type","target","current","adaptiveCardRoot","querySelector","console","warn","preventDefault","tabIndex","handleClickAndKeyPressForTapAction","undefined","handleExecuteAction","action","actionTypeName","getJsonTypeName","image","iconUrl","title","value","url","data","__isBotFrameworkCardAction","cardAction","error","setTabIndexAtCardRoot","applyActionShouldBePushButtonMod","undoActionShouldBePushButtonMod","applyActionSetShouldNotBeMenuBarMod","undoActionSetShouldNotBeMenuBarMod","applyActiveElementMod","undoActiveElementMod","applyDisabledMod","undoDisabledMod","applyPersistValuesMod","undoPersistValuesMod","adaptiveCardsPackage","element","errors","onExecuteAction","appendChild","removeChild","length","defaultProps","propTypes","PropTypes","string","any","isRequired","bool","shape"],"mappings":"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","sourceRoot":"bundle:///","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"]}
|