diff --git a/ignite-html.js b/ignite-html.js
index 18851ce..80f8a13 100644
--- a/ignite-html.js
+++ b/ignite-html.js
@@ -413,6 +413,7 @@ class IgniteProperty {
/**
* Return the value of the property if we try to convert
* the property to a string.
+ * @ignore
*/
IgniteProperty.prototype.toString = function () {
if (this.value) {
@@ -462,24 +463,7 @@ Array.prototype.getOldPropertyValues = function (property, oldValue) {
* The outline of an IgniteObject which contains IgniteProperties.
*/
class IgniteObject {
- /**
- * Creates a new IgniteObject from an object and returns it.
- * @param {Any} obj The object to create an IgniteObject out of.
- * @returns {IgniteObject} The ignite object created.
- */
- constructor(obj) {
- //Only do this if the object is not an ignite object already.
- if (!(obj instanceof IgniteObject)) {
- Object.keys(obj).forEach(name => {
- var prop = new IgniteProperty(obj[name]);
- Object.defineProperty(this, name, {
- get: () => { return (IgniteRendering.rendering ? prop : prop.value); },
- set: (value) => { prop.value = value; }
- });
- });
- } else {
- return obj;
- }
+ constructor() {
}
/**
diff --git a/ignite-template.js b/ignite-template.js
index 0678213..f7d3768 100644
--- a/ignite-template.js
+++ b/ignite-template.js
@@ -1155,7 +1155,9 @@ class IgniteTemplate {
}
//Invoke any refs we have and pass back the element reference.
- this._refs.forEach((ref) => ref(this.element));
+ if (this._refs) {
+ this._refs.forEach((ref) => ref(this.element));
+ }
}
//Set the classes on this element
@@ -1285,16 +1287,7 @@ class IgniteTemplate {
* there are no memory leaks.
*/
deconstruct() {
- //Remove and disconnect all events
- if (this.element && this._events) {
- var keys = Object.keys(this._events);
- for (var i = 0; i < keys.length; i++) {
- this.element.removeEventListener(keys[i], this._events[keys[i]]);
- }
- this._events = null;
- }
-
- //Remove our element if we have one.
+ //Remove our element if we have one, this will destroy all events too.
if (this.element) {
this.element.remove();
this.element = null;
@@ -1307,40 +1300,28 @@ class IgniteTemplate {
this.children[i].deconstruct();
}
}
- this.children = null;
- }
-
- //Disconnect all callbacks
- if (this._callbacks) {
- this._callbacks.forEach((item) => item.disconnect());
- this._callbacks = null;
}
//Stop observing resize events if we need to.
if (this._resizeObserver) {
this._resizeObserver.disconnect();
this._resizeObserver = null;
- this._resizeObserverCallback = null;
}
//Stop observing intersects if we need to.
if (this._intersectObserver) {
this._intersectObserver.disconnect();
this._intersectObserver = null;
- this._intersectObserverCallback = null;
}
- //Remove any refs
+ //Invoke any refs and pass null.
if (this._refs) {
- //Pass null to our refs so that the reference is updated.
this._refs.forEach(ref => ref(null));
- this._refs = null;
}
//Invoke any custom destructors
if (this._destructors) {
this._destructors.forEach(d => d());
- this._destructors = null;
}
}