var Temme=function(e){var t={};function s(n){if(t[n])return t[n].exports;var r=t[n]={i:n,l:!1,exports:{}};return e[n].call(r.exports,r,r.exports,s),r.l=!0,r.exports}return s.m=e,s.c=t,s.d=function(e,t,n){s.o(e,t)||Object.defineProperty(e,t,{enumerable:!0,get:n})},s.r=function(e){"undefined"!=typeof Symbol&&Symbol.toStringTag&&Object.defineProperty(e,Symbol.toStringTag,{value:"Module"}),Object.defineProperty(e,"__esModule",{value:!0})},s.t=function(e,t){if(1&t&&(e=s(e)),8&t)return e;if(4&t&&"object"==typeof e&&e&&e.__esModule)return e;var n=Object.create(null);if(s.r(n),Object.defineProperty(n,"default",{enumerable:!0,value:e}),2&t&&"string"!=typeof e)for(var r in e)s.d(n,r,function(t){return e[t]}.bind(null,r));return n},s.n=function(e){var t=e&&e.__esModule?function(){return e.default}:function(){return e};return s.d(t,"a",t),t},s.o=function(e,t){return Object.prototype.hasOwnProperty.call(e,t)},s.p="",s(s.s=0)}([function(e,t,s){"use strict";s.r(t),s.d(t,"parse",(function(){return z})),s.d(t,"validate",(function(){return U}));class n{constructor(e,t,s,n,r=!1){this.label=e,this.type=t,this.values=s,this.default=n,this.inherited=r}static validateOptionType(e,t){let s="";return s=Array.isArray(e)?"array":typeof e,{valid:s===t.type,type:s}}static validateOptionValue(e,t){if(null!=t&&t.values.length>0){if("include"!==t.label&&"exclude"!==t.label)return-1!==t.values.indexOf(e);for(const s of e)if(-1===t.values.indexOf(s))return!1}return!0}}n.validateOptionName=e=>null!=e;class r extends n{constructor(){super("ref","string",[],""),this.getKeyFromElement=e=>null}inherit(e,t){}}class o extends n{constructor(){super("value","string",[],""),this.getKeyFromElement=e=>null}inherit(e,t){}}class i extends n{constructor(){super("type","string",["text","html"],"text"),this.getKeyFromElement=e=>null}inherit(e,t){}}class a extends n{constructor(){super("mode","string",["append","override"],"append"),this.getKeyFromElement=e=>null}inherit(e,t){}}class l extends n{constructor(){super("placement","string",["after","before"],"after"),this.getKeyFromElement=e=>null}inherit(e,t){}}class c extends n{constructor(){super("allow","boolean",[],!1),this.getKeyFromElement=e=>null}inherit(e,t){}}class h extends n{constructor(){super("children","object",[],{allow:(new c).default,placement:(new l).default}),this.keys={allow:new c,placement:new l},this.getKeyFromElement=e=>null}inherit(e,t){}}class u extends n{constructor(){super("include","array",["name","id","classes","attributes","dataset","content","childNodes"],["name","id","classes","attributes","dataset","content","childNodes"]),this.getKeyFromElement=e=>null}inherit(e,t){}}class d extends n{constructor(){super("exclude","array",["name","id","classes","attributes","dataset","content","childNodes"],[]),this.getKeyFromElement=e=>null}inherit(e,t){}}const f=[new r,new class extends n{constructor(){super("name","string",[],"div",!0),this.getKeyFromElement=e=>null}inherit(e,t){null!=t&&"override"===e.from.mode&&(e.name=t)}},new class extends n{constructor(){super("id","string",[],"",!0),this.getKeyFromElement=e=>e.id}inherit(e,t){""!==t&&("append"===e.from.mode?""===e.id&&(e.id=t):e.id=t)}parse(e,t){""!=t.id&&(e.id=t.id)}},new class extends n{constructor(){super("content","object",[],{type:(new i).default,value:(new o).default},!0),this.keys={type:new i,value:new o}}inherit(e,t){let s=t.value;""!==t.value&&("append"===e.from.mode?s=`${e.content.value}${s.length>0?" ":""}${s}`:e.content=t,e.content.value=s)}getKeyFromElement(e){return{type:"html",value:e.innerHTML}}parse(e,t){""!=t.content.value&&("text"===t.content.type?e.textContent=t.content.value:e.innerHTML=t.content.value)}},new class extends n{constructor(){super("temmeIds","array",[],[]),this.getKeyFromElement=e=>null}inherit(e,t){}},new class extends n{constructor(){super("templates","array",[],[]),this.getKeyFromElement=e=>null}inherit(e,t){}},new class extends n{constructor(){super("classes","array",[],[],!0)}inherit(e,t){"append"===e.from.mode?e.classes.push(...t):e.classes=t,e.classes=e.classes.filter((t,s)=>e.classes.indexOf(t)===s),e.classes.sort()}getKeyFromElement(e){let t=[];return e.classList.forEach(e=>t.push(e)),t}parse(e,t){t.classes.length>0&&e.classList.add(...t.classes)}},new class extends n{constructor(){super("childNodes","array",[],[],!0),this.getKeyFromElement=e=>e.innerHTML}inherit(e,t){let s=[...e.childNodes];!0===e.from.children.allow&&("append"===e.from.mode?"before"===e.from.children.placement?s.unshift(...t):s.push(...t):s=t),e.childNodes=s}},new class extends n{constructor(){super("attributes","object",[],{},!0)}inherit(e,t){const s=Object.assign({},t);if("append"===e.from.mode)for(const t in e.attributes)s[t]=e.attributes[t];else for(const t in e.attributes)t in s||(s[t]=e.attributes[t]);e.attributes=s}getKeyFromElement(e){let t={};for(const s in e.attributes)isNaN(parseInt(s))||-1!==["id","class"].indexOf(e.attributes[s].nodeName)||"data-"===e.attributes[s].nodeName.substring(0,5)||(t[e.attributes[s].nodeName]=e.attributes[s].nodeValue);return t}parse(e,t){for(const s in t.attributes)e.setAttribute(s,t.attributes[s])}},new class extends n{constructor(){super("dataset","object",[],{},!0)}inherit(e,t){const s=Object.assign({},t);if("append"===e.from.mode)for(const t in e.dataset)s[t]=e.dataset[t];else for(const t in e.dataset)t in s||(s[t]=e.dataset[t]);e.dataset=s}getKeyFromElement(e){let t={};for(const s in e.dataset)t[s]=e.dataset[s];return t}parse(e,t){for(const s in t.dataset)e.dataset[s]=t.dataset[s]}},new class extends n{constructor(){super("from","object",[],{ref:(new r).default,mode:(new a).default,children:(new h).default,include:(new u).default,exclude:(new d).default}),this.keys={ref:new r,mode:new a,children:new h,include:new u,exclude:new d},this.getKeyFromElement=e=>null}inherit(e,t){}}],m=function(){let e=[];return f.forEach(t=>{if(e.push(t),"keys"in t){const s=function e(t){let s=[];for(const n in t.keys){const r=t.keys[n];if(s.push(r),"keys"in r){const t=e(r);s=s.concat(t)}}return s}(t);e=e.concat(s)}}),e}(),p=["name","childNodes","templates"];function g(e){const t=[];return m.forEach(s=>{if("keys"in s&&s.label===e)for(const e in s.keys){const n=s.keys[e];t.push(n)}}),t}class y extends Error{constructor(e){super(),this.name="TemmyError",this.message="Temme isn't feeling good",this.message=e.length>0?e:this.message}}class w extends y{constructor(e){super(""),this.name="InvalidTemplateOptionError",this.message="A template has an invalid option";const t=`“${e}” is not a valid option to use in templates`;this.message=e.length>0?t:this.message}}class b extends y{constructor(e){super(""),this.name="InvalidOptionNameError",this.message="An option is not valid";const t=`“${e}” is not a valid option`;this.message=e.length>0?t:this.message}}class v extends y{constructor(e,t){super(""),this.name="InvalidOptionTypeError",this.message="An option doesn't have a valid value type";const s=`The “${e}” option doesn't accept values of type “${t}”`;this.message=e.length>0?s:this.message}}class E extends y{constructor(e,t){super(""),this.name="InvalidOptionValueError",this.message="An option doesn't have a valid value";const s=`The “${e}” option doesn't accept “${t}” as a value`;this.message=e.length>0?s:this.message}}class x extends y{constructor(e,t){super(""),this.name="InvalidSubOptionNameError",this.message="A sub-option is not valid";const s=`The “${e}” option doesn't not recognize “${t}” as a valid sub-option`;this.message=e.length>0||t.length>0?s:this.message}}class N extends y{constructor(e,t){super(""),this.name="InvalidSubOptionTypeError",this.message="A sub-option doesn't have a valid value type";const s=`The “${e}” sub-option doesn't accept values of type “${t}”`;this.message=e.length>0||t.length>0?s:this.message}}class O extends y{constructor(e,t){super(""),this.name="InvalidSubOptionValueError",this.message="A sub-option doesn't have a valid value";const s=`The “${e}” sub-option doesn't accept “${t}” as a value`;this.message=e.length>0||t.length>0?s:this.message}}class T extends y{constructor(e){super(""),this.name="InvalidReferencingOptionError",this.message="A referencing option is not valid",this.message=e.length>0?e:this.message}}class k extends y{constructor(e){super(""),this.name="InvalidReferenceOptionValueError",this.message="“ref” options must not begin with the “@” symbol",this.message=e.length>0?e:this.message}}class I extends y{constructor(e){super(""),this.name="InvalidReferenceError",this.message="A reference is invalid",this.message=e.length>0?`“${e}” is an invalid reference`:this.message}}class F extends y{constructor(e){super(""),this.name="InvalidTemplateError",this.message="A template does not have a “ref” option",this.message=e.length>0?e:this.message}}function K(e,t=[],s=!1){try{const n=function(e=!1){const t="0123456789abcdefghijklmnopqrstuvwxyz",s=!1===e?6:4;let n="";for(let e=0;e{K(t,e.temmeIds)}),"templates"in e&&e.templates.forEach(t=>{K(t,e.temmeIds,!0)})}catch(e){throw e}}function $(e){return e.temmeIds[e.temmeIds.length-1]}class j extends y{constructor(e,t){super(""),this.name="InvalidTemplateReferencingError",this.message="Templates can only reference other templates.";const s=`The template with the reference “${e}” is trying to reference “${t}” a non-template object`;this.message=e.length>0?s:this.message}}class A extends y{constructor(e){super(""),this.name="ReferenceOutOfScopeError",this.message="An object is referencing an element out of its scope",this.message=e.length>0?e:this.message}}function M(e){try{for(const t in e){const s=f.filter(e=>e.label===t)[0],r=e[t];if(!1===n.validateOptionName(s))throw new b(t);const o=n.validateOptionType(r,s);if(!1===o.valid)throw new v(t,o.type);if(!1===n.validateOptionValue(r,s))throw new E(t,r);if("keys"in s){const e=s.keys;L(t,r,e)}}if(!1===function(e){if("from"in e)return"ref"in e.from;return!0}(e))throw new T("The “from” option must always have a “ref” sub-option");if(!1===function(e){if("from"in e)return!("include"in e.from&&"exclude"in e.from);return!0}(e))throw new T("The “from” option can't have both the “include” and “exclude” sub-options at the same time");"templates"in e&&e.templates.forEach(e=>{!function(e){try{if(!("ref"in e))throw new F("");for(const t in e){if(p.indexOf(t)>-1)throw new w(t);M(e)}}catch(e){throw e}}(e)}),"childNodes"in e&&e.childNodes.forEach(e=>{M(e)})}catch(e){throw e}}const S=(e,t)=>null!=t.filter(t=>t.hierarchy.ref===e.from.ref&&$(e)!==$(t.hierarchy))[0];function L(e,t,s){for(const r in t){const o=g(e).filter(e=>e.label===r)[0],i=t[r];if(!(r in s))throw new x(e,r);{if(!1===n.validateOptionName(o))throw new x(e,r);const s=n.validateOptionType(i,o);if(!1===s.valid)throw new N(r,s.type);if(!1===n.validateOptionValue(i,o))throw new O(r,i);if("keys"in o){const e=t[r];L(r,e,o.keys)}}}}function V(e){try{f.forEach(t=>{if(t.label in e){if("keys"in t)for(const s in t.keys){const n=t.keys[s];H(e[t.label],n)}}else e[t.label]=t.default}),e.classes=e.classes.filter((t,s)=>e.classes.indexOf(t)===s),e.classes.sort(),"childNodes"in e&&e.childNodes.length>0&&e.childNodes.forEach(e=>{V(e)}),"templates"in e&&e.templates.length>0&&e.templates.forEach(e=>{!function(e){try{f.filter(e=>-1===p.indexOf(e.label)).forEach(t=>{if(t.label in e){if("keys"in t)for(const s in t.keys){const n=t.keys[s];H(e[t.label],n)}}else e[t.label]=t.default})}catch(e){throw e}}(e)})}catch(e){throw e}}function H(e,t){try{if(t.label in e?"include"!==t.label&&"exclude"!==t.label||(e[t.label]=e[t.label].filter((s,n)=>e[t.label].indexOf(s)===n),e[t.label].sort()):e[t.label]=t.default,"keys"in t)for(const s in t.keys){const n=e[t.label];H(n,t.keys[s])}}catch(e){throw e}}function _(e){try{const t=function e(t,s=0){const n=[];s++,""!==t.ref&&n.push({depth:s,hierarchy:t});"childNodes"in t&&t.childNodes.length>0&&t.childNodes.forEach(t=>{n.push(...e(t,s))});"templates"in t&&t.templates.length>0&&t.templates.forEach(t=>{n.push(...e(t,s-1))});return n}(e);!function e(t,s){try{if("@"===t.ref[0])throw new k("");if("@"===t.from.ref[0]){const e=t.from.ref.substring(1);if(null==document.querySelector(e))throw new k(`No outer element corresponds to the selector “${e}”`)}else if(!1===S(t,s)&&""!==t.from.ref)throw new I(t.from.ref);"childNodes"in t&&t.childNodes.length>0&&t.childNodes.forEach(t=>{e(t,s)}),"templates"in t&&t.templates.length>0&&t.templates.forEach(t=>{e(t,s)})}catch(e){throw e}}(e,t),function e(t,s){try{const n=t.templates;n.length>0&&n.forEach(e=>{if(e.from.ref.length>0){if(!1===(4===$(s.filter(t=>t.hierarchy.ref===e.from.ref)[0].hierarchy).length))throw new j(e.ref,e.from.ref)}}),t.childNodes.forEach(t=>{e(t,s)})}catch(e){throw e}}(e,t),function e(t,s,n=0){try{const r=t.from.ref;if(n++,""!==r&&"@"!==r[0]){if(null==s.filter(e=>e.hierarchy.ref===r&&n>=e.depth)[0])throw new A("")}"childNodes"in t&&t.childNodes.length>0&&t.childNodes.forEach(t=>{e(t,s,n)}),"templates"in t&&t.templates.length>0&&t.templates.forEach(t=>{e(t,s,n)})}catch(e){throw e}}(e,t),function e(t,s){try{"templates"in t&&t.templates.length>0&&t.templates.forEach(e=>{if(""!==e.from.ref)for(const t in e){const n=f.filter(e=>e.label===t)[0],r=s.filter(t=>t.hierarchy.ref===e.from.ref)[0];n.inherit(e,r.hierarchy[t])}}),"childNodes"in t&&t.childNodes.length>0&&t.childNodes.forEach(t=>{e(t,s)})}catch(e){throw e}}(e,t.filter(e=>P(e.hierarchy))),function e(t,s){try{if("childNodes"in t&&t.childNodes.length>0&&t.childNodes.forEach(t=>{e(t,s)}),""!==t.from.ref)if("@"===t.from.ref[0]){const e=t.from.ref.substring(1),s=document.querySelector(e);for(const e in t){const n=f.filter(t=>t.label===e)[0],r=n.getKeyFromElement(s);null!=r&&n.inherit(t,r)}}else{const e=s.filter(e=>e.hierarchy.ref===t.from.ref)[0];t.from.include.filter(e=>-1===t.from.exclude.indexOf(e)).forEach(s=>{f.filter(e=>e.label===s)[0].inherit(t,e.hierarchy[s])})}}catch(e){throw e}}(e,t)}catch(e){throw e}}const P=e=>4===$(e).length;function R(e,t,s,n=!1){try{const r=function(e,t,s=!1){try{const n=!0===s?t:document.createElement(e.name);return f.forEach(t=>{"function"==typeof t.parse&&t.parse(n,e)}),!1===s&&t.appendChild(n),n}catch(e){throw e}}(e,t,n);s($(e),e),"childNodes"in e&&e.childNodes.length>0&&e.childNodes.forEach(e=>{R(e,r,s)})}catch(e){throw e}}class q extends y{constructor(e){super(""),this.name="InvalidHierarchyError",this.message="The hierarchy object is not valid",this.message=e.length>0?e:this.message}}class C extends y{constructor(e){super(""),this.name="InvalidTargetError",this.message="The target is not a valid HTML element",this.message=e.length>0?e:this.message}}function z(e,t,s=(e=>{}),n=(()=>{})){try{if(!(e=>null!=e&&e instanceof HTMLElement)(t))throw new C("");if(!(e=>null!=e&&"object"==typeof e&&!Array.isArray(e))(e))throw new q("");return M(e),V(e),K(e),_(e),R(e,t,n,!0),s(e),e}catch(e){throw e.message=`[Temme]: ${e.message}.`,e}}function U(e){try{return M(e),{valid:!0,error:null}}catch(e){return{valid:!1,error:e}}}}]); //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["webpack://Temme/webpack/bootstrap","webpack://Temme/src/C:/Users/user 22/Documents/Projects/other/temmejs/src/modules/models/Option.ts","webpack://Temme/src/C:/Users/user 22/Documents/Projects/other/temmejs/src/modules/options/RefOption.ts","webpack://Temme/src/C:/Users/user 22/Documents/Projects/other/temmejs/src/modules/options/sub-options/ValueSubOption.ts","webpack://Temme/src/C:/Users/user 22/Documents/Projects/other/temmejs/src/modules/options/sub-options/ContentTypeSubOption.ts","webpack://Temme/src/C:/Users/user 22/Documents/Projects/other/temmejs/src/modules/options/sub-options/ModeSubOption.ts","webpack://Temme/src/C:/Users/user 22/Documents/Projects/other/temmejs/src/modules/options/sub-options/PlacementSubOption.ts","webpack://Temme/src/C:/Users/user 22/Documents/Projects/other/temmejs/src/modules/options/sub-options/ChildrenAllowSubOption.ts","webpack://Temme/src/C:/Users/user 22/Documents/Projects/other/temmejs/src/modules/options/sub-options/ChildrenSubOption.ts","webpack://Temme/src/C:/Users/user 22/Documents/Projects/other/temmejs/src/modules/options/sub-options/IncludeSubOption.ts","webpack://Temme/src/C:/Users/user 22/Documents/Projects/other/temmejs/src/modules/options/sub-options/ExcludeSubOption.ts","webpack://Temme/src/C:/Users/user 22/Documents/Projects/other/temmejs/src/modules/options.ts","webpack://Temme/src/C:/Users/user 22/Documents/Projects/other/temmejs/src/modules/options/NameOption.ts","webpack://Temme/src/C:/Users/user 22/Documents/Projects/other/temmejs/src/modules/options/IdOption.ts","webpack://Temme/src/C:/Users/user 22/Documents/Projects/other/temmejs/src/modules/options/ContentOption.ts","webpack://Temme/src/C:/Users/user 22/Documents/Projects/other/temmejs/src/modules/options/TemmeIdsOption.ts","webpack://Temme/src/C:/Users/user 22/Documents/Projects/other/temmejs/src/modules/options/TemplatesOption.ts","webpack://Temme/src/C:/Users/user 22/Documents/Projects/other/temmejs/src/modules/options/ClassesOption.ts","webpack://Temme/src/C:/Users/user 22/Documents/Projects/other/temmejs/src/modules/options/ChildrenNodesOption.ts","webpack://Temme/src/C:/Users/user 22/Documents/Projects/other/temmejs/src/modules/options/AttributesOption.ts","webpack://Temme/src/C:/Users/user 22/Documents/Projects/other/temmejs/src/modules/options/DatasetOption.ts","webpack://Temme/src/C:/Users/user 22/Documents/Projects/other/temmejs/src/modules/options/FromOption.ts","webpack://Temme/src/C:/Users/user 22/Documents/Projects/other/temmejs/src/modules/models/TemmyError.ts","webpack://Temme/src/C:/Users/user 22/Documents/Projects/other/temmejs/src/modules/errors/InvalidTemplateOptionError.ts","webpack://Temme/src/C:/Users/user 22/Documents/Projects/other/temmejs/src/modules/errors/InvalidOptionNameError.ts","webpack://Temme/src/C:/Users/user 22/Documents/Projects/other/temmejs/src/modules/errors/InvalidOptionTypeError.ts","webpack://Temme/src/C:/Users/user 22/Documents/Projects/other/temmejs/src/modules/errors/InvalidOptionValueError.ts","webpack://Temme/src/C:/Users/user 22/Documents/Projects/other/temmejs/src/modules/errors/InvalidSubOptionNameError.ts","webpack://Temme/src/C:/Users/user 22/Documents/Projects/other/temmejs/src/modules/errors/InvalidSubOptionTypeError.ts","webpack://Temme/src/C:/Users/user 22/Documents/Projects/other/temmejs/src/modules/errors/InvalidSubOptionValueError.ts","webpack://Temme/src/C:/Users/user 22/Documents/Projects/other/temmejs/src/modules/errors/InvalidReferencingOptionError.ts","webpack://Temme/src/C:/Users/user 22/Documents/Projects/other/temmejs/src/modules/errors/InvalidReferenceOptionValueError.ts","webpack://Temme/src/C:/Users/user 22/Documents/Projects/other/temmejs/src/modules/errors/InvalidReferenceError.ts","webpack://Temme/src/C:/Users/user 22/Documents/Projects/other/temmejs/src/modules/errors/InvalidTemplateError.ts","webpack://Temme/src/C:/Users/user 22/Documents/Projects/other/temmejs/src/modules/idfier.ts","webpack://Temme/src/C:/Users/user 22/Documents/Projects/other/temmejs/src/modules/errors/InvalidTemplateReferencingError.ts","webpack://Temme/src/C:/Users/user 22/Documents/Projects/other/temmejs/src/modules/errors/ReferenceOutOfScopeError.ts","webpack://Temme/src/C:/Users/user 22/Documents/Projects/other/temmejs/src/modules/validator.ts","webpack://Temme/src/C:/Users/user 22/Documents/Projects/other/temmejs/src/modules/sanitizer.ts","webpack://Temme/src/C:/Users/user 22/Documents/Projects/other/temmejs/src/modules/referencer.ts","webpack://Temme/src/C:/Users/user 22/Documents/Projects/other/temmejs/src/modules/parser.ts","webpack://Temme/src/C:/Users/user 22/Documents/Projects/other/temmejs/src/modules/errors/InvalidHierarchyError.ts","webpack://Temme/src/C:/Users/user 22/Documents/Projects/other/temmejs/src/modules/errors/InvalidTargetError.ts","webpack://Temme/src/C:/Users/user 22/Documents/Projects/other/temmejs/src/temme.ts"],"names":["installedModules","__webpack_require__","moduleId","exports","module","i","l","modules","call","m","c","d","name","getter","o","Object","defineProperty","enumerable","get","r","Symbol","toStringTag","value","t","mode","__esModule","ns","create","key","bind","n","object","property","prototype","hasOwnProperty","p","s","Option","label","type","values","defaultValue","inherited","this","default","matchingOption","optionType","Array","isArray","valid","length","indexOf","val","validateOptionName","super","getKeyFromElement","element","hierarchy","ref","allow","placement","keys","options","from","id","content","ct","innerHTML","textContent","temmeIds","templates","classes","push","filter","cls","index","sort","classList","forEach","add","childNodes","children","unshift","attributes","attr","attrKey","isNaN","parseInt","nodeName","substring","nodeValue","dataKey","setAttribute","dataset","dt","include","exclude","allOptions","opt","subOptions","getAllSubOptions","option","allSubOptions","subOption","opts","concat","getAllOptions","forbiddenOptions","getSubOptions","TemmyError","Error","message","reference","idfy","temmeId","chars","max","Math","floor","random","uppercase","toUpperCase","generateTemmeId","child","template","e","getTemmeId","target","validateOptions","optionValue","typeValidation","validateOptionType","validateOptionValue","validateSubOptions","validateReferencingOption","validateReferencingRange","validateTemplates","validateReference","references","optionName","matchingSubOption","subOptionValue","sanitize","sanitizeOption","sanitizeTemplate","subHierarchy","process","getReferences","depth","validateReferences","selector","document","querySelector","validateTemplateReference","validateParentToChildReference","refObject","processTemplates","referencedHierarchy","inherit","processHierarchies","optName","parse","parent","nodeCallback","topParent","createElement","appendChild","parseElement","endCallback","HTMLElement","validate","error","err"],"mappings":"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","file":"temme.js","sourcesContent":[" \t// The module cache\n \tvar installedModules = {};\n\n \t// The require function\n \tfunction __webpack_require__(moduleId) {\n\n \t\t// Check if module is in cache\n \t\tif(installedModules[moduleId]) {\n \t\t\treturn installedModules[moduleId].exports;\n \t\t}\n \t\t// Create a new module (and put it into the cache)\n \t\tvar module = installedModules[moduleId] = {\n \t\t\ti: moduleId,\n \t\t\tl: false,\n \t\t\texports: {}\n \t\t};\n\n \t\t// Execute the module function\n \t\tmodules[moduleId].call(module.exports, module, module.exports, __webpack_require__);\n\n \t\t// Flag the module as loaded\n \t\tmodule.l = true;\n\n \t\t// Return the exports of the module\n \t\treturn module.exports;\n \t}\n\n\n \t// expose the modules object (__webpack_modules__)\n \t__webpack_require__.m = modules;\n\n \t// expose the module cache\n \t__webpack_require__.c = installedModules;\n\n \t// define getter function for harmony exports\n \t__webpack_require__.d = function(exports, name, getter) {\n \t\tif(!__webpack_require__.o(exports, name)) {\n \t\t\tObject.defineProperty(exports, name, { enumerable: true, get: getter });\n \t\t}\n \t};\n\n \t// define __esModule on exports\n \t__webpack_require__.r = function(exports) {\n \t\tif(typeof Symbol !== 'undefined' && Symbol.toStringTag) {\n \t\t\tObject.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n \t\t}\n \t\tObject.defineProperty(exports, '__esModule', { value: true });\n \t};\n\n \t// create a fake namespace object\n \t// mode & 1: value is a module id, require it\n \t// mode & 2: merge all properties of value into the ns\n \t// mode & 4: return value when already ns object\n \t// mode & 8|1: behave like require\n \t__webpack_require__.t = function(value, mode) {\n \t\tif(mode & 1) value = __webpack_require__(value);\n \t\tif(mode & 8) return value;\n \t\tif((mode & 4) && typeof value === 'object' && value && value.__esModule) return value;\n \t\tvar ns = Object.create(null);\n \t\t__webpack_require__.r(ns);\n \t\tObject.defineProperty(ns, 'default', { enumerable: true, value: value });\n \t\tif(mode & 2 && typeof value != 'string') for(var key in value) __webpack_require__.d(ns, key, function(key) { return value[key]; }.bind(null, key));\n \t\treturn ns;\n \t};\n\n \t// getDefaultExport function for compatibility with non-harmony modules\n \t__webpack_require__.n = function(module) {\n \t\tvar getter = module && module.__esModule ?\n \t\t\tfunction getDefault() { return module['default']; } :\n \t\t\tfunction getModuleExports() { return module; };\n \t\t__webpack_require__.d(getter, 'a', getter);\n \t\treturn getter;\n \t};\n\n \t// Object.prototype.hasOwnProperty.call\n \t__webpack_require__.o = function(object, property) { return Object.prototype.hasOwnProperty.call(object, property); };\n\n \t// __webpack_public_path__\n \t__webpack_require__.p = \"\";\n\n\n \t// Load entry module and return exports\n \treturn __webpack_require__(__webpack_require__.s = 0);\n","/**\r\n * The hierarchy's option model.\r\n * What defines a valid option.\r\n */\r\n\r\n\r\n import { Hierarchy } from \"./Hierarchy\";\r\n\r\n\r\n/**\r\n * The interface that indicates\r\n * sub-options.\r\n */\r\nexport interface IKeys {\r\n\r\n    keys: any;\r\n}\r\n\r\n\r\n/**\r\n * The interface for options that have to parse their\r\n * respective values into a specific HTML element.\r\n */\r\nexport interface IParser {\r\n\r\n    parse: (element: HTMLElement, hierarchy: Hierarchy) => void\r\n}\r\n\r\n\r\n/**\r\n * The option's class.\r\n */\r\nexport default abstract class Option {\r\n\r\n    /**\r\n     * The name of the option.\r\n     */\r\n    public label: string;\r\n\r\n    /**\r\n     * The data type of the option.\r\n     */\r\n    public type: string;\r\n\r\n    /**\r\n     * The possible values of the option.\r\n     */\r\n    public values: Array<any>;\r\n\r\n    /**\r\n     * The default value of the option.\r\n     */\r\n    public default: any;\r\n\r\n    /**\r\n     * Whether or not an option is inherited.\r\n     */\r\n    public inherited: boolean;\r\n    \r\n\r\n    /**\r\n     * Constructor with parameters.\r\n     * \r\n     * @param label The name of the option.\r\n     * @param type The data type of the option.\r\n     * @param defaultValue The default value of the option.\r\n     * @param values The possible values of the option.\r\n     */\r\n    constructor(label: string, type: string, values: Array<any>, defaultValue: any, inherited: boolean = false) {\r\n\r\n        this.label = label;\r\n        this.type = type;\r\n        this.values = values;\r\n        this.default = defaultValue;\r\n        this.inherited = inherited;\r\n    }\r\n\r\n\r\n    /**\r\n     * Performs inheritance process on an option.\r\n     */\r\n    public abstract inherit (hierarchy: any, value: any): void\r\n\r\n\r\n    /**\r\n     * Get an option value from an existing HTML element.\r\n     */\r\n    public abstract getKeyFromElement (element: HTMLElement): any\r\n\r\n\r\n    /**\r\n     * Validates the option's name.\r\n     * \r\n     * @param matchingOption The option object with the matching name.\r\n     * \r\n     */\r\n    public static validateOptionName = (matchingOption: Option): boolean => matchingOption != null;\r\n\r\n\r\n    /**\r\n     * Validates the data type of the option.\r\n     * \r\n     * @param value The value of the option.\r\n     * @param matchingOption The option object with the matching name.\r\n     * \r\n     */\r\n    public static validateOptionType(value: any, matchingOption: Option): { valid: boolean, type: string } {\r\n\r\n        let optionType: string = \"\";\r\n\r\n        // Getting the appropriate data type.\r\n        if (Array.isArray(value)) {\r\n            optionType = \"array\";\r\n        } else {\r\n            optionType = typeof value;\r\n        }\r\n\r\n        return {\r\n            valid: optionType === matchingOption.type,\r\n            type: optionType\r\n        }\r\n    }\r\n\r\n\r\n    /**\r\n     * Validates the option's value.\r\n     * \r\n     * @param value The value to check.\r\n     * @param matchingOption The option object with the matching name.\r\n     * \r\n     */\r\n    public static validateOptionValue(value: any, matchingOption: Option): boolean {\r\n        \r\n        // Checking if the matching object is valid.\r\n        if (matchingOption != null && matchingOption.values.length > 0) {\r\n            \r\n\r\n            if (matchingOption.label === 'include' || matchingOption.label === 'exclude') {\r\n\r\n                for (const val of value) {\r\n                    \r\n                    if (matchingOption.values.indexOf(val) === -1) {\r\n                        return false;\r\n                    }\r\n                }\r\n            } else {\r\n\r\n                // Checking if the value is not a valid one.\r\n                return matchingOption.values.indexOf(value) !== -1;\r\n            }\r\n        }\r\n\r\n        return true;\r\n    }\r\n}\r\n","/**\r\n * The reference option model.\r\n */\r\n\r\n\r\nimport Option from \"../models/Option\";\r\n\r\n\r\nexport default class RefOption extends Option {\r\n\r\n    /**\r\n     * Parameterless constructor.\r\n     */\r\n    constructor() {\r\n\r\n        super('ref', 'string', [], '');\r\n    }\r\n\r\n\r\n    /**\r\n     * Performs inheritance process on an option.\r\n     * \r\n     * @param hierarchy The hierarchy object that inherits.\r\n     * @param ref The ref to inherit.\r\n     */\r\n    public inherit(hierarchy: any, ref: any): void { }\r\n\r\n\r\n    /**\r\n     * Gets nothing from a given HTML element.\r\n     * \r\n     * @param element The HTML element to target. \r\n     */\r\n    public getKeyFromElement = (element: HTMLElement): any => null;\r\n}\r\n","/**\r\n * The value sub option model.\r\n */\r\n\r\n\r\nimport Option from \"../../models/Option\";\r\n\r\n\r\nexport default class ValueSubOption extends Option {\r\n\r\n    /**\r\n     * Parameterless constructor.\r\n     */\r\n    constructor() {\r\n\r\n        super('value', 'string', [], '');\r\n    }\r\n\r\n    /**\r\n     * Performs inheritance process on an option.\r\n     * \r\n     * @param hierarchy The hierarchy object that inherits.\r\n     * @param value The value to inherit.\r\n     */\r\n    public inherit(hierarchy: any, value: any): void { }\r\n\r\n\r\n    /**\r\n     * Gets nothing from a given HTML element.\r\n     * \r\n     * @param element The HTML element to target. \r\n     */\r\n    public getKeyFromElement = (element: HTMLElement): any => null;\r\n}\r\n","/**\r\n * The content type sub option model.\r\n */\r\n\r\n\r\nimport Option from \"../../models/Option\";\r\n\r\n\r\nexport default class ContentTypeSubOption extends Option {\r\n\r\n    /**\r\n     * Parameterless constructor.\r\n     */\r\n    constructor() {\r\n\r\n        super('type', 'string', ['text', 'html'], 'text');\r\n    }\r\n\r\n\r\n    /**\r\n     * Performs inheritance process on an option.\r\n     * \r\n     * @param hierarchy The hierarchy object that inherits.\r\n     * @param value The value to inherit.\r\n     */\r\n    public inherit(hierarchy: any, value: any): void { }\r\n\r\n\r\n    /**\r\n     * Gets nothing from a given HTML element.\r\n     * \r\n     * @param element The HTML element to target. \r\n     */\r\n    public getKeyFromElement = (element: HTMLElement): any => null;\r\n}\r\n","/**\r\n * The mode sub option model.\r\n */\r\n\r\n\r\nimport Option from \"../../models/Option\";\r\n\r\n\r\nexport default class ModeSubOption extends Option {\r\n\r\n    /**\r\n     * Parameterless constructor.\r\n     */\r\n    constructor() {\r\n\r\n        super('mode', 'string', ['append', 'override'], 'append');\r\n    }\r\n\r\n    /**\r\n     * Performs inheritance process on an option.\r\n     * \r\n     * @param hierarchy The hierarchy object that inherits.\r\n     * @param value The value to inherit.\r\n     */\r\n    public inherit(hierarchy: any, value: any): void { }\r\n\r\n\r\n    /**\r\n     * Gets nothing from a given HTML element.\r\n     * \r\n     * @param element The HTML element to target. \r\n     */\r\n    public getKeyFromElement = (element: HTMLElement): any => null;\r\n}\r\n","/**\r\n * The placement sub option model.\r\n */\r\n\r\n\r\nimport Option from \"../../models/Option\";\r\n\r\n\r\nexport default class PlacementSubOption extends Option {\r\n\r\n    /**\r\n     * Parameterless constructor.\r\n     */\r\n    constructor() {\r\n\r\n        super('placement', 'string', ['after', 'before'], 'after');\r\n    }\r\n\r\n    /**\r\n     * Performs inheritance process on an option.\r\n     * \r\n     * @param hierarchy The hierarchy object that inherits.\r\n     * @param value The value to inherit.\r\n     */\r\n    public inherit(hierarchy: any, value: any): void { }\r\n\r\n\r\n    /**\r\n     * Gets nothing from a given HTML element.\r\n     * \r\n     * @param element The HTML element to target. \r\n     */\r\n    public getKeyFromElement = (element: HTMLElement): any => null;\r\n}\r\n","/**\r\n * The allow sub option model for the from-children option.\r\n */\r\n\r\n\r\nimport Option from \"../../models/Option\";\r\n\r\n\r\nexport default class ChildrenAllowSubOption extends Option {\r\n\r\n    /**\r\n     * Parameterless constructor.\r\n     */\r\n    constructor() {\r\n\r\n        super('allow', 'boolean', [], false);\r\n    }\r\n\r\n    \r\n    /**\r\n     * Performs inheritance process on an option.\r\n     * \r\n     * @param hierarchy The hierarchy object that inherits.\r\n     * @param value The value to inherit.\r\n     */\r\n    public inherit(hierarchy: any, value: any): void { }\r\n\r\n\r\n    /**\r\n     * Gets nothing from a given HTML element.\r\n     * \r\n     * @param element The HTML element to target. \r\n     */\r\n    public getKeyFromElement = (element: HTMLElement): any => null;\r\n}\r\n","/**\r\n * The children sub option model.\r\n */\r\n\r\n\r\nimport Option, { IKeys } from \"../../models/Option\";\r\nimport PlacementSubOption from \"./PlacementSubOption\";\r\nimport ChildrenAllowSubOption from \"./ChildrenAllowSubOption\";\r\n\r\n\r\n/**\r\n * The children sub option class\r\n * of the from option.\r\n */\r\nexport default class ChildrenSubOption extends Option implements IKeys {\r\n\r\n    /**\r\n     * The keys of the `children` sub option.\r\n     */\r\n    public keys: FromChildrenKeys = {\r\n        allow: new ChildrenAllowSubOption(),\r\n        placement: new PlacementSubOption()\r\n    };\r\n\r\n    /**\r\n     * Parameterless constructor.\r\n     */\r\n    constructor() {\r\n\r\n        super('children', 'object', [], {\r\n            allow: (new ChildrenAllowSubOption()).default,\r\n            placement: (new PlacementSubOption()).default\r\n        });\r\n    }\r\n\r\n    /**\r\n     * Performs inheritance process on an option.\r\n     * \r\n     * @param hierarchy The hierarchy object that inherits.\r\n     * @param value The value to inherit.\r\n     */\r\n    public inherit(hierarchy: any, value: any): void { }\r\n\r\n\r\n    /**\r\n     * Gets nothing from a given HTML element.\r\n     * \r\n     * @param element The HTML element to target. \r\n     */\r\n    public getKeyFromElement = (element: HTMLElement): any => null;\r\n}\r\n\r\n\r\n/**\r\n * The FromChildrenKeys type.\r\n */\r\ntype FromChildrenKeys = {\r\n\r\n    /**\r\n     * Whether or not to allow children inheritance.\r\n     */\r\n    allow: ChildrenAllowSubOption;\r\n\r\n    /**\r\n     * The inheritance mode.\r\n     */\r\n    placement: PlacementSubOption;\r\n}\r\n","/**\r\n * The include sub-option.\r\n */\r\n\r\n\r\nimport Option from \"../../models/Option\";\r\n\r\n\r\nexport default class IncludeSubOption extends Option {\r\n\r\n    /**\r\n     * Parameterless constructor.\r\n     */\r\n    constructor() {\r\n\r\n        super('include', 'array', ['name', 'id', 'classes', 'attributes', 'dataset', 'content', 'childNodes'], ['name', 'id', 'classes', 'attributes', 'dataset', 'content', 'childNodes']);\r\n    }\r\n\r\n    /**\r\n     * Performs inheritance process on an option.\r\n     * \r\n     * @param hierarchy The hierarchy object that inherits.\r\n     * @param value The value to inherit.\r\n     */\r\n    public inherit(hierarchy: any, value: any): void { }\r\n\r\n\r\n    /**\r\n     * Gets nothing from a given HTML element.\r\n     * \r\n     * @param element The HTML element to target. \r\n     */\r\n    public getKeyFromElement = (element: HTMLElement): any => null;\r\n}\r\n","/**\r\n * The exclude sub-option.\r\n */\r\n\r\n\r\nimport Option from \"../../models/Option\";\r\n\r\n\r\nexport default class ExcludeSubOption extends Option {\r\n\r\n    /**\r\n     * Parameterless constructor.\r\n     */\r\n    constructor() {\r\n\r\n        super('exclude', 'array', ['name', 'id', 'classes', 'attributes', 'dataset', 'content', 'childNodes'], []);\r\n    }\r\n\r\n    /**\r\n     * Performs inheritance process on an option.\r\n     * \r\n     * @param hierarchy The hierarchy object that inherits.\r\n     * @param value The value to inherit.\r\n     */\r\n    public inherit(hierarchy: any, value: any): void { }\r\n\r\n\r\n    /**\r\n     * Gets nothing from a given HTML element.\r\n     * \r\n     * @param element The HTML element to target. \r\n     */\r\n    public getKeyFromElement = (element: HTMLElement): any => null;\r\n}\r\n","/**\r\n * The list of supported options.\r\n */\r\n\r\n\r\nimport Option, { IKeys } from \"./models/Option\";\r\nimport RefOption from \"./options/RefOption\";\r\nimport NameOption from \"./options/NameOption\";\r\nimport IdOption from \"./options/IdOption\";\r\nimport ContentOption from \"./options/ContentOption\";\r\nimport TemmeIdsOption from \"./options/TemmeIdsOption\";\r\nimport TemplatesOption from \"./options/TemplatesOption\";\r\nimport ClassesOption from \"./options/ClassesOption\";\r\nimport ChildNodesOption from \"./options/ChildrenNodesOption\";\r\nimport AttributesOption from \"./options/AttributesOption\";\r\nimport DatasetOption from \"./options/DatasetOption\";\r\nimport FromOption from \"./options/FromOption\";\r\n\r\n\r\n/**\r\n * All the global options.\r\n */\r\nexport const options: Array<Option> = [\r\n    new RefOption(),\r\n    new NameOption(),\r\n    new IdOption(),\r\n    new ContentOption(),\r\n    new TemmeIdsOption(),\r\n    new TemplatesOption(),\r\n    new ClassesOption(),\r\n    new ChildNodesOption(),\r\n    new AttributesOption(),\r\n    new DatasetOption(),\r\n    new FromOption()\r\n];\r\n\r\n\r\n/**\r\n * The of the options available (including sub-options).\r\n */\r\nexport const allOptions = getAllOptions();\r\n\r\n\r\n/**\r\n * The options that are not allowed for templates.\r\n */\r\nexport const forbiddenOptions: Array<string> = ['name', 'childNodes', 'templates'];\r\n\r\n\r\n/**\r\n * Gets all the sub-options of an option.\r\n * \r\n * @param option The parent option's name.\r\n */\r\nexport function getSubOptions(option: string): Array<Option> {\r\n\r\n    const subOptions: Array<any> = [];\r\n\r\n    // Looping through all of the options.\r\n    allOptions.forEach((opt: Option) => {\r\n\r\n        if ('keys' in opt && (<Option>opt).label === option) {\r\n\r\n            for (const key in (<IKeys>opt).keys) {\r\n\r\n                // Getting the sub-option.\r\n                const subOption = (<IKeys>opt).keys[key];\r\n\r\n                // Pushing the sub-option.\r\n                subOptions.push(subOption);\r\n            }\r\n        }\r\n    });\r\n\r\n    // Returning the found sub-options.\r\n    return subOptions;\r\n}\r\n\r\n\r\n/**\r\n * Gets all of the options and sub-options.\r\n */\r\nfunction getAllOptions(): Array<Option> {\r\n\r\n    let allOptions: Array<Option> = [];\r\n\r\n    options.forEach((opt: Option) => {\r\n\r\n        allOptions.push(opt);\r\n\r\n        if ('keys' in opt) {\r\n\r\n            // Getting all of the sub-options.\r\n            const subOptions: Array<Option> = getAllSubOptions(opt);\r\n\r\n            allOptions = allOptions.concat(subOptions);\r\n        }\r\n    });\r\n\r\n    return allOptions;\r\n}\r\n\r\n\r\n/**\r\n * Gets all the sub-options of an option.\r\n * \r\n * @param opt The option to get the sub-options of.\r\n */\r\nfunction getAllSubOptions(option: Option): Array<Option> {\r\n\r\n    let allSubOptions: Array<Option> = [];\r\n\r\n    for (const key in (<any>option).keys) {\r\n\r\n        const subOption: Option = (<any>option).keys[key];\r\n\r\n        allSubOptions.push(subOption);\r\n\r\n        if ('keys' in subOption) {\r\n\r\n            const opts: Array<Option> = getAllSubOptions(subOption);\r\n\r\n            allSubOptions = allSubOptions.concat(opts);\r\n        }\r\n    }\r\n\r\n    return allSubOptions;\r\n}\r\n","/**\r\n * The name option model.\r\n */\r\n\r\n\r\nimport Option from \"../models/Option\";\r\n\r\n\r\nexport default class NameOption extends Option {\r\n\r\n    /**\r\n     * Parameterless constructor.\r\n     */\r\n    constructor() {\r\n\r\n        super('name', 'string', [], 'div', true);\r\n    }\r\n\r\n    /**\r\n     * Performs inheritance process on an option.\r\n     * \r\n     * @param hierarchy The hierarchy object that inherits.\r\n     * @param name The name to inherit.\r\n     */\r\n    public inherit(hierarchy: any, name: any): void {\r\n\r\n        if (name != null) {\r\n\r\n            if (hierarchy.from.mode === 'override') {\r\n\r\n                hierarchy.name = name;\r\n            }\r\n        }\r\n    }\r\n\r\n\r\n    /**\r\n     * Gets the nothing from a given HTML element.\r\n     * \r\n     * @param element The HTML element to target. \r\n     */\r\n    public getKeyFromElement = (element: HTMLElement): any => null;\r\n}\r\n","/**\r\n * The ID option model.\r\n */\r\n\r\n\r\nimport Option, { IParser } from \"../models/Option\";\r\nimport { Hierarchy } from \"../models/Hierarchy\";\r\n\r\n\r\nexport default class IdOption extends Option implements IParser {\r\n\r\n    /**\r\n     * Parameterless constructor.\r\n     */\r\n    constructor() {\r\n\r\n        super('id', 'string', [], '', true);\r\n    }\r\n\r\n\r\n    /**\r\n     * Performs inheritance process on an option.\r\n     * \r\n     * @param hierarchy The hierarchy object that inherits.\r\n     * @param id The id to inherit.\r\n     */\r\n    public inherit(hierarchy: any, id: any): void {\r\n\r\n        if (id !== '') {\r\n\r\n            if (hierarchy.from.mode === 'append') {\r\n\r\n                if (hierarchy.id === '') {\r\n\r\n                    hierarchy.id = id;\r\n                }\r\n            } else {\r\n\r\n                hierarchy.id = id;\r\n            }\r\n        }\r\n    }\r\n\r\n\r\n    /**\r\n     * Gets the id from a given HTML element.\r\n     * \r\n     * @param element The HTML element to target. \r\n     */\r\n    public getKeyFromElement = (element: HTMLElement): any => element.id;\r\n\r\n\r\n    /**\r\n     * Sets the id for an HTML element.\r\n     * \r\n     * @param element The HTML element to set the id for\r\n     */\r\n    public parse(element: HTMLElement, hierarchy: Hierarchy) {\r\n\r\n        if (hierarchy.id != \"\") {\r\n\r\n            element.id = hierarchy.id;\r\n        }\r\n    }\r\n}\r\n","/**\r\n * The text option model.\r\n */\r\n\r\n\r\nimport Option, { IKeys, IParser } from \"../models/Option\";\r\nimport { Hierarchy } from '../models/Hierarchy';\r\nimport ValueSubOption from \"./sub-options/ValueSubOption\";\r\nimport ContentTypeSubOption from \"./sub-options/ContentTypeSubOption\";\r\n\r\n\r\n/**\r\n * The content option class.\r\n */\r\nexport default class ContentOption extends Option implements IKeys, IParser {\r\n\r\n    /**\r\n     * The keys of the `content` option.\r\n     */\r\n    public keys: ContentKeys = {\r\n        type: new ContentTypeSubOption(),\r\n        value: new ValueSubOption()\r\n    };\r\n\r\n    /**\r\n     * Parameterless constructor.\r\n     */\r\n    constructor() {\r\n\r\n        super('content', 'object', [], {\r\n            type: (new ContentTypeSubOption()).default,\r\n            value: (new ValueSubOption()).default\r\n        }, true);\r\n    }\r\n\r\n\r\n    /**\r\n     * Performs inheritance process on an option.\r\n     * \r\n     * @param hierarchy The hierarchy object that inherits.\r\n     * @param content The content to inherit.\r\n     */\r\n    public inherit(hierarchy: any, content: any): void {\r\n        \r\n        let ct: string = content.value;\r\n\r\n        if (content.value !== \"\") {\r\n\r\n            if (hierarchy.from.mode === 'append') {\r\n    \r\n                ct = `${hierarchy.content.value}${ct.length > 0 ? ' ' : ''}${ct}`;\r\n            } else {\r\n    \r\n                hierarchy.content = content;\r\n            }\r\n    \r\n            hierarchy.content.value = ct;\r\n        }\r\n    }\r\n\r\n\r\n    /**\r\n     * Gets content from a given HTML element.\r\n     * \r\n     * @param element The HTML element to target. \r\n     */\r\n    public getKeyFromElement(element: HTMLElement): any { \r\n\r\n        return {\r\n            type: \"html\",\r\n            value: element.innerHTML\r\n        }\r\n    };\r\n\r\n\r\n    /**\r\n     * Sets the content for an HTML element.\r\n     * \r\n     * @param element The HTML element to set the content for\r\n     */\r\n    public parse (element: HTMLElement, hierarchy: Hierarchy) {\r\n\r\n        if ((<any>hierarchy).content.value != \"\") {\r\n\r\n            if ((<any>hierarchy).content.type === 'text') {\r\n\r\n                element.textContent = (<any>hierarchy).content.value;\r\n            } else {\r\n\r\n                element.innerHTML = (<any>hierarchy).content.value;\r\n            }\r\n        }\r\n    }\r\n}\r\n\r\n\r\n/**\r\n * The ContentKeys type.\r\n */\r\ntype ContentKeys = {\r\n\r\n    type: ContentTypeSubOption;\r\n    value: ValueSubOption;\r\n}\r\n","/**\r\n * The reference option model.\r\n */\r\n\r\n\r\nimport Option from \"../models/Option\";\r\n\r\n\r\nexport default class TemmeIdsOption extends Option {\r\n\r\n    /**\r\n     * Parameterless constructor.\r\n     */\r\n    constructor() {\r\n\r\n        super('temmeIds', 'array', [], []);\r\n    }\r\n\r\n\r\n    /**\r\n     * Performs inheritance process on an option.\r\n     * \r\n     * @param hierarchy The hierarchy object that inherits.\r\n     * @param temmeIds The temmeIds to inherit.\r\n     */\r\n    public inherit(hierarchy: any, temmeIds: any): void { }\r\n\r\n\r\n    /**\r\n     * Gets nothing from a given HTML element.\r\n     * \r\n     * @param element The HTML element to target. \r\n     */\r\n    public getKeyFromElement = (element: HTMLElement): any => null;\r\n}\r\n","/**\r\n * The templates option model.\r\n */\r\n\r\n\r\nimport Option from \"../models/Option\";\r\n\r\n\r\nexport default class TemplatesOption extends Option {\r\n\r\n    /**\r\n     * Parameterless constructor.\r\n     */\r\n    constructor() {\r\n\r\n        super('templates', 'array', [], []);\r\n    }\r\n\r\n    /**\r\n     * Performs inheritance process on an option.\r\n     * \r\n     * @param hierarchy The hierarchy object that inherits.\r\n     * @param templates The templates to inherit.\r\n     */\r\n    public inherit(hierarchy: any, templates: any): void { }\r\n\r\n\r\n    /**\r\n     * Gets nothing from a given HTML element.\r\n     * \r\n     * @param element The HTML element to target. \r\n     */\r\n    public getKeyFromElement = (element: HTMLElement): any => null;\r\n}\r\n","/**\r\n * The classes option model.\r\n */\r\n\r\n\r\nimport Option, { IParser } from \"../models/Option\";\r\nimport { Hierarchy } from '../models/Hierarchy';\r\n\r\n\r\nexport default class ClassesOption extends Option implements IParser {\r\n\r\n    /**\r\n     * Parameterless constructor.\r\n     */\r\n    constructor() {\r\n\r\n        super('classes', 'array', [], [], true);\r\n    }\r\n\r\n    /**\r\n     * Performs inheritance process on an option.\r\n     * \r\n     * @param hierarchy The hierarchy object that inherits.\r\n     * @param classes The classes to inherit.\r\n     */\r\n    public inherit(hierarchy: any, classes: any): void {\r\n        \r\n        if (hierarchy.from.mode === 'append') {\r\n\r\n            hierarchy.classes.push(...classes);\r\n        } else {\r\n\r\n            hierarchy.classes = classes;\r\n        }\r\n        \r\n        // Removing duplicates.\r\n        hierarchy.classes = hierarchy.classes.filter((cls: string, index: number) => hierarchy.classes.indexOf(cls) === index);\r\n\r\n        // Sorting the classes.\r\n        hierarchy.classes.sort();\r\n    }\r\n\r\n\r\n    /**\r\n     * Gets classes from a given HTML element.\r\n     * \r\n     * @param element The HTML element to target. \r\n     */\r\n    public getKeyFromElement(element: HTMLElement): any {\r\n      \r\n        let classes: Array<string> = [];\r\n\r\n        element.classList.forEach((cls: string) => classes.push(cls));\r\n\r\n        return classes;\r\n    };\r\n\r\n\r\n    /**\r\n     * Sets the classes for an HTML element.\r\n     * \r\n     * @param element The HTML element to set the classes for\r\n     */\r\n    public parse (element: HTMLElement, hierarchy: Hierarchy) {\r\n\r\n        if (hierarchy.classes.length > 0) {\r\n\r\n            element.classList.add(...hierarchy.classes);\r\n        }\r\n    }\r\n}\r\n","/**\r\n * The children option model.\r\n */\r\n\r\n\r\nimport Option from \"../models/Option\";\r\n\r\n\r\nexport default class ChildNodesOption extends Option {\r\n\r\n    /**\r\n     * Parameterless constructor.\r\n     */\r\n    constructor() {\r\n\r\n        super('childNodes', 'array', [], [], true);\r\n    }\r\n\r\n    /**\r\n     * Performs inheritance process on an option.\r\n     * \r\n     * @param hierarchy The hierarchy object that inherits.\r\n     * @param childNodes The childNodes to inherit.\r\n     */\r\n    public inherit(hierarchy: any, childNodes: any): void {\r\n\r\n        let children: any = [ ...hierarchy.childNodes ];\r\n\r\n        if (hierarchy.from.children.allow === true) {\r\n            \r\n            if (hierarchy.from.mode === 'append') {\r\n                \r\n                if (hierarchy.from.children.placement === 'before') {\r\n                    \r\n                    children.unshift(...childNodes);\r\n                } else {\r\n\r\n                    children.push(...childNodes);\r\n                }\r\n            } else {\r\n\r\n                children = childNodes;\r\n            }\r\n        }\r\n\r\n        hierarchy.childNodes = children;\r\n    }\r\n\r\n\r\n    /**\r\n     * Gets children from a given HTML element.\r\n     * \r\n     * @param element The HTML element to target. \r\n     */\r\n    public getKeyFromElement = (element: HTMLElement): any => element.innerHTML;\r\n}\r\n","/**\r\n * The attributes option model.\r\n */\r\n\r\n\r\nimport Option, { IParser } from \"../models/Option\";\r\nimport { Hierarchy } from \"../models/Hierarchy\";\r\n\r\n\r\nexport default class AttributesOption extends Option implements IParser {\r\n\r\n    /**\r\n     * Parameterless constructor.\r\n     */\r\n    constructor() {\r\n\r\n        super('attributes', 'object', [], {}, true);\r\n    }\r\n\r\n\r\n    /**\r\n     * Performs inheritance process on an option.\r\n     * \r\n     * @param hierarchy The hierarchy object that inherits.\r\n     * @param attributes The attributes to inherit.\r\n     */\r\n    public inherit(hierarchy: any, attributes: any): void {\r\n\r\n        const attr: any = { ...attributes };\r\n\r\n        if (hierarchy.from.mode === 'append') {\r\n\r\n            for (const attrKey in hierarchy.attributes) {\r\n\r\n                attr[attrKey] = hierarchy.attributes[attrKey];\r\n            }\r\n        } else {\r\n\r\n            for (const attrKey in hierarchy.attributes) {\r\n\r\n                if (!(attrKey in attr)) {\r\n\r\n                    attr[attrKey] = hierarchy.attributes[attrKey];\r\n                }\r\n            }\r\n        }\r\n\r\n        hierarchy.attributes = attr;\r\n    }\r\n\r\n\r\n    /**\r\n     * Gets attributes from a given HTML element.\r\n     * \r\n     * @param element The HTML element to target. \r\n     */\r\n    public getKeyFromElement(element: HTMLElement): any {\r\n\r\n        let attributes: any = {};\r\n\r\n        for (const attrKey in element.attributes) {\r\n\r\n            if (!isNaN(parseInt(attrKey)) && ['id', 'class'].indexOf(element.attributes[attrKey].nodeName) === -1 && element.attributes[attrKey].nodeName.substring(0, 5) !== 'data-') {\r\n\r\n                attributes[element.attributes[attrKey].nodeName] = element.attributes[attrKey].nodeValue;\r\n            }\r\n        }\r\n\r\n        return attributes;\r\n    }\r\n\r\n\r\n    /**\r\n     * Sets the attributes for an HTML element.\r\n     * \r\n     * @param element The HTML element to set the attributes for\r\n     */\r\n    public parse (element: HTMLElement, hierarchy: Hierarchy) {\r\n\r\n        for (const dataKey in hierarchy.attributes) {\r\n            \r\n            element.setAttribute(dataKey, (<any>hierarchy).attributes[dataKey]);\r\n        }\r\n    }\r\n}\r\n","/**\r\n * The dataset option model.\r\n */\r\n\r\n\r\nimport Option, { IParser } from \"../models/Option\";\r\nimport { Hierarchy } from '../models/Hierarchy';\r\n\r\n\r\nexport default class DatasetOption extends Option implements IParser {\r\n\r\n    /**\r\n     * Parameterless constructor.\r\n     */\r\n    constructor() {\r\n\r\n        super('dataset', 'object', [], {}, true);\r\n    }\r\n\r\n    /**\r\n     * Performs inheritance process on an option.\r\n     * \r\n     * @param hierarchy The hierarchy object that inherits.\r\n     * @param dataset The dataset to inherit.\r\n     */\r\n    public inherit(hierarchy: any, dataset: any): void {\r\n\r\n        const dt: any = { ...dataset };\r\n\r\n        if (hierarchy.from.mode === 'append') {\r\n\r\n            for (const dataKey in hierarchy.dataset) {\r\n\r\n                dt[dataKey] = hierarchy.dataset[dataKey];\r\n            }\r\n        } else {\r\n\r\n            for (const dataKey in hierarchy.dataset) {\r\n\r\n                if (!(dataKey in dt)) {\r\n\r\n                    dt[dataKey] = hierarchy.dataset[dataKey];\r\n                }\r\n            }\r\n        }\r\n\r\n        hierarchy.dataset = dt;\r\n    }\r\n\r\n\r\n    /**\r\n     * Gets datatset from a given HTML element.\r\n     * \r\n     * @param element The HTML element to target. \r\n     */\r\n    public getKeyFromElement(element: HTMLElement): any {\r\n\r\n        let dataset: any = {};\r\n\r\n        for (const dataKey in element.dataset) {\r\n\r\n            dataset[dataKey] = element.dataset[dataKey];\r\n        }\r\n\r\n        return dataset;\r\n    }\r\n\r\n\r\n    /**\r\n     * Sets the dataset for an HTML element.\r\n     * \r\n     * @param element The HTML element to set the dataset for\r\n     */\r\n    public parse (element: HTMLElement, hierarchy: Hierarchy) {\r\n\r\n        for (const dataKey in hierarchy.dataset) {\r\n\r\n            element.dataset[dataKey] = (<any>hierarchy).dataset[dataKey];\r\n        }\r\n    }\r\n}\r\n","/**\r\n * The from option model.\r\n */\r\n\r\n\r\n\r\nimport Option, { IKeys } from \"../models/Option\";\r\nimport RefOption from \"./RefOption\";\r\nimport ModeSubOption from \"./sub-options/ModeSubOption\";\r\nimport ChildrenSubOption from \"./sub-options/ChildrenSubOption\";\r\nimport IncludeSubOption from \"./sub-options/IncludeSubOption\";\r\nimport ExcludeSubOption from \"./sub-options/ExcludeSubOption\";\r\n\r\n\r\nexport default class FromOption extends Option implements IKeys {\r\n\r\n    /**\r\n     * The keys of the `from` option.\r\n     */\r\n    public keys: FromKeys = {\r\n        ref: new RefOption(),\r\n        mode: new ModeSubOption(),\r\n        children: new ChildrenSubOption(),\r\n        include: new IncludeSubOption(),\r\n        exclude: new ExcludeSubOption()\r\n    };\r\n\r\n    /**\r\n     * Parameterless constructor.\r\n     */\r\n    constructor() {\r\n\r\n        super('from', 'object', [], {\r\n            ref: (new RefOption()).default,\r\n            mode: (new ModeSubOption()).default,\r\n            children: (new ChildrenSubOption()).default,\r\n            include: (new IncludeSubOption()).default,\r\n            exclude: (new ExcludeSubOption()).default\r\n        });\r\n    }\r\n\r\n    /**\r\n     * Performs inheritance process on an option.\r\n     * \r\n     * @param hierarchy The hierarchy object that inherits.\r\n     * @param from The from to inherit.\r\n     */\r\n    public inherit(hierarchy: any, from: any): void { }\r\n\r\n\r\n    /**\r\n     * Gets nothing from a given HTML element.\r\n     * \r\n     * @param element The HTML element to target. \r\n     */\r\n    public getKeyFromElement = (element: HTMLElement): any => null;\r\n}\r\n\r\n\r\n/**\r\n * The FromKeys type.\r\n */\r\ntype FromKeys = {\r\n\r\n    /**\r\n     * The reference sub option.\r\n     */\r\n    ref: RefOption;\r\n\r\n    /**\r\n     * The inheritance mode.\r\n     */\r\n    mode: ModeSubOption;\r\n\r\n    /**\r\n     * The inheritance mode.\r\n     */\r\n    children: ChildrenSubOption;\r\n\r\n\r\n    /**\r\n     * What options to inherite.\r\n     */\r\n    include: IncludeSubOption;\r\n\r\n\r\n    /**\r\n     * What options not to inherit.\r\n     */\r\n    exclude: ExcludeSubOption;\r\n}\r\n","/**\r\n * Temme's error interface.\r\n */\r\ninterface ITemmyError {\r\n\r\n    /**\r\n     * The name of the error.\r\n     */\r\n    readonly name: string;\r\n\r\n    /**\r\n     * The message of the error.\r\n     */\r\n    message: string;\r\n}\r\n\r\n\r\n/**\r\n * Temme's custom errors.\r\n */\r\nexport default class TemmyError extends Error implements ITemmyError {\r\n\r\n    /**\r\n     * The name of the error.\r\n     */\r\n    public readonly name: string = 'TemmyError';\r\n\r\n    /**\r\n     * The message of the error.\r\n     */\r\n    public message: string = \"Temme isn't feeling good\";\r\n\r\n    /**\r\n     * Constructor with parameters.\r\n     * \r\n     * @param message The message of the error.\r\n     */\r\n    constructor(message: string) {\r\n\r\n        // Calling the parent class `TemmyError`.\r\n        super();\r\n\r\n        // Updating the error's message.\r\n        this.message = message.length > 0 ? message : this.message;\r\n    }\r\n}\r\n","/**\r\n * The error thrown when a template\r\n * has a forbidden option.\r\n */\r\n\r\n\r\nimport TemmyError from \"../models/TemmyError\";\r\n\r\n\r\nexport default class InvalidTemplateOptionError extends TemmyError {\r\n\r\n    /**\r\n     * The name of the error.\r\n     */\r\n    public name: string = \"InvalidTemplateOptionError\";\r\n\r\n    /**\r\n     * The message of the error.\r\n     */\r\n    public message: string = \"A template has an invalid option\";\r\n\r\n    /**\r\n     * Constructor with parameters.\r\n     * \r\n     * @param option The invalid option's name.\r\n     */\r\n    constructor(option: string) {\r\n\r\n        // Calling the parent class `TemmyError`.\r\n        super(\"\");\r\n\r\n        // Constructing the error message.\r\n        const message: string = `“${option}” is not a valid option to use in templates`;\r\n\r\n        // Updating the error's message.\r\n        this.message = option.length > 0 ? message : this.message;\r\n    }\r\n}\r\n","/**\r\n * The error thrown when an option\r\n * is not valid.\r\n */\r\n\r\n\r\nimport TemmyError from \"../models/TemmyError\";\r\n\r\n\r\nexport default class InvalidOptionNameError extends TemmyError {\r\n\r\n    /**\r\n     * The name of the error.\r\n     */\r\n    public name: string = \"InvalidOptionNameError\";\r\n\r\n    /**\r\n     * The message of the error.\r\n     */\r\n    public message: string = \"An option is not valid\";\r\n\r\n    /**\r\n     * Constructor with parameters.\r\n     * \r\n     * @param option The invalid option's name.\r\n     */\r\n    constructor(option: string) {\r\n\r\n        // Calling the parent class `TemmyError`.\r\n        super(\"\");\r\n\r\n        // Constructing the error message.\r\n        const message: string = `“${option}” is not a valid option`;\r\n\r\n        // Updating the error's message.\r\n        this.message = option.length > 0 ? message : this.message;\r\n    }\r\n}\r\n","/**\r\n * The error thrown when an option\r\n * is not of a valid data type.\r\n */\r\n\r\n\r\nimport TemmyError from \"../models/TemmyError\";\r\n\r\n\r\nexport default class InvalidOptionTypeError extends TemmyError {\r\n\r\n    /**\r\n     * The name of the error.\r\n     */\r\n    public name: string = \"InvalidOptionTypeError\";\r\n\r\n    /**\r\n     * The message of the error.\r\n     */\r\n    public message: string = \"An option doesn't have a valid value type\";\r\n\r\n    /**\r\n     * Constructor with parameters.\r\n     * \r\n     * @param option The invalid option's name.\r\n     * @param value The invalid option's value.\r\n     */\r\n    constructor(option: string, type: string) {\r\n\r\n        // Calling the parent class `TemmyError`.\r\n        super(\"\");\r\n\r\n        // Constructing the error message.\r\n        const message: string = `The “${option}” option doesn't accept values of type “${type}”`;\r\n\r\n        // Updating the error's message.\r\n        this.message = option.length > 0 ? message : this.message;\r\n    }\r\n}\r\n","/**\r\n * The error thrown when an option\r\n * is not of a valid value.\r\n */\r\n\r\n\r\nimport TemmyError from \"../models/TemmyError\";\r\n\r\n\r\nexport default class InvalidOptionValueError extends TemmyError {\r\n\r\n    /**\r\n     * The name of the error.\r\n     */\r\n    public name: string = \"InvalidOptionValueError\";\r\n\r\n    /**\r\n     * The message of the error.\r\n     */\r\n    public message: string = \"An option doesn't have a valid value\";\r\n\r\n    /**\r\n     * Constructor with parameters.\r\n     * \r\n     * @param option The invalid option's name.\r\n     * @param value The invalid option's value.\r\n     */\r\n    constructor(option: string, value: string) {\r\n\r\n        // Calling the parent class `TemmyError`.\r\n        super(\"\");\r\n\r\n        // Constructing the error message.\r\n        const message: string = `The “${option}” option doesn't accept “${value}” as a value`;\r\n\r\n        // Updating the error's message.\r\n        this.message = option.length > 0 ? message : this.message;\r\n    }\r\n}\r\n","/**\r\n * The error thrown when a sub-option\r\n * is not valid.\r\n */\r\n\r\n\r\nimport TemmyError from \"../models/TemmyError\";\r\n\r\n\r\nexport default class InvalidSubOptionNameError extends TemmyError {\r\n\r\n    /**\r\n     * The name of the error.\r\n     */\r\n    public name: string = \"InvalidSubOptionNameError\";\r\n\r\n    /**\r\n     * The message of the error.\r\n     */\r\n    public message: string = \"A sub-option is not valid\";\r\n\r\n    /**\r\n     * Constructor with parameters.\r\n     * \r\n     * @param option The parent option's name.\r\n     * @param subOption The invalid sub-option's name.\r\n     */\r\n    constructor(option: string, subOption: string) {\r\n\r\n        // Calling the parent class `TemmyError`.\r\n        super(\"\");\r\n\r\n        // Constructing the error message.\r\n        const message: string = `The “${option}” option doesn't not recognize “${subOption}” as a valid sub-option`;\r\n\r\n        // Updating the error's message.\r\n        this.message = option.length > 0 || subOption.length > 0 ? message : this.message;\r\n    }\r\n}\r\n","/**\r\n * The error thrown when a sub-ption\r\n * is not of a valid data type.\r\n */\r\n\r\n\r\nimport TemmyError from \"../models/TemmyError\";\r\n\r\n\r\nexport default class InvalidSubOptionTypeError extends TemmyError {\r\n\r\n    /**\r\n     * The name of the error.\r\n     */\r\n    public name: string = \"InvalidSubOptionTypeError\";\r\n\r\n    /**\r\n     * The message of the error.\r\n     */\r\n    public message: string = \"A sub-option doesn't have a valid value type\";\r\n\r\n    /**\r\n     * Constructor with parameters.\r\n     * \r\n     * @param subOption The invalid sub-option's name.\r\n     * @param value The invalid sub-option's value.\r\n     */\r\n    constructor(subOption: string, type: string) {\r\n\r\n        // Calling the parent class `TemmyError`.\r\n        super(\"\");\r\n\r\n        // Constructing the error message.\r\n        const message: string = `The “${subOption}” sub-option doesn't accept values of type “${type}”`;\r\n\r\n        // Updating the error's message.\r\n        this.message = subOption.length > 0 || type.length > 0 ? message : this.message;\r\n    }\r\n}\r\n","/**\r\n * The error thrown when a sub-option\r\n * is not of a valid value.\r\n */\r\n\r\n\r\nimport TemmyError from \"../models/TemmyError\";\r\n\r\n\r\nexport default class InvalidSubOptionValueError extends TemmyError {\r\n\r\n    /**\r\n     * The name of the error.\r\n     */\r\n    public name: string = \"InvalidSubOptionValueError\";\r\n\r\n    /**\r\n     * The message of the error.\r\n     */\r\n    public message: string = \"A sub-option doesn't have a valid value\";\r\n\r\n    /**\r\n     * Constructor with parameters.\r\n     * \r\n     * @param subOption The invalid sub-option's name.\r\n     * @param value The invalid sub-option's value.\r\n     */\r\n    constructor(subOption: string, value: string) {\r\n\r\n        // Calling the parent class `TemmyError`.\r\n        super(\"\");\r\n\r\n        // Constructing the error message.\r\n        const message: string = `The “${subOption}” sub-option doesn't accept “${value}” as a value`;\r\n\r\n        // Updating the error's message.\r\n        this.message = subOption.length > 0 || value.length > 0 ? message : this.message;\r\n    }\r\n}\r\n","/**\r\n * The error thrown when a \r\n * from option is not valid\r\n */\r\n\r\n\r\nimport TemmyError from \"../models/TemmyError\";\r\n\r\n\r\nexport default class InvalidReferencingOptionError extends TemmyError {\r\n\r\n    /**\r\n     * The name of the error.\r\n     */\r\n    public name: string = \"InvalidReferencingOptionError\";\r\n\r\n    /**\r\n     * The message of the error.\r\n     */\r\n    public message: string = \"A referencing option is not valid\";\r\n\r\n    /**\r\n     * Constructor with parameters.\r\n     * \r\n     * @param message The error's message.\r\n     */\r\n    constructor(message: string) {\r\n\r\n        // Calling the parent class `TemmyError`.\r\n        super(\"\");\r\n\r\n        // Updating the error's message.\r\n        this.message = message.length > 0 ? message : this.message;\r\n    }\r\n}\r\n","/**\r\n * The error thrown when a \r\n * ref option starts with the symbole “@”.\r\n */\r\n\r\n\r\nimport TemmyError from \"../models/TemmyError\";\r\n\r\n\r\nexport default class InvalidReferenceOptionValueError extends TemmyError {\r\n\r\n    /**\r\n     * The name of the error.\r\n     */\r\n    public name: string = \"InvalidReferenceOptionValueError\";\r\n\r\n    /**\r\n     * The message of the error.\r\n     */\r\n    public message: string = \"“ref” options must not begin with the “@” symbol\";\r\n\r\n    /**\r\n     * Constructor with parameters.\r\n     * \r\n     * @param message The error's message.\r\n     */\r\n    constructor(message: string) {\r\n\r\n        // Calling the parent class `TemmyError`.\r\n        super(\"\");\r\n\r\n        // Updating the error's message.\r\n        this.message = message.length > 0 ? message : this.message;\r\n    }\r\n}\r\n","/**\r\n * The error thrown when a ref option\r\n * references an invalid object.\r\n */\r\n\r\n\r\nimport TemmyError from \"../models/TemmyError\";\r\n\r\n\r\nexport default class InvalidReferenceError extends TemmyError {\r\n\r\n    /**\r\n     * The name of the error.\r\n     */\r\n    public name: string = \"InvalidReferenceError\";\r\n\r\n    /**\r\n     * The message of the error.\r\n     */\r\n    public message: string = \"A reference is invalid\";\r\n\r\n    /**\r\n     * Constructor with parameters.\r\n     * \r\n     * @param reference The invalid reference.\r\n     */\r\n    constructor(reference: string) {\r\n\r\n        // Calling the parent class `TemmyError`.\r\n        super(\"\");\r\n\r\n        // Updating the error's message.\r\n        this.message = reference.length > 0 ? `“${reference}” is an invalid reference` : this.message;\r\n    }\r\n}\r\n","/**\r\n * The error thrown when a template\r\n * is invalid (doesn't have a “ref” option).\r\n */\r\n\r\n\r\nimport TemmyError from \"../models/TemmyError\";\r\n\r\n\r\nexport default class InvalidTemplateError extends TemmyError {\r\n\r\n    /**\r\n     * The name of the error.\r\n     */\r\n    public name: string = \"InvalidTemplateError\";\r\n\r\n    /**\r\n     * The message of the error.\r\n     */\r\n    public message: string = \"A template does not have a “ref” option\";\r\n\r\n    /**\r\n     * Constructor with parameters.\r\n     * \r\n     * @param message The message of the error.\r\n     */\r\n    constructor(message: string) {\r\n\r\n        // Calling the parent class `TemmyError`.\r\n        super(\"\");\r\n\r\n        // Updating the error's message.\r\n        this.message = message.length > 0 ? message : this.message;\r\n    }\r\n}\r\n","/**\r\n * Here goes's everything that ID-fies\r\n * anything to do with the hierarchy object.\r\n */\r\n\r\n\r\nimport { Hierarchy } from \"./models/Hierarchy\";\r\nimport { Template } from \"./models/Template\";\r\n\r\n\r\n/**\r\n * Assigns temmeIds to a hierarchy object.\r\n * \r\n * @param hierarchy The hierarchy object to assing a temmeId to.\r\n * @param temmeIds The series of temmeIds leading to the current hierarchy object.\r\n * @param mode The mode of the temmeId, if it's false, the temmeId will be of 6 characters\r\n * indicating it's a hierarchy object, if it's true, it'll have 4 characters indicating it's\r\n * a template.\r\n */\r\nexport function idfy(hierarchy: any, temmeIds: Array<string> = [], mode: boolean = false) {\r\n    \r\n    try {\r\n\r\n        // Generating a temme Id.\r\n        const temmeId: string = generateTemmeId(mode);\r\n        \r\n        // Assigning a temmeId.\r\n        hierarchy.temmeIds = [...temmeIds, temmeId];\r\n        \r\n        // Checking of the hierarchy object has any children.\r\n        if ('childNodes' in hierarchy) {\r\n            \r\n            hierarchy.childNodes.forEach((child: Object) => {\r\n                \r\n                idfy(child, hierarchy.temmeIds);\r\n            });\r\n        }\r\n    \r\n        // Checking of the hierarchy object has any templates.\r\n        if ('templates' in hierarchy) {\r\n    \r\n            hierarchy.templates.forEach((template: Object) => {\r\n    \r\n                idfy(template, hierarchy.temmeIds, true);\r\n            });\r\n        }\r\n    }\r\n    catch(e) {\r\n\r\n        throw e;\r\n    }\r\n}\r\n\r\n\r\n/**\r\n * Gets the temmeId of a hierarchy or template object.\r\n * \r\n * @param hierarchy The hierarchy to get the temmeId of.\r\n */\r\nexport function getTemmeId (hierarchy: Hierarchy | Template): string {\r\n    return hierarchy.temmeIds[hierarchy.temmeIds.length - 1];\r\n}\r\n\r\n\r\n/**\r\n * Generates a unique temmeId.\r\n */\r\nfunction generateTemmeId(mode: boolean = false) {\r\n\r\n    const\r\n        chars = \"0123456789abcdefghijklmnopqrstuvwxyz\",\r\n        max = (mode === false) ? 6 : 4;\r\n\r\n    let key = '';\r\n\r\n    for (let i = 0; i<max; i++) {\r\n\r\n        const\r\n            index = Math.floor((Math.random() * chars.length)),\r\n            uppercase = Math.floor(Math.random() * 2);\r\n\r\n        key += uppercase === 1 ? chars[index].toUpperCase() : chars[index];\r\n    }\r\n\r\n    return key;\r\n}\r\n","/**\r\n * The error thrown when a template\r\n * has is referencing a non-template object.\r\n */\r\n\r\n\r\nimport TemmyError from \"../models/TemmyError\";\r\n\r\n\r\nexport default class InvalidTemplateReferencingError extends TemmyError {\r\n\r\n    /**\r\n     * The name of the error.\r\n     */\r\n    public name: string = \"InvalidTemplateReferencingError\";\r\n\r\n    /**\r\n     * The message of the error.\r\n     */\r\n    public message: string = \"Templates can only reference other templates.\";\r\n\r\n    /**\r\n     * Constructor with parameters.\r\n     * \r\n     * @param ref The template's reference.\r\n     * @param target The reference target.\r\n     */\r\n    constructor(ref: string, target: string) {\r\n\r\n        // Calling the parent class `TemmyError`.\r\n        super(\"\");\r\n\r\n        // Constructing the error message.\r\n        const message: string = `The template with the reference “${ref}” is trying to reference “${target}” a non-template object`;\r\n\r\n        // Updating the error's message.\r\n        this.message = ref.length > 0 ? message : this.message;\r\n    }\r\n}\r\n","/**\r\n * The error thrown when a a hierarchy objecy\r\n * is referencing an element out of its scope.\r\n */\r\n\r\n\r\nimport TemmyError from \"../models/TemmyError\";\r\n\r\n\r\nexport default class ReferenceOutOfScopeError extends TemmyError {\r\n\r\n    /**\r\n     * The name of the error.\r\n     */\r\n    public name: string = \"ReferenceOutOfScopeError\";\r\n\r\n    /**\r\n     * The message of the error.\r\n     */\r\n    public message: string = \"An object is referencing an element out of its scope\";\r\n\r\n    /**\r\n     * Constructor with parameters.\r\n     * \r\n     * @param message The error's message.\r\n     */\r\n    constructor(message: string) {\r\n\r\n        // Calling the parent class `TemmyError`.\r\n        super(\"\");\r\n\r\n        // Updating the error's message.\r\n        this.message = message.length > 0 ? message : this.message;\r\n    }\r\n}\r\n","/**\r\n * The module responsible for validating the input.\r\n */\r\n\r\n\r\nimport Option, { IKeys } from \"./models/Option\";\r\nimport { options, forbiddenOptions, getSubOptions } from \"./options\";\r\nimport InvalidTemplateOptionError from \"./errors/InvalidTemplateOptionError\";\r\nimport InvalidOptionNameError from \"./errors/InvalidOptionNameError\";\r\nimport InvalidOptionTypeError from \"./errors/InvalidOptionTypeError\";\r\nimport InvalidOptionValueError from \"./errors/InvalidOptionValueError\";\r\nimport InvalidSubOptionNameError from \"./errors/InvalidSubOptionNameError\";\r\nimport InvalidSubOptionTypeError from \"./errors/InvalidSubOptionTypeError\";\r\nimport InvalidSubOptionValueError from \"./errors/InvalidSubOptionValueError\";\r\nimport InvalidReferencingOptionError from \"./errors/InvalidReferencingOptionError\";\r\nimport InvalidReferenceOptionValueError from \"./errors/InvalidReferenceOptionValueError\";\r\nimport InvalidReferenceError from \"./errors/InvalidReferenceError\";\r\nimport InvalidTemplateError from \"./errors/InvalidTemplateError\";\r\nimport { ReferenceType } from \"./referencer\";\r\nimport { getTemmeId } from \"./idfier\";\r\nimport { Hierarchy } from \"./models/Hierarchy\";\r\nimport InvalidTemplateReferencingError from \"./errors/InvalidTemplateReferencingError\";\r\nimport ReferenceOutOfRangeError from \"./errors/ReferenceOutOfScopeError\";\r\n\r\n\r\n/**\r\n * Checks if an object is a valid hierarchy object.\r\n * \r\n * @param hierarchy The object to check.\r\n */\r\nexport const isValidHierarchy = (hierarchy: Object): boolean => hierarchy != null && typeof hierarchy === 'object' && !Array.isArray(hierarchy);\r\n\r\n\r\n/**\r\n * Checks if an object is a valid HTML element.\r\n * \r\n * @param target The object to check.\r\n */\r\nexport const isValidHTMLElement = (target: HTMLElement): boolean => target != null && target instanceof HTMLElement;\r\n\r\n\r\n/**\r\n * Validates the options in a hierarchy object for any\r\n * options it has or values it contains.\r\n * \r\n * @param hierarchy The hierarchy object to validate the options for.\r\n * \r\n * @throws InvalidOptionNameError, InvalidOptionTypeError, InvalidOptionValueError, InvalidSubOptionNameError, InvalidSubOptionTypeError, InvalidSubOptionValueError, InvalidTemplateOptionError\r\n */\r\nexport function validateOptions(hierarchy: any): void {\r\n\r\n    try {\r\n\r\n        // Looping through the hierarchy's options.\r\n        for (const option in hierarchy) {\r\n\r\n            const\r\n                matchingOption: Option = <Option>options.filter((opt: Option) => opt.label === option)[0],\r\n                optionValue: any = hierarchy[option];\r\n\r\n            // Validating the option's name.\r\n            if (Option.validateOptionName(matchingOption) === false) {\r\n                throw new InvalidOptionNameError(option);\r\n            }\r\n\r\n            // Validating the option's type.\r\n            const typeValidation: { valid: boolean, type: string } = Option.validateOptionType(optionValue, matchingOption);\r\n\r\n            if (typeValidation.valid === false) {\r\n                throw new InvalidOptionTypeError(option, typeValidation.type);\r\n            }\r\n\r\n            // Validating the option's value.\r\n            if (Option.validateOptionValue(optionValue, matchingOption) === false) {\r\n                throw new InvalidOptionValueError(option, optionValue);\r\n            }\r\n\r\n            // Repeating the same check for options that have keys.\r\n            if ('keys' in matchingOption) {\r\n\r\n                // Getting the option's sub-options.\r\n                const subOptions = (<IKeys>matchingOption).keys;\r\n\r\n                // Validating the sub-options.\r\n                validateSubOptions(option, optionValue, subOptions);\r\n            }\r\n        }\r\n\r\n        // Validating references.\r\n        if (validateReferencingOption(hierarchy) === false) {\r\n            throw new InvalidReferencingOptionError(\"The “from” option must always have a “ref” sub-option\");\r\n        }\r\n\r\n        if (validateReferencingRange(hierarchy) === false) {\r\n            throw new InvalidReferencingOptionError(\"The “from” option can't have both the “include” and “exclude” sub-options at the same time\");\r\n        }\r\n\r\n        // Checking if the hierarchy object contains any templates.\r\n        if ('templates' in hierarchy) {\r\n\r\n            hierarchy.templates.forEach((template: Object) => {\r\n                validateTemplates(template);\r\n            });\r\n        }\r\n\r\n        // Repeating the same check for the hierarchy's children.\r\n        if ('childNodes' in hierarchy) {\r\n\r\n            hierarchy.childNodes.forEach((child: Object) => {\r\n                validateOptions(child);\r\n            });\r\n        }\r\n    }\r\n    catch (e) {\r\n\r\n        throw e;\r\n    }\r\n}\r\n\r\n\r\n/**\r\n * Validates the templates in a hierarchy object.\r\n * \r\n * @param template The template object to validate.\r\n * \r\n * @throws InvalidOptionNameError, InvalidOptionTypeError, InvalidOptionValueError, InvalidSubOptionNameError, InvalidSubOptionTypeError, InvalidSubOptionValueError, InvalidTemplateError, InvalidTemplateOptionError\r\n */\r\nexport function validateTemplates(template: any): void {\r\n\r\n    try {\r\n\r\n        if (!('ref' in template)) {\r\n            throw new InvalidTemplateError(\"\");\r\n        }\r\n\r\n        // Looping through the options of the template.\r\n        for (const option in template) {\r\n\r\n            // Checking if the template contains any invalid options.\r\n            if (forbiddenOptions.indexOf(option) > -1) {\r\n                throw new InvalidTemplateOptionError(option);\r\n            } else {\r\n                validateOptions(template);\r\n            }\r\n        }\r\n    }\r\n    catch (e) {\r\n\r\n        throw e;\r\n    }\r\n}\r\n\r\n\r\n/**\r\n * Validates the references in the hierarchy object.\r\n * \r\n * @param hierarchy The hierarchy object to validate the references for.\r\n * @param references The valid refernces.\r\n * \r\n * @throws InvalidReferenceError\r\n */\r\nexport function validateReferences(hierarchy: any, references: Array<ReferenceType>): void {\r\n\r\n    try {\r\n\r\n        // Checking if the “ref” option starts with the “@” symbol.\r\n        if (hierarchy.ref[0] === '@') {\r\n            throw new InvalidReferenceOptionValueError(\"\");\r\n        } \r\n        \r\n        // Checking if the object is referencing an outer element.\r\n        if (hierarchy.from.ref[0] === '@') {\r\n\r\n            const\r\n                selector: string = (<string>hierarchy.from.ref).substring(1),\r\n                element: HTMLElement | null = document.querySelector(selector);\r\n\r\n            if (element == null) {\r\n                throw new InvalidReferenceOptionValueError(`No outer element corresponds to the selector “${selector}”`);\r\n            }\r\n        } else {\r\n\r\n            // Checking of the reference exists.\r\n            if (validateReference(hierarchy, references) === false && hierarchy.from.ref !== \"\") {\r\n                throw new InvalidReferenceError(hierarchy.from.ref);\r\n            }\r\n        }\r\n\r\n        // Checking if the hierarchy object has any children.\r\n        if ('childNodes' in hierarchy && hierarchy.childNodes.length > 0) {\r\n\r\n            hierarchy.childNodes.forEach((child: Hierarchy) => {\r\n\r\n                validateReferences(child, references);\r\n            });\r\n        }\r\n\r\n        // Checking if the hierarchy object has any templates.\r\n        if ('templates' in hierarchy && hierarchy.templates.length > 0) {\r\n\r\n            hierarchy.templates.forEach((template: any) => {\r\n\r\n                validateReferences(template, references);\r\n            });\r\n        }\r\n    }\r\n    catch (e) {\r\n\r\n        throw e;\r\n    }\r\n}\r\n\r\n\r\n/**\r\n * Validates a passed reference.\r\n * \r\n * @param reference The reference to validate.\r\n * @param references The valid references.\r\n */\r\nconst validateReference = (hierarchy: any, references: Array<ReferenceType>): boolean => references.filter((ref: ReferenceType) => ref.hierarchy.ref === hierarchy.from.ref && getTemmeId(hierarchy) !== getTemmeId(ref.hierarchy))[0] != null;\r\n\r\n\r\n/**\r\n * Validates whether templates are referencing non-template element\r\n * or not, in which case, an error is thrown.\r\n * \r\n * @param hierarchy The hierarchy to validate the template inheritance for.\r\n * @param references There valid references.\r\n * \r\n * @throws InvalidTemplateReferencingError\r\n */\r\nexport function validateTemplateReference(hierarchy: any, references: Array<ReferenceType>): void {\r\n\r\n    try {\r\n\r\n        // Getting the templates.\r\n        const templates = hierarchy.templates;\r\n\r\n        // Checking if there are any valid templates.\r\n        if (templates.length > 0) {\r\n\r\n            templates.forEach((template: any) => {\r\n\r\n                // Checking if the template's referencing value is valid.\r\n                if (template.from.ref.length > 0) {\r\n\r\n                    const\r\n                        referencedElement: any = references.filter((ref: ReferenceType) => (<Hierarchy>ref.hierarchy).ref === template.from.ref)[0],\r\n                        isTemplate: boolean = getTemmeId(referencedElement.hierarchy).length === 4;\r\n    \r\n                    if (isTemplate === false) {\r\n                       throw new InvalidTemplateReferencingError(template.ref, template.from.ref);\r\n                    }\r\n                }\r\n            });\r\n        }\r\n\r\n        hierarchy.childNodes.forEach((child: any) => {\r\n\r\n            validateTemplateReference(child, references);\r\n        });\r\n    }\r\n    catch(e)\r\n    {\r\n\r\n        throw e;\r\n    }\r\n}\r\n\r\n\r\n/**\r\n * Validates whether a hierarchy object is referencing its child.\r\n * \r\n * @param hierarchy The hierarchy to validate.\r\n * @param references There valid references.\r\n * @param depth The depth of the validation.\r\n */\r\nexport function validateParentToChildReference(hierarchy: any, references: Array<ReferenceType>, depth: number = 0): void {\r\n\r\n    try {\r\n\r\n        const ref: string = hierarchy.from.ref;\r\n\r\n        // Incrementing the depth\r\n        depth++;\r\n\r\n        // Checking if the reference is valid.\r\n        if (ref !== \"\" && ref[0] !== '@') {\r\n\r\n            // Getting the referenced hierarchy.\r\n            const referencedHierarchy: ReferenceType = references.filter((refObject: ReferenceType) => (<Hierarchy>refObject.hierarchy).ref === ref && depth >= refObject.depth)[0];\r\n\r\n            if (referencedHierarchy == null) {\r\n                throw new ReferenceOutOfRangeError(\"\");\r\n            }\r\n        }\r\n\r\n        // Checking if the hierarchy object has any children.\r\n        if ('childNodes' in hierarchy && hierarchy.childNodes.length > 0) {\r\n\r\n            hierarchy.childNodes.forEach((child: Hierarchy) => {\r\n\r\n                validateParentToChildReference(child, references, depth);\r\n            });\r\n        }\r\n\r\n        // Checking if the hierarchy object has any templates.\r\n        if ('templates' in hierarchy && hierarchy.templates.length > 0) {\r\n\r\n            hierarchy.templates.forEach((template: any) => {\r\n\r\n                validateParentToChildReference(template, references, depth);\r\n            });\r\n        }\r\n        \r\n    }\r\n    catch(e) {\r\n\r\n        throw e;\r\n    }\r\n}\r\n\r\n\r\n/**\r\n * Validates the sub-options of another option.\r\n * @param optionName The name of the option to validate the sub-options for. \r\n * @param optionValue The sub-options to validate.\r\n * @param subOptions The expected sub-options.\r\n */\r\nfunction validateSubOptions(optionName: string, optionValue: any, subOptions: IKeys): void {\r\n\r\n    // Looping through the expected sub-options.\r\n    for (const subOption in optionValue) {\r\n\r\n        const\r\n            matchingSubOption: Option = getSubOptions(optionName).filter((subOptions: Option) => subOptions.label === subOption)[0],\r\n            subOptionValue: any = optionValue[subOption];\r\n\r\n        // Checking if a sub-option is in the parent option.\r\n        if (subOption in subOptions) {\r\n\r\n            // Validating the sub-option's name.\r\n            if (Option.validateOptionName(matchingSubOption) === false) {\r\n                throw new InvalidSubOptionNameError(optionName, subOption);\r\n            }\r\n\r\n            // Validating the sub-options's data type.\r\n            const typeValidation: { valid: boolean, type: string } = Option.validateOptionType(subOptionValue, matchingSubOption);\r\n\r\n            if (typeValidation.valid === false) {\r\n                throw new InvalidSubOptionTypeError(subOption, typeValidation.type);\r\n            }\r\n\r\n            // Validating the sub-option's value.\r\n            if (Option.validateOptionValue(subOptionValue, matchingSubOption) === false) {\r\n                throw new InvalidSubOptionValueError(subOption, subOptionValue);\r\n            }\r\n\r\n            if ('keys' in matchingSubOption) {\r\n\r\n                // Getting the option's sub-options.\r\n                const subOptionValue = optionValue[subOption];\r\n\r\n                validateSubOptions(subOption, subOptionValue, (<IKeys>matchingSubOption).keys);\r\n            }\r\n\r\n        } else {\r\n\r\n            throw new InvalidSubOptionNameError(optionName, subOption);\r\n        }\r\n    }\r\n}\r\n\r\n\r\n/**\r\n * Validates the references in a hierarchy object.\r\n * \r\n * @param hierarchy The hierarchy object to validate the references for.\r\n */\r\nfunction validateReferencingOption(hierarchy: any): boolean {\r\n\r\n    if ('from' in hierarchy) {\r\n\r\n        return 'ref' in hierarchy.from;\r\n    }\r\n\r\n    return true;\r\n}\r\n\r\n\r\n/**\r\n * Validates the references in a hierarchy object.\r\n * \r\n * @param hierarchy The hierarchy object to validate the references for.\r\n */\r\nfunction validateReferencingRange(hierarchy: any): boolean {\r\n\r\n    if ('from' in hierarchy) {\r\n\r\n        return !('include' in hierarchy.from && 'exclude' in hierarchy.from);\r\n    }\r\n\r\n    return true;\r\n}\r\n","/**\r\n * What's responsible for sanitizing the input\r\n * and populating the defaults.\r\n */\r\n\r\n\r\nimport Option, { IKeys } from \"./models/Option\";\r\nimport { options, forbiddenOptions } from \"./options\";\r\n\r\n\r\n/**\r\n * Sanitizes a hierarchy object into an apropriate one.\r\n * \r\n * @param hierarchy The hierarchy object to sanitize.\r\n */\r\nexport function sanitize(hierarchy: any): void {\r\n\r\n    try {\r\n\r\n        // Looping through the available options.\r\n        options.forEach((opt: Option) => {\r\n\r\n            if (!(opt.label in hierarchy)) {\r\n\r\n                // Populating a default.\r\n                hierarchy[opt.label] = opt.default;\r\n            } else {\r\n\r\n                // Sanitizing the sub-option.\r\n                if ('keys' in opt) {\r\n\r\n                    for (const key in (<IKeys>opt).keys) {\r\n\r\n                        // Getting the sub-option.\r\n                        const subOption: Option = (<IKeys>opt).keys[key];\r\n\r\n                        // Sanitizing the sub-option.\r\n                        sanitizeOption(hierarchy[(<Option>opt).label], subOption);\r\n                    }\r\n                }\r\n            }\r\n\r\n        });\r\n\r\n        // Removing duplicates.\r\n        hierarchy.classes = hierarchy.classes.filter((cls: string, index: number) => hierarchy.classes.indexOf(cls) === index);\r\n\r\n        // Sorting the classes.\r\n        hierarchy.classes.sort();\r\n\r\n        // Checking if the hierarchy has children.\r\n        if ('childNodes' in hierarchy && hierarchy.childNodes.length > 0) {\r\n\r\n            hierarchy.childNodes.forEach((child: any) => {\r\n\r\n                sanitize(child);\r\n            });\r\n        }\r\n\r\n        // Checking if the hierarchy has templates.\r\n        if ('templates' in hierarchy && hierarchy.templates.length > 0) {\r\n\r\n            hierarchy.templates.forEach((template: any) => {\r\n\r\n                sanitizeTemplate(template);\r\n            });\r\n        }\r\n    }\r\n    catch (e) {\r\n\r\n        throw e;\r\n    }\r\n}\r\n\r\n\r\n/**\r\n * Sanitizes an option.\r\n * \r\n * @param hierarchy The hierarchy object to sanitize the option for.\r\n * @param option The option to sanitize.\r\n */\r\nfunction sanitizeOption(hierarchy: any, option: Option): void {\r\n\r\n    try {\r\n\r\n        if (!(option.label in hierarchy)) {\r\n\r\n            hierarchy[option.label] = option.default;\r\n        } else if (option.label === 'include' || option.label === 'exclude') {\r\n\r\n            // Removing duplicates from the “include” and “exclude” sub-option.\r\n            hierarchy[option.label] = hierarchy[option.label].filter((opt: string, index: number) => hierarchy[option.label].indexOf(opt) === index);\r\n        \r\n            // Sorting the values.\r\n            hierarchy[option.label].sort();\r\n        }\r\n\r\n        if ('keys' in option) {\r\n\r\n            for (const key in (<IKeys>option).keys) {\r\n\r\n                const\r\n                    subHierarchy: any = hierarchy[(<Option>option).label],\r\n                    subOption = (<IKeys>option).keys[key];\r\n\r\n                sanitizeOption(subHierarchy, subOption);\r\n            }\r\n        }\r\n    }\r\n    catch (e) {\r\n\r\n        throw e;\r\n    }\r\n}\r\n\r\n\r\n/**\r\n * Sanitizes templates.\r\n * \r\n * @param template The template to sanitize.\r\n */\r\nfunction sanitizeTemplate(template: any): void {\r\n\r\n    try {\r\n\r\n        // Looping through the allowed options in templates.\r\n        options\r\n            .filter((opt: Option) => forbiddenOptions.indexOf(opt.label) === -1)\r\n            .forEach((opt: Option) => {\r\n\r\n                // Checking of the template doesn't have a said option.\r\n                if (!(opt.label in template)) {\r\n\r\n                    // Populating a default.\r\n                    template[opt.label] = opt.default;\r\n                } else {\r\n\r\n                    // Sanitizing the sub-option.\r\n                    if ('keys' in opt) {\r\n\r\n                        for (const key in (<IKeys>opt).keys) {\r\n\r\n                            // Getting the sub-option.\r\n                            const subOption: Option = (<IKeys>opt).keys[key];\r\n\r\n                            // Sanitizing the sub-option.\r\n                            sanitizeOption(template[(<Option>opt).label], subOption);\r\n                        }\r\n                    }\r\n                }\r\n            });\r\n    }\r\n    catch (e) {\r\n\r\n        throw e;\r\n    }\r\n}\r\n","/**\r\n * What processes all of the references.\r\n */\r\n\r\n\r\nimport { Hierarchy } from \"./models/Hierarchy\";\r\nimport { Template } from \"./models/Template\";\r\nimport { validateReferences, validateTemplateReference, validateParentToChildReference } from \"./validator\";\r\nimport { getTemmeId } from \"./idfier\";\r\nimport { options } from \"./options\";\r\nimport Option from \"./models/Option\";\r\n\r\n\r\n/**\r\n * The reference type.\r\n */\r\nexport type ReferenceType = { depth: number, hierarchy: any };\r\n\r\n\r\n/**\r\n * Takes care of all the inheritance and references stuff.\r\n * \r\n * @param hierarchy The hierarchy to process the references for.\r\n */\r\nexport function process(hierarchy: any): void {\r\n\r\n    try {\r\n\r\n        const references: Array<ReferenceType> = getReferences(hierarchy);\r\n\r\n        // Validating all of the refereces.\r\n        validateReferences(hierarchy, references);\r\n\r\n        // Checking if templates are inheriting hierarchy objects.\r\n        validateTemplateReference(hierarchy, references);\r\n\r\n        // Checking if a parent is trying to reference their childern.\r\n        validateParentToChildReference(hierarchy, references);\r\n\r\n        // Processing template references.\r\n        processTemplates(hierarchy, references.filter((ref: ReferenceType) => isTemplate(ref.hierarchy)));\r\n\r\n        // Processing hierarchies (non-template) references.\r\n        processHierarchies(hierarchy, references);\r\n    }\r\n    catch (e) {\r\n\r\n        throw e;\r\n    }\r\n}\r\n\r\n\r\n/**\r\n * Checks if a hierarchy is a template or not.\r\n * \r\n * @param hierarchy The hierarchy to check.\r\n */\r\nexport const isTemplate = (hierarchy: any): boolean => getTemmeId(hierarchy).length === 4;\r\n\r\n\r\n/**\r\n * Processes all of the references for template hierarchies.\r\n * \r\n * @param hierarchy The hierarchy that contain templates to reference.\r\n * @param references The valid references.\r\n */\r\nfunction processTemplates(hierarchy: any, references: Array<ReferenceType>): void {\r\n\r\n    try {\r\n\r\n        // Checking if the hierarchy object has any templates.\r\n        if ('templates' in hierarchy && hierarchy.templates.length > 0) {\r\n\r\n            hierarchy.templates.forEach((template: any) => {\r\n\r\n                if (template.from.ref !== \"\") {\r\n\r\n                    for (const key in template) {\r\n\r\n                        // Getting the proper option.\r\n                        const\r\n                            option: any = options.filter((opt: Option) => opt.label === key)[0],\r\n                            referencedHierarchy: ReferenceType = references.filter((ref: ReferenceType) => ref.hierarchy.ref === template.from.ref)[0];\r\n\r\n                        // Inheriting the value.\r\n                        option.inherit(template, referencedHierarchy.hierarchy[key]);\r\n                    }\r\n                }\r\n            });\r\n        }\r\n\r\n        // Checking if the hierarchy object has any children.\r\n        if ('childNodes' in hierarchy && hierarchy.childNodes.length > 0) {\r\n\r\n            hierarchy.childNodes.forEach((child: Hierarchy) => {\r\n\r\n                processTemplates(child, references);\r\n            });\r\n        }\r\n    }\r\n    catch (e) {\r\n\r\n        throw e;\r\n    }\r\n}\r\n\r\n\r\n/**\r\n * Processes all of the references for hierarchy objects (non-templates).\r\n * \r\n * @param hierarchy The hierarchies to reference.\r\n * @param reference The valid references.\r\n */\r\nfunction processHierarchies(hierarchy: any, references: Array<ReferenceType>): void {\r\n\r\n    try {\r\n\r\n        // Checking if the hierarchy object has any children.\r\n        if ('childNodes' in hierarchy && hierarchy.childNodes.length > 0) {\r\n\r\n            hierarchy.childNodes.forEach((child: Hierarchy) => {\r\n\r\n                processHierarchies(child, references);\r\n            });\r\n        }\r\n\r\n        if (hierarchy.from.ref !== \"\") {\r\n\r\n            // If an outer element is referenced.\r\n            if (hierarchy.from.ref[0] === \"@\") {\r\n\r\n                const\r\n                    selector = hierarchy.from.ref.substring(1),\r\n                    element = document.querySelector(selector);\r\n\r\n                for (const key in hierarchy) {\r\n\r\n                    // Getting the proper option.\r\n                    const\r\n                        option: any = options.filter((opt: Option) => opt.label === key)[0],\r\n                        value = option.getKeyFromElement(element);\r\n\r\n                    if (value != null) {\r\n\r\n                        // Inheriting the value.\r\n                        option.inherit(hierarchy, value);\r\n                    }\r\n                }\r\n            } else {\r\n\r\n                const\r\n                    referencedHierarchy: ReferenceType = references.filter((ref: ReferenceType) => ref.hierarchy.ref === hierarchy.from.ref)[0],\r\n                    toInherit: Array<string> = hierarchy.from.include.filter((opt: string) => hierarchy.from.exclude.indexOf(opt) === -1);\r\n\r\n                toInherit.forEach((optName: string) => {\r\n\r\n                    // Getting the proper option.\r\n                    const option: Option = options.filter((opt: Option) => opt.label === optName)[0];\r\n\r\n                    // Inheriting the value.\r\n                    option.inherit(hierarchy, referencedHierarchy.hierarchy[optName]);\r\n                });\r\n            }\r\n        }\r\n    }\r\n    catch (e) {\r\n\r\n        throw e;\r\n    }\r\n}\r\n\r\n\r\n/**\r\n * Getting all the references in a said hierarchy.\r\n * \r\n * @param hierarchy The hierarchy object to get the references from.\r\n * @param depth The current depth in the said hierarchy object.\r\n */\r\nfunction getReferences(hierarchy: any, depth: number = 0): Array<ReferenceType> {\r\n\r\n    const references: Array<ReferenceType> = [];\r\n\r\n    // Incrementing the depth.\r\n    depth++;\r\n\r\n    // Checking if the reference is valid.\r\n    if (hierarchy.ref !== \"\") {\r\n\r\n        references.push({\r\n            depth: depth,\r\n            hierarchy: hierarchy\r\n        });\r\n    }\r\n\r\n    // Checking if the hierarchy object has any children.\r\n    if ('childNodes' in hierarchy && hierarchy.childNodes.length > 0) {\r\n\r\n        hierarchy.childNodes.forEach((child: Hierarchy) => {\r\n\r\n            references.push(...getReferences(child, depth));\r\n        });\r\n    }\r\n\r\n    // Checking if the hierarchy object has any templates.\r\n    if ('templates' in hierarchy && hierarchy.templates.length > 0) {\r\n\r\n        hierarchy.templates.forEach((template: Template) => {\r\n\r\n            // Substracting 1 to make templates on the same depth level\r\n            // as their hierarchy parent.\r\n            references.push(...getReferences(template, depth - 1));\r\n        });\r\n    }\r\n\r\n    // Returning all found references.\r\n    return references;\r\n}\r\n","/**\r\n * What parses the hierarchy to an HTML tree.\r\n */\r\n\r\n\r\nimport { Hierarchy } from './models/Hierarchy'\r\nimport { getTemmeId } from './idfier';\r\nimport { options } from './options';\r\nimport Option, { IParser } from './models/Option';\r\n\r\n\r\n/**\r\n * Parses the hierarchy object into an HTML element.\r\n * \r\n * @param hierarchy The hierarchy object to parse.\r\n * @param parent The HTML element to host the parsed element.\r\n * @param nodeCallback The callback that executes whenever an HTML element has been created.\r\n * @param topParent Whether or not we're parsing the top parent.\r\n */\r\nexport function parse(hierarchy: any, parent: HTMLElement, nodeCallback: (temmeId: string, currentHierarchy: any) => void, topParent: boolean = false): void {\r\n\r\n    try {\r\n\r\n        // Parsing the element.\r\n        const element: HTMLElement = parseElement(hierarchy, parent, topParent);\r\n\r\n        // Executing the node callback.\r\n        nodeCallback(getTemmeId(hierarchy), hierarchy);\r\n\r\n        // Checking if the hierarchy object has any children.\r\n        if ('childNodes' in hierarchy && hierarchy.childNodes.length > 0) {\r\n\r\n            hierarchy.childNodes.forEach((child: Hierarchy) => {\r\n\r\n                parse(child, element, nodeCallback);\r\n            });\r\n        }\r\n    }\r\n    catch (e) {\r\n\r\n        throw e;\r\n    }\r\n}\r\n\r\n\r\n/**\r\n * Converts a hierarchy into an HTML element.\r\n * \r\n * @param hierarchy The hierarchy to parse.\r\n * @param parent The HTML element to host the parsed hierarchy.\r\n * @param topParent Whether or not the parsed element is the top parent.\r\n */\r\nfunction parseElement(hierarchy: Hierarchy, parent: HTMLElement, topParent: boolean = false): HTMLElement {\r\n\r\n    try {\r\n\r\n        // Creating an HTML tag out of the hierarchy.\r\n        const element: HTMLElement = (topParent === true) ? parent : document.createElement(hierarchy.name);\r\n\r\n        // Appending the appropriate values.\r\n        options.forEach((opt: Option | IParser) => {\r\n\r\n            if (typeof (<IParser>opt).parse === 'function') {\r\n\r\n                (<IParser>opt).parse(element, hierarchy);\r\n            }\r\n        });        \r\n\r\n        // Appending the created element.\r\n        if (topParent === false) {\r\n            parent.appendChild(element);\r\n        }\r\n\r\n        // Returning the parsed element.\r\n        return element;\r\n    }\r\n    catch(e) {\r\n\r\n        throw e;\r\n    }\r\n}\r\n","/**\r\n * The error thrown when a hierarchy object\r\n * is not valid.\r\n */\r\n\r\n\r\nimport TemmyError from \"../models/TemmyError\";\r\n\r\n\r\nexport default class InvalidHierarchyError extends TemmyError {\r\n\r\n    /**\r\n     * The name of the error.\r\n     */\r\n    public name: string = \"InvalidHierarchyError\";\r\n\r\n    /**\r\n     * The message of the error.\r\n     */\r\n    public message: string = \"The hierarchy object is not valid\";\r\n\r\n    /**\r\n     * Constructor with parameters.\r\n     * \r\n     * @param message The message of the error.\r\n     */\r\n    constructor(message: string) {\r\n\r\n        // Calling the parent class `TemmyError`.\r\n        super(\"\");\r\n\r\n        // Updating the error's message.\r\n        this.message = message.length > 0 ? message : this.message;\r\n    }\r\n}\r\n","/**\r\n * The error thrown when a target is not a valid\r\n * HTML element.\r\n */\r\n\r\nimport TemmyError from \"../models/TemmyError\";\r\n\r\nexport default class InvalidTargetError extends TemmyError {\r\n\r\n    /**\r\n     * The name of the error.\r\n     */\r\n    public name: string = \"InvalidTargetError\";\r\n\r\n    /**\r\n     * The message of the error.\r\n     */\r\n    public message: string = \"The target is not a valid HTML element\";\r\n\r\n    /**\r\n     * Constructor with parameters.\r\n     * \r\n     * @param message The message of the error.\r\n     */\r\n    constructor(message: string) {\r\n\r\n        // Calling the parent class `TemmyError`.\r\n        super(\"\");\r\n\r\n        // Updating the error's message.\r\n        this.message = message.length > 0 ? message : this.message;\r\n    }\r\n}\r\n","/**\r\n * \r\n * @name:       temmejs\r\n * @version:    1.0.1\r\n * @author:     EOussama\r\n * @license     MIT\r\n * @source:     https://github.com/EOussama/temmejs\r\n * \r\n * Temme (or Emmet in reverse) is to javascript what Emmet is to HTML and CSS,\r\n * with no doubts, Emmet saved us from the headache of working with HTML and CSS, \r\n * and now, Temme is doing Javascript the same favour too.\r\n * \r\n */\r\n\r\n\r\nimport * as Validator from \"./modules/validator\";\r\nimport * as Sanitizer from \"./modules/sanitizer\";\r\nimport * as Referencer from \"./modules/referencer\";\r\nimport * as Parser from './modules/parser';\r\nimport * as Idfier from \"./modules/idfier\";\r\nimport TemmyError from \"./modules/models/TemmyError\";\r\nimport InvalidHierarchyError from \"./modules/errors/InvalidHierarchyError\";\r\nimport InvalidTargetError from \"./modules/errors/InvalidTargetError\";\r\n\r\n\r\n/**\r\n * The entry point of Temme, it's what initiates everything\r\n * from sanitizing, to parsing, like a boss.\r\n * \r\n * @param hierarchy The hierarchy object that maps the HTML skeleton.\r\n * @param target The HTML element that will host the parsed skeleton.\r\n * @param endCallback The function that execute when the skeleton has been parsed.\r\n * @param nodeCallback The function that executes whenever an element has been parsed.\r\n * \r\n * @throws InvalidTargetError, InvalidHierarchyError\r\n */\r\nexport function parse(hierarchy: Object, target: HTMLElement, endCallback: (resultedHierarchy: any) => void = (hierarchy) => { }, nodeCallback: (temmeId: string, currentHierarchy: any) => void = () => { }): Object {\r\n\r\n    try {\r\n\r\n        // Checking if the target is a valid HTML element and throwing\r\n        // an error if it's not.\r\n        if (!Validator.isValidHTMLElement(target)) {\r\n            throw new InvalidTargetError(\"\");\r\n        }\r\n\r\n        // Checking if the hierarchy object is and throwing\r\n        // an error if it's not.\r\n        if (!Validator.isValidHierarchy(hierarchy)) {\r\n            throw new InvalidHierarchyError(\"\");\r\n        }\r\n\r\n        // Checking if the hierarchy object contains\r\n        // valid options.\r\n        Validator.validateOptions(hierarchy);\r\n\r\n        // Sanitizing the hierarchy.\r\n        Sanitizer.sanitize(hierarchy);\r\n\r\n        // Assigning temmeIds to the hierarchy object.\r\n        Idfier.idfy(hierarchy);\r\n\r\n        // Processing all of the references.\r\n        Referencer.process(hierarchy);\r\n\r\n        // Parsing the hierarchy into an HTML tree.\r\n        Parser.parse(hierarchy, target, nodeCallback, true);\r\n\r\n        // Executing the end callback.\r\n        endCallback(hierarchy);\r\n\r\n        // Returning the resulted hierarchy object.\r\n        return hierarchy;\r\n    }\r\n    catch (e) {\r\n\r\n        // Appending a tag in front of the error's message.\r\n        (<TemmyError>e).message = `[Temme]: ${e.message}.`;\r\n\r\n        // Throwing the error.\r\n        throw e;\r\n    }\r\n}\r\n\r\n/**\r\n * Validates the hierarchy object\r\n *\r\n * @param hierarchy The hierarchy object that maps the HTML skeleton.\r\n * @throws InvalidHierarchyError\r\n */\r\nexport function validate(hierarchy: Object): Object {\r\n    try {\r\n\r\n        // Validate options\r\n        Validator.validateOptions(hierarchy);\r\n\r\n        // Returns a valid object\r\n        return {\r\n            valid: true,\r\n            error: null\r\n        };\r\n    } catch (err) {\r\n\r\n        // Returns an invalid object\r\n        return {\r\n            valid: false,\r\n            error: err\r\n        }\r\n    }\r\n}\r\n"],"sourceRoot":""}