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
|
@@ -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 = useDisabledModEffect;
|
|
9
|
+
|
|
10
|
+
var _react = require("react");
|
|
11
|
+
|
|
12
|
+
var _bunchUndos = _interopRequireDefault(require("../../DOMManipulationWithUndo/bunchUndos"));
|
|
13
|
+
|
|
14
|
+
var _durableDisableInputElementAccessiblyWithUndo = _interopRequireDefault(require("../../DOMManipulationWithUndo/durableDisableInputElementAccessiblyWithUndo"));
|
|
15
|
+
|
|
16
|
+
var _useAdaptiveCardModEffect = _interopRequireDefault(require("./private/useAdaptiveCardModEffect"));
|
|
17
|
+
|
|
18
|
+
// This is intended. This is a no-op function and intended to do nothing.
|
|
19
|
+
// eslint-disable-next-line @typescript-eslint/no-empty-function
|
|
20
|
+
var NO_OP = function NO_OP() {}; // In Adaptive Cards, <button> with "aria-expanded" attribute means it is makeshift of <details> and it is Action.ShowCard.
|
|
21
|
+
// In HTML, <details> should not be disabled unless the accordion does not permit the panel to be collapsed.
|
|
22
|
+
// So when we look for input elements, should skip <button> that mimick <details>.
|
|
23
|
+
|
|
24
|
+
|
|
25
|
+
var INPUT_ELEMENT_SELECTOR = 'button:not([aria-expanded]), input, select, textarea';
|
|
26
|
+
|
|
27
|
+
/**
|
|
28
|
+
* Accessibility: Form fields in Adaptive Cards need to be disabled to reduce confusion for screen reader users.
|
|
29
|
+
*
|
|
30
|
+
* One exception is the `Action.ShowUrl`, this is because this action is expand/collapse of an accordion control.
|
|
31
|
+
* Similar to `<details>`/`<summary>`, accordion must not allowed to be disabled.
|
|
32
|
+
*/
|
|
33
|
+
function useDisabledModEffect(adaptiveCard) {
|
|
34
|
+
var modder = (0, _react.useMemo)(function () {
|
|
35
|
+
return function (_, cardElement, disabled) {
|
|
36
|
+
if (!disabled) {
|
|
37
|
+
return NO_OP;
|
|
38
|
+
}
|
|
39
|
+
|
|
40
|
+
var undoStack = Array.from(cardElement.querySelectorAll(INPUT_ELEMENT_SELECTOR)).map(function (element) {
|
|
41
|
+
return (0, _durableDisableInputElementAccessiblyWithUndo.default)(element);
|
|
42
|
+
});
|
|
43
|
+
return function () {
|
|
44
|
+
return (0, _bunchUndos.default)(undoStack)();
|
|
45
|
+
};
|
|
46
|
+
};
|
|
47
|
+
}, []);
|
|
48
|
+
return (0, _useAdaptiveCardModEffect.default)(modder, adaptiveCard);
|
|
49
|
+
}
|
|
50
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3NyYy9hZGFwdGl2ZUNhcmRzL0F0dGFjaG1lbnQvQWRhcHRpdmVDYXJkSGFja3MvdXNlRGlzYWJsZWRNb2RFZmZlY3QudHMiXSwibmFtZXMiOlsiTk9fT1AiLCJJTlBVVF9FTEVNRU5UX1NFTEVDVE9SIiwidXNlRGlzYWJsZWRNb2RFZmZlY3QiLCJhZGFwdGl2ZUNhcmQiLCJtb2RkZXIiLCJfIiwiY2FyZEVsZW1lbnQiLCJkaXNhYmxlZCIsInVuZG9TdGFjayIsIkFycmF5IiwiZnJvbSIsInF1ZXJ5U2VsZWN0b3JBbGwiLCJtYXAiLCJlbGVtZW50Il0sIm1hcHBpbmdzIjoiOzs7Ozs7Ozs7QUFBQTs7QUFFQTs7QUFDQTs7QUFDQTs7QUFLQTtBQUNBO0FBQ0EsSUFBTUEsS0FBbUIsR0FBRyxTQUF0QkEsS0FBc0IsR0FBTSxDQUFFLENBQXBDLEMsQ0FFQTtBQUNBO0FBQ0E7OztBQUNBLElBQU1DLHNCQUFzQixHQUFHLHNEQUEvQjs7QUFHQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDZSxTQUFTQyxvQkFBVCxDQUNiQyxZQURhLEVBRWlFO0FBQzlFLE1BQU1DLE1BQU0sR0FBRyxvQkFDYjtBQUFBLFdBQU0sVUFBQ0MsQ0FBRCxFQUFJQyxXQUFKLEVBQThCQyxRQUE5QixFQUFvRDtBQUN4RCxVQUFJLENBQUNBLFFBQUwsRUFBZTtBQUNiLGVBQU9QLEtBQVA7QUFDRDs7QUFFRCxVQUFNUSxTQUF5QixHQUFHQyxLQUFLLENBQUNDLElBQU4sQ0FDaENKLFdBQVcsQ0FBQ0ssZ0JBQVosQ0FBNkJWLHNCQUE3QixDQURnQyxFQUVoQ1csR0FGZ0MsQ0FFNUIsVUFBQUMsT0FBTztBQUFBLGVBQUksMkRBQTZDQSxPQUE3QyxDQUFKO0FBQUEsT0FGcUIsQ0FBbEM7QUFJQSxhQUFPO0FBQUEsZUFBTSx5QkFBV0wsU0FBWCxHQUFOO0FBQUEsT0FBUDtBQUNELEtBVkQ7QUFBQSxHQURhLEVBWWIsRUFaYSxDQUFmO0FBZUEsU0FBTyx1Q0FBeUJKLE1BQXpCLEVBQWlDRCxZQUFqQyxDQUFQO0FBQ0QiLCJzb3VyY2VSb290IjoiYnVuZGxlOi8vLyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IHVzZU1lbW8gfSBmcm9tICdyZWFjdCc7XG5cbmltcG9ydCBidW5jaFVuZG9zIGZyb20gJy4uLy4uL0RPTU1hbmlwdWxhdGlvbldpdGhVbmRvL2J1bmNoVW5kb3MnO1xuaW1wb3J0IGR1cmFibGVEaXNhYmxlSW5wdXRFbGVtZW50QWNjZXNzaWJseVdpdGhVbmRvIGZyb20gJy4uLy4uL0RPTU1hbmlwdWxhdGlvbldpdGhVbmRvL2R1cmFibGVEaXNhYmxlSW5wdXRFbGVtZW50QWNjZXNzaWJseVdpdGhVbmRvJztcbmltcG9ydCB1c2VBZGFwdGl2ZUNhcmRNb2RFZmZlY3QgZnJvbSAnLi9wcml2YXRlL3VzZUFkYXB0aXZlQ2FyZE1vZEVmZmVjdCc7XG5cbmltcG9ydCB0eXBlIHsgQWRhcHRpdmVDYXJkIH0gZnJvbSAnYWRhcHRpdmVjYXJkcyc7XG5pbXBvcnQgdHlwZSB7IFVuZG9GdW5jdGlvbiB9IGZyb20gJy4uLy4uL0RPTU1hbmlwdWxhdGlvbldpdGhVbmRvL3R5cGVzL1VuZG9GdW5jdGlvbic7XG5cbi8vIFRoaXMgaXMgaW50ZW5kZWQuIFRoaXMgaXMgYSBuby1vcCBmdW5jdGlvbiBhbmQgaW50ZW5kZWQgdG8gZG8gbm90aGluZy5cbi8vIGVzbGludC1kaXNhYmxlLW5leHQtbGluZSBAdHlwZXNjcmlwdC1lc2xpbnQvbm8tZW1wdHktZnVuY3Rpb25cbmNvbnN0IE5PX09QOiBVbmRvRnVuY3Rpb24gPSAoKSA9PiB7fTtcblxuLy8gSW4gQWRhcHRpdmUgQ2FyZHMsIDxidXR0b24+IHdpdGggXCJhcmlhLWV4cGFuZGVkXCIgYXR0cmlidXRlIG1lYW5zIGl0IGlzIG1ha2VzaGlmdCBvZiA8ZGV0YWlscz4gYW5kIGl0IGlzIEFjdGlvbi5TaG93Q2FyZC5cbi8vIEluIEhUTUwsIDxkZXRhaWxzPiBzaG91bGQgbm90IGJlIGRpc2FibGVkIHVubGVzcyB0aGUgYWNjb3JkaW9uIGRvZXMgbm90IHBlcm1pdCB0aGUgcGFuZWwgdG8gYmUgY29sbGFwc2VkLlxuLy8gU28gd2hlbiB3ZSBsb29rIGZvciBpbnB1dCBlbGVtZW50cywgc2hvdWxkIHNraXAgPGJ1dHRvbj4gdGhhdCBtaW1pY2sgPGRldGFpbHM+LlxuY29uc3QgSU5QVVRfRUxFTUVOVF9TRUxFQ1RPUiA9ICdidXR0b246bm90KFthcmlhLWV4cGFuZGVkXSksIGlucHV0LCBzZWxlY3QsIHRleHRhcmVhJztcbnR5cGUgSW5wdXRFbGVtZW50VHlwZSA9IEhUTUxCdXR0b25FbGVtZW50IHwgSFRNTElucHV0RWxlbWVudCB8IEhUTUxTZWxlY3RFbGVtZW50IHwgSFRNTFRleHRBcmVhRWxlbWVudDtcblxuLyoqXG4gKiBBY2Nlc3NpYmlsaXR5OiBGb3JtIGZpZWxkcyBpbiBBZGFwdGl2ZSBDYXJkcyBuZWVkIHRvIGJlIGRpc2FibGVkIHRvIHJlZHVjZSBjb25mdXNpb24gZm9yIHNjcmVlbiByZWFkZXIgdXNlcnMuXG4gKlxuICogT25lIGV4Y2VwdGlvbiBpcyB0aGUgYEFjdGlvbi5TaG93VXJsYCwgdGhpcyBpcyBiZWNhdXNlIHRoaXMgYWN0aW9uIGlzIGV4cGFuZC9jb2xsYXBzZSBvZiBhbiBhY2NvcmRpb24gY29udHJvbC5cbiAqIFNpbWlsYXIgdG8gYDxkZXRhaWxzPmAvYDxzdW1tYXJ5PmAsIGFjY29yZGlvbiBtdXN0IG5vdCBhbGxvd2VkIHRvIGJlIGRpc2FibGVkLlxuICovXG5leHBvcnQgZGVmYXVsdCBmdW5jdGlvbiB1c2VEaXNhYmxlZE1vZEVmZmVjdChcbiAgYWRhcHRpdmVDYXJkOiBBZGFwdGl2ZUNhcmRcbik6IHJlYWRvbmx5IFsoY2FyZEVsZW1lbnQ6IEhUTUxFbGVtZW50LCBkaXNhYmxlZDogYm9vbGVhbikgPT4gdm9pZCwgKCkgPT4gdm9pZF0ge1xuICBjb25zdCBtb2RkZXIgPSB1c2VNZW1vKFxuICAgICgpID0+IChfLCBjYXJkRWxlbWVudDogSFRNTEVsZW1lbnQsIGRpc2FibGVkOiBib29sZWFuKSA9PiB7XG4gICAgICBpZiAoIWRpc2FibGVkKSB7XG4gICAgICAgIHJldHVybiBOT19PUDtcbiAgICAgIH1cblxuICAgICAgY29uc3QgdW5kb1N0YWNrOiAoKCkgPT4gdm9pZClbXSA9IEFycmF5LmZyb20oXG4gICAgICAgIGNhcmRFbGVtZW50LnF1ZXJ5U2VsZWN0b3JBbGwoSU5QVVRfRUxFTUVOVF9TRUxFQ1RPUikgYXMgTm9kZUxpc3RPZjxJbnB1dEVsZW1lbnRUeXBlPlxuICAgICAgKS5tYXAoZWxlbWVudCA9PiBkdXJhYmxlRGlzYWJsZUlucHV0RWxlbWVudEFjY2Vzc2libHlXaXRoVW5kbyhlbGVtZW50KSk7XG5cbiAgICAgIHJldHVybiAoKSA9PiBidW5jaFVuZG9zKHVuZG9TdGFjaykoKTtcbiAgICB9LFxuICAgIFtdXG4gICk7XG5cbiAgcmV0dXJuIHVzZUFkYXB0aXZlQ2FyZE1vZEVmZmVjdChtb2RkZXIsIGFkYXB0aXZlQ2FyZCk7XG59XG4iXX0=
|
|
@@ -0,0 +1,6 @@
|
|
|
1
|
+
import type { AdaptiveCard } from 'adaptivecards';
|
|
2
|
+
/**
|
|
3
|
+
* Re-rendering: Current user-inputted values must be saved and restored on re-render.
|
|
4
|
+
*/
|
|
5
|
+
export default function usePersistValuesModEffect(adaptiveCard: AdaptiveCard): readonly [(cardElement: HTMLElement) => void, () => void];
|
|
6
|
+
//# sourceMappingURL=usePersistValuesModEffect.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"usePersistValuesModEffect.d.ts","sourceRoot":"","sources":["../../../../src/adaptiveCards/Attachment/AdaptiveCardHacks/usePersistValuesModEffect.ts"],"names":[],"mappings":"AAKA,OAAO,KAAK,EAAE,YAAY,EAAc,MAAM,eAAe,CAAC;AAyE9D;;GAEG;AACH,MAAM,CAAC,OAAO,UAAU,yBAAyB,CAAC,YAAY,EAAE,YAAY,6DA4B3E"}
|
|
@@ -0,0 +1,103 @@
|
|
|
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 = usePersistValuesModEffect;
|
|
9
|
+
|
|
10
|
+
var _react = require("react");
|
|
11
|
+
|
|
12
|
+
var _useAdaptiveCardModEffect = _interopRequireDefault(require("./private/useAdaptiveCardModEffect"));
|
|
13
|
+
|
|
14
|
+
var _usePrevious = _interopRequireDefault(require("./private/usePrevious"));
|
|
15
|
+
|
|
16
|
+
/**
|
|
17
|
+
* Gets all user-inputted values under a DOM node.
|
|
18
|
+
*
|
|
19
|
+
* We assume values are ID-ed. If not ID-ed (such as `<textarea>`), there will be only a single instance (no two `<textarea>`).
|
|
20
|
+
*/
|
|
21
|
+
function getUserValues(element) {
|
|
22
|
+
if (!element) {
|
|
23
|
+
return new Set();
|
|
24
|
+
}
|
|
25
|
+
|
|
26
|
+
return Array.from(element.querySelectorAll('input, option, textarea')).reduce(function (values, element) {
|
|
27
|
+
if (element instanceof HTMLInputElement) {
|
|
28
|
+
var type = element.type;
|
|
29
|
+
|
|
30
|
+
if (type === 'checkbox' || type === 'radio') {
|
|
31
|
+
element.checked && values.add(element.value);
|
|
32
|
+
} else {
|
|
33
|
+
// ASSUMPTION: We expect CardObject will NOT mix <input type="text"> with <input type="checkbox">.
|
|
34
|
+
values.clear();
|
|
35
|
+
values.add(element.value);
|
|
36
|
+
}
|
|
37
|
+
} else if (element instanceof HTMLOptionElement) {
|
|
38
|
+
element.selected && values.add(element.value);
|
|
39
|
+
} else {
|
|
40
|
+
// ASSUMPTION: We expect CardObject will NOT mix <textarea> with <input type="checkbox">.
|
|
41
|
+
values.clear();
|
|
42
|
+
values.add(element.value);
|
|
43
|
+
}
|
|
44
|
+
|
|
45
|
+
return values;
|
|
46
|
+
}, new Set());
|
|
47
|
+
}
|
|
48
|
+
/**
|
|
49
|
+
* Set multiple user-inputted values under a DOM node.
|
|
50
|
+
*
|
|
51
|
+
* This function must be paired with `getUserValues`.
|
|
52
|
+
*/
|
|
53
|
+
|
|
54
|
+
|
|
55
|
+
function setUserValues(element, values) {
|
|
56
|
+
if (!element) {
|
|
57
|
+
return;
|
|
58
|
+
} // If the element does not support multiple choices, say <input type="text"> or <textarea>, then, use the first value.
|
|
59
|
+
|
|
60
|
+
|
|
61
|
+
var defaultValue = Array.from(values)[0] || '';
|
|
62
|
+
element.querySelectorAll('input, option, textarea').forEach(function (element) {
|
|
63
|
+
if (element instanceof HTMLInputElement) {
|
|
64
|
+
var type = element.type;
|
|
65
|
+
|
|
66
|
+
if (type === 'checkbox' || type === 'radio') {
|
|
67
|
+
element.checked = values.has(element.value);
|
|
68
|
+
} else {
|
|
69
|
+
element.value = defaultValue;
|
|
70
|
+
}
|
|
71
|
+
} else if (element instanceof HTMLOptionElement) {
|
|
72
|
+
element.selected = values.has(element.value);
|
|
73
|
+
} else {
|
|
74
|
+
element.value = defaultValue;
|
|
75
|
+
}
|
|
76
|
+
});
|
|
77
|
+
}
|
|
78
|
+
/**
|
|
79
|
+
* Re-rendering: Current user-inputted values must be saved and restored on re-render.
|
|
80
|
+
*/
|
|
81
|
+
|
|
82
|
+
|
|
83
|
+
function usePersistValuesModEffect(adaptiveCard) {
|
|
84
|
+
var prevAdaptiveCard = (0, _usePrevious.default)(adaptiveCard);
|
|
85
|
+
var valuesMapRef = (0, _react.useRef)(new Map());
|
|
86
|
+
prevAdaptiveCard === adaptiveCard || valuesMapRef.current.clear();
|
|
87
|
+
var modder = (0, _react.useMemo)(function () {
|
|
88
|
+
return function (adaptiveCard) {
|
|
89
|
+
var valuesMap = valuesMapRef.current;
|
|
90
|
+
adaptiveCard.getAllInputs().forEach(function (cardObject) {
|
|
91
|
+
valuesMap.has(cardObject) && setUserValues(cardObject.renderedElement, valuesMap.get(cardObject));
|
|
92
|
+
});
|
|
93
|
+
return function () {
|
|
94
|
+
valuesMapRef.current = adaptiveCard.getAllInputs().reduce(function (valuesMap, cardObject) {
|
|
95
|
+
var value = getUserValues(cardObject.renderedElement);
|
|
96
|
+
return typeof value !== 'undefined' ? valuesMap.set(cardObject, value) : valuesMap;
|
|
97
|
+
}, new Map());
|
|
98
|
+
};
|
|
99
|
+
};
|
|
100
|
+
}, [valuesMapRef]);
|
|
101
|
+
return (0, _useAdaptiveCardModEffect.default)(modder, adaptiveCard);
|
|
102
|
+
}
|
|
103
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../../src/adaptiveCards/Attachment/AdaptiveCardHacks/usePersistValuesModEffect.ts"],"names":["getUserValues","element","Set","Array","from","querySelectorAll","reduce","values","HTMLInputElement","type","checked","add","value","clear","HTMLOptionElement","selected","setUserValues","defaultValue","forEach","has","usePersistValuesModEffect","adaptiveCard","prevAdaptiveCard","valuesMapRef","Map","current","modder","valuesMap","getAllInputs","cardObject","renderedElement","get","set"],"mappings":"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","sourceRoot":"bundle:///","sourcesContent":["import { useMemo, useRef } from 'react';\n\nimport useAdaptiveCardModEffect from './private/useAdaptiveCardModEffect';\nimport usePrevious from './private/usePrevious';\n\nimport type { AdaptiveCard, CardObject } from 'adaptivecards';\n\n/**\n * Gets all user-inputted values under a DOM node.\n *\n * We assume values are ID-ed. If not ID-ed (such as `<textarea>`), there will be only a single instance (no two `<textarea>`).\n */\nfunction getUserValues(element: HTMLElement | undefined): Set<string> {\n  if (!element) {\n    return new Set();\n  }\n\n  return Array.from(\n    element.querySelectorAll('input, option, textarea') as NodeListOf<\n      HTMLInputElement | HTMLOptionElement | HTMLTextAreaElement\n    >\n  ).reduce<Set<string>>((values, element) => {\n    if (element instanceof HTMLInputElement) {\n      const { type } = element;\n\n      if (type === 'checkbox' || type === 'radio') {\n        element.checked && values.add(element.value);\n      } else {\n        // ASSUMPTION: We expect CardObject will NOT mix <input type=\"text\"> with <input type=\"checkbox\">.\n        values.clear();\n        values.add(element.value);\n      }\n    } else if (element instanceof HTMLOptionElement) {\n      element.selected && values.add(element.value);\n    } else {\n      // ASSUMPTION: We expect CardObject will NOT mix <textarea> with <input type=\"checkbox\">.\n      values.clear();\n      values.add(element.value);\n    }\n\n    return values;\n  }, new Set());\n}\n\n/**\n * Set multiple user-inputted values under a DOM node.\n *\n * This function must be paired with `getUserValues`.\n */\nfunction setUserValues(element: HTMLElement | undefined, values: Set<string>): void {\n  if (!element) {\n    return;\n  }\n\n  // If the element does not support multiple choices, say <input type=\"text\"> or <textarea>, then, use the first value.\n  const defaultValue = Array.from(values)[0] || '';\n\n  (\n    element.querySelectorAll('input, option, textarea') as NodeListOf<\n      HTMLInputElement | HTMLOptionElement | HTMLTextAreaElement\n    >\n  ).forEach(element => {\n    if (element instanceof HTMLInputElement) {\n      const { type } = element;\n\n      if (type === 'checkbox' || type === 'radio') {\n        element.checked = values.has(element.value);\n      } else {\n        element.value = defaultValue;\n      }\n    } else if (element instanceof HTMLOptionElement) {\n      element.selected = values.has(element.value);\n    } else {\n      element.value = defaultValue;\n    }\n  });\n}\n\n/**\n * Re-rendering: Current user-inputted values must be saved and restored on re-render.\n */\nexport default function usePersistValuesModEffect(adaptiveCard: AdaptiveCard) {\n  const prevAdaptiveCard = usePrevious(adaptiveCard);\n  const valuesMapRef = useRef<Map<CardObject, Set<string>>>(new Map());\n\n  prevAdaptiveCard === adaptiveCard || valuesMapRef.current.clear();\n\n  const modder = useMemo(\n    () => (adaptiveCard: AdaptiveCard) => {\n      const { current: valuesMap } = valuesMapRef;\n\n      adaptiveCard.getAllInputs().forEach(cardObject => {\n        valuesMap.has(cardObject) && setUserValues(cardObject.renderedElement, valuesMap.get(cardObject));\n      });\n\n      return () => {\n        valuesMapRef.current = adaptiveCard\n          .getAllInputs()\n          .reduce<Map<CardObject, Set<string>>>((valuesMap, cardObject) => {\n            const value = getUserValues(cardObject.renderedElement);\n\n            return typeof value !== 'undefined' ? valuesMap.set(cardObject, value) : valuesMap;\n          }, new Map());\n      };\n    },\n    [valuesMapRef]\n  );\n\n  return useAdaptiveCardModEffect(modder, adaptiveCard);\n}\n"]}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"AdaptiveCardRenderer.d.ts","sourceRoot":"","sources":["../../../src/adaptiveCards/Attachment/AdaptiveCardRenderer.tsx"],"names":[],"mappings":"AAEA,OAAO,
|
|
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;AAkBtE,aAAK,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,CA6MxD,CAAC;AAuBF,eAAe,oBAAoB,CAAC"}
|