@angular/core 18.0.0-next.5 → 18.0.0-next.6
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/esm2022/primitives/event-dispatch/contract_binary.mjs +10 -0
- package/esm2022/primitives/event-dispatch/index.mjs +13 -0
- package/esm2022/primitives/event-dispatch/src/a11y_click.mjs +54 -0
- package/esm2022/primitives/event-dispatch/src/accessibility.mjs +35 -0
- package/esm2022/primitives/event-dispatch/src/attribute.mjs +72 -0
- package/esm2022/primitives/event-dispatch/src/base_dispatcher.mjs +196 -0
- package/esm2022/primitives/event-dispatch/src/cache.mjs +95 -0
- package/esm2022/primitives/event-dispatch/src/char.mjs +35 -0
- package/esm2022/primitives/event-dispatch/src/custom_events.mjs +63 -0
- package/esm2022/primitives/event-dispatch/src/dispatcher.mjs +254 -0
- package/esm2022/primitives/event-dispatch/src/dom.mjs +48 -0
- package/esm2022/primitives/event-dispatch/src/earlyeventcontract.mjs +36 -0
- package/esm2022/primitives/event-dispatch/src/event.mjs +638 -0
- package/esm2022/primitives/event-dispatch/src/event_contract_container.mjs +63 -0
- package/esm2022/primitives/event-dispatch/src/event_contract_defines.mjs +48 -0
- package/esm2022/primitives/event-dispatch/src/event_contract_multi_container.mjs +192 -0
- package/esm2022/primitives/event-dispatch/src/event_handler.mjs +9 -0
- package/esm2022/primitives/event-dispatch/src/event_info.mjs +199 -0
- package/esm2022/primitives/event-dispatch/src/event_type.mjs +244 -0
- package/esm2022/primitives/event-dispatch/src/eventcontract.mjs +675 -0
- package/esm2022/primitives/event-dispatch/src/key_code.mjs +21 -0
- package/esm2022/primitives/event-dispatch/src/legacy_dispatcher.mjs +9 -0
- package/esm2022/primitives/event-dispatch/src/property.mjs +35 -0
- package/esm2022/primitives/event-dispatch/src/register_events.mjs +32 -0
- package/esm2022/primitives/event-dispatch/src/replay.mjs +389 -0
- package/esm2022/primitives/event-dispatch/src/restriction.mjs +15 -0
- package/esm2022/primitives/signals/index.mjs +3 -3
- package/esm2022/primitives/signals/src/computed.mjs +5 -3
- package/esm2022/primitives/signals/src/graph.mjs +14 -9
- package/esm2022/primitives/signals/src/signal.mjs +2 -2
- package/esm2022/primitives/signals/src/watch.mjs +2 -2
- package/esm2022/src/change_detection/scheduling/zoneless_scheduling_impl.mjs +50 -5
- package/esm2022/src/core.mjs +2 -1
- package/esm2022/src/core_private_export.mjs +2 -1
- package/esm2022/src/defer/instructions.mjs +31 -8
- package/esm2022/src/di/host_tag_name_token.mjs +65 -0
- package/esm2022/src/di/index.mjs +2 -1
- package/esm2022/src/errors.mjs +1 -1
- package/esm2022/src/hydration/annotate.mjs +15 -1
- package/esm2022/src/hydration/event_replay.mjs +181 -0
- package/esm2022/src/hydration/tokens.mjs +6 -1
- package/esm2022/src/pending_tasks.mjs +54 -11
- package/esm2022/src/render3/component_ref.mjs +1 -1
- package/esm2022/src/render3/context_discovery.mjs +15 -1
- package/esm2022/src/render3/instructions/control_flow.mjs +50 -3
- package/esm2022/src/render3/list_reconciliation.mjs +41 -1
- package/esm2022/src/util/callback_scheduler.mjs +13 -2
- package/esm2022/src/version.mjs +1 -1
- package/esm2022/src/zone/ng_zone.mjs +22 -6
- package/esm2022/testing/src/async.mjs +2 -10
- package/esm2022/testing/src/defer.mjs +1 -2
- package/esm2022/testing/src/logger.mjs +3 -3
- package/event-dispatch-contract.min.js +1 -1
- package/fesm2022/core.mjs +516 -39
- package/fesm2022/core.mjs.map +1 -1
- package/fesm2022/primitives/event-dispatch.mjs +3044 -0
- package/fesm2022/primitives/event-dispatch.mjs.map +1 -0
- package/fesm2022/primitives/signals.mjs +17 -10
- package/fesm2022/primitives/signals.mjs.map +1 -1
- package/fesm2022/rxjs-interop.mjs +1 -1
- package/fesm2022/testing.mjs +3 -12
- package/fesm2022/testing.mjs.map +1 -1
- package/index.d.ts +75 -13
- package/package.json +7 -1
- package/primitives/event-dispatch/index.d.ts +627 -0
- package/primitives/signals/index.d.ts +1 -1
- package/rxjs-interop/index.d.ts +1 -1
- package/schematics/migrations/{transfer-state → http-providers}/bundle.js +254 -68
- package/schematics/migrations/http-providers/bundle.js.map +7 -0
- package/schematics/migrations/invalid-two-way-bindings/bundle.js +659 -337
- package/schematics/migrations/invalid-two-way-bindings/bundle.js.map +2 -2
- package/schematics/migrations.json +6 -16
- package/schematics/ng-generate/control-flow-migration/bundle.js +667 -345
- package/schematics/ng-generate/control-flow-migration/bundle.js.map +2 -2
- package/schematics/ng-generate/standalone-migration/bundle.js +1030 -660
- package/schematics/ng-generate/standalone-migration/bundle.js.map +2 -2
- package/testing/index.d.ts +2 -9
- package/schematics/migrations/block-template-entities/bundle.js +0 -22808
- package/schematics/migrations/block-template-entities/bundle.js.map +0 -7
- package/schematics/migrations/compiler-options/bundle.js +0 -582
- package/schematics/migrations/compiler-options/bundle.js.map +0 -7
- package/schematics/migrations/transfer-state/bundle.js.map +0 -7
|
@@ -0,0 +1,63 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* @license
|
|
3
|
+
* Copyright Google LLC All Rights Reserved.
|
|
4
|
+
*
|
|
5
|
+
* Use of this source code is governed by an MIT-style license that can be
|
|
6
|
+
* found in the LICENSE file at https://angular.io/license
|
|
7
|
+
*/
|
|
8
|
+
import * as eventLib from './event';
|
|
9
|
+
/**
|
|
10
|
+
* Whether the user agent is running on iOS.
|
|
11
|
+
*/
|
|
12
|
+
const isIos = typeof navigator !== 'undefined' && /iPhone|iPad|iPod/.test(navigator.userAgent);
|
|
13
|
+
/**
|
|
14
|
+
* A class representing a container node and all the event handlers
|
|
15
|
+
* installed on it. Used so that handlers can be cleaned up if the
|
|
16
|
+
* container is removed from the contract.
|
|
17
|
+
*/
|
|
18
|
+
export class EventContractContainer {
|
|
19
|
+
/**
|
|
20
|
+
* @param element The container Element.
|
|
21
|
+
*/
|
|
22
|
+
constructor(element) {
|
|
23
|
+
this.element = element;
|
|
24
|
+
/**
|
|
25
|
+
* Array of event handlers and their corresponding event types that are
|
|
26
|
+
* installed on this container.
|
|
27
|
+
*
|
|
28
|
+
*/
|
|
29
|
+
this.handlerInfos = [];
|
|
30
|
+
}
|
|
31
|
+
/**
|
|
32
|
+
* Installs the provided installer on the element owned by this container,
|
|
33
|
+
* and maintains a reference to resulting handler in order to remove it
|
|
34
|
+
* later if desired.
|
|
35
|
+
*/
|
|
36
|
+
addEventListener(eventType, getHandler) {
|
|
37
|
+
// In iOS, event bubbling doesn't happen automatically in any DOM element,
|
|
38
|
+
// unless it has an onclick attribute or DOM event handler attached to it.
|
|
39
|
+
// This breaks JsAction in some cases. See "Making Elements Clickable"
|
|
40
|
+
// section at http://goo.gl/2VoGnB.
|
|
41
|
+
//
|
|
42
|
+
// A workaround for this issue is to change the CSS cursor style to 'pointer'
|
|
43
|
+
// for the container element, which magically turns on event bubbling. This
|
|
44
|
+
// solution is described in the comments section at http://goo.gl/6pEO1z.
|
|
45
|
+
//
|
|
46
|
+
// We use a navigator.userAgent check here as this problem is present both
|
|
47
|
+
// on Mobile Safari and thin WebKit wrappers, such as Chrome for iOS.
|
|
48
|
+
if (isIos) {
|
|
49
|
+
this.element.style.cursor = 'pointer';
|
|
50
|
+
}
|
|
51
|
+
this.handlerInfos.push(eventLib.addEventListener(this.element, eventType, getHandler(this.element)));
|
|
52
|
+
}
|
|
53
|
+
/**
|
|
54
|
+
* Removes all the handlers installed on this container.
|
|
55
|
+
*/
|
|
56
|
+
cleanUp() {
|
|
57
|
+
for (let i = 0; i < this.handlerInfos.length; i++) {
|
|
58
|
+
eventLib.removeEventListener(this.element, this.handlerInfos[i]);
|
|
59
|
+
}
|
|
60
|
+
this.handlerInfos = [];
|
|
61
|
+
}
|
|
62
|
+
}
|
|
63
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZXZlbnRfY29udHJhY3RfY29udGFpbmVyLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vcGFja2FnZXMvY29yZS9wcmltaXRpdmVzL2V2ZW50LWRpc3BhdGNoL3NyYy9ldmVudF9jb250cmFjdF9jb250YWluZXIudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUE7Ozs7OztHQU1HO0FBRUgsT0FBTyxLQUFLLFFBQVEsTUFBTSxTQUFTLENBQUM7QUFnQnBDOztHQUVHO0FBQ0gsTUFBTSxLQUFLLEdBQUcsT0FBTyxTQUFTLEtBQUssV0FBVyxJQUFJLGtCQUFrQixDQUFDLElBQUksQ0FBQyxTQUFTLENBQUMsU0FBUyxDQUFDLENBQUM7QUFFL0Y7Ozs7R0FJRztBQUNILE1BQU0sT0FBTyxzQkFBc0I7SUFRakM7O09BRUc7SUFDSCxZQUFxQixPQUFnQjtRQUFoQixZQUFPLEdBQVAsT0FBTyxDQUFTO1FBVnJDOzs7O1dBSUc7UUFDSyxpQkFBWSxHQUF1QixFQUFFLENBQUM7SUFLTixDQUFDO0lBRXpDOzs7O09BSUc7SUFDSCxnQkFBZ0IsQ0FBQyxTQUFpQixFQUFFLFVBQXdEO1FBQzFGLDBFQUEwRTtRQUMxRSwwRUFBMEU7UUFDMUUsc0VBQXNFO1FBQ3RFLG1DQUFtQztRQUNuQyxFQUFFO1FBQ0YsNkVBQTZFO1FBQzdFLDJFQUEyRTtRQUMzRSx5RUFBeUU7UUFDekUsRUFBRTtRQUNGLDBFQUEwRTtRQUMxRSxxRUFBcUU7UUFDckUsSUFBSSxLQUFLLEVBQUUsQ0FBQztZQUNULElBQUksQ0FBQyxPQUF1QixDQUFDLEtBQUssQ0FBQyxNQUFNLEdBQUcsU0FBUyxDQUFDO1FBQ3pELENBQUM7UUFDRCxJQUFJLENBQUMsWUFBWSxDQUFDLElBQUksQ0FDcEIsUUFBUSxDQUFDLGdCQUFnQixDQUFDLElBQUksQ0FBQyxPQUFPLEVBQUUsU0FBUyxFQUFFLFVBQVUsQ0FBQyxJQUFJLENBQUMsT0FBTyxDQUFDLENBQUMsQ0FDN0UsQ0FBQztJQUNKLENBQUM7SUFFRDs7T0FFRztJQUNILE9BQU87UUFDTCxLQUFLLElBQUksQ0FBQyxHQUFHLENBQUMsRUFBRSxDQUFDLEdBQUcsSUFBSSxDQUFDLFlBQVksQ0FBQyxNQUFNLEVBQUUsQ0FBQyxFQUFFLEVBQUUsQ0FBQztZQUNsRCxRQUFRLENBQUMsbUJBQW1CLENBQUMsSUFBSSxDQUFDLE9BQU8sRUFBRSxJQUFJLENBQUMsWUFBWSxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUM7UUFDbkUsQ0FBQztRQUVELElBQUksQ0FBQyxZQUFZLEdBQUcsRUFBRSxDQUFDO0lBQ3pCLENBQUM7Q0FDRiIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogQGxpY2Vuc2VcbiAqIENvcHlyaWdodCBHb29nbGUgTExDIEFsbCBSaWdodHMgUmVzZXJ2ZWQuXG4gKlxuICogVXNlIG9mIHRoaXMgc291cmNlIGNvZGUgaXMgZ292ZXJuZWQgYnkgYW4gTUlULXN0eWxlIGxpY2Vuc2UgdGhhdCBjYW4gYmVcbiAqIGZvdW5kIGluIHRoZSBMSUNFTlNFIGZpbGUgYXQgaHR0cHM6Ly9hbmd1bGFyLmlvL2xpY2Vuc2VcbiAqL1xuXG5pbXBvcnQgKiBhcyBldmVudExpYiBmcm9tICcuL2V2ZW50JztcbmltcG9ydCB7RXZlbnRIYW5kbGVySW5mb30gZnJvbSAnLi9ldmVudF9oYW5kbGVyJztcblxuLyoqXG4gKiBBbiBgRXZlbnRDb250cmFjdENvbnRhaW5lck1hbmFnZXJgIHByb3ZpZGVzIHRoZSBjb21tb24gaW50ZXJmYWNlIGZvciBtYW5hZ2luZ1xuICogY29udGFpbmVycy5cbiAqL1xuZXhwb3J0IGludGVyZmFjZSBFdmVudENvbnRyYWN0Q29udGFpbmVyTWFuYWdlciB7XG4gIGFkZEV2ZW50TGlzdGVuZXIoXG4gICAgZXZlbnRUeXBlOiBzdHJpbmcsXG4gICAgZ2V0SGFuZGxlcjogKGVsZW1lbnQ6IEVsZW1lbnQpID0+IChldmVudDogRXZlbnQpID0+IHZvaWQsXG4gICk6IHZvaWQ7XG5cbiAgY2xlYW5VcCgpOiB2b2lkO1xufVxuXG4vKipcbiAqIFdoZXRoZXIgdGhlIHVzZXIgYWdlbnQgaXMgcnVubmluZyBvbiBpT1MuXG4gKi9cbmNvbnN0IGlzSW9zID0gdHlwZW9mIG5hdmlnYXRvciAhPT0gJ3VuZGVmaW5lZCcgJiYgL2lQaG9uZXxpUGFkfGlQb2QvLnRlc3QobmF2aWdhdG9yLnVzZXJBZ2VudCk7XG5cbi8qKlxuICogQSBjbGFzcyByZXByZXNlbnRpbmcgYSBjb250YWluZXIgbm9kZSBhbmQgYWxsIHRoZSBldmVudCBoYW5kbGVyc1xuICogaW5zdGFsbGVkIG9uIGl0LiBVc2VkIHNvIHRoYXQgaGFuZGxlcnMgY2FuIGJlIGNsZWFuZWQgdXAgaWYgdGhlXG4gKiBjb250YWluZXIgaXMgcmVtb3ZlZCBmcm9tIHRoZSBjb250cmFjdC5cbiAqL1xuZXhwb3J0IGNsYXNzIEV2ZW50Q29udHJhY3RDb250YWluZXIgaW1wbGVtZW50cyBFdmVudENvbnRyYWN0Q29udGFpbmVyTWFuYWdlciB7XG4gIC8qKlxuICAgKiBBcnJheSBvZiBldmVudCBoYW5kbGVycyBhbmQgdGhlaXIgY29ycmVzcG9uZGluZyBldmVudCB0eXBlcyB0aGF0IGFyZVxuICAgKiBpbnN0YWxsZWQgb24gdGhpcyBjb250YWluZXIuXG4gICAqXG4gICAqL1xuICBwcml2YXRlIGhhbmRsZXJJbmZvczogRXZlbnRIYW5kbGVySW5mb1tdID0gW107XG5cbiAgLyoqXG4gICAqIEBwYXJhbSBlbGVtZW50IFRoZSBjb250YWluZXIgRWxlbWVudC5cbiAgICovXG4gIGNvbnN0cnVjdG9yKHJlYWRvbmx5IGVsZW1lbnQ6IEVsZW1lbnQpIHt9XG5cbiAgLyoqXG4gICAqIEluc3RhbGxzIHRoZSBwcm92aWRlZCBpbnN0YWxsZXIgb24gdGhlIGVsZW1lbnQgb3duZWQgYnkgdGhpcyBjb250YWluZXIsXG4gICAqIGFuZCBtYWludGFpbnMgYSByZWZlcmVuY2UgdG8gcmVzdWx0aW5nIGhhbmRsZXIgaW4gb3JkZXIgdG8gcmVtb3ZlIGl0XG4gICAqIGxhdGVyIGlmIGRlc2lyZWQuXG4gICAqL1xuICBhZGRFdmVudExpc3RlbmVyKGV2ZW50VHlwZTogc3RyaW5nLCBnZXRIYW5kbGVyOiAoZWxlbWVudDogRWxlbWVudCkgPT4gKGV2ZW50OiBFdmVudCkgPT4gdm9pZCkge1xuICAgIC8vIEluIGlPUywgZXZlbnQgYnViYmxpbmcgZG9lc24ndCBoYXBwZW4gYXV0b21hdGljYWxseSBpbiBhbnkgRE9NIGVsZW1lbnQsXG4gICAgLy8gdW5sZXNzIGl0IGhhcyBhbiBvbmNsaWNrIGF0dHJpYnV0ZSBvciBET00gZXZlbnQgaGFuZGxlciBhdHRhY2hlZCB0byBpdC5cbiAgICAvLyBUaGlzIGJyZWFrcyBKc0FjdGlvbiBpbiBzb21lIGNhc2VzLiBTZWUgXCJNYWtpbmcgRWxlbWVudHMgQ2xpY2thYmxlXCJcbiAgICAvLyBzZWN0aW9uIGF0IGh0dHA6Ly9nb28uZ2wvMlZvR25CLlxuICAgIC8vXG4gICAgLy8gQSB3b3JrYXJvdW5kIGZvciB0aGlzIGlzc3VlIGlzIHRvIGNoYW5nZSB0aGUgQ1NTIGN1cnNvciBzdHlsZSB0byAncG9pbnRlcidcbiAgICAvLyBmb3IgdGhlIGNvbnRhaW5lciBlbGVtZW50LCB3aGljaCBtYWdpY2FsbHkgdHVybnMgb24gZXZlbnQgYnViYmxpbmcuIFRoaXNcbiAgICAvLyBzb2x1dGlvbiBpcyBkZXNjcmliZWQgaW4gdGhlIGNvbW1lbnRzIHNlY3Rpb24gYXQgaHR0cDovL2dvby5nbC82cEVPMXouXG4gICAgLy9cbiAgICAvLyBXZSB1c2UgYSBuYXZpZ2F0b3IudXNlckFnZW50IGNoZWNrIGhlcmUgYXMgdGhpcyBwcm9ibGVtIGlzIHByZXNlbnQgYm90aFxuICAgIC8vIG9uIE1vYmlsZSBTYWZhcmkgYW5kIHRoaW4gV2ViS2l0IHdyYXBwZXJzLCBzdWNoIGFzIENocm9tZSBmb3IgaU9TLlxuICAgIGlmIChpc0lvcykge1xuICAgICAgKHRoaXMuZWxlbWVudCBhcyBIVE1MRWxlbWVudCkuc3R5bGUuY3Vyc29yID0gJ3BvaW50ZXInO1xuICAgIH1cbiAgICB0aGlzLmhhbmRsZXJJbmZvcy5wdXNoKFxuICAgICAgZXZlbnRMaWIuYWRkRXZlbnRMaXN0ZW5lcih0aGlzLmVsZW1lbnQsIGV2ZW50VHlwZSwgZ2V0SGFuZGxlcih0aGlzLmVsZW1lbnQpKSxcbiAgICApO1xuICB9XG5cbiAgLyoqXG4gICAqIFJlbW92ZXMgYWxsIHRoZSBoYW5kbGVycyBpbnN0YWxsZWQgb24gdGhpcyBjb250YWluZXIuXG4gICAqL1xuICBjbGVhblVwKCkge1xuICAgIGZvciAobGV0IGkgPSAwOyBpIDwgdGhpcy5oYW5kbGVySW5mb3MubGVuZ3RoOyBpKyspIHtcbiAgICAgIGV2ZW50TGliLnJlbW92ZUV2ZW50TGlzdGVuZXIodGhpcy5lbGVtZW50LCB0aGlzLmhhbmRsZXJJbmZvc1tpXSk7XG4gICAgfVxuXG4gICAgdGhpcy5oYW5kbGVySW5mb3MgPSBbXTtcbiAgfVxufVxuIl19
|
|
@@ -0,0 +1,48 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* @license
|
|
3
|
+
* Copyright Google LLC All Rights Reserved.
|
|
4
|
+
*
|
|
5
|
+
* Use of this source code is governed by an MIT-style license that can be
|
|
6
|
+
* found in the LICENSE file at https://angular.io/license
|
|
7
|
+
*/
|
|
8
|
+
/**
|
|
9
|
+
* @define Support for jsnamespace attribute. This flag can be overridden in a
|
|
10
|
+
* build rule to trim down the EventContract's binary size.
|
|
11
|
+
*/
|
|
12
|
+
export const JSNAMESPACE_SUPPORT = true;
|
|
13
|
+
/**
|
|
14
|
+
* @define Handles a11y click casting in the dispatcher rather than
|
|
15
|
+
* the event contract. When enabled, it will enable
|
|
16
|
+
* EventContract.A11Y_CLICK_SUPPORT as well as both are required for this
|
|
17
|
+
* functionality.
|
|
18
|
+
*/
|
|
19
|
+
export const A11Y_SUPPORT_IN_DISPATCHER = false;
|
|
20
|
+
/**
|
|
21
|
+
* @define Support for accessible click actions. This flag can be overridden in
|
|
22
|
+
* a build rule.
|
|
23
|
+
*/
|
|
24
|
+
const A11Y_CLICK_SUPPORT_FLAG_ENABLED = false;
|
|
25
|
+
/**
|
|
26
|
+
* Enables a11y click casting when either A11Y_CLICK_SUPPORT_FLAG_ENABLED or
|
|
27
|
+
* A11Y_SUPPORT_IN_DISPATCHER.
|
|
28
|
+
*/
|
|
29
|
+
export const A11Y_CLICK_SUPPORT = A11Y_CLICK_SUPPORT_FLAG_ENABLED || A11Y_SUPPORT_IN_DISPATCHER;
|
|
30
|
+
/**
|
|
31
|
+
* @define Support for the non-bubbling mouseenter and mouseleave events. This
|
|
32
|
+
* flag can be overridden in a build rule.
|
|
33
|
+
*/
|
|
34
|
+
export const MOUSE_SPECIAL_SUPPORT = false;
|
|
35
|
+
/**
|
|
36
|
+
* @define Call stopPropagation on handled events. When integrating with
|
|
37
|
+
* non-jsaction event handler based code, you will likely want to turn this flag
|
|
38
|
+
* off. While most event handlers will continue to work, jsaction binds focus
|
|
39
|
+
* and blur events in the capture phase and thus with stopPropagation, none of
|
|
40
|
+
* your non-jsaction-handlers will ever see it.
|
|
41
|
+
*/
|
|
42
|
+
export const STOP_PROPAGATION = true;
|
|
43
|
+
/**
|
|
44
|
+
* @define Support for custom events, which are type EventType.CUSTOM. These are
|
|
45
|
+
* native DOM events with an additional type field and an optional payload.
|
|
46
|
+
*/
|
|
47
|
+
export const CUSTOM_EVENT_SUPPORT = false;
|
|
48
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZXZlbnRfY29udHJhY3RfZGVmaW5lcy5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uLy4uL3BhY2thZ2VzL2NvcmUvcHJpbWl0aXZlcy9ldmVudC1kaXNwYXRjaC9zcmMvZXZlbnRfY29udHJhY3RfZGVmaW5lcy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQTs7Ozs7O0dBTUc7QUFFSDs7O0dBR0c7QUFDSCxNQUFNLENBQUMsTUFBTSxtQkFBbUIsR0FBRyxJQUFJLENBQUM7QUFFeEM7Ozs7O0dBS0c7QUFDSCxNQUFNLENBQUMsTUFBTSwwQkFBMEIsR0FBRyxLQUFLLENBQUM7QUFFaEQ7OztHQUdHO0FBQ0gsTUFBTSwrQkFBK0IsR0FBRyxLQUFLLENBQUM7QUFFOUM7OztHQUdHO0FBQ0gsTUFBTSxDQUFDLE1BQU0sa0JBQWtCLEdBQUcsK0JBQStCLElBQUksMEJBQTBCLENBQUM7QUFFaEc7OztHQUdHO0FBQ0gsTUFBTSxDQUFDLE1BQU0scUJBQXFCLEdBQUcsS0FBSyxDQUFDO0FBRTNDOzs7Ozs7R0FNRztBQUNILE1BQU0sQ0FBQyxNQUFNLGdCQUFnQixHQUFHLElBQUksQ0FBQztBQUVyQzs7O0dBR0c7QUFDSCxNQUFNLENBQUMsTUFBTSxvQkFBb0IsR0FBRyxLQUFLLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyIvKipcbiAqIEBsaWNlbnNlXG4gKiBDb3B5cmlnaHQgR29vZ2xlIExMQyBBbGwgUmlnaHRzIFJlc2VydmVkLlxuICpcbiAqIFVzZSBvZiB0aGlzIHNvdXJjZSBjb2RlIGlzIGdvdmVybmVkIGJ5IGFuIE1JVC1zdHlsZSBsaWNlbnNlIHRoYXQgY2FuIGJlXG4gKiBmb3VuZCBpbiB0aGUgTElDRU5TRSBmaWxlIGF0IGh0dHBzOi8vYW5ndWxhci5pby9saWNlbnNlXG4gKi9cblxuLyoqXG4gKiBAZGVmaW5lIFN1cHBvcnQgZm9yIGpzbmFtZXNwYWNlIGF0dHJpYnV0ZS4gIFRoaXMgZmxhZyBjYW4gYmUgb3ZlcnJpZGRlbiBpbiBhXG4gKiBidWlsZCBydWxlIHRvIHRyaW0gZG93biB0aGUgRXZlbnRDb250cmFjdCdzIGJpbmFyeSBzaXplLlxuICovXG5leHBvcnQgY29uc3QgSlNOQU1FU1BBQ0VfU1VQUE9SVCA9IHRydWU7XG5cbi8qKlxuICogQGRlZmluZSBIYW5kbGVzIGExMXkgY2xpY2sgY2FzdGluZyBpbiB0aGUgZGlzcGF0Y2hlciByYXRoZXIgdGhhblxuICogdGhlIGV2ZW50IGNvbnRyYWN0LiBXaGVuIGVuYWJsZWQsIGl0IHdpbGwgZW5hYmxlXG4gKiBFdmVudENvbnRyYWN0LkExMVlfQ0xJQ0tfU1VQUE9SVCBhcyB3ZWxsIGFzIGJvdGggYXJlIHJlcXVpcmVkIGZvciB0aGlzXG4gKiBmdW5jdGlvbmFsaXR5LlxuICovXG5leHBvcnQgY29uc3QgQTExWV9TVVBQT1JUX0lOX0RJU1BBVENIRVIgPSBmYWxzZTtcblxuLyoqXG4gKiBAZGVmaW5lIFN1cHBvcnQgZm9yIGFjY2Vzc2libGUgY2xpY2sgYWN0aW9ucy4gIFRoaXMgZmxhZyBjYW4gYmUgb3ZlcnJpZGRlbiBpblxuICogYSBidWlsZCBydWxlLlxuICovXG5jb25zdCBBMTFZX0NMSUNLX1NVUFBPUlRfRkxBR19FTkFCTEVEID0gZmFsc2U7XG5cbi8qKlxuICogRW5hYmxlcyBhMTF5IGNsaWNrIGNhc3Rpbmcgd2hlbiBlaXRoZXIgQTExWV9DTElDS19TVVBQT1JUX0ZMQUdfRU5BQkxFRCBvclxuICogQTExWV9TVVBQT1JUX0lOX0RJU1BBVENIRVIuXG4gKi9cbmV4cG9ydCBjb25zdCBBMTFZX0NMSUNLX1NVUFBPUlQgPSBBMTFZX0NMSUNLX1NVUFBPUlRfRkxBR19FTkFCTEVEIHx8IEExMVlfU1VQUE9SVF9JTl9ESVNQQVRDSEVSO1xuXG4vKipcbiAqIEBkZWZpbmUgU3VwcG9ydCBmb3IgdGhlIG5vbi1idWJibGluZyBtb3VzZWVudGVyIGFuZCBtb3VzZWxlYXZlIGV2ZW50cy4gIFRoaXNcbiAqIGZsYWcgY2FuIGJlIG92ZXJyaWRkZW4gaW4gYSBidWlsZCBydWxlLlxuICovXG5leHBvcnQgY29uc3QgTU9VU0VfU1BFQ0lBTF9TVVBQT1JUID0gZmFsc2U7XG5cbi8qKlxuICogQGRlZmluZSBDYWxsIHN0b3BQcm9wYWdhdGlvbiBvbiBoYW5kbGVkIGV2ZW50cy4gV2hlbiBpbnRlZ3JhdGluZyB3aXRoXG4gKiBub24tanNhY3Rpb24gZXZlbnQgaGFuZGxlciBiYXNlZCBjb2RlLCB5b3Ugd2lsbCBsaWtlbHkgd2FudCB0byB0dXJuIHRoaXMgZmxhZ1xuICogb2ZmLiBXaGlsZSBtb3N0IGV2ZW50IGhhbmRsZXJzIHdpbGwgY29udGludWUgdG8gd29yaywganNhY3Rpb24gYmluZHMgZm9jdXNcbiAqIGFuZCBibHVyIGV2ZW50cyBpbiB0aGUgY2FwdHVyZSBwaGFzZSBhbmQgdGh1cyB3aXRoIHN0b3BQcm9wYWdhdGlvbiwgbm9uZSBvZlxuICogeW91ciBub24tanNhY3Rpb24taGFuZGxlcnMgd2lsbCBldmVyIHNlZSBpdC5cbiAqL1xuZXhwb3J0IGNvbnN0IFNUT1BfUFJPUEFHQVRJT04gPSB0cnVlO1xuXG4vKipcbiAqIEBkZWZpbmUgU3VwcG9ydCBmb3IgY3VzdG9tIGV2ZW50cywgd2hpY2ggYXJlIHR5cGUgRXZlbnRUeXBlLkNVU1RPTS4gVGhlc2UgYXJlXG4gKiBuYXRpdmUgRE9NIGV2ZW50cyB3aXRoIGFuIGFkZGl0aW9uYWwgdHlwZSBmaWVsZCBhbmQgYW4gb3B0aW9uYWwgcGF5bG9hZC5cbiAqL1xuZXhwb3J0IGNvbnN0IENVU1RPTV9FVkVOVF9TVVBQT1JUID0gZmFsc2U7XG4iXX0=
|
|
@@ -0,0 +1,192 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* @license
|
|
3
|
+
* Copyright Google LLC All Rights Reserved.
|
|
4
|
+
*
|
|
5
|
+
* Use of this source code is governed by an MIT-style license that can be
|
|
6
|
+
* found in the LICENSE file at https://angular.io/license
|
|
7
|
+
*/
|
|
8
|
+
import { EventContractContainer } from './event_contract_container';
|
|
9
|
+
/**
|
|
10
|
+
* An `EventContractContainerManager` that supports multiple containers.
|
|
11
|
+
*/
|
|
12
|
+
export class EventContractMultiContainer {
|
|
13
|
+
/**
|
|
14
|
+
* @param stopPropagation Controls whether events can bubble between
|
|
15
|
+
* containers or not.
|
|
16
|
+
*/
|
|
17
|
+
constructor(stopPropagation = false) {
|
|
18
|
+
this.stopPropagation = stopPropagation;
|
|
19
|
+
/** The list of containers. */
|
|
20
|
+
this.containers = [];
|
|
21
|
+
/** The list of nested containers. */
|
|
22
|
+
this.nestedContainers = [];
|
|
23
|
+
/** The list of event handler installers. */
|
|
24
|
+
this.eventHandlerInstallers = [];
|
|
25
|
+
}
|
|
26
|
+
/**
|
|
27
|
+
* Installs the provided installer on the element owned by this container,
|
|
28
|
+
* and maintains a reference to resulting handler in order to remove it
|
|
29
|
+
* later if desired.
|
|
30
|
+
*/
|
|
31
|
+
addEventListener(eventType, getHandler) {
|
|
32
|
+
const eventHandlerInstaller = (container) => {
|
|
33
|
+
container.addEventListener(eventType, getHandler);
|
|
34
|
+
};
|
|
35
|
+
for (let i = 0; i < this.containers.length; i++) {
|
|
36
|
+
eventHandlerInstaller(this.containers[i]);
|
|
37
|
+
}
|
|
38
|
+
this.eventHandlerInstallers.push(eventHandlerInstaller);
|
|
39
|
+
}
|
|
40
|
+
/**
|
|
41
|
+
* Removes all the handlers installed on all containers.
|
|
42
|
+
*/
|
|
43
|
+
cleanUp() {
|
|
44
|
+
const allContainers = [...this.containers, ...this.nestedContainers];
|
|
45
|
+
for (let i = 0; i < allContainers.length; i++) {
|
|
46
|
+
allContainers[i].cleanUp();
|
|
47
|
+
}
|
|
48
|
+
this.containers = [];
|
|
49
|
+
this.nestedContainers = [];
|
|
50
|
+
this.eventHandlerInstallers = [];
|
|
51
|
+
}
|
|
52
|
+
/**
|
|
53
|
+
* Adds a container to the `MultiEventContractContainer`.
|
|
54
|
+
* Signs the event contract for a new container. All registered events
|
|
55
|
+
* are enabled for this container too. Containers have to be kept disjoint,
|
|
56
|
+
* so if the newly added container is a parent/child of existing containers,
|
|
57
|
+
* they will be merged. If the container is already tracked by this
|
|
58
|
+
* `EventContract`, then the previously registered `EventContractContainer`
|
|
59
|
+
* will be returned.
|
|
60
|
+
*/
|
|
61
|
+
addContainer(element) {
|
|
62
|
+
// If the container is already registered, return.
|
|
63
|
+
for (let i = 0; i < this.containers.length; i++) {
|
|
64
|
+
if (element === this.containers[i].element) {
|
|
65
|
+
return this.containers[i];
|
|
66
|
+
}
|
|
67
|
+
}
|
|
68
|
+
const container = new EventContractContainer(element);
|
|
69
|
+
if (this.stopPropagation) {
|
|
70
|
+
// Events are not propagated, so containers can be considered independent.
|
|
71
|
+
this.setUpContainer(container);
|
|
72
|
+
this.containers.push(container);
|
|
73
|
+
}
|
|
74
|
+
else {
|
|
75
|
+
if (this.isNestedContainer(container)) {
|
|
76
|
+
// This container has an ancestor that is already a contract container.
|
|
77
|
+
// Don't install event listeners on it in order to prevent an event from
|
|
78
|
+
// being handled multiple times.
|
|
79
|
+
this.nestedContainers.push(container);
|
|
80
|
+
return container;
|
|
81
|
+
}
|
|
82
|
+
this.setUpContainer(container);
|
|
83
|
+
this.containers.push(container);
|
|
84
|
+
this.updateNestedContainers();
|
|
85
|
+
}
|
|
86
|
+
return container;
|
|
87
|
+
}
|
|
88
|
+
/**
|
|
89
|
+
* Removes an already-added container from the contract.
|
|
90
|
+
*/
|
|
91
|
+
removeContainer(container) {
|
|
92
|
+
container.cleanUp();
|
|
93
|
+
let removed = false;
|
|
94
|
+
for (let i = 0; i < this.containers.length; ++i) {
|
|
95
|
+
if (this.containers[i] === container) {
|
|
96
|
+
this.containers.splice(i, 1);
|
|
97
|
+
removed = true;
|
|
98
|
+
break;
|
|
99
|
+
}
|
|
100
|
+
}
|
|
101
|
+
if (!removed) {
|
|
102
|
+
for (let i = 0; i < this.nestedContainers.length; ++i) {
|
|
103
|
+
if (this.nestedContainers[i] === container) {
|
|
104
|
+
this.nestedContainers.splice(i, 1);
|
|
105
|
+
break;
|
|
106
|
+
}
|
|
107
|
+
}
|
|
108
|
+
}
|
|
109
|
+
if (this.stopPropagation) {
|
|
110
|
+
return;
|
|
111
|
+
}
|
|
112
|
+
this.updateNestedContainers();
|
|
113
|
+
}
|
|
114
|
+
/**
|
|
115
|
+
* Tested whether any current container is a parent of the new container.
|
|
116
|
+
*/
|
|
117
|
+
isNestedContainer(container) {
|
|
118
|
+
for (let i = 0; i < this.containers.length; i++) {
|
|
119
|
+
if (containsNode(this.containers[i].element, container.element)) {
|
|
120
|
+
return true;
|
|
121
|
+
}
|
|
122
|
+
}
|
|
123
|
+
return false;
|
|
124
|
+
}
|
|
125
|
+
/** Installs all existing event handlers on a new container. */
|
|
126
|
+
setUpContainer(container) {
|
|
127
|
+
for (let i = 0; i < this.eventHandlerInstallers.length; i++) {
|
|
128
|
+
this.eventHandlerInstallers[i](container);
|
|
129
|
+
}
|
|
130
|
+
}
|
|
131
|
+
/**
|
|
132
|
+
* Updates the list of nested containers after an add/remove operation. Only
|
|
133
|
+
* containers that are not children of other containers are placed in the
|
|
134
|
+
* containers list (and have event listeners on them). This is done in order
|
|
135
|
+
* to prevent events from being handled multiple times when `stopPropagation`
|
|
136
|
+
* is false.
|
|
137
|
+
*/
|
|
138
|
+
updateNestedContainers() {
|
|
139
|
+
const allContainers = [...this.nestedContainers, ...this.containers];
|
|
140
|
+
const newNestedContainers = [];
|
|
141
|
+
const newContainers = [];
|
|
142
|
+
for (let i = 0; i < this.containers.length; ++i) {
|
|
143
|
+
const container = this.containers[i];
|
|
144
|
+
if (isNested(container, allContainers)) {
|
|
145
|
+
newNestedContainers.push(container);
|
|
146
|
+
// Remove the event listeners from the nested container.
|
|
147
|
+
container.cleanUp();
|
|
148
|
+
}
|
|
149
|
+
else {
|
|
150
|
+
newContainers.push(container);
|
|
151
|
+
}
|
|
152
|
+
}
|
|
153
|
+
for (let i = 0; i < this.nestedContainers.length; ++i) {
|
|
154
|
+
const container = this.nestedContainers[i];
|
|
155
|
+
if (isNested(container, allContainers)) {
|
|
156
|
+
newNestedContainers.push(container);
|
|
157
|
+
}
|
|
158
|
+
else {
|
|
159
|
+
newContainers.push(container);
|
|
160
|
+
// The container is no longer nested, add event listeners on it.
|
|
161
|
+
this.setUpContainer(container);
|
|
162
|
+
}
|
|
163
|
+
}
|
|
164
|
+
this.containers = newContainers;
|
|
165
|
+
this.nestedContainers = newNestedContainers;
|
|
166
|
+
}
|
|
167
|
+
}
|
|
168
|
+
/**
|
|
169
|
+
* Checks whether the container is a child of any of the containers.
|
|
170
|
+
*/
|
|
171
|
+
function isNested(container, containers) {
|
|
172
|
+
for (let i = 0; i < containers.length; ++i) {
|
|
173
|
+
if (containsNode(containers[i].element, container.element)) {
|
|
174
|
+
return true;
|
|
175
|
+
}
|
|
176
|
+
}
|
|
177
|
+
return false;
|
|
178
|
+
}
|
|
179
|
+
/**
|
|
180
|
+
* Checks whether parent contains child.
|
|
181
|
+
* IE11 only supports the native `Node.contains` for HTMLElement.
|
|
182
|
+
*/
|
|
183
|
+
function containsNode(parent, child) {
|
|
184
|
+
if (parent === child) {
|
|
185
|
+
return false;
|
|
186
|
+
}
|
|
187
|
+
while (parent !== child && child.parentNode) {
|
|
188
|
+
child = child.parentNode;
|
|
189
|
+
}
|
|
190
|
+
return parent === child;
|
|
191
|
+
}
|
|
192
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"event_contract_multi_container.js","sourceRoot":"","sources":["../../../../../../../../packages/core/primitives/event-dispatch/src/event_contract_multi_container.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * @license\n * Copyright Google LLC All Rights Reserved.\n *\n * Use of this source code is governed by an MIT-style license that can be\n * found in the LICENSE file at https://angular.io/license\n */\n\nimport {EventContractContainer, EventContractContainerManager} from './event_contract_container';\n\n/**\n * An `EventContractContainerManager` that supports multiple containers.\n */\nexport class EventContractMultiContainer implements EventContractContainerManager {\n  /** The list of containers. */\n  private containers: EventContractContainer[] = [];\n  /** The list of nested containers. */\n  private nestedContainers: EventContractContainer[] = [];\n  /** The list of event handler installers. */\n  private eventHandlerInstallers: Array<(container: EventContractContainer) => void> = [];\n\n  /**\n   * @param stopPropagation Controls whether events can bubble between\n   *    containers or not.\n   */\n  constructor(private readonly stopPropagation = false) {}\n\n  /**\n   * Installs the provided installer on the element owned by this container,\n   * and maintains a reference to resulting handler in order to remove it\n   * later if desired.\n   */\n  addEventListener(eventType: string, getHandler: (element: Element) => (event: Event) => void) {\n    const eventHandlerInstaller = (container: EventContractContainer) => {\n      container.addEventListener(eventType, getHandler);\n    };\n    for (let i = 0; i < this.containers.length; i++) {\n      eventHandlerInstaller(this.containers[i]);\n    }\n    this.eventHandlerInstallers.push(eventHandlerInstaller);\n  }\n\n  /**\n   * Removes all the handlers installed on all containers.\n   */\n  cleanUp() {\n    const allContainers = [...this.containers, ...this.nestedContainers];\n    for (let i = 0; i < allContainers.length; i++) {\n      allContainers[i].cleanUp();\n    }\n    this.containers = [];\n    this.nestedContainers = [];\n    this.eventHandlerInstallers = [];\n  }\n\n  /**\n   * Adds a container to the `MultiEventContractContainer`.\n   * Signs the event contract for a new container. All registered events\n   * are enabled for this container too. Containers have to be kept disjoint,\n   * so if the newly added container is a parent/child of existing containers,\n   * they will be merged. If the container is already tracked by this\n   * `EventContract`, then the previously registered `EventContractContainer`\n   * will be returned.\n   */\n  addContainer(element: Element): EventContractContainer {\n    // If the container is already registered, return.\n    for (let i = 0; i < this.containers.length; i++) {\n      if (element === this.containers[i].element) {\n        return this.containers[i];\n      }\n    }\n    const container = new EventContractContainer(element);\n    if (this.stopPropagation) {\n      // Events are not propagated, so containers can be considered independent.\n      this.setUpContainer(container);\n      this.containers.push(container);\n    } else {\n      if (this.isNestedContainer(container)) {\n        // This container has an ancestor that is already a contract container.\n        // Don't install event listeners on it in order to prevent an event from\n        // being handled multiple times.\n        this.nestedContainers.push(container);\n        return container;\n      }\n      this.setUpContainer(container);\n      this.containers.push(container);\n      this.updateNestedContainers();\n    }\n    return container;\n  }\n\n  /**\n   * Removes an already-added container from the contract.\n   */\n  removeContainer(container: EventContractContainer) {\n    container.cleanUp();\n    let removed = false;\n    for (let i = 0; i < this.containers.length; ++i) {\n      if (this.containers[i] === container) {\n        this.containers.splice(i, 1);\n        removed = true;\n        break;\n      }\n    }\n\n    if (!removed) {\n      for (let i = 0; i < this.nestedContainers.length; ++i) {\n        if (this.nestedContainers[i] === container) {\n          this.nestedContainers.splice(i, 1);\n          break;\n        }\n      }\n    }\n\n    if (this.stopPropagation) {\n      return;\n    }\n    this.updateNestedContainers();\n  }\n\n  /**\n   * Tested whether any current container is a parent of the new container.\n   */\n  private isNestedContainer(container: EventContractContainer): boolean {\n    for (let i = 0; i < this.containers.length; i++) {\n      if (containsNode(this.containers[i].element, container.element)) {\n        return true;\n      }\n    }\n    return false;\n  }\n\n  /** Installs all existing event handlers on a new container. */\n  private setUpContainer(container: EventContractContainer) {\n    for (let i = 0; i < this.eventHandlerInstallers.length; i++) {\n      this.eventHandlerInstallers[i](container);\n    }\n  }\n\n  /**\n   * Updates the list of nested containers after an add/remove operation. Only\n   * containers that are not children of other containers are placed in the\n   * containers list (and have event listeners on them). This is done in order\n   * to prevent events from being handled multiple times when `stopPropagation`\n   * is false.\n   */\n  private updateNestedContainers() {\n    const allContainers = [...this.nestedContainers, ...this.containers];\n    const newNestedContainers = [];\n    const newContainers = [];\n\n    for (let i = 0; i < this.containers.length; ++i) {\n      const container = this.containers[i];\n      if (isNested(container, allContainers)) {\n        newNestedContainers.push(container);\n        // Remove the event listeners from the nested container.\n        container.cleanUp();\n      } else {\n        newContainers.push(container);\n      }\n    }\n\n    for (let i = 0; i < this.nestedContainers.length; ++i) {\n      const container = this.nestedContainers[i];\n      if (isNested(container, allContainers)) {\n        newNestedContainers.push(container);\n      } else {\n        newContainers.push(container);\n        // The container is no longer nested, add event listeners on it.\n        this.setUpContainer(container);\n      }\n    }\n\n    this.containers = newContainers;\n    this.nestedContainers = newNestedContainers;\n  }\n}\n\n/**\n * Checks whether the container is a child of any of the containers.\n */\nfunction isNested(\n  container: EventContractContainer,\n  containers: EventContractContainer[],\n): boolean {\n  for (let i = 0; i < containers.length; ++i) {\n    if (containsNode(containers[i].element, container.element)) {\n      return true;\n    }\n  }\n\n  return false;\n}\n\n/**\n * Checks whether parent contains child.\n * IE11 only supports the native `Node.contains` for HTMLElement.\n */\nfunction containsNode(parent: Node, child: Node): boolean {\n  if (parent === child) {\n    return false;\n  }\n  while (parent !== child && child.parentNode) {\n    child = child.parentNode;\n  }\n  return parent === child;\n}\n"]}
|
|
@@ -0,0 +1,9 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* @license
|
|
3
|
+
* Copyright Google LLC All Rights Reserved.
|
|
4
|
+
*
|
|
5
|
+
* Use of this source code is governed by an MIT-style license that can be
|
|
6
|
+
* found in the LICENSE file at https://angular.io/license
|
|
7
|
+
*/
|
|
8
|
+
export {};
|
|
9
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZXZlbnRfaGFuZGxlci5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uLy4uL3BhY2thZ2VzL2NvcmUvcHJpbWl0aXZlcy9ldmVudC1kaXNwYXRjaC9zcmMvZXZlbnRfaGFuZGxlci50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQTs7Ozs7O0dBTUciLCJzb3VyY2VzQ29udGVudCI6WyIvKipcbiAqIEBsaWNlbnNlXG4gKiBDb3B5cmlnaHQgR29vZ2xlIExMQyBBbGwgUmlnaHRzIFJlc2VydmVkLlxuICpcbiAqIFVzZSBvZiB0aGlzIHNvdXJjZSBjb2RlIGlzIGdvdmVybmVkIGJ5IGFuIE1JVC1zdHlsZSBsaWNlbnNlIHRoYXQgY2FuIGJlXG4gKiBmb3VuZCBpbiB0aGUgTElDRU5TRSBmaWxlIGF0IGh0dHBzOi8vYW5ndWxhci5pby9saWNlbnNlXG4gKi9cblxuLyoqXG4gKlxuICogSW5mb3JtYXRpb24gYWJvdXQgYSByZWdpc3RlcmVkIGV2ZW50IGhhbmRsZXIsIHdoaWNoIGNhbiBiZSB1c2VkIHRvXG4gKiBkZXJlZ2lzdGVyIHRoZSBldmVudCBoYW5kbGVyLlxuICovXG5leHBvcnQgaW50ZXJmYWNlIEV2ZW50SGFuZGxlckluZm8ge1xuICBldmVudFR5cGU6IHN0cmluZztcblxuICBoYW5kbGVyOiAoZXZlbnQ6IEV2ZW50KSA9PiB2b2lkO1xuXG4gIGNhcHR1cmU6IGJvb2xlYW47XG59XG4iXX0=
|
|
@@ -0,0 +1,199 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* @license
|
|
3
|
+
* Copyright Google LLC All Rights Reserved.
|
|
4
|
+
*
|
|
5
|
+
* Use of this source code is governed by an MIT-style license that can be
|
|
6
|
+
* found in the LICENSE file at https://angular.io/license
|
|
7
|
+
*/
|
|
8
|
+
/** Added for readability when accessing stable property names. */
|
|
9
|
+
export function getEventType(eventInfo) {
|
|
10
|
+
return eventInfo.eventType;
|
|
11
|
+
}
|
|
12
|
+
/** Added for readability when accessing stable property names. */
|
|
13
|
+
export function setEventType(eventInfo, eventType) {
|
|
14
|
+
eventInfo.eventType = eventType;
|
|
15
|
+
}
|
|
16
|
+
/** Added for readability when accessing stable property names. */
|
|
17
|
+
export function getEvent(eventInfo) {
|
|
18
|
+
return eventInfo.event;
|
|
19
|
+
}
|
|
20
|
+
/** Added for readability when accessing stable property names. */
|
|
21
|
+
export function setEvent(eventInfo, event) {
|
|
22
|
+
eventInfo.event = event;
|
|
23
|
+
}
|
|
24
|
+
/** Added for readability when accessing stable property names. */
|
|
25
|
+
export function getTargetElement(eventInfo) {
|
|
26
|
+
return eventInfo.targetElement;
|
|
27
|
+
}
|
|
28
|
+
/** Added for readability when accessing stable property names. */
|
|
29
|
+
export function setTargetElement(eventInfo, targetElement) {
|
|
30
|
+
eventInfo.targetElement = targetElement;
|
|
31
|
+
}
|
|
32
|
+
/** Added for readability when accessing stable property names. */
|
|
33
|
+
export function getContainer(eventInfo) {
|
|
34
|
+
return eventInfo.eic;
|
|
35
|
+
}
|
|
36
|
+
/** Added for readability when accessing stable property names. */
|
|
37
|
+
export function setContainer(eventInfo, container) {
|
|
38
|
+
eventInfo.eic = container;
|
|
39
|
+
}
|
|
40
|
+
/** Added for readability when accessing stable property names. */
|
|
41
|
+
export function getTimestamp(eventInfo) {
|
|
42
|
+
return eventInfo.timeStamp;
|
|
43
|
+
}
|
|
44
|
+
/** Added for readability when accessing stable property names. */
|
|
45
|
+
export function setTimestamp(eventInfo, timestamp) {
|
|
46
|
+
eventInfo.timeStamp = timestamp;
|
|
47
|
+
}
|
|
48
|
+
/** Added for readability when accessing stable property names. */
|
|
49
|
+
export function getAction(eventInfo) {
|
|
50
|
+
return eventInfo.eia;
|
|
51
|
+
}
|
|
52
|
+
/** Added for readability when accessing stable property names. */
|
|
53
|
+
export function setAction(eventInfo, actionName, actionElement) {
|
|
54
|
+
eventInfo.eia = [actionName, actionElement];
|
|
55
|
+
}
|
|
56
|
+
/** Added for readability when accessing stable property names. */
|
|
57
|
+
export function unsetAction(eventInfo) {
|
|
58
|
+
eventInfo.eia = undefined;
|
|
59
|
+
}
|
|
60
|
+
/** Added for readability when accessing stable property names. */
|
|
61
|
+
export function getActionName(actionInfo) {
|
|
62
|
+
return actionInfo[0];
|
|
63
|
+
}
|
|
64
|
+
/** Added for readability when accessing stable property names. */
|
|
65
|
+
export function getActionElement(actionInfo) {
|
|
66
|
+
return actionInfo[1];
|
|
67
|
+
}
|
|
68
|
+
/** Added for readability when accessing stable property names. */
|
|
69
|
+
export function getIsReplay(eventInfo) {
|
|
70
|
+
return eventInfo.eirp;
|
|
71
|
+
}
|
|
72
|
+
/** Added for readability when accessing stable property names. */
|
|
73
|
+
export function setIsReplay(eventInfo, replay) {
|
|
74
|
+
eventInfo.eirp = replay;
|
|
75
|
+
}
|
|
76
|
+
/** Added for readability when accessing stable property names. */
|
|
77
|
+
export function getA11yClickKey(eventInfo) {
|
|
78
|
+
return eventInfo.eiack;
|
|
79
|
+
}
|
|
80
|
+
/** Added for readability when accessing stable property names. */
|
|
81
|
+
export function setA11yClickKey(eventInfo, a11yClickKey) {
|
|
82
|
+
eventInfo.eiack = a11yClickKey;
|
|
83
|
+
}
|
|
84
|
+
/** Clones an `EventInfo` */
|
|
85
|
+
export function cloneEventInfo(eventInfo) {
|
|
86
|
+
return {
|
|
87
|
+
eventType: eventInfo.eventType,
|
|
88
|
+
event: eventInfo.event,
|
|
89
|
+
targetElement: eventInfo.targetElement,
|
|
90
|
+
eic: eventInfo.eic,
|
|
91
|
+
eia: eventInfo.eia,
|
|
92
|
+
timeStamp: eventInfo.timeStamp,
|
|
93
|
+
eirp: eventInfo.eirp,
|
|
94
|
+
eiack: eventInfo.eiack,
|
|
95
|
+
};
|
|
96
|
+
}
|
|
97
|
+
/**
|
|
98
|
+
* Utility function for creating an `EventInfo`.
|
|
99
|
+
*
|
|
100
|
+
* This can be used from code-size sensitive compilation units, as taking
|
|
101
|
+
* parameters vs. an `Object` literal reduces code size.
|
|
102
|
+
*/
|
|
103
|
+
export function createEventInfoFromParameters(eventType, event, targetElement, container, timestamp, action, isReplay, a11yClickKey) {
|
|
104
|
+
return {
|
|
105
|
+
eventType,
|
|
106
|
+
event,
|
|
107
|
+
targetElement,
|
|
108
|
+
eic: container,
|
|
109
|
+
timeStamp: timestamp,
|
|
110
|
+
eia: action,
|
|
111
|
+
eirp: isReplay,
|
|
112
|
+
eiack: a11yClickKey,
|
|
113
|
+
};
|
|
114
|
+
}
|
|
115
|
+
/**
|
|
116
|
+
* Utility function for creating an `EventInfo`.
|
|
117
|
+
*
|
|
118
|
+
* This should be used in compilation units that are less sensitive to code
|
|
119
|
+
* size.
|
|
120
|
+
*/
|
|
121
|
+
export function createEventInfo({ eventType, event, targetElement, container, timestamp, action, isReplay, a11yClickKey, }) {
|
|
122
|
+
return {
|
|
123
|
+
eventType,
|
|
124
|
+
event,
|
|
125
|
+
targetElement,
|
|
126
|
+
eic: container,
|
|
127
|
+
timeStamp: timestamp,
|
|
128
|
+
eia: action ? [action.name, action.element] : undefined,
|
|
129
|
+
eirp: isReplay,
|
|
130
|
+
eiack: a11yClickKey,
|
|
131
|
+
};
|
|
132
|
+
}
|
|
133
|
+
/**
|
|
134
|
+
* Utility class around an `EventInfo`.
|
|
135
|
+
*
|
|
136
|
+
* This should be used in compilation units that are less sensitive to code
|
|
137
|
+
* size.
|
|
138
|
+
*/
|
|
139
|
+
export class EventInfoWrapper {
|
|
140
|
+
constructor(eventInfo) {
|
|
141
|
+
this.eventInfo = eventInfo;
|
|
142
|
+
}
|
|
143
|
+
getEventType() {
|
|
144
|
+
return getEventType(this.eventInfo);
|
|
145
|
+
}
|
|
146
|
+
setEventType(eventType) {
|
|
147
|
+
setEventType(this.eventInfo, eventType);
|
|
148
|
+
}
|
|
149
|
+
getEvent() {
|
|
150
|
+
return getEvent(this.eventInfo);
|
|
151
|
+
}
|
|
152
|
+
setEvent(event) {
|
|
153
|
+
setEvent(this.eventInfo, event);
|
|
154
|
+
}
|
|
155
|
+
getTargetElement() {
|
|
156
|
+
return getTargetElement(this.eventInfo);
|
|
157
|
+
}
|
|
158
|
+
setTargetElement(targetElement) {
|
|
159
|
+
setTargetElement(this.eventInfo, targetElement);
|
|
160
|
+
}
|
|
161
|
+
getContainer() {
|
|
162
|
+
return getContainer(this.eventInfo);
|
|
163
|
+
}
|
|
164
|
+
setContainer(container) {
|
|
165
|
+
setContainer(this.eventInfo, container);
|
|
166
|
+
}
|
|
167
|
+
getTimestamp() {
|
|
168
|
+
return getTimestamp(this.eventInfo);
|
|
169
|
+
}
|
|
170
|
+
setTimestamp(timestamp) {
|
|
171
|
+
setTimestamp(this.eventInfo, timestamp);
|
|
172
|
+
}
|
|
173
|
+
getAction() {
|
|
174
|
+
const action = getAction(this.eventInfo);
|
|
175
|
+
if (!action)
|
|
176
|
+
return undefined;
|
|
177
|
+
return {
|
|
178
|
+
name: action[0],
|
|
179
|
+
element: action[1],
|
|
180
|
+
};
|
|
181
|
+
}
|
|
182
|
+
setAction(action) {
|
|
183
|
+
if (!action) {
|
|
184
|
+
unsetAction(this.eventInfo);
|
|
185
|
+
return;
|
|
186
|
+
}
|
|
187
|
+
setAction(this.eventInfo, action.name, action.element);
|
|
188
|
+
}
|
|
189
|
+
getIsReplay() {
|
|
190
|
+
return getIsReplay(this.eventInfo);
|
|
191
|
+
}
|
|
192
|
+
setIsReplay(replay) {
|
|
193
|
+
setIsReplay(this.eventInfo, replay);
|
|
194
|
+
}
|
|
195
|
+
clone() {
|
|
196
|
+
return new EventInfoWrapper(cloneEventInfo(this.eventInfo));
|
|
197
|
+
}
|
|
198
|
+
}
|
|
199
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"event_info.js","sourceRoot":"","sources":["../../../../../../../../packages/core/primitives/event-dispatch/src/event_info.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * @license\n * Copyright Google LLC All Rights Reserved.\n *\n * Use of this source code is governed by an MIT-style license that can be\n * found in the LICENSE file at https://angular.io/license\n */\n\n/**\n * Records information about the action that should handle a given `Event`.\n */\nexport interface ActionInfo {\n  name: string;\n  element: Element;\n}\n\ntype ActionInfoInternal = [name: string, element: Element];\n\n/**\n * Records information for later handling of events. This type is\n * shared, and instances of it are passed, between the eventcontract\n * and the dispatcher jsbinary. Therefore, the fields of this type are\n * referenced by string literals rather than property literals\n * throughout the code.\n *\n * 'targetElement' is the element the action occurred on, 'actionElement'\n * is the element that has the jsaction handler.\n *\n * A null 'actionElement' identifies an EventInfo instance that didn't match a\n * jsaction attribute.  This allows us to execute global event handlers with the\n * appropriate event type (including a11y clicks and custom events).\n * The declare portion of this interface creates a set of externs that make sure\n * renaming doesn't happen for EventInfo. This is important since EventInfo\n * is shared across multiple binaries.\n */\nexport declare interface EventInfo {\n  eventType: string;\n  event: Event;\n  targetElement: Element;\n  /** The element that is the container for this Event. */\n  eic: Element;\n  timeStamp: number;\n  /**\n   * The action parsed from the JSAction element.\n   */\n  eia?: ActionInfoInternal;\n  /**\n   * Whether this `Event` is a replay event, meaning no dispatcher was\n   * installed when this `Event` was originally dispatched.\n   */\n  eirp?: boolean;\n  /**\n   * Whether this `Event` represents a `keydown` event that should be processed\n   * as a `click`. Only used when a11y click events is on.\n   */\n  eiack?: boolean;\n}\n\n/** Added for readability when accessing stable property names. */\nexport function getEventType(eventInfo: EventInfo) {\n  return eventInfo.eventType;\n}\n\n/** Added for readability when accessing stable property names. */\nexport function setEventType(eventInfo: EventInfo, eventType: string) {\n  eventInfo.eventType = eventType;\n}\n\n/** Added for readability when accessing stable property names. */\nexport function getEvent(eventInfo: EventInfo) {\n  return eventInfo.event;\n}\n\n/** Added for readability when accessing stable property names. */\nexport function setEvent(eventInfo: EventInfo, event: Event) {\n  eventInfo.event = event;\n}\n\n/** Added for readability when accessing stable property names. */\nexport function getTargetElement(eventInfo: EventInfo) {\n  return eventInfo.targetElement;\n}\n\n/** Added for readability when accessing stable property names. */\nexport function setTargetElement(eventInfo: EventInfo, targetElement: Element) {\n  eventInfo.targetElement = targetElement;\n}\n\n/** Added for readability when accessing stable property names. */\nexport function getContainer(eventInfo: EventInfo) {\n  return eventInfo.eic;\n}\n\n/** Added for readability when accessing stable property names. */\nexport function setContainer(eventInfo: EventInfo, container: Element) {\n  eventInfo.eic = container;\n}\n\n/** Added for readability when accessing stable property names. */\nexport function getTimestamp(eventInfo: EventInfo) {\n  return eventInfo.timeStamp;\n}\n\n/** Added for readability when accessing stable property names. */\nexport function setTimestamp(eventInfo: EventInfo, timestamp: number) {\n  eventInfo.timeStamp = timestamp;\n}\n\n/** Added for readability when accessing stable property names. */\nexport function getAction(eventInfo: EventInfo) {\n  return eventInfo.eia;\n}\n\n/** Added for readability when accessing stable property names. */\nexport function setAction(eventInfo: EventInfo, actionName: string, actionElement: Element) {\n  eventInfo.eia = [actionName, actionElement];\n}\n\n/** Added for readability when accessing stable property names. */\nexport function unsetAction(eventInfo: EventInfo) {\n  eventInfo.eia = undefined;\n}\n\n/** Added for readability when accessing stable property names. */\nexport function getActionName(actionInfo: ActionInfoInternal) {\n  return actionInfo[0];\n}\n\n/** Added for readability when accessing stable property names. */\nexport function getActionElement(actionInfo: ActionInfoInternal) {\n  return actionInfo[1];\n}\n\n/** Added for readability when accessing stable property names. */\nexport function getIsReplay(eventInfo: EventInfo) {\n  return eventInfo.eirp;\n}\n\n/** Added for readability when accessing stable property names. */\nexport function setIsReplay(eventInfo: EventInfo, replay: boolean) {\n  eventInfo.eirp = replay;\n}\n\n/** Added for readability when accessing stable property names. */\nexport function getA11yClickKey(eventInfo: EventInfo) {\n  return eventInfo.eiack;\n}\n\n/** Added for readability when accessing stable property names. */\nexport function setA11yClickKey(eventInfo: EventInfo, a11yClickKey: boolean) {\n  eventInfo.eiack = a11yClickKey;\n}\n\n/** Clones an `EventInfo` */\nexport function cloneEventInfo(eventInfo: EventInfo): EventInfo {\n  return {\n    eventType: eventInfo.eventType,\n    event: eventInfo.event,\n    targetElement: eventInfo.targetElement,\n    eic: eventInfo.eic,\n    eia: eventInfo.eia,\n    timeStamp: eventInfo.timeStamp,\n    eirp: eventInfo.eirp,\n    eiack: eventInfo.eiack,\n  };\n}\n\n/**\n * Utility function for creating an `EventInfo`.\n *\n * This can be used from code-size sensitive compilation units, as taking\n * parameters vs. an `Object` literal reduces code size.\n */\nexport function createEventInfoFromParameters(\n  eventType: string,\n  event: Event,\n  targetElement: Element,\n  container: Element,\n  timestamp: number,\n  action?: ActionInfoInternal,\n  isReplay?: boolean,\n  a11yClickKey?: boolean,\n): EventInfo {\n  return {\n    eventType,\n    event,\n    targetElement,\n    eic: container,\n    timeStamp: timestamp,\n    eia: action,\n    eirp: isReplay,\n    eiack: a11yClickKey,\n  };\n}\n\n/**\n * Utility function for creating an `EventInfo`.\n *\n * This should be used in compilation units that are less sensitive to code\n * size.\n */\nexport function createEventInfo({\n  eventType,\n  event,\n  targetElement,\n  container,\n  timestamp,\n  action,\n  isReplay,\n  a11yClickKey,\n}: {\n  eventType: string;\n  event: Event;\n  targetElement: Element;\n  container: Element;\n  timestamp: number;\n  action?: ActionInfo;\n  isReplay?: boolean;\n  a11yClickKey?: boolean;\n}): EventInfo {\n  return {\n    eventType,\n    event,\n    targetElement,\n    eic: container,\n    timeStamp: timestamp,\n    eia: action ? [action.name, action.element] : undefined,\n    eirp: isReplay,\n    eiack: a11yClickKey,\n  };\n}\n\n/**\n * Utility class around an `EventInfo`.\n *\n * This should be used in compilation units that are less sensitive to code\n * size.\n */\nexport class EventInfoWrapper {\n  constructor(readonly eventInfo: EventInfo) {}\n\n  getEventType() {\n    return getEventType(this.eventInfo);\n  }\n\n  setEventType(eventType: string) {\n    setEventType(this.eventInfo, eventType);\n  }\n\n  getEvent() {\n    return getEvent(this.eventInfo);\n  }\n\n  setEvent(event: Event) {\n    setEvent(this.eventInfo, event);\n  }\n\n  getTargetElement() {\n    return getTargetElement(this.eventInfo);\n  }\n\n  setTargetElement(targetElement: Element) {\n    setTargetElement(this.eventInfo, targetElement);\n  }\n\n  getContainer() {\n    return getContainer(this.eventInfo);\n  }\n\n  setContainer(container: Element) {\n    setContainer(this.eventInfo, container);\n  }\n  getTimestamp() {\n    return getTimestamp(this.eventInfo);\n  }\n\n  setTimestamp(timestamp: number) {\n    setTimestamp(this.eventInfo, timestamp);\n  }\n\n  getAction() {\n    const action = getAction(this.eventInfo);\n    if (!action) return undefined;\n    return {\n      name: action[0],\n      element: action[1],\n    };\n  }\n\n  setAction(action: ActionInfo | undefined) {\n    if (!action) {\n      unsetAction(this.eventInfo);\n      return;\n    }\n    setAction(this.eventInfo, action.name, action.element);\n  }\n\n  getIsReplay() {\n    return getIsReplay(this.eventInfo);\n  }\n\n  setIsReplay(replay: boolean) {\n    setIsReplay(this.eventInfo, replay);\n  }\n\n  clone() {\n    return new EventInfoWrapper(cloneEventInfo(this.eventInfo));\n  }\n}\n"]}
|