I'm currently trying to implement a repeater WebComponent
to allow the company to easily create front-end without depending on any framework
(decision took by architecture).
Here's my current code:
<ul>
<company-repeat datas='[{"name": "NameValeur", "value": "valeurId"}, {"name": "NameObject", "value": "objectId"}]'>
<li>${name}</option>
</company-repeat>
</ul>
<select name="" id="">
<company-repeat datas='[{"name": "NameValeur", "value": "valeurId"}, {"name": "NameObject", "value": "objectId"}]'>
<option value="${value}">${name}</option>
</company-repeat>
</select>
The list
is rightly working since it seems to have no limitation on which tag allowed inside, but the select is not allowing the customElement
company-repeat
in it and by extension, break the feature and just display <option value="${value}">${name}</option>
Here's the source code of my WebComponent
class CompanyRepeater extends HTMLElement {
connectedCallback() {
this.render();
}
render() {
let datas = JSON.parse(this.getAttribute('datas'));
let elementType = this.getAttribute('element');
this.template = this.innerHTML;
console.log(elementType);
let htmlContent = elementType !== null ? `<${elementType.toLowerCase()}>` : '';
datas.forEach(elem => {
htmlContent += this.interpolate(this.template, elem)}
);
htmlContent += elementType !== null ? `</${elementType.toLowerCase()}>` : '';
this.innerHTML = htmlContent;
}
interpolate(template, obj) {
for(var key in obj) {
const pattern = "${" + key + "}";
if(template.indexOf(pattern) > -1) {
template = template.replace(pattern, obj[key]);
delete(obj[key]);
}
};
return template;
}
}
customElements.define('company-repeat', CompanyRepeater);
My question now is, how can I make it work, no matter what's the parent element? I've added a property element
to my repeater, but it's not allowing me to declare more attribute, and it'll stick not work inside a table.
This is the only thing to prevent me from moving everything to WebComponent.