ember-inspector 4.10.4 → 4.11.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/.github/workflows/build.yml +9 -9
- package/CHANGELOG.md +19 -0
- package/app/services/adapters/web-extension.js +5 -0
- package/dist/bookmarklet/panes-3-16-0/assets/{chunk.143.19ad6fbd35ab48abdce5.js → chunk.143.1816c95b481be6c0f8ef.js} +4 -4
- package/dist/{firefox/panes-3-16-0/assets/chunk.178.80c8fe8e9f921589de61.js → bookmarklet/panes-3-16-0/assets/chunk.178.0ffaf1f84f8bdf2ef148.js} +3 -3
- package/dist/bookmarklet/panes-3-16-0/assets/ember-inspector.js +3 -3
- package/dist/bookmarklet/panes-3-16-0/ember_debug.js +124 -152
- package/dist/bookmarklet/panes-3-16-0/index.html +2 -2
- package/dist/chrome/manifest.json +1 -1
- package/dist/{firefox/panes-3-16-0/assets/chunk.143.19ad6fbd35ab48abdce5.js → chrome/panes-3-16-0/assets/chunk.143.1816c95b481be6c0f8ef.js} +4 -4
- package/dist/{bookmarklet/panes-3-16-0/assets/chunk.178.80c8fe8e9f921589de61.js → chrome/panes-3-16-0/assets/chunk.178.0ffaf1f84f8bdf2ef148.js} +3 -3
- package/dist/chrome/panes-3-16-0/assets/ember-inspector.js +3 -3
- package/dist/chrome/panes-3-16-0/ember_debug.js +124 -152
- package/dist/chrome/panes-3-16-0/index.html +2 -2
- package/dist/firefox/manifest.json +1 -1
- package/dist/{chrome/panes-3-16-0/assets/chunk.143.19ad6fbd35ab48abdce5.js → firefox/panes-3-16-0/assets/chunk.143.1816c95b481be6c0f8ef.js} +4 -4
- package/dist/{websocket/assets/chunk.178.80c8fe8e9f921589de61.js → firefox/panes-3-16-0/assets/chunk.178.0ffaf1f84f8bdf2ef148.js} +3 -3
- package/dist/firefox/panes-3-16-0/assets/ember-inspector.js +3 -3
- package/dist/firefox/panes-3-16-0/ember_debug.js +124 -152
- package/dist/firefox/panes-3-16-0/index.html +2 -2
- package/dist/websocket/assets/{chunk.143.19ad6fbd35ab48abdce5.js → chunk.143.1816c95b481be6c0f8ef.js} +4 -4
- package/dist/{chrome/panes-3-16-0/assets/chunk.178.80c8fe8e9f921589de61.js → websocket/assets/chunk.178.0ffaf1f84f8bdf2ef148.js} +3 -3
- package/dist/websocket/assets/ember-inspector.js +3 -3
- package/dist/websocket/ember_debug.js +124 -152
- package/dist/websocket/index.html +2 -2
- package/ember_debug/libs/render-tree.js +108 -148
- package/ember_debug/object-inspector.js +25 -19
- package/ember_debug/utils/base-object.js +3 -1
- package/ember_debug/view-debug.js +1 -1
- package/package.json +1 -1
- package/tests/ember_debug/object-inspector-test.js +17 -1
- package/tests/ember_debug/view-debug-test.js +22 -3
- package/tests/index.html +1 -1
@@ -5904,10 +5904,8 @@ define("ember-debug/libs/render-tree", ["exports", "ember-debug/libs/capture-ren
|
|
5904
5904
|
constructor(owner) {
|
5905
5905
|
this.nodeMap = new Map();
|
5906
5906
|
this.remoteRoots = [];
|
5907
|
-
this.currentNode = null;
|
5908
|
-
this.nodeStack = [];
|
5909
|
-
this.remoteNodeStack = [];
|
5910
5907
|
this.runtime = this.require('@glimmer/runtime');
|
5908
|
+
this.reference = this.require('@glimmer/reference');
|
5911
5909
|
try {
|
5912
5910
|
this.Wormhole = requireModule('ember-wormhole/components/ember-wormhole');
|
5913
5911
|
} catch (e) {
|
@@ -5920,100 +5918,107 @@ define("ember-debug/libs/render-tree", ["exports", "ember-debug/libs/capture-ren
|
|
5920
5918
|
reset() {
|
5921
5919
|
this.nodeMap.clear();
|
5922
5920
|
this.remoteRoots.length = 0;
|
5923
|
-
this.nodeStack.length = 0;
|
5924
|
-
this.remoteNodeStack.length = 0;
|
5925
|
-
this.currentRemoteNode = null;
|
5926
|
-
this.currentNode = null;
|
5927
|
-
}
|
5928
|
-
buildInElementNode(node) {
|
5929
|
-
const obj = Object.create(null);
|
5930
|
-
obj.index = this.currentNode?.refs?.size || 0;
|
5931
|
-
obj.name = 'in-element';
|
5932
|
-
obj.type = 'component';
|
5933
|
-
obj.template = null;
|
5934
|
-
obj.isRemote = true;
|
5935
|
-
obj.args = {
|
5936
|
-
positional: [],
|
5937
|
-
named: {
|
5938
|
-
destination: node
|
5939
|
-
}
|
5940
|
-
};
|
5941
|
-
obj.instance = {
|
5942
|
-
args: obj.args.named,
|
5943
|
-
constructor: {
|
5944
|
-
name: 'InElement'
|
5945
|
-
}
|
5946
|
-
};
|
5947
|
-
obj.bounds = {
|
5948
|
-
firstNode: node,
|
5949
|
-
lastNode: node,
|
5950
|
-
parentElement: node.parentElement
|
5951
|
-
};
|
5952
|
-
obj.children = [];
|
5953
|
-
return obj;
|
5954
5921
|
}
|
5955
5922
|
patch() {
|
5956
5923
|
const self = this;
|
5957
|
-
const
|
5958
|
-
|
5959
|
-
|
5960
|
-
|
5961
|
-
|
5962
|
-
|
5963
|
-
|
5964
|
-
|
5965
|
-
|
5966
|
-
|
5967
|
-
|
5968
|
-
|
5969
|
-
|
5924
|
+
const NewElementBuilder = this.NewElementBuilder;
|
5925
|
+
const remoteStack = [];
|
5926
|
+
const componentStack = [];
|
5927
|
+
function createRef(value) {
|
5928
|
+
if (self.reference.createUnboundRef) {
|
5929
|
+
return self.reference.createUnboundRef(value);
|
5930
|
+
} else {
|
5931
|
+
return value;
|
5932
|
+
}
|
5933
|
+
}
|
5934
|
+
const appendChild = this.debugRenderTree.appendChild;
|
5935
|
+
this.debugRenderTree.appendChild = function (node, state) {
|
5936
|
+
if (node.type === 'component') {
|
5937
|
+
componentStack.push(node);
|
5938
|
+
}
|
5939
|
+
return appendChild.call(this, node, state);
|
5970
5940
|
};
|
5971
5941
|
const exit = this.debugRenderTree.exit;
|
5972
|
-
this.debugRenderTree.exit = function (
|
5973
|
-
|
5974
|
-
|
5942
|
+
this.debugRenderTree.exit = function (state) {
|
5943
|
+
const node = this.nodeFor(this.stack.current);
|
5944
|
+
if (node?.type === 'component') {
|
5945
|
+
componentStack.pop();
|
5946
|
+
}
|
5947
|
+
exit.call(this, state);
|
5975
5948
|
};
|
5976
|
-
const NewElementBuilder = this.NewElementBuilder;
|
5977
5949
|
const didAppendNode = NewElementBuilder.prototype.didAppendNode;
|
5978
5950
|
NewElementBuilder.prototype.didAppendNode = function (...args) {
|
5979
|
-
args[0].__emberInspectorParentNode =
|
5951
|
+
args[0].__emberInspectorParentNode = componentStack.at(-1);
|
5980
5952
|
return didAppendNode.call(this, ...args);
|
5981
5953
|
};
|
5982
5954
|
const pushElement = NewElementBuilder.prototype.pushElement;
|
5983
5955
|
NewElementBuilder.prototype.pushElement = function (...args) {
|
5984
|
-
|
5985
|
-
|
5956
|
+
pushElement.call(this, ...args);
|
5957
|
+
args[0].__emberInspectorParentNode = componentStack.at(-1);
|
5986
5958
|
};
|
5987
5959
|
const pushRemoteElement = NewElementBuilder.prototype.pushRemoteElement;
|
5988
|
-
NewElementBuilder.prototype.pushRemoteElement = function (
|
5989
|
-
|
5990
|
-
|
5991
|
-
|
5992
|
-
|
5993
|
-
|
5994
|
-
|
5960
|
+
NewElementBuilder.prototype.pushRemoteElement = function (element, guid, insertBefore) {
|
5961
|
+
remoteStack.push({
|
5962
|
+
element
|
5963
|
+
});
|
5964
|
+
const ref = createRef(element);
|
5965
|
+
const capturedArgs = {
|
5966
|
+
positional: [ref],
|
5967
|
+
named: {}
|
5968
|
+
};
|
5969
|
+
if (insertBefore) {
|
5970
|
+
capturedArgs.named.insertBefore = insertBefore;
|
5971
|
+
}
|
5972
|
+
const inElementArgs = self.reference.createUnboundRef ? capturedArgs : {
|
5973
|
+
value() {
|
5974
|
+
return capturedArgs;
|
5975
|
+
}
|
5976
|
+
};
|
5977
|
+
const debugRenderTree = self.debugRenderTree;
|
5978
|
+
debugRenderTree?.create(remoteStack.at(-1), {
|
5979
|
+
type: 'keyword',
|
5980
|
+
name: 'in-element',
|
5981
|
+
args: inElementArgs,
|
5982
|
+
instance: {
|
5983
|
+
args: {
|
5984
|
+
named: {
|
5985
|
+
insertBefore
|
5986
|
+
},
|
5987
|
+
positional: [element]
|
5988
|
+
},
|
5989
|
+
constructor: {
|
5990
|
+
name: 'InElement'
|
5991
|
+
}
|
5992
|
+
}
|
5993
|
+
});
|
5994
|
+
return pushRemoteElement.call(this, element, guid, insertBefore);
|
5995
5995
|
};
|
5996
5996
|
const popRemoteElement = NewElementBuilder.prototype.popRemoteElement;
|
5997
5997
|
NewElementBuilder.prototype.popRemoteElement = function (...args) {
|
5998
|
-
const
|
5999
|
-
|
6000
|
-
|
6001
|
-
|
6002
|
-
|
5998
|
+
const element = this.element;
|
5999
|
+
popRemoteElement.call(this, ...args);
|
6000
|
+
const parentElement = this.element;
|
6001
|
+
const debugRenderTree = self.debugRenderTree;
|
6002
|
+
debugRenderTree?.didRender(remoteStack.at(-1), {
|
6003
|
+
parentElement: () => parentElement,
|
6004
|
+
firstNode: () => element,
|
6005
|
+
lastNode: () => element
|
6006
|
+
});
|
6007
|
+
remoteStack.pop();
|
6003
6008
|
};
|
6004
6009
|
this.debugRenderTreeFunctions = {
|
6005
|
-
|
6006
|
-
|
6007
|
-
captureNode
|
6010
|
+
appendChild,
|
6011
|
+
exit
|
6008
6012
|
};
|
6009
6013
|
this.NewElementBuilderFunctions = {
|
6010
6014
|
pushElement,
|
6011
6015
|
pushRemoteElement,
|
6016
|
+
popRemoteElement,
|
6012
6017
|
didAppendNode
|
6013
6018
|
};
|
6014
6019
|
}
|
6015
6020
|
teardown() {
|
6016
|
-
if (!this.
|
6021
|
+
if (!this.NewElementBuilderFunctions) {
|
6017
6022
|
return;
|
6018
6023
|
}
|
6019
6024
|
Object.assign(this.debugRenderTree, this.debugRenderTreeFunctions);
|
@@ -6022,72 +6027,6 @@ define("ember-debug/libs/render-tree", ["exports", "ember-debug/libs/capture-ren
|
|
6022
6027
|
require(req) {
|
6023
6028
|
return requireModule.has(req) ? requireModule(req) : _loader.EmberLoader.require(req);
|
6024
6029
|
}
|
6025
|
-
enter(node) {
|
6026
|
-
if (this.currentNode && this.currentNode === this.currentRemoteNode) {
|
6027
|
-
this.currentRemoteNode.children.push(node);
|
6028
|
-
node.remoteParent = this.currentRemoteNode;
|
6029
|
-
}
|
6030
|
-
this.currentNode = node;
|
6031
|
-
this.nodeStack.push(this.currentNode);
|
6032
|
-
}
|
6033
|
-
exit() {
|
6034
|
-
this.nodeStack.pop();
|
6035
|
-
this.currentNode = this.nodeStack[this.nodeStack.length - 1];
|
6036
|
-
}
|
6037
|
-
registerRemote(block, node) {
|
6038
|
-
const obj = this.buildInElementNode(node);
|
6039
|
-
if (this.currentNode) {
|
6040
|
-
this.currentNode.remotes = this.currentNode.remotes || [];
|
6041
|
-
this.currentNode.remotes.push(obj);
|
6042
|
-
}
|
6043
|
-
this.remoteRoots.push(obj);
|
6044
|
-
this.currentNode = obj;
|
6045
|
-
}
|
6046
|
-
setupNodeRemotes(node, id, capture) {
|
6047
|
-
capture.isInRemote = !!node.remoteParent;
|
6048
|
-
this.nodeMap.set(node, id);
|
6049
|
-
if (node.remoteParent) {
|
6050
|
-
const idx = node.remoteParent.children.indexOf(node);
|
6051
|
-
if (idx >= 0) {
|
6052
|
-
node.remoteParent.children[idx] = capture;
|
6053
|
-
}
|
6054
|
-
}
|
6055
|
-
capture.children = capture.children.filter(c => !c.isInRemote);
|
6056
|
-
node.remotes?.forEach(remote => {
|
6057
|
-
remote.id = 'remote-render-node:' + this.remoteRoots.length;
|
6058
|
-
this.nodeMap.set(remote, remote.id);
|
6059
|
-
this.remoteRoots.push(remote);
|
6060
|
-
capture.children.splice(remote.index, 0, remote);
|
6061
|
-
});
|
6062
|
-
if (capture.instance?.__emberInspectorTargetNode) {
|
6063
|
-
Object.defineProperty(capture, 'bounds', {
|
6064
|
-
get() {
|
6065
|
-
return {
|
6066
|
-
firstNode: capture.instance.__emberInspectorTargetNode,
|
6067
|
-
lastNode: capture.instance.__emberInspectorTargetNode,
|
6068
|
-
parentElement: capture.instance.__emberInspectorTargetNode.parentElement
|
6069
|
-
};
|
6070
|
-
}
|
6071
|
-
});
|
6072
|
-
}
|
6073
|
-
if (this.Wormhole && capture.instance instanceof this.Wormhole.default) {
|
6074
|
-
this.remoteRoots.push(capture);
|
6075
|
-
const bounds = capture.bounds;
|
6076
|
-
Object.defineProperty(capture, 'bounds', {
|
6077
|
-
get() {
|
6078
|
-
if (capture.instance._destination) {
|
6079
|
-
return {
|
6080
|
-
firstNode: capture.instance._destination,
|
6081
|
-
lastNode: capture.instance._destination,
|
6082
|
-
parentElement: capture.instance._destination.parentElement
|
6083
|
-
};
|
6084
|
-
}
|
6085
|
-
return bounds;
|
6086
|
-
}
|
6087
|
-
});
|
6088
|
-
}
|
6089
|
-
return capture;
|
6090
|
-
}
|
6091
6030
|
}
|
6092
6031
|
class RenderTree {
|
6093
6032
|
/**
|
@@ -6112,6 +6051,7 @@ define("ember-debug/libs/render-tree", ["exports", "ember-debug/libs/capture-ren
|
|
6112
6051
|
try {
|
6113
6052
|
this.inElementSupport = new InElementSupportProvider(owner);
|
6114
6053
|
} catch (e) {
|
6054
|
+
console.error('failed to setup in element support', e);
|
6115
6055
|
// not supported
|
6116
6056
|
}
|
6117
6057
|
|
@@ -6190,7 +6130,7 @@ define("ember-debug/libs/render-tree", ["exports", "ember-debug/libs/capture-ren
|
|
6190
6130
|
let hintNode = this._findUp(this.nodes[hint]);
|
6191
6131
|
let hints = [hintNode];
|
6192
6132
|
if (node.__emberInspectorParentNode) {
|
6193
|
-
const remoteNode = this.inElementSupport
|
6133
|
+
const remoteNode = this.inElementSupport?.nodeMap.get(node);
|
6194
6134
|
const n = remoteNode && this.nodes[remoteNode];
|
6195
6135
|
hints.push(n);
|
6196
6136
|
}
|
@@ -6336,6 +6276,27 @@ define("ember-debug/libs/render-tree", ["exports", "ember-debug/libs/capture-ren
|
|
6336
6276
|
let serialized = this.serialized[node.id];
|
6337
6277
|
if (serialized === undefined) {
|
6338
6278
|
this.nodes[node.id] = node;
|
6279
|
+
if (node.type === 'keyword') {
|
6280
|
+
node.type = 'component';
|
6281
|
+
this.inElementSupport?.nodeMap.set(node, node.id);
|
6282
|
+
this.inElementSupport?.remoteRoots.push(node);
|
6283
|
+
}
|
6284
|
+
if (this.inElementSupport?.Wormhole && node.instance instanceof this.inElementSupport.Wormhole.default) {
|
6285
|
+
this.inElementSupport?.remoteRoots.push(node);
|
6286
|
+
const bounds = node.bounds;
|
6287
|
+
Object.defineProperty(node, 'bounds', {
|
6288
|
+
get() {
|
6289
|
+
if (node.instance._destination) {
|
6290
|
+
return {
|
6291
|
+
firstNode: node.instance._destination,
|
6292
|
+
lastNode: node.instance._destination,
|
6293
|
+
parentElement: node.instance._destination.parentElement
|
6294
|
+
};
|
6295
|
+
}
|
6296
|
+
return bounds;
|
6297
|
+
}
|
6298
|
+
});
|
6299
|
+
}
|
6339
6300
|
if (parentNode) {
|
6340
6301
|
this.parentNodes[node.id] = parentNode;
|
6341
6302
|
}
|
@@ -6496,11 +6457,10 @@ define("ember-debug/libs/render-tree", ["exports", "ember-debug/libs/capture-ren
|
|
6496
6457
|
return firstNode === lastNode;
|
6497
6458
|
}
|
6498
6459
|
function isAttached({
|
6499
|
-
parentElement,
|
6500
6460
|
firstNode,
|
6501
6461
|
lastNode
|
6502
6462
|
}) {
|
6503
|
-
return
|
6463
|
+
return firstNode.isConnected && lastNode.isConnected;
|
6504
6464
|
}
|
6505
6465
|
function isEmptyRect({
|
6506
6466
|
x,
|
@@ -8016,19 +7976,20 @@ define("ember-debug/object-inspector", ["exports", "ember-debug/debug-port", "em
|
|
8016
7976
|
}
|
8017
7977
|
const subtags = tag.subtags || (Array.isArray(tag.subtag) ? tag.subtag : []);
|
8018
7978
|
if (tag.subtag && !Array.isArray(tag.subtag)) {
|
8019
|
-
if (tag.subtag._propertyKey) props.push(
|
7979
|
+
if (tag.subtag._propertyKey) props.push(tag.subtag);
|
8020
7980
|
props.push(...getTagTrackedProps(tag.subtag, ownTag, level + 1));
|
8021
7981
|
}
|
8022
7982
|
if (subtags) {
|
8023
7983
|
subtags.forEach(t => {
|
8024
7984
|
if (t === ownTag) return;
|
8025
|
-
if (t._propertyKey) props.push(
|
7985
|
+
if (t._propertyKey) props.push(t);
|
8026
7986
|
props.push(...getTagTrackedProps(t, ownTag, level + 1));
|
8027
7987
|
});
|
8028
7988
|
}
|
8029
7989
|
return props;
|
8030
7990
|
}
|
8031
|
-
function getTrackedDependencies(object, property,
|
7991
|
+
function getTrackedDependencies(object, property, tagInfo) {
|
7992
|
+
const tag = tagInfo.tag;
|
8032
7993
|
const proto = Object.getPrototypeOf(object);
|
8033
7994
|
if (!proto) return [];
|
8034
7995
|
const cpDesc = emberMeta(object).peekDescriptors(property);
|
@@ -8040,20 +8001,29 @@ define("ember-debug/object-inspector", ["exports", "ember-debug/debug-port", "em
|
|
8040
8001
|
const ownTag = tagForProperty(object, property);
|
8041
8002
|
const props = getTagTrackedProps(tag, ownTag);
|
8042
8003
|
const mapping = {};
|
8043
|
-
|
8004
|
+
let maxRevision = tagInfo.revision ?? 0;
|
8005
|
+
let minRevision = Infinity;
|
8006
|
+
props.forEach(t => {
|
8007
|
+
const p = (t._object ? (0, _getObjectName.default)(t._object) + '.' : '') + t._propertyKey;
|
8044
8008
|
const [objName, ...props] = p.split('.');
|
8045
8009
|
mapping[objName] = mapping[objName] || new Set();
|
8046
|
-
|
8010
|
+
maxRevision = Math.max(maxRevision, t.revision);
|
8011
|
+
minRevision = Math.min(minRevision, t.revision);
|
8012
|
+
props.forEach(p => mapping[objName].add([p, t.revision]));
|
8047
8013
|
});
|
8014
|
+
const hasChange = maxRevision !== minRevision;
|
8048
8015
|
Object.entries(mapping).forEach(([objName, props]) => {
|
8049
8016
|
if (props.size > 1) {
|
8050
8017
|
dependentKeys.push(objName);
|
8051
8018
|
props.forEach(p => {
|
8052
|
-
|
8019
|
+
const changed = hasChange && p[1] >= maxRevision ? ' 🔸' : '';
|
8020
|
+
dependentKeys.push(' • -- ' + p[0] + changed);
|
8053
8021
|
});
|
8054
8022
|
}
|
8055
8023
|
if (props.size === 1) {
|
8056
|
-
|
8024
|
+
const p = [...props][0];
|
8025
|
+
const changed = hasChange && p[1] >= maxRevision ? ' 🔸' : '';
|
8026
|
+
dependentKeys.push(objName + '.' + p[0] + changed);
|
8057
8027
|
}
|
8058
8028
|
if (props.size === 0) {
|
8059
8029
|
dependentKeys.push(objName);
|
@@ -8118,7 +8088,6 @@ define("ember-debug/object-inspector", ["exports", "ember-debug/debug-port", "em
|
|
8118
8088
|
tagInfo.tag = track(() => {
|
8119
8089
|
value = object.get?.(item.name) || object[item.name];
|
8120
8090
|
});
|
8121
|
-
tagInfo.revision = tagValue(tagInfo.tag);
|
8122
8091
|
}
|
8123
8092
|
tracked[item.name] = tagInfo;
|
8124
8093
|
} else {
|
@@ -8133,7 +8102,8 @@ define("ember-debug/object-inspector", ["exports", "ember-debug/debug-port", "em
|
|
8133
8102
|
value.isCalculated = true;
|
8134
8103
|
let dependentKeys = null;
|
8135
8104
|
if (tracked[item.name]) {
|
8136
|
-
dependentKeys = getTrackedDependencies(object, item.name, tracked[item.name]
|
8105
|
+
dependentKeys = getTrackedDependencies(object, item.name, tracked[item.name]);
|
8106
|
+
tracked[item.name].revision = tagValue(tracked[item.name].tag);
|
8137
8107
|
}
|
8138
8108
|
this.sendMessage('updateProperty', {
|
8139
8109
|
objectId,
|
@@ -8748,8 +8718,8 @@ define("ember-debug/object-inspector", ["exports", "ember-debug/debug-port", "em
|
|
8748
8718
|
item.isTracked = true;
|
8749
8719
|
}
|
8750
8720
|
}
|
8721
|
+
item.dependentKeys = getTrackedDependencies(object, item.name, tagInfo);
|
8751
8722
|
tagInfo.revision = tagValue(tagInfo.tag);
|
8752
|
-
item.dependentKeys = getTrackedDependencies(object, item.name, tagInfo.tag);
|
8753
8723
|
} else {
|
8754
8724
|
value = calculateCP(object, item, errorsForObject);
|
8755
8725
|
}
|
@@ -8909,7 +8879,7 @@ define("ember-debug/object-inspector", ["exports", "ember-debug/debug-port", "em
|
|
8909
8879
|
if (object instanceof _ember.default.ArrayProxy && property == parseInt(property)) {
|
8910
8880
|
return object.objectAt(property);
|
8911
8881
|
}
|
8912
|
-
return item.isGetter || property.includes('.') ? object[property] : object.get?.(property) || object[property]; // need to use `get` to be able to detect tracked props
|
8882
|
+
return item.isGetter || property.includes?.('.') ? object[property] : object.get?.(property) || object[property]; // need to use `get` to be able to detect tracked props
|
8913
8883
|
} catch (error) {
|
8914
8884
|
errorsForObject[property] = {
|
8915
8885
|
property,
|
@@ -9690,7 +9660,9 @@ define("ember-debug/utils/base-object", ["exports"], function (_exports) {
|
|
9690
9660
|
this.init();
|
9691
9661
|
}
|
9692
9662
|
init() {}
|
9693
|
-
willDestroy() {
|
9663
|
+
willDestroy() {
|
9664
|
+
this.isDestroying = true;
|
9665
|
+
}
|
9694
9666
|
destroy() {
|
9695
9667
|
this.willDestroy();
|
9696
9668
|
this.isDestroyed = true;
|
@@ -10618,7 +10590,7 @@ define("ember-debug/view-debug", ["exports", "ember-debug/debug-port", "ember-de
|
|
10618
10590
|
}, 250);
|
10619
10591
|
}
|
10620
10592
|
send() {
|
10621
|
-
if (this.isDestroying) {
|
10593
|
+
if (this.isDestroying || this.isDestroyed) {
|
10622
10594
|
return;
|
10623
10595
|
}
|
10624
10596
|
this.sendMessage('renderTree', {
|
@@ -9,7 +9,7 @@
|
|
9
9
|
<meta name="viewport" content="width=device-width, initial-scale=1">
|
10
10
|
|
11
11
|
|
12
|
-
<meta name="ember-inspector/config/environment" content="%7B%22modulePrefix%22%3A%22ember-inspector%22%2C%22environment%22%3A%22production%22%2C%22rootURL%22%3A%22%22%2C%22locationType%22%3A%22hash%22%2C%22version%22%3A%224.
|
12
|
+
<meta name="ember-inspector/config/environment" content="%7B%22modulePrefix%22%3A%22ember-inspector%22%2C%22environment%22%3A%22production%22%2C%22rootURL%22%3A%22%22%2C%22locationType%22%3A%22hash%22%2C%22version%22%3A%224.11.0%22%2C%22emberVersionsSupported%22%3A%5B%223.16.0%22%2C%22%22%5D%2C%22previousEmberVersionsSupported%22%3A%5B%220.0.0%22%2C%222.7.0%22%2C%223.4.0%22%5D%2C%22EmberENV%22%3A%7B%22FEATURES%22%3A%7B%7D%2C%22_APPLICATION_TEMPLATE_WRAPPER%22%3Afalse%2C%22_DEFAULT_ASYNC_OBSERVERS%22%3Atrue%2C%22_JQUERY_INTEGRATION%22%3Afalse%2C%22_TEMPLATE_ONLY_GLIMMER_COMPONENTS%22%3Atrue%7D%2C%22APP%22%3A%7B%22name%22%3A%22ember-inspector%22%2C%22version%22%3A%224.11.0%2B5c3255cc%22%7D%7D" />
|
13
13
|
|
14
14
|
<style type="text/css">
|
15
15
|
@font-face {
|
@@ -39,7 +39,7 @@
|
|
39
39
|
|
40
40
|
<script src="assets/vendor.js"></script>
|
41
41
|
<script src="assets/chunk.359.0be5d21f60d2b5d6d423.js"></script>
|
42
|
-
<script src="assets/chunk.143.
|
42
|
+
<script src="assets/chunk.143.1816c95b481be6c0f8ef.js"></script>
|
43
43
|
<script src="assets/ember-inspector.js"></script>
|
44
44
|
|
45
45
|
|