ember-inspector 4.13.1-alpha.2025.6.19 → 4.13.1-alpha.2025.6.21

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (32) hide show
  1. package/dist/bookmarklet/panes-3-16-0/assets/{chunk.524.7b97a9e9caaec2bf8dd7.js → chunk.524.ef839d668b8055a7b20a.js} +4 -4
  2. package/dist/{firefox/panes-3-16-0/assets/chunk.582.fb8575406d3fbe1d4a24.js → bookmarklet/panes-3-16-0/assets/chunk.582.3ef89902373ee8f2cf0a.js} +5 -5
  3. package/dist/bookmarklet/panes-3-16-0/assets/ember-inspector.js +2 -2
  4. package/dist/bookmarklet/panes-3-16-0/ember_debug.js +68 -54
  5. package/dist/bookmarklet/panes-3-16-0/index.html +2 -2
  6. package/dist/chrome/manifest.json +2 -2
  7. package/dist/{firefox/panes-3-16-0/assets/chunk.524.7b97a9e9caaec2bf8dd7.js → chrome/panes-3-16-0/assets/chunk.524.ef839d668b8055a7b20a.js} +4 -4
  8. package/dist/{bookmarklet/panes-3-16-0/assets/chunk.582.fb8575406d3fbe1d4a24.js → chrome/panes-3-16-0/assets/chunk.582.3ef89902373ee8f2cf0a.js} +5 -5
  9. package/dist/chrome/panes-3-16-0/assets/ember-inspector.js +2 -2
  10. package/dist/chrome/panes-3-16-0/ember_debug.js +68 -54
  11. package/dist/chrome/panes-3-16-0/index.html +2 -2
  12. package/dist/firefox/manifest.json +2 -2
  13. package/dist/{chrome/panes-3-16-0/assets/chunk.524.7b97a9e9caaec2bf8dd7.js → firefox/panes-3-16-0/assets/chunk.524.ef839d668b8055a7b20a.js} +4 -4
  14. package/dist/{websocket/assets/chunk.582.fb8575406d3fbe1d4a24.js → firefox/panes-3-16-0/assets/chunk.582.3ef89902373ee8f2cf0a.js} +5 -5
  15. package/dist/firefox/panes-3-16-0/assets/ember-inspector.js +2 -2
  16. package/dist/firefox/panes-3-16-0/ember_debug.js +68 -54
  17. package/dist/firefox/panes-3-16-0/index.html +2 -2
  18. package/dist/websocket/assets/{chunk.524.7b97a9e9caaec2bf8dd7.js → chunk.524.ef839d668b8055a7b20a.js} +4 -4
  19. package/dist/{chrome/panes-3-16-0/assets/chunk.582.fb8575406d3fbe1d4a24.js → websocket/assets/chunk.582.3ef89902373ee8f2cf0a.js} +5 -5
  20. package/dist/websocket/assets/ember-inspector.js +2 -2
  21. package/dist/websocket/ember_debug.js +68 -54
  22. package/dist/websocket/index.html +2 -2
  23. package/ember_debug/libs/render-tree.js +23 -25
  24. package/ember_debug/libs/view-inspection.js +10 -2
  25. package/ember_debug/object-inspector.js +15 -30
  26. package/ember_debug/utils/ember-object-names.js +4 -5
  27. package/ember_debug/utils/ember.js +20 -0
  28. package/ember_debug/utils/type-check.js +2 -2
  29. package/ember_debug/view-debug.js +5 -0
  30. package/package.json +11 -5
  31. package/skeletons/web-extension/manifest.json +2 -2
  32. package/tests/ember_debug/view-debug-test.js +78 -1
@@ -22,6 +22,8 @@ import EmberDebug from 'ember-debug/main';
22
22
  import setupEmberDebugTest from '../helpers/setup-ember-debug-test';
23
23
  import { isInVersionSpecifier } from 'ember-debug/version';
24
24
  import { VERSION } from 'ember-debug/ember';
25
+ import GlimmerComponent from '@glimmer/component';
26
+ import { tracked } from '@glimmer/tracking';
25
27
 
26
28
  let templateOnlyComponent = null;
27
29
  try {
@@ -373,6 +375,7 @@ module('Ember Debug - View', function (hooks) {
373
375
  this.route('test-component-in-in-element');
374
376
  this.route('wormhole');
375
377
  this.route('inputs');
378
+ this.route('component-in-shadow-dom');
376
379
  this.route('comments', { resetNamespace: true }, function () {});
377
380
  this.route('posts', { resetNamespace: true });
378
381
  },
@@ -499,6 +502,31 @@ module('Ember Debug - View', function (hooks) {
499
502
  }),
500
503
  );
501
504
 
505
+ this.owner.register(
506
+ 'component:shadow-dom',
507
+ setComponentTemplate(
508
+ hbs(
509
+ `<div {{did-insert this.setupRoot}} />
510
+ {{#if this.shadow}}
511
+ {{#in-element this.shadow}}
512
+ {{yield}}
513
+ {{/in-element}}
514
+ {{/if}}
515
+ `,
516
+ {
517
+ moduleName: 'my-app/components/shadow-dom.hbs',
518
+ },
519
+ ),
520
+ class extends GlimmerComponent {
521
+ @tracked shadow;
522
+ setupRoot = (element) => {
523
+ this.shadow = element.attachShadow({ mode: 'open' });
524
+ window.testShadow = this.shadow;
525
+ };
526
+ },
527
+ ),
528
+ );
529
+
502
530
  this.owner.register(
503
531
  'component:test-foo',
504
532
  setComponentTemplate(
@@ -596,7 +624,9 @@ module('Ember Debug - View', function (hooks) {
596
624
  hbs(
597
625
  `
598
626
  <div {{did-insert this.foo}}>
599
- Simple {{test-foo}} {{test-bar value=(hash x=123 [x.y]=456)}} {{#in-element this.elementTarget}}<TestComponentInInElement />{{/in-element}}
627
+ <div>
628
+ Simple {{test-foo}} {{test-bar value=(hash x=123 [x.y]=456)}} {{#in-element this.elementTarget}}<TestComponentInInElement />{{/in-element}}
629
+ </div>
600
630
  </div>
601
631
  `,
602
632
  {
@@ -635,6 +665,13 @@ module('Ember Debug - View', function (hooks) {
635
665
  }),
636
666
  );
637
667
 
668
+ this.owner.register(
669
+ 'template:component-in-shadow-dom',
670
+ hbs('<ShadowDom><TestFoo /></ShadowDom>', {
671
+ moduleName: 'my-app/templates/component-in-shadow-dom.hbs',
672
+ }),
673
+ );
674
+
638
675
  this.owner.register(
639
676
  'template:comments/index',
640
677
  hbs('{{#each this.comments as |comment|}}{{comment}}{{/each}}', {
@@ -1200,5 +1237,45 @@ module('Ember Debug - View', function (hooks) {
1200
1237
  .dom('.ember-inspector-tooltip-detail-instance', tooltip)
1201
1238
  .hasText(/ember-wormhole/);
1202
1239
  });
1240
+
1241
+ test('component inside shadow dom', async function (assert) {
1242
+ if (isInVersionSpecifier('^5.8.0', VERSION)) {
1243
+ assert.expect(2);
1244
+ return;
1245
+ }
1246
+ await visit('component-in-shadow-dom');
1247
+ await rerender();
1248
+ await getRenderTree();
1249
+
1250
+ const inShadow = window.testShadow.querySelector('.simple-component');
1251
+
1252
+ await click(window.testShadow.host, {
1253
+ clientX: inShadow.getBoundingClientRect().x,
1254
+ clientY: inShadow.getBoundingClientRect().y,
1255
+ });
1256
+
1257
+ assert
1258
+ .dom('.ember-inspector-tooltip-header', tooltip)
1259
+ .hasText('<TestFoo>');
1260
+
1261
+ let actual = highlight.getBoundingClientRect();
1262
+ let expected = inShadow.getBoundingClientRect();
1263
+
1264
+ assert.ok(isVisible(tooltip), 'tooltip is visible');
1265
+ assert.ok(isVisible(highlight), 'highlight is visible');
1266
+
1267
+ assert.deepEqual(actual.x, expected.x, 'same x as component');
1268
+ assert.deepEqual(actual.y, expected.y, 'same y as component');
1269
+ assert.deepEqual(actual.width, expected.width, 'same width as component');
1270
+ assert.deepEqual(
1271
+ actual.height,
1272
+ expected.height,
1273
+ 'same height as component',
1274
+ );
1275
+
1276
+ assert
1277
+ .dom('.ember-inspector-tooltip-detail-instance', tooltip)
1278
+ .hasText('App.TestFooComponent');
1279
+ });
1203
1280
  });
1204
1281
  });