@norith/glimmer-tracking 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.
- package/README.md +44 -0
- package/dist/commonjs/index.d.ts +2 -0
- package/dist/commonjs/index.js +8 -0
- package/dist/commonjs/src/cached.d.ts +58 -0
- package/dist/commonjs/src/cached.js +100 -0
- package/dist/commonjs/src/tracked.d.ts +57 -0
- package/dist/commonjs/src/tracked.js +109 -0
- package/dist/commonjs/test/cached-decorator-test.d.ts +1 -0
- package/dist/commonjs/test/cached-decorator-test.js +137 -0
- package/dist/commonjs/test/fixtures/typescript.d.ts +47 -0
- package/dist/commonjs/test/fixtures/typescript.js +297 -0
- package/dist/commonjs/test/helpers/tags.d.ts +2 -0
- package/dist/commonjs/test/helpers/tags.js +10 -0
- package/dist/commonjs/test/index.d.ts +2 -0
- package/dist/commonjs/test/index.js +5 -0
- package/dist/commonjs/test/tracked-decorator-test.d.ts +1 -0
- package/dist/commonjs/test/tracked-decorator-test.js +182 -0
- package/dist/modules/index.d.ts +2 -0
- package/dist/modules/index.js +3 -0
- package/dist/modules/src/cached.d.ts +58 -0
- package/dist/modules/src/cached.js +96 -0
- package/dist/modules/src/tracked.d.ts +57 -0
- package/dist/modules/src/tracked.js +105 -0
- package/dist/modules/test/cached-decorator-test.d.ts +1 -0
- package/dist/modules/test/cached-decorator-test.js +116 -0
- package/dist/modules/test/fixtures/typescript.d.ts +47 -0
- package/dist/modules/test/fixtures/typescript.js +280 -0
- package/dist/modules/test/helpers/tags.d.ts +2 -0
- package/dist/modules/test/helpers/tags.js +6 -0
- package/dist/modules/test/index.d.ts +2 -0
- package/dist/modules/test/index.js +3 -0
- package/dist/modules/test/tracked-decorator-test.d.ts +1 -0
- package/dist/modules/test/tracked-decorator-test.js +161 -0
- package/ember-addon-main.js +5 -0
- package/package.json +41 -0
|
@@ -0,0 +1,297 @@
|
|
|
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
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
9
|
+
exports.createClassWithCachedAsDecoratorFactory = exports.createClassWithTrackedAsDecoratorFactory = exports.createClassWithCachedDependentKeys = exports.createClassWithTrackedDependentKeys = exports.createClassWithCachedSetter = exports.createClassWithTrackedSetter = exports.createClassWithCachedProperty = exports.createClassWithTrackedGetter = exports.PersonForContact = exports.Contact = exports.PersonWithSalutation = exports.PersonWithCount = exports.FrozenToran = exports.Toran = exports.Tom = void 0;
|
|
10
|
+
const glimmer_tracking_1 = require("@norith/glimmer-tracking");
|
|
11
|
+
class Tom {
|
|
12
|
+
constructor() {
|
|
13
|
+
this.firstName = 'Tom';
|
|
14
|
+
}
|
|
15
|
+
}
|
|
16
|
+
__decorate([
|
|
17
|
+
glimmer_tracking_1.tracked
|
|
18
|
+
], Tom.prototype, "firstName", void 0);
|
|
19
|
+
exports.Tom = Tom;
|
|
20
|
+
class Toran {
|
|
21
|
+
constructor() {
|
|
22
|
+
this.firstName = 'Toran';
|
|
23
|
+
this.lastName = 'Billups';
|
|
24
|
+
}
|
|
25
|
+
}
|
|
26
|
+
__decorate([
|
|
27
|
+
glimmer_tracking_1.tracked
|
|
28
|
+
], Toran.prototype, "firstName", void 0);
|
|
29
|
+
exports.Toran = Toran;
|
|
30
|
+
class FrozenToran {
|
|
31
|
+
constructor() {
|
|
32
|
+
this.firstName = 'Toran';
|
|
33
|
+
this.lastName = 'Billups';
|
|
34
|
+
}
|
|
35
|
+
}
|
|
36
|
+
__decorate([
|
|
37
|
+
glimmer_tracking_1.tracked
|
|
38
|
+
], FrozenToran.prototype, "firstName", void 0);
|
|
39
|
+
exports.FrozenToran = FrozenToran;
|
|
40
|
+
Object.freeze(FrozenToran);
|
|
41
|
+
class PersonWithCount {
|
|
42
|
+
constructor() {
|
|
43
|
+
this._firstName = 'Tom';
|
|
44
|
+
this._count = 0;
|
|
45
|
+
}
|
|
46
|
+
get firstName() {
|
|
47
|
+
return this._firstName + this._count++;
|
|
48
|
+
}
|
|
49
|
+
set firstName(value) {
|
|
50
|
+
this._firstName = value;
|
|
51
|
+
}
|
|
52
|
+
}
|
|
53
|
+
__decorate([
|
|
54
|
+
glimmer_tracking_1.tracked
|
|
55
|
+
], PersonWithCount.prototype, "_firstName", void 0);
|
|
56
|
+
exports.PersonWithCount = PersonWithCount;
|
|
57
|
+
class PersonWithSalutation {
|
|
58
|
+
constructor() {
|
|
59
|
+
this.firstName = 'Tom';
|
|
60
|
+
this.lastName = 'Dale';
|
|
61
|
+
}
|
|
62
|
+
get salutation() {
|
|
63
|
+
return `Hello, ${this.fullName}!`;
|
|
64
|
+
}
|
|
65
|
+
get fullName() {
|
|
66
|
+
return `${this.firstName} ${this.lastName}`;
|
|
67
|
+
}
|
|
68
|
+
set fullName(fullName) {
|
|
69
|
+
const [firstName, lastName] = fullName.split(' ');
|
|
70
|
+
this.firstName = firstName;
|
|
71
|
+
this.lastName = lastName;
|
|
72
|
+
}
|
|
73
|
+
}
|
|
74
|
+
__decorate([
|
|
75
|
+
glimmer_tracking_1.tracked
|
|
76
|
+
], PersonWithSalutation.prototype, "firstName", void 0);
|
|
77
|
+
__decorate([
|
|
78
|
+
glimmer_tracking_1.tracked
|
|
79
|
+
], PersonWithSalutation.prototype, "lastName", void 0);
|
|
80
|
+
exports.PersonWithSalutation = PersonWithSalutation;
|
|
81
|
+
class Contact {
|
|
82
|
+
constructor(person, email) {
|
|
83
|
+
this.person = person;
|
|
84
|
+
this.email = email;
|
|
85
|
+
}
|
|
86
|
+
get contact() {
|
|
87
|
+
return `${this.person} @ ${this.email}`;
|
|
88
|
+
}
|
|
89
|
+
}
|
|
90
|
+
__decorate([
|
|
91
|
+
glimmer_tracking_1.tracked
|
|
92
|
+
], Contact.prototype, "email", void 0);
|
|
93
|
+
__decorate([
|
|
94
|
+
glimmer_tracking_1.tracked
|
|
95
|
+
], Contact.prototype, "person", void 0);
|
|
96
|
+
exports.Contact = Contact;
|
|
97
|
+
class PersonForContact {
|
|
98
|
+
constructor() {
|
|
99
|
+
this.firstName = 'Tom';
|
|
100
|
+
this.lastName = 'Dale';
|
|
101
|
+
}
|
|
102
|
+
get salutation() {
|
|
103
|
+
return `Hello, ${this.fullName}!`;
|
|
104
|
+
}
|
|
105
|
+
get fullName() {
|
|
106
|
+
return `${this.firstName} ${this.lastName}`;
|
|
107
|
+
}
|
|
108
|
+
set fullName(fullName) {
|
|
109
|
+
const [firstName, lastName] = fullName.split(' ');
|
|
110
|
+
this.firstName = firstName;
|
|
111
|
+
this.lastName = lastName;
|
|
112
|
+
}
|
|
113
|
+
toString() {
|
|
114
|
+
return this.fullName;
|
|
115
|
+
}
|
|
116
|
+
}
|
|
117
|
+
__decorate([
|
|
118
|
+
glimmer_tracking_1.tracked
|
|
119
|
+
], PersonForContact.prototype, "firstName", void 0);
|
|
120
|
+
__decorate([
|
|
121
|
+
glimmer_tracking_1.tracked
|
|
122
|
+
], PersonForContact.prototype, "lastName", void 0);
|
|
123
|
+
exports.PersonForContact = PersonForContact;
|
|
124
|
+
function createClassWithTrackedGetter() {
|
|
125
|
+
class PersonWithTrackedGetter {
|
|
126
|
+
constructor() {
|
|
127
|
+
this.firstName = 'Tom';
|
|
128
|
+
}
|
|
129
|
+
get salutation() {
|
|
130
|
+
return `Hello, ${this.firstName} ${this.lastName}!`;
|
|
131
|
+
}
|
|
132
|
+
}
|
|
133
|
+
__decorate([
|
|
134
|
+
glimmer_tracking_1.tracked
|
|
135
|
+
], PersonWithTrackedGetter.prototype, "firstName", void 0);
|
|
136
|
+
__decorate([
|
|
137
|
+
glimmer_tracking_1.tracked
|
|
138
|
+
], PersonWithTrackedGetter.prototype, "lastName", void 0);
|
|
139
|
+
__decorate([
|
|
140
|
+
glimmer_tracking_1.tracked
|
|
141
|
+
], PersonWithTrackedGetter.prototype, "salutation", null);
|
|
142
|
+
return new PersonWithTrackedGetter();
|
|
143
|
+
}
|
|
144
|
+
exports.createClassWithTrackedGetter = createClassWithTrackedGetter;
|
|
145
|
+
function createClassWithCachedProperty() {
|
|
146
|
+
class PersonWithCachedProperty {
|
|
147
|
+
constructor() {
|
|
148
|
+
this.firstName = 'Tom';
|
|
149
|
+
}
|
|
150
|
+
}
|
|
151
|
+
__decorate([
|
|
152
|
+
glimmer_tracking_1.cached
|
|
153
|
+
], PersonWithCachedProperty.prototype, "firstName", void 0);
|
|
154
|
+
return new PersonWithCachedProperty();
|
|
155
|
+
}
|
|
156
|
+
exports.createClassWithCachedProperty = createClassWithCachedProperty;
|
|
157
|
+
function createClassWithTrackedSetter() {
|
|
158
|
+
class PersonWithTrackedSetter {
|
|
159
|
+
constructor() {
|
|
160
|
+
this.firstName = 'Tom';
|
|
161
|
+
}
|
|
162
|
+
// @ts-ignore
|
|
163
|
+
set fullName(fullName) {
|
|
164
|
+
const [firstName, lastName] = fullName.split(' ');
|
|
165
|
+
this.firstName = firstName;
|
|
166
|
+
this.lastName = lastName;
|
|
167
|
+
}
|
|
168
|
+
}
|
|
169
|
+
__decorate([
|
|
170
|
+
glimmer_tracking_1.tracked
|
|
171
|
+
], PersonWithTrackedSetter.prototype, "firstName", void 0);
|
|
172
|
+
__decorate([
|
|
173
|
+
glimmer_tracking_1.tracked
|
|
174
|
+
], PersonWithTrackedSetter.prototype, "lastName", void 0);
|
|
175
|
+
__decorate([
|
|
176
|
+
glimmer_tracking_1.tracked
|
|
177
|
+
], PersonWithTrackedSetter.prototype, "fullName", null);
|
|
178
|
+
return new PersonWithTrackedSetter();
|
|
179
|
+
}
|
|
180
|
+
exports.createClassWithTrackedSetter = createClassWithTrackedSetter;
|
|
181
|
+
function createClassWithCachedSetter() {
|
|
182
|
+
class PersonWithCachedSetter {
|
|
183
|
+
constructor() {
|
|
184
|
+
this.firstName = 'Tom';
|
|
185
|
+
}
|
|
186
|
+
// @ts-ignore
|
|
187
|
+
set fullName(fullName) {
|
|
188
|
+
const [firstName, lastName] = fullName.split(' ');
|
|
189
|
+
this.firstName = firstName;
|
|
190
|
+
this.lastName = lastName;
|
|
191
|
+
}
|
|
192
|
+
}
|
|
193
|
+
__decorate([
|
|
194
|
+
glimmer_tracking_1.tracked
|
|
195
|
+
], PersonWithCachedSetter.prototype, "firstName", void 0);
|
|
196
|
+
__decorate([
|
|
197
|
+
glimmer_tracking_1.tracked
|
|
198
|
+
], PersonWithCachedSetter.prototype, "lastName", void 0);
|
|
199
|
+
__decorate([
|
|
200
|
+
glimmer_tracking_1.cached
|
|
201
|
+
], PersonWithCachedSetter.prototype, "fullName", null);
|
|
202
|
+
return new PersonWithCachedSetter();
|
|
203
|
+
}
|
|
204
|
+
exports.createClassWithCachedSetter = createClassWithCachedSetter;
|
|
205
|
+
function createClassWithTrackedDependentKeys() {
|
|
206
|
+
class DependentKeysAreCool {
|
|
207
|
+
constructor() {
|
|
208
|
+
this.firstName = 'Tom';
|
|
209
|
+
this.lastName = 'Dale';
|
|
210
|
+
}
|
|
211
|
+
// @ts-ignore
|
|
212
|
+
fullName() {
|
|
213
|
+
return `${this.firstName} ${this.lastName}`;
|
|
214
|
+
}
|
|
215
|
+
}
|
|
216
|
+
__decorate([
|
|
217
|
+
glimmer_tracking_1.tracked('firstName', 'lastName')
|
|
218
|
+
], DependentKeysAreCool.prototype, "fullName", null);
|
|
219
|
+
__decorate([
|
|
220
|
+
glimmer_tracking_1.tracked
|
|
221
|
+
], DependentKeysAreCool.prototype, "firstName", void 0);
|
|
222
|
+
__decorate([
|
|
223
|
+
glimmer_tracking_1.tracked
|
|
224
|
+
], DependentKeysAreCool.prototype, "lastName", void 0);
|
|
225
|
+
return new DependentKeysAreCool();
|
|
226
|
+
}
|
|
227
|
+
exports.createClassWithTrackedDependentKeys = createClassWithTrackedDependentKeys;
|
|
228
|
+
function createClassWithCachedDependentKeys() {
|
|
229
|
+
class DependentKeysAreCool {
|
|
230
|
+
constructor() {
|
|
231
|
+
this.firstName = 'Tom';
|
|
232
|
+
this.lastName = 'Dale';
|
|
233
|
+
}
|
|
234
|
+
// @ts-ignore
|
|
235
|
+
fullName() {
|
|
236
|
+
return `${this.firstName} ${this.lastName}`;
|
|
237
|
+
}
|
|
238
|
+
}
|
|
239
|
+
__decorate([
|
|
240
|
+
glimmer_tracking_1.cached('firstName', 'lastName')
|
|
241
|
+
], DependentKeysAreCool.prototype, "fullName", null);
|
|
242
|
+
__decorate([
|
|
243
|
+
glimmer_tracking_1.tracked
|
|
244
|
+
], DependentKeysAreCool.prototype, "firstName", void 0);
|
|
245
|
+
__decorate([
|
|
246
|
+
glimmer_tracking_1.tracked
|
|
247
|
+
], DependentKeysAreCool.prototype, "lastName", void 0);
|
|
248
|
+
return new DependentKeysAreCool();
|
|
249
|
+
}
|
|
250
|
+
exports.createClassWithCachedDependentKeys = createClassWithCachedDependentKeys;
|
|
251
|
+
function createClassWithTrackedAsDecoratorFactory() {
|
|
252
|
+
class DependentKeysAreCool {
|
|
253
|
+
constructor() {
|
|
254
|
+
this.firstName = 'Tom';
|
|
255
|
+
this.lastName = 'Dale';
|
|
256
|
+
}
|
|
257
|
+
// @ts-ignore
|
|
258
|
+
fullName() {
|
|
259
|
+
return `${this.firstName} ${this.lastName}`;
|
|
260
|
+
}
|
|
261
|
+
}
|
|
262
|
+
__decorate([
|
|
263
|
+
glimmer_tracking_1.tracked()
|
|
264
|
+
], DependentKeysAreCool.prototype, "fullName", null);
|
|
265
|
+
__decorate([
|
|
266
|
+
glimmer_tracking_1.tracked
|
|
267
|
+
], DependentKeysAreCool.prototype, "firstName", void 0);
|
|
268
|
+
__decorate([
|
|
269
|
+
glimmer_tracking_1.tracked
|
|
270
|
+
], DependentKeysAreCool.prototype, "lastName", void 0);
|
|
271
|
+
return new DependentKeysAreCool();
|
|
272
|
+
}
|
|
273
|
+
exports.createClassWithTrackedAsDecoratorFactory = createClassWithTrackedAsDecoratorFactory;
|
|
274
|
+
function createClassWithCachedAsDecoratorFactory() {
|
|
275
|
+
class DependentKeysAreCool {
|
|
276
|
+
constructor() {
|
|
277
|
+
this.firstName = 'Tom';
|
|
278
|
+
this.lastName = 'Dale';
|
|
279
|
+
}
|
|
280
|
+
// @ts-ignore
|
|
281
|
+
fullName() {
|
|
282
|
+
return `${this.firstName} ${this.lastName}`;
|
|
283
|
+
}
|
|
284
|
+
}
|
|
285
|
+
__decorate([
|
|
286
|
+
glimmer_tracking_1.cached()
|
|
287
|
+
], DependentKeysAreCool.prototype, "fullName", null);
|
|
288
|
+
__decorate([
|
|
289
|
+
glimmer_tracking_1.tracked
|
|
290
|
+
], DependentKeysAreCool.prototype, "firstName", void 0);
|
|
291
|
+
__decorate([
|
|
292
|
+
glimmer_tracking_1.tracked
|
|
293
|
+
], DependentKeysAreCool.prototype, "lastName", void 0);
|
|
294
|
+
return new DependentKeysAreCool();
|
|
295
|
+
}
|
|
296
|
+
exports.createClassWithCachedAsDecoratorFactory = createClassWithCachedAsDecoratorFactory;
|
|
297
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"typescript.js","sourceRoot":"","sources":["../../../../../../packages/@glimmer/tracking/test/fixtures/typescript.ts"],"names":[],"mappings":"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","sourcesContent":["import { cached, tracked } from '@norith/glimmer-tracking';\n\nexport class Tom {\n  @tracked firstName = 'Tom';\n}\n\nexport class Toran {\n  @tracked firstName = 'Toran';\n  lastName = 'Billups';\n}\n\nclass FrozenToran {\n  @tracked firstName = 'Toran';\n  lastName = 'Billups';\n}\n\nObject.freeze(FrozenToran);\n\nexport { FrozenToran };\n\nexport class PersonWithCount {\n  @tracked _firstName = 'Tom';\n  _count = 0;\n\n  get firstName() {\n    return this._firstName + this._count++;\n  }\n\n  set firstName(value) {\n    this._firstName = value;\n  }\n}\n\nexport class PersonWithSalutation {\n  get salutation() {\n    return `Hello, ${this.fullName}!`;\n  }\n\n  get fullName() {\n    return `${this.firstName} ${this.lastName}`;\n  }\n\n  set fullName(fullName) {\n    const [firstName, lastName] = fullName.split(' ');\n    this.firstName = firstName;\n    this.lastName = lastName;\n  }\n\n  @tracked firstName = 'Tom';\n  @tracked lastName = 'Dale';\n}\n\nexport class Contact {\n  @tracked email: string;\n  @tracked person: PersonForContact;\n\n  constructor(person: PersonForContact, email: string) {\n    this.person = person;\n    this.email = email;\n  }\n\n  get contact(): string {\n    return `${this.person} @ ${this.email}`;\n  }\n}\n\nexport class PersonForContact {\n  get salutation() {\n    return `Hello, ${this.fullName}!`;\n  }\n\n  get fullName(): string {\n    return `${this.firstName} ${this.lastName}`;\n  }\n\n  set fullName(fullName: string) {\n    const [firstName, lastName] = fullName.split(' ');\n    this.firstName = firstName;\n    this.lastName = lastName;\n  }\n\n  toString() {\n    return this.fullName;\n  }\n\n  @tracked firstName = 'Tom';\n  @tracked lastName = 'Dale';\n}\n\nexport function createClassWithTrackedGetter(): any {\n  class PersonWithTrackedGetter {\n    @tracked firstName = 'Tom';\n    @tracked lastName: any;\n\n    @tracked get salutation() {\n      return `Hello, ${this.firstName} ${this.lastName}!`;\n    }\n  }\n\n  return new PersonWithTrackedGetter();\n}\n\nexport function createClassWithCachedProperty(): any {\n  class PersonWithCachedProperty {\n    @cached firstName = 'Tom';\n  }\n\n  return new PersonWithCachedProperty();\n}\n\nexport function createClassWithTrackedSetter(): any {\n  class PersonWithTrackedSetter {\n    @tracked firstName = 'Tom';\n    @tracked lastName: any;\n\n    // @ts-ignore\n    @tracked set fullName(fullName) {\n      const [firstName, lastName] = fullName.split(' ');\n      this.firstName = firstName;\n      this.lastName = lastName;\n    }\n  }\n\n  return new PersonWithTrackedSetter();\n}\n\nexport function createClassWithCachedSetter(): any {\n  class PersonWithCachedSetter {\n    @tracked firstName = 'Tom';\n    @tracked lastName: any;\n\n    // @ts-ignore\n    @cached set fullName(fullName) {\n      const [firstName, lastName] = fullName.split(' ');\n      this.firstName = firstName;\n      this.lastName = lastName;\n    }\n  }\n\n  return new PersonWithCachedSetter();\n}\n\nexport function createClassWithTrackedDependentKeys(): any {\n  class DependentKeysAreCool {\n    // @ts-ignore\n    @tracked('firstName', 'lastName') fullName() {\n      return `${this.firstName} ${this.lastName}`;\n    }\n\n    @tracked firstName = 'Tom';\n    @tracked lastName = 'Dale';\n  }\n  return new DependentKeysAreCool();\n}\n\nexport function createClassWithCachedDependentKeys(): any {\n  class DependentKeysAreCool {\n    // @ts-ignore\n    @cached('firstName', 'lastName') fullName() {\n      return `${this.firstName} ${this.lastName}`;\n    }\n\n    @tracked firstName = 'Tom';\n    @tracked lastName = 'Dale';\n  }\n  return new DependentKeysAreCool();\n}\n\nexport function createClassWithTrackedAsDecoratorFactory(): any {\n  class DependentKeysAreCool {\n    // @ts-ignore\n    @tracked() fullName() {\n      return `${this.firstName} ${this.lastName}`;\n    }\n\n    @tracked firstName = 'Tom';\n    @tracked lastName = 'Dale';\n  }\n  return new DependentKeysAreCool();\n}\n\nexport function createClassWithCachedAsDecoratorFactory(): any {\n  class DependentKeysAreCool {\n    // @ts-ignore\n    @cached() fullName() {\n      return `${this.firstName} ${this.lastName}`;\n    }\n\n    @tracked firstName = 'Tom';\n    @tracked lastName = 'Dale';\n  }\n  return new DependentKeysAreCool();\n}\n"]}
|
|
@@ -0,0 +1,10 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.assertValidAfterUnrelatedBump = void 0;
|
|
4
|
+
const validator_1 = require("@glimmer/validator");
|
|
5
|
+
function assertValidAfterUnrelatedBump(tag, snapshot) {
|
|
6
|
+
validator_1.bump();
|
|
7
|
+
QUnit.assert.strictEqual(validator_1.validateTag(tag, snapshot), true, 'tag is still valid after an unrelated bump');
|
|
8
|
+
}
|
|
9
|
+
exports.assertValidAfterUnrelatedBump = assertValidAfterUnrelatedBump;
|
|
10
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGFncy5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL3BhY2thZ2VzL0BnbGltbWVyL3RyYWNraW5nL3Rlc3QvaGVscGVycy90YWdzLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7OztBQUFBLGtEQUE0RDtBQUU1RCxTQUFnQiw2QkFBNkIsQ0FBQyxHQUFRLEVBQUUsUUFBZ0I7SUFDdEUsZ0JBQUksRUFBRSxDQUFDO0lBRVAsS0FBSyxDQUFDLE1BQU0sQ0FBQyxXQUFXLENBQ3RCLHVCQUFXLENBQUMsR0FBRyxFQUFFLFFBQVEsQ0FBQyxFQUMxQixJQUFJLEVBQ0osNENBQTRDLENBQzdDLENBQUM7QUFDSixDQUFDO0FBUkQsc0VBUUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBidW1wLCBUYWcsIHZhbGlkYXRlVGFnIH0gZnJvbSAnQGdsaW1tZXIvdmFsaWRhdG9yJztcblxuZXhwb3J0IGZ1bmN0aW9uIGFzc2VydFZhbGlkQWZ0ZXJVbnJlbGF0ZWRCdW1wKHRhZzogVGFnLCBzbmFwc2hvdDogbnVtYmVyKTogdm9pZCB7XG4gIGJ1bXAoKTtcblxuICBRVW5pdC5hc3NlcnQuc3RyaWN0RXF1YWwoXG4gICAgdmFsaWRhdGVUYWcodGFnLCBzbmFwc2hvdCksXG4gICAgdHJ1ZSxcbiAgICAndGFnIGlzIHN0aWxsIHZhbGlkIGFmdGVyIGFuIHVucmVsYXRlZCBidW1wJ1xuICApO1xufVxuIl19
|
|
@@ -0,0 +1,5 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
require("./tracked-decorator-test");
|
|
4
|
+
require("./cached-decorator-test");
|
|
5
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wYWNrYWdlcy9AZ2xpbW1lci90cmFja2luZy90ZXN0L2luZGV4LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7O0FBQUEsb0NBQWtDO0FBQ2xDLG1DQUFpQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCAnLi90cmFja2VkLWRlY29yYXRvci10ZXN0JztcbmltcG9ydCAnLi9jYWNoZWQtZGVjb3JhdG9yLXRlc3QnO1xuIl19
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export {};
|
|
@@ -0,0 +1,182 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
|
|
3
|
+
if (k2 === undefined) k2 = k;
|
|
4
|
+
Object.defineProperty(o, k2, { enumerable: true, get: function() { return m[k]; } });
|
|
5
|
+
}) : (function(o, m, k, k2) {
|
|
6
|
+
if (k2 === undefined) k2 = k;
|
|
7
|
+
o[k2] = m[k];
|
|
8
|
+
}));
|
|
9
|
+
var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
|
|
10
|
+
Object.defineProperty(o, "default", { enumerable: true, value: v });
|
|
11
|
+
}) : function(o, v) {
|
|
12
|
+
o["default"] = v;
|
|
13
|
+
});
|
|
14
|
+
var __importStar = (this && this.__importStar) || function (mod) {
|
|
15
|
+
if (mod && mod.__esModule) return mod;
|
|
16
|
+
var result = {};
|
|
17
|
+
if (mod != null) for (var k in mod) if (k !== "default" && Object.prototype.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k);
|
|
18
|
+
__setModuleDefault(result, mod);
|
|
19
|
+
return result;
|
|
20
|
+
};
|
|
21
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
22
|
+
/* tslint:disable:no-unused-expression */
|
|
23
|
+
const { test } = QUnit;
|
|
24
|
+
const env_1 = require("@glimmer/env");
|
|
25
|
+
const validator_1 = require("@glimmer/validator");
|
|
26
|
+
const TSFixtures = __importStar(require("./fixtures/typescript"));
|
|
27
|
+
// eslint-disable-next-line @typescript-eslint/ban-ts-comment
|
|
28
|
+
// @ts-ignore
|
|
29
|
+
const BabelFixtures = __importStar(require("./fixtures/babel"));
|
|
30
|
+
const tags_1 = require("./helpers/tags");
|
|
31
|
+
[
|
|
32
|
+
['Babel', BabelFixtures],
|
|
33
|
+
['TypeScript', TSFixtures],
|
|
34
|
+
].forEach(([compiler, F]) => {
|
|
35
|
+
QUnit.module(`[@glimmer/tracking] Tracked Property Decorators with ${compiler}`);
|
|
36
|
+
test('tracked properties can be read and written to', (assert) => {
|
|
37
|
+
const obj = new F.Tom();
|
|
38
|
+
assert.strictEqual(obj.firstName, 'Tom');
|
|
39
|
+
obj.firstName = 'Edsger';
|
|
40
|
+
assert.strictEqual(obj.firstName, 'Edsger');
|
|
41
|
+
});
|
|
42
|
+
test('can request a tag for a property', (assert) => {
|
|
43
|
+
const obj = new F.Tom();
|
|
44
|
+
assert.strictEqual(obj.firstName, 'Tom');
|
|
45
|
+
const tag = validator_1.track(() => {
|
|
46
|
+
obj.firstName;
|
|
47
|
+
});
|
|
48
|
+
let snapshot = validator_1.valueForTag(tag);
|
|
49
|
+
assert.ok(validator_1.validateTag(tag, snapshot), 'tag should be valid to start');
|
|
50
|
+
obj.firstName = 'Edsger';
|
|
51
|
+
assert.strictEqual(validator_1.validateTag(tag, snapshot), false, 'tag is invalidated after property is set');
|
|
52
|
+
snapshot = validator_1.valueForTag(tag);
|
|
53
|
+
assert.strictEqual(validator_1.validateTag(tag, snapshot), true, 'tag is valid on the second check');
|
|
54
|
+
tags_1.assertValidAfterUnrelatedBump(tag, snapshot);
|
|
55
|
+
});
|
|
56
|
+
test('can request a tag from a frozen class instance', (assert) => {
|
|
57
|
+
const obj = Object.freeze(new F.Toran());
|
|
58
|
+
assert.strictEqual(obj.firstName, 'Toran');
|
|
59
|
+
assert.strictEqual(obj.lastName, 'Billups');
|
|
60
|
+
// Explicitly annotated tracked properties
|
|
61
|
+
let tag = validator_1.track(() => {
|
|
62
|
+
obj.firstName;
|
|
63
|
+
});
|
|
64
|
+
let snapshot = validator_1.valueForTag(tag);
|
|
65
|
+
assert.ok(validator_1.validateTag(tag, snapshot), 'tag should be valid to start');
|
|
66
|
+
snapshot = validator_1.valueForTag(tag);
|
|
67
|
+
assert.strictEqual(validator_1.validateTag(tag, snapshot), true, 'tag is still valid');
|
|
68
|
+
// Non-tracked data properties
|
|
69
|
+
tag = validator_1.track(() => {
|
|
70
|
+
obj.lastName;
|
|
71
|
+
});
|
|
72
|
+
snapshot = validator_1.valueForTag(tag);
|
|
73
|
+
assert.ok(validator_1.validateTag(tag, snapshot), 'tag should be valid to start');
|
|
74
|
+
snapshot = validator_1.valueForTag(tag);
|
|
75
|
+
assert.strictEqual(validator_1.validateTag(tag, snapshot), true, 'tag is still valid');
|
|
76
|
+
tags_1.assertValidAfterUnrelatedBump(tag, snapshot);
|
|
77
|
+
});
|
|
78
|
+
test('can request a tag from an instance of a frozen class', (assert) => {
|
|
79
|
+
const obj = Object.freeze(new F.FrozenToran());
|
|
80
|
+
assert.strictEqual(obj.firstName, 'Toran');
|
|
81
|
+
const tag = validator_1.track(() => {
|
|
82
|
+
obj.firstName;
|
|
83
|
+
});
|
|
84
|
+
let snapshot = validator_1.valueForTag(tag);
|
|
85
|
+
assert.ok(validator_1.validateTag(tag, snapshot), 'tag should be valid to start');
|
|
86
|
+
snapshot = validator_1.valueForTag(tag);
|
|
87
|
+
assert.strictEqual(validator_1.validateTag(tag, snapshot), true, 'tag is still valid');
|
|
88
|
+
tags_1.assertValidAfterUnrelatedBump(tag, snapshot);
|
|
89
|
+
});
|
|
90
|
+
test('can track a getter', (assert) => {
|
|
91
|
+
const obj = new F.PersonWithCount();
|
|
92
|
+
assert.strictEqual(obj.firstName, 'Tom0');
|
|
93
|
+
assert.strictEqual(obj.firstName, 'Tom1');
|
|
94
|
+
const tag = validator_1.track(() => {
|
|
95
|
+
obj.firstName;
|
|
96
|
+
});
|
|
97
|
+
let snapshot = validator_1.valueForTag(tag);
|
|
98
|
+
assert.ok(validator_1.validateTag(tag, snapshot), 'tag should be valid to start');
|
|
99
|
+
assert.strictEqual(obj.firstName, 'Tom3');
|
|
100
|
+
assert.ok(validator_1.validateTag(tag, snapshot), 'reading from property does not invalidate the tag');
|
|
101
|
+
obj.firstName = 'Edsger';
|
|
102
|
+
assert.strictEqual(validator_1.validateTag(tag, snapshot), false, 'tag is invalidated after property is set');
|
|
103
|
+
snapshot = validator_1.valueForTag(tag);
|
|
104
|
+
tags_1.assertValidAfterUnrelatedBump(tag, snapshot);
|
|
105
|
+
});
|
|
106
|
+
test('getters are invalidated when their dependencies are invalidated', (assert) => {
|
|
107
|
+
const obj = new F.PersonWithSalutation();
|
|
108
|
+
assert.strictEqual(obj.salutation, 'Hello, Tom Dale!', `the saluation field is valid`);
|
|
109
|
+
assert.strictEqual(obj.fullName, 'Tom Dale', `the fullName field is valid`);
|
|
110
|
+
const tag = validator_1.track(() => {
|
|
111
|
+
obj.salutation;
|
|
112
|
+
});
|
|
113
|
+
let snapshot = validator_1.valueForTag(tag);
|
|
114
|
+
assert.ok(validator_1.validateTag(tag, snapshot), 'tag should be valid to start');
|
|
115
|
+
obj.firstName = 'Edsger';
|
|
116
|
+
obj.lastName = 'Dijkstra';
|
|
117
|
+
assert.strictEqual(validator_1.validateTag(tag, snapshot), false, 'tag is invalidated after chained dependency is set');
|
|
118
|
+
assert.strictEqual(obj.fullName, 'Edsger Dijkstra');
|
|
119
|
+
assert.strictEqual(obj.salutation, 'Hello, Edsger Dijkstra!');
|
|
120
|
+
snapshot = validator_1.valueForTag(tag);
|
|
121
|
+
assert.strictEqual(validator_1.validateTag(tag, snapshot), true);
|
|
122
|
+
obj.fullName = 'Alan Kay';
|
|
123
|
+
assert.strictEqual(validator_1.validateTag(tag, snapshot), false, 'tag is invalidated after chained dependency is set');
|
|
124
|
+
assert.strictEqual(obj.fullName, 'Alan Kay');
|
|
125
|
+
assert.strictEqual(obj.firstName, 'Alan');
|
|
126
|
+
assert.strictEqual(obj.lastName, 'Kay');
|
|
127
|
+
assert.strictEqual(obj.salutation, 'Hello, Alan Kay!');
|
|
128
|
+
snapshot = validator_1.valueForTag(tag);
|
|
129
|
+
assert.strictEqual(validator_1.validateTag(tag, snapshot), true);
|
|
130
|
+
tags_1.assertValidAfterUnrelatedBump(tag, snapshot);
|
|
131
|
+
});
|
|
132
|
+
test('nested @tracked in multiple objects', (assert) => {
|
|
133
|
+
const obj = new F.Contact(new F.PersonForContact(), 'tom@example.com');
|
|
134
|
+
assert.strictEqual(obj.contact, 'Tom Dale @ tom@example.com', `the contact field is valid`);
|
|
135
|
+
assert.strictEqual(obj.person.fullName, 'Tom Dale', `the fullName field is valid`);
|
|
136
|
+
const person = obj.person;
|
|
137
|
+
const tag = validator_1.track(() => {
|
|
138
|
+
obj.contact;
|
|
139
|
+
});
|
|
140
|
+
let snapshot = validator_1.valueForTag(tag);
|
|
141
|
+
assert.ok(validator_1.validateTag(tag, snapshot), 'tag should be valid to start');
|
|
142
|
+
person.firstName = 'Edsger';
|
|
143
|
+
person.lastName = 'Dijkstra';
|
|
144
|
+
assert.strictEqual(validator_1.validateTag(tag, snapshot), false, 'tag is invalidated after nested dependency is set');
|
|
145
|
+
assert.strictEqual(person.fullName, 'Edsger Dijkstra');
|
|
146
|
+
assert.strictEqual(obj.contact, 'Edsger Dijkstra @ tom@example.com');
|
|
147
|
+
snapshot = validator_1.valueForTag(tag);
|
|
148
|
+
assert.strictEqual(validator_1.validateTag(tag, snapshot), true);
|
|
149
|
+
person.fullName = 'Alan Kay';
|
|
150
|
+
assert.strictEqual(validator_1.validateTag(tag, snapshot), false, 'tag is invalidated after chained dependency is set');
|
|
151
|
+
assert.strictEqual(person.fullName, 'Alan Kay');
|
|
152
|
+
assert.strictEqual(person.firstName, 'Alan');
|
|
153
|
+
assert.strictEqual(person.lastName, 'Kay');
|
|
154
|
+
assert.strictEqual(obj.contact, 'Alan Kay @ tom@example.com');
|
|
155
|
+
snapshot = validator_1.valueForTag(tag);
|
|
156
|
+
assert.strictEqual(validator_1.validateTag(tag, snapshot), true);
|
|
157
|
+
obj.email = 'alan@example.com';
|
|
158
|
+
assert.strictEqual(validator_1.validateTag(tag, snapshot), false, 'tag is invalidated after chained dependency is set');
|
|
159
|
+
assert.strictEqual(person.fullName, 'Alan Kay');
|
|
160
|
+
assert.strictEqual(person.firstName, 'Alan');
|
|
161
|
+
assert.strictEqual(person.lastName, 'Kay');
|
|
162
|
+
assert.strictEqual(obj.contact, 'Alan Kay @ alan@example.com');
|
|
163
|
+
snapshot = validator_1.valueForTag(tag);
|
|
164
|
+
assert.strictEqual(validator_1.validateTag(tag, snapshot), true);
|
|
165
|
+
tags_1.assertValidAfterUnrelatedBump(tag, snapshot);
|
|
166
|
+
});
|
|
167
|
+
if (env_1.DEBUG) {
|
|
168
|
+
test('Tracked decorator with a getter throws an error', (assert) => {
|
|
169
|
+
assert.throws(F.createClassWithTrackedGetter);
|
|
170
|
+
});
|
|
171
|
+
test('Tracked decorator with a setter throws an error', (assert) => {
|
|
172
|
+
assert.throws(F.createClassWithTrackedSetter);
|
|
173
|
+
});
|
|
174
|
+
test('Tracked decorator with arguments throws an error', function (assert) {
|
|
175
|
+
assert.throws(F.createClassWithTrackedDependentKeys, /@tracked\('firstName', 'lastName'\)/, 'the correct error is thrown');
|
|
176
|
+
});
|
|
177
|
+
test('Using @tracked as a decorator factory throws an error', function (assert) {
|
|
178
|
+
assert.throws(F.createClassWithTrackedAsDecoratorFactory, /@tracked\(\)/, 'The correct error is thrown');
|
|
179
|
+
});
|
|
180
|
+
}
|
|
181
|
+
});
|
|
182
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"tracked-decorator-test.js","sourceRoot":"","sources":["../../../../../packages/@glimmer/tracking/test/tracked-decorator-test.ts"],"names":[],"mappings":"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","sourcesContent":["/* tslint:disable:no-unused-expression */\nconst { test } = QUnit;\n\nimport { DEBUG } from '@glimmer/env';\nimport { track, valueForTag, validateTag } from '@glimmer/validator';\n\nimport * as TSFixtures from './fixtures/typescript';\n// eslint-disable-next-line @typescript-eslint/ban-ts-comment\n// @ts-ignore\nimport * as BabelFixtures from './fixtures/babel';\nimport { assertValidAfterUnrelatedBump } from './helpers/tags';\n\n[\n  ['Babel', BabelFixtures],\n  ['TypeScript', TSFixtures],\n].forEach(([compiler, F]) => {\n  QUnit.module(`[@glimmer/tracking] Tracked Property Decorators with ${compiler}`);\n\n  test('tracked properties can be read and written to', (assert) => {\n    const obj = new F.Tom();\n    assert.strictEqual(obj.firstName, 'Tom');\n    obj.firstName = 'Edsger';\n    assert.strictEqual(obj.firstName, 'Edsger');\n  });\n\n  test('can request a tag for a property', (assert) => {\n    const obj = new F.Tom();\n    assert.strictEqual(obj.firstName, 'Tom');\n\n    const tag = track(() => {\n      obj.firstName;\n    });\n    let snapshot = valueForTag(tag);\n    assert.ok(validateTag(tag, snapshot), 'tag should be valid to start');\n\n    obj.firstName = 'Edsger';\n    assert.strictEqual(\n      validateTag(tag, snapshot),\n      false,\n      'tag is invalidated after property is set'\n    );\n    snapshot = valueForTag(tag);\n    assert.strictEqual(validateTag(tag, snapshot), true, 'tag is valid on the second check');\n\n    assertValidAfterUnrelatedBump(tag, snapshot);\n  });\n\n  test('can request a tag from a frozen class instance', (assert) => {\n    const obj = Object.freeze(new F.Toran());\n    assert.strictEqual(obj.firstName, 'Toran');\n    assert.strictEqual(obj.lastName, 'Billups');\n\n    // Explicitly annotated tracked properties\n    let tag = track(() => {\n      obj.firstName;\n    });\n    let snapshot = valueForTag(tag);\n    assert.ok(validateTag(tag, snapshot), 'tag should be valid to start');\n    snapshot = valueForTag(tag);\n    assert.strictEqual(validateTag(tag, snapshot), true, 'tag is still valid');\n\n    // Non-tracked data properties\n    tag = track(() => {\n      obj.lastName;\n    });\n    snapshot = valueForTag(tag);\n    assert.ok(validateTag(tag, snapshot), 'tag should be valid to start');\n    snapshot = valueForTag(tag);\n    assert.strictEqual(validateTag(tag, snapshot), true, 'tag is still valid');\n\n    assertValidAfterUnrelatedBump(tag, snapshot);\n  });\n\n  test('can request a tag from an instance of a frozen class', (assert) => {\n    const obj = Object.freeze(new F.FrozenToran());\n\n    assert.strictEqual(obj.firstName, 'Toran');\n\n    const tag = track(() => {\n      obj.firstName;\n    });\n    let snapshot = valueForTag(tag);\n    assert.ok(validateTag(tag, snapshot), 'tag should be valid to start');\n    snapshot = valueForTag(tag);\n    assert.strictEqual(validateTag(tag, snapshot), true, 'tag is still valid');\n\n    assertValidAfterUnrelatedBump(tag, snapshot);\n  });\n\n  test('can track a getter', (assert) => {\n    const obj = new F.PersonWithCount();\n    assert.strictEqual(obj.firstName, 'Tom0');\n    assert.strictEqual(obj.firstName, 'Tom1');\n\n    const tag = track(() => {\n      obj.firstName;\n    });\n    let snapshot = valueForTag(tag);\n    assert.ok(validateTag(tag, snapshot), 'tag should be valid to start');\n\n    assert.strictEqual(obj.firstName, 'Tom3');\n    assert.ok(validateTag(tag, snapshot), 'reading from property does not invalidate the tag');\n\n    obj.firstName = 'Edsger';\n    assert.strictEqual(\n      validateTag(tag, snapshot),\n      false,\n      'tag is invalidated after property is set'\n    );\n    snapshot = valueForTag(tag);\n\n    assertValidAfterUnrelatedBump(tag, snapshot);\n  });\n\n  test('getters are invalidated when their dependencies are invalidated', (assert) => {\n    const obj = new F.PersonWithSalutation();\n    assert.strictEqual(obj.salutation, 'Hello, Tom Dale!', `the saluation field is valid`);\n    assert.strictEqual(obj.fullName, 'Tom Dale', `the fullName field is valid`);\n\n    const tag = track(() => {\n      obj.salutation;\n    });\n    let snapshot = valueForTag(tag);\n    assert.ok(validateTag(tag, snapshot), 'tag should be valid to start');\n\n    obj.firstName = 'Edsger';\n    obj.lastName = 'Dijkstra';\n    assert.strictEqual(\n      validateTag(tag, snapshot),\n      false,\n      'tag is invalidated after chained dependency is set'\n    );\n    assert.strictEqual(obj.fullName, 'Edsger Dijkstra');\n    assert.strictEqual(obj.salutation, 'Hello, Edsger Dijkstra!');\n\n    snapshot = valueForTag(tag);\n    assert.strictEqual(validateTag(tag, snapshot), true);\n\n    obj.fullName = 'Alan Kay';\n    assert.strictEqual(\n      validateTag(tag, snapshot),\n      false,\n      'tag is invalidated after chained dependency is set'\n    );\n    assert.strictEqual(obj.fullName, 'Alan Kay');\n    assert.strictEqual(obj.firstName, 'Alan');\n    assert.strictEqual(obj.lastName, 'Kay');\n    assert.strictEqual(obj.salutation, 'Hello, Alan Kay!');\n\n    snapshot = valueForTag(tag);\n    assert.strictEqual(validateTag(tag, snapshot), true);\n\n    assertValidAfterUnrelatedBump(tag, snapshot);\n  });\n\n  test('nested @tracked in multiple objects', (assert) => {\n    const obj = new F.Contact(new F.PersonForContact(), 'tom@example.com');\n    assert.strictEqual(obj.contact, 'Tom Dale @ tom@example.com', `the contact field is valid`);\n    assert.strictEqual(obj.person.fullName, 'Tom Dale', `the fullName field is valid`);\n    const person = obj.person;\n\n    const tag = track(() => {\n      obj.contact;\n    });\n    let snapshot = valueForTag(tag);\n    assert.ok(validateTag(tag, snapshot), 'tag should be valid to start');\n\n    person.firstName = 'Edsger';\n    person.lastName = 'Dijkstra';\n    assert.strictEqual(\n      validateTag(tag, snapshot),\n      false,\n      'tag is invalidated after nested dependency is set'\n    );\n    assert.strictEqual(person.fullName, 'Edsger Dijkstra');\n    assert.strictEqual(obj.contact, 'Edsger Dijkstra @ tom@example.com');\n\n    snapshot = valueForTag(tag);\n    assert.strictEqual(validateTag(tag, snapshot), true);\n\n    person.fullName = 'Alan Kay';\n    assert.strictEqual(\n      validateTag(tag, snapshot),\n      false,\n      'tag is invalidated after chained dependency is set'\n    );\n    assert.strictEqual(person.fullName, 'Alan Kay');\n    assert.strictEqual(person.firstName, 'Alan');\n    assert.strictEqual(person.lastName, 'Kay');\n    assert.strictEqual(obj.contact, 'Alan Kay @ tom@example.com');\n\n    snapshot = valueForTag(tag);\n    assert.strictEqual(validateTag(tag, snapshot), true);\n\n    obj.email = 'alan@example.com';\n    assert.strictEqual(\n      validateTag(tag, snapshot),\n      false,\n      'tag is invalidated after chained dependency is set'\n    );\n    assert.strictEqual(person.fullName, 'Alan Kay');\n    assert.strictEqual(person.firstName, 'Alan');\n    assert.strictEqual(person.lastName, 'Kay');\n    assert.strictEqual(obj.contact, 'Alan Kay @ alan@example.com');\n\n    snapshot = valueForTag(tag);\n    assert.strictEqual(validateTag(tag, snapshot), true);\n\n    assertValidAfterUnrelatedBump(tag, snapshot);\n  });\n\n  if (DEBUG) {\n    test('Tracked decorator with a getter throws an error', (assert) => {\n      assert.throws(F.createClassWithTrackedGetter);\n    });\n\n    test('Tracked decorator with a setter throws an error', (assert) => {\n      assert.throws(F.createClassWithTrackedSetter);\n    });\n\n    test('Tracked decorator with arguments throws an error', function (assert) {\n      assert.throws(\n        F.createClassWithTrackedDependentKeys,\n        /@tracked\\('firstName', 'lastName'\\)/,\n        'the correct error is thrown'\n      );\n    });\n\n    test('Using @tracked as a decorator factory throws an error', function (assert) {\n      assert.throws(\n        F.createClassWithTrackedAsDecoratorFactory,\n        /@tracked\\(\\)/,\n        'The correct error is thrown'\n      );\n    });\n  }\n});\n"]}
|
|
@@ -0,0 +1,3 @@
|
|
|
1
|
+
export { cached } from './src/cached';
|
|
2
|
+
export { tracked } from './src/tracked';
|
|
3
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9wYWNrYWdlcy9AZ2xpbW1lci90cmFja2luZy9pbmRleC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsTUFBTSxFQUFFLE1BQU0sY0FBYyxDQUFDO0FBQ3RDLE9BQU8sRUFBRSxPQUFPLEVBQUUsTUFBTSxlQUFlLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgeyBjYWNoZWQgfSBmcm9tICcuL3NyYy9jYWNoZWQnO1xuZXhwb3J0IHsgdHJhY2tlZCB9IGZyb20gJy4vc3JjL3RyYWNrZWQnO1xuIl19
|
|
@@ -0,0 +1,58 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* @decorator
|
|
3
|
+
*
|
|
4
|
+
* The `@cached` decorator can be used on getters in order to cache the return
|
|
5
|
+
* value of the getter. This is useful when a getter is expensive and used very
|
|
6
|
+
* often.
|
|
7
|
+
*
|
|
8
|
+
*
|
|
9
|
+
* @example
|
|
10
|
+
*
|
|
11
|
+
* in this guest list class, we have the `sortedGuests`
|
|
12
|
+
* getter that sorts the guests alphabetically:
|
|
13
|
+
*
|
|
14
|
+
* ```js
|
|
15
|
+
* import { tracked } from '@norith/glimmer-tracking';
|
|
16
|
+
*
|
|
17
|
+
* class GuestList {
|
|
18
|
+
* @tracked guests = ['Zoey', 'Tomster'];
|
|
19
|
+
*
|
|
20
|
+
* get sortedGuests() {
|
|
21
|
+
* return this.guests.slice().sort()
|
|
22
|
+
* }
|
|
23
|
+
* }
|
|
24
|
+
* ```
|
|
25
|
+
*
|
|
26
|
+
* Every time `sortedGuests` is accessed, a new array will be created and sorted,
|
|
27
|
+
* because JavaScript getters do not cache by default. When the guest list is
|
|
28
|
+
* small, like the one in the example, this is not a problem. However, if the guest
|
|
29
|
+
* list were to grow very large, it would mean that we would be doing a large
|
|
30
|
+
* amount of work each time we accessed `sortedGetters`. With `@cached`, we can
|
|
31
|
+
* cache the value instead:
|
|
32
|
+
*
|
|
33
|
+
* ```js
|
|
34
|
+
* import { tracked, cached } from '@norith/glimmer-tracking';
|
|
35
|
+
*
|
|
36
|
+
* class GuestList {
|
|
37
|
+
* @tracked guests = ['Zoey', 'Tomster'];
|
|
38
|
+
*
|
|
39
|
+
* @cached
|
|
40
|
+
* get sortedGuests() {
|
|
41
|
+
* return this.guests.slice().sort()
|
|
42
|
+
* }
|
|
43
|
+
* }
|
|
44
|
+
* ```
|
|
45
|
+
*
|
|
46
|
+
* Now the `sortedGuests` getter will be cached based on _autotracking_. It will
|
|
47
|
+
* only rerun and create a new sorted array when the `guests` tracked property is
|
|
48
|
+
* updated.
|
|
49
|
+
*
|
|
50
|
+
* In general, you should avoid using `@cached` unless you have confirmed that the
|
|
51
|
+
* getter you are decorating is computationally expensive. `@cached` adds a small
|
|
52
|
+
* amount of overhead to the getter, making it more expensive. While this overhead
|
|
53
|
+
* is small, if `@cached` is overused it can add up to a large impact overall in
|
|
54
|
+
* your app. Many getters and tracked properties are only accessed once, rendered,
|
|
55
|
+
* and then never rerendered, so adding `@cached` when it is unnecessary can
|
|
56
|
+
* negatively impact performance.
|
|
57
|
+
*/
|
|
58
|
+
export declare const cached: PropertyDecorator;
|