@ngxs/store 3.7.4 → 3.7.5
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/README.md +16 -16
- package/bundles/ngxs-store-internals-testing.umd.js +315 -315
- package/bundles/ngxs-store-internals-testing.umd.js.map +1 -1
- package/bundles/ngxs-store-internals-testing.umd.min.js.map +1 -1
- package/bundles/ngxs-store-internals.umd.js +192 -397
- package/bundles/ngxs-store-internals.umd.js.map +1 -1
- package/bundles/ngxs-store-internals.umd.min.js +1 -1
- package/bundles/ngxs-store-internals.umd.min.js.map +1 -1
- package/bundles/ngxs-store-operators.umd.js +310 -310
- package/bundles/ngxs-store-operators.umd.js.map +1 -1
- package/bundles/ngxs-store-operators.umd.min.js.map +1 -1
- package/bundles/ngxs-store.umd.js +4401 -4481
- package/bundles/ngxs-store.umd.js.map +1 -1
- package/bundles/ngxs-store.umd.min.js +1 -1
- package/bundles/ngxs-store.umd.min.js.map +1 -1
- package/esm2015/index.js +13 -13
- package/esm2015/internals/angular.js +20 -20
- package/esm2015/internals/index.js +10 -11
- package/esm2015/internals/initial-state.js +34 -34
- package/esm2015/internals/internal-tokens.js +16 -16
- package/esm2015/internals/memoize.js +70 -70
- package/esm2015/internals/ngxs-bootstrapper.js +41 -41
- package/esm2015/internals/ngxs-store-internals.js +9 -9
- package/esm2015/internals/src/symbols.js +14 -14
- package/esm2015/internals/symbols.js +14 -14
- package/esm2015/internals/testing/fresh-platform.js +110 -110
- package/esm2015/internals/testing/helpers/ngxs-test.component.js +22 -22
- package/esm2015/internals/testing/helpers/ngxs-test.module.js +24 -24
- package/esm2015/internals/testing/index.js +8 -8
- package/esm2015/internals/testing/ngxs-store-internals-testing.js +8 -8
- package/esm2015/internals/testing/ngxs.setup.js +76 -76
- package/esm2015/internals/testing/skip-console-logging.js +62 -62
- package/esm2015/internals/testing/symbol.js +29 -29
- package/esm2015/ngxs-store.js +24 -23
- package/esm2015/operators/append.js +31 -31
- package/esm2015/operators/compose.js +24 -24
- package/esm2015/operators/iif.js +56 -56
- package/esm2015/operators/index.js +18 -18
- package/esm2015/operators/insert-item.js +41 -41
- package/esm2015/operators/internals.js +5 -5
- package/esm2015/operators/ngxs-store-operators.js +8 -8
- package/esm2015/operators/patch.js +39 -39
- package/esm2015/operators/remove-item.js +34 -34
- package/esm2015/operators/update-item.js +52 -52
- package/esm2015/operators/utils.js +50 -50
- package/esm2015/src/actions/actions.js +39 -39
- package/esm2015/src/actions/symbols.js +39 -39
- package/esm2015/src/actions-stream.js +140 -140
- package/esm2015/src/configs/messages.config.js +79 -79
- package/esm2015/src/decorators/action.js +48 -48
- package/esm2015/src/decorators/select/select-factory.js +45 -49
- package/esm2015/src/decorators/select/select.js +45 -81
- package/esm2015/src/decorators/select/symbols.js +50 -94
- package/esm2015/src/decorators/selector/selector.js +59 -59
- package/esm2015/src/decorators/selector/symbols.js +5 -5
- package/esm2015/src/decorators/selector-options.js +34 -34
- package/esm2015/src/decorators/state.js +77 -83
- package/esm2015/src/execution/dispatch-outside-zone-ngxs-execution-strategy.js +103 -103
- package/esm2015/src/execution/internal-ngxs-execution-strategy.js +45 -45
- package/esm2015/src/execution/noop-ngxs-execution-strategy.js +29 -29
- package/esm2015/src/execution/symbols.js +52 -52
- package/esm2015/src/internal/dispatcher.js +219 -217
- package/esm2015/src/internal/internals.js +493 -493
- package/esm2015/src/internal/lifecycle-state-manager.js +129 -129
- package/esm2015/src/internal/state-context-factory.js +138 -138
- package/esm2015/src/internal/state-factory.js +457 -449
- package/esm2015/src/internal/state-operations.js +124 -133
- package/esm2015/src/internal/state-operators.js +33 -33
- package/esm2015/src/internal/state-stream.js +30 -30
- package/esm2015/src/ivy/ivy-enabled-in-dev-mode.js +28 -28
- package/esm2015/src/module.js +159 -157
- package/esm2015/src/modules/ngxs-feature.module.js +63 -63
- package/esm2015/src/modules/ngxs-root.module.js +49 -52
- package/esm2015/src/operators/leave-ngxs.js +58 -58
- package/esm2015/src/operators/of-action.js +191 -191
- package/esm2015/src/plugin-manager.js +70 -70
- package/esm2015/src/plugin_api.js +10 -10
- package/esm2015/src/public_api.js +29 -29
- package/esm2015/src/public_to_deprecate.js +64 -64
- package/esm2015/src/state-token/state-token.js +45 -45
- package/esm2015/src/state-token/symbols.js +5 -5
- package/esm2015/src/store.js +190 -190
- package/esm2015/src/symbols.js +221 -220
- package/esm2015/src/utils/compose.js +44 -44
- package/esm2015/src/utils/freeze.js +35 -35
- package/esm2015/src/utils/selector-utils.js +221 -221
- package/esm2015/src/utils/store-validators.js +60 -60
- package/esm2015/src/utils/utils.js +143 -143
- package/esm5/index.js +13 -13
- package/esm5/internals/angular.js +20 -20
- package/esm5/internals/index.js +10 -11
- package/esm5/internals/initial-state.js +45 -45
- package/esm5/internals/internal-tokens.js +16 -16
- package/esm5/internals/memoize.js +71 -71
- package/esm5/internals/ngxs-bootstrapper.js +56 -56
- package/esm5/internals/ngxs-store-internals.js +9 -9
- package/esm5/internals/src/symbols.js +14 -14
- package/esm5/internals/symbols.js +14 -14
- package/esm5/internals/testing/fresh-platform.js +121 -121
- package/esm5/internals/testing/helpers/ngxs-test.component.js +32 -32
- package/esm5/internals/testing/helpers/ngxs-test.module.js +32 -32
- package/esm5/internals/testing/index.js +8 -8
- package/esm5/internals/testing/ngxs-store-internals-testing.js +8 -8
- package/esm5/internals/testing/ngxs.setup.js +98 -98
- package/esm5/internals/testing/skip-console-logging.js +62 -62
- package/esm5/internals/testing/symbol.js +29 -29
- package/esm5/ngxs-store.js +24 -23
- package/esm5/operators/append.js +31 -31
- package/esm5/operators/compose.js +28 -28
- package/esm5/operators/iif.js +56 -56
- package/esm5/operators/index.js +18 -18
- package/esm5/operators/insert-item.js +41 -41
- package/esm5/operators/internals.js +5 -5
- package/esm5/operators/ngxs-store-operators.js +8 -8
- package/esm5/operators/patch.js +40 -40
- package/esm5/operators/remove-item.js +34 -34
- package/esm5/operators/update-item.js +52 -52
- package/esm5/operators/utils.js +50 -50
- package/esm5/src/actions/actions.js +62 -62
- package/esm5/src/actions/symbols.js +39 -39
- package/esm5/src/actions-stream.js +186 -186
- package/esm5/src/configs/messages.config.js +79 -79
- package/esm5/src/decorators/action.js +60 -60
- package/esm5/src/decorators/select/select-factory.js +46 -50
- package/esm5/src/decorators/select/select.js +50 -87
- package/esm5/src/decorators/select/symbols.js +51 -95
- package/esm5/src/decorators/selector/selector.js +59 -59
- package/esm5/src/decorators/selector/symbols.js +5 -5
- package/esm5/src/decorators/selector-options.js +34 -34
- package/esm5/src/decorators/state.js +78 -84
- package/esm5/src/execution/dispatch-outside-zone-ngxs-execution-strategy.js +123 -123
- package/esm5/src/execution/internal-ngxs-execution-strategy.js +54 -54
- package/esm5/src/execution/noop-ngxs-execution-strategy.js +43 -43
- package/esm5/src/execution/symbols.js +52 -52
- package/esm5/src/internal/dispatcher.js +255 -253
- package/esm5/src/internal/internals.js +495 -495
- package/esm5/src/internal/lifecycle-state-manager.js +177 -177
- package/esm5/src/internal/state-context-factory.js +146 -146
- package/esm5/src/internal/state-factory.js +583 -575
- package/esm5/src/internal/state-operations.js +134 -143
- package/esm5/src/internal/state-operators.js +34 -34
- package/esm5/src/internal/state-stream.js +37 -37
- package/esm5/src/ivy/ivy-enabled-in-dev-mode.js +28 -28
- package/esm5/src/module.js +202 -200
- package/esm5/src/modules/ngxs-feature.module.js +65 -65
- package/esm5/src/modules/ngxs-root.module.js +44 -47
- package/esm5/src/operators/leave-ngxs.js +58 -58
- package/esm5/src/operators/of-action.js +217 -217
- package/esm5/src/plugin-manager.js +82 -82
- package/esm5/src/plugin_api.js +10 -10
- package/esm5/src/public_api.js +29 -29
- package/esm5/src/public_to_deprecate.js +64 -64
- package/esm5/src/state-token/state-token.js +57 -57
- package/esm5/src/state-token/symbols.js +5 -5
- package/esm5/src/store.js +241 -241
- package/esm5/src/symbols.js +230 -229
- package/esm5/src/utils/compose.js +55 -55
- package/esm5/src/utils/freeze.js +35 -35
- package/esm5/src/utils/selector-utils.js +230 -230
- package/esm5/src/utils/store-validators.js +78 -78
- package/esm5/src/utils/utils.js +151 -151
- package/fesm2015/ngxs-store-internals-testing.js +274 -274
- package/fesm2015/ngxs-store-internals-testing.js.map +1 -1
- package/fesm2015/ngxs-store-internals.js +175 -377
- package/fesm2015/ngxs-store-internals.js.map +1 -1
- package/fesm2015/ngxs-store-operators.js +312 -312
- package/fesm2015/ngxs-store-operators.js.map +1 -1
- package/fesm2015/ngxs-store.js +3915 -3995
- package/fesm2015/ngxs-store.js.map +1 -1
- package/fesm5/ngxs-store-internals-testing.js +321 -321
- package/fesm5/ngxs-store-internals-testing.js.map +1 -1
- package/fesm5/ngxs-store-internals.js +200 -402
- package/fesm5/ngxs-store-internals.js.map +1 -1
- package/fesm5/ngxs-store-operators.js +316 -316
- package/fesm5/ngxs-store-operators.js.map +1 -1
- package/fesm5/ngxs-store.js +4410 -4491
- package/fesm5/ngxs-store.js.map +1 -1
- package/index.d.ts +8 -8
- package/internals/angular.d.ts +1 -1
- package/internals/index.d.ts +6 -7
- package/internals/initial-state.d.ts +8 -8
- package/internals/internal-tokens.d.ts +9 -9
- package/internals/memoize.d.ts +9 -9
- package/internals/ngxs-bootstrapper.d.ts +13 -13
- package/internals/ngxs-store-internals.d.ts +4 -4
- package/internals/ngxs-store-internals.metadata.json +1 -1
- package/internals/src/symbols.d.ts +7 -7
- package/internals/symbols.d.ts +7 -7
- package/internals/testing/fresh-platform.d.ts +1 -1
- package/internals/testing/helpers/ngxs-test.component.d.ts +5 -5
- package/internals/testing/helpers/ngxs-test.module.d.ts +4 -4
- package/internals/testing/index.d.ts +4 -4
- package/internals/testing/ngxs-store-internals-testing.d.ts +4 -4
- package/internals/testing/ngxs.setup.d.ts +7 -7
- package/internals/testing/skip-console-logging.d.ts +1 -1
- package/internals/testing/symbol.d.ts +14 -14
- package/ngxs-store.d.ts +20 -19
- package/ngxs-store.metadata.json +1 -1
- package/operators/append.d.ts +6 -6
- package/operators/compose.d.ts +2 -2
- package/operators/iif.d.ts +11 -11
- package/operators/index.d.ts +13 -13
- package/operators/insert-item.d.ts +7 -7
- package/operators/internals.d.ts +2 -2
- package/operators/ngxs-store-operators.d.ts +4 -4
- package/operators/patch.d.ts +10 -10
- package/operators/remove-item.d.ts +7 -7
- package/operators/update-item.d.ts +10 -10
- package/operators/utils.d.ts +9 -9
- package/package.json +1 -1
- package/src/actions/actions.d.ts +15 -15
- package/src/actions/symbols.d.ts +21 -21
- package/src/actions-stream.d.ts +49 -49
- package/src/configs/messages.config.d.ts +11 -11
- package/src/decorators/action.d.ts +5 -5
- package/src/decorators/select/select-factory.d.ts +13 -13
- package/src/decorators/select/select.d.ts +4 -4
- package/src/decorators/select/symbols.d.ts +10 -14
- package/src/decorators/selector/selector.d.ts +5 -5
- package/src/decorators/selector/symbols.d.ts +4 -4
- package/src/decorators/selector-options.d.ts +5 -5
- package/src/decorators/state.d.ts +6 -6
- package/src/execution/dispatch-outside-zone-ngxs-execution-strategy.d.ts +11 -11
- package/src/execution/internal-ngxs-execution-strategy.d.ts +7 -7
- package/src/execution/noop-ngxs-execution-strategy.d.ts +5 -5
- package/src/execution/symbols.d.ts +10 -10
- package/src/internal/dispatcher.d.ts +32 -32
- package/src/internal/internals.d.ts +166 -166
- package/src/internal/lifecycle-state-manager.d.ts +20 -20
- package/src/internal/state-context-factory.d.ts +15 -15
- package/src/internal/state-factory.d.ts +57 -57
- package/src/internal/state-operations.d.ts +19 -19
- package/src/internal/state-operators.d.ts +2 -2
- package/src/internal/state-stream.d.ts +11 -11
- package/src/ivy/ivy-enabled-in-dev-mode.d.ts +6 -6
- package/src/module.d.ts +23 -23
- package/src/modules/ngxs-feature.module.d.ts +13 -13
- package/src/modules/ngxs-root.module.d.ts +13 -13
- package/src/operators/leave-ngxs.d.ts +7 -7
- package/src/operators/of-action.d.ts +43 -43
- package/src/plugin-manager.d.ts +10 -10
- package/src/plugin_api.d.ts +5 -5
- package/src/public_api.d.ts +17 -17
- package/src/public_to_deprecate.d.ts +21 -21
- package/src/state-token/state-token.d.ts +7 -7
- package/src/state-token/symbols.d.ts +5 -5
- package/src/store.d.ts +59 -59
- package/src/symbols.d.ts +139 -138
- package/src/utils/compose.d.ts +23 -23
- package/src/utils/freeze.d.ts +5 -5
- package/src/utils/selector-utils.d.ts +23 -23
- package/src/utils/store-validators.d.ts +7 -7
- package/src/utils/utils.d.ts +46 -46
- package/types/index.d.ts +2 -2
- package/esm2015/internals/decorator-injector-adapter.js +0 -204
- package/esm5/internals/decorator-injector-adapter.js +0 -204
- package/internals/decorator-injector-adapter.d.ts +0 -15
package/esm2015/src/symbols.js
CHANGED
|
@@ -1,220 +1,221 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* @fileoverview added by tsickle
|
|
3
|
-
* @suppress {checkTypes,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc
|
|
4
|
-
*/
|
|
5
|
-
import { Injectable, InjectionToken } from '@angular/core';
|
|
6
|
-
import { DispatchOutsideZoneNgxsExecutionStrategy } from './execution/dispatch-outside-zone-ngxs-execution-strategy';
|
|
7
|
-
/** @type {?} */
|
|
8
|
-
export const ROOT_STATE_TOKEN = new InjectionToken('ROOT_STATE_TOKEN');
|
|
9
|
-
/** @type {?} */
|
|
10
|
-
export const FEATURE_STATE_TOKEN = new InjectionToken('FEATURE_STATE_TOKEN');
|
|
11
|
-
/** @type {?} */
|
|
12
|
-
export const NGXS_PLUGINS = new InjectionToken('NGXS_PLUGINS');
|
|
13
|
-
/** @type {?} */
|
|
14
|
-
export const META_KEY = 'NGXS_META';
|
|
15
|
-
/** @type {?} */
|
|
16
|
-
export const META_OPTIONS_KEY = 'NGXS_OPTIONS_META';
|
|
17
|
-
/** @type {?} */
|
|
18
|
-
export const SELECTOR_META_KEY = 'NGXS_SELECTOR_META';
|
|
19
|
-
/**
|
|
20
|
-
* The NGXS config settings.
|
|
21
|
-
*/
|
|
22
|
-
export class NgxsConfig {
|
|
23
|
-
constructor() {
|
|
24
|
-
/**
|
|
25
|
-
* Defining the default state before module initialization
|
|
26
|
-
* This is convenient if we need to create a define our own set of states.
|
|
27
|
-
* @deprecated will be removed after v4
|
|
28
|
-
* (default: {})
|
|
29
|
-
*/
|
|
30
|
-
this.defaultsState = {};
|
|
31
|
-
/**
|
|
32
|
-
* Defining shared selector options
|
|
33
|
-
*/
|
|
34
|
-
this.selectorOptions = {
|
|
35
|
-
injectContainerState: true,
|
|
36
|
-
// TODO: default is true in v3, will change in v4
|
|
37
|
-
suppressErrors: true // TODO: default is true in v3, will change in v4
|
|
38
|
-
};
|
|
39
|
-
this.compatibility = {
|
|
40
|
-
strictContentSecurityPolicy: false
|
|
41
|
-
};
|
|
42
|
-
this.executionStrategy = DispatchOutsideZoneNgxsExecutionStrategy;
|
|
43
|
-
}
|
|
44
|
-
}
|
|
45
|
-
NgxsConfig.decorators = [
|
|
46
|
-
{ type: Injectable }
|
|
47
|
-
];
|
|
48
|
-
/** @nocollapse */
|
|
49
|
-
NgxsConfig.ctorParameters = () => [];
|
|
50
|
-
if (false) {
|
|
51
|
-
/**
|
|
52
|
-
* Run in development mode. This will add additional debugging features:
|
|
53
|
-
* - Object.freeze on the state and actions to guarantee immutability
|
|
54
|
-
* (default: false)
|
|
55
|
-
*
|
|
56
|
-
*
|
|
57
|
-
*
|
|
58
|
-
*
|
|
59
|
-
|
|
60
|
-
|
|
61
|
-
|
|
62
|
-
|
|
63
|
-
|
|
64
|
-
|
|
65
|
-
*
|
|
66
|
-
*
|
|
67
|
-
*
|
|
68
|
-
*
|
|
69
|
-
*
|
|
70
|
-
*
|
|
71
|
-
*
|
|
72
|
-
*
|
|
73
|
-
*
|
|
74
|
-
|
|
75
|
-
|
|
76
|
-
|
|
77
|
-
|
|
78
|
-
*
|
|
79
|
-
*
|
|
80
|
-
*
|
|
81
|
-
*
|
|
82
|
-
|
|
83
|
-
|
|
84
|
-
|
|
85
|
-
|
|
86
|
-
*
|
|
87
|
-
|
|
88
|
-
|
|
89
|
-
|
|
90
|
-
|
|
91
|
-
|
|
92
|
-
*
|
|
93
|
-
* @
|
|
94
|
-
|
|
95
|
-
|
|
96
|
-
|
|
97
|
-
|
|
98
|
-
|
|
99
|
-
*
|
|
100
|
-
|
|
101
|
-
|
|
102
|
-
|
|
103
|
-
|
|
104
|
-
*
|
|
105
|
-
* @
|
|
106
|
-
|
|
107
|
-
|
|
108
|
-
|
|
109
|
-
|
|
110
|
-
*
|
|
111
|
-
* @
|
|
112
|
-
|
|
113
|
-
|
|
114
|
-
|
|
115
|
-
|
|
116
|
-
*
|
|
117
|
-
* @
|
|
118
|
-
|
|
119
|
-
|
|
120
|
-
}
|
|
121
|
-
|
|
122
|
-
|
|
123
|
-
*
|
|
124
|
-
|
|
125
|
-
|
|
126
|
-
|
|
127
|
-
|
|
128
|
-
|
|
129
|
-
*
|
|
130
|
-
* @param {?}
|
|
131
|
-
* @param {?}
|
|
132
|
-
* @
|
|
133
|
-
|
|
134
|
-
|
|
135
|
-
}
|
|
136
|
-
|
|
137
|
-
|
|
138
|
-
*
|
|
139
|
-
* @
|
|
140
|
-
|
|
141
|
-
|
|
142
|
-
|
|
143
|
-
|
|
144
|
-
|
|
145
|
-
*
|
|
146
|
-
|
|
147
|
-
|
|
148
|
-
|
|
149
|
-
|
|
150
|
-
*
|
|
151
|
-
|
|
152
|
-
|
|
153
|
-
|
|
154
|
-
|
|
155
|
-
*
|
|
156
|
-
|
|
157
|
-
|
|
158
|
-
|
|
159
|
-
|
|
160
|
-
|
|
161
|
-
*
|
|
162
|
-
*
|
|
163
|
-
|
|
164
|
-
|
|
165
|
-
|
|
166
|
-
|
|
167
|
-
* @param {?}
|
|
168
|
-
* @param {?}
|
|
169
|
-
|
|
170
|
-
|
|
171
|
-
|
|
172
|
-
this.
|
|
173
|
-
this.
|
|
174
|
-
|
|
175
|
-
}
|
|
176
|
-
|
|
177
|
-
|
|
178
|
-
|
|
179
|
-
|
|
180
|
-
|
|
181
|
-
|
|
182
|
-
|
|
183
|
-
|
|
184
|
-
|
|
185
|
-
|
|
186
|
-
*
|
|
187
|
-
|
|
188
|
-
|
|
189
|
-
|
|
190
|
-
|
|
191
|
-
|
|
192
|
-
* @
|
|
193
|
-
|
|
194
|
-
|
|
195
|
-
}
|
|
196
|
-
|
|
197
|
-
|
|
198
|
-
*
|
|
199
|
-
|
|
200
|
-
|
|
201
|
-
|
|
202
|
-
|
|
203
|
-
|
|
204
|
-
* @
|
|
205
|
-
|
|
206
|
-
|
|
207
|
-
}
|
|
208
|
-
|
|
209
|
-
|
|
210
|
-
*
|
|
211
|
-
|
|
212
|
-
|
|
213
|
-
|
|
214
|
-
|
|
215
|
-
|
|
216
|
-
* @
|
|
217
|
-
|
|
218
|
-
|
|
219
|
-
}
|
|
220
|
-
|
|
1
|
+
/**
|
|
2
|
+
* @fileoverview added by tsickle
|
|
3
|
+
* @suppress {checkTypes,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc
|
|
4
|
+
*/
|
|
5
|
+
import { Injectable, InjectionToken } from '@angular/core';
|
|
6
|
+
import { DispatchOutsideZoneNgxsExecutionStrategy } from './execution/dispatch-outside-zone-ngxs-execution-strategy';
|
|
7
|
+
/** @type {?} */
|
|
8
|
+
export const ROOT_STATE_TOKEN = new InjectionToken('ROOT_STATE_TOKEN');
|
|
9
|
+
/** @type {?} */
|
|
10
|
+
export const FEATURE_STATE_TOKEN = new InjectionToken('FEATURE_STATE_TOKEN');
|
|
11
|
+
/** @type {?} */
|
|
12
|
+
export const NGXS_PLUGINS = new InjectionToken('NGXS_PLUGINS');
|
|
13
|
+
/** @type {?} */
|
|
14
|
+
export const META_KEY = 'NGXS_META';
|
|
15
|
+
/** @type {?} */
|
|
16
|
+
export const META_OPTIONS_KEY = 'NGXS_OPTIONS_META';
|
|
17
|
+
/** @type {?} */
|
|
18
|
+
export const SELECTOR_META_KEY = 'NGXS_SELECTOR_META';
|
|
19
|
+
/**
|
|
20
|
+
* The NGXS config settings.
|
|
21
|
+
*/
|
|
22
|
+
export class NgxsConfig {
|
|
23
|
+
constructor() {
|
|
24
|
+
/**
|
|
25
|
+
* Defining the default state before module initialization
|
|
26
|
+
* This is convenient if we need to create a define our own set of states.
|
|
27
|
+
* @deprecated will be removed after v4
|
|
28
|
+
* (default: {})
|
|
29
|
+
*/
|
|
30
|
+
this.defaultsState = {};
|
|
31
|
+
/**
|
|
32
|
+
* Defining shared selector options
|
|
33
|
+
*/
|
|
34
|
+
this.selectorOptions = {
|
|
35
|
+
injectContainerState: true,
|
|
36
|
+
// TODO: default is true in v3, will change in v4
|
|
37
|
+
suppressErrors: true // TODO: default is true in v3, will change in v4
|
|
38
|
+
};
|
|
39
|
+
this.compatibility = {
|
|
40
|
+
strictContentSecurityPolicy: false
|
|
41
|
+
};
|
|
42
|
+
this.executionStrategy = DispatchOutsideZoneNgxsExecutionStrategy;
|
|
43
|
+
}
|
|
44
|
+
}
|
|
45
|
+
NgxsConfig.decorators = [
|
|
46
|
+
{ type: Injectable }
|
|
47
|
+
];
|
|
48
|
+
/** @nocollapse */
|
|
49
|
+
NgxsConfig.ctorParameters = () => [];
|
|
50
|
+
if (false) {
|
|
51
|
+
/**
|
|
52
|
+
* Run in development mode. This will add additional debugging features:
|
|
53
|
+
* - Object.freeze on the state and actions to guarantee immutability
|
|
54
|
+
* (default: false)
|
|
55
|
+
*
|
|
56
|
+
* Note: this property will be accounted only in development mode when using the Ivy compiler.
|
|
57
|
+
* It makes sense to use it only during development to ensure there're no state mutations.
|
|
58
|
+
* When building for production, the Object.freeze will be tree-shaken away.
|
|
59
|
+
* @type {?}
|
|
60
|
+
*/
|
|
61
|
+
NgxsConfig.prototype.developmentMode;
|
|
62
|
+
/** @type {?} */
|
|
63
|
+
NgxsConfig.prototype.compatibility;
|
|
64
|
+
/**
|
|
65
|
+
* Determines the execution context to perform async operations inside. An implementation can be
|
|
66
|
+
* provided to override the default behaviour where the async operations are run
|
|
67
|
+
* outside Angular's zone but all observable behaviours of NGXS are run back inside Angular's zone.
|
|
68
|
+
* These observable behaviours are from:
|
|
69
|
+
* `\@Select(...)`, `store.select(...)`, `actions.subscribe(...)` or `store.dispatch(...).subscribe(...)`
|
|
70
|
+
* Every `zone.run` causes Angular to run change detection on the whole tree (`app.tick()`) so of your
|
|
71
|
+
* application doesn't rely on zone.js running change detection then you can switch to the
|
|
72
|
+
* `NoopNgxsExecutionStrategy` that doesn't interact with zones.
|
|
73
|
+
* (default: null)
|
|
74
|
+
* @type {?}
|
|
75
|
+
*/
|
|
76
|
+
NgxsConfig.prototype.executionStrategy;
|
|
77
|
+
/**
|
|
78
|
+
* Defining the default state before module initialization
|
|
79
|
+
* This is convenient if we need to create a define our own set of states.
|
|
80
|
+
* @deprecated will be removed after v4
|
|
81
|
+
* (default: {})
|
|
82
|
+
* @type {?}
|
|
83
|
+
*/
|
|
84
|
+
NgxsConfig.prototype.defaultsState;
|
|
85
|
+
/**
|
|
86
|
+
* Defining shared selector options
|
|
87
|
+
* @type {?}
|
|
88
|
+
*/
|
|
89
|
+
NgxsConfig.prototype.selectorOptions;
|
|
90
|
+
}
|
|
91
|
+
/**
|
|
92
|
+
* State context provided to the actions in the state.
|
|
93
|
+
* @record
|
|
94
|
+
* @template T
|
|
95
|
+
*/
|
|
96
|
+
export function StateContext() { }
|
|
97
|
+
if (false) {
|
|
98
|
+
/**
|
|
99
|
+
* Get the current state.
|
|
100
|
+
* @return {?}
|
|
101
|
+
*/
|
|
102
|
+
StateContext.prototype.getState = function () { };
|
|
103
|
+
/**
|
|
104
|
+
* Reset the state to a new value.
|
|
105
|
+
* @param {?} val
|
|
106
|
+
* @return {?}
|
|
107
|
+
*/
|
|
108
|
+
StateContext.prototype.setState = function (val) { };
|
|
109
|
+
/**
|
|
110
|
+
* Patch the existing state with the provided value.
|
|
111
|
+
* @param {?} val
|
|
112
|
+
* @return {?}
|
|
113
|
+
*/
|
|
114
|
+
StateContext.prototype.patchState = function (val) { };
|
|
115
|
+
/**
|
|
116
|
+
* Dispatch a new action and return the dispatched observable.
|
|
117
|
+
* @param {?} actions
|
|
118
|
+
* @return {?}
|
|
119
|
+
*/
|
|
120
|
+
StateContext.prototype.dispatch = function (actions) { };
|
|
121
|
+
}
|
|
122
|
+
/**
|
|
123
|
+
* Plugin interface
|
|
124
|
+
* @record
|
|
125
|
+
*/
|
|
126
|
+
export function NgxsPlugin() { }
|
|
127
|
+
if (false) {
|
|
128
|
+
/**
|
|
129
|
+
* Handle the state/action before its submitted to the state handlers.
|
|
130
|
+
* @param {?} state
|
|
131
|
+
* @param {?} action
|
|
132
|
+
* @param {?} next
|
|
133
|
+
* @return {?}
|
|
134
|
+
*/
|
|
135
|
+
NgxsPlugin.prototype.handle = function (state, action, next) { };
|
|
136
|
+
}
|
|
137
|
+
/**
|
|
138
|
+
* Options that can be provided to the store.
|
|
139
|
+
* @record
|
|
140
|
+
* @template T
|
|
141
|
+
*/
|
|
142
|
+
export function StoreOptions() { }
|
|
143
|
+
if (false) {
|
|
144
|
+
/**
|
|
145
|
+
* Name of the state. Required.
|
|
146
|
+
* @type {?}
|
|
147
|
+
*/
|
|
148
|
+
StoreOptions.prototype.name;
|
|
149
|
+
/**
|
|
150
|
+
* Default values for the state. If not provided, uses empty object.
|
|
151
|
+
* @type {?|undefined}
|
|
152
|
+
*/
|
|
153
|
+
StoreOptions.prototype.defaults;
|
|
154
|
+
/**
|
|
155
|
+
* Sub states for the given state.
|
|
156
|
+
* @type {?|undefined}
|
|
157
|
+
*/
|
|
158
|
+
StoreOptions.prototype.children;
|
|
159
|
+
}
|
|
160
|
+
/**
|
|
161
|
+
* Represents a basic change from a previous to a new value for a single state instance.
|
|
162
|
+
* Passed as a value in a NgxsSimpleChanges object to the ngxsOnChanges hook.
|
|
163
|
+
* @template T
|
|
164
|
+
*/
|
|
165
|
+
export class NgxsSimpleChange {
|
|
166
|
+
/**
|
|
167
|
+
* @param {?} previousValue
|
|
168
|
+
* @param {?} currentValue
|
|
169
|
+
* @param {?} firstChange
|
|
170
|
+
*/
|
|
171
|
+
constructor(previousValue, currentValue, firstChange) {
|
|
172
|
+
this.previousValue = previousValue;
|
|
173
|
+
this.currentValue = currentValue;
|
|
174
|
+
this.firstChange = firstChange;
|
|
175
|
+
}
|
|
176
|
+
}
|
|
177
|
+
if (false) {
|
|
178
|
+
/** @type {?} */
|
|
179
|
+
NgxsSimpleChange.prototype.previousValue;
|
|
180
|
+
/** @type {?} */
|
|
181
|
+
NgxsSimpleChange.prototype.currentValue;
|
|
182
|
+
/** @type {?} */
|
|
183
|
+
NgxsSimpleChange.prototype.firstChange;
|
|
184
|
+
}
|
|
185
|
+
/**
|
|
186
|
+
* On init interface
|
|
187
|
+
* @record
|
|
188
|
+
*/
|
|
189
|
+
export function NgxsOnInit() { }
|
|
190
|
+
if (false) {
|
|
191
|
+
/**
|
|
192
|
+
* @param {?} ctx
|
|
193
|
+
* @return {?}
|
|
194
|
+
*/
|
|
195
|
+
NgxsOnInit.prototype.ngxsOnInit = function (ctx) { };
|
|
196
|
+
}
|
|
197
|
+
/**
|
|
198
|
+
* On change interface
|
|
199
|
+
* @record
|
|
200
|
+
*/
|
|
201
|
+
export function NgxsOnChanges() { }
|
|
202
|
+
if (false) {
|
|
203
|
+
/**
|
|
204
|
+
* @param {?} change
|
|
205
|
+
* @return {?}
|
|
206
|
+
*/
|
|
207
|
+
NgxsOnChanges.prototype.ngxsOnChanges = function (change) { };
|
|
208
|
+
}
|
|
209
|
+
/**
|
|
210
|
+
* After bootstrap interface
|
|
211
|
+
* @record
|
|
212
|
+
*/
|
|
213
|
+
export function NgxsAfterBootstrap() { }
|
|
214
|
+
if (false) {
|
|
215
|
+
/**
|
|
216
|
+
* @param {?} ctx
|
|
217
|
+
* @return {?}
|
|
218
|
+
*/
|
|
219
|
+
NgxsAfterBootstrap.prototype.ngxsAfterBootstrap = function (ctx) { };
|
|
220
|
+
}
|
|
221
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"symbols.js","sourceRoot":"ng://@ngxs/store/","sources":["src/symbols.ts"],"names":[],"mappings":";;;;AAAA,OAAO,EAAE,UAAU,EAAE,cAAc,EAAQ,MAAM,eAAe,CAAC;AAMjE,OAAO,EAAE,wCAAwC,EAAE,MAAM,2DAA2D,CAAC;;AAGrH,MAAM,OAAO,gBAAgB,GAAG,IAAI,cAAc,CAAM,kBAAkB,CAAC;;AAC3E,MAAM,OAAO,mBAAmB,GAAG,IAAI,cAAc,CAAM,qBAAqB,CAAC;;AACjF,MAAM,OAAO,YAAY,GAAG,IAAI,cAAc,CAAC,cAAc,CAAC;;AAE9D,MAAM,OAAO,QAAQ,GAAG,WAAW;;AACnC,MAAM,OAAO,gBAAgB,GAAG,mBAAmB;;AACnD,MAAM,OAAO,iBAAiB,GAAG,oBAAoB;;;;AAYrD,MAAM,OAAO,UAAU;IA8CrB;;;;;;;QATA,kBAAa,GAAgB,EAAE,CAAC;;;;QAIhC,oBAAe,GAA0B;YACvC,oBAAoB,EAAE,IAAI;;YAC1B,cAAc,EAAE,IAAI,CAAC,iDAAiD;SACvE,CAAC;QAGA,IAAI,CAAC,aAAa,GAAG;YACnB,2BAA2B,EAAE,KAAK;SACnC,CAAC;QACF,IAAI,CAAC,iBAAiB,GAAG,wCAAwC,CAAC;IACpE,CAAC;;;YApDF,UAAU;;;;;;;;;;;;;;;IAWT,qCAAyB;;IACzB,mCAOE;;;;;;;;;;;;;IAYF,uCAA+C;;;;;;;;IAO/C,mCAAgC;;;;;IAIhC,qCAGE;;;;;;;AAeJ,kCAoBC;;;;;;IAhBC,kDAAc;;;;;;IAKd,qDAAuC;;;;;;IAKvC,uDAA+B;;;;;;IAK/B,yDAAiD;;;;;;AAQnD,gCAKC;;;;;;;;;IADC,iEAA6D;;;;;;;AAM/D,kCAeC;;;;;;IAXC,4BAA6B;;;;;IAK7B,gCAAa;;;;;IAKb,gCAAwB;;;;;;;AAO1B,MAAM,OAAO,gBAAgB;;;;;;IAC3B,YACkB,aAAgB,EAChB,YAAe,EACf,WAAoB;QAFpB,kBAAa,GAAb,aAAa,CAAG;QAChB,iBAAY,GAAZ,YAAY,CAAG;QACf,gBAAW,GAAX,WAAW,CAAS;IACnC,CAAC;CACL;;;IAJG,yCAAgC;;IAChC,wCAA+B;;IAC/B,uCAAoC;;;;;;AAOxC,gCAEC;;;;;;IADC,qDAAyC;;;;;;AAM3C,mCAEC;;;;;;IADC,8DAA8C;;;;;;AAMhD,wCAEC;;;;;;IADC,qEAAiD","sourcesContent":["import { Injectable, InjectionToken, Type } from '@angular/core';\nimport { Observable } from 'rxjs';\n\nimport { PlainObject, StateClass } from '@ngxs/store/internals';\nimport { SharedSelectorOptions } from './internal/internals';\nimport { NgxsExecutionStrategy } from './execution/symbols';\nimport { DispatchOutsideZoneNgxsExecutionStrategy } from './execution/dispatch-outside-zone-ngxs-execution-strategy';\nimport { StateToken } from './state-token/state-token';\n\nexport const ROOT_STATE_TOKEN = new InjectionToken<any>('ROOT_STATE_TOKEN');\nexport const FEATURE_STATE_TOKEN = new InjectionToken<any>('FEATURE_STATE_TOKEN');\nexport const NGXS_PLUGINS = new InjectionToken('NGXS_PLUGINS');\n\nexport const META_KEY = 'NGXS_META';\nexport const META_OPTIONS_KEY = 'NGXS_OPTIONS_META';\nexport const SELECTOR_META_KEY = 'NGXS_SELECTOR_META';\n\nexport type NgxsLifeCycle = Partial<NgxsOnChanges> &\n  Partial<NgxsOnInit> &\n  Partial<NgxsAfterBootstrap>;\n\nexport type NgxsPluginFn = (state: any, mutation: any, next: NgxsNextPluginFn) => any;\n\n/**\n * The NGXS config settings.\n */\n@Injectable()\nexport class NgxsConfig {\n  /**\n   * Run in development mode. This will add additional debugging features:\n   * - Object.freeze on the state and actions to guarantee immutability\n   * (default: false)\n   *\n   * Note: this property will be accounted only in development mode when using the Ivy compiler.\n   * It makes sense to use it only during development to ensure there're no state mutations.\n   * When building for production, the Object.freeze will be tree-shaken away.\n   */\n  developmentMode: boolean;\n  compatibility: {\n    /**\n     * Support a strict Content Security Policy.\n     * This will circumvent some optimisations that violate a strict CSP through the use of `new Function(...)`.\n     * (default: false)\n     */\n    strictContentSecurityPolicy: boolean;\n  };\n  /**\n   * Determines the execution context to perform async operations inside. An implementation can be\n   * provided to override the default behaviour where the async operations are run\n   * outside Angular's zone but all observable behaviours of NGXS are run back inside Angular's zone.\n   * These observable behaviours are from:\n   *   `@Select(...)`, `store.select(...)`, `actions.subscribe(...)` or `store.dispatch(...).subscribe(...)`\n   * Every `zone.run` causes Angular to run change detection on the whole tree (`app.tick()`) so of your\n   * application doesn't rely on zone.js running change detection then you can switch to the\n   * `NoopNgxsExecutionStrategy` that doesn't interact with zones.\n   * (default: null)\n   */\n  executionStrategy: Type<NgxsExecutionStrategy>;\n  /**\n   * Defining the default state before module initialization\n   * This is convenient if we need to create a define our own set of states.\n   * @deprecated will be removed after v4\n   * (default: {})\n   */\n  defaultsState: PlainObject = {};\n  /**\n   * Defining shared selector options\n   */\n  selectorOptions: SharedSelectorOptions = {\n    injectContainerState: true, // TODO: default is true in v3, will change in v4\n    suppressErrors: true // TODO: default is true in v3, will change in v4\n  };\n\n  constructor() {\n    this.compatibility = {\n      strictContentSecurityPolicy: false\n    };\n    this.executionStrategy = DispatchOutsideZoneNgxsExecutionStrategy;\n  }\n}\n\nexport type StateOperator<T> = (existing: Readonly<T>) => T;\n\n/**\n * State context provided to the actions in the state.\n */\nexport interface StateContext<T> {\n  /**\n   * Get the current state.\n   */\n  getState(): T;\n\n  /**\n   * Reset the state to a new value.\n   */\n  setState(val: T | StateOperator<T>): T;\n\n  /**\n   * Patch the existing state with the provided value.\n   */\n  patchState(val: Partial<T>): T;\n\n  /**\n   * Dispatch a new action and return the dispatched observable.\n   */\n  dispatch(actions: any | any[]): Observable<void>;\n}\n\nexport type NgxsNextPluginFn = (state: any, mutation: any) => any;\n\n/**\n * Plugin interface\n */\nexport interface NgxsPlugin {\n  /**\n   * Handle the state/action before its submitted to the state handlers.\n   */\n  handle(state: any, action: any, next: NgxsNextPluginFn): any;\n}\n\n/**\n * Options that can be provided to the store.\n */\nexport interface StoreOptions<T> {\n  /**\n   * Name of the state. Required.\n   */\n  name: string | StateToken<T>;\n\n  /**\n   * Default values for the state. If not provided, uses empty object.\n   */\n  defaults?: T;\n\n  /**\n   * Sub states for the given state.\n   */\n  children?: StateClass[];\n}\n\n/**\n * Represents a basic change from a previous to a new value for a single state instance.\n * Passed as a value in a NgxsSimpleChanges object to the ngxsOnChanges hook.\n */\nexport class NgxsSimpleChange<T = any> {\n  constructor(\n    public readonly previousValue: T,\n    public readonly currentValue: T,\n    public readonly firstChange: boolean\n  ) {}\n}\n\n/**\n * On init interface\n */\nexport interface NgxsOnInit {\n  ngxsOnInit(ctx: StateContext<any>): void;\n}\n\n/**\n * On change interface\n */\nexport interface NgxsOnChanges {\n  ngxsOnChanges(change: NgxsSimpleChange): void;\n}\n\n/**\n * After bootstrap interface\n */\nexport interface NgxsAfterBootstrap {\n  ngxsAfterBootstrap(ctx: StateContext<any>): void;\n}\n\nexport type NgxsModuleOptions = Partial<NgxsConfig>;\n\n/** @internal */\ndeclare global {\n  const ngDevMode: boolean;\n}\n"]}
|
|
@@ -1,44 +1,44 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* @fileoverview added by tsickle
|
|
3
|
-
* @suppress {checkTypes,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc
|
|
4
|
-
*/
|
|
5
|
-
/**
|
|
6
|
-
* Composes a array of functions from left to right. Example:
|
|
7
|
-
*
|
|
8
|
-
* compose([fn, final])(state, action);
|
|
9
|
-
*
|
|
10
|
-
* then the funcs have a signature like:
|
|
11
|
-
*
|
|
12
|
-
* function fn (state, action, next) {
|
|
13
|
-
* console.log('here', state, action, next);
|
|
14
|
-
* return next(state, action);
|
|
15
|
-
* }
|
|
16
|
-
*
|
|
17
|
-
* function final (state, action) {
|
|
18
|
-
* console.log('here', state, action);
|
|
19
|
-
* return state;
|
|
20
|
-
* }
|
|
21
|
-
*
|
|
22
|
-
* the last function should not call `next`.
|
|
23
|
-
*
|
|
24
|
-
* @ignore
|
|
25
|
-
* @type {?}
|
|
26
|
-
*/
|
|
27
|
-
export const compose = (/**
|
|
28
|
-
* @param {?} funcs
|
|
29
|
-
* @return {?}
|
|
30
|
-
*/
|
|
31
|
-
(funcs) => (/**
|
|
32
|
-
* @param {...?} args
|
|
33
|
-
* @return {?}
|
|
34
|
-
*/
|
|
35
|
-
(...args) => {
|
|
36
|
-
/** @type {?} */
|
|
37
|
-
const curr = (/** @type {?} */ (funcs.shift()));
|
|
38
|
-
return curr(...args, (/**
|
|
39
|
-
* @param {...?} nextArgs
|
|
40
|
-
* @return {?}
|
|
41
|
-
*/
|
|
42
|
-
(...nextArgs) => compose(funcs)(...nextArgs)));
|
|
43
|
-
}));
|
|
44
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
1
|
+
/**
|
|
2
|
+
* @fileoverview added by tsickle
|
|
3
|
+
* @suppress {checkTypes,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc
|
|
4
|
+
*/
|
|
5
|
+
/**
|
|
6
|
+
* Composes a array of functions from left to right. Example:
|
|
7
|
+
*
|
|
8
|
+
* compose([fn, final])(state, action);
|
|
9
|
+
*
|
|
10
|
+
* then the funcs have a signature like:
|
|
11
|
+
*
|
|
12
|
+
* function fn (state, action, next) {
|
|
13
|
+
* console.log('here', state, action, next);
|
|
14
|
+
* return next(state, action);
|
|
15
|
+
* }
|
|
16
|
+
*
|
|
17
|
+
* function final (state, action) {
|
|
18
|
+
* console.log('here', state, action);
|
|
19
|
+
* return state;
|
|
20
|
+
* }
|
|
21
|
+
*
|
|
22
|
+
* the last function should not call `next`.
|
|
23
|
+
*
|
|
24
|
+
* @ignore
|
|
25
|
+
* @type {?}
|
|
26
|
+
*/
|
|
27
|
+
export const compose = (/**
|
|
28
|
+
* @param {?} funcs
|
|
29
|
+
* @return {?}
|
|
30
|
+
*/
|
|
31
|
+
(funcs) => (/**
|
|
32
|
+
* @param {...?} args
|
|
33
|
+
* @return {?}
|
|
34
|
+
*/
|
|
35
|
+
(...args) => {
|
|
36
|
+
/** @type {?} */
|
|
37
|
+
const curr = (/** @type {?} */ (funcs.shift()));
|
|
38
|
+
return curr(...args, (/**
|
|
39
|
+
* @param {...?} nextArgs
|
|
40
|
+
* @return {?}
|
|
41
|
+
*/
|
|
42
|
+
(...nextArgs) => compose(funcs)(...nextArgs)));
|
|
43
|
+
}));
|
|
44
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY29tcG9zZS5qcyIsInNvdXJjZVJvb3QiOiJuZzovL0BuZ3hzL3N0b3JlLyIsInNvdXJjZXMiOlsic3JjL3V0aWxzL2NvbXBvc2UudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7QUF1QkEsTUFBTSxPQUFPLE9BQU87Ozs7QUFBRyxDQUFDLEtBQWdCLEVBQUUsRUFBRTs7OztBQUFDLENBQUMsR0FBRyxJQUFXLEVBQUUsRUFBRTs7VUFDeEQsSUFBSSxHQUFHLG1CQUFBLEtBQUssQ0FBQyxLQUFLLEVBQUUsRUFBQztJQUMzQixPQUFPLElBQUksQ0FBQyxHQUFHLElBQUk7Ozs7SUFBRSxDQUFDLEdBQUcsUUFBZSxFQUFFLEVBQUUsQ0FBQyxPQUFPLENBQUMsS0FBSyxDQUFDLENBQUMsR0FBRyxRQUFRLENBQUMsRUFBQyxDQUFDO0FBQzVFLENBQUMsQ0FBQSxDQUFBIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0IHR5cGUgU3RhdGVGbiA9ICguLi5hcmdzOiBhbnlbXSkgPT4gYW55O1xuXG4vKipcbiAqIENvbXBvc2VzIGEgYXJyYXkgb2YgZnVuY3Rpb25zIGZyb20gbGVmdCB0byByaWdodC4gRXhhbXBsZTpcbiAqXG4gKiAgICAgIGNvbXBvc2UoW2ZuLCBmaW5hbF0pKHN0YXRlLCBhY3Rpb24pO1xuICpcbiAqIHRoZW4gdGhlIGZ1bmNzIGhhdmUgYSBzaWduYXR1cmUgbGlrZTpcbiAqXG4gKiAgICAgIGZ1bmN0aW9uIGZuIChzdGF0ZSwgYWN0aW9uLCBuZXh0KSB7XG4gKiAgICAgICAgICBjb25zb2xlLmxvZygnaGVyZScsIHN0YXRlLCBhY3Rpb24sIG5leHQpO1xuICogICAgICAgICAgcmV0dXJuIG5leHQoc3RhdGUsIGFjdGlvbik7XG4gKiAgICAgIH1cbiAqXG4gKiAgICAgIGZ1bmN0aW9uIGZpbmFsIChzdGF0ZSwgYWN0aW9uKSB7XG4gKiAgICAgICAgICBjb25zb2xlLmxvZygnaGVyZScsIHN0YXRlLCBhY3Rpb24pO1xuICogICAgICAgICAgcmV0dXJuIHN0YXRlO1xuICogICAgICB9XG4gKlxuICogdGhlIGxhc3QgZnVuY3Rpb24gc2hvdWxkIG5vdCBjYWxsIGBuZXh0YC5cbiAqXG4gKiBAaWdub3JlXG4gKi9cbmV4cG9ydCBjb25zdCBjb21wb3NlID0gKGZ1bmNzOiBTdGF0ZUZuW10pID0+ICguLi5hcmdzOiBhbnlbXSkgPT4ge1xuICBjb25zdCBjdXJyID0gZnVuY3Muc2hpZnQoKSE7XG4gIHJldHVybiBjdXJyKC4uLmFyZ3MsICguLi5uZXh0QXJnczogYW55W10pID0+IGNvbXBvc2UoZnVuY3MpKC4uLm5leHRBcmdzKSk7XG59O1xuIl19
|