@ember-data/tracking 5.4.0-beta.1 → 5.4.0-beta.2

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/addon/-private.js CHANGED
@@ -1,22 +1,9 @@
1
+ import { tagForProperty } from '@ember/-internals/metal';
2
+ import { consumeTag, dirtyTag } from '@glimmer/validator';
1
3
  import { macroCondition, getOwnConfig } from '@embroider/macros';
2
-
3
- /**
4
- * This package provides primitives that allow powerful low-level
5
- * adjustments to change tracking notification behaviors.
6
- *
7
- * Typically you want to use these primitives when you want to divorce
8
- * property accesses on EmberData provided objects from the current
9
- * tracking context. Typically this sort of thing occurs when serializing
10
- * tracked data to send in a request: the data itself is often ancillary
11
- * to the thing which triggered the request in the first place and you
12
- * would not want to re-trigger the request for any update to the data.
13
- *
14
- * @module @ember-data/tracking
15
- * @main @ember-data/tracking
16
- */
17
4
  let TRANSACTION = null;
18
5
  function createTransaction() {
19
- let transaction = {
6
+ const transaction = {
20
7
  cbs: new Set(),
21
8
  props: new Set(),
22
9
  sub: new Set(),
@@ -27,9 +14,37 @@ function createTransaction() {
27
14
  }
28
15
  TRANSACTION = transaction;
29
16
  }
17
+ function maybeConsume(tag) {
18
+ if (tag) {
19
+ consumeTag(tag);
20
+ }
21
+ }
22
+ function maybeDirty(tag) {
23
+ if (tag) {
24
+ // @ts-expect-error - we are using Ember's Tag not Glimmer's
25
+ dirtyTag(tag);
26
+ }
27
+ }
28
+
29
+ /**
30
+ * If there is a current transaction, ensures that the relevant tag (and any
31
+ * array computed chains symbols, if applicable) will be consumed during the
32
+ * transaction.
33
+ *
34
+ * If there is no current transaction, will consume the tag(s) immediately.
35
+ *
36
+ * @internal
37
+ * @param obj
38
+ */
30
39
  function subscribe(obj) {
31
40
  if (TRANSACTION) {
32
41
  TRANSACTION.sub.add(obj);
42
+ } else if ('tag' in obj) {
43
+ if (macroCondition(getOwnConfig().deprecations.DEPRECATE_COMPUTED_CHAINS)) {
44
+ maybeConsume(obj['[]']);
45
+ maybeConsume(obj['@length']);
46
+ }
47
+ consumeTag(obj.tag);
33
48
  } else {
34
49
  obj.ref;
35
50
  }
@@ -37,20 +52,23 @@ function subscribe(obj) {
37
52
  function updateRef(obj) {
38
53
  if (macroCondition(getOwnConfig().env.DEBUG)) {
39
54
  try {
40
- obj.ref = null;
55
+ if ('tag' in obj) {
56
+ if (macroCondition(getOwnConfig().deprecations.DEPRECATE_COMPUTED_CHAINS)) {
57
+ maybeDirty(obj['[]']);
58
+ maybeDirty(obj['@length']);
59
+ }
60
+ // @ts-expect-error - we are using Ember's Tag not Glimmer's
61
+ dirtyTag(obj.tag);
62
+ } else {
63
+ obj.ref = null;
64
+ }
41
65
  } catch (e) {
42
66
  if (e instanceof Error) {
43
- if (e.message.includes('You attempted to update `ref` on `Tag`')) {
44
- e.message = e.message.replace('You attempted to update `ref` on `Tag`',
67
+ if (e.message.includes('You attempted to update `undefined`')) {
45
68
  // @ts-expect-error
46
- `You attempted to update <${obj._debug_base}>.${obj._debug_prop}` // eslint-disable-line
47
- );
48
-
49
- e.stack = e.stack?.replace('You attempted to update `ref` on `Tag`',
50
- // @ts-expect-error
51
- `You attempted to update <${obj._debug_base}>.${obj._debug_prop}` // eslint-disable-line
52
- );
53
-
69
+ const key = `<${obj._debug_base}>.${obj.key}`;
70
+ e.message = e.message.replace('You attempted to update `undefined`', `You attempted to update ${key}`);
71
+ e.stack = e.stack?.replace('You attempted to update `undefined`', `You attempted to update ${key}`);
54
72
  const lines = e.stack?.split(`\n`);
55
73
  const finalLines = [];
56
74
  let lastFile = null;
@@ -73,20 +91,29 @@ function updateRef(obj) {
73
91
  finalLines.push(line);
74
92
  }
75
93
  });
76
- const splitstr = '`ref` was first used:';
94
+ const splitstr = '`undefined` was first used:';
77
95
  const parts = e.message.split(splitstr);
78
- parts.splice(1, 0, `Original Stack\n=============\n${finalLines.join(`\n`)}\n\n${splitstr}`);
96
+ parts.splice(1, 0, `Original Stack\n=============\n${finalLines.join(`\n`)}\n\n\`${key}\` was first used:`);
79
97
  e.message = parts.join('');
80
98
  }
81
99
  }
82
100
  throw e;
83
101
  }
84
102
  } else {
85
- obj.ref = null;
103
+ if ('tag' in obj) {
104
+ if (macroCondition(getOwnConfig().deprecations.DEPRECATE_COMPUTED_CHAINS)) {
105
+ maybeDirty(obj['[]']);
106
+ maybeDirty(obj['@length']);
107
+ }
108
+ // @ts-expect-error - we are using Ember's Tag not Glimmer's
109
+ dirtyTag(obj.tag);
110
+ } else {
111
+ obj.ref = null;
112
+ }
86
113
  }
87
114
  }
88
115
  function flushTransaction() {
89
- let transaction = TRANSACTION;
116
+ const transaction = TRANSACTION;
90
117
  TRANSACTION = transaction.parent;
91
118
  transaction.cbs.forEach(cb => {
92
119
  cb();
@@ -97,11 +124,19 @@ function flushTransaction() {
97
124
  updateRef(obj);
98
125
  });
99
126
  transaction.sub.forEach(obj => {
100
- obj.ref;
127
+ if ('tag' in obj) {
128
+ if (macroCondition(getOwnConfig().deprecations.DEPRECATE_COMPUTED_CHAINS)) {
129
+ maybeConsume(obj['[]']);
130
+ maybeConsume(obj['@length']);
131
+ }
132
+ consumeTag(obj.tag);
133
+ } else {
134
+ obj.ref;
135
+ }
101
136
  });
102
137
  }
103
138
  async function untrack() {
104
- let transaction = TRANSACTION;
139
+ const transaction = TRANSACTION;
105
140
  TRANSACTION = transaction.parent;
106
141
 
107
142
  // defer writes
@@ -144,7 +179,7 @@ function addTransactionCB(method) {
144
179
  * @static
145
180
  * @for @ember-data/tracking
146
181
  * @param method
147
- * @returns result of invoking method
182
+ * @return result of invoking method
148
183
  */
149
184
  function untracked(method) {
150
185
  createTransaction();
@@ -167,7 +202,7 @@ function untracked(method) {
167
202
  * @static
168
203
  * @for @ember-data/tracking
169
204
  * @param method
170
- * @returns result of invoking method
205
+ * @return result of invoking method
171
206
  */
172
207
  function transact(method) {
173
208
  createTransaction();
@@ -186,7 +221,7 @@ function transact(method) {
186
221
  * @static
187
222
  * @for @ember-data/tracking
188
223
  * @param method
189
- * @returns a function that will invoke method in a transaction with any provided args and return its result
224
+ * @return a function that will invoke method in a transaction with any provided args and return its result
190
225
  */
191
226
  function memoTransact(method) {
192
227
  return function (...args) {
@@ -196,4 +231,142 @@ function memoTransact(method) {
196
231
  return ret;
197
232
  };
198
233
  }
199
- export { addToTransaction, addTransactionCB, memoTransact, subscribe, transact, untracked };
234
+ const Signals = Symbol('Signals');
235
+
236
+ /**
237
+ * use to add a signal property to the prototype of something.
238
+ *
239
+ * First arg is the thing to define on
240
+ * Second arg is the property name
241
+ * Third agg is the initial value of the property if any.
242
+ *
243
+ * for instance
244
+ *
245
+ * ```ts
246
+ * class Model {}
247
+ * defineSignal(Model.prototype, 'isLoading', false);
248
+ * ```
249
+ *
250
+ * This is sort of like using a stage-3 decorator but works today
251
+ * while we are still on legacy decorators.
252
+ *
253
+ * e.g. it is equivalent to
254
+ *
255
+ * ```ts
256
+ * class Model {
257
+ * @signal accessor isLoading = false;
258
+ * }
259
+ * ```
260
+ *
261
+ * @internal
262
+ */
263
+ function defineSignal(obj, key, v) {
264
+ Object.defineProperty(obj, key, {
265
+ enumerable: true,
266
+ configurable: false,
267
+ get() {
268
+ const signals = this[Signals] = this[Signals] || new Map();
269
+ const existing = signals.has(key);
270
+ const _signal = entangleSignal(signals, this, key);
271
+ if (!existing && v !== undefined) {
272
+ _signal.lastValue = v;
273
+ }
274
+ return _signal.lastValue;
275
+ },
276
+ set(value) {
277
+ const signals = this[Signals] = this[Signals] || new Map();
278
+ let _signal = signals.get(key);
279
+ if (!_signal) {
280
+ _signal = createSignal(this, key);
281
+ signals.set(key, _signal);
282
+ }
283
+ if (_signal.lastValue !== value) {
284
+ _signal.lastValue = value;
285
+ addToTransaction(_signal);
286
+ }
287
+ }
288
+ });
289
+ }
290
+ function createArrayTags(obj, signal) {
291
+ if (macroCondition(getOwnConfig().deprecations.DEPRECATE_COMPUTED_CHAINS)) {
292
+ signal['[]'] = tagForProperty(obj, '[]');
293
+ signal['@length'] = tagForProperty(obj, 'length');
294
+ }
295
+ }
296
+
297
+ /**
298
+ * Create a signal for the key/object pairing.
299
+ *
300
+ * @internal
301
+ * @param obj Object we're creating the signal on
302
+ * @param key Key to create the signal for
303
+ * @return the signal
304
+ */
305
+ function createSignal(obj, key) {
306
+ const _signal = {
307
+ key,
308
+ tag: tagForProperty(obj, key),
309
+ t: false,
310
+ shouldReset: false,
311
+ '[]': null,
312
+ '@length': null,
313
+ lastValue: undefined
314
+ };
315
+ if (macroCondition(getOwnConfig().env.DEBUG)) {
316
+ // eslint-disable-next-line no-inner-declarations
317
+ function tryGet(prop) {
318
+ try {
319
+ return obj[prop];
320
+ } catch {
321
+ return;
322
+ }
323
+ }
324
+ const modelName = tryGet('$type') ?? tryGet('modelName') ?? tryGet('constructor')?.modelName ?? '';
325
+ // eslint-disable-next-line @typescript-eslint/no-base-to-string
326
+ const className = obj.constructor?.name ?? obj.toString?.() ?? 'unknown';
327
+ _signal._debug_base = `${className}${modelName && !className.startsWith('SchemaRecord') ? `:${modelName}` : ''}`;
328
+ }
329
+ return _signal;
330
+ }
331
+
332
+ /**
333
+ * Create a signal for the key/object pairing and subscribes to the signal.
334
+ *
335
+ * Use when you need to ensure a signal exists and is subscribed to.
336
+ *
337
+ * @internal
338
+ * @param signals Map of signals
339
+ * @param obj Object we're creating the signal on
340
+ * @param key Key to create the signal for
341
+ * @return the signal
342
+ */
343
+ function entangleSignal(signals, obj, key) {
344
+ let _signal = signals.get(key);
345
+ if (!_signal) {
346
+ _signal = createSignal(obj, key);
347
+ signals.set(key, _signal);
348
+ }
349
+ subscribe(_signal);
350
+ return _signal;
351
+ }
352
+ function getSignal(obj, key, initialState) {
353
+ let signals = obj[Signals];
354
+ if (!signals) {
355
+ signals = new Map();
356
+ obj[Signals] = signals;
357
+ }
358
+ let _signal = signals.get(key);
359
+ if (!_signal) {
360
+ _signal = createSignal(obj, key);
361
+ _signal.shouldReset = initialState;
362
+ signals.set(key, _signal);
363
+ }
364
+ return _signal;
365
+ }
366
+ function peekSignal(obj, key) {
367
+ const signals = obj[Signals];
368
+ if (signals) {
369
+ return signals.get(key);
370
+ }
371
+ }
372
+ export { Signals, addToTransaction, addTransactionCB, createArrayTags, createSignal, defineSignal, entangleSignal, getSignal, memoTransact, peekSignal, subscribe, transact, untracked };
@@ -1 +1 @@
1
- {"version":3,"file":"-private.js","sources":["../src/-private.ts"],"sourcesContent":["import { DEBUG } from '@ember-data/env';\n\n/**\n * This package provides primitives that allow powerful low-level\n * adjustments to change tracking notification behaviors.\n *\n * Typically you want to use these primitives when you want to divorce\n * property accesses on EmberData provided objects from the current\n * tracking context. Typically this sort of thing occurs when serializing\n * tracked data to send in a request: the data itself is often ancillary\n * to the thing which triggered the request in the first place and you\n * would not want to re-trigger the request for any update to the data.\n *\n * @module @ember-data/tracking\n * @main @ember-data/tracking\n */\ntype OpaqueFn = (...args: unknown[]) => unknown;\ntype Tag = { ref: null; t: boolean };\ntype Transaction = {\n cbs: Set<OpaqueFn>;\n props: Set<Tag>;\n sub: Set<Tag>;\n parent: Transaction | null;\n};\nlet TRANSACTION: Transaction | null = null;\n\nfunction createTransaction() {\n let transaction: Transaction = {\n cbs: new Set(),\n props: new Set(),\n sub: new Set(),\n parent: null,\n };\n if (TRANSACTION) {\n transaction.parent = TRANSACTION;\n }\n TRANSACTION = transaction;\n}\n\nexport function subscribe(obj: Tag): void {\n if (TRANSACTION) {\n TRANSACTION.sub.add(obj);\n } else {\n obj.ref;\n }\n}\n\nfunction updateRef(obj: Tag): void {\n if (DEBUG) {\n try {\n obj.ref = null;\n } catch (e: unknown) {\n if (e instanceof Error) {\n if (e.message.includes('You attempted to update `ref` on `Tag`')) {\n e.message = e.message.replace(\n 'You attempted to update `ref` on `Tag`',\n // @ts-expect-error\n `You attempted to update <${obj._debug_base}>.${obj._debug_prop}` // eslint-disable-line\n );\n e.stack = e.stack?.replace(\n 'You attempted to update `ref` on `Tag`',\n // @ts-expect-error\n `You attempted to update <${obj._debug_base}>.${obj._debug_prop}` // eslint-disable-line\n );\n\n const lines = e.stack?.split(`\\n`);\n const finalLines: string[] = [];\n let lastFile: string | null = null;\n\n lines?.forEach((line) => {\n if (line.trim().startsWith('at ')) {\n // get the last string in the line which contains the code source location\n const location = line.split(' ').at(-1)!;\n // remove the line and char offset info\n\n if (location.includes(':')) {\n const parts = location.split(':');\n parts.pop();\n parts.pop();\n const file = parts.join(':');\n if (file !== lastFile) {\n lastFile = file;\n finalLines.push('');\n }\n }\n finalLines.push(line);\n }\n });\n\n const splitstr = '`ref` was first used:';\n const parts = e.message.split(splitstr);\n parts.splice(1, 0, `Original Stack\\n=============\\n${finalLines.join(`\\n`)}\\n\\n${splitstr}`);\n\n e.message = parts.join('');\n }\n }\n throw e;\n }\n } else {\n obj.ref = null;\n }\n}\n\nfunction flushTransaction() {\n let transaction = TRANSACTION!;\n TRANSACTION = transaction.parent;\n transaction.cbs.forEach((cb) => {\n cb();\n });\n transaction.props.forEach((obj: Tag) => {\n // mark this mutation as part of a transaction\n obj.t = true;\n updateRef(obj);\n });\n transaction.sub.forEach((obj: Tag) => {\n obj.ref;\n });\n}\nasync function untrack() {\n let transaction = TRANSACTION!;\n TRANSACTION = transaction.parent;\n\n // defer writes\n await Promise.resolve();\n transaction.cbs.forEach((cb) => {\n cb();\n });\n transaction.props.forEach((obj: Tag) => {\n // mark this mutation as part of a transaction\n obj.t = true;\n updateRef(obj);\n });\n}\n\nexport function addToTransaction(obj: Tag): void {\n if (TRANSACTION) {\n TRANSACTION.props.add(obj);\n } else {\n updateRef(obj);\n }\n}\nexport function addTransactionCB(method: OpaqueFn): void {\n if (TRANSACTION) {\n TRANSACTION.cbs.add(method);\n } else {\n method();\n }\n}\n\n/**\n * Run `method` without subscribing to any tracked properties\n * controlled by EmberData.\n *\n * This should rarely be used except by libraries that really\n * know what they are doing. It is most useful for wrapping\n * certain kinds of fetch/query logic from within a `Resource`\n * `hook` or other similar pattern.\n *\n * @function untracked\n * @public\n * @static\n * @for @ember-data/tracking\n * @param method\n * @returns result of invoking method\n */\nexport function untracked<T extends OpaqueFn>(method: T): ReturnType<T> {\n createTransaction();\n const ret = method();\n void untrack();\n return ret as ReturnType<T>;\n}\n\n/**\n * Run the method, subscribing to any tracked properties\n * managed by EmberData that were accessed or written during\n * the method's execution as per-normal but while allowing\n * interleaving of reads and writes.\n *\n * This is useful when for instance you want to perform\n * a mutation based on existing state that must be read first.\n *\n * @function transact\n * @public\n * @static\n * @for @ember-data/tracking\n * @param method\n * @returns result of invoking method\n */\nexport function transact<T extends OpaqueFn>(method: T): ReturnType<T> {\n createTransaction();\n const ret = method();\n flushTransaction();\n return ret as ReturnType<T>;\n}\n\n/**\n * A helpful utility for creating a new function that\n * always runs in a transaction. E.G. this \"memoizes\"\n * calling `transact(fn)`, currying args as necessary.\n *\n * @method memoTransact\n * @public\n * @static\n * @for @ember-data/tracking\n * @param method\n * @returns a function that will invoke method in a transaction with any provided args and return its result\n */\nexport function memoTransact<T extends OpaqueFn>(method: T): (...args: unknown[]) => ReturnType<T> {\n return function (...args: unknown[]) {\n createTransaction();\n const ret = method(...args);\n flushTransaction();\n return ret as ReturnType<T>;\n };\n}\n"],"names":["TRANSACTION","createTransaction","transaction","cbs","Set","props","sub","parent","subscribe","obj","add","ref","updateRef","macroCondition","getOwnConfig","env","DEBUG","e","Error","message","includes","replace","_debug_base","_debug_prop","stack","lines","split","finalLines","lastFile","forEach","line","trim","startsWith","location","at","parts","pop","file","join","push","splitstr","splice","flushTransaction","cb","t","untrack","Promise","resolve","addToTransaction","addTransactionCB","method","untracked","ret","transact","memoTransact","args"],"mappings":"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"}
1
+ {"version":3,"file":"-private.js","sources":["../src/-private.ts"],"sourcesContent":["import { tagForProperty } from '@ember/-internals/metal';\nimport { consumeTag, dirtyTag } from '@glimmer/validator';\n\nimport { DEPRECATE_COMPUTED_CHAINS } from '@ember-data/deprecations';\nimport { DEBUG } from '@ember-data/env';\n\n/**\n * This package provides primitives that allow powerful low-level\n * adjustments to change tracking notification behaviors.\n *\n * Typically you want to use these primitives when you want to divorce\n * property accesses on EmberData provided objects from the current\n * tracking context. Typically this sort of thing occurs when serializing\n * tracked data to send in a request: the data itself is often ancillary\n * to the thing which triggered the request in the first place and you\n * would not want to re-trigger the request for any update to the data.\n *\n * @module @ember-data/tracking\n * @main @ember-data/tracking\n */\ntype OpaqueFn = (...args: unknown[]) => unknown;\ntype Tag = { ref: null; t: boolean };\ntype Transaction = {\n cbs: Set<OpaqueFn>;\n props: Set<Tag | Signal>;\n sub: Set<Tag | Signal>;\n parent: Transaction | null;\n};\nlet TRANSACTION: Transaction | null = null;\n\nfunction createTransaction() {\n const transaction: Transaction = {\n cbs: new Set(),\n props: new Set(),\n sub: new Set(),\n parent: null,\n };\n if (TRANSACTION) {\n transaction.parent = TRANSACTION;\n }\n TRANSACTION = transaction;\n}\n\nfunction maybeConsume(tag: ReturnType<typeof tagForProperty> | null): void {\n if (tag) {\n consumeTag(tag);\n }\n}\n\nfunction maybeDirty(tag: ReturnType<typeof tagForProperty> | null): void {\n if (tag) {\n // @ts-expect-error - we are using Ember's Tag not Glimmer's\n dirtyTag(tag);\n }\n}\n\n/**\n * If there is a current transaction, ensures that the relevant tag (and any\n * array computed chains symbols, if applicable) will be consumed during the\n * transaction.\n *\n * If there is no current transaction, will consume the tag(s) immediately.\n *\n * @internal\n * @param obj\n */\nexport function subscribe(obj: Tag | Signal): void {\n if (TRANSACTION) {\n TRANSACTION.sub.add(obj);\n } else if ('tag' in obj) {\n if (DEPRECATE_COMPUTED_CHAINS) {\n maybeConsume(obj['[]']);\n maybeConsume(obj['@length']);\n }\n consumeTag(obj.tag);\n } else {\n obj.ref;\n }\n}\n\nfunction updateRef(obj: Tag | Signal): void {\n if (DEBUG) {\n try {\n if ('tag' in obj) {\n if (DEPRECATE_COMPUTED_CHAINS) {\n maybeDirty(obj['[]']);\n maybeDirty(obj['@length']);\n }\n // @ts-expect-error - we are using Ember's Tag not Glimmer's\n dirtyTag(obj.tag);\n } else {\n obj.ref = null;\n }\n } catch (e: unknown) {\n if (e instanceof Error) {\n if (e.message.includes('You attempted to update `undefined`')) {\n // @ts-expect-error\n const key = `<${obj._debug_base}>.${obj.key}`;\n e.message = e.message.replace('You attempted to update `undefined`', `You attempted to update ${key}`);\n e.stack = e.stack?.replace('You attempted to update `undefined`', `You attempted to update ${key}`);\n\n const lines = e.stack?.split(`\\n`);\n const finalLines: string[] = [];\n let lastFile: string | null = null;\n\n lines?.forEach((line) => {\n if (line.trim().startsWith('at ')) {\n // get the last string in the line which contains the code source location\n const location = line.split(' ').at(-1)!;\n // remove the line and char offset info\n\n if (location.includes(':')) {\n const parts = location.split(':');\n parts.pop();\n parts.pop();\n const file = parts.join(':');\n if (file !== lastFile) {\n lastFile = file;\n finalLines.push('');\n }\n }\n finalLines.push(line);\n }\n });\n\n const splitstr = '`undefined` was first used:';\n const parts = e.message.split(splitstr);\n parts.splice(1, 0, `Original Stack\\n=============\\n${finalLines.join(`\\n`)}\\n\\n\\`${key}\\` was first used:`);\n\n e.message = parts.join('');\n }\n }\n throw e;\n }\n } else {\n if ('tag' in obj) {\n if (DEPRECATE_COMPUTED_CHAINS) {\n maybeDirty(obj['[]']);\n maybeDirty(obj['@length']);\n }\n // @ts-expect-error - we are using Ember's Tag not Glimmer's\n dirtyTag(obj.tag);\n } else {\n obj.ref = null;\n }\n }\n}\n\nfunction flushTransaction() {\n const transaction = TRANSACTION!;\n TRANSACTION = transaction.parent;\n transaction.cbs.forEach((cb) => {\n cb();\n });\n transaction.props.forEach((obj) => {\n // mark this mutation as part of a transaction\n obj.t = true;\n updateRef(obj);\n });\n transaction.sub.forEach((obj) => {\n if ('tag' in obj) {\n if (DEPRECATE_COMPUTED_CHAINS) {\n maybeConsume(obj['[]']);\n maybeConsume(obj['@length']);\n }\n consumeTag(obj.tag);\n } else {\n obj.ref;\n }\n });\n}\nasync function untrack() {\n const transaction = TRANSACTION!;\n TRANSACTION = transaction.parent;\n\n // defer writes\n await Promise.resolve();\n transaction.cbs.forEach((cb) => {\n cb();\n });\n transaction.props.forEach((obj) => {\n // mark this mutation as part of a transaction\n obj.t = true;\n updateRef(obj);\n });\n}\n\nexport function addToTransaction(obj: Tag | Signal): void {\n if (TRANSACTION) {\n TRANSACTION.props.add(obj);\n } else {\n updateRef(obj);\n }\n}\nexport function addTransactionCB(method: OpaqueFn): void {\n if (TRANSACTION) {\n TRANSACTION.cbs.add(method);\n } else {\n method();\n }\n}\n\n/**\n * Run `method` without subscribing to any tracked properties\n * controlled by EmberData.\n *\n * This should rarely be used except by libraries that really\n * know what they are doing. It is most useful for wrapping\n * certain kinds of fetch/query logic from within a `Resource`\n * `hook` or other similar pattern.\n *\n * @function untracked\n * @public\n * @static\n * @for @ember-data/tracking\n * @param method\n * @return result of invoking method\n */\nexport function untracked<T extends OpaqueFn>(method: T): ReturnType<T> {\n createTransaction();\n const ret = method();\n void untrack();\n return ret as ReturnType<T>;\n}\n\n/**\n * Run the method, subscribing to any tracked properties\n * managed by EmberData that were accessed or written during\n * the method's execution as per-normal but while allowing\n * interleaving of reads and writes.\n *\n * This is useful when for instance you want to perform\n * a mutation based on existing state that must be read first.\n *\n * @function transact\n * @public\n * @static\n * @for @ember-data/tracking\n * @param method\n * @return result of invoking method\n */\nexport function transact<T extends OpaqueFn>(method: T): ReturnType<T> {\n createTransaction();\n const ret = method();\n flushTransaction();\n return ret as ReturnType<T>;\n}\n\n/**\n * A helpful utility for creating a new function that\n * always runs in a transaction. E.G. this \"memoizes\"\n * calling `transact(fn)`, currying args as necessary.\n *\n * @method memoTransact\n * @public\n * @static\n * @for @ember-data/tracking\n * @param method\n * @return a function that will invoke method in a transaction with any provided args and return its result\n */\nexport function memoTransact<T extends OpaqueFn>(method: T): (...args: unknown[]) => ReturnType<T> {\n return function (...args: unknown[]) {\n createTransaction();\n const ret = method(...args);\n flushTransaction();\n return ret as ReturnType<T>;\n };\n}\n\nexport const Signals = Symbol('Signals');\n\n/**\n * use to add a signal property to the prototype of something.\n *\n * First arg is the thing to define on\n * Second arg is the property name\n * Third agg is the initial value of the property if any.\n *\n * for instance\n *\n * ```ts\n * class Model {}\n * defineSignal(Model.prototype, 'isLoading', false);\n * ```\n *\n * This is sort of like using a stage-3 decorator but works today\n * while we are still on legacy decorators.\n *\n * e.g. it is equivalent to\n *\n * ```ts\n * class Model {\n * @signal accessor isLoading = false;\n * }\n * ```\n *\n * @internal\n */\nexport function defineSignal<T extends object>(obj: T, key: string, v?: unknown) {\n Object.defineProperty(obj, key, {\n enumerable: true,\n configurable: false,\n get(this: T & { [Signals]: Map<string, Signal> }) {\n const signals = (this[Signals] = this[Signals] || new Map());\n const existing = signals.has(key);\n const _signal = entangleSignal(signals, this, key);\n if (!existing && v !== undefined) {\n _signal.lastValue = v;\n }\n return _signal.lastValue;\n },\n set(this: T & { [Signals]: Map<string, Signal> }, value: unknown) {\n const signals = (this[Signals] = this[Signals] || new Map());\n let _signal = signals.get(key);\n if (!_signal) {\n _signal = createSignal(this, key);\n signals.set(key, _signal);\n }\n if (_signal.lastValue !== value) {\n _signal.lastValue = value;\n addToTransaction(_signal);\n }\n },\n });\n}\n\nexport interface Signal {\n /**\n * Key on the associated object\n * @internal\n */\n key: string;\n _debug_base?: string;\n\n /**\n * Whether this signal is part of an active transaction.\n * @internal\n */\n t: boolean;\n\n /**\n * Whether to \"bust\" the lastValue cache\n * @internal\n */\n shouldReset: boolean;\n\n /**\n * The framework specific \"signal\" e.g. glimmer \"tracked\"\n * or starbeam \"cell\" to consume/invalidate when appropriate.\n *\n * @internal\n */\n tag: ReturnType<typeof tagForProperty>;\n\n /**\n * In classic ember, arrays must entangle a `[]` symbol\n * in addition to any other tag in order for array chains to work.\n *\n * Note, this symbol MUST be the one that ember itself generates\n *\n * @internal\n */\n '[]': ReturnType<typeof tagForProperty> | null;\n /**\n * In classic ember, arrays must entangle a `@length` symbol\n * in addition to any other tag in order for array chains to work.\n *\n * Note, this symbol MUST be the one that ember itself generates\n *\n * @internal\n */\n '@length': ReturnType<typeof tagForProperty> | null;\n\n /**\n * The lastValue computed for this signal when\n * a signal is also used for storage.\n * @internal\n */\n lastValue: unknown;\n}\n\nexport function createArrayTags<T extends object>(obj: T, signal: Signal) {\n if (DEPRECATE_COMPUTED_CHAINS) {\n signal['[]'] = tagForProperty(obj, '[]');\n signal['@length'] = tagForProperty(obj, 'length');\n }\n}\n\n/**\n * Create a signal for the key/object pairing.\n *\n * @internal\n * @param obj Object we're creating the signal on\n * @param key Key to create the signal for\n * @return the signal\n */\nexport function createSignal<T extends object>(obj: T, key: string): Signal {\n const _signal: Signal = {\n key,\n tag: tagForProperty(obj, key),\n\n t: false,\n shouldReset: false,\n '[]': null,\n '@length': null,\n lastValue: undefined,\n };\n\n if (DEBUG) {\n // eslint-disable-next-line no-inner-declarations\n function tryGet<T1 = string>(prop: string): T1 | undefined {\n try {\n return obj[prop as keyof typeof obj] as unknown as T1;\n } catch {\n return;\n }\n }\n const modelName =\n tryGet('$type') ?? tryGet('modelName') ?? tryGet<{ modelName?: string }>('constructor')?.modelName ?? '';\n // eslint-disable-next-line @typescript-eslint/no-base-to-string\n const className = obj.constructor?.name ?? obj.toString?.() ?? 'unknown';\n _signal._debug_base = `${className}${modelName && !className.startsWith('SchemaRecord') ? `:${modelName}` : ''}`;\n }\n\n return _signal;\n}\n\n/**\n * Create a signal for the key/object pairing and subscribes to the signal.\n *\n * Use when you need to ensure a signal exists and is subscribed to.\n *\n * @internal\n * @param signals Map of signals\n * @param obj Object we're creating the signal on\n * @param key Key to create the signal for\n * @return the signal\n */\nexport function entangleSignal<T extends object>(signals: Map<string, Signal>, obj: T, key: string): Signal {\n let _signal = signals.get(key);\n if (!_signal) {\n _signal = createSignal(obj, key);\n signals.set(key, _signal);\n }\n subscribe(_signal);\n return _signal;\n}\n\ninterface Signaler {\n [Signals]: Map<string, Signal>;\n}\n\nexport function getSignal<T extends object>(obj: T, key: string, initialState: boolean): Signal {\n let signals = (obj as Signaler)[Signals];\n\n if (!signals) {\n signals = new Map();\n (obj as Signaler)[Signals] = signals;\n }\n\n let _signal = signals.get(key);\n if (!_signal) {\n _signal = createSignal(obj, key);\n _signal.shouldReset = initialState;\n signals.set(key, _signal);\n }\n return _signal;\n}\n\nexport function peekSignal<T extends object>(obj: T, key: string): Signal | undefined {\n const signals = (obj as Signaler)[Signals];\n if (signals) {\n return signals.get(key);\n }\n}\n"],"names":["TRANSACTION","createTransaction","transaction","cbs","Set","props","sub","parent","maybeConsume","tag","consumeTag","maybeDirty","dirtyTag","subscribe","obj","add","macroCondition","getOwnConfig","deprecations","DEPRECATE_COMPUTED_CHAINS","ref","updateRef","env","DEBUG","e","Error","message","includes","key","_debug_base","replace","stack","lines","split","finalLines","lastFile","forEach","line","trim","startsWith","location","at","parts","pop","file","join","push","splitstr","splice","flushTransaction","cb","t","untrack","Promise","resolve","addToTransaction","addTransactionCB","method","untracked","ret","transact","memoTransact","args","Signals","Symbol","defineSignal","v","Object","defineProperty","enumerable","configurable","get","signals","Map","existing","has","_signal","entangleSignal","undefined","lastValue","set","value","createSignal","createArrayTags","signal","tagForProperty","shouldReset","tryGet","prop","modelName","className","constructor","name","toString","getSignal","initialState","peekSignal"],"mappings":"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"}
package/addon/index.js CHANGED
@@ -1 +1,19 @@
1
- export { memoTransact, transact, untracked } from "./-private";
1
+ import { assert } from '@ember/debug';
2
+ import { createCache, getValue } from '@glimmer/tracking/primitives/cache';
3
+ export { createCache, getValue } from '@glimmer/tracking/primitives/cache';
4
+ export { memoTransact, transact, untracked } from "./-private";
5
+ export { dependentKeyCompat as compat } from '@ember/object/compat';
6
+ function cached(target, key, descriptor) {
7
+ // Error on `@cached()`, `@cached(...args)`, and `@cached propName = value;`
8
+ assert('You attempted to use @cached(), which is not necessary nor supported. Remove the parentheses and you will be good to go!', target !== undefined);
9
+ assert(`You attempted to use @cached on with ${arguments.length > 1 ? 'arguments' : 'an argument'} ( @cached(${Array.from(arguments).map(d => `'${d}'`).join(', ')}), which is not supported. Dependencies are automatically tracked, so you can just use ${'`@cached`'}`, typeof target === 'object' && typeof key === 'string' && typeof descriptor === 'object' && arguments.length === 3);
10
+ assert(`The @cached decorator must be applied to getters. '${key}' is not a getter.`, typeof descriptor.get === 'function');
11
+ const caches = new WeakMap();
12
+ // eslint-disable-next-line @typescript-eslint/unbound-method
13
+ const getter = descriptor.get;
14
+ descriptor.get = function () {
15
+ if (!caches.has(this)) caches.set(this, createCache(getter.bind(this)));
16
+ return getValue(caches.get(this));
17
+ };
18
+ }
19
+ export { cached };
@@ -1 +1 @@
1
- {"version":3,"file":"index.js","sources":[],"sourcesContent":[],"names":[],"mappings":""}
1
+ {"version":3,"file":"index.js","sources":["../src/index.ts"],"sourcesContent":["import { assert } from '@ember/debug';\nimport { createCache, getValue } from '@glimmer/tracking/primitives/cache';\n\nexport { transact, memoTransact, untracked } from './-private';\n\n// temporary so we can remove the glimmer and ember imports elsewhere\n// eslint-disable-next-line no-restricted-imports\nexport { dependentKeyCompat as compat } from '@ember/object/compat';\n\nexport function cached<T extends object, K extends keyof T & string>(\n target: T,\n key: K,\n descriptor: PropertyDescriptor\n) {\n // Error on `@cached()`, `@cached(...args)`, and `@cached propName = value;`\n assert(\n 'You attempted to use @cached(), which is not necessary nor supported. Remove the parentheses and you will be good to go!',\n target !== undefined\n );\n assert(\n `You attempted to use @cached on with ${arguments.length > 1 ? 'arguments' : 'an argument'} ( @cached(${Array.from(\n arguments\n )\n .map((d) => `'${d}'`)\n .join(\n ', '\n )}), which is not supported. Dependencies are automatically tracked, so you can just use ${'`@cached`'}`,\n typeof target === 'object' && typeof key === 'string' && typeof descriptor === 'object' && arguments.length === 3\n );\n assert(\n `The @cached decorator must be applied to getters. '${key}' is not a getter.`,\n typeof descriptor.get === 'function'\n );\n\n const caches = new WeakMap<object, object>();\n // eslint-disable-next-line @typescript-eslint/unbound-method\n const getter = descriptor.get;\n descriptor.get = function () {\n if (!caches.has(this)) caches.set(this, createCache(getter.bind(this)));\n return getValue<unknown>(caches.get(this) as Parameters<typeof getValue>[0]);\n };\n}\n\nexport { createCache, getValue };\n"],"names":["cached","target","key","descriptor","assert","undefined","arguments","length","Array","from","map","d","join","get","caches","WeakMap","getter","has","set","createCache","bind","getValue"],"mappings":";;;;;;AASO,SAASA,MAAMA,CACpBC,MAAS,EACTC,GAAM,EACNC,UAA8B,EAC9B;AACA;AACAC,EAAAA,MAAM,CACJ,0HAA0H,EAC1HH,MAAM,KAAKI,SACb,CAAC,CAAA;EACDD,MAAM,CACH,CAAuCE,qCAAAA,EAAAA,SAAS,CAACC,MAAM,GAAG,CAAC,GAAG,WAAW,GAAG,aAAc,CAAaC,WAAAA,EAAAA,KAAK,CAACC,IAAI,CAChHH,SACF,CAAC,CACEI,GAAG,CAAEC,CAAC,IAAM,CAAA,CAAA,EAAGA,CAAE,CAAA,CAAA,CAAE,CAAC,CACpBC,IAAI,CACH,IACF,CAAE,CAAA,uFAAA,EAAyF,WAAY,CAAA,CAAC,EAC1G,OAAOX,MAAM,KAAK,QAAQ,IAAI,OAAOC,GAAG,KAAK,QAAQ,IAAI,OAAOC,UAAU,KAAK,QAAQ,IAAIG,SAAS,CAACC,MAAM,KAAK,CAClH,CAAC,CAAA;EACDH,MAAM,CACH,CAAqDF,mDAAAA,EAAAA,GAAI,CAAmB,kBAAA,CAAA,EAC7E,OAAOC,UAAU,CAACU,GAAG,KAAK,UAC5B,CAAC,CAAA;AAED,EAAA,MAAMC,MAAM,GAAG,IAAIC,OAAO,EAAkB,CAAA;AAC5C;AACA,EAAA,MAAMC,MAAM,GAAGb,UAAU,CAACU,GAAG,CAAA;EAC7BV,UAAU,CAACU,GAAG,GAAG,YAAY;IAC3B,IAAI,CAACC,MAAM,CAACG,GAAG,CAAC,IAAI,CAAC,EAAEH,MAAM,CAACI,GAAG,CAAC,IAAI,EAAEC,WAAW,CAACH,MAAM,CAACI,IAAI,CAAC,IAAI,CAAC,CAAC,CAAC,CAAA;IACvE,OAAOC,QAAQ,CAAUP,MAAM,CAACD,GAAG,CAAC,IAAI,CAAmC,CAAC,CAAA;GAC7E,CAAA;AACH;;;;"}
package/package.json CHANGED
@@ -1,7 +1,7 @@
1
1
  {
2
2
  "name": "@ember-data/tracking",
3
3
  "description": "Tracking Primitives for controlling change notification of Tracked properties when working with EmberData",
4
- "version": "5.4.0-beta.1",
4
+ "version": "5.4.0-beta.2",
5
5
  "private": false,
6
6
  "license": "MIT",
7
7
  "author": "Chris Thoburn <runspired@users.noreply.github.com>",
@@ -13,7 +13,7 @@
13
13
  "homepage": "https://github.com/emberjs/data",
14
14
  "bugs": "https://github.com/emberjs/data/issues",
15
15
  "engines": {
16
- "node": "16.* || >= 18"
16
+ "node": ">= 18.19.1"
17
17
  },
18
18
  "keywords": [
19
19
  "ember-addon"
@@ -27,47 +27,63 @@
27
27
  }
28
28
  },
29
29
  "dependencies": {
30
- "@ember-data/private-build-infra": "5.4.0-beta.1",
31
- "@embroider/macros": "^1.13.1",
32
- "ember-cli-babel": "^8.0.0"
30
+ "@ember-data/private-build-infra": "5.4.0-beta.2",
31
+ "@embroider/macros": "^1.13.4",
32
+ "ember-cached-decorator-polyfill": "^1.0.2",
33
+ "ember-cli-babel": "^8.2.0",
34
+ "pnpm-sync-dependencies-meta-injected": "0.0.10"
33
35
  },
34
36
  "files": [
35
- "addon-main.js",
37
+ "addon-main.cjs",
36
38
  "addon",
37
39
  "README.md",
38
40
  "LICENSE.md",
39
41
  "ember-data-logo-dark.svg",
40
42
  "ember-data-logo-light.svg"
41
43
  ],
44
+ "exports": {
45
+ ".": {
46
+ "default": "./addon/index.js"
47
+ },
48
+ "./*": {
49
+ "default": "./addon/*.js"
50
+ }
51
+ },
42
52
  "ember-addon": {
43
- "main": "addon-main.js",
53
+ "main": "addon-main.cjs",
44
54
  "type": "addon",
45
55
  "version": 1
46
56
  },
47
57
  "devDependencies": {
48
- "@babel/cli": "^7.22.15",
49
- "@babel/core": "^7.22.20",
50
- "@babel/plugin-proposal-decorators": "^7.22.15",
51
- "@babel/plugin-transform-class-properties": "^7.22.5",
52
- "@babel/plugin-transform-private-methods": "^7.22.5",
53
- "@babel/plugin-transform-runtime": "^7.22.15",
54
- "@babel/plugin-transform-typescript": "^7.22.15",
55
- "@babel/preset-env": "^7.22.20",
56
- "@babel/preset-typescript": "^7.22.15",
57
- "@babel/runtime": "^7.22.15",
58
- "@embroider/addon-dev": "^4.1.0",
59
- "@rollup/plugin-babel": "^6.0.3",
60
- "@rollup/plugin-node-resolve": "^15.2.1",
61
- "rollup": "^3.29.3",
62
- "tslib": "^2.6.2",
63
- "typescript": "^5.2.2",
58
+ "@babel/cli": "^7.23.4",
59
+ "@babel/core": "^7.23.7",
60
+ "@babel/plugin-proposal-decorators": "^7.23.7",
61
+ "@babel/plugin-transform-class-properties": "^7.23.3",
62
+ "@babel/plugin-transform-private-methods": "^7.23.3",
63
+ "@babel/plugin-transform-runtime": "^7.23.7",
64
+ "@babel/plugin-transform-typescript": "^7.23.6",
65
+ "@babel/preset-env": "^7.23.8",
66
+ "@babel/preset-typescript": "^7.23.3",
67
+ "@babel/runtime": "^7.23.8",
68
+ "@embroider/addon-dev": "^4.1.2",
69
+ "@glimmer/component": "^1.1.2",
70
+ "@glimmer/validator": "^0.88.1",
71
+ "@rollup/plugin-babel": "^6.0.4",
72
+ "@rollup/plugin-node-resolve": "^15.2.3",
73
+ "@warp-drive/internal-config": "5.4.0-beta.2",
74
+ "ember-source": "~5.6.0",
75
+ "rollup": "^4.9.6",
76
+ "typescript": "^5.3.3",
64
77
  "walk-sync": "^3.0.0"
65
78
  },
66
79
  "ember": {
67
80
  "edition": "octane"
68
81
  },
69
82
  "scripts": {
70
- "build": "rollup --config && babel ./addon --out-dir addon --plugins=../private-build-infra/src/transforms/babel-plugin-transform-ext.js",
71
- "start": "rollup --config --watch"
83
+ "lint": "eslint . --quiet --cache --cache-strategy=content --ext .js,.ts,.mjs,.cjs --report-unused-disable-directives",
84
+ "build:runtime": "rollup --config && babel ./addon --out-dir addon --plugins=../private-build-infra/src/transforms/babel-plugin-transform-ext.js",
85
+ "build:types": "echo \"Types are private\" && exit 0",
86
+ "_build": "bun run build:runtime && bun run build:types",
87
+ "_syncPnpm": "bun run sync-dependencies-meta-injected"
72
88
  }
73
89
  }
File without changes