@norith/glimmer-component 1.0.0

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.
Files changed (72) hide show
  1. package/README.md +42 -0
  2. package/addon/-private/base-component-manager.ts +35 -0
  3. package/addon/-private/component.ts +287 -0
  4. package/addon/-private/ember-component-manager.ts +99 -0
  5. package/addon/index.ts +34 -0
  6. package/config/environment.js +5 -0
  7. package/dist/commonjs/addon/-private/base-component-manager.d.ts +13 -0
  8. package/dist/commonjs/addon/-private/base-component-manager.js +20 -0
  9. package/dist/commonjs/addon/-private/component.d.ts +244 -0
  10. package/dist/commonjs/addon/-private/component.js +170 -0
  11. package/dist/commonjs/index.d.ts +1 -0
  12. package/dist/commonjs/index.js +9 -0
  13. package/dist/commonjs/src/component-manager.d.ts +12 -0
  14. package/dist/commonjs/src/component-manager.js +30 -0
  15. package/dist/commonjs/src/component.d.ts +4 -0
  16. package/dist/commonjs/src/component.js +23 -0
  17. package/dist/commonjs/test/index.d.ts +1 -0
  18. package/dist/commonjs/test/index.js +4 -0
  19. package/dist/commonjs/test/interactive/args-test.d.ts +1 -0
  20. package/dist/commonjs/test/interactive/args-test.js +47 -0
  21. package/dist/commonjs/test/interactive/index.d.ts +2 -0
  22. package/dist/commonjs/test/interactive/index.js +5 -0
  23. package/dist/commonjs/test/interactive/lifecycle-hook-test.d.ts +1 -0
  24. package/dist/commonjs/test/interactive/lifecycle-hook-test.js +92 -0
  25. package/dist/modules/addon/-private/base-component-manager.d.ts +13 -0
  26. package/dist/modules/addon/-private/base-component-manager.js +17 -0
  27. package/dist/modules/addon/-private/component.d.ts +244 -0
  28. package/dist/modules/addon/-private/component.js +167 -0
  29. package/dist/modules/index.d.ts +1 -0
  30. package/dist/modules/index.js +2 -0
  31. package/dist/modules/src/component-manager.d.ts +12 -0
  32. package/dist/modules/src/component-manager.js +24 -0
  33. package/dist/modules/src/component.d.ts +4 -0
  34. package/dist/modules/src/component.js +17 -0
  35. package/dist/modules/test/index.d.ts +1 -0
  36. package/dist/modules/test/index.js +2 -0
  37. package/dist/modules/test/interactive/args-test.d.ts +1 -0
  38. package/dist/modules/test/interactive/args-test.js +42 -0
  39. package/dist/modules/test/interactive/index.d.ts +2 -0
  40. package/dist/modules/test/interactive/index.js +3 -0
  41. package/dist/modules/test/interactive/lifecycle-hook-test.d.ts +1 -0
  42. package/dist/modules/test/interactive/lifecycle-hook-test.js +87 -0
  43. package/ember-addon-main.js +5 -0
  44. package/index.ts +1 -0
  45. package/package.json +115 -0
  46. package/src/component-manager.ts +24 -0
  47. package/src/component.ts +22 -0
  48. package/test/ember/dummy/app/app.js +14 -0
  49. package/test/ember/dummy/app/components/conference-speakers.js +22 -0
  50. package/test/ember/dummy/app/config/environment.d.ts +16 -0
  51. package/test/ember/dummy/app/index.html +25 -0
  52. package/test/ember/dummy/app/resolver.js +3 -0
  53. package/test/ember/dummy/app/router.js +13 -0
  54. package/test/ember/dummy/app/styles/app.css +0 -0
  55. package/test/ember/dummy/app/templates/application.hbs +3 -0
  56. package/test/ember/dummy/app/templates/components/conference-speakers.hbs +14 -0
  57. package/test/ember/dummy/app/templates/conference-speakers.hbs +1 -0
  58. package/test/ember/dummy/config/environment.js +51 -0
  59. package/test/ember/dummy/config/optional-features.json +6 -0
  60. package/test/ember/dummy/config/targets.js +14 -0
  61. package/test/ember/dummy/public/robots.txt +3 -0
  62. package/test/ember/index.html +40 -0
  63. package/test/ember/integration/components/glimmer-component-guide-test.js +42 -0
  64. package/test/ember/integration/components/glimmer-component-test.js +288 -0
  65. package/test/ember/test-helper.js +12 -0
  66. package/test/index.ts +1 -0
  67. package/test/interactive/args-test.ts +49 -0
  68. package/test/interactive/index.ts +2 -0
  69. package/test/interactive/lifecycle-hook-test.ts +99 -0
  70. package/types/@ember/component.d.ts +11 -0
  71. package/types/ember/index.d.ts +9 -0
  72. package/types/ember-compatibility-helpers.d.ts +1 -0
@@ -0,0 +1,244 @@
1
+ export declare function setDestroying(component: GlimmerComponent<object>): void;
2
+ export declare function setDestroyed(component: GlimmerComponent<object>): void;
3
+ interface ArgsSetMap extends WeakMap<Args<unknown>, boolean> {
4
+ get<S>(key: Args<S>): boolean | undefined;
5
+ set<S>(key: Args<S>, value: boolean): this;
6
+ has<S>(key: Args<S>): boolean;
7
+ }
8
+ export declare let ARGS_SET: ArgsSetMap;
9
+ declare const Empty: unique symbol;
10
+ /**
11
+ * This provides us a way to have a "fallback" which represents an empty object,
12
+ * without the downsides of how TS treats `{}`. Specifically: this will
13
+ * correctly leverage "excess property checking" so that, given a component
14
+ * which has no named args, if someone invokes it with any named args, they will
15
+ * get a type error.
16
+ *
17
+ * @internal This is exported so declaration emit works (if it were not emitted,
18
+ * declarations which fall back to it would not work). It is *not* intended for
19
+ * public usage, and the specific mechanics it uses may change at any time.
20
+ * The location of this export *is* part of the public API, because moving it
21
+ * will break existing declarations, but is not legal for end users to import
22
+ * themselves, so ***DO NOT RELY ON IT***.
23
+ */
24
+ export declare type EmptyObject = {
25
+ [Empty]?: true;
26
+ };
27
+ declare type GetOrElse<Obj, K extends PropertyKey, Fallback> = Obj extends {
28
+ [Key in K]: infer U;
29
+ } ? U : Fallback;
30
+ /** Given a signature `S`, get back the `Args` type. */
31
+ declare type ArgsFor<S> = S extends {
32
+ Args: infer Args;
33
+ } ? Args extends {
34
+ Named?: object;
35
+ Positional?: unknown[];
36
+ } ? {
37
+ Named: GetOrElse<S['Args'], 'Named', EmptyObject>;
38
+ Positional: GetOrElse<S['Args'], 'Positional', []>;
39
+ } : {
40
+ Named: S['Args'];
41
+ Positional: [];
42
+ } : {
43
+ Named: EmptyObject;
44
+ Positional: [];
45
+ };
46
+ declare type _ExpandSignature<T> = {
47
+ Element: GetOrElse<T, 'Element', null>;
48
+ Args: keyof T extends 'Args' | 'Element' | 'Blocks' ? ArgsFor<T> : {
49
+ Named: T;
50
+ Positional: [];
51
+ };
52
+ Blocks: T extends {
53
+ Blocks: infer Blocks;
54
+ } ? {
55
+ [Block in keyof Blocks]: Blocks[Block] extends unknown[] ? {
56
+ Params: {
57
+ Positional: Blocks[Block];
58
+ };
59
+ } : Blocks[Block];
60
+ } : EmptyObject;
61
+ };
62
+ /**
63
+ * Given any allowed shorthand form of a signature, desugars it to its full
64
+ * expanded type.
65
+ *
66
+ * @internal This is only exported so we can avoid duplicating it in
67
+ * [Glint](https://github.com/typed-ember/glint) or other such tooling. It is
68
+ * *not* intended for public usage, and the specific mechanics it uses may
69
+ * change at any time. Although the signature produced by is part of Glimmer's
70
+ * public API the existence and mechanics of this specific symbol are *not*,
71
+ * so ***DO NOT RELY ON IT***.
72
+ */
73
+ export declare type ExpandSignature<T> = T extends any ? _ExpandSignature<T> : never;
74
+ /**
75
+ * @internal we use this type for convenience internally; inference means users
76
+ * should not normally need to name it
77
+ */
78
+ export declare type Args<S> = ExpandSignature<S>['Args']['Named'];
79
+ /**
80
+ * The `Component` class defines an encapsulated UI element that is rendered to
81
+ * the DOM. A component is made up of a template and, optionally, this component
82
+ * object.
83
+ *
84
+ * ## Defining a Component
85
+ *
86
+ * To define a component, subclass `Component` and add your own properties,
87
+ * methods and lifecycle hooks:
88
+ *
89
+ * ```ts
90
+ * import Component from '@norith/glimmer-component';
91
+ *
92
+ * export default class extends Component {
93
+ * }
94
+ * ```
95
+ *
96
+ * ## Lifecycle Hooks
97
+ *
98
+ * Lifecycle hooks allow you to respond to changes to a component, such as when
99
+ * it gets created, rendered, updated or destroyed. To add a lifecycle hook to a
100
+ * component, implement the hook as a method on your component subclass.
101
+ *
102
+ * For example, to be notified when Glimmer has rendered your component so you
103
+ * can attach a legacy jQuery plugin, implement the `didInsertElement()` method:
104
+ *
105
+ * ```ts
106
+ * import Component from '@norith/glimmer-component';
107
+ *
108
+ * export default class extends Component {
109
+ * didInsertElement() {
110
+ * $(this.element).pickadate();
111
+ * }
112
+ * }
113
+ * ```
114
+ *
115
+ * ## Data for Templates
116
+ *
117
+ * `Component`s have two different kinds of data, or state, that can be
118
+ * displayed in templates:
119
+ *
120
+ * 1. Arguments
121
+ * 2. Properties
122
+ *
123
+ * Arguments are data that is passed in to a component from its parent
124
+ * component. For example, if I have a `UserGreeting` component, I can pass it
125
+ * a name and greeting to use:
126
+ *
127
+ * ```hbs
128
+ * <UserGreeting @name="Ricardo" @greeting="Olá" />
129
+ * ```
130
+ *
131
+ * Inside my `UserGreeting` template, I can access the `@name` and `@greeting`
132
+ * arguments that I've been given:
133
+ *
134
+ * ```hbs
135
+ * {{@greeting}}, {{@name}}!
136
+ * ```
137
+ *
138
+ * Arguments are also available inside my component:
139
+ *
140
+ * ```ts
141
+ * console.log(this.args.greeting); // prints "Olá"
142
+ * ```
143
+ *
144
+ * Properties, on the other hand, are internal to the component and declared in
145
+ * the class. You can use properties to store data that you want to show in the
146
+ * template, or pass to another component as an argument.
147
+ *
148
+ * ```ts
149
+ * import Component from '@norith/glimmer-component';
150
+ *
151
+ * export default class extends Component {
152
+ * user = {
153
+ * name: 'Robbie'
154
+ * }
155
+ * }
156
+ * ```
157
+ *
158
+ * In the above example, we've defined a component with a `user` property that
159
+ * contains an object with its own `name` property.
160
+ *
161
+ * We can render that property in our template:
162
+ *
163
+ * ```hbs
164
+ * Hello, {{user.name}}!
165
+ * ```
166
+ *
167
+ * We can also take that property and pass it as an argument to the
168
+ * `UserGreeting` component we defined above:
169
+ *
170
+ * ```hbs
171
+ * <UserGreeting @greeting="Hello" @name={{user.name}} />
172
+ * ```
173
+ *
174
+ * ## Arguments vs. Properties
175
+ *
176
+ * Remember, arguments are data that was given to your component by its parent
177
+ * component, and properties are data your component has defined for itself.
178
+ *
179
+ * You can tell the difference between arguments and properties in templates
180
+ * because arguments always start with an `@` sign (think "A is for arguments"):
181
+ *
182
+ * ```hbs
183
+ * {{@firstName}}
184
+ * ```
185
+ *
186
+ * We know that `@firstName` came from the parent component, not the current
187
+ * component, because it starts with `@` and is therefore an argument.
188
+ *
189
+ * On the other hand, if we see:
190
+ *
191
+ * ```hbs
192
+ * {{name}}
193
+ * ```
194
+ *
195
+ * We know that `name` is a property on the component. If we want to know where
196
+ * the data is coming from, we can go look at our component class to find out.
197
+ *
198
+ * Inside the component itself, arguments always show up inside the component's
199
+ * `args` property. For example, if `{{@firstName}}` is `Tom` in the template,
200
+ * inside the component `this.args.firstName` would also be `Tom`.
201
+ */
202
+ export default class GlimmerComponent<S = unknown> {
203
+ /**
204
+ * Constructs a new component and assigns itself the passed properties. You
205
+ * should not construct new components yourself. Instead, Glimmer will
206
+ * instantiate new components automatically as it renders.
207
+ *
208
+ * @param owner
209
+ * @param args
210
+ */
211
+ constructor(owner: unknown, args: Args<S>);
212
+ /**
213
+ * Named arguments passed to the component from its parent component.
214
+ * They can be accessed in JavaScript via `this.args.argumentName` and in the template via `@argumentName`.
215
+ *
216
+ * Say you have the following component, which will have two `args`, `firstName` and `lastName`:
217
+ *
218
+ * ```hbs
219
+ * <my-component @firstName="Arthur" @lastName="Dent" />
220
+ * ```
221
+ *
222
+ * If you needed to calculate `fullName` by combining both of them, you would do:
223
+ *
224
+ * ```ts
225
+ * didInsertElement() {
226
+ * console.log(`Hi, my full name is ${this.args.firstName} ${this.args.lastName}`);
227
+ * }
228
+ * ```
229
+ *
230
+ * While in the template you could do:
231
+ *
232
+ * ```hbs
233
+ * <p>Welcome, {{@firstName}} {{@lastName}}!</p>
234
+ * ```
235
+ */
236
+ readonly args: Readonly<Args<S>>;
237
+ get isDestroying(): boolean;
238
+ get isDestroyed(): boolean;
239
+ /**
240
+ * Called before the component has been removed from the DOM.
241
+ */
242
+ willDestroy(): void;
243
+ }
244
+ export {};
@@ -0,0 +1,170 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.ARGS_SET = exports.setDestroyed = exports.setDestroying = void 0;
4
+ const env_1 = require("@glimmer/env");
5
+ const DESTROYING = new WeakMap();
6
+ const DESTROYED = new WeakMap();
7
+ function setDestroying(component) {
8
+ DESTROYING.set(component, true);
9
+ }
10
+ exports.setDestroying = setDestroying;
11
+ function setDestroyed(component) {
12
+ DESTROYED.set(component, true);
13
+ }
14
+ exports.setDestroyed = setDestroyed;
15
+ if (env_1.DEBUG) {
16
+ exports.ARGS_SET = new WeakMap();
17
+ }
18
+ /**
19
+ * The `Component` class defines an encapsulated UI element that is rendered to
20
+ * the DOM. A component is made up of a template and, optionally, this component
21
+ * object.
22
+ *
23
+ * ## Defining a Component
24
+ *
25
+ * To define a component, subclass `Component` and add your own properties,
26
+ * methods and lifecycle hooks:
27
+ *
28
+ * ```ts
29
+ * import Component from '@norith/glimmer-component';
30
+ *
31
+ * export default class extends Component {
32
+ * }
33
+ * ```
34
+ *
35
+ * ## Lifecycle Hooks
36
+ *
37
+ * Lifecycle hooks allow you to respond to changes to a component, such as when
38
+ * it gets created, rendered, updated or destroyed. To add a lifecycle hook to a
39
+ * component, implement the hook as a method on your component subclass.
40
+ *
41
+ * For example, to be notified when Glimmer has rendered your component so you
42
+ * can attach a legacy jQuery plugin, implement the `didInsertElement()` method:
43
+ *
44
+ * ```ts
45
+ * import Component from '@norith/glimmer-component';
46
+ *
47
+ * export default class extends Component {
48
+ * didInsertElement() {
49
+ * $(this.element).pickadate();
50
+ * }
51
+ * }
52
+ * ```
53
+ *
54
+ * ## Data for Templates
55
+ *
56
+ * `Component`s have two different kinds of data, or state, that can be
57
+ * displayed in templates:
58
+ *
59
+ * 1. Arguments
60
+ * 2. Properties
61
+ *
62
+ * Arguments are data that is passed in to a component from its parent
63
+ * component. For example, if I have a `UserGreeting` component, I can pass it
64
+ * a name and greeting to use:
65
+ *
66
+ * ```hbs
67
+ * <UserGreeting @name="Ricardo" @greeting="Olá" />
68
+ * ```
69
+ *
70
+ * Inside my `UserGreeting` template, I can access the `@name` and `@greeting`
71
+ * arguments that I've been given:
72
+ *
73
+ * ```hbs
74
+ * {{@greeting}}, {{@name}}!
75
+ * ```
76
+ *
77
+ * Arguments are also available inside my component:
78
+ *
79
+ * ```ts
80
+ * console.log(this.args.greeting); // prints "Olá"
81
+ * ```
82
+ *
83
+ * Properties, on the other hand, are internal to the component and declared in
84
+ * the class. You can use properties to store data that you want to show in the
85
+ * template, or pass to another component as an argument.
86
+ *
87
+ * ```ts
88
+ * import Component from '@norith/glimmer-component';
89
+ *
90
+ * export default class extends Component {
91
+ * user = {
92
+ * name: 'Robbie'
93
+ * }
94
+ * }
95
+ * ```
96
+ *
97
+ * In the above example, we've defined a component with a `user` property that
98
+ * contains an object with its own `name` property.
99
+ *
100
+ * We can render that property in our template:
101
+ *
102
+ * ```hbs
103
+ * Hello, {{user.name}}!
104
+ * ```
105
+ *
106
+ * We can also take that property and pass it as an argument to the
107
+ * `UserGreeting` component we defined above:
108
+ *
109
+ * ```hbs
110
+ * <UserGreeting @greeting="Hello" @name={{user.name}} />
111
+ * ```
112
+ *
113
+ * ## Arguments vs. Properties
114
+ *
115
+ * Remember, arguments are data that was given to your component by its parent
116
+ * component, and properties are data your component has defined for itself.
117
+ *
118
+ * You can tell the difference between arguments and properties in templates
119
+ * because arguments always start with an `@` sign (think "A is for arguments"):
120
+ *
121
+ * ```hbs
122
+ * {{@firstName}}
123
+ * ```
124
+ *
125
+ * We know that `@firstName` came from the parent component, not the current
126
+ * component, because it starts with `@` and is therefore an argument.
127
+ *
128
+ * On the other hand, if we see:
129
+ *
130
+ * ```hbs
131
+ * {{name}}
132
+ * ```
133
+ *
134
+ * We know that `name` is a property on the component. If we want to know where
135
+ * the data is coming from, we can go look at our component class to find out.
136
+ *
137
+ * Inside the component itself, arguments always show up inside the component's
138
+ * `args` property. For example, if `{{@firstName}}` is `Tom` in the template,
139
+ * inside the component `this.args.firstName` would also be `Tom`.
140
+ */
141
+ class GlimmerComponent {
142
+ /**
143
+ * Constructs a new component and assigns itself the passed properties. You
144
+ * should not construct new components yourself. Instead, Glimmer will
145
+ * instantiate new components automatically as it renders.
146
+ *
147
+ * @param owner
148
+ * @param args
149
+ */
150
+ constructor(owner, args) {
151
+ if (env_1.DEBUG && !(owner !== null && typeof owner === 'object' && exports.ARGS_SET.has(args))) {
152
+ throw new Error(`You must pass both the owner and args to super() in your component: ${this.constructor.name}. You can pass them directly, or use ...arguments to pass all arguments through.`);
153
+ }
154
+ this.args = args;
155
+ DESTROYING.set(this, false);
156
+ DESTROYED.set(this, false);
157
+ }
158
+ get isDestroying() {
159
+ return DESTROYING.get(this) || false;
160
+ }
161
+ get isDestroyed() {
162
+ return DESTROYED.get(this) || false;
163
+ }
164
+ /**
165
+ * Called before the component has been removed from the DOM.
166
+ */
167
+ willDestroy() { } // eslint-disable-line @typescript-eslint/no-empty-function
168
+ }
169
+ exports.default = GlimmerComponent;
170
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vcGFja2FnZXMvQGdsaW1tZXIvY29tcG9uZW50L2FkZG9uLy1wcml2YXRlL2NvbXBvbmVudC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7QUFBQSxzQ0FBcUM7QUFFckMsTUFBTSxVQUFVLEdBQUcsSUFBSSxPQUFPLEVBQXFDLENBQUM7QUFDcEUsTUFBTSxTQUFTLEdBQUcsSUFBSSxPQUFPLEVBQXFDLENBQUM7QUFFbkUsU0FBZ0IsYUFBYSxDQUFDLFNBQW1DO0lBQy9ELFVBQVUsQ0FBQyxHQUFHLENBQUMsU0FBUyxFQUFFLElBQUksQ0FBQyxDQUFDO0FBQ2xDLENBQUM7QUFGRCxzQ0FFQztBQUNELFNBQWdCLFlBQVksQ0FBQyxTQUFtQztJQUM5RCxTQUFTLENBQUMsR0FBRyxDQUFDLFNBQVMsRUFBRSxJQUFJLENBQUMsQ0FBQztBQUNqQyxDQUFDO0FBRkQsb0NBRUM7QUFnQkQsSUFBSSxXQUFLLEVBQUU7SUFDVCxnQkFBUSxHQUFHLElBQUksT0FBTyxFQUFnQixDQUFDO0NBQ3hDO0FBMkVEOzs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7OztHQTBIRztBQUNILE1BQXFCLGdCQUFnQjtJQUNuQzs7Ozs7OztPQU9HO0lBQ0gsWUFBWSxLQUFjLEVBQUUsSUFBYTtRQUN2QyxJQUFJLFdBQUssSUFBSSxDQUFDLENBQUMsS0FBSyxLQUFLLElBQUksSUFBSSxPQUFPLEtBQUssS0FBSyxRQUFRLElBQUksZ0JBQVEsQ0FBQyxHQUFHLENBQUMsSUFBSSxDQUFDLENBQUMsRUFBRTtZQUNqRixNQUFNLElBQUksS0FBSyxDQUNiLHVFQUF1RSxJQUFJLENBQUMsV0FBVyxDQUFDLElBQUksa0ZBQWtGLENBQy9LLENBQUM7U0FDSDtRQUVELElBQUksQ0FBQyxJQUFJLEdBQUcsSUFBSSxDQUFDO1FBRWpCLFVBQVUsQ0FBQyxHQUFHLENBQUMsSUFBSSxFQUFFLEtBQUssQ0FBQyxDQUFDO1FBQzVCLFNBQVMsQ0FBQyxHQUFHLENBQUMsSUFBSSxFQUFFLEtBQUssQ0FBQyxDQUFDO0lBQzdCLENBQUM7SUE0QkQsSUFBSSxZQUFZO1FBQ2QsT0FBTyxVQUFVLENBQUMsR0FBRyxDQUFDLElBQUksQ0FBQyxJQUFJLEtBQUssQ0FBQztJQUN2QyxDQUFDO0lBRUQsSUFBSSxXQUFXO1FBQ2IsT0FBTyxTQUFTLENBQUMsR0FBRyxDQUFDLElBQUksQ0FBQyxJQUFJLEtBQUssQ0FBQztJQUN0QyxDQUFDO0lBRUQ7O09BRUc7SUFDSCxXQUFXLEtBQVUsQ0FBQyxDQUFDLDJEQUEyRDtDQUNuRjtBQTVERCxtQ0E0REMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBERUJVRyB9IGZyb20gJ0BnbGltbWVyL2Vudic7XG5cbmNvbnN0IERFU1RST1lJTkcgPSBuZXcgV2Vha01hcDxHbGltbWVyQ29tcG9uZW50PG9iamVjdD4sIGJvb2xlYW4+KCk7XG5jb25zdCBERVNUUk9ZRUQgPSBuZXcgV2Vha01hcDxHbGltbWVyQ29tcG9uZW50PG9iamVjdD4sIGJvb2xlYW4+KCk7XG5cbmV4cG9ydCBmdW5jdGlvbiBzZXREZXN0cm95aW5nKGNvbXBvbmVudDogR2xpbW1lckNvbXBvbmVudDxvYmplY3Q+KTogdm9pZCB7XG4gIERFU1RST1lJTkcuc2V0KGNvbXBvbmVudCwgdHJ1ZSk7XG59XG5leHBvcnQgZnVuY3Rpb24gc2V0RGVzdHJveWVkKGNvbXBvbmVudDogR2xpbW1lckNvbXBvbmVudDxvYmplY3Q+KTogdm9pZCB7XG4gIERFU1RST1lFRC5zZXQoY29tcG9uZW50LCB0cnVlKTtcbn1cblxuLy8gVGhpcyBwcm92aWRlcyBhIHR5cGUtc2FmZSBgV2Vha01hcGA6IHRoZSBnZXR0ZXIgYW5kIHNldHRlciBsaW5rIHRoZSBrZXkgdG8gYVxuLy8gc3BlY2lmaWMgdmFsdWUuIFRoaXMgaXMgaG93IGBXZWFrTWFwYHMgYWN0dWFsbHkgYmVoYXZlLCBidXQgdGhlIFRTIHR5cGVcbi8vIHN5c3RlbSBkb2VzIG5vdCAoeWV0ISkgaGF2ZSBhIGdvb2Qgd2F5IHRvIGNhcHR1cmUgdGhhdCBmb3IgdHlwZXMgbGlrZVxuLy8gYFdlYWtNYXBgIHdoZXJlIHRoZSB0eXBlIGlzIGdlbmVyaWMgb3ZlciBhbm90aGVyIGdlbmVyaWMgdHlwZSAoaGVyZSwgYEFyZ3NgKS5cbmludGVyZmFjZSBBcmdzU2V0TWFwIGV4dGVuZHMgV2Vha01hcDxBcmdzPHVua25vd24+LCBib29sZWFuPiB7XG4gIGdldDxTPihrZXk6IEFyZ3M8Uz4pOiBib29sZWFuIHwgdW5kZWZpbmVkO1xuICBzZXQ8Uz4oa2V5OiBBcmdzPFM+LCB2YWx1ZTogYm9vbGVhbik6IHRoaXM7XG4gIGhhczxTPihrZXk6IEFyZ3M8Uz4pOiBib29sZWFuO1xufVxuXG4vLyBTQUZFVFk6IHRoaXMgb25seSBob2xkcyBiZWNhdXNlIHdlICpvbmx5KiBhY2NlcyB0aGlzIHdoZW4gYERFQlVHYCBpcyBgdHJ1ZWAuXG4vLyBUaGVyZSBpcyBub3QgYSBncmVhdCB3YXkgdG8gY29ubmVjdCB0aGF0IGRhdGEgaW4gVFMgYXQgcHJlc2VudC5cbmV4cG9ydCBsZXQgQVJHU19TRVQ6IEFyZ3NTZXRNYXA7XG5cbmlmIChERUJVRykge1xuICBBUkdTX1NFVCA9IG5ldyBXZWFrTWFwKCkgYXMgQXJnc1NldE1hcDtcbn1cblxuLy8gLS0tIFR5cGUgdXRpbGl0aWVzIGZvciBjb21wb25lbnQgc2lnbmF0dXJlcyAtLS0gLy9cbi8vIFR5cGUtb25seSBcInN5bWJvbFwiIHRvIHVzZSB3aXRoIGBFbXB0eU9iamVjdGAgYmVsb3csIHNvIHRoYXQgaXQgaXMgKm5vdCpcbi8vIGVxdWl2YWxlbnQgdG8gYW4gZW1wdHkgaW50ZXJmYWNlLlxuZGVjbGFyZSBjb25zdCBFbXB0eTogdW5pcXVlIHN5bWJvbDtcblxuLyoqXG4gKiBUaGlzIHByb3ZpZGVzIHVzIGEgd2F5IHRvIGhhdmUgYSBcImZhbGxiYWNrXCIgd2hpY2ggcmVwcmVzZW50cyBhbiBlbXB0eSBvYmplY3QsXG4gKiB3aXRob3V0IHRoZSBkb3duc2lkZXMgb2YgaG93IFRTIHRyZWF0cyBge31gLiBTcGVjaWZpY2FsbHk6IHRoaXMgd2lsbFxuICogY29ycmVjdGx5IGxldmVyYWdlIFwiZXhjZXNzIHByb3BlcnR5IGNoZWNraW5nXCIgc28gdGhhdCwgZ2l2ZW4gYSBjb21wb25lbnRcbiAqIHdoaWNoIGhhcyBubyBuYW1lZCBhcmdzLCBpZiBzb21lb25lIGludm9rZXMgaXQgd2l0aCBhbnkgbmFtZWQgYXJncywgdGhleSB3aWxsXG4gKiBnZXQgYSB0eXBlIGVycm9yLlxuICpcbiAqIEBpbnRlcm5hbCBUaGlzIGlzIGV4cG9ydGVkIHNvIGRlY2xhcmF0aW9uIGVtaXQgd29ya3MgKGlmIGl0IHdlcmUgbm90IGVtaXR0ZWQsXG4gKiAgIGRlY2xhcmF0aW9ucyB3aGljaCBmYWxsIGJhY2sgdG8gaXQgd291bGQgbm90IHdvcmspLiBJdCBpcyAqbm90KiBpbnRlbmRlZCBmb3JcbiAqICAgcHVibGljIHVzYWdlLCBhbmQgdGhlIHNwZWNpZmljIG1lY2hhbmljcyBpdCB1c2VzIG1heSBjaGFuZ2UgYXQgYW55IHRpbWUuXG4gKiAgIFRoZSBsb2NhdGlvbiBvZiB0aGlzIGV4cG9ydCAqaXMqIHBhcnQgb2YgdGhlIHB1YmxpYyBBUEksIGJlY2F1c2UgbW92aW5nIGl0XG4gKiAgIHdpbGwgYnJlYWsgZXhpc3RpbmcgZGVjbGFyYXRpb25zLCBidXQgaXMgbm90IGxlZ2FsIGZvciBlbmQgdXNlcnMgdG8gaW1wb3J0XG4gKiAgIHRoZW1zZWx2ZXMsIHNvICoqKkRPIE5PVCBSRUxZIE9OIElUKioqLlxuICovXG5leHBvcnQgdHlwZSBFbXB0eU9iamVjdCA9IHsgW0VtcHR5XT86IHRydWUgfTtcblxudHlwZSBHZXRPckVsc2U8T2JqLCBLIGV4dGVuZHMgUHJvcGVydHlLZXksIEZhbGxiYWNrPiA9IE9iaiBleHRlbmRzIHsgW0tleSBpbiBLXTogaW5mZXIgVSB9XG4gID8gVVxuICA6IEZhbGxiYWNrO1xuXG4vKiogR2l2ZW4gYSBzaWduYXR1cmUgYFNgLCBnZXQgYmFjayB0aGUgYEFyZ3NgIHR5cGUuICovXG50eXBlIEFyZ3NGb3I8Uz4gPSBTIGV4dGVuZHMgeyBBcmdzOiBpbmZlciBBcmdzIH1cbiAgPyBBcmdzIGV4dGVuZHMgeyBOYW1lZD86IG9iamVjdDsgUG9zaXRpb25hbD86IHVua25vd25bXSB9IC8vIEFyZSB0aGV5IGxvbmdoYW5kIGFscmVhZHk/XG4gICAgPyB7XG4gICAgICAgIE5hbWVkOiBHZXRPckVsc2U8U1snQXJncyddLCAnTmFtZWQnLCBFbXB0eU9iamVjdD47XG4gICAgICAgIFBvc2l0aW9uYWw6IEdldE9yRWxzZTxTWydBcmdzJ10sICdQb3NpdGlvbmFsJywgW10+O1xuICAgICAgfVxuICAgIDogeyBOYW1lZDogU1snQXJncyddOyBQb3NpdGlvbmFsOiBbXSB9XG4gIDogeyBOYW1lZDogRW1wdHlPYmplY3Q7IFBvc2l0aW9uYWw6IFtdIH07XG5cbnR5cGUgX0V4cGFuZFNpZ25hdHVyZTxUPiA9IHtcbiAgRWxlbWVudDogR2V0T3JFbHNlPFQsICdFbGVtZW50JywgbnVsbD47XG4gIEFyZ3M6IGtleW9mIFQgZXh0ZW5kcyAnQXJncycgfCAnRWxlbWVudCcgfCAnQmxvY2tzJyAvLyBJcyB0aGlzIGEgYFNpZ25hdHVyZWA/XG4gICAgPyBBcmdzRm9yPFQ+IC8vIFRoZW4gdXNlIGBTaWduYXR1cmVgIGFyZ3NcbiAgICA6IHsgTmFtZWQ6IFQ7IFBvc2l0aW9uYWw6IFtdIH07IC8vIE90aGVyd2lzZSBmYWxsIGJhY2sgdG8gY2xhc3NpYyBgQXJnc2AuXG4gIEJsb2NrczogVCBleHRlbmRzIHsgQmxvY2tzOiBpbmZlciBCbG9ja3MgfVxuICAgID8ge1xuICAgICAgICBbQmxvY2sgaW4ga2V5b2YgQmxvY2tzXTogQmxvY2tzW0Jsb2NrXSBleHRlbmRzIHVua25vd25bXVxuICAgICAgICAgID8geyBQYXJhbXM6IHsgUG9zaXRpb25hbDogQmxvY2tzW0Jsb2NrXSB9IH1cbiAgICAgICAgICA6IEJsb2Nrc1tCbG9ja107XG4gICAgICB9XG4gICAgOiBFbXB0eU9iamVjdDtcbn07XG4vKipcbiAqIEdpdmVuIGFueSBhbGxvd2VkIHNob3J0aGFuZCBmb3JtIG9mIGEgc2lnbmF0dXJlLCBkZXN1Z2FycyBpdCB0byBpdHMgZnVsbFxuICogZXhwYW5kZWQgdHlwZS5cbiAqXG4gKiBAaW50ZXJuYWwgVGhpcyBpcyBvbmx5IGV4cG9ydGVkIHNvIHdlIGNhbiBhdm9pZCBkdXBsaWNhdGluZyBpdCBpblxuICogICBbR2xpbnRdKGh0dHBzOi8vZ2l0aHViLmNvbS90eXBlZC1lbWJlci9nbGludCkgb3Igb3RoZXIgc3VjaCB0b29saW5nLiBJdCBpc1xuICogICAqbm90KiBpbnRlbmRlZCBmb3IgcHVibGljIHVzYWdlLCBhbmQgdGhlIHNwZWNpZmljIG1lY2hhbmljcyBpdCB1c2VzIG1heVxuICogICBjaGFuZ2UgYXQgYW55IHRpbWUuIEFsdGhvdWdoIHRoZSBzaWduYXR1cmUgcHJvZHVjZWQgYnkgaXMgcGFydCBvZiBHbGltbWVyJ3NcbiAqICAgcHVibGljIEFQSSB0aGUgZXhpc3RlbmNlIGFuZCBtZWNoYW5pY3Mgb2YgdGhpcyBzcGVjaWZpYyBzeW1ib2wgYXJlICpub3QqLFxuICogICBzbyAqKipETyBOT1QgUkVMWSBPTiBJVCoqKi5cbiAqL1xuLy8gVGhlIGNvbmRpdGlvbmFsIHR5cGUgaGVyZSBpcyBiZWNhdXNlIFRTIGFwcGxpZXMgY29uZGl0aW9uYWwgdHlwZXNcbi8vIGRpc3RyaWJ1dGl2ZWx5LiBUaGlzIG1lYW5zIHRoYXQgZm9yIHVuaW9uIHR5cGVzLCBjaGVja3MgbGlrZSBga2V5b2YgVGAgZ2V0XG4vLyBhbGwgdGhlIGtleXMgZnJvbSBhbGwgZWxlbWVudHMgb2YgdGhlIHVuaW9uLCBpbnN0ZWFkIG9mIGVuZGluZyB1cCBhcyBgbmV2ZXJgXG4vLyBhbmQgdGhlbiBhbHdheXMgZmFsbGluZyBpbnRvIHRoZSBgU2lnbmF0dXJlYCBwYXRoIGluc3RlYWQgb2YgZmFsbGluZyBiYWNrIHRvXG4vLyB0aGUgbGVnYWN5IGFyZ3MgaGFuZGxpbmcgcGF0aC5cbi8vIGVzbGludC1kaXNhYmxlLW5leHQtbGluZSBAdHlwZXNjcmlwdC1lc2xpbnQvbm8tZXhwbGljaXQtYW55XG5leHBvcnQgdHlwZSBFeHBhbmRTaWduYXR1cmU8VD4gPSBUIGV4dGVuZHMgYW55ID8gX0V4cGFuZFNpZ25hdHVyZTxUPiA6IG5ldmVyO1xuXG4vKipcbiAqIEBpbnRlcm5hbCB3ZSB1c2UgdGhpcyB0eXBlIGZvciBjb252ZW5pZW5jZSBpbnRlcm5hbGx5OyBpbmZlcmVuY2UgbWVhbnMgdXNlcnNcbiAqICAgc2hvdWxkIG5vdCBub3JtYWxseSBuZWVkIHRvIG5hbWUgaXRcbiAqL1xuZXhwb3J0IHR5cGUgQXJnczxTPiA9IEV4cGFuZFNpZ25hdHVyZTxTPlsnQXJncyddWydOYW1lZCddO1xuXG4vKipcbiAqIFRoZSBgQ29tcG9uZW50YCBjbGFzcyBkZWZpbmVzIGFuIGVuY2Fwc3VsYXRlZCBVSSBlbGVtZW50IHRoYXQgaXMgcmVuZGVyZWQgdG9cbiAqIHRoZSBET00uIEEgY29tcG9uZW50IGlzIG1hZGUgdXAgb2YgYSB0ZW1wbGF0ZSBhbmQsIG9wdGlvbmFsbHksIHRoaXMgY29tcG9uZW50XG4gKiBvYmplY3QuXG4gKlxuICogIyMgRGVmaW5pbmcgYSBDb21wb25lbnRcbiAqXG4gKiBUbyBkZWZpbmUgYSBjb21wb25lbnQsIHN1YmNsYXNzIGBDb21wb25lbnRgIGFuZCBhZGQgeW91ciBvd24gcHJvcGVydGllcyxcbiAqIG1ldGhvZHMgYW5kIGxpZmVjeWNsZSBob29rczpcbiAqXG4gKiBgYGB0c1xuICogaW1wb3J0IENvbXBvbmVudCBmcm9tICdAbm9yaXRoL2dsaW1tZXItY29tcG9uZW50JztcbiAqXG4gKiBleHBvcnQgZGVmYXVsdCBjbGFzcyBleHRlbmRzIENvbXBvbmVudCB7XG4gKiB9XG4gKiBgYGBcbiAqXG4gKiAjIyBMaWZlY3ljbGUgSG9va3NcbiAqXG4gKiBMaWZlY3ljbGUgaG9va3MgYWxsb3cgeW91IHRvIHJlc3BvbmQgdG8gY2hhbmdlcyB0byBhIGNvbXBvbmVudCwgc3VjaCBhcyB3aGVuXG4gKiBpdCBnZXRzIGNyZWF0ZWQsIHJlbmRlcmVkLCB1cGRhdGVkIG9yIGRlc3Ryb3llZC4gVG8gYWRkIGEgbGlmZWN5Y2xlIGhvb2sgdG8gYVxuICogY29tcG9uZW50LCBpbXBsZW1lbnQgdGhlIGhvb2sgYXMgYSBtZXRob2Qgb24geW91ciBjb21wb25lbnQgc3ViY2xhc3MuXG4gKlxuICogRm9yIGV4YW1wbGUsIHRvIGJlIG5vdGlmaWVkIHdoZW4gR2xpbW1lciBoYXMgcmVuZGVyZWQgeW91ciBjb21wb25lbnQgc28geW91XG4gKiBjYW4gYXR0YWNoIGEgbGVnYWN5IGpRdWVyeSBwbHVnaW4sIGltcGxlbWVudCB0aGUgYGRpZEluc2VydEVsZW1lbnQoKWAgbWV0aG9kOlxuICpcbiAqIGBgYHRzXG4gKiBpbXBvcnQgQ29tcG9uZW50IGZyb20gJ0Bub3JpdGgvZ2xpbW1lci1jb21wb25lbnQnO1xuICpcbiAqIGV4cG9ydCBkZWZhdWx0IGNsYXNzIGV4dGVuZHMgQ29tcG9uZW50IHtcbiAqICAgZGlkSW5zZXJ0RWxlbWVudCgpIHtcbiAqICAgICAkKHRoaXMuZWxlbWVudCkucGlja2FkYXRlKCk7XG4gKiAgIH1cbiAqIH1cbiAqIGBgYFxuICpcbiAqICMjIERhdGEgZm9yIFRlbXBsYXRlc1xuICpcbiAqIGBDb21wb25lbnRgcyBoYXZlIHR3byBkaWZmZXJlbnQga2luZHMgb2YgZGF0YSwgb3Igc3RhdGUsIHRoYXQgY2FuIGJlXG4gKiBkaXNwbGF5ZWQgaW4gdGVtcGxhdGVzOlxuICpcbiAqIDEuIEFyZ3VtZW50c1xuICogMi4gUHJvcGVydGllc1xuICpcbiAqIEFyZ3VtZW50cyBhcmUgZGF0YSB0aGF0IGlzIHBhc3NlZCBpbiB0byBhIGNvbXBvbmVudCBmcm9tIGl0cyBwYXJlbnRcbiAqIGNvbXBvbmVudC4gRm9yIGV4YW1wbGUsIGlmIEkgaGF2ZSBhIGBVc2VyR3JlZXRpbmdgIGNvbXBvbmVudCwgSSBjYW4gcGFzcyBpdFxuICogYSBuYW1lIGFuZCBncmVldGluZyB0byB1c2U6XG4gKlxuICogYGBgaGJzXG4gKiA8VXNlckdyZWV0aW5nIEBuYW1lPVwiUmljYXJkb1wiIEBncmVldGluZz1cIk9sw6FcIiAvPlxuICogYGBgXG4gKlxuICogSW5zaWRlIG15IGBVc2VyR3JlZXRpbmdgIHRlbXBsYXRlLCBJIGNhbiBhY2Nlc3MgdGhlIGBAbmFtZWAgYW5kIGBAZ3JlZXRpbmdgXG4gKiBhcmd1bWVudHMgdGhhdCBJJ3ZlIGJlZW4gZ2l2ZW46XG4gKlxuICogYGBgaGJzXG4gKiB7e0BncmVldGluZ319LCB7e0BuYW1lfX0hXG4gKiBgYGBcbiAqXG4gKiBBcmd1bWVudHMgYXJlIGFsc28gYXZhaWxhYmxlIGluc2lkZSBteSBjb21wb25lbnQ6XG4gKlxuICogYGBgdHNcbiAqIGNvbnNvbGUubG9nKHRoaXMuYXJncy5ncmVldGluZyk7IC8vIHByaW50cyBcIk9sw6FcIlxuICogYGBgXG4gKlxuICogUHJvcGVydGllcywgb24gdGhlIG90aGVyIGhhbmQsIGFyZSBpbnRlcm5hbCB0byB0aGUgY29tcG9uZW50IGFuZCBkZWNsYXJlZCBpblxuICogdGhlIGNsYXNzLiBZb3UgY2FuIHVzZSBwcm9wZXJ0aWVzIHRvIHN0b3JlIGRhdGEgdGhhdCB5b3Ugd2FudCB0byBzaG93IGluIHRoZVxuICogdGVtcGxhdGUsIG9yIHBhc3MgdG8gYW5vdGhlciBjb21wb25lbnQgYXMgYW4gYXJndW1lbnQuXG4gKlxuICogYGBgdHNcbiAqIGltcG9ydCBDb21wb25lbnQgZnJvbSAnQG5vcml0aC9nbGltbWVyLWNvbXBvbmVudCc7XG4gKlxuICogZXhwb3J0IGRlZmF1bHQgY2xhc3MgZXh0ZW5kcyBDb21wb25lbnQge1xuICogICB1c2VyID0ge1xuICogICAgIG5hbWU6ICdSb2JiaWUnXG4gKiAgIH1cbiAqIH1cbiAqIGBgYFxuICpcbiAqIEluIHRoZSBhYm92ZSBleGFtcGxlLCB3ZSd2ZSBkZWZpbmVkIGEgY29tcG9uZW50IHdpdGggYSBgdXNlcmAgcHJvcGVydHkgdGhhdFxuICogY29udGFpbnMgYW4gb2JqZWN0IHdpdGggaXRzIG93biBgbmFtZWAgcHJvcGVydHkuXG4gKlxuICogV2UgY2FuIHJlbmRlciB0aGF0IHByb3BlcnR5IGluIG91ciB0ZW1wbGF0ZTpcbiAqXG4gKiBgYGBoYnNcbiAqIEhlbGxvLCB7e3VzZXIubmFtZX19IVxuICogYGBgXG4gKlxuICogV2UgY2FuIGFsc28gdGFrZSB0aGF0IHByb3BlcnR5IGFuZCBwYXNzIGl0IGFzIGFuIGFyZ3VtZW50IHRvIHRoZVxuICogYFVzZXJHcmVldGluZ2AgY29tcG9uZW50IHdlIGRlZmluZWQgYWJvdmU6XG4gKlxuICogYGBgaGJzXG4gKiA8VXNlckdyZWV0aW5nIEBncmVldGluZz1cIkhlbGxvXCIgQG5hbWU9e3t1c2VyLm5hbWV9fSAvPlxuICogYGBgXG4gKlxuICogIyMgQXJndW1lbnRzIHZzLiBQcm9wZXJ0aWVzXG4gKlxuICogUmVtZW1iZXIsIGFyZ3VtZW50cyBhcmUgZGF0YSB0aGF0IHdhcyBnaXZlbiB0byB5b3VyIGNvbXBvbmVudCBieSBpdHMgcGFyZW50XG4gKiBjb21wb25lbnQsIGFuZCBwcm9wZXJ0aWVzIGFyZSBkYXRhIHlvdXIgY29tcG9uZW50IGhhcyBkZWZpbmVkIGZvciBpdHNlbGYuXG4gKlxuICogWW91IGNhbiB0ZWxsIHRoZSBkaWZmZXJlbmNlIGJldHdlZW4gYXJndW1lbnRzIGFuZCBwcm9wZXJ0aWVzIGluIHRlbXBsYXRlc1xuICogYmVjYXVzZSBhcmd1bWVudHMgYWx3YXlzIHN0YXJ0IHdpdGggYW4gYEBgIHNpZ24gKHRoaW5rIFwiQSBpcyBmb3IgYXJndW1lbnRzXCIpOlxuICpcbiAqIGBgYGhic1xuICoge3tAZmlyc3ROYW1lfX1cbiAqIGBgYFxuICpcbiAqIFdlIGtub3cgdGhhdCBgQGZpcnN0TmFtZWAgY2FtZSBmcm9tIHRoZSBwYXJlbnQgY29tcG9uZW50LCBub3QgdGhlIGN1cnJlbnRcbiAqIGNvbXBvbmVudCwgYmVjYXVzZSBpdCBzdGFydHMgd2l0aCBgQGAgYW5kIGlzIHRoZXJlZm9yZSBhbiBhcmd1bWVudC5cbiAqXG4gKiBPbiB0aGUgb3RoZXIgaGFuZCwgaWYgd2Ugc2VlOlxuICpcbiAqIGBgYGhic1xuICoge3tuYW1lfX1cbiAqIGBgYFxuICpcbiAqIFdlIGtub3cgdGhhdCBgbmFtZWAgaXMgYSBwcm9wZXJ0eSBvbiB0aGUgY29tcG9uZW50LiBJZiB3ZSB3YW50IHRvIGtub3cgd2hlcmVcbiAqIHRoZSBkYXRhIGlzIGNvbWluZyBmcm9tLCB3ZSBjYW4gZ28gbG9vayBhdCBvdXIgY29tcG9uZW50IGNsYXNzIHRvIGZpbmQgb3V0LlxuICpcbiAqIEluc2lkZSB0aGUgY29tcG9uZW50IGl0c2VsZiwgYXJndW1lbnRzIGFsd2F5cyBzaG93IHVwIGluc2lkZSB0aGUgY29tcG9uZW50J3NcbiAqIGBhcmdzYCBwcm9wZXJ0eS4gRm9yIGV4YW1wbGUsIGlmIGB7e0BmaXJzdE5hbWV9fWAgaXMgYFRvbWAgaW4gdGhlIHRlbXBsYXRlLFxuICogaW5zaWRlIHRoZSBjb21wb25lbnQgYHRoaXMuYXJncy5maXJzdE5hbWVgIHdvdWxkIGFsc28gYmUgYFRvbWAuXG4gKi9cbmV4cG9ydCBkZWZhdWx0IGNsYXNzIEdsaW1tZXJDb21wb25lbnQ8UyA9IHVua25vd24+IHtcbiAgLyoqXG4gICAqIENvbnN0cnVjdHMgYSBuZXcgY29tcG9uZW50IGFuZCBhc3NpZ25zIGl0c2VsZiB0aGUgcGFzc2VkIHByb3BlcnRpZXMuIFlvdVxuICAgKiBzaG91bGQgbm90IGNvbnN0cnVjdCBuZXcgY29tcG9uZW50cyB5b3Vyc2VsZi4gSW5zdGVhZCwgR2xpbW1lciB3aWxsXG4gICAqIGluc3RhbnRpYXRlIG5ldyBjb21wb25lbnRzIGF1dG9tYXRpY2FsbHkgYXMgaXQgcmVuZGVycy5cbiAgICpcbiAgICogQHBhcmFtIG93bmVyXG4gICAqIEBwYXJhbSBhcmdzXG4gICAqL1xuICBjb25zdHJ1Y3Rvcihvd25lcjogdW5rbm93biwgYXJnczogQXJnczxTPikge1xuICAgIGlmIChERUJVRyAmJiAhKG93bmVyICE9PSBudWxsICYmIHR5cGVvZiBvd25lciA9PT0gJ29iamVjdCcgJiYgQVJHU19TRVQuaGFzKGFyZ3MpKSkge1xuICAgICAgdGhyb3cgbmV3IEVycm9yKFxuICAgICAgICBgWW91IG11c3QgcGFzcyBib3RoIHRoZSBvd25lciBhbmQgYXJncyB0byBzdXBlcigpIGluIHlvdXIgY29tcG9uZW50OiAke3RoaXMuY29uc3RydWN0b3IubmFtZX0uIFlvdSBjYW4gcGFzcyB0aGVtIGRpcmVjdGx5LCBvciB1c2UgLi4uYXJndW1lbnRzIHRvIHBhc3MgYWxsIGFyZ3VtZW50cyB0aHJvdWdoLmBcbiAgICAgICk7XG4gICAgfVxuXG4gICAgdGhpcy5hcmdzID0gYXJncztcblxuICAgIERFU1RST1lJTkcuc2V0KHRoaXMsIGZhbHNlKTtcbiAgICBERVNUUk9ZRUQuc2V0KHRoaXMsIGZhbHNlKTtcbiAgfVxuXG4gIC8qKlxuICAgKiBOYW1lZCBhcmd1bWVudHMgcGFzc2VkIHRvIHRoZSBjb21wb25lbnQgZnJvbSBpdHMgcGFyZW50IGNvbXBvbmVudC5cbiAgICogVGhleSBjYW4gYmUgYWNjZXNzZWQgaW4gSmF2YVNjcmlwdCB2aWEgYHRoaXMuYXJncy5hcmd1bWVudE5hbWVgIGFuZCBpbiB0aGUgdGVtcGxhdGUgdmlhIGBAYXJndW1lbnROYW1lYC5cbiAgICpcbiAgICogU2F5IHlvdSBoYXZlIHRoZSBmb2xsb3dpbmcgY29tcG9uZW50LCB3aGljaCB3aWxsIGhhdmUgdHdvIGBhcmdzYCwgYGZpcnN0TmFtZWAgYW5kIGBsYXN0TmFtZWA6XG4gICAqXG4gICAqIGBgYGhic1xuICAgKiA8bXktY29tcG9uZW50IEBmaXJzdE5hbWU9XCJBcnRodXJcIiBAbGFzdE5hbWU9XCJEZW50XCIgLz5cbiAgICogYGBgXG4gICAqXG4gICAqIElmIHlvdSBuZWVkZWQgdG8gY2FsY3VsYXRlIGBmdWxsTmFtZWAgYnkgY29tYmluaW5nIGJvdGggb2YgdGhlbSwgeW91IHdvdWxkIGRvOlxuICAgKlxuICAgKiBgYGB0c1xuICAgKiBkaWRJbnNlcnRFbGVtZW50KCkge1xuICAgKiAgIGNvbnNvbGUubG9nKGBIaSwgbXkgZnVsbCBuYW1lIGlzICR7dGhpcy5hcmdzLmZpcnN0TmFtZX0gJHt0aGlzLmFyZ3MubGFzdE5hbWV9YCk7XG4gICAqIH1cbiAgICogYGBgXG4gICAqXG4gICAqIFdoaWxlIGluIHRoZSB0ZW1wbGF0ZSB5b3UgY291bGQgZG86XG4gICAqXG4gICAqIGBgYGhic1xuICAgKiA8cD5XZWxjb21lLCB7e0BmaXJzdE5hbWV9fSB7e0BsYXN0TmFtZX19ITwvcD5cbiAgICogYGBgXG4gICAqL1xuICByZWFkb25seSBhcmdzOiBSZWFkb25seTxBcmdzPFM+PjtcblxuICBnZXQgaXNEZXN0cm95aW5nKCk6IGJvb2xlYW4ge1xuICAgIHJldHVybiBERVNUUk9ZSU5HLmdldCh0aGlzKSB8fCBmYWxzZTtcbiAgfVxuXG4gIGdldCBpc0Rlc3Ryb3llZCgpOiBib29sZWFuIHtcbiAgICByZXR1cm4gREVTVFJPWUVELmdldCh0aGlzKSB8fCBmYWxzZTtcbiAgfVxuXG4gIC8qKlxuICAgKiBDYWxsZWQgYmVmb3JlIHRoZSBjb21wb25lbnQgaGFzIGJlZW4gcmVtb3ZlZCBmcm9tIHRoZSBET00uXG4gICAqL1xuICB3aWxsRGVzdHJveSgpOiB2b2lkIHt9IC8vIGVzbGludC1kaXNhYmxlLWxpbmUgQHR5cGVzY3JpcHQtZXNsaW50L25vLWVtcHR5LWZ1bmN0aW9uXG59XG4iXX0=
@@ -0,0 +1 @@
1
+ export { default } from './src/component';
@@ -0,0 +1,9 @@
1
+ "use strict";
2
+ var __importDefault = (this && this.__importDefault) || function (mod) {
3
+ return (mod && mod.__esModule) ? mod : { "default": mod };
4
+ };
5
+ Object.defineProperty(exports, "__esModule", { value: true });
6
+ exports.default = void 0;
7
+ var component_1 = require("./src/component");
8
+ Object.defineProperty(exports, "default", { enumerable: true, get: function () { return __importDefault(component_1).default; } });
9
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9wYWNrYWdlcy9AZ2xpbW1lci9jb21wb25lbnQvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7Ozs7O0FBQUEsNkNBQTBDO0FBQWpDLHFIQUFBLE9BQU8sT0FBQSIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCB7IGRlZmF1bHQgfSBmcm9tICcuL3NyYy9jb21wb25lbnQnO1xuIl19
@@ -0,0 +1,12 @@
1
+ import BaseComponentManager from '../addon/-private/base-component-manager';
2
+ import GlimmerComponent from '../addon/-private/component';
3
+ /**
4
+ * This component manager runs in Glimmer.js environments and extends the base component manager to:
5
+ *
6
+ * 1. Implement a lightweight destruction protocol (currently not deferred, like in Ember)
7
+ * 2. Invoke legacy component lifecycle hooks (didInsertElement and didUpdate)
8
+ */
9
+ export default class GlimmerComponentManager extends BaseComponentManager<GlimmerComponent> {
10
+ capabilities: import("@norith/glimmer-core").ComponentCapabilities;
11
+ destroyComponent(component: GlimmerComponent): void;
12
+ }
@@ -0,0 +1,30 @@
1
+ "use strict";
2
+ var __importDefault = (this && this.__importDefault) || function (mod) {
3
+ return (mod && mod.__esModule) ? mod : { "default": mod };
4
+ };
5
+ Object.defineProperty(exports, "__esModule", { value: true });
6
+ const glimmer_core_1 = require("@norith/glimmer-core");
7
+ const base_component_manager_1 = __importDefault(require("../addon/-private/base-component-manager"));
8
+ const component_1 = require("../addon/-private/component");
9
+ const CAPABILITIES = glimmer_core_1.componentCapabilities('3.13', {
10
+ destructor: true,
11
+ });
12
+ /**
13
+ * This component manager runs in Glimmer.js environments and extends the base component manager to:
14
+ *
15
+ * 1. Implement a lightweight destruction protocol (currently not deferred, like in Ember)
16
+ * 2. Invoke legacy component lifecycle hooks (didInsertElement and didUpdate)
17
+ */
18
+ class GlimmerComponentManager extends base_component_manager_1.default {
19
+ constructor() {
20
+ super(...arguments);
21
+ this.capabilities = CAPABILITIES;
22
+ }
23
+ destroyComponent(component) {
24
+ component_1.setDestroying(component);
25
+ component.willDestroy();
26
+ component_1.setDestroyed(component);
27
+ }
28
+ }
29
+ exports.default = GlimmerComponentManager;
30
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY29tcG9uZW50LW1hbmFnZXIuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wYWNrYWdlcy9AZ2xpbW1lci9jb21wb25lbnQvc3JjL2NvbXBvbmVudC1tYW5hZ2VyLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7Ozs7O0FBQUEsdURBQTZEO0FBRTdELHNHQUE0RTtBQUM1RSwyREFBNEY7QUFFNUYsTUFBTSxZQUFZLEdBQUcsb0NBQXFCLENBQUMsTUFBTSxFQUFFO0lBQ2pELFVBQVUsRUFBRSxJQUFJO0NBQ2pCLENBQUMsQ0FBQztBQUVIOzs7OztHQUtHO0FBQ0gsTUFBcUIsdUJBQXdCLFNBQVEsZ0NBQXNDO0lBQTNGOztRQUNFLGlCQUFZLEdBQUcsWUFBWSxDQUFDO0lBTzlCLENBQUM7SUFMQyxnQkFBZ0IsQ0FBQyxTQUEyQjtRQUMxQyx5QkFBYSxDQUFDLFNBQVMsQ0FBQyxDQUFDO1FBQ3pCLFNBQVMsQ0FBQyxXQUFXLEVBQUUsQ0FBQztRQUN4Qix3QkFBWSxDQUFDLFNBQVMsQ0FBQyxDQUFDO0lBQzFCLENBQUM7Q0FDRjtBQVJELDBDQVFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgY29tcG9uZW50Q2FwYWJpbGl0aWVzIH0gZnJvbSAnQG5vcml0aC9nbGltbWVyLWNvcmUnO1xuXG5pbXBvcnQgQmFzZUNvbXBvbmVudE1hbmFnZXIgZnJvbSAnLi4vYWRkb24vLXByaXZhdGUvYmFzZS1jb21wb25lbnQtbWFuYWdlcic7XG5pbXBvcnQgR2xpbW1lckNvbXBvbmVudCwgeyBzZXREZXN0cm95aW5nLCBzZXREZXN0cm95ZWQgfSBmcm9tICcuLi9hZGRvbi8tcHJpdmF0ZS9jb21wb25lbnQnO1xuXG5jb25zdCBDQVBBQklMSVRJRVMgPSBjb21wb25lbnRDYXBhYmlsaXRpZXMoJzMuMTMnLCB7XG4gIGRlc3RydWN0b3I6IHRydWUsXG59KTtcblxuLyoqXG4gKiBUaGlzIGNvbXBvbmVudCBtYW5hZ2VyIHJ1bnMgaW4gR2xpbW1lci5qcyBlbnZpcm9ubWVudHMgYW5kIGV4dGVuZHMgdGhlIGJhc2UgY29tcG9uZW50IG1hbmFnZXIgdG86XG4gKlxuICogMS4gSW1wbGVtZW50IGEgbGlnaHR3ZWlnaHQgZGVzdHJ1Y3Rpb24gcHJvdG9jb2wgKGN1cnJlbnRseSBub3QgZGVmZXJyZWQsIGxpa2UgaW4gRW1iZXIpXG4gKiAyLiBJbnZva2UgbGVnYWN5IGNvbXBvbmVudCBsaWZlY3ljbGUgaG9va3MgKGRpZEluc2VydEVsZW1lbnQgYW5kIGRpZFVwZGF0ZSlcbiAqL1xuZXhwb3J0IGRlZmF1bHQgY2xhc3MgR2xpbW1lckNvbXBvbmVudE1hbmFnZXIgZXh0ZW5kcyBCYXNlQ29tcG9uZW50TWFuYWdlcjxHbGltbWVyQ29tcG9uZW50PiB7XG4gIGNhcGFiaWxpdGllcyA9IENBUEFCSUxJVElFUztcblxuICBkZXN0cm95Q29tcG9uZW50KGNvbXBvbmVudDogR2xpbW1lckNvbXBvbmVudCk6IHZvaWQge1xuICAgIHNldERlc3Ryb3lpbmcoY29tcG9uZW50KTtcbiAgICBjb21wb25lbnQud2lsbERlc3Ryb3koKTtcbiAgICBzZXREZXN0cm95ZWQoY29tcG9uZW50KTtcbiAgfVxufVxuIl19
@@ -0,0 +1,4 @@
1
+ import _GlimmerComponent, { Args } from '../addon/-private/component';
2
+ export default class GlimmerComponent<S = unknown> extends _GlimmerComponent<S> {
3
+ constructor(owner: object, args: Args<S>);
4
+ }
@@ -0,0 +1,23 @@
1
+ "use strict";
2
+ var __importDefault = (this && this.__importDefault) || function (mod) {
3
+ return (mod && mod.__esModule) ? mod : { "default": mod };
4
+ };
5
+ Object.defineProperty(exports, "__esModule", { value: true });
6
+ const glimmer_core_1 = require("@norith/glimmer-core");
7
+ const component_manager_1 = __importDefault(require("./component-manager"));
8
+ const component_1 = __importDefault(require("../addon/-private/component"));
9
+ const env_1 = require("@glimmer/env");
10
+ class GlimmerComponent extends component_1.default {
11
+ constructor(owner, args) {
12
+ super(owner, args);
13
+ if (env_1.DEBUG && !(owner !== null && typeof owner === 'object')) {
14
+ throw new Error(`You must pass both the owner and args to super() in your component: ${this.constructor.name}. You can pass them directly, or use ...arguments to pass all arguments through.`);
15
+ }
16
+ glimmer_core_1.setOwner(this, owner);
17
+ }
18
+ }
19
+ exports.default = GlimmerComponent;
20
+ glimmer_core_1.setComponentManager((owner) => {
21
+ return new component_manager_1.default(owner);
22
+ }, GlimmerComponent);
23
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vcGFja2FnZXMvQGdsaW1tZXIvY29tcG9uZW50L3NyYy9jb21wb25lbnQudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7Ozs7QUFBQSx1REFBcUU7QUFDckUsNEVBQTBEO0FBQzFELDRFQUFzRTtBQUN0RSxzQ0FBcUM7QUFFckMsTUFBcUIsZ0JBQThCLFNBQVEsbUJBQW9CO0lBQzdFLFlBQVksS0FBYSxFQUFFLElBQWE7UUFDdEMsS0FBSyxDQUFDLEtBQUssRUFBRSxJQUFJLENBQUMsQ0FBQztRQUVuQixJQUFJLFdBQUssSUFBSSxDQUFDLENBQUMsS0FBSyxLQUFLLElBQUksSUFBSSxPQUFPLEtBQUssS0FBSyxRQUFRLENBQUMsRUFBRTtZQUMzRCxNQUFNLElBQUksS0FBSyxDQUNiLHVFQUF1RSxJQUFJLENBQUMsV0FBVyxDQUFDLElBQUksa0ZBQWtGLENBQy9LLENBQUM7U0FDSDtRQUVELHVCQUFRLENBQUMsSUFBSSxFQUFFLEtBQUssQ0FBQyxDQUFDO0lBQ3hCLENBQUM7Q0FDRjtBQVpELG1DQVlDO0FBRUQsa0NBQW1CLENBQUMsQ0FBQyxLQUFTLEVBQUUsRUFBRTtJQUNoQyxPQUFPLElBQUksMkJBQXVCLENBQUMsS0FBSyxDQUFDLENBQUM7QUFDNUMsQ0FBQyxFQUFFLGdCQUFnQixDQUFDLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBzZXRDb21wb25lbnRNYW5hZ2VyLCBzZXRPd25lciB9IGZyb20gJ0Bub3JpdGgvZ2xpbW1lci1jb3JlJztcbmltcG9ydCBHbGltbWVyQ29tcG9uZW50TWFuYWdlciBmcm9tICcuL2NvbXBvbmVudC1tYW5hZ2VyJztcbmltcG9ydCBfR2xpbW1lckNvbXBvbmVudCwgeyBBcmdzIH0gZnJvbSAnLi4vYWRkb24vLXByaXZhdGUvY29tcG9uZW50JztcbmltcG9ydCB7IERFQlVHIH0gZnJvbSAnQGdsaW1tZXIvZW52JztcblxuZXhwb3J0IGRlZmF1bHQgY2xhc3MgR2xpbW1lckNvbXBvbmVudDxTID0gdW5rbm93bj4gZXh0ZW5kcyBfR2xpbW1lckNvbXBvbmVudDxTPiB7XG4gIGNvbnN0cnVjdG9yKG93bmVyOiBvYmplY3QsIGFyZ3M6IEFyZ3M8Uz4pIHtcbiAgICBzdXBlcihvd25lciwgYXJncyk7XG5cbiAgICBpZiAoREVCVUcgJiYgIShvd25lciAhPT0gbnVsbCAmJiB0eXBlb2Ygb3duZXIgPT09ICdvYmplY3QnKSkge1xuICAgICAgdGhyb3cgbmV3IEVycm9yKFxuICAgICAgICBgWW91IG11c3QgcGFzcyBib3RoIHRoZSBvd25lciBhbmQgYXJncyB0byBzdXBlcigpIGluIHlvdXIgY29tcG9uZW50OiAke3RoaXMuY29uc3RydWN0b3IubmFtZX0uIFlvdSBjYW4gcGFzcyB0aGVtIGRpcmVjdGx5LCBvciB1c2UgLi4uYXJndW1lbnRzIHRvIHBhc3MgYWxsIGFyZ3VtZW50cyB0aHJvdWdoLmBcbiAgICAgICk7XG4gICAgfVxuXG4gICAgc2V0T3duZXIodGhpcywgb3duZXIpO1xuICB9XG59XG5cbnNldENvbXBvbmVudE1hbmFnZXIoKG93bmVyOiB7fSkgPT4ge1xuICByZXR1cm4gbmV3IEdsaW1tZXJDb21wb25lbnRNYW5hZ2VyKG93bmVyKTtcbn0sIEdsaW1tZXJDb21wb25lbnQpO1xuIl19
@@ -0,0 +1 @@
1
+ import './interactive';
@@ -0,0 +1,4 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ require("./interactive");
4
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wYWNrYWdlcy9AZ2xpbW1lci9jb21wb25lbnQvdGVzdC9pbmRleC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOztBQUFBLHlCQUF1QiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCAnLi9pbnRlcmFjdGl2ZSc7XG4iXX0=
@@ -0,0 +1 @@
1
+ export {};
@@ -0,0 +1,47 @@
1
+ "use strict";
2
+ var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {
3
+ var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
4
+ if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
5
+ else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
6
+ return c > 3 && r && Object.defineProperty(target, key, r), r;
7
+ };
8
+ var __importDefault = (this && this.__importDefault) || function (mod) {
9
+ return (mod && mod.__esModule) ? mod : { "default": mod };
10
+ };
11
+ Object.defineProperty(exports, "__esModule", { value: true });
12
+ const glimmer_component_1 = __importDefault(require("@norith/glimmer-component"));
13
+ const glimmer_tracking_1 = require("@norith/glimmer-tracking");
14
+ const glimmer_core_1 = require("@norith/glimmer-core");
15
+ const utils_1 = require("@norith/glimmer-core/test/utils");
16
+ QUnit.module('[@glimmer/component] Component Arguments', () => {
17
+ utils_1.test('Getters that depend on `args` re-render correctly', async function (assert) {
18
+ assert.expect(2);
19
+ let parent;
20
+ class ParentComponent extends glimmer_component_1.default {
21
+ constructor(owner, args) {
22
+ super(owner, args);
23
+ this.firstName = 'Tom';
24
+ this.status = 'is dope';
25
+ parent = this;
26
+ }
27
+ }
28
+ __decorate([
29
+ glimmer_tracking_1.tracked
30
+ ], ParentComponent.prototype, "firstName", void 0);
31
+ __decorate([
32
+ glimmer_tracking_1.tracked
33
+ ], ParentComponent.prototype, "status", void 0);
34
+ class ChildComponent extends glimmer_component_1.default {
35
+ get name() {
36
+ return `${this.args.firstName} Dale`;
37
+ }
38
+ }
39
+ glimmer_core_1.setComponentTemplate(glimmer_core_1.precompileTemplate('<ChildComponent @firstName={{this.firstName}} @status={{this.status}} />', { strictMode: true, scope: { ChildComponent } }), ParentComponent);
40
+ glimmer_core_1.setComponentTemplate(glimmer_core_1.precompileTemplate('{{this.name}} {{@status}}', { strictMode: true }), ChildComponent);
41
+ assert.equal(await utils_1.render(ParentComponent), 'Tom Dale is dope');
42
+ parent.firstName = 'Thom';
43
+ parent.status = 'is dank';
44
+ assert.equal(await utils_1.settled(), 'Thom Dale is dank');
45
+ });
46
+ });
47
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYXJncy10ZXN0LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vcGFja2FnZXMvQGdsaW1tZXIvY29tcG9uZW50L3Rlc3QvaW50ZXJhY3RpdmUvYXJncy10ZXN0LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7Ozs7Ozs7Ozs7O0FBQUEsa0ZBQWtEO0FBQ2xELCtEQUFtRDtBQUVuRCx1REFBZ0Y7QUFDaEYsMkRBQXdFO0FBRXhFLEtBQUssQ0FBQyxNQUFNLENBQUMsMENBQTBDLEVBQUUsR0FBRyxFQUFFO0lBQzVELFlBQUksQ0FBQyxtREFBbUQsRUFBRSxLQUFLLFdBQVcsTUFBTTtRQUM5RSxNQUFNLENBQUMsTUFBTSxDQUFDLENBQUMsQ0FBQyxDQUFDO1FBRWpCLElBQUksTUFBdUIsQ0FBQztRQUU1QixNQUFNLGVBQWdCLFNBQVEsMkJBQVM7WUFJckMsWUFBWSxLQUFhLEVBQUUsSUFBUTtnQkFDakMsS0FBSyxDQUFDLEtBQUssRUFBRSxJQUFJLENBQUMsQ0FBQztnQkFKWixjQUFTLEdBQUcsS0FBSyxDQUFDO2dCQUNsQixXQUFNLEdBQUcsU0FBUyxDQUFDO2dCQUkxQixNQUFNLEdBQUcsSUFBSSxDQUFDO1lBQ2hCLENBQUM7U0FDRjtRQVBVO1lBQVIsMEJBQU87MERBQW1CO1FBQ2xCO1lBQVIsMEJBQU87dURBQW9CO1FBUTlCLE1BQU0sY0FBZSxTQUFRLDJCQUFnQztZQUMzRCxJQUFJLElBQUk7Z0JBQ04sT0FBTyxHQUFHLElBQUksQ0FBQyxJQUFJLENBQUMsU0FBUyxPQUFPLENBQUM7WUFDdkMsQ0FBQztTQUNGO1FBRUQsbUNBQW9CLENBQ2xCLGlDQUFrQixDQUNoQiwwRUFBMEUsRUFDMUUsRUFBRSxVQUFVLEVBQUUsSUFBSSxFQUFFLEtBQUssRUFBRSxFQUFFLGNBQWMsRUFBRSxFQUFFLENBQ2hELEVBQ0QsZUFBZSxDQUNoQixDQUFDO1FBRUYsbUNBQW9CLENBQ2xCLGlDQUFrQixDQUFDLDJCQUEyQixFQUFFLEVBQUUsVUFBVSxFQUFFLElBQUksRUFBRSxDQUFDLEVBQ3JFLGNBQWMsQ0FDZixDQUFDO1FBRUYsTUFBTSxDQUFDLEtBQUssQ0FBQyxNQUFNLGNBQU0sQ0FBQyxlQUFlLENBQUMsRUFBRSxrQkFBa0IsQ0FBQyxDQUFDO1FBRWhFLE1BQU8sQ0FBQyxTQUFTLEdBQUcsTUFBTSxDQUFDO1FBQzNCLE1BQU8sQ0FBQyxNQUFNLEdBQUcsU0FBUyxDQUFDO1FBRTNCLE1BQU0sQ0FBQyxLQUFLLENBQUMsTUFBTSxlQUFPLEVBQUUsRUFBRSxtQkFBbUIsQ0FBQyxDQUFDO0lBQ3JELENBQUMsQ0FBQyxDQUFDO0FBQ0wsQ0FBQyxDQUFDLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgQ29tcG9uZW50IGZyb20gJ0Bub3JpdGgvZ2xpbW1lci1jb21wb25lbnQnO1xuaW1wb3J0IHsgdHJhY2tlZCB9IGZyb20gJ0Bub3JpdGgvZ2xpbW1lci10cmFja2luZyc7XG5cbmltcG9ydCB7IHNldENvbXBvbmVudFRlbXBsYXRlLCBwcmVjb21waWxlVGVtcGxhdGUgfSBmcm9tICdAbm9yaXRoL2dsaW1tZXItY29yZSc7XG5pbXBvcnQgeyB0ZXN0LCByZW5kZXIsIHNldHRsZWQgfSBmcm9tICdAbm9yaXRoL2dsaW1tZXItY29yZS90ZXN0L3V0aWxzJztcblxuUVVuaXQubW9kdWxlKCdbQGdsaW1tZXIvY29tcG9uZW50XSBDb21wb25lbnQgQXJndW1lbnRzJywgKCkgPT4ge1xuICB0ZXN0KCdHZXR0ZXJzIHRoYXQgZGVwZW5kIG9uIGBhcmdzYCByZS1yZW5kZXIgY29ycmVjdGx5JywgYXN5bmMgZnVuY3Rpb24gKGFzc2VydCkge1xuICAgIGFzc2VydC5leHBlY3QoMik7XG5cbiAgICBsZXQgcGFyZW50OiBQYXJlbnRDb21wb25lbnQ7XG5cbiAgICBjbGFzcyBQYXJlbnRDb21wb25lbnQgZXh0ZW5kcyBDb21wb25lbnQge1xuICAgICAgQHRyYWNrZWQgZmlyc3ROYW1lID0gJ1RvbSc7XG4gICAgICBAdHJhY2tlZCBzdGF0dXMgPSAnaXMgZG9wZSc7XG5cbiAgICAgIGNvbnN0cnVjdG9yKG93bmVyOiBvYmplY3QsIGFyZ3M6IHt9KSB7XG4gICAgICAgIHN1cGVyKG93bmVyLCBhcmdzKTtcbiAgICAgICAgcGFyZW50ID0gdGhpcztcbiAgICAgIH1cbiAgICB9XG5cbiAgICBjbGFzcyBDaGlsZENvbXBvbmVudCBleHRlbmRzIENvbXBvbmVudDx7IGZpcnN0TmFtZTogc3RyaW5nIH0+IHtcbiAgICAgIGdldCBuYW1lKCk6IHN0cmluZyB7XG4gICAgICAgIHJldHVybiBgJHt0aGlzLmFyZ3MuZmlyc3ROYW1lfSBEYWxlYDtcbiAgICAgIH1cbiAgICB9XG5cbiAgICBzZXRDb21wb25lbnRUZW1wbGF0ZShcbiAgICAgIHByZWNvbXBpbGVUZW1wbGF0ZShcbiAgICAgICAgJzxDaGlsZENvbXBvbmVudCBAZmlyc3ROYW1lPXt7dGhpcy5maXJzdE5hbWV9fSBAc3RhdHVzPXt7dGhpcy5zdGF0dXN9fSAvPicsXG4gICAgICAgIHsgc3RyaWN0TW9kZTogdHJ1ZSwgc2NvcGU6IHsgQ2hpbGRDb21wb25lbnQgfSB9XG4gICAgICApLFxuICAgICAgUGFyZW50Q29tcG9uZW50XG4gICAgKTtcblxuICAgIHNldENvbXBvbmVudFRlbXBsYXRlKFxuICAgICAgcHJlY29tcGlsZVRlbXBsYXRlKCd7e3RoaXMubmFtZX19IHt7QHN0YXR1c319JywgeyBzdHJpY3RNb2RlOiB0cnVlIH0pLFxuICAgICAgQ2hpbGRDb21wb25lbnRcbiAgICApO1xuXG4gICAgYXNzZXJ0LmVxdWFsKGF3YWl0IHJlbmRlcihQYXJlbnRDb21wb25lbnQpLCAnVG9tIERhbGUgaXMgZG9wZScpO1xuXG4gICAgcGFyZW50IS5maXJzdE5hbWUgPSAnVGhvbSc7XG4gICAgcGFyZW50IS5zdGF0dXMgPSAnaXMgZGFuayc7XG5cbiAgICBhc3NlcnQuZXF1YWwoYXdhaXQgc2V0dGxlZCgpLCAnVGhvbSBEYWxlIGlzIGRhbmsnKTtcbiAgfSk7XG59KTtcbiJdfQ==
@@ -0,0 +1,2 @@
1
+ import './args-test';
2
+ import './lifecycle-hook-test';
@@ -0,0 +1,5 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ require("./args-test");
4
+ require("./lifecycle-hook-test");
5
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wYWNrYWdlcy9AZ2xpbW1lci9jb21wb25lbnQvdGVzdC9pbnRlcmFjdGl2ZS9pbmRleC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOztBQUFBLHVCQUFxQjtBQUNyQixpQ0FBK0IiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgJy4vYXJncy10ZXN0JztcbmltcG9ydCAnLi9saWZlY3ljbGUtaG9vay10ZXN0JztcbiJdfQ==