Skip to content

Commit

Permalink
fix: addChild with index should allow for children that are elements (#…
Browse files Browse the repository at this point in the history
…6644)

The fix in #6297 doesn't work where the child to insert before is an element rather than a component, e.g. the video element.
Check if the child to insert before is an element, as well as checking if it has an el_
  • Loading branch information
mister-ben authored May 26, 2020
1 parent a4ea1f9 commit 0b91f74
Show file tree
Hide file tree
Showing 2 changed files with 27 additions and 2 deletions.
9 changes: 7 additions & 2 deletions src/js/component.js
Original file line number Diff line number Diff line change
Expand Up @@ -526,8 +526,13 @@ class Component {
// If inserting before a component, insert before that component's element
let refNode = null;

if (this.children_[index + 1] && this.children_[index + 1].el_) {
refNode = this.children_[index + 1].el_;
if (this.children_[index + 1]) {
// Most children are components, but the video tech is an HTML element
if (this.children_[index + 1].el_) {
refNode = this.children_[index + 1].el_;
} else if (Dom.isEl(this.children_[index + 1])) {
refNode = this.children_[index + 1];
}
}

this.contentEl().insertBefore(component.el(), refNode);
Expand Down
20 changes: 20 additions & 0 deletions test/unit/component.test.js
Original file line number Diff line number Diff line change
Expand Up @@ -164,6 +164,26 @@ QUnit.test('should insert element relative to the element of the component to in
/* eslint-enable no-unused-vars */
});

QUnit.test('should allow for children that are elements', function(assert) {

// for legibility of the test itself:
/* eslint-disable no-unused-vars */

const comp = new Component(getFakePlayer());
const testEl = Dom.createEl('div');

// Add element as video el gets added to player
comp.el().appendChild(testEl);
comp.children_.unshift(testEl);

const child1 = comp.addChild('component', {el: Dom.createEl('div', {}, {class: 'c1'})});
const child2 = comp.addChild('component', {el: Dom.createEl('div', {}, {class: 'c4'})}, 0);

assert.ok(child2.el_.nextSibling === testEl, 'addChild should insert el before a sibling that is an element');

/* eslint-enable no-unused-vars */
});

QUnit.test('addChild should throw if the child does not exist', function(assert) {
const comp = new Component(getFakePlayer());

Expand Down

0 comments on commit 0b91f74

Please sign in to comment.