InnerHtml now allows property arrays to be used.
This commit is contained in:
parent
8259fdb9ab
commit
0ae84fc73b
@ -360,6 +360,25 @@ class IgniteTemplate {
|
|||||||
this._callbacks.push(value.attachOnSplice((list, start, deleteCount, items) => this.onInnerHTMLChanged((converter != null ? converter(list) : list), (converter != null ? converter(list) : null))));
|
this._callbacks.push(value.attachOnSplice((list, start, deleteCount, items) => this.onInnerHTMLChanged((converter != null ? converter(list) : list), (converter != null ? converter(list) : null))));
|
||||||
|
|
||||||
this._elementInnerHTML = (converter != null ? converter(value.value) : value.value);
|
this._elementInnerHTML = (converter != null ? converter(value.value) : value.value);
|
||||||
|
} else if (Array.isArray(value) && value.length > 0 && value[0] instanceof IgniteProperty) {
|
||||||
|
//There must be a converter for this to work correctly
|
||||||
|
if (!converter) {
|
||||||
|
throw "Cannot pass an array of properties without using a converter!";
|
||||||
|
}
|
||||||
|
|
||||||
|
//Attack a callback for all the properties
|
||||||
|
value.forEach(prop => {
|
||||||
|
if (prop instanceof IgniteProperty) {
|
||||||
|
this._callbacks.push(prop.attachOnChange((oldValue, newValue) => this.onInnerHTMLChanged(converter(...value.getOldPropertyValues(prop, oldValue)), converter(...value.getPropertyValues()))));
|
||||||
|
this._callbacks.push(prop.attachOnPush((list, items) => this.onInnerHTMLChanged(converter(...value.getOldPropertyValues(prop, list)), converter(...value.getPropertyValues()))));
|
||||||
|
this._callbacks.push(prop.attachOnUnshift((list, items) => this.onInnerHTMLChanged(converter(...value.getOldPropertyValues(prop, list)), converter(...value.getPropertyValues()))));
|
||||||
|
this._callbacks.push(prop.attachOnPop((list) => this.onInnerHTMLChanged(converter(...value.getOldPropertyValues(prop, list)), converter(...value.getPropertyValues()))));
|
||||||
|
this._callbacks.push(prop.attachOnShift((list) => this.onInnerHTMLChanged(converter(...value.getOldPropertyValues(prop, list)), converter(...value.getPropertyValues()))));
|
||||||
|
this._callbacks.push(prop.attachOnSplice((list, start, deleteCount, items) => this.onInnerHTMLChanged(converter(...value.getOldPropertyValues(prop, list)), converter(...value.getPropertyValues()))));
|
||||||
|
}
|
||||||
|
});
|
||||||
|
|
||||||
|
this._elementInnerHTML = converter(...value.getPropertyValues());
|
||||||
} else {
|
} else {
|
||||||
this._elementInnerHTML = (converter != null ? converter(value) : value);
|
this._elementInnerHTML = (converter != null ? converter(value) : value);
|
||||||
}
|
}
|
||||||
|
Loading…
x
Reference in New Issue
Block a user