hotstaq 0.8.21 → 0.8.23

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -1,2 +1,2 @@
1
- var HotStaqWeb;(()=>{var __webpack_modules__={230:t=>{t.exports="object"==typeof self?self.FormData:window.FormData},646:function(t){t.exports=function(){"use strict";function t(t){for(var e=1;e<arguments.length;e++){var n=arguments[e];for(var r in n)t[r]=n[r]}return t}return function e(n,r){function o(e,o,s){if("undefined"!=typeof document){"number"==typeof(s=t({},r,s)).expires&&(s.expires=new Date(Date.now()+864e5*s.expires)),s.expires&&(s.expires=s.expires.toUTCString()),e=encodeURIComponent(e).replace(/%(2[346B]|5E|60|7C)/g,decodeURIComponent).replace(/[()]/g,escape);var i="";for(var l in s)s[l]&&(i+="; "+l,!0!==s[l]&&(i+="="+s[l].split(";")[0]));return document.cookie=e+"="+n.write(o,e)+i}}return Object.create({set:o,get:function(t){if("undefined"!=typeof document&&(!arguments.length||t)){for(var e=document.cookie?document.cookie.split("; "):[],r={},o=0;o<e.length;o++){var s=e[o].split("="),i=s.slice(1).join("=");try{var l=decodeURIComponent(s[0]);if(r[l]=n.read(i,l),t===l)break}catch(t){}}return t?r[t]:r}},remove:function(e,n){o(e,"",t({},n,{expires:-1}))},withAttributes:function(n){return e(this.converter,t({},this.attributes,n))},withConverter:function(n){return e(t({},this.converter,n),this.attributes)}},{attributes:{value:Object.freeze(r)},converter:{value:Object.freeze(n)}})}({read:function(t){return'"'===t[0]&&(t=t.slice(1,-1)),t.replace(/(%[\dA-F]{2})+/gi,decodeURIComponent)},write:function(t){return encodeURIComponent(t).replace(/%(2[346BF]|3[AC-F]|40|5[BDE]|60|7[BCD])/g,decodeURIComponent)}},{path:"/"})}()},300:(t,e)=>{"use strict";var n=function(){if("undefined"!=typeof self)return self;if("undefined"!=typeof window)return window;if(void 0!==n)return n;throw new Error("unable to locate global object")}();t.exports=e=n.fetch,n.fetch&&(e.default=n.fetch.bind(n)),e.Headers=n.Headers,e.Request=n.Request,e.Response=n.Response},507:function(t,e,n){"use strict";var r=this&&this.__awaiter||function(t,e,n,r){return new(n||(n=Promise))((function(o,s){function i(t){try{a(r.next(t))}catch(t){s(t)}}function l(t){try{a(r.throw(t))}catch(t){s(t)}}function a(t){var e;t.done?o(t.value):(e=t.value,e instanceof n?e:new n((function(t){t(e)}))).then(i,l)}a((r=r.apply(t,e||[])).next())}))},o=this&&this.__importDefault||function(t){return t&&t.__esModule?t:{default:t}};Object.defineProperty(e,"__esModule",{value:!0}),e.Hot=e.DeveloperMode=void 0;const s=n(732),i=n(243),l=n(967),a=o(n(646)),u=o(n(300)),c=n(70);var h;!function(t){t[t.Production=0]="Production",t[t.Development=1]="Development"}(h=e.DeveloperMode||(e.DeveloperMode={}));class p{static include(t,e=null){return r(this,void 0,void 0,(function*(){if(!0===i.HotStaq.isWeb&&"string"==typeof t){const e=t.toLowerCase();e.indexOf(".hott")>-1&&e.indexOf("nahfam")<0&&(t+="?hstqserve=nahfam")}p.echo(yield p.getFile(t,e))}))}static includeJS(t,e=null,o=null){return r(this,void 0,void 0,(function*(){const r=yield p.getFile(t,e);return!0===i.HotStaq.isWeb?null==o&&(o=window):null==o&&(o=n.g),eval.apply(o,[r])}))}static import(t,e=null,o=null){return r(this,void 0,void 0,(function*(){let r=p.CurrentPage.processor.getModule(t);if(null!=r)return r;const s=`./hotstaq_modules/${t}/index.js`,l=yield p.getFile(s,e);!0===i.HotStaq.isWeb?null==o&&(o=window):null==o&&(o=n.g);let a=new Function(l).apply(o);return null!=a.loadHTML&&(yield a.loadHTML()),p.CurrentPage.processor.addModule(t,a),a}))}static runFile(t,e=null){return r(this,void 0,void 0,(function*(){let n=p.CurrentPage.processor.getFile(t);n.page=this.CurrentPage;let r=yield n.process(e);p.echo(r)}))}static getFile(t,e=null){return r(this,void 0,void 0,(function*(){let n=null;"string"==typeof t?(n=new s.HotFile,n.name=t,!0===i.HotStaq.isWeb?n.url=t:n.localFile=t):n=t;let r=p.CurrentPage.processor.getFile(n.name,!1);return null!=r&&(n=r),yield n.load(),n.page=this.CurrentPage,yield n.process(e)}))}static apiCall(t,e=null,n=c.HotEventMethod.POST,o={}){return r(this,void 0,void 0,(function*(){let r=null;if(null==p.CurrentPage)throw new Error("Current page is null!");if(null==p.CurrentPage.processor)throw new Error("Current page's processor is null!");if(null==p.CurrentPage.processor.api)throw new Error("Current page's processor api is null! Did you forget to set the API name or URL?");return null!=p.CurrentPage.processor.api&&(r=yield p.CurrentPage.processor.api.makeCall(t,e,n,o)),r}))}static getJSON(t){return r(this,void 0,void 0,(function*(){return p.jsonRequest(t,null,c.HotEventMethod.GET)}))}static jsonRequest(t,e=null,n=c.HotEventMethod.POST){return r(this,void 0,void 0,(function*(){try{let r={method:n,headers:{Accept:"application/json","Content-Type":"application/json"}};n===c.HotEventMethod.POST&&(r.body=JSON.stringify(e));let o=yield(0,u.default)(t,r);if(!1===o.ok)throw new Error(`${o.status}: ${o.statusText}`);return yield o.json()}catch(e){return JSON.stringify({error:`${e.message} - Could not fetch ${t}`})}}))}static httpRequest(t,e){return r(this,void 0,void 0,(function*(){return yield(0,u.default)(t,e)}))}static echo(t){p.Output+=t}static displayCSS(){for(let t=0;t<p.CSS.length;t++){let e=p.CSS[t],n=p.cssStr;n=n.replace(/\%CSS_FILE\%/g,e),p.echo(n)}}static displayJSFiles(){for(let t=0;t<p.JSFiles.length;t++){let e=p.JSFiles[t],n=p.jsFileStr;n=n.replace(/\%JS_FILE\%/g,e),p.echo(n)}}static displayJSScripts(){for(let t=0;t<p.JSScripts.length;t++){let e=p.JSScripts[t],n=p.jsScriptsStr;n=n.replace(/\%JS_CODE\%/g,e),p.echo(n)}}}e.Hot=p,p.CurrentPage=null,p.Arguments=null,p.DeveloperMode=h,p.HotTestElement=l.HotTestElement,p.Mode=h.Production,p.API=null,p.TesterAPI=null,p.Output="",p.Data={},p.Cookies=a.default,p.PublicKeys={},p.cssStr='<link rel = "stylesheet" href = "%CSS_FILE%" />',p.CSS=[],p.JSFiles=[],p.JSScripts=[],p.jsFileStr='<script type = "text/javascript" src = "%JS_FILE%"><\/script>',p.jsScriptsStr='<script type = "text/javascript">%JS_CODE%<\/script>'},233:function(t,e,n){"use strict";var r=this&&this.__awaiter||function(t,e,n,r){return new(n||(n=Promise))((function(o,s){function i(t){try{a(r.next(t))}catch(t){s(t)}}function l(t){try{a(r.throw(t))}catch(t){s(t)}}function a(t){var e;t.done?o(t.value):(e=t.value,e instanceof n?e:new n((function(t){t(e)}))).then(i,l)}a((r=r.apply(t,e||[])).next())}))},o=this&&this.__importDefault||function(t){return t&&t.__esModule?t:{default:t}};Object.defineProperty(e,"__esModule",{value:!0}),e.HotAPI=e.EventExecutionType=void 0;const s=o(n(300)),i=o(n(230)),l=n(810),a=n(761),u=n(70);var c;!function(t){t[t.HotRoute=0]="HotRoute",t[t.HotMethod=1]="HotMethod",t[t.HotAPI=2]="HotAPI"}(c=e.EventExecutionType||(e.EventExecutionType={})),e.HotAPI=class{constructor(t,e,n=null){if(null==e)throw new Error(`No server attached to api with baseUrl: ${t}`);this.connection=e,this.description="",this.baseUrl=t,this.createFunctions=!0,this.executeEventsUsing=c.HotRoute,this.db=n,this.authCredentials=null,this.userAuth=null,this.routes={},this.onPreRegister=null,this.onPostRegister=null}setDBSchema(t){if(null==this.connection.api)throw new Error("No API has been set!");if(null==this.connection.api.db)throw new Error(`No database has been set for API base url ${this.connection.api.baseUrl}`);this.connection.api.db.schema=t}getDB(){if(null==this.connection.api.db)throw new Error(`No database has been set for API base url ${this.connection.api.baseUrl}`);return this.connection.api.db}getDBSchema(){if(null==this.connection.api.db)throw new Error(`No database has been set for API base url ${this.connection.api.baseUrl}`);return this.connection.api.db.schema}addRoute(t,e=null,n=null){let r="";if("string"==typeof t?(r=t,null==this.routes[r]&&(this.routes[r]=new a.HotRoute(this.connection,r)),"string"==typeof e?this.routes[r].addMethod(new u.HotRouteMethod(this.routes[r],e,n)):this.routes[r].addMethod(e)):(r=t.route,this.routes[t.route]=t),this.routes[r].connection=this.connection,!0===this.createFunctions){let t=this[r];null==t&&(t={});for(let e=0;e<this.routes[r].methods.length;e++){let n=this.routes[r],o=this.routes[r].methods[e];t[o.name]=(t,e)=>{let r=o.type,s=o.getRouteUrl(),i=null;if(null!=this.authCredentials&&(i=this.authCredentials),null!=o.authCredentials?i=o.authCredentials:null!=o.route.authCredentials&&(i=o.route.authCredentials),null==i&&"undefined"!=typeof Hot&&null!=Hot&&null!=Hot.API&&null!=Hot.API[n.route]&&null!=Hot.API[n.route].authCredentials&&(i=Hot.API[n.route].authCredentials),null!=i)for(let e in i){let n=i[e];null==t[e]&&(t[e]=n)}let l=[s,t,r,e];return this.makeCall.apply(this,l)}}this[r]=t}}registerRoute(t){return r(this,void 0,void 0,(function*(){this.connection instanceof l.HotServer&&(yield this.connection.registerRoute(t))}))}registerRoutes(){return r(this,void 0,void 0,(function*(){for(let t in this.routes){let e=this.routes[t];yield this.registerRoute(e)}}))}makeCall(t,e,n=u.HotEventMethod.POST,o={}){return r(this,void 0,void 0,(function*(){let l=this.baseUrl;const a=n.toUpperCase();if("/"===l[l.length-1]&&(l=l.substr(0,l.length-1)),"/"!==t[0]&&(l+="/"),l+=t,Object.keys(o).length>0){if("POST"!==a)throw new Error("To upload files, you must set the httpMethod to POST.");const r=new i.default;for(let t in o)r.append(t,o[t]);let u=yield(0,s.default)(l,{method:"POST",body:r}),c=yield u.json();return null==e.hotstaq&&(e.hotstaq={}),null==e.hotstaq.uploads&&(e.hotstaq.uploads={}),e.hotstaq.uploads.uploadId=c.hotstaq.uploads.uploadId,yield this.makeCall(t,e,n)}let u={method:n,headers:{Accept:"application/json","Content-Type":"application/json"}};return"GET"!==a&&"HEAD"!==a&&(u.body=JSON.stringify(e)),new Promise(((t,e)=>{(0,s.default)(l,u).then((e=>r(this,void 0,void 0,(function*(){e.json().then((e=>{t(e)})).catch((t=>{throw new Error(`${l}: ${t.message}`)}))})))).catch((t=>{throw new Error(`${l}: ${t.message}`)}))}))}))}}},316:(t,e)=>{"use strict";Object.defineProperty(e,"__esModule",{value:!0}),e.HotAsset=void 0,e.HotAsset=class{constructor(t,e=""){this.type=t,this.name=e,this.path="",this.content=""}load(){}output(){if(null==this.path&&null==this.content)throw new Error(`HotAsset ${this.name} of type ${this.type} does not have a path or content set!`);let t="";if(null!=this.path&&""!==this.path&&("js"===this.type&&(t=`<script type = "text/javascript" src = "${this.path}"><\/script>`),"css"===this.type&&(t=`<link href = "${this.path}" rel = "stylesheet" />`),"html"===this.type||"component"===this.type)){if(""===this.name)throw new Error("Loading an HTML or component asset requires a name to be set!");this.path,t={name:this.name,url:this.path}}if(null!=this.content&&""!==this.content){if("js"===this.type)throw new Error("Loading JS assets using content is not supported yet!");if("css"===this.type)throw new Error("Loading CSS assets using content is not supported yet!");if("html"===this.type){if(""===this.name)throw new Error("Loading an HTML asset requires a name to be set!");let e=JSON.stringify(this.content),n=this.path,r="";e=e.replace(new RegExp("\\<script","gmi"),'<scr" + "ipt'),e=e.replace(new RegExp("\\<\\/script","gmi"),'</scr" + "ipt'),r=e,t={name:this.name,url:n,content:e}}}return t}}},957:(t,e,n)=>{"use strict";Object.defineProperty(e,"__esModule",{value:!0}),e.HotClient=void 0;const r=n(810);e.HotClient=class{constructor(t){this.processor=t,this.api=null,this.testerAPI=null,this.type=r.HotServerType.HTTP,this.logger=t.logger}}},260:(t,e,n)=>{"use strict";Object.defineProperty(e,"__esModule",{value:!0}),e.HotComponent=void 0;const r=n(243);e.HotComponent=class{constructor(t,e=null){t instanceof r.HotStaq||null==t?(this.processor=t,this.htmlElements=[],this.name="",this.tag="",this.api=null,this.elementOptions=void 0,this.observedAttributes=[],this.type="",this.value=null,this.inner=null,this.events={}):(this.processor=t.processor,this.htmlElements=t.htmlElements||[],this.name=t.name||"",this.tag=t.tag||this.name,this.api=t.api||null,this.elementOptions=t.elementOptions||void 0,this.observedAttributes=t.observedAttributes||[],this.type=t.type||"",this.value=t.value||null,this.inner=t.inner||null,this.events={}),null!=e&&(this.api=e)}onCreated(t){return t}}},732:function(t,e,n){"use strict";var r=this&&this.__createBinding||(Object.create?function(t,e,n,r){void 0===r&&(r=n),Object.defineProperty(t,r,{enumerable:!0,get:function(){return e[n]}})}:function(t,e,n,r){void 0===r&&(r=n),t[r]=e[n]}),o=this&&this.__setModuleDefault||(Object.create?function(t,e){Object.defineProperty(t,"default",{enumerable:!0,value:e})}:function(t,e){t.default=e}),s=this&&this.__importStar||function(t){if(t&&t.__esModule)return t;var e={};if(null!=t)for(var n in t)"default"!==n&&Object.prototype.hasOwnProperty.call(t,n)&&r(e,t,n);return o(e,t),e},i=this&&this.__awaiter||function(t,e,n,r){return new(n||(n=Promise))((function(o,s){function i(t){try{a(r.next(t))}catch(t){s(t)}}function l(t){try{a(r.throw(t))}catch(t){s(t)}}function a(t){var e;t.done?o(t.value):(e=t.value,e instanceof n?e:new n((function(t){t(e)}))).then(i,l)}a((r=r.apply(t,e||[])).next())}))},l=this&&this.__importDefault||function(t){return t&&t.__esModule?t:{default:t}};Object.defineProperty(e,"__esModule",{value:!0}),e.HotFile=void 0;const a=s(n(351)),u=l(n(300)),c=n(507);class h{constructor(t={}){this.page=t.page||null,this.name=t.name||"",this.url=t.url||"",this.localFile=t.localFile||"",this.content=t.content||"",this.throwAllErrors=t.throwAllErrors||!1}setContent(t){this.content=t}getContent(){return this.content}static httpGet(t){return i(this,void 0,void 0,(function*(){try{let e=yield(0,u.default)(t);if(!1===e.ok)throw new Error(`${e.status}: ${e.statusText}`);return yield e.text()}catch(e){return JSON.stringify({error:`${e.message} - Could not fetch ${t}`})}}))}loadUrl(){return i(this,void 0,void 0,(function*(){return this.content=yield h.httpGet(this.url),this.content}))}loadLocalFile(){return i(this,void 0,void 0,(function*(){return new Promise(((t,e)=>{a.readFile(this.localFile,((e,n)=>{if(null!=e)throw e;let r=n.toString();this.content=r,t(this.content)}))}))}))}load(){return i(this,void 0,void 0,(function*(){let t="";return""!==this.url&&(t=yield this.loadUrl()),""!==this.localFile&&(t=yield this.loadLocalFile()),t}))}static processContent(t,e,n,r,o=2,s=2){let i=e.exec(t),l=0,a="";for(;null!=i;){let u=i.index-o,c=e.lastIndex+s,h=t.substr(l,u-l);l=c,a+=r(h),a+=n(i[0]),i=e.exec(t)}return a+=r(t.substr(l)),a}static processNestedContent(t,e,n,r,o,s,i=2,l=1){let a=t.indexOf(e),u=0,c=t.indexOf(r,a),h="";for(;a>-1;){let p=t.indexOf(n,a),d=0;if(""!==r){let e=t.lastIndexOf(r,p-l);for(;e>-1&&e!==c;)e=t.lastIndexOf(r,e-l),d++}if(d>0){let r=t.indexOf(n,p+l),o=r;for(;r>-1&&d>0&&!(o<0)&&!(t.lastIndexOf(e,o-l)>r);)r=o,o=t.indexOf(n,r+l),d--;p=r}h+=s(t.substr(u,a-u)),h+=o(t.substr(a+i,p-(a+i))),a=t.indexOf(e,p+l),c=t.indexOf(r,a),u=p+l}return h+=s(t.substr(u)),h}static parseContent(t,e,n=null){null==n&&(n={outputCommands:!0,allowStringify:!0});let r="JSON.stringify (",o=")";return!1===n.allowStringify&&(r="",o=""),h.processContent(t,new RegExp("(?=\\<\\*)([\\s\\S]*?)(?=\\*\\>)","g"),(t=>`${t=t.substr(2)}`),(t=>{if(""===t)return"";let s=h.processNestedContent(t,"!{","}","{",(t=>`*&&%*%@#@!${t}*&!#%@!@*!`),(t=>t)),i=h.processNestedContent(s,"STR{","}","{",(t=>{let s="";return s=!0===n.outputCommands?`*&&%*%@#@!echoOutput (JSON.stringify(${t}), ${e});*&!#%@!@*!`:`*&&%*%@#@!${r}${t}${o}, ${e});*&!#%@!@*!`,s}),(t=>t),4,1),l=h.processNestedContent(i,"${","}","{",(t=>{let r="";var o;return!0===n.outputCommands?(r=`*&&%*%@#@!try { Hot.echo (${t}); }catch (ex){Hot.echo (\`\\\${${o=t,o.replace(/[`]/g,"\\`")}}\`);}*&!#%@!@*!`,!0===e&&(r=`*&&%*%@#@!Hot.echo (${t});*&!#%@!@*!`)):r=`*&&%*%@#@!${t}*&!#%@!@*!`,r}),(t=>t)),a="";c.Hot.Mode===c.DeveloperMode.Production&&(a=h.processNestedContent(l,"?(",")","(",(t=>""),(t=>t))),c.Hot.Mode===c.DeveloperMode.Development&&(a=h.processNestedContent(l,"?(",")","(",(t=>{let e="";try{JSON.parse(t),e=!0===n.allowStringify?JSON.stringify(t):`${t}`}catch(n){e=`${t}`}let r="";if(!0===n.outputCommands)r=`*&&%*%@#@!{\nconst testElm = createTestElement (${e});\nHot.echo (\`data-test-object-name = "\${testElm.name}" data-test-object-func = "\${testElm.func}" data-test-object-value = "\${testElm.value}"\`);\n}*&!#%@!@*!\n`;else{let t=t=>{let e=null;try{let n=t;if("string"==typeof t&&(n=JSON.parse(t)),"string"==typeof n&&(e=new c.Hot.HotTestElement(n)),n instanceof Array&&(e=new c.Hot.HotTestElement(n[0],n[1],n[2])),null!=n.name&&(e=new c.Hot.HotTestElement(n)),null!=c.Hot.CurrentPage.testElements[e.name])throw new Error(`Test element ${e.name} already exists!`)}catch(e){throw new Error(`Error processing test element ${t} in ${c.Hot.CurrentPage.name}. Error: ${e.message}`)}return e};const n=t(e);r=`*&&%*%@#@!data-test-object-name = "${n.name}" data-test-object-func = "${n.func}" data-test-object-value = "${n.value}"*&!#%@!@*!`}return r}),(t=>t)));let u=h.processNestedContent(a,"*&&%*%@#@!","*&!#%@!@*!","*&&%*%@#@!",(t=>t),(t=>{let r="";r=!0===n.allowStringify?JSON.stringify(t):t;let o="";return o=!0===n.outputCommands?`echoOutput (${r}, ${e});\n`:r,o}),"*&&%*%@#@!".length,"*&!#%@!@*!".length);return u=u.replace(/\*\&\&\%\*\%\@\#\@\!/g,""),u=u.replace(/\*\&\!\#\%\@\!\@\*\!/g,""),u}),0)}process(t=null){return i(this,void 0,void 0,(function*(){let e=this.content;if(null!=t&&t instanceof Array)throw new Error(`In ${this.name}, the passed arguments received cannot be an array!`);c.Hot.Mode=this.page.processor.mode,c.Hot.Arguments=t,c.Hot.CurrentPage=this.page,c.Hot.PublicKeys=this.page.processor.publicKeys,c.Hot.API=this.page.getAPI(),c.Hot.TesterAPI=this.page.getTesterAPI();let n=h.parseContent(e,this.throwAllErrors),r=null;try{let e="\n\t\t\tvar Hot = arguments[0];\n\t\t\tvar PassedHotFile = arguments[1];\n\n\t\t\t";if("string"==typeof t)throw new Error("The passing arguments cannot be a string!");for(let n in t){let r="",o=t[n];r=`var ${n} = ${JSON.stringify(o)};\n`,e+=r}let o=this.name;""===o&&(o=this.localFile),""===o&&(o=this.url),e+='\n\t\t\tfunction echoOutput (content, throwErrors)\n\t\t\t{\n\t\t\t\tif (throwErrors == null)\n\t\t\t\t\tthrowErrors = true;\n\n\t\t\t\tif (throwErrors === true)\n\t\t\t\t{\n\t\t\t\t\tHot.echo (content);\n\n\t\t\t\t\treturn;\n\t\t\t\t}\n\n\t\t\t\ttry\n\t\t\t\t{\n\t\t\t\t\tHot.echo (content);\n\t\t\t\t}\n\t\t\t\tcatch (ex)\n\t\t\t\t{\n\t\t\t\t\tHot.echo ("");\n\t\t\t\t}\n\t\t\t}\n\n\t\t\tfunction createTestElement (foundStr)\n\t\t\t{\n\t\t\t\tlet testElm = null;\n\n\t\t\t\ttry\n\t\t\t\t{\n\t\t\t\t\tlet obj = foundStr;\n\n\t\t\t\t\tif (typeof (foundStr) === "string")\n\t\t\t\t\t\tobj = JSON.parse (foundStr);\n\n\t\t\t\t\tif (typeof (obj) === "string")\n\t\t\t\t\t\ttestElm = new Hot.HotTestElement (obj);\n\n\t\t\t\t\tif (obj instanceof Array)\n\t\t\t\t\t\ttestElm = new Hot.HotTestElement (obj[0], obj[1], obj[2]);\n\n\t\t\t\t\tif (obj["name"] != null)\n\t\t\t\t\t\ttestElm = new Hot.HotTestElement (obj);\n\n\t\t\t\t\tif (Hot.CurrentPage.testElements[testElm.name] != null)\n\t\t\t\t\t\tthrow new Error (`Test element ${testElm.name} already exists!`);\n\n\t\t\t\t\tHot.CurrentPage.addTestElement (testElm);\n\t\t\t\t}\n\t\t\t\tcatch (ex)\n\t\t\t\t{\n\t\t\t\t\tthrow new Error (\n\t\t\t`Error processing test element ${foundStr} in ${Hot.CurrentPage.name}. Error: ${ex.message}`\n\t\t\t\t\t\t);\n\t\t\t\t}\n\n\t\t\t\treturn (testElm);\n\t\t\t}\n\n\t\t\tasync function runContent (CurrentHotFile)\n\t\t\t{\n',e+=n,e+="\n\t\t\t}\n\n\t\t\treturn (runContent (PassedHotFile).then (() =>\n\t\t\t{\n\t\t\t\treturn ({\n\t\t\t\t\t\thot: Hot,\n\t\t\t\t\t\toutput: Hot.Output,\n\t\t\t\t\t\tdata: JSON.stringify (Hot.Data)\n\t\t\t\t\t});\n\t\t\t}));";let s=new Function(e);r=yield s.apply(this,[c.Hot,this])}catch(t){throw SyntaxError,t}c.Hot.Data=r.hot.Data;let o=r.output;return c.Hot.Output="",o}))}}e.HotFile=h},802:(t,e)=>{"use strict";var n;Object.defineProperty(e,"__esModule",{value:!0}),e.HotLog=e.HotLogLevel=void 0,function(t){t[t.Info=0]="Info",t[t.Warning=1]="Warning",t[t.Error=2]="Error",t[t.Verbose=3]="Verbose",t[t.All=4]="All",t[t.None=5]="None"}(n=e.HotLogLevel||(e.HotLogLevel={})),e.HotLog=class{constructor(t=n.All){this.logLevel=t}static parse(t){let e=n.All;return"info"===t&&(e=n.Info),"warning"===t&&(e=n.Warning),"error"===t&&(e=n.Error),"verbose"===t&&(e=n.Verbose),"all"===t&&(e=n.All),"none"===t&&(e=n.None),e}log(t,e){this.logLevel===n.Verbose&&(t===n.Error&&this.error(e),t===n.Warning&&this.warning(e),t!==n.Info&&t!==n.Verbose||this.info(e)),this.logLevel===n.All&&(t===n.Error&&this.error(e),t===n.Warning&&this.warning(e),t===n.Info&&this.info(e)),this.logLevel===n.Error&&t===n.Error&&this.error(e),this.logLevel===n.Warning&&t===n.Warning&&this.warning(e),this.logLevel===n.Info&&t===n.Info&&this.info(e)}verbose(t){this.logLevel===n.Verbose&&("string"==typeof t?console.info(t):console.info(t()))}info(t){this.logLevel!==n.All&&this.logLevel!==n.Verbose&&this.logLevel!==n.Info||console.info(t)}warning(t){this.logLevel!==n.All&&this.logLevel!==n.Verbose&&this.logLevel!==n.Warning||console.warn(t)}error(t){if(this.logLevel===n.All||this.logLevel===n.Verbose||this.logLevel===n.Error){let e="";"string"==typeof t?e=t:(null!=t.message&&(e=t.message),null!=t.stack&&(e=t.stack)),console.error(e)}}}},202:function(t,e,n){"use strict";var r=this&&this.__awaiter||function(t,e,n,r){return new(n||(n=Promise))((function(o,s){function i(t){try{a(r.next(t))}catch(t){s(t)}}function l(t){try{a(r.throw(t))}catch(t){s(t)}}function a(t){var e;t.done?o(t.value):(e=t.value,e instanceof n?e:new n((function(t){t(e)}))).then(i,l)}a((r=r.apply(t,e||[])).next())}))};Object.defineProperty(e,"__esModule",{value:!0}),e.HotModule=void 0;const o=n(507),s=n(316);e.HotModule=class{constructor(t){this.name=t,this.import=[],this.html=[],this.css=[],this.js=[],this.componentLibrary="",this.components=[]}outputCSS(t=!0){if(null==this.css)return;let e="";return this.outputAsset("css",this.css,(t=>{const n=t.output();e+=`${n}\n`})),!0===t&&o.Hot.echo(e),e}outputJS(t=!0){if(null==this.js)return;let e="";return this.outputAsset("js",this.js,(t=>{const n=t.output();e+=`${n}\n`})),!0===t&&o.Hot.echo(e),e}output(t,e=null){return r(this,void 0,void 0,(function*(){yield o.Hot.include(`${this.name}/${t}.hott`,e)}))}loadHTML(){return r(this,void 0,void 0,(function*(){if(null==this.html)return;let t={};this.outputAsset("html",this.html,(e=>{const n=e.output();if("string"==typeof n)throw new Error("HTML assets cannot be outputted using only a string!");t[n.name]=n})),yield o.Hot.CurrentPage.processor.loadHotFiles(t)}))}outputComponents(t=!0){if(null==this.components)return"";if(this.components.length<1)return"";let e='<script type = "text/javascript">',n="";null!=this.componentLibrary&&""!==this.componentLibrary&&(n=`${this.componentLibrary}.`);for(let t=0;t<this.components.length;t++)e+=`Hot.CurrentPage.processor.addComponent (${n}${this.components[t]});\n`;return e+="<\/script>",!0===t&&o.Hot.echo(e),e}outputAsset(t,e=[],n){for(let r=0;r<e.length;r++){let o=e[r],i=null;i=new s.HotAsset(t),"string"==typeof o?i.path=o:(null!=o.name&&(i.name=o.name),null!=o.path&&(i.path=o.path),null!=o.content&&(i.content=o.content)),n(i)}}}},136:function(t,e,n){"use strict";var r=this&&this.__awaiter||function(t,e,n,r){return new(n||(n=Promise))((function(o,s){function i(t){try{a(r.next(t))}catch(t){s(t)}}function l(t){try{a(r.throw(t))}catch(t){s(t)}}function a(t){var e;t.done?o(t.value):(e=t.value,e instanceof n?e:new n((function(t){t(e)}))).then(i,l)}a((r=r.apply(t,e||[])).next())}))};Object.defineProperty(e,"__esModule",{value:!0}),e.HotPage=void 0;const o=n(507),s=n(243);e.HotPage=class{constructor(t){t instanceof s.HotStaq?(this.processor=t,this.name="",this.testerName="HotTesterMochaSelenium",this.testerMap="",this.route="",this.components={},this.files=[],this.testElements={},this.testPaths={}):(this.processor=t.processor,this.name=t.name||"",this.testerName=t.testerName||"HotTesterMochaSelenium",this.testerMap=t.testerMap||"",this.route=t.route||"",this.components=t.components||{},this.files=t.files||[],this.testElements=t.testElements||{},this.testPaths=t.testPaths||{})}addFile(t){return r(this,void 0,void 0,(function*(){t.page=this,this.files.push(t)}))}getAPI(){return this.processor.api}getTesterAPI(){return this.processor.testerAPI}load(t){return r(this,void 0,void 0,(function*(){for(let t=0;t<this.files.length;t++){let e=this.files[t];yield e.load()}}))}process(t=null){return r(this,void 0,void 0,(function*(){let e="";for(let n=0;n<this.files.length;n++){let r=this.files[n];o.Hot.Output="",r.page=this,e+=(yield r.process(t))}return e}))}addTestElement(t){if(null!=this.testElements[t.name])throw new Error(`Test element ${t.name} already exists!`);this.testElements[t.name]=t}getTestElement(t){if(null==this.testElements[t])throw new Error(`Test element ${t} doest not exist!`);return this.testElements[t]}createTestPath(t,e){if(null!=this.testPaths[t])throw new Error(`Test path ${t} already exists!`);this.testPaths[t]=e}}},761:(t,e,n)=>{"use strict";Object.defineProperty(e,"__esModule",{value:!0}),e.HotRoute=void 0;const r=n(70);class o{constructor(t,e,n=[]){this.onPreRegister=null,this.onRegister=null,this.onPostRegister=null,this.onAuthorizeUser=null,this.connection=t,this.logger=null,null!=this.connection&&null!=this.connection.processor&&(this.logger=this.connection.processor.logger),this.route=e,this.description="",this.version="v1",this.prefix="",this.authCredentials=null,this.methods=n,this.errors={not_authorized:o.createError("Not authorized."),no_server_execute_function:o.createError("Missing server execute function.")}}static createError(t){return{error:t}}addMethod(t,e=null,n=r.HotEventMethod.POST,o=null){"string"==typeof t&&(t=new r.HotRouteMethod(this,t,e,n,null,null,null,o)),t instanceof r.HotRouteMethod||(null==t.route&&(t.route=this),t=new r.HotRouteMethod(t)),this.methods.push(t)}getMethod(t){let e=null;for(let n=0;n<this.methods.length;n++){let r=this.methods[n];if(r.name===t){e=r;break}}return e}}e.HotRoute=o},70:(t,e,n)=>{"use strict";Object.defineProperty(e,"__esModule",{value:!0}),e.HotRouteMethod=e.ServerRequest=e.HotEventMethod=void 0;const r=n(507),o=n(761),s=n(810);var i;!function(t){t.GET="get",t.POST="post",t.FILE_UPLOAD="file_upload_then_post_json",t.WEBSOCKET_CLIENT_PUB_EVENT="websocket_client_pub_event"}(i=e.HotEventMethod||(e.HotEventMethod={})),e.ServerRequest=class{constructor(t=null){null==t&&(t={}),this.req=t.req||null,this.res=t.res||null,this.wsSocket=t.wsSocket||null,this.authorizedValue=t.authorizedValue||null,this.jsonObj=t.jsonObj||null,this.queryObj=t.queryObj||null,this.files=t.files||null}},e.HotRouteMethod=class{constructor(t,e="",n=null,l=i.POST,a=null,u=null,c=null,h=null){let p=null;if(t instanceof o.HotRoute)p=t;else{if(p=t.route,null!=t.type&&(l=t.type),null!=t.name&&(e=t.name),null!=t.description&&(this.description=t.description),null!=t.returns&&("string"==typeof t.returns?this.returns={type:"string",required:!0,description:t.returns}:this.returns=t.returns),null!=t.parameters){this.parameters={};for(let e in t.parameters){let n=t.parameters[e];"string"==typeof n?this.parameters[e]={type:n,required:!1,description:""}:(null==n.type&&(n.type="string"),this.parameters[e]=n)}}null!=t.authCredentials&&(c=t.authCredentials),null!=t.onServerExecute&&(n=t.onServerExecute),null!=t.onServerAuthorize&&(a=t.onServerAuthorize),null!=t.onRegister&&(u=t.onRegister),null!=t.onPostRegister&&(this.onPostRegister=t.onPostRegister),null!=t.onServerExecute&&(this.onServerExecute=t.onServerExecute),null!=t.onClientExecute&&(this.onClientExecute=t.onClientExecute),null!=t.testCases&&(h=t.testCases)}if(""===e)throw new Error("All route methods must have a name!");if(this.route=p,this.name=e,this.type=l,this.isRegistered=!1,this.executeSetup=!1,this.authCredentials=c,this.onServerAuthorize=a,this.onRegister=u,this.testCases={},this.route.connection.processor.mode===r.DeveloperMode.Development&&null!=h)if(h instanceof Array)for(let t=0;t<h.length;t++){let e=h[t];if("string"==typeof e){const n=e,r=h[t+1];this.addTestCase(n,r),t++}else this.addTestCase(e)}else for(let t in h){let e=h[t];this.addTestCase(e)}this.route.connection instanceof s.HotServer&&(this.onServerExecute=n)}addTestCase(t,e=null){if("string"==typeof t){const n=t,r=e;return void(this.testCases[n]={name:n,func:r})}if("function"==typeof t){const e=Object.keys(this.testCases).length,n=`${this.route.route}/${this.name} test case ${e}`,r=t;return void(this.testCases[n]={name:n,func:r})}const n=t;this.testCases[n.name]=n}getRouteUrl(){if(null==this.route)throw new Error(`Route method ${this.name} does not have a parent route!`);let t="/";return""!==this.route.version&&(t+=`${this.route.version}/`),""!==this.route.prefix&&(t+=`${this.route.prefix}/`),""!==this.route.route&&(t+=`${this.route.route}/`),t+=this.name,t}}},810:function(t,e,n){"use strict";var r=this&&this.__awaiter||function(t,e,n,r){return new(n||(n=Promise))((function(o,s){function i(t){try{a(r.next(t))}catch(t){s(t)}}function l(t){try{a(r.throw(t))}catch(t){s(t)}}function a(t){var e;t.done?o(t.value):(e=t.value,e instanceof n?e:new n((function(t){t(e)}))).then(i,l)}a((r=r.apply(t,e||[])).next())}))};Object.defineProperty(e,"__esModule",{value:!0}),e.HotServer=e.HotServerType=void 0;const o=n(243);var s;!function(t){t[t.HTTP=0]="HTTP",t[t.WebSockets=1]="WebSockets",t[t.Generate=2]="Generate",t[t.WebTesting=3]="WebTesting",t[t.APITesting=4]="APITesting"}(s=e.HotServerType||(e.HotServerType={})),e.HotServer=class{constructor(t){t instanceof o.HotStaq?(this.processor=t,this.serverType="Server",this.api=null,this.listenAddress="0.0.0.0",this.ports={http:5e3,https:443},this.ssl={cert:"",key:"",ca:""},this.redirectHTTPtoHTTPS=!0,this.type=s.HTTP,this.logger=t.logger,this.secrets={}):(this.processor=t.processor,this.serverType=t.serverType||"Server",this.api=t.api||null,this.listenAddress=t.listenAddress||"0.0.0.0",this.ports=t.ports||{http:5e3,https:443},this.ssl=t.ssl||{cert:"",key:"",ca:""},this.redirectHTTPtoHTTPS=null==t.redirectHTTPtoHTTPS||t.redirectHTTPtoHTTPS,this.type=t.type||s.HTTP,this.logger=t.logger,this.secrets=t.secrets||{})}setAPI(t){return r(this,void 0,void 0,(function*(){this.processor.api=t,this.api=t}))}}},243:function(__unused_webpack_module,exports,__webpack_require__){"use strict";var __createBinding=this&&this.__createBinding||(Object.create?function(t,e,n,r){void 0===r&&(r=n),Object.defineProperty(t,r,{enumerable:!0,get:function(){return e[n]}})}:function(t,e,n,r){void 0===r&&(r=n),t[r]=e[n]}),__setModuleDefault=this&&this.__setModuleDefault||(Object.create?function(t,e){Object.defineProperty(t,"default",{enumerable:!0,value:e})}:function(t,e){t.default=e}),__importStar=this&&this.__importStar||function(t){if(t&&t.__esModule)return t;var e={};if(null!=t)for(var n in t)"default"!==n&&Object.prototype.hasOwnProperty.call(t,n)&&__createBinding(e,t,n);return __setModuleDefault(e,t),e},__awaiter=this&&this.__awaiter||function(t,e,n,r){return new(n||(n=Promise))((function(o,s){function i(t){try{a(r.next(t))}catch(t){s(t)}}function l(t){try{a(r.throw(t))}catch(t){s(t)}}function a(t){var e;t.done?o(t.value):(e=t.value,e instanceof n?e:new n((function(t){t(e)}))).then(i,l)}a((r=r.apply(t,e||[])).next())}))},__importDefault=this&&this.__importDefault||function(t){return t&&t.__esModule?t:{default:t}};Object.defineProperty(exports,"__esModule",{value:!0}),exports.HotStaq=void 0;const ppath=__importStar(__webpack_require__(606)),node_fetch_1=__importDefault(__webpack_require__(300)),validate_npm_package_name_1=__importDefault(__webpack_require__(651)),HotPage_1=__webpack_require__(136),HotFile_1=__webpack_require__(732),HotLog_1=__webpack_require__(802),Hot_1=__webpack_require__(507),HotAsset_1=__webpack_require__(316),HotClient_1=__webpack_require__(957),HotTesterAPI_1=__webpack_require__(414),HotTestMap_1=__webpack_require__(985),HotTestDestination_1=__webpack_require__(473),HotStaqRegisterComponent_1=__webpack_require__(638),HotStaqWebStart_1=__webpack_require__(23);var HotTesterMocha=null,HotTesterMochaSelenium=null,HotTestSeleniumDriver=null;class HotStaq{constructor(t={}){this.logger=new HotLog_1.HotLog(HotLog_1.HotLogLevel.All),this.startDelay=0,this.api=t.api||null,this.testerAPI=t.testerAPI||null,this.mode=t.mode||Hot_1.DeveloperMode.Production,this.pages=t.pages||{},this.modules=t.modules||{},this.components=t.components||{},this.files=t.files||{},this.hotSite=t.hotSite||null,this.apiContent="\n\t\t\t{\n\t\t\t\tvar %api_name% = %api_exported_name%.%api_name%;\n\t\t\t\tvar newHotClient = new HotClient (processor);\n\t\t\t\tvar newapi = new %api_name% (%base_url%, newHotClient);\n\t\t\t\tnewHotClient.api = newapi;\n\t\t\t\tprocessor.api = newapi;\n\t\t\t}",this.testerApiContent="\n\t\t\tvar HotTesterAPI = HotStaqWeb.HotTesterAPI;\n\t\t\tvar newHotTesterClient = new HotClient (processor);\n\t\t\tvar newtesterapi = new HotTesterAPI (%base_tester_url%, newHotTesterClient);\n\t\t\tnewHotTesterClient.testerAPI = newtesterapi;\n\t\t\tprocessor.testerAPI = newtesterapi;",this.pageContent='<!DOCTYPE html>\n<html>\n\n<head>\n\t<title>%title%</title>\n\n\t<script type = "text/javascript" src = "%hotstaq_js_src%"><\/script>\n\t<script type = "text/javascript">\n\t\tfor (let key in HotStaqWeb)\n\t\t\twindow[key] = HotStaqWeb[key];\n\t<\/script>\n\n%apis_to_load%\n\n\t<script type = "text/javascript">\n\t\tasync function hotstaq_startApp ()\n\t\t{\n\t\t\tlet tempMode = 0;\n\n\t\t\tif (window["Hot"] != null)\n\t\t\t\ttempMode = Hot.Mode;\n\n\t\t\t%start_delay%\n\n\t\t\tvar processor = new HotStaq ();\n\t\t\tprocessor.logger.logLevel = %logging_level%;\n\n\t\t\tvar promises = [];\n\t\t\t%developer_mode%\n\n\t\t\t%api_code%\n\n\t\t\t%public_secrets%\n\t\t\t%tester_api%\n\t\t\t%load_files%\n\n\t\t\tprocessor.mode = tempMode;\n\n\t\t\tPromise.all (promises).then (function ()\n\t\t\t\t{\n\t\t\t\t\tHotStaq.displayUrl ({\n\t\t\t\t\t\t\turl: "%url%",\n\t\t\t\t\t\t\tname: "%title%",\n\t\t\t\t\t\t\tprocessor: processor,\n\t\t\t\t\t\t\targs: %args%,\n\t\t\t\t\t\t\ttesterName: %tester_name%,\n\t\t\t\t\t\t\ttesterMap: %tester_map%,\n\t\t\t\t\t\t\ttesterAPIBaseUrl: %tester_api_base_url%,\n\t\t\t\t\t\t\ttesterLaunchpadUrl: %tester_launchpad_url%\n\t\t\t\t\t\t});\n\t\t\t\t});\n\t\t}\n\n\t\thotstaq_startApp ();\n\t<\/script>\n</head>\n\n<body>\n</body>\n\n</html>',this.publicKeys={},this.testers={}}static parseBoolean(t){return"true"===(t=t.toLowerCase())||"false"!==t&&("yes"===t||"no"!==t&&"yep"===t)}static getParam(t,e,n=!0,r=!0){let o=e[t];if(null==o&&!0===n&&!0===r)throw new Error(`Missing required parameter ${t}.`);if("string"==typeof o&&!0===n&&""===o&&!0===r)throw new Error(`Missing required parameter ${t}.`);return o}static getParamDefault(t,e,n){let r=e[t];return null==r||"string"==typeof r&&""===r?n:r}static executeError(t){if(null!=HotStaq.errors[t]){let e=HotStaq.errors[t].redirectToUrl;if(null!=e&&""!==e)return void(window.location.href=e);let n=HotStaq.errors[t].func;null!=n&&n(t)}}static wait(t){return __awaiter(this,void 0,void 0,(function*(){return yield new Promise(((e,n)=>{setTimeout((()=>{e()}),t)}))}))}addPage(t){this.pages[t.name]=t}getPage(t){return this.pages[t]}addModule(t,e){this.modules[t]=e}getModule(t){return this.modules[t]}addFile(t){let e=t.name;""===e&&(e=t.localFile),""===e&&(e=t.url),this.files[e]=t}getFile(t,e=!0){if(null==this.files[t]){let n=t.indexOf("?hstqserve="),r=t;if(n>-1&&(r=t.substring(0,n)),null!=this.files[r])return this.files[r];if(!0===e)throw new Error(`Unable to find file ${t}`);return null}return this.files[t]}static keepContext(t,e,n){return function(){var r=Array.prototype.slice.call(arguments);return null!=n&&r.push(n),null==e?t.apply(this,r):t.apply(e,r)}}addComponent(t,e=null,n){let r=this.api;null!=e&&(r=e);let o=new t(this,r);if(null!=this.components[o.tag])throw new Error(`Component ${o.tag} already exists!`);this.components[o.tag]={componentType:t,processor:this,api:r},HotStaqRegisterComponent_1.registerComponent.call(this,o.tag,n)}static fixHTML(t){const e=t.replace(/ \/>/g,">").replace(/(<(area|base|br|col|command|embed|hr|img|input|keygen|link|meta|param|source|track|wbr).*?>)/g,"$1</$2>"),n=(new DOMParser).parseFromString(`<xml>${e}</xml>`,"text/xml");let r="";if(n.documentElement.children.length>0){const e=n.documentElement.children[0].tagName.toLowerCase();"tr"===e&&(t=`<table>${t}</table>`,r="tbody"),"th"===e&&(t=`<table>${t}</table>`,r=e)}return{fixedStr:t,querySelector:r}}static addHtml(t,e){let n=null;if(n="string"==typeof t?document.querySelector(t):t,null==n)throw new Error(`Unable to find parent ${t}!`);let r=null;if("string"==typeof e){let t=HotStaq.fixHTML(e),r=(new DOMParser).parseFromString(t.fixedStr,"text/html"),o=null;o=""===t.querySelector?r.body.children:r.querySelector(t.querySelector).children;let s=[];for(let t=0;t<o.length;t++){let e=o[t];s.push(n.appendChild(e))}return s}return r=n.appendChild(e),r}static checkHotSiteName(t,e=!1){let n=(0,validate_npm_package_name_1.default)(t),r=!0;if(!1===n.validForNewPackages&&(r=!1),null!=n.errors&&n.errors.length>0&&(r=!1),!1===r&&!0===e)throw new Error(`HotSite ${t} has an invalid name! The name cannot be empty and must have a valid NPM module name.`);return r}static replaceKey(t,e,n){return t.replace(new RegExp(`\\$\\{${e}\\}`,"g"),n)}static getValueFromHotSiteObj(t,e){let n=null;if(null!=t){let r=t;for(let t=0;t<e.length;t++){let n=e[t];if(null==r[n]){r=null;break}r=r[n]}null!=r&&(n=r)}return n}processHotSite(tester=null){return __awaiter(this,void 0,void 0,(function*(){HotStaq.checkHotSiteName(this.hotSite.name,!0);let routes=this.hotSite.routes;if(null!=routes)for(let t in routes){let e=routes[t],n=new HotFile_1.HotFile(e),r=new HotPage_1.HotPage({processor:this,name:e.name||"",route:t,files:[n]});if(null!=tester&&this.mode===Hot_1.DeveloperMode.Development){let t=e.name,n=null;if(null!=e.map){if("string"==typeof e.map){if(null==tester.testMaps[e.map])throw new Error(`Test map ${e.map} does not exist!`);tester.testMaps[t]=tester.testMaps[e.map]}else{n=new HotTestMap_1.HotTestMap;let t=null;if(e.map instanceof Array){t=[];for(let n=0;n<e.map.length;n++){let r=e.map[n];t.push(new HotTestDestination_1.HotTestDestination(r))}}else{t={};for(let n in e.map){let r=e.map[n];t[n]=new HotTestDestination_1.HotTestDestination(r)}}n.destinations=t}tester.testMaps[t]=n}null!=e.destinationOrder&&(tester.testMaps[t].destinationOrder=e.destinationOrder)}this.addPage(r)}if(null!=this.hotSite.apis)for(let t in this.hotSite.apis){let e=this.hotSite.apis[t];if(null!=e.map&&!1===HotStaq.isWeb&&this.mode===Hot_1.DeveloperMode.Development){let n=t,r=new HotTestMap_1.HotTestMap;r.destinations=[];for(let t=0;t<e.map.length;t++){let n=e.map[t];r.destinations.push(new HotTestDestination_1.HotTestDestination(n))}null!=tester?tester.testMaps[n]=r:this.logger.warning("A tester was not created first! You must specify one in the CLI.")}}if(!0===HotStaq.isWeb)for(let key in this.hotSite.components){let component=this.hotSite.components[key],componentUrl=component.url,res=yield(0,node_fetch_1.default)(componentUrl),ComponentClass=eval(res);this.addComponent(ComponentClass)}null==this.hotSite.routes&&(this.hotSite.routes={});let disableFileLoading=!1;null!=this.hotSite.disableFileLoading&&(disableFileLoading=this.hotSite.disableFileLoading),!1===disableFileLoading?yield this.loadHotFiles(this.hotSite.files,!1,!1):this.logger.verbose("Hotsite has file loading disabled..."),null!=tester&&this.addTester(tester),this.logger.verbose(`Processed HotSite ${this.hotSite.name}`)}))}loadHotSite(path){return __awaiter(this,void 0,void 0,(function*(){let jsonStr="";const ext=ppath.extname(path).toLowerCase();if(!0===HotStaq.isWeb){this.logger.verbose(`Downloading HotSite ${path}`);let t=yield(0,node_fetch_1.default)(path);this.logger.verbose(`Downloaded site ${path}`),jsonStr=t.text()}else{path=ppath.normalize(path),this.logger.verbose(`Accessing HotSite ${path}`);let HotIO=eval("require")("./HotIO").HotIO;jsonStr=yield HotIO.readTextFile(path),this.logger.verbose(`Accessed site ${path}`)}if(".yaml"===ext||".yml"===ext){if(!0===HotStaq.isWeb)throw new Error("YAML support for HotSites is not available on the web yet!");let yaml=eval("require")("yaml");this.hotSite=yaml.parse(jsonStr)}else this.hotSite=JSON.parse(jsonStr);if(null==this.hotSite)throw new Error(`HotSite ${path} cannot be null!`);this.hotSite.hotsitePath=path}))}saveHotSite(path){return __awaiter(this,void 0,void 0,(function*(){if(!0===HotStaq.isWeb)throw new Error("Cannot save a HotSite on the web!");const hotsiteStr=JSON.stringify(this.hotSite,null,2);let HotIO=eval("require")("./HotIO").HotIO;yield HotIO.writeTextFile(path,hotsiteStr),this.logger.verbose(`Saved site ${path}`)}))}loadHotFiles(t,e=!1,n=!0){return __awaiter(this,void 0,void 0,(function*(){this.logger.verbose("Loading Hott files...");for(let r in t){let o=t[r],s=null;HotStaq.isWeb,s=new HotFile_1.HotFile({name:r}),null!=o.url&&(!0===HotStaq.isWeb?s.url=`${o.url}?hstqserve=nahfam`:s.url=o.url),!1===HotStaq.isWeb&&null!=o.localFile&&(s.localFile=o.localFile);let i=!0;null!=o.content&&(s.content=o.content,i=!1),!0===e&&(i=!0),!1===n&&""!==s.url&&(i=!1),!0===i&&(this.logger.verbose(`Loading Hott file: ${s.url}`),yield s.load(),this.logger.verbose(`Finished loading Hott file: ${s.url}`)),this.addFile(s)}this.logger.verbose("Finished loading Hott files...")}))}generateContent(t,e="",n="./",r="./js/HotStaq.min.js",o=!0,s=null){return __awaiter(this,void 0,void 0,(function*(){let i="",l="",a="";if(null!=this.hotSite){if(null!=this.hotSite.server.globalApi&&""!==this.hotSite.server.globalApi){const t=this.hotSite.apis[this.hotSite.server.globalApi];if(null==t)this.logger.warning(`API with name ${this.hotSite.server.globalApi} doesn't exist!`);else{let e=!0;if(null==t.jsapi&&(e=!1,this.logger.warning(`API with name ${this.hotSite.server.globalApi} doesn't have a jsapi set. Will not send js content to client.`)),null==t.libraryName&&(e=!1,this.logger.warning(`API with name ${this.hotSite.server.globalApi} doesn't have a libraryName set. Will not send js content to client.`)),null==t.apiName&&(e=!1,this.logger.warning(`API with name ${this.hotSite.server.globalApi} doesn't have a apiName set. Will not send js content to client.`)),!0===e){i+=`\t<script type = "text/javascript" src = "${t.jsapi}"><\/script>\n`;let e='""';null!=t.url&&(e=`"${t.url}"`),null!=this.api&&(e=`"${this.api.baseUrl}"`);let n=this.apiContent;n=n.replace(/\%api\_name\%/g,t.apiName),n=n.replace(/\%api\_exported\_name\%/g,t.libraryName),n=n.replace(/\%base\_url\%/g,e),l+=n}}}if(null!=this.hotSite.apis){let e=this.hotSite.routes[t];if(null!=e&&null!=e.api){let t=this.hotSite.apis[e.api];if(null==t)throw new Error(`Unable to find API ${e.api}`);if(e.api!==this.hotSite.server.globalApi){let n=!0;if(null==t.jsapi&&(n=!1,this.logger.warning(`API with name ${e.api} doesn't have a jsapi set. Will not send js content to client.`)),null==t.libraryName&&(n=!1,this.logger.warning(`API with name ${e.api} doesn't have a libraryName set. Will not send js content to client.`)),null==t.apiName&&(n=!1,this.logger.warning(`API with name ${e.api} doesn't have a apiName set. Will not send js content to client.`)),!0===n){let e=t.jsapi;i+=`\t<script type = "text/javascript" src = "${e}"><\/script>\n`;let n='""';null!=t.url&&(n=`"${t.url}"`),null!=this.api&&(n=`"${this.api.baseUrl}"`);let r=this.apiContent;r=r.replace(/\%api\_name\%/g,t.apiName),r=r.replace(/\%api\_exported\_name\%/g,t.libraryName),r=r.replace(/\%base\_url\%/g,n),l+=r}}}}if(null!=this.hotSite.server&&null!=this.hotSite.server.jsSrcPath&&(r=this.hotSite.server.jsSrcPath),null!=this.hotSite.publicKeys)for(let t in this.hotSite.publicKeys){let e,n=this.hotSite.publicKeys[t];if("string"==typeof n)e=JSON.stringify(n);else if(!1===HotStaq.isWeb){if(null!=this.api){if(null==this.api.connection)throw new Error("Cannot pass secrets from the API if there's no connection!");let r=this.api.connection;null!=n.passSecretFromAPI&&(e=JSON.stringify(r.secrets[t]))}if(null!=n.env){const t=n.env;e=JSON.stringify(process.env[t])}}a+=`processor.publicKeys["${t}"] = ${e};\n`}}let u=this.pageContent;return u=yield(u=>__awaiter(this,void 0,void 0,(function*(){let c="",h="";this.mode===Hot_1.DeveloperMode.Development&&(c="tempMode = HotStaqWeb.DeveloperMode.Development;",null!=this.hotSite&&null!=this.hotSite.testing&&null!=this.hotSite.testing.web&&(h=this.testerApiContent,null==this.hotSite.testing.web.testerAPIUrl&&(this.hotSite.testing.web.testerAPIUrl="http://127.0.0.1:8182"),h=h.replace(/\%base\_tester\_url\%/g,`"${this.hotSite.testing.web.testerAPIUrl}"`)));let p="";if(Object.keys(this.files).length>0){p+="var files = {};\n\n";for(let t in this.files){let e=this.files[t],n=new HotAsset_1.HotAsset("html",t);""!==e.localFile&&(n.path=e.localFile),""!==e.url&&(n.path=e.url),""!==e.content&&(n.path="",n.content=e.content);let r=yield n.output();if("string"==typeof r)throw new Error("During initial load, HTML assets cannot be outputted using only a string!");let o="",s="";null!=r.url&&(o=`"url": "${r.url}", `),null!=r.content&&(s=`"content": ${r.content}`),p+=`\t\t\tfiles["${r.name}"] = { ${o}${s} };\n`}p+="\t\t\tpromises.push (processor.loadHotFiles (files));\n"}u=u.replace(/\%title\%/g,e),!0===o&&(u=u.replace(/\%args\%/g,"Hot.Arguments")),null!=s&&(u=u.replace(/\%args\%/g,JSON.stringify(s)));let d=t,f="",m="",g="HotTesterMochaSelenium";for(let t in this.testers){g=t;break}null!=this.hotSite&&(null!=this.hotSite.testing&&null!=this.hotSite.testing.web&&(null!=this.hotSite.testing.web.testerName&&(g=this.hotSite.testing.web.testerName),null!=this.hotSite.testing.web.testerAPIUrl&&(f=this.hotSite.testing.web.testerAPIUrl),null!=this.hotSite.testing.web.launchpadUrl&&(m=this.hotSite.testing.web.launchpadUrl)),null!=this.hotSite.routes&&null!=this.hotSite.routes[t])&&(d=this.hotSite.routes[t].name);let _="";return 0!==this.startDelay&&(_=`await HotStaq.wait (${this.startDelay});`),u=(u=(u=(u=(u=(u=(u=(u=(u=(u=(u=(u=(u=(u=u.replace(/\%start\_delay\%/g,_)).replace(/\%logging\_level\%/g,`HotLogLevel.${HotLog_1.HotLogLevel[this.logger.logLevel]}`)).replace(/\%hotstaq\_js\_src\%/g,r)).replace(/\%developer\_mode\%/g,c)).replace(/\%tester\_api\%/g,h)).replace(/\%apis\_to\_load\%/g,i)).replace(/\%load\_files\%/g,p)).replace(/\%api\_code\%/g,l)).replace(/\%public\_secrets\%/g,a)).replace(/\%url\%/g,n)).replace(/\%tester\_name\%/g,`"${g}"`)).replace(/\%tester\_map\%/g,`"${d}"`)).replace(/\%tester\_api\_base\_url\%/g,`"${f}"`)).replace(/\%tester\_launchpad\_url\%/g,`"${m}"`)})))(u),u}))}createExpressRoutes(t,e="./js/HotStaq.min.js"){return __awaiter(this,void 0,void 0,(function*(){for(let n in this.pages){let r=this.pages[n];const o=yield this.generateContent(r.route,r.name,r.files[0].url,e);t.get(r.route,((t,e)=>{this.logger.verbose("Sending custom Express content."),e.status(200).send(o)}))}}))}addTester(t){this.testers[t.name]=t}getWebTestingMaps(){if(null==this.hotSite)throw new Error("No HotSite was loaded!");if(null==this.hotSite.testing)throw new Error("The HotSite does not have a testing object!");if(null==this.hotSite.testing.web)throw new Error("The HotSite does not have a testing web object!");if(null==this.hotSite.testing.web.maps)throw new Error("The HotSite testing object does not have any maps!");return this.hotSite.testing.web.maps}getAPITestingMaps(){if(null==this.hotSite)throw new Error("No HotSite was loaded!");if(null==this.hotSite.testing)throw new Error("The HotSite does not have a testing object!");if(null==this.hotSite.testing.api)throw new Error("The HotSite does not have a testing api object!");if(null==this.hotSite.testing.api.maps)throw new Error("The HotSite testing object does not have any maps!");return this.hotSite.testing.api.maps}getRouteKeyFromName(t){let e="";if(null!=this.hotSite&&null!=this.hotSite.routes)for(let n in this.hotSite.routes)if(this.hotSite.routes[n].name===t){e=n;break}return e}getRouteFromName(t){let e=null,n=this.getRouteKeyFromName(t);return""!==n&&(e=this.hotSite.routes[n]),e}executeTests(t,e){return __awaiter(this,void 0,void 0,(function*(){let n=this.testers[t];if(null==n)throw new Error(`Unable to execute tests. Tester ${t} does not exist!`);return n.execute(e)}))}executeAllWebTests(t){return __awaiter(this,void 0,void 0,(function*(){let e=this.getWebTestingMaps();if(null==this.testers[t])throw new Error(`Unable to execute tests. Tester ${t} does not exist!`);for(let n=0;n<e.length;n++){let r=e[n];yield this.executeTests(t,r)}}))}executeAllAPITests(t){return __awaiter(this,void 0,void 0,(function*(){let e=this.getAPITestingMaps();if(null==this.testers[t])throw new Error(`Unable to execute tests. Tester ${t} does not exist!`);this.logger.verbose((()=>`Executing all API tests for tester ${t}. Maps: ${JSON.stringify(e)}`));for(let n=0;n<e.length;n++){let r=e[n];yield this.executeTests(t,r)}}))}process(t,e=null){return __awaiter(this,void 0,void 0,(function*(){let n=this.getPage(t);return yield n.process(e)}))}static processLocalFile(t,e=t,n=null){return __awaiter(this,void 0,void 0,(function*(){let r=new HotStaq,o=new HotFile_1.HotFile({localFile:t});yield o.load();let s=new HotPage_1.HotPage({processor:r,name:e,files:[o]});return r.addPage(s),yield r.process(e,n)}))}static processUrl(t){return __awaiter(this,void 0,void 0,(function*(){let e=new HotFile_1.HotFile({url:t.url});yield e.load();let n=new HotPage_1.HotPage({processor:t.processor,name:t.name,files:[e],testerName:t.testerName,testerMap:t.testerMap});return t.processor.addPage(n),yield t.processor.process(t.name,t.args)}))}static processContent(t){return __awaiter(this,void 0,void 0,(function*(){let e=new HotFile_1.HotFile({content:t.content});yield e.load();let n=new HotPage_1.HotPage({processor:t.processor,name:t.name,files:[e]});return t.processor.addPage(n),yield t.processor.process(t.name,t.args)}))}static onReady(t){"complete"===document.readyState||"interactive"===document.readyState?t():window.addEventListener("load",t)}static useOutput(t){return __awaiter(this,void 0,void 0,(function*(){let e=(new DOMParser).parseFromString(t,"text/html");document.getElementsByTagName("html")[0].innerHTML=e.getElementsByTagName("html")[0].innerHTML;let n=document.getElementsByTagName("script");if(n.length>0){let t=[];for(let e=0;e<n.length;e++)t.push(n[e]);for(let e=0;e<t.length;e++){let n=document.createElement("script");t[e].parentNode.appendChild(n),t[e].parentNode.removeChild(t[e]),yield new Promise(((r,o)=>{n.onload=()=>{r()};let s=!1;null!=t[e].getAttribute("src")&&""!==t[e].getAttribute("src")&&(n.setAttribute("src",t[e].getAttribute("src")),s=!0),null!=t[e].getAttribute("type")&&""!==t[e].getAttribute("type")&&n.setAttribute("type",t[e].getAttribute("type")),n.innerHTML=t[e].innerHTML,!1===s&&r()}))}}}))}static waitForTesters(){return __awaiter(this,void 0,void 0,(function*(){for(;!1===HotStaq.isReadyForTesting;)yield HotStaq.wait(10);null!=HotStaq.onReadyForTesting&&(yield HotStaq.onReadyForTesting())}))}static setupTesters(t,e){if(t.mode===Hot_1.DeveloperMode.Development&&null==t.testerAPI){null==e.testerAPIBaseUrl&&(e.testerAPIBaseUrl=""),""===e.testerAPIBaseUrl&&(e.testerAPIBaseUrl="http://127.0.0.1:8182");let n=new HotClient_1.HotClient(t),r=new HotTesterAPI_1.HotTesterAPI(e.testerAPIBaseUrl,n);r.connection.api=r,t.testerAPI=r}}static setupClientTesters(t){let e="";return t.mode===Hot_1.DeveloperMode.Development&&(e+='<script type = "text/javascript">\nfunction hotstaq_isDocumentReady ()\n{\nif (window["Hot"] != null)\n{\nif (Hot.Mode === HotStaqWeb.DeveloperMode.Development)\n{\nlet func = function ()\n\t{\n\t\tif (Hot.TesterAPI != null)\n\t\t{\n\t\t\tlet testPaths = {};\n\t\t\tlet testElements = JSON.stringify (Hot.CurrentPage.testElements);\n\t\t\tlet testMaps = JSON.stringify (Hot.CurrentPage.testMaps);\n\n\t\t\tfor (let key in Hot.CurrentPage.testPaths)\n\t\t\t{\n\t\t\t\tlet testPath = Hot.CurrentPage.testPaths[key];\n\n\t\t\t\ttestPaths[key] = testPath.toString ();\n\t\t\t}\n\n\t\t\tlet testPathsStr = JSON.stringify (testPaths);\n\n\t\t\tHot.TesterAPI.tester.pageLoaded ({\n\t\t\t\t\ttesterName: Hot.CurrentPage.testerName,\n\t\t\t\t\ttesterMap: Hot.CurrentPage.testerMap,\n\t\t\t\t\tpageName: Hot.CurrentPage.name,\n\t\t\t\t\ttestElements: testElements,\n\t\t\t\t\ttestPaths: testPathsStr\n\t\t\t\t}).then (function (resp)\n\t\t\t\t\t{\n\t\t\t\t\t\tif (resp.error != null)\n\t\t\t\t\t\t{\n\t\t\t\t\t\t\tif (resp.error !== "")\n\t\t\t\t\t\t\t\tthrow new Error (resp.error);\n\t\t\t\t\t\t}\n\n\t\t\t\t\t\tHotStaqWeb.HotStaq.isReadyForTesting = true;\n\t\t\t\t\t});\n\t\t}\n\t};\n\nif ((document.readyState === "complete") || (document.readyState === "interactive"))\n\tfunc ();\nelse\n\tdocument.addEventListener ("DOMContentLoaded", func);\n}\n}\n}\n\nhotstaq_isDocumentReady ();\n<\/script>'),e}static displayUrl(t,e=null,n=null,r=null){return __awaiter(this,void 0,void 0,(function*(){return new Promise(((o,s)=>{HotStaq.onReady((()=>__awaiter(this,void 0,void 0,(function*(){let s={url:""};s.name=null==e?"string"==typeof t?t:t.name:e,""===s.name&&(s.name="string"==typeof t?t:t.name),"string"==typeof t?s.url=t:(s.url=t.url,null==n&&null!=t.processor&&(n=t.processor),null==r&&null!=t.args&&(r=t.args),null!=t.testerMap&&(s.testerMap=t.testerMap),null!=t.testerName&&(s.testerName=t.testerName),null!=t.testerAPIBaseUrl&&(s.testerAPIBaseUrl=t.testerAPIBaseUrl)),null==n&&(n=new HotStaq),HotStaq.setupTesters(n,s),s.processor=n,s.args=r,s.url.indexOf("hstqserve")<0&&(s.url+="?hstqserve=nahfam");let i=yield HotStaq.processUrl(s);i+=HotStaq.setupClientTesters(n),yield HotStaq.useOutput(i),o(n)}))))}))}))}static displayContent(t,e=null,n=null,r=null){return __awaiter(this,void 0,void 0,(function*(){return new Promise(((o,s)=>{HotStaq.onReady((()=>__awaiter(this,void 0,void 0,(function*(){let s={content:""};s.name=null==e?"string"==typeof t?"":t.name:e,""===s.name&&(s.name="string"==typeof t?"":t.name),"string"==typeof t?s.content=t:(s.content=t.content,null==n&&null!=t.processor&&(n=t.processor),null==r&&null!=t.args&&(r=t.args),null!=t.testerMap&&(s.testerMap=t.testerMap),null!=t.testerName&&(s.testerName=t.testerName),null!=t.testerAPIBaseUrl&&(s.testerAPIBaseUrl=t.testerAPIBaseUrl)),null==n&&(n=new HotStaq),HotStaq.setupTesters(n,s),s.processor=n,s.args=r;let i=yield HotStaq.processContent(s);yield HotStaq.useOutput(i),o(n)}))))}))}))}}exports.HotStaq=HotStaq,HotStaq.version="0.8.21",HotStaq.isWeb=!1,HotStaq.isReadyForTesting=!1,HotStaq.onReadyForTesting=null,HotStaq.errors={},"undefined"!=typeof document&&window.addEventListener("load",HotStaqWebStart_1.hotStaqWebStart)},638:(t,e,n)=>{"use strict";Object.defineProperty(e,"__esModule",{value:!0}),e.registerComponent=void 0;const r=n(732),o=n(260),s=n(243),i=n(507);e.registerComponent=function(t,e){if(null==t||""===t)throw new Error("All components must have a tag!");if(void 0!==customElements.get(t))return;let n=this.components;customElements.define(t,class extends HTMLElement{constructor(){super();let e=n[t];if(this.component=new e.componentType(e.processor,e.api),this.hotComponent=this.component,this.component.htmlElements=[this],this.component.inner=this.innerHTML,null!=this.component.handleAttributes)this.component.handleAttributes(this.attributes);else for(let t=0;t<this.attributes.length;t++){const e=this.attributes[t],n=e.name.toLowerCase(),r=e.value;if("id"===n&&(this.component.name=r),"name"===n&&(this.component.name=r),"value"===n&&(this.component.value=r),n.indexOf("hot-")>-1){const t=n.substring(4);this.component[t]=r}}if(null!=this.component.onPreOutput&&!1===this.component.onPreOutput())return;let l=this.component.output();null!=this.component.onPostOutput&&(l=this.component.onPostOutput(l));let a=[];"string"==typeof l?a.push({html:l}):a=l instanceof Array?l:[l];for(let t=0;t<a.length;t++){let e=a[t],n=e.html,l="";null!=e.addFunctionsTo&&(l=e.addFunctionsTo);let u=r.HotFile.parseContent(n,!0,{outputCommands:!1});null!=this.component.onParsed&&(u=this.component.onParsed(u));let c={fixedStr:"",querySelector:""};c=null!=this.component.onFixHTML?this.component.onFixHTML(u):s.HotStaq.fixHTML(u);let h=[];for(let t=this.children.length-1;t>-1;t--){let e=this.children[t];h.push(this.removeChild(e))}let p=null,d=null;if(p=null!=this.component.onParseDOM?this.component.onParseDOM(c.fixedStr):(new DOMParser).parseFromString(c.fixedStr,"text/html"),p.body.children.length<1)throw new Error(`No component output from ${this.component.name} with tag ${this.component.tag}`);if(p.body.children.length>1){let t=!0;for(let e=0;e<p.body.children.length;e++){let n=p.body.children[e];if(n instanceof HTMLElement&&"parsererror"===n.tagName.toLowerCase()){d=n,t=!1;break}}if(!0===t)throw new Error(`Only a single html element can come from component ${this.component.name}, multiple elements were detected.`)}d=""===c.querySelector?p.body.children[0]:p.querySelector(c.querySelector),this.replaceWith(d),null!=this.component.click&&d.addEventListener("click",this.component.click.bind(this.component));for(let t in this.component.events){let e=this.component.events[t];d.addEventListener(e.type,e.func,e.options)}let f=Object.getOwnPropertyNames(this.component.constructor.prototype);for(let t=0;t<f.length;t++){let e=f[t];if("constructor"!==e&&"function"==typeof this.component[e]){let t=!0;for(let n in o.HotComponent.prototype)if(e===n){t=!1;break}!0===t&&(d[e]=s.HotStaq.keepContext(this.component[e],this.component),""!==l)&&(document.querySelector(l)[e]=s.HotStaq.keepContext(this.component[e],this.component))}}null!=this.component.onPrePlace&&(d=this.component.onPrePlace(d));let m=this.component.onCreated(d);if(null!=this.component.onParentPlace&&(m.onParentPlace=this.component.onParentPlace),m.hotComponent=this.component,this.component.htmlElements.push(m),null!=e.closestSelector){let t=m;for(;t;){let n=t.querySelector(e.closestSelector);if(null!=n){t=n;break}t=t.parentElement}if(null==t)throw new Error(`Unable to find closest node with selector '${e.closestSelector}'`);m.parentElement.removeChild(m),t.appendChild(m),null!=m.onParentPlace&&m.hotComponent.onParentPlace(parentNode,m)}if(null!=e.documentSelector){let t=document.querySelector(e.documentSelector);if(null==t)throw new Error(`Unable to find document node with selector '${e.documentSelector}'`);m.parentElement.removeChild(m),t.appendChild(m),null!=m.onParentPlace&&m.hotComponent.onParentPlace(t,m)}let g=(t,e,n)=>{let r=0;for(;r<10&&null!=t&&!(t instanceof HTMLHtmlElement);){let o=t.querySelectorAll(`hot-place-here[name="${e}"]`);if(o.length>0){let t=o[0];null!=n.parentNode&&n.parentNode.removeChild(n),t.appendChild(n),null!=n.onParentPlace&&n.hotComponent.onParentPlace(t,n);break}if(o.length<1){let r=t.querySelectorAll(`[hot-place-here="${e}"]`);if(r.length>0){let t=r[0];null!=n.parentNode&&n.parentNode.removeChild(n),t.appendChild(n),null!=n.onParentPlace&&n.hotComponent.onParentPlace(t,n);break}}t=t.parentNode,r++}return t};if(null!=e.placeHereParent){let t=m.parentNode;if(t=g(t,e.placeHereParent,m),null==t)throw new Error(`Unable to find parent node with hot-place-here attribute '${e.placeHereParent}'`)}for(let t=0;t<h.length;t++){const n=h[t];let r=!1;if(void 0!==n.getAttribute){let t=n.getAttribute("hot-place-parent");if(null!=t&&""!==t){let o=m;if(o=g(o,t,n),null==o)throw new Error(`Unable to find parent node with hot-place-here attribute '${e.placeHereParent}'`);r=!0}}!1===r&&m.appendChild(n),null!=n.onParentPlace&&n.hotComponent.onParentPlace(m,n)}if(null!=this.component.onPostPlace){let t=this.component.onPostPlace(m.parentElement,m);null!=t&&(m=t)}if(void 0!==i.Hot&&null!=i.Hot.CurrentPage){let t="";null!=this.component.name&&(t=this.component.name),null!=t&&""!==t||(t=this.id),""!==t&&(i.Hot.CurrentPage.components[t]=this.component)}}}looseParseFromString(t,e){e=e.replace(/ \/>/g,">").replace(/(<(area|base|br|col|command|embed|hr|img|input|keygen|link|meta|param|source|track|wbr).*?>)/g,"$1</$2>");const n=t.parseFromString("<xml>"+e+"</xml>","text/xml"),r=t.parseFromString("","text/html");for(let t of Array.from(n.documentElement.children))r.body.appendChild(t);for(let t of Array.from(r.querySelectorAll("area,base,br,col,command,embed,hr,img,input,keygen,link,meta,param,source,track,wbr")))t.outerHTML="<"+t.outerHTML.slice(1).split("<")[0];return r}get observedAttributes(){return this.component.observedAttributes}},e)}},23:function(__unused_webpack_module,exports,__webpack_require__){"use strict";var __awaiter=this&&this.__awaiter||function(t,e,n,r){return new(n||(n=Promise))((function(o,s){function i(t){try{a(r.next(t))}catch(t){s(t)}}function l(t){try{a(r.throw(t))}catch(t){s(t)}}function a(t){var e;t.done?o(t.value):(e=t.value,e instanceof n?e:new n((function(t){t(e)}))).then(i,l)}a((r=r.apply(t,e||[])).next())}))};Object.defineProperty(exports,"__esModule",{value:!0}),exports.hotStaqWebStart=void 0;const Hot_1=__webpack_require__(507),HotClient_1=__webpack_require__(957),HotLog_1=__webpack_require__(802),HotStaq_1=__webpack_require__(243);function hotStaqWebStart(){let hotstaqElms=document.getElementsByTagName("hotstaq");if(HotStaq_1.HotStaq.isWeb=!0,void 0!==HotStaqWeb)for(let t in HotStaqWeb)window[t]=HotStaqWeb[t];if(hotstaqElms.length>0){let hotstaqElm=hotstaqElms[0];setTimeout((function(){return __awaiter(this,void 0,void 0,(function*(){let getAttr=(t,e)=>{for(let n=0;n<e.length;n++){let r=e[n];if(null!=t.getAttribute(r))return t.getAttribute(r);if(null!=t.getAttribute(`data-${r}`))return t.getAttribute(`data-${r}`)}},loadPage=getAttr(hotstaqElm,["load-page","loadPage","src"])||"",loggingLevel=getAttr(hotstaqElm,["logging-level","loggingLevel"])||null,startDelay=getAttr(hotstaqElm,["start-delay","startDelay"])||null,router=getAttr(hotstaqElm,["router"])||"",name=getAttr(hotstaqElm,["name"])||"default",args=getAttr(hotstaqElm,["args"])||null,apiLibrary=getAttr(hotstaqElm,["api-library","apiLibrary"])||null,apiName=getAttr(hotstaqElm,["api-name","apiName"])||null,apiUrl=getAttr(hotstaqElm,["api-url","apiUrl"])||null,testerName=getAttr(hotstaqElm,["tester-name","testerName"])||"HotTesterMochaSelenium",testerMap=getAttr(hotstaqElm,["tester-map","testerMap"])||null,testerApiBaseUrl=getAttr(hotstaqElm,["tester-api-base-url","testerApiBaseUrl"])||null,testerLaunchpadUrl=getAttr(hotstaqElm,["tester-launchpad-url","testerLaunchpadUrl"])||null,dontReuseProcessor=!1,passRawUrl=!1,htmlSource=hotstaqElm.innerHTML||"",routerManager={},routerWildcards=[],search=new URLSearchParams(window.location.search);null!=startDelay&&(yield HotStaq_1.HotStaq.wait(parseInt(startDelay))),null!=getAttr(hotstaqElm,["src"])&&(loadPage=getAttr(hotstaqElm,["src"])),null!=getAttr(hotstaqElm,["passRawUrl"])&&(passRawUrl=!0),null!=getAttr(hotstaqElm,["dont-reuse-processor","dontReuseProcessor"])&&(dontReuseProcessor=!0);let hstqbaseredirect=search.get("hstqbaseredirect");null!=hstqbaseredirect&&(hstqbaseredirect=decodeURI(hstqbaseredirect),window.history.replaceState("","",hstqbaseredirect),loadPage=hstqbaseredirect);let hotstaqErrors=document.getElementsByTagName("hotstaq-error");for(let t=0;t<hotstaqErrors.length;t++){let e=hotstaqErrors[t],n=getAttr(e,["status"]),r=getAttr(e,["unsupported-browser-redirect"]);null!=r?HotStaq_1.HotStaq.errors.unsupportedBrowser={redirectToUrl:r}:HotStaq_1.HotStaq.errors[`${n}`]={redirectToUrl:r}}try{eval("async () => {}")}catch(t){HotStaq_1.HotStaq.executeError("unsupportedBrowser")}if(""!==router){let t=document.getElementsByTagName("hotstaq-router");for(let e=0;e<t.length;e++){let n=t[e],r=getAttr(n,["name"]),o=getAttr(n,["serve-local","serveLocally"]);if(r===router){for(let t=0;t<n.childNodes.length;t++){let e=n.childNodes[t];if(e instanceof HTMLElement&&"ROUTE"===e.tagName.toUpperCase()){let t=getAttr(e,["path"]),n=getAttr(e,["redirect"]),r=getAttr(e,["base-redirect","baseRedirect"]),o=getAttr(e,["base"]),s=getAttr(e,["src"]);t.indexOf("*")>-1&&routerWildcards.push(t),routerManager[t]={redirect:n||void 0,baseRedirect:r||void 0,base:o||void 0,src:s||void 0}}}let t=window.location.pathname,e=window.location.pathname;if(null!=o){const n=o.toLowerCase();if("true"===n||"yes"===n||"1"===n){const n=t.lastIndexOf("/");n>-1&&(t=t.substring(n),e=e.substring(n))}}if(routerWildcards.length>0)for(let e=0;e<routerWildcards.length;e++){let n=routerWildcards[e],r=n.replace("*","");if(t.indexOf(r)>-1){t=n;break}}if(null!=routerManager[t]){if(null!=routerManager[t].redirect)return void(window.location.href=routerManager[t].redirect);if(null!=routerManager[t].baseRedirect){const n=window.location.search;let r="";return""!==n&&"?"!==n&&(r=`&${n.substring(1)}`),void(window.location.href=`${routerManager[t].baseRedirect}?hstqbaseredirect=${encodeURI(e+n)}${r}`)}null!=routerManager[t].src&&(loadPage=routerManager[t].src)}break}}}args=null!=args?JSON.parse(args):Hot_1.Hot.Arguments;let hasHtmlSource=!1;if(""!==htmlSource){const t=htmlSource.replace(/\s/g,"");""!==t&&(hasHtmlSource=!0)}let tempMode=0;null!=window.Hot&&(tempMode=Hot_1.Hot.Mode);let processor=null;!1===dontReuseProcessor&&void 0!==Hot_1.Hot&&null!=Hot_1.Hot.CurrentPage&&null!=Hot_1.Hot.CurrentPage.processor&&(processor=Hot_1.Hot.CurrentPage.processor),null==processor&&(processor=new HotStaq_1.HotStaq),null!=loggingLevel&&(processor.logger.logLevel=HotLog_1.HotLog.parse(loggingLevel)),processor.mode=tempMode;let options={name,processor,args};if(""!==loadPage&&(!1===passRawUrl&&loadPage.indexOf("hstqserve")<0&&(loadPage+="?hstqserve=nahfam"),options.url=loadPage),null!=testerMap&&(options.testerMap=testerMap,options.testerName=testerName),null!=testerName&&(options.testerName=testerName),null!=testerApiBaseUrl&&(options.testerAPIBaseUrl=testerApiBaseUrl),null!=testerLaunchpadUrl&&(options.testerLaunchpadUrl=testerLaunchpadUrl),null!=apiName){let t=new HotClient_1.HotClient(processor);if(""===apiUrl)throw new Error("api-url was not set!");let e=window;null!=apiLibrary&&(e=window[apiLibrary]);let n=new e[apiName](apiUrl,t);n.connection.api=n,processor.api=n}if(!1===hasHtmlSource){if(""===loadPage)throw new Error("The hotstaq tag must have a src, HTML contents inside it, or a router set.");HotStaq_1.HotStaq.displayUrl(options)}else HotStaq_1.HotStaq.displayContent(options)}))}),50)}}exports.hotStaqWebStart=hotStaqWebStart},473:(t,e)=>{"use strict";Object.defineProperty(e,"__esModule",{value:!0}),e.HotTestDestination=void 0;class n{constructor(t="",e=!0){"string"==typeof t?(this.destination=t,this.autoStart=e):t instanceof n?(this.destination=t.destination,this.autoStart=t.autoStart):(this.destination=t.path,this.autoStart=t.autoStart)}}e.HotTestDestination=n},628:function(t,e){"use strict";var n=this&&this.__awaiter||function(t,e,n,r){return new(n||(n=Promise))((function(o,s){function i(t){try{a(r.next(t))}catch(t){s(t)}}function l(t){try{a(r.throw(t))}catch(t){s(t)}}function a(t){var e;t.done?o(t.value):(e=t.value,e instanceof n?e:new n((function(t){t(e)}))).then(i,l)}a((r=r.apply(t,e||[])).next())}))};Object.defineProperty(e,"__esModule",{value:!0}),e.HotTestDriver=void 0,e.HotTestDriver=class{constructor(t,e=null){this.processor=t,this.page=e,this.commandDelay=20,this.persistentData={}}parseTestObject(t){let e=t.indexOf("*"),n="";e>-1&&(t=t.replace(/\*/,""),n="*");let r=`[data-test-object-name${n}='${t}']`;return e=t.indexOf(">"),e>-1&&(r=t=t.replace(/\>/,"")),r}wait(t){return n(this,void 0,void 0,(function*(){return yield new Promise(((e,n)=>{setTimeout((()=>{e()}),t)}))}))}print(t){return n(this,void 0,void 0,(function*(){process.stdout.write(t)}))}println(t){return n(this,void 0,void 0,(function*(){yield this.print(`${t}\n`)}))}destroy(){return n(this,void 0,void 0,(function*(){}))}assert(t,e=""){return n(this,void 0,void 0,(function*(){if(!t)throw new Error(e)}))}}},967:(t,e)=>{"use strict";Object.defineProperty(e,"__esModule",{value:!0}),e.HotTestElement=e.HotTestElementOptions=void 0,e.HotTestElementOptions=class{constructor(t={}){this.mustBeVisible=t.mustBeVisible||!0,this.ignoreMissingElementError=t.ignoreMissingElementError||!1}},e.HotTestElement=class{constructor(t,e="",n=null){"string"==typeof t?(this.name=t,this.func=e,this.value=n):(this.name=t.name,this.func=t.func||e,this.value=t.value||n)}}},985:(t,e,n)=>{"use strict";Object.defineProperty(e,"__esModule",{value:!0}),e.HotTestMap=void 0;const r=n(473);e.HotTestMap=class{constructor(t=[],e={},n=[]){if(t instanceof Array){this.destinations=[];for(let e=0;e<t.length;e++){let n=t[e];this.destinations.push(new r.HotTestDestination(n))}}else{this.destinations={};for(let e in t){let n=t[e];this.destinations[e]=new r.HotTestDestination(n)}}this.destinationOrder=n,this.pages=e}}},677:function(t,e,n){"use strict";var r=this&&this.__awaiter||function(t,e,n,r){return new(n||(n=Promise))((function(o,s){function i(t){try{a(r.next(t))}catch(t){s(t)}}function l(t){try{a(r.throw(t))}catch(t){s(t)}}function a(t){var e;t.done?o(t.value):(e=t.value,e instanceof n?e:new n((function(t){t(e)}))).then(i,l)}a((r=r.apply(t,e||[])).next())}))};Object.defineProperty(e,"__esModule",{value:!0}),e.HotTester=void 0;const o=n(243);class s{constructor(t,e,n,r,o={}){if(null==o)throw new Error("The testMaps parameter can be an empty object, but cannot be null! It is set to null.");this.processor=t,this.name=e,this.timeout=1e4,this.baseUrl=n,this.testMaps=o,this.driver=r,this.finishedLoading=!1,this.hasBeenSetup=!1,this.hasBeenDestroyed=!1}setup(t,e,n){return r(this,void 0,void 0,(function*(){}))}destroy(){return r(this,void 0,void 0,(function*(){}))}waitForData(){return r(this,void 0,void 0,(function*(){for(;!1===this.finishedLoading;)yield o.HotStaq.wait(10)}))}getTestPage(t){return this.testMaps[t.mapName].pages[t.page]}getTestPath(t,e){return this.testMaps[t.mapName].pages[t.page].testPaths[e]}static interpretDestination(t,e){let n={mapName:t,page:"",api:"",paths:[]},r=e.destination.split(/\-\>/g),o=r[0];if(o.length<2)return null;if("/"===o[0]&&"/"===o[1])return null;let s=(t,e)=>{let n=t.indexOf(e),r="";return n>-1&&(r=t.substr(n+e.length),r=r.trim()),r};n.page=s(o,"page:"),n.api=s(o,"api:");for(let t=1;t<r.length;t++){let e=r[t],o={cmd:"",dest:"",path:""};e=e.trim(),o.dest=s(e,"dest:"),o.cmd=s(e,"cmd:"),o.path=s(e,"path:"),""==o.dest&&""==o.cmd&&""==o.path&&(o.path=e),n.paths.push(o)}return n}executeTestAPIPath(t,e,n,o=!1,s=!1){return r(this,void 0,void 0,(function*(){let r=!0;if(null==e)throw new Error(`Trying to access null method on destination map ${t.mapName}.`);!1===o&&null!=this.onTestAPIPathStart&&(r=yield this.onTestAPIPathStart(t,e,n,s));let i=null;if(!0===r){let t=e.testCases[n];if(null==t)throw new Error(`HotTester: Test case object ${n} does not exist!`);i=yield t.func(this.driver)}return!1===o&&null!=this.onTestAPIPathEnd&&(yield this.onTestAPIPathEnd(t,e,n,i,s)),i}))}executeTestAPIPaths(t){return r(this,void 0,void 0,(function*(){let e=[];if(null==this.testMaps[t.mapName])throw new Error(`HotTester: API Map ${t.mapName} does not exist!`);if(null==this.processor.api)throw new Error("HotTester: Associated processor does not have an API!");let n=this.processor.api.routes[t.api];if(null==n)throw new Error(`HotTester: API does not have route ${t.api}!`);for(let r=0;r<t.paths.length;r+=2){let o=t.paths[r].path,s=n.getMethod(o),i=t.paths[r+1].path;if(null==s)throw new Error(`Unable to find method related to path ${o} in map ${t.mapName}`);let l=yield this.executeTestAPIPath(t,s,i);e.push(l)}return e}))}executeTestPagePath(t,e,n=!1,o=!1){return r(this,void 0,void 0,(function*(){let r=!0,s=this.testMaps[t.mapName];if(null==s)throw new Error(`HotTester: Web Map ${t.mapName} does not exist!`);let i=s.pages[t.page];if(null==i)throw new Error(`HotTester: Page ${t.page} does not exist!`);this.driver.page=i;let l=e.path,a=i.testPaths[l];!1===n&&null!=this.onTestPagePathStart&&(r=yield this.onTestPagePathStart(t,i,e,o));let u=null;if(!0===r){if(null==a)throw new Error(`HotTester: Test path ${l} does not have a function!`);u=yield a(this.driver)}return!1===n&&null!=this.onTestPagePathEnd&&(yield this.onTestPagePathEnd(t,a,u,o)),u}))}executeCommand(t,e,n,s){return r(this,void 0,void 0,(function*(){let i=(t,e,r)=>{let o=!1;n.cmd===e&&(o=!0);const s=n.cmd.indexOf("(");return s>-1&&n.cmd.substr(0,s)===e&&(o=!0),o},l=t=>{let e=[],n=t.match(/(?=\()(.*?)(?=\))/g);if(null!=n){let t=n[0];t=t.substr(2,t.length),e.push(t)}if(e.length<1)throw new Error(`HotTester: Command ${t} requires arguments, but none were supplied.`);return e},a=null,u=null,c=[];if("undefined"!=typeof HotTesterMochaSelenium&&this instanceof HotTesterMochaSelenium&&(a=this),null!=a&&(!0===i(n.cmd,"url")&&(c=l(n.cmd),u=t=>r(this,void 0,void 0,(function*(){let e=t[0];yield a.driver.navigateToUrl(e)}))),!0===i(n.cmd,"waitForTestObject")&&(c=l(n.cmd),u=t=>r(this,void 0,void 0,(function*(){let e=JSON.parse(t[0]);yield a.driver.waitForTestElement(e)})))),!0===i(n.cmd,"waitForTesterAPIData")&&(u=t=>r(this,void 0,void 0,(function*(){this.finishedLoading=!1,yield this.waitForData()}))),!0===i(n.cmd,"wait")&&(c=l(n.cmd),u=t=>r(this,void 0,void 0,(function*(){let e=parseInt(t[0]);yield o.HotStaq.wait(e)}))),!0===i(n.cmd,"print")&&(c=l(n.cmd),u=t=>r(this,void 0,void 0,(function*(){let e=t[0];yield this.driver.print(e)}))),!0===i(n.cmd,"println")&&(c=l(n.cmd),u=t=>r(this,void 0,void 0,(function*(){let e=t[0];yield this.driver.println(e)}))),null==u)throw new Error(`HotTester: Command ${n.cmd} does not exist!`);yield this.onCommand(t,e,n,s,c,u)}))}executeTestPagePaths(t,e=!1){return r(this,void 0,void 0,(function*(){let n=[],r=this.testMaps[t.mapName];if(null==r)throw new Error(`HotTester: Web Map ${t.mapName} does not exist!`);for(let o=0;o<t.paths.length;o++){let i=t.paths[o],l=null,a=r.pages[t.page];if(null==a)throw new Error(`HotTester: Page ${t.page} does not exist!`);if(""!==i.dest){if(r.destinations instanceof Array)throw new Error(`HotTester: When using type 'dest' in a destination string, all destinations in map ${t.mapName} must be named.`);let e=r.destinations[i.dest],n=s.interpretDestination(t.mapName,e);null!=n&&(l=yield this.executeTestPagePaths(n))}""!==i.cmd&&(yield this.executeCommand(t,a,i,i.cmd)),""!==i.path&&(l=yield this.executeTestPagePath(t,i,!1,e)),n.push(l)}return n}))}execute(t){return r(this,void 0,void 0,(function*(){let e=this.testMaps[t];if(null==e)throw new Error(`HotTester: Map ${t} does not exist!`);this.processor.logger.verbose(`HotTester: Executing map ${t}...`);let n=this.processor.getRouteKeyFromName(t),o="";this.baseUrl,""!==n&&(o=`${this.baseUrl}${n}`);let i=(e,n="")=>r(this,void 0,void 0,(function*(){if(!1!==e.autoStart)try{this.processor.logger.verbose((()=>`HotTester: Executing ${t} destination ${JSON.stringify(e)}...`));let r=s.interpretDestination(t,e),i=!1,l=!0;""!==r.page&&(i=!0),null!=this.setup&&!1===this.hasBeenSetup&&(yield this.setup(i,o,n),this.hasBeenSetup=!0,this.hasBeenDestroyed=!1),null!=this.onTestStart&&(l=yield this.onTestStart(r,o,n)),!0===l&&(""!==r.page&&(yield this.executeTestPagePaths(r)),""!==r.api&&(yield this.executeTestAPIPaths(r))),null!=this.onTestEnd&&(yield this.onTestEnd(r)),null!=this.destroy&&!1===this.hasBeenDestroyed&&(yield this.destroy(),this.hasBeenDestroyed=!0,this.hasBeenSetup=!1)}catch(t){throw t}}));if(e.destinations instanceof Array)for(let t=0;t<e.destinations.length;t++){let n=e.destinations[t];yield i(n)}else if(e.destinationOrder.length>0){let t=[];for(let n=0;n<e.destinationOrder.length;n++){let r=e.destinationOrder[n],o=e.destinations[r];if(null==o)throw new Error(`HotTester: Destination ${r} does not exist!`);t.push(r),yield i(o,r)}for(let n in e.destinations){let r=!0;for(let e=0;e<t.length;e++)if(t[e]===n){r=!1;break}if(!0===r){let t=e.destinations[n];yield i(t,n)}}}else for(let t in e.destinations){let n=e.destinations[t];yield i(n,t)}}))}}e.HotTester=s},414:function(__unused_webpack_module,exports,__webpack_require__){"use strict";var __awaiter=this&&this.__awaiter||function(t,e,n,r){return new(n||(n=Promise))((function(o,s){function i(t){try{a(r.next(t))}catch(t){s(t)}}function l(t){try{a(r.throw(t))}catch(t){s(t)}}function a(t){var e;t.done?o(t.value):(e=t.value,e instanceof n?e:new n((function(t){t(e)}))).then(i,l)}a((r=r.apply(t,e||[])).next())}))};Object.defineProperty(exports,"__esModule",{value:!0}),exports.HotTesterAPI=void 0;const HotAPI_1=__webpack_require__(233),HotRoute_1=__webpack_require__(761),HotRouteMethod_1=__webpack_require__(70);class HotTesterAPI extends HotAPI_1.HotAPI{constructor(t,e=null,n=null){super(t,e,n),this.executeEventsUsing=HotAPI_1.EventExecutionType.HotAPI;let r=new HotRoute_1.HotRoute(e,"tester");r.addMethod({name:"pageLoaded",onServerExecute:this.pageLoaded,parameters:{testerName:{required:!0,type:"string",description:"The name of the tester executing the test."},testerMap:{required:!0,type:"string",description:"The tester map executing the test."},pageName:{required:!0,type:"string",description:"The name of the page executing the test."},testElements:{required:!0,type:"array",description:"The test elements on the page."},testPaths:{required:!0,type:"array",description:"The test paths on the page."}},returns:"Returns true as an acknowledgement."}),r.addMethod({name:"executeTests",onServerExecute:this.executeTests,parameters:{testerName:{required:!0,type:"string",description:"The name of the tester executing the test."},testerMap:{required:!0,type:"object",description:"The tester map to execute."}},returns:"Returns true when tests are complete."}),r.addMethod({name:"heartbeat",type:HotRouteMethod_1.HotEventMethod.GET,onServerExecute:this.heartbeat,returns:"Returns true as an acknowledgement."}),this.addRoute(r)}pageLoaded(request){return __awaiter(this,void 0,void 0,(function*(){let testerObj={testerName:request.jsonObj.testerName,testerMap:request.jsonObj.testerMap,pageName:request.jsonObj.pageName,testElements:request.jsonObj.testElements,testPathsStrs:request.jsonObj.testPaths};for(let t in testerObj){let e=testerObj[t],n=!1;if(null==e&&(n=!0),""!=testerObj.testerName&&""!==testerObj.testerMap&&""!==testerObj.testElements&&""!==testerObj.testPathsStrs||(n=!0),!0===n)throw new Error(`TesterAPI: Object ${t} was not passed.`)}testerObj.testElements=JSON.parse(testerObj.testElements),testerObj.testPathsStrs=JSON.parse(testerObj.testPathsStrs);let testPaths={};for(let key in testerObj.testPathsStrs){let testPath=eval(testerObj.testPathsStrs[key]);testPaths[key]=testPath}let tester=this.connection.processor.testers[testerObj.testerName];if(null==tester)throw new Error(`TesterAPI: Tester ${testerObj.testerName} does not exist!`);let testMap=tester.testMaps[testerObj.testerMap];if(null==testMap)throw new Error(`TesterAPI: Tester map ${testerObj.testerMap} does not exist!`);return testMap.pages[testerObj.pageName]={testElements:{},testPaths:{}},testMap.pages[testerObj.pageName].testElements=testerObj.testElements,testMap.pages[testerObj.pageName].testPaths=testPaths,tester.finishedLoading=!0,null!=tester.onFinishedLoading&&(yield tester.onFinishedLoading()),!0}))}executeTests(t){return __awaiter(this,void 0,void 0,(function*(){let e=t.jsonObj.testerName,n=t.jsonObj.testerMap;if(null==e||null==n)throw new Error("TesterAPI: Not all required json objects were passed.");if(""===e||""===n)throw new Error("TesterAPI: Not all required json objects were passed.");let r=this.connection;return null!=r.executeTests&&(yield r.executeTests(e,n)),!0}))}heartbeat(t){return __awaiter(this,void 0,void 0,(function*(){return!0}))}}exports.HotTesterAPI=HotTesterAPI},651:t=>{"use strict";t.exports={}},351:()=>{},606:()=>{}},__webpack_module_cache__={};function __webpack_require__(t){var e=__webpack_module_cache__[t];if(void 0!==e)return e.exports;var n=__webpack_module_cache__[t]={exports:{}};return __webpack_modules__[t].call(n.exports,n,n.exports,__webpack_require__),n.exports}__webpack_require__.g=function(){if("object"==typeof globalThis)return globalThis;try{return this||new Function("return this")()}catch(t){if("object"==typeof window)return window}}();var __webpack_exports__={};(()=>{"use strict";var t=__webpack_exports__;Object.defineProperty(t,"__esModule",{value:!0}),t.HotTestDriver=t.HotTestElementOptions=t.HotTestElement=t.HotTestDestination=t.HotTestMap=t.HotTesterAPI=t.HotTester=t.HotClient=t.HotServerType=t.HotServer=t.ServerRequest=t.HotEventMethod=t.HotRouteMethod=t.HotRoute=t.HotPage=t.HotLogLevel=t.HotLog=t.HotFile=t.EventExecutionType=t.HotAPI=t.HotComponent=t.DeveloperMode=t.HotAsset=t.HotModule=t.Hot=t.HotStaq=void 0;const e=__webpack_require__(243);Object.defineProperty(t,"HotStaq",{enumerable:!0,get:function(){return e.HotStaq}});const n=__webpack_require__(507);Object.defineProperty(t,"Hot",{enumerable:!0,get:function(){return n.Hot}}),Object.defineProperty(t,"DeveloperMode",{enumerable:!0,get:function(){return n.DeveloperMode}});const r=__webpack_require__(316);Object.defineProperty(t,"HotAsset",{enumerable:!0,get:function(){return r.HotAsset}});const o=__webpack_require__(202);Object.defineProperty(t,"HotModule",{enumerable:!0,get:function(){return o.HotModule}});const s=__webpack_require__(260);Object.defineProperty(t,"HotComponent",{enumerable:!0,get:function(){return s.HotComponent}});const i=__webpack_require__(732);Object.defineProperty(t,"HotFile",{enumerable:!0,get:function(){return i.HotFile}});const l=__webpack_require__(802);Object.defineProperty(t,"HotLog",{enumerable:!0,get:function(){return l.HotLog}}),Object.defineProperty(t,"HotLogLevel",{enumerable:!0,get:function(){return l.HotLogLevel}});const a=__webpack_require__(136);Object.defineProperty(t,"HotPage",{enumerable:!0,get:function(){return a.HotPage}});const u=__webpack_require__(233);Object.defineProperty(t,"HotAPI",{enumerable:!0,get:function(){return u.HotAPI}}),Object.defineProperty(t,"EventExecutionType",{enumerable:!0,get:function(){return u.EventExecutionType}});const c=__webpack_require__(761);Object.defineProperty(t,"HotRoute",{enumerable:!0,get:function(){return c.HotRoute}});const h=__webpack_require__(70);Object.defineProperty(t,"HotRouteMethod",{enumerable:!0,get:function(){return h.HotRouteMethod}}),Object.defineProperty(t,"HotEventMethod",{enumerable:!0,get:function(){return h.HotEventMethod}}),Object.defineProperty(t,"ServerRequest",{enumerable:!0,get:function(){return h.ServerRequest}});const p=__webpack_require__(810);Object.defineProperty(t,"HotServer",{enumerable:!0,get:function(){return p.HotServer}}),Object.defineProperty(t,"HotServerType",{enumerable:!0,get:function(){return p.HotServerType}});const d=__webpack_require__(957);Object.defineProperty(t,"HotClient",{enumerable:!0,get:function(){return d.HotClient}});const f=__webpack_require__(628);Object.defineProperty(t,"HotTestDriver",{enumerable:!0,get:function(){return f.HotTestDriver}});const m=__webpack_require__(967);Object.defineProperty(t,"HotTestElement",{enumerable:!0,get:function(){return m.HotTestElement}}),Object.defineProperty(t,"HotTestElementOptions",{enumerable:!0,get:function(){return m.HotTestElementOptions}});const g=__webpack_require__(677);Object.defineProperty(t,"HotTester",{enumerable:!0,get:function(){return g.HotTester}});const _=__webpack_require__(414);Object.defineProperty(t,"HotTesterAPI",{enumerable:!0,get:function(){return _.HotTesterAPI}});const v=__webpack_require__(985);Object.defineProperty(t,"HotTestMap",{enumerable:!0,get:function(){return v.HotTestMap}});const w=__webpack_require__(473);Object.defineProperty(t,"HotTestDestination",{enumerable:!0,get:function(){return w.HotTestDestination}}),e.HotStaq.isWeb=!0})(),HotStaqWeb=__webpack_exports__})();
2
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"HotStaq.js","mappings":"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","sources":["webpack://HotStaqWeb/./node_modules/form-data/lib/browser.js","webpack://HotStaqWeb/./node_modules/js-cookie/dist/js.cookie.js","webpack://HotStaqWeb/./node_modules/node-fetch/browser.js","webpack://HotStaqWeb/./src/Hot.ts","webpack://HotStaqWeb/./src/HotAPI.ts","webpack://HotStaqWeb/./src/HotAsset.ts","webpack://HotStaqWeb/./src/HotClient.ts","webpack://HotStaqWeb/./src/HotComponent.ts","webpack://HotStaqWeb/./src/HotFile.ts","webpack://HotStaqWeb/./src/HotLog.ts","webpack://HotStaqWeb/./src/HotModule.ts","webpack://HotStaqWeb/./src/HotPage.ts","webpack://HotStaqWeb/./src/HotRoute.ts","webpack://HotStaqWeb/./src/HotRouteMethod.ts","webpack://HotStaqWeb/./src/HotServer.ts","webpack://HotStaqWeb/./src/HotStaq.ts","webpack://HotStaqWeb/./src/HotStaqRegisterComponent.ts","webpack://HotStaqWeb/./src/HotStaqWebStart.ts","webpack://HotStaqWeb/./src/HotTestDestination.ts","webpack://HotStaqWeb/./src/HotTestDriver.ts","webpack://HotStaqWeb/./src/HotTestElement.ts","webpack://HotStaqWeb/./src/HotTestMap.ts","webpack://HotStaqWeb/./src/HotTester.ts","webpack://HotStaqWeb/./src/HotTesterAPI.ts","webpack://HotStaqWeb/external var \"{}\"","webpack://HotStaqWeb/webpack/bootstrap","webpack://HotStaqWeb/webpack/runtime/global","webpack://HotStaqWeb/./src/api-web.ts"],"sourcesContent":["/* eslint-env browser */\nmodule.exports = typeof self == 'object' ? self.FormData : window.FormData;\n","/*! js-cookie v3.0.1 | MIT */\n;\n(function (global, factory) {\n  typeof exports === 'object' && typeof module !== 'undefined' ? module.exports = factory() :\n  typeof define === 'function' && define.amd ? define(factory) :\n  (global = global || self, (function () {\n    var current = global.Cookies;\n    var exports = global.Cookies = factory();\n    exports.noConflict = function () { global.Cookies = current; return exports; };\n  }()));\n}(this, (function () { 'use strict';\n\n  /* eslint-disable no-var */\n  function assign (target) {\n    for (var i = 1; i < arguments.length; i++) {\n      var source = arguments[i];\n      for (var key in source) {\n        target[key] = source[key];\n      }\n    }\n    return target\n  }\n  /* eslint-enable no-var */\n\n  /* eslint-disable no-var */\n  var defaultConverter = {\n    read: function (value) {\n      if (value[0] === '\"') {\n        value = value.slice(1, -1);\n      }\n      return value.replace(/(%[\\dA-F]{2})+/gi, decodeURIComponent)\n    },\n    write: function (value) {\n      return encodeURIComponent(value).replace(\n        /%(2[346BF]|3[AC-F]|40|5[BDE]|60|7[BCD])/g,\n        decodeURIComponent\n      )\n    }\n  };\n  /* eslint-enable no-var */\n\n  /* eslint-disable no-var */\n\n  function init (converter, defaultAttributes) {\n    function set (key, value, attributes) {\n      if (typeof document === 'undefined') {\n        return\n      }\n\n      attributes = assign({}, defaultAttributes, attributes);\n\n      if (typeof attributes.expires === 'number') {\n        attributes.expires = new Date(Date.now() + attributes.expires * 864e5);\n      }\n      if (attributes.expires) {\n        attributes.expires = attributes.expires.toUTCString();\n      }\n\n      key = encodeURIComponent(key)\n        .replace(/%(2[346B]|5E|60|7C)/g, decodeURIComponent)\n        .replace(/[()]/g, escape);\n\n      var stringifiedAttributes = '';\n      for (var attributeName in attributes) {\n        if (!attributes[attributeName]) {\n          continue\n        }\n\n        stringifiedAttributes += '; ' + attributeName;\n\n        if (attributes[attributeName] === true) {\n          continue\n        }\n\n        // Considers RFC 6265 section 5.2:\n        // ...\n        // 3.  If the remaining unparsed-attributes contains a %x3B (\";\")\n        //     character:\n        // Consume the characters of the unparsed-attributes up to,\n        // not including, the first %x3B (\";\") character.\n        // ...\n        stringifiedAttributes += '=' + attributes[attributeName].split(';')[0];\n      }\n\n      return (document.cookie =\n        key + '=' + converter.write(value, key) + stringifiedAttributes)\n    }\n\n    function get (key) {\n      if (typeof document === 'undefined' || (arguments.length && !key)) {\n        return\n      }\n\n      // To prevent the for loop in the first place assign an empty array\n      // in case there are no cookies at all.\n      var cookies = document.cookie ? document.cookie.split('; ') : [];\n      var jar = {};\n      for (var i = 0; i < cookies.length; i++) {\n        var parts = cookies[i].split('=');\n        var value = parts.slice(1).join('=');\n\n        try {\n          var foundKey = decodeURIComponent(parts[0]);\n          jar[foundKey] = converter.read(value, foundKey);\n\n          if (key === foundKey) {\n            break\n          }\n        } catch (e) {}\n      }\n\n      return key ? jar[key] : jar\n    }\n\n    return Object.create(\n      {\n        set: set,\n        get: get,\n        remove: function (key, attributes) {\n          set(\n            key,\n            '',\n            assign({}, attributes, {\n              expires: -1\n            })\n          );\n        },\n        withAttributes: function (attributes) {\n          return init(this.converter, assign({}, this.attributes, attributes))\n        },\n        withConverter: function (converter) {\n          return init(assign({}, this.converter, converter), this.attributes)\n        }\n      },\n      {\n        attributes: { value: Object.freeze(defaultAttributes) },\n        converter: { value: Object.freeze(converter) }\n      }\n    )\n  }\n\n  var api = init(defaultConverter, { path: '/' });\n  /* eslint-enable no-var */\n\n  return api;\n\n})));\n","\"use strict\";\n\n// ref: https://github.com/tc39/proposal-global\nvar getGlobal = function () {\n\t// the only reliable means to get the global object is\n\t// `Function('return this')()`\n\t// However, this causes CSP violations in Chrome apps.\n\tif (typeof self !== 'undefined') { return self; }\n\tif (typeof window !== 'undefined') { return window; }\n\tif (typeof global !== 'undefined') { return global; }\n\tthrow new Error('unable to locate global object');\n}\n\nvar global = getGlobal();\n\nmodule.exports = exports = global.fetch;\n\n// Needed for TypeScript and Webpack.\nif (global.fetch) {\n\texports.default = global.fetch.bind(global);\n}\n\nexports.Headers = global.Headers;\nexports.Request = global.Request;\nexports.Response = global.Response;","import { HotFile } from \"./HotFile\";\nimport { HotPage } from \"./HotPage\";\nimport { HotStaq } from \"./HotStaq\";\nimport { HotAPI } from \"./HotAPI\";\nimport { HotTestElement } from \"./HotTestElement\";\n\nimport Cookies from \"js-cookie\";\nimport fetch from \"node-fetch\";\nimport { HotEventMethod } from \"./HotRouteMethod\";\nimport { HotComponent, IHotComponent } from \"./HotComponent\";\nimport { HotModule } from \"./HotModule\";\n\n/**\n * The available developer modes.\n */\nexport enum DeveloperMode\n{\n\t/**\n\t * The default developer mode. No tests will be executed and \n\t * any test related data will be ignored.\n\t */\n\tProduction,\n\t/**\n\t * For use during development/debugging. All test data will \n\t * be collected and executed if necessary.\n\t */\n\tDevelopment\n}\n\n/**\n * A CSS object to embed.\n */\nexport interface CSSObject\n{\n\t/**\n\t * The url to the CSS file to embed.\n\t */\n\turl: string;\n\t/**\n\t * The integrity hash to generate during initial compilation.\n\t */\n\tintegrityHash: string;\n}\n\n/**\n * The api used during processing.\n */\nexport class Hot\n{\n\t/**\n\t * The currently generated page being displayed. This is cleared between every file processed.\n\t */\n\tstatic CurrentPage: HotPage = null;\n\t/**\n\t * The arguments passed.\n\t */\n\tstatic Arguments: any = null;\n\t/**\n\t * The mode in which this application is running. If it's set to development mode, all testing\n\t * related data will be collected, parsed, and executed if necessary.\n\t */\n\tstatic DeveloperMode = DeveloperMode;\n\t/**\n\t * The mode in which this application is running. If it's set to development mode, all testing\n\t * related data will be collected, parsed, and executed if necessary.\n\t */\n\tstatic HotTestElement = HotTestElement;\n\t/**\n\t * The mode in which this application is running. If it's set to development mode, all testing\n\t * related data will be collected, parsed, and executed if necessary.\n\t */\n\tstatic Mode: DeveloperMode = DeveloperMode.Production;\n\t/**\n\t *The current API used on this page. This is cleared between every file processed.\n\t */\n\tstatic API: HotAPI = null;\n\t/**\n\t * The API being used by the tester.\n\t */\n\tstatic TesterAPI: HotAPI = null;\n\t/**\n\t * Contains the buffer to output. This is cleared between every file processed.\n\t */\n\tstatic Output: string = \"\";\n\t/**\n\t * The data to share across all the different files and pages. This data will be public.\n\t */\n\tstatic Data: any = {};\n\t/**\n\t * The cookies to use between pages.\n\t */\n\tstatic Cookies: Cookies.CookiesStatic = Cookies;\n\t/**\n\t * Any public keys that need to be shown. These can be passed from HotSite.json.\n\t */\n\tstatic PublicKeys: any = {};\n\t/**\n\t * The CSS string to use when echoing out the CSS files.\n\t */\n\tstatic cssStr: string = `<link rel = \"stylesheet\" href = \"%CSS_FILE%\" />`;\n\t/**\n\t * The CSS files to use in the current page being generated.\n\t * \n\t * @todo Make this a \"string | CSSObject\" data type so it can also include \n\t * the integrity hashes as well.\n\t */\n\tstatic CSS: string[] = [];\n\t/**\n\t * The JavaScript files to use in the current page being generated.\n\t * \n\t * @todo Make this a \"string | JSFileObject\" data type so it can also include \n\t * the integrity hashes as well.\n\t */\n\tstatic JSFiles: any[] = [];\n\t/**\n\t * The JavaScript inline code to use in the current page being generated.\n\t */\n\tstatic JSScripts: any[] = [];\n\t/**\n\t * The JavaScript string to use when echoing out the Scripts files.\n\t */\n\tstatic jsFileStr: string = `<script type = \"text/javascript\" src = \"%JS_FILE%\"></script>`;\n\t/**\n\t * The JavaScript string to use when echoing out the Scripts files.\n\t */\n\tstatic jsScriptsStr: string = `<script type = \"text/javascript\">%JS_CODE%</script>`;\n\n\t/**\n\t * Retrieve a file and echo out it's contents.\n\t */\n\tstatic async include (file: HotFile | string, args: any[] = null): Promise<void>\n\t{\n\t\tif (HotStaq.isWeb === true)\n\t\t{\n\t\t\tif (typeof (file) === \"string\")\n\t\t\t{\n\t\t\t\tconst lowerFile: string = file.toLowerCase ();\n\n\t\t\t\t// If the file to be included does not have a nahfam, add it. This \n\t\t\t\t// will ensure the server sends only the file content.\n\t\t\t\tif (lowerFile.indexOf (\".hott\") > -1)\n\t\t\t\t{\n\t\t\t\t\tif (lowerFile.indexOf (\"nahfam\") < 0)\n\t\t\t\t\t\tfile += \"?hstqserve=nahfam\";\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\n\t\tHot.echo (await Hot.getFile (file, args));\n\t}\n\n\t/**\n\t * Include and execute JavaScript for use when running the preprocessor.\n\t */\n\tstatic async includeJS (file: HotFile | string, args: any[] = null, parentObject: any = null): Promise<any>\n\t{\n\t\tconst output: string = await Hot.getFile (file, args);\n\n\t\tif (HotStaq.isWeb === true)\n\t\t{\n\t\t\tif (parentObject == null)\n\t\t\t\tparentObject = window;\n\t\t}\n\t\telse\n\t\t{\n\t\t\tif (parentObject == null)\n\t\t\t\tparentObject = global;\n\t\t}\n\n\t\treturn (eval.apply (parentObject, [output]));\n\t}\n\n\t/**\n\t * Retrieve a file and echo out it's contents.\n\t */\n\tstatic async import (moduleName: string, args: any[] = null, parentObject: any = null): Promise<any>\n\t{\n\t\tlet foundModule: HotModule = Hot.CurrentPage.processor.getModule (moduleName);\n\n\t\tif (foundModule != null)\n\t\t\treturn (foundModule);\n\n\t\tconst file: string = `./hotstaq_modules/${moduleName}/index.js`;\n\t\tconst output: string = await Hot.getFile (file, args);\n\n\t\tif (HotStaq.isWeb === true)\n\t\t{\n\t\t\tif (parentObject == null)\n\t\t\t\tparentObject = window;\n\t\t}\n\t\telse\n\t\t{\n\t\t\tif (parentObject == null)\n\t\t\t\tparentObject = global;\n\t\t}\n\n\t\tlet newModule = new Function (output).apply (parentObject);\n\n\t\tif (newModule.loadHTML != null)\n\t\t\tawait newModule.loadHTML ();\n\n\t\tHot.CurrentPage.processor.addModule (moduleName, newModule);\n\n\t\treturn (newModule);\n\t}\n\n\t/**\n\t * Run an already loaded file and echo out it's contents.\n\t */\n\tstatic async runFile (fileName: string, args: any[] = null): Promise<void>\n\t{\n\t\tlet file: HotFile = Hot.CurrentPage.processor.getFile (fileName);\n\t\t/// @fixme Does the file need to be deep cloned first?\n\t\t//let clonedFile: HotFile = new HotFile (Object.assign ({}, file));\n\t\tlet tempFile: HotFile = file;\n\n\t\ttempFile.page = this.CurrentPage;\n\t\tlet content: string = await tempFile.process (args);\n\n\t\tHot.echo (content);\n\t}\n\n\t/**\n\t * Get the content of a file.\n\t */\n\tstatic async getFile (path: HotFile | string, args: any[] = null): Promise<string>\n\t{\n\t\tlet tempFile: HotFile = null;\n\n\t\tif (typeof (path) === \"string\")\n\t\t{\n\t\t\ttempFile = new HotFile ();\n\t\t\ttempFile.name = path;\n\n\t\t\tif (HotStaq.isWeb === true)\n\t\t\t\ttempFile.url = path;\n\t\t\telse\n\t\t\t\ttempFile.localFile = path;\n\t\t}\n\t\telse\n\t\t\ttempFile = path;\n\n\t\tlet checkFile: HotFile = Hot.CurrentPage.processor.getFile (tempFile.name, false);\n\n\t\tif (checkFile != null)\n\t\t\ttempFile = checkFile;\n\n\t\tawait tempFile.load ();\n\n\t\ttempFile.page = this.CurrentPage;\n\t\tlet content: string = await tempFile.process (args);\n\n\t\treturn (content);\n\t}\n\n\t/**\n\t * Make an api call.\n\t */\n\tstatic async apiCall (route: string, data: any = null, \n\t\thttpMethod: HotEventMethod = HotEventMethod.POST, \n\t\tfiles: { [name: string]: any } = {}): Promise<any>\n\t{\n\t\tlet result: any = null;\n\n\t\tif (Hot.CurrentPage == null)\n\t\t\tthrow new Error (\"Current page is null!\");\n\n\t\tif (Hot.CurrentPage.processor == null)\n\t\t\tthrow new Error (\"Current page's processor is null!\");\n\n\t\tif (Hot.CurrentPage.processor.api == null)\n\t\t\tthrow new Error (\"Current page's processor api is null! Did you forget to set the API name or URL?\");\n\n\t\tif (Hot.CurrentPage.processor.api != null)\n\t\t{\n\t\t\tresult = await Hot.CurrentPage.processor.api.makeCall (route, \n\t\t\t\t\t\t\tdata, httpMethod, files);\n\t\t}\n\n\t\treturn (result);\n\t}\n\n\t/**\n\t * Get a HTTP JSON file or request.\n\t * \n\t * @param url The full url to make the HTTP call.\n\t * \n\t * @returns The parsed JSON object.\n\t */\n\tstatic async getJSON (url: string): Promise<any>\n\t{\n\t\treturn (Hot.jsonRequest (url, null, HotEventMethod.GET));\n\t}\n\n\t/**\n\t * Make a HTTP JSON request.\n\t * \n\t * @param url The full url to make the HTTP call.\n\t * @param data The data to JSON.stringify and send.\n\t * @param httpMethod The HTTP method to use to send the data.\n\t * \n\t * @returns The parsed JSON object.\n\t */\n\tstatic async jsonRequest (url: string, data: any = null, httpMethod: HotEventMethod = HotEventMethod.POST): Promise<any>\n\t{\n\t\ttry\n\t\t{\n\t\t\tlet fetchObj = {\n\t\t\t\t\"method\": httpMethod,\n\t\t\t\t\"headers\": {\n\t\t\t\t\t\t\"Accept\": \"application/json\",\n\t\t\t\t\t\t\"Content-Type\": \"application/json\"\n\t\t\t\t\t}\n\t\t\t}\n\n\t\t\tif (httpMethod === HotEventMethod.POST)\n\t\t\t{\n\t\t\t\t/// @ts-ignore\n\t\t\t\tfetchObj[\"body\"] = JSON.stringify (data);\n\t\t\t}\n\n\t\t\tlet res = await fetch (url, fetchObj);\n\n\t\t\tif (res.ok === false)\n\t\t\t\tthrow new Error (`${res.status}: ${res.statusText}`);\n\n\t\t\tlet result: any = await res.json ();\n\n\t\t\treturn (result);\n\t\t}\n\t\tcatch (ex)\n\t\t{\n\t\t\treturn (JSON.stringify ({ \"error\": `${ex.message} - Could not fetch ${url}` }));\n\t\t}\n\t}\n\n\t/**\n\t * Make a HTTP request. This is basically just a wrapper for fetch.\n\t * \n\t * @param {string} url The full url to make the HTTP call.\n\t * @param {RequestInit} requestInit The request parameters to send.\n\t * \n\t * @returns The HTTP response.\n\t */\n\tstatic async httpRequest (url: string, requestInit: any = undefined): Promise<any>\n\t{\n\t\tlet res = await fetch (url, requestInit);\n\n\t\treturn (res);\n\t}\n\n\t/**\n\t * Echo out some output.\n\t */\n\tstatic echo (message: string): void\n\t{\n\t\tHot.Output += message;\n\t}\n\n\t/**\n\t * Echo out the CSS for the current page being generated.\n\t */\n\tstatic displayCSS (): void\n\t{\n\t\tfor (let iIdx = 0; iIdx < Hot.CSS.length; iIdx++)\n\t\t{\n\t\t\tlet cssFile: string = Hot.CSS[iIdx];\n\t\t\tlet cssOut: string = Hot.cssStr;\n\n\t\t\tcssOut = cssOut.replace (/\\%CSS_FILE\\%/g, cssFile);\n\n\t\t\tHot.echo (cssOut);\n\t\t}\n\t}\n\n\t/**\n\t * Echo out the JS files for the current page being generated.\n\t */\n\tstatic displayJSFiles (): void\n\t{\n\t\tfor (let iIdx = 0; iIdx < Hot.JSFiles.length; iIdx++)\n\t\t{\n\t\t\tlet jsFile: string = Hot.JSFiles[iIdx];\n\t\t\tlet jsFileOut: string = Hot.jsFileStr;\n\n\t\t\tjsFileOut = jsFileOut.replace (/\\%JS_FILE\\%/g, jsFile);\n\n\t\t\tHot.echo (jsFileOut);\n\t\t}\n\t}\n\n\t/**\n\t * Echo out the JS scripts for the current page being generated.\n\t */\n\tstatic displayJSScripts (): void\n\t{\n\t\tfor (let iIdx = 0; iIdx < Hot.JSScripts.length; iIdx++)\n\t\t{\n\t\t\tlet jsScript: string = Hot.JSScripts[iIdx];\n\t\t\tlet jsScriptOut: string = Hot.jsScriptsStr;\n\n\t\t\tjsScriptOut = jsScriptOut.replace (/\\%JS_CODE\\%/g, jsScript);\n\n\t\t\tHot.echo (jsScriptOut);\n\t\t}\n\t}\n}","import fetch from \"node-fetch\";\nimport FormData from \"form-data\";\n\nimport { HotServer } from \"./HotServer\";\nimport { HotRoute } from \"./HotRoute\";\nimport { HotClient } from \"./HotClient\";\nimport { HotEventMethod, HotRouteMethod, ServerAuthorizationFunction } from \"./HotRouteMethod\";\nimport { HotDB } from \"./HotDB\";\n\nimport { HotDBSchema } from \"./schemas/HotDBSchema\";\nimport { HotWebSocketServer } from \"./HotWebSocketServer\";\nimport { HotHTTPServer } from \"./HotHTTPServer\";\n\n/**\n * The API to load.\n */\nexport type APItoLoad = {\n\t/**\n\t * The imported class to load.\n\t */\n\timportedAPIClass: any;\n\t/**\n\t * The exported class name to import and instantiate.\n\t */\n\texportedClassName: string;\n\t/**\n\t * The path to the HotAPI class to load.\n\t */\n\tpath: string;\n };\n\n/**\n * The type of object to use during event executions.\n */\nexport enum EventExecutionType\n{\n\tHotRoute,\n\tHotMethod,\n\tHotAPI\n}\n\n/**\n * The API to use.\n */\nexport abstract class HotAPI\n{\n\t/**\n\t * The server connection.\n\t */\n\tconnection: HotServer | HotClient;\n\t/**\n\t * The description of the API.\n\t */\n\tdescription: string;\n\t/**\n\t * The base url for the server.\n\t */\n\tbaseUrl: string;\n\t/**\n\t * If set, this will create the route variables and functions for \n\t * easy client/server calling.\n\t */\n\tcreateFunctions: boolean;\n\t/**\n\t * The database connection.\n\t */\n\texecuteEventsUsing: EventExecutionType;\n\t/**\n\t * The database connection.\n\t */\n\tdb: HotDB;\n\t/**\n\t * The authorization credentials the client uses throughout the application. If using \n\t * basic authentication for HTTP requests, be sure to override the \n\t * `toAuthorizationHeaderString` in this object.\n\t * \n\t * Example of this object:\n\t * ```ts\n\t * this.authCredentials = {\n\t * \t\tuser: \"username\",\n\t * \t\tpassword: \"password\",\n\t * \t\ttoAuthorizationHeaderString: function ()\n\t * \t\t\t{\n\t * \t\t\t\treturn (btoa (this.user + \":\" + this.password));\n\t * \t\t\t}\n\t * \t};\n\t * ```\n\t */\n\tauthCredentials: any;\n\t/**\n\t * The function used for user authentication.\n\t */\n\tuserAuth: ServerAuthorizationFunction;\n\t/**\n\t * The database connection.\n\t */\n\troutes: { [name: string]: HotRoute };\n\t/**\n\t * Executed when the API is about to start registering routes. If \n\t * this function returns false, the server will not start.\n\t */\n\tonPreRegister: () => Promise<boolean>;\n\t/**\n\t * Executed when the API has finished registering routes. If \n\t * this function returns false, the server will not start.\n\t */\n\tonPostRegister: () => Promise<boolean>;\n\n\tconstructor (baseUrl: string, connection: HotServer | HotClient, db: HotDB = null)\n\t{\n\t\tif (connection == null)\n\t\t\tthrow new Error (`No server attached to api with baseUrl: ${baseUrl}`);\n\n\t\tthis.connection = connection;\n\t\tthis.description = \"\";\n\t\tthis.baseUrl = baseUrl;\n\t\tthis.createFunctions = true;\n\t\tthis.executeEventsUsing = EventExecutionType.HotRoute;\n\t\tthis.db = db;\n\t\tthis.authCredentials = null;\n\t\tthis.userAuth = null;\n\t\tthis.routes = {};\n\t\tthis.onPreRegister = null;\n\t\tthis.onPostRegister = null;\n\t}\n\n\t/**\n\t * Set the database schema for use.\n\t */\n\tsetDBSchema (schema: HotDBSchema): void\n\t{\n\t\tif (this.connection.api == null)\n\t\t\tthrow new Error (`No API has been set!`);\n\n\t\tif (this.connection.api.db == null)\n\t\t\tthrow new Error (`No database has been set for API base url ${this.connection.api.baseUrl}`);\n\n\t\tthis.connection.api.db.schema = schema;\n\t}\n\n\t/**\n\t * Get the database being used.\n\t */\n\tgetDB (): HotDB\n\t{\n\t\tif (this.connection.api.db == null)\n\t\t\tthrow new Error (`No database has been set for API base url ${this.connection.api.baseUrl}`);\n\n\t\treturn (this.connection.api.db);\n\t}\n\n\t/**\n\t * Get the database schema being used.\n\t */\n\tgetDBSchema (): HotDBSchema\n\t{\n\t\tif (this.connection.api.db == null)\n\t\t\tthrow new Error (`No database has been set for API base url ${this.connection.api.baseUrl}`);\n\n\t\treturn (this.connection.api.db.schema);\n\t}\n\n\t/**\n\t * Add a route. If this.createFunctions is set to true (which is default), this will take the incoming \n\t * route and create an object in this HotAPI object using the name of the route. If there's \n\t * any HotRouteMethods inside of the incoming HotRoute, it will create the methods \n\t * and attach them to the newly created HotRoute object.\n\t * \n\t * @example\n\t * ```ts\n\t * import { HotAPI, HotRoute } from \"hotstaq\";\n\t * \n\t * class AppAPI extends HotAPI\n\t * {\n\t * \t\tconstructor (baseUrl: string, connection: HotServer | HotClient = null, db: any = null)\n\t * \t\t{\n\t * \t\t\tsuper(baseUrl, connection, db);\n\t * \n\t * \t\t\t// Creates the route http://127.0.0.1:8080/v1/hello_world/\n\t * \t\t\tthis.addRoute (new ExampleRoute (this));\n\t * \t\t}\n\t * }\n\t * \n\t * class ExampleRoute extends HotRoute\n\t * {\n\t * \t\tconstructor (api: AppAPI)\n\t * \t\t{\n\t * \t\t\tsuper (api.connection, \"hello_world\");\n\t * \n\t * \t\t\t// Creates the HTTP GET endpoint: http://127.0.0.1:8080/v1/hello_world/hi\n\t * \t\t\t// When this endpoint is accessed, the JSON response will return \"hello\"\n\t * \t\t\tthis.addMethod (\"hi\", async () =>\n\t * \t\t\t{\n\t * \t\t\t\treturn (\"hello\");\n\t * \t\t\t});\n\t * \t\t}\n\t * }\n\t * ```\n\t * \n\t * In the client browser, this would be used like so:\n\t * ```\n\t * await Hot.API.hello_world.hi ();\n\t * ```\n\t * \n\t * @param route The route to add. Can be either a full HotRoute object, or just \n\t * the route's name. If a HotRoute object is supplied, the rest of the parameters \n\t * will be ignored.\n\t * @param routeMethod The route's method to add. If the route parameter is a string, \n\t * it will be interpreted as the route's name, and this will be the method added to \n\t * the new route.\n\t * @param executeFunction The function to execute when routeMethod is called by the API.\n\t */\n\taddRoute (\n\t\troute: HotRoute | string,\n\t\trouteMethod: HotRouteMethod | string = null,\n\t\texecuteFunction: (req: any, res: any, authorizedValue: any, jsonObj: any, queryObj: any) => Promise<any> = null\n\t\t): void\n\t{\n\t\tlet routeName: string = \"\";\n\n\t\tif (typeof (route) === \"string\")\n\t\t{\n\t\t\trouteName = route;\n\n\t\t\tif (this.routes[routeName] == null)\n\t\t\t\tthis.routes[routeName] = new HotRoute (this.connection, routeName);\n\n\t\t\tif (typeof (routeMethod) === \"string\")\n\t\t\t{\n\t\t\t\tthis.routes[routeName].addMethod (new HotRouteMethod (\n\t\t\t\t\tthis.routes[routeName], routeMethod, executeFunction));\n\t\t\t}\n\t\t\telse\n\t\t\t\tthis.routes[routeName].addMethod (routeMethod);\n\t\t}\n\t\telse\n\t\t{\n\t\t\trouteName = route.route;\n\t\t\tthis.routes[route.route] = route;\n\t\t}\n\n\t\tthis.routes[routeName].connection = this.connection;\n\n\t\t// Create the route functions for the server/client.\n\t\tif (this.createFunctions === true)\n\t\t{\n\t\t\t// @ts-ignore\n\t\t\tlet newRoute: { [name: string]: Function } = this[routeName];\n\n\t\t\tif (newRoute == null)\n\t\t\t\tnewRoute = {};\n\n\t\t\tfor (let iIdx = 0; iIdx < this.routes[routeName].methods.length; iIdx++)\n\t\t\t{\n\t\t\t\tlet currentRoute: HotRoute = this.routes[routeName];\n\t\t\t\tlet newRouteMethod: HotRouteMethod = this.routes[routeName].methods[iIdx];\n\n\t\t\t\t/*\n\t\t\t\t/// @fixme Is this really necessary? A HTTP call is much more preferable, \n\t\t\t\t/// especially for accruate testing.\n\t\t\t\tif (this.connection instanceof HotServer)\n\t\t\t\t{\n\t\t\t\t\tif (newRouteMethod.onServerExecute != null)\n\t\t\t\t\t\tnewRoute[newRouteMethod.name] = newRouteMethod.onServerExecute;\n\t\t\t\t}\n\t\t\t\telse*/\n\t\t\t\t{\n\t\t\t\t\t/*\n\t\t\t\t\t/// @fixme Is onClientExecute necessary? I'm thinking the dev can just simply create \n\t\t\t\t\t/// their own function to call.\n\t\t\t\t\tif (newRouteMethod.onClientExecute != null)\n\t\t\t\t\t\tnewRoute[newRouteMethod.name] = newRouteMethod.onClientExecute;\n\t\t\t\t\telse\n\t\t\t\t\t{*/\n\t\t\t\t\t\tnewRoute[newRouteMethod.name] = (data: any, files: any): any =>\n\t\t\t\t\t\t\t{\n\t\t\t\t\t\t\t\tlet httpMethod: string = newRouteMethod.type;\n\t\t\t\t\t\t\t\t// Construct the url here. Base + route + route method\n\t\t\t\t\t\t\t\tlet routeStr: string = newRouteMethod.getRouteUrl ();\n\t\t\t\t\t\t\t\tlet authCredentials: any = null;\n\n\t\t\t\t\t\t\t\t// Getting the authorization credentials from the API is the lowest \n\t\t\t\t\t\t\t\t// priority for getting credentials. The priorities are in this order: \n\t\t\t\t\t\t\t\t// 1. HotRouteMethod\n\t\t\t\t\t\t\t\t// 2. HotRoute\n\t\t\t\t\t\t\t\t// 3. HotAPI\n\t\t\t\t\t\t\t\tif (this.authCredentials != null)\n\t\t\t\t\t\t\t\t\tauthCredentials = this.authCredentials;\n\n\t\t\t\t\t\t\t\t// Find the authorization credentials. Prioritize them when they're \n\t\t\t\t\t\t\t\t// in the method. Only add the ones from the route if the ones from \n\t\t\t\t\t\t\t\t// the method are missing.\n\t\t\t\t\t\t\t\tif (newRouteMethod.authCredentials != null)\n\t\t\t\t\t\t\t\t\tauthCredentials = newRouteMethod.authCredentials;\n\t\t\t\t\t\t\t\telse\n\t\t\t\t\t\t\t\t{\n\t\t\t\t\t\t\t\t\tif (newRouteMethod.route.authCredentials != null)\n\t\t\t\t\t\t\t\t\t\tauthCredentials = newRouteMethod.route.authCredentials;\n\t\t\t\t\t\t\t\t}\n\n\t\t\t\t\t\t\t\tif (authCredentials == null)\n\t\t\t\t\t\t\t\t{\n\t\t\t\t\t\t\t\t\t// @ts-ignore\n\t\t\t\t\t\t\t\t\tif (typeof (Hot) !== \"undefined\")\n\t\t\t\t\t\t\t\t\t{\n\t\t\t\t\t\t\t\t\t\t// @ts-ignore\n\t\t\t\t\t\t\t\t\t\tif (Hot != null)\n\t\t\t\t\t\t\t\t\t\t{\n\t\t\t\t\t\t\t\t\t\t\t// @ts-ignore\n\t\t\t\t\t\t\t\t\t\t\tif (Hot.API != null)\n\t\t\t\t\t\t\t\t\t\t\t{\n\t\t\t\t\t\t\t\t\t\t\t\t// @ts-ignore\n\t\t\t\t\t\t\t\t\t\t\t\tif (Hot.API[currentRoute.route] != null)\n\t\t\t\t\t\t\t\t\t\t\t\t{\n\t\t\t\t\t\t\t\t\t\t\t\t\t// @ts-ignore\n\t\t\t\t\t\t\t\t\t\t\t\t\tif (Hot.API[currentRoute.route].authCredentials != null)\n\t\t\t\t\t\t\t\t\t\t\t\t\t{\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t// @ts-ignore\n\t\t\t\t\t\t\t\t\t\t\t\t\t\tauthCredentials = Hot.API[currentRoute.route].authCredentials;\n\t\t\t\t\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t}\n\n\t\t\t\t\t\t\t\tif (authCredentials != null)\n\t\t\t\t\t\t\t\t{\n\t\t\t\t\t\t\t\t\t// Add the authorization credentials to the data being sent.\n\t\t\t\t\t\t\t\t\tfor (let key in authCredentials)\n\t\t\t\t\t\t\t\t\t{\n\t\t\t\t\t\t\t\t\t\tlet authCredential: any = authCredentials[key];\n\n\t\t\t\t\t\t\t\t\t\t// Do not overwrite any existing keys in the data about \n\t\t\t\t\t\t\t\t\t\t// to be sent.\n\t\t\t\t\t\t\t\t\t\tif (data[key] == null)\n\t\t\t\t\t\t\t\t\t\t\tdata[key] = authCredential;\n\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t}\n\n\t\t\t\t\t\t\t\tlet args: any[] = [routeStr, data, httpMethod, files];\n\n\t\t\t\t\t\t\t\treturn (this.makeCall.apply (this, args));\n\t\t\t\t\t\t\t};\n\t\t\t\t\t//}\n\t\t\t\t}\n\t\t\t}\n\n\t\t\t// @ts-ignore\n\t\t\tthis[routeName] = newRoute;\n\t\t}\n\t}\n\n\t/**\n\t * Register a route with the server.\n\t */\n\tasync registerRoute (route: HotRoute): Promise<void>\n\t{\n\t\tif (this.connection instanceof HotServer)\n\t\t\tawait this.connection.registerRoute (route);\n\t}\n\n\t/**\n\t * Register all routes with the server.\n\t */\n\tasync registerRoutes (): Promise<void>\n\t{\n\t\tfor (let key in this.routes)\n\t\t{\n\t\t\tlet route: HotRoute = this.routes[key];\n\n\t\t\tawait this.registerRoute (route);\n\t\t}\n\t}\n\n\t/**\n\t * Make a call to the API.\n\t */\n\tasync makeCall (route: string, data: any, httpMethod: HotEventMethod = HotEventMethod.POST, \n\t\tfiles: { [name: string]: any } = {}): Promise<any>\n\t{\n\t\tlet url: string = this.baseUrl;\n\n\t\tconst httpMethodStr: string = httpMethod.toUpperCase ();\n\n\t\tif (url[(url.length - 1)] === \"/\")\n\t\t\turl = url.substr (0, (url.length - 1));\n\n\t\tif (route[0] !== \"/\")\n\t\t\turl += \"/\";\n\n\t\turl += route;\n\n\t\tconst numFiles: number = Object.keys (files).length;\n\n\t\tif (numFiles > 0)\n\t\t{\n\t\t\tif (httpMethodStr !== \"POST\")\n\t\t\t\tthrow new Error (`To upload files, you must set the httpMethod to POST.`);\n\n\t\t\tconst formData: FormData = new FormData ();\n\n\t\t\tfor (let key in files)\n\t\t\t\tformData.append (key, files[key]);\n\n\t\t\tlet res = await fetch (url, {\n\t\t\t\t\tmethod: \"POST\",\n\t\t\t\t\t// @ts-ignore\n\t\t\t\t\tbody: formData\n\t\t\t\t});\n\t\t\tlet jsonRes: any = await res.json ();\n\n\t\t\tif (data[\"hotstaq\"] == null)\n\t\t\t\tdata[\"hotstaq\"] = {};\n\n\t\t\tif (data[\"hotstaq\"][\"uploads\"] == null)\n\t\t\t\tdata[\"hotstaq\"][\"uploads\"] = {};\n\n\t\t\tdata[\"hotstaq\"][\"uploads\"][\"uploadId\"] = \n\t\t\t\t\tjsonRes[\"hotstaq\"][\"uploads\"][\"uploadId\"];\n\n\t\t\t// After the upload, make the actual JSON call. Do not pass files again.\n\t\t\tconst result: any = await this.makeCall (route, data, httpMethod);\n\n\t\t\treturn (result);\n\t\t}\n\n\t\tlet fetchObj: any = {\n\t\t\t\tmethod: httpMethod,\n\t\t\t\theaders: {\n\t\t\t\t\t\t\"Accept\": \"application/json\",\n\t\t\t\t\t\t\"Content-Type\": \"application/json\"\n\t\t\t\t\t}\n\t\t\t};\n\n\t\tif ((httpMethodStr !== \"GET\") && \n\t\t\t(httpMethodStr !== \"HEAD\"))\n\t\t{\n\t\t\tfetchObj[\"body\"] = JSON.stringify (data);\n\t\t}\n\n\t\tlet promise = new Promise ((resolve, reject) => \n\t\t\t{\n\t\t\t\tfetch (url, fetchObj).then (async (res) =>\n\t\t\t\t\t{\n\t\t\t\t\t\tres.json ().then ((jsonObj: any) =>\n\t\t\t\t\t\t\t{\n\t\t\t\t\t\t\t\tresolve (jsonObj);\n\t\t\t\t\t\t\t})\n\t\t\t\t\t\t\t.catch ((reason: any) =>\n\t\t\t\t\t\t\t{\n\t\t\t\t\t\t\t\tthrow new Error (`${url}: ${reason.message}`);\n\t\t\t\t\t\t\t});\n\t\t\t\t\t})\n\t\t\t\t\t.catch ((reason: any) =>\n\t\t\t\t\t{\n\t\t\t\t\t\tthrow new Error (`${url}: ${reason.message}`);\n\t\t\t\t\t});\n\t\t\t});\n\n\t\treturn (promise);\n\t}\n}\n","/**\n * An asset to load.\n */\nexport class HotAsset\n{\n\t/**\n\t * The type of asset. Can be:\n\t * * js\n\t * * css\n\t * * html\n\t * * component\n\t */\n\ttype: string;\n\t/**\n\t * The name of the asset to load.\n\t */\n\tname?: string;\n\t/**\n\t * The path to the assets to load.\n\t */\n\tpath?: string;\n\t/**\n\t * The preloaded content to load. Requires name to be set.\n\t */\n\tcontent?: string;\n\n\tconstructor (type: string, name: string = \"\")\n\t{\n\t\tthis.type = type;\n\t\tthis.name = name;\n\t\tthis.path = \"\";\n\t\tthis.content = \"\";\n\t}\n\n\tload (): void\n\t{\n\t}\n\n\t/**\n\t * Load the asset.\n\t */\n\toutput (): string | { name: string; url?: string; content?: string; }\n\t{\n\t\tif ((this.path == null) && (this.content == null))\n\t\t\tthrow new Error (`HotAsset ${this.name} of type ${this.type} does not have a path or content set!`);\n\n\t\tlet output: string | { name: string; url?: string; content?: string; } = \"\";\n\n\t\tif (this.path != null)\n\t\t{\n\t\t\tif (this.path !== \"\")\n\t\t\t{\n\t\t\t\tif (this.type === \"js\")\n\t\t\t\t\toutput = `<script type = \"text/javascript\" src = \"${this.path}\"></script>`;\n\n\t\t\t\tif (this.type === \"css\")\n\t\t\t\t\toutput = `<link href = \"${this.path}\" rel = \"stylesheet\" />`;\n\n\t\t\t\tif ((this.type === \"html\") || \n\t\t\t\t\t(this.type === \"component\"))\n\t\t\t\t{\n\t\t\t\t\tif (this.name === \"\")\n\t\t\t\t\t\tthrow new Error (`Loading an HTML or component asset requires a name to be set!`);\n\n\t\t\t\t\tlet fileUrl: string = `\"${this.path}\"`;\n\t\t\t\t\toutput = { name: this.name, url: this.path };\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\n\t\tif (this.content != null)\n\t\t{\n\t\t\tif (this.content !== \"\")\n\t\t\t{\n\t\t\t\tif (this.type === \"js\")\n\t\t\t\t\tthrow new Error (`Loading JS assets using content is not supported yet!`);\n\n\t\t\t\tif (this.type === \"css\")\n\t\t\t\t\tthrow new Error (`Loading CSS assets using content is not supported yet!`);\n\n\t\t\t\tif (this.type === \"html\")\n\t\t\t\t{\n\t\t\t\t\tif (this.name === \"\")\n\t\t\t\t\t\tthrow new Error (`Loading an HTML asset requires a name to be set!`);\n\n\t\t\t\t\tlet escapedContent: string = JSON.stringify (this.content);\n\t\t\t\t\tlet fileUrl: string = this.path;\n\t\t\t\t\tlet fileContent: string = \"\";\n\n\t\t\t\t\t// Find any script tags and interrupt them so the HTML parsers \n\t\t\t\t\t// don't get confused.\n\t\t\t\t\tescapedContent = escapedContent.replace (new RegExp (\"\\\\<script\", \"gmi\"), \"<scr\\\" + \\\"ipt\");\n\t\t\t\t\tescapedContent = escapedContent.replace (new RegExp (\"\\\\<\\\\/script\", \"gmi\"), \"</scr\\\" + \\\"ipt\");\n\n\t\t\t\t\tfileContent = escapedContent;\n\n\t\t\t\t\toutput = { name: this.name, url: fileUrl, content: escapedContent };\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\n\t\treturn (output);\n\t}\n}","import { HotStaq } from \"./HotStaq\";\nimport { HotAPI } from \"./HotAPI\";\nimport { HotServerType } from \"./HotServer\";\nimport { HotLog } from \"./HotLog\";\n\n/**\n * A client connected to a server.\n */\nexport class HotClient\n{\n\t/**\n\t * The processor to use.\n\t */\n\tprocessor: HotStaq;\n\t/**\n\t * The API to use.\n\t */\n\tapi: HotAPI;\n\t/**\n\t * The tester API to use.\n\t */\n\ttesterAPI: HotAPI;\n\t/**\n\t * The type of server.\n\t */\n\ttype: HotServerType;\n\t/**\n\t * The logger.\n\t */\n\tlogger: HotLog;\n\n\tconstructor (processor: HotStaq)\n\t{\n\t\tthis.processor = processor;\n\t\tthis.api = null;\n\t\tthis.testerAPI = null;\n\t\tthis.type = HotServerType.HTTP;\n\t\tthis.logger = processor.logger;\n\t}\n}","import { HotAPI } from \"./HotAPI\";\nimport { HotStaq } from \"./HotStaq\";\n\nexport interface HotComponentOutput\n{\n\t/**\n\t * The HTML to output.\n\t */\n\thtml: string;\n\t/**\n\t * The query selector to add this component's functions to.\n\t * \n\t * @example #objectId\n\t */\n\taddFunctionsTo?: string;\n\t/**\n\t * The place here parent name to attach this html to.\n\t * \n\t * @example top\n\t */\n\tplaceHereParent?: string;\n\t/**\n\t * Append the output to an existing element using a CSS selector that is \n\t * the closest.\n\t * \n\t * @example div .testClass\n\t */\n\tclosestSelector?: string;\n\t/**\n\t * Append the output to an existing element somewhere on the document.\n\t * \n\t * @example div .testClass\n\t */\n\tdocumentSelector?: string;\n}\n\n/**\n * A component to preprocess.\n */\nexport interface IHotComponent\n{\n\t/**\n\t * The processor to use.\n\t */\n\tprocessor: HotStaq;\n\t/**\n\t * The associated HTMLElements.\n\t */\n\thtmlElements?: HTMLElement[];\n\t/**\n\t * The name of the page.\n\t */\n\tname?: string;\n\t/**\n\t * The name of the tag.\n\t */\n\ttag?: string;\n\t/**\n\t * The connected API.\n\t */\n\tapi?: HotAPI;\n\t/**\n\t * The options to include with registering this component.\n\t */\n\telementOptions?: ElementDefinitionOptions;\n\t/**\n\t * Any extra attributes to register.\n\t */\n\tobservedAttributes?: string[];\n\t/**\n\t * The type of component.\n\t */\n\ttype?: string;\n\t/**\n\t * The value of the component.\n\t */\n\tvalue?: any;\n\t/**\n\t * The inner HTML or value of the component.\n\t */\n\tinner: any;\n\t/**\n\t * The events to trigger.\n\t */\n\tevents?: {\n\t\t\t[name: string]: {\n\t\t\t\ttype: string;\n\t\t\t\tfunc: Function;\n\t\t\t\toptions?: any;\n\t\t\t}\n\t\t};\n\t/**\n\t * Execute prior to output.\n\t * \n\t * @returns If set to false, the component will not be registered.\n\t */\n\tonPreOutput?: () => boolean;\n\t/**\n\t * Execute after getting the output, but before the DOM parsing.\n\t * \n\t * @param output The output from the component to register. Can be manipulated one last time prior to \n\t * being parsed into a DOM element.\n\t * \n\t * @returns The final output to be parsed as a DOM element.\n\t */\n\tonPostOutput?: (output: (string | HotComponentOutput[])) => (string | HotComponentOutput[]);\n\t/**\n\t * Execute when its time to fix the HTML prior to DOM parsing. This will skip the HotStaq default fixing.\n\t */\n\tonFixHTML?: (output: string) => { fixedStr: string, querySelector: string; };\n\t/**\n\t * Execute a custom DOM parser.\n\t */\n\tonParseDOM?: (output: string) => Document;\n\t/**\n\t * Execute after the output has been parsed and is ready to be placed into the DOM.\n\t */\n\tonParsed?: (output: string) => string;\n\t/**\n\t * Execute prior to placing the new DOM element.\n\t */\n\tonPrePlace?: (htmlElement: HTMLElement) => HTMLElement;\n\t/**\n\t * Execute after placing the new DOM element. Can be manipulated one final time prior to being rendered.\n\t */\n\tonPostPlace?: (parentHtmlElement: HTMLElement, htmlElement: HTMLElement) => HTMLElement;\n\t/**\n\t * Execute after placing the DOM element onto the newly created parent.\n\t */\n\tonParentPlace?: (parentHtmlElement: HTMLElement, htmlElement: HTMLElement) => void;\n}\n\n/**\n * A component to preprocess.\n */\nexport abstract class HotComponent implements IHotComponent\n{\n\t/**\n\t * The processor to use.\n\t */\n\tprocessor: HotStaq;\n\t/**\n\t * The associated HTMLElements.\n\t */\n\thtmlElements: HTMLElement[];\n\t/**\n\t * The name of the component.\n\t */\n\tname: string;\n\t/**\n\t * The name of the tag.\n\t */\n\ttag: string;\n\t/**\n\t * The connected API.\n\t */\n\tapi: HotAPI;\n\t/**\n\t * The options to include with registering this component.\n\t */\n\telementOptions: ElementDefinitionOptions;\n\t/**\n\t * Any extra attributes to register.\n\t */\n\tobservedAttributes: string[];\n\t/**\n\t * The type of component.\n\t */\n\ttype: string;\n\t/**\n\t * The value of the component.\n\t */\n\tvalue: any;\n\t/**\n\t * The inner HTML or value of the component.\n\t */\n\tinner: any;\n\t/**\n\t * The events to trigger.\n\t */\n\tevents: {\n\t\t[name: string]: {\n\t\t\t\ttype: string;\n\t\t\t\tfunc: Function;\n\t\t\t\toptions: any;\n\t\t\t}\n\t\t};\n\t/**\n\t * Execute prior to output.\n\t * \n\t * @returns If set to false, the component will not be registered.\n\t */\n\tonPreOutput? (): boolean;\n\t/**\n\t * Execute after getting the output, but before the DOM parsing.\n\t * \n\t * @param output The output from the component to register. Can be manipulated one last time prior to \n\t * being parsed into a DOM element.\n\t * \n\t * @returns The final output to be parsed as a DOM element.\n\t */\n\tonPostOutput? (output: (string | HotComponentOutput[])): (string | HotComponentOutput[]);\n\t/**\n\t * Execute when its time to fix the HTML prior to DOM parsing. This will skip the HotStaq default fixing.\n\t */\n\tonFixHTML? (output: string): { fixedStr: string, querySelector: string; };\n\t/**\n\t * Execute a custom DOM parser.\n\t */\n\tonParseDOM? (output: string): Document;\n\t/**\n\t * Execute after the output has been parsed and is ready to be placed into the DOM.\n\t */\n\tonParsed? (output: string): string;\n\t/**\n\t * Execute prior to placing the new DOM element.\n\t */\n\tonPrePlace? (htmlElement: HTMLElement): HTMLElement;\n\t/**\n\t * Execute after placing the new DOM element. Can be manipulated one final time prior to being rendered.\n\t */\n\tonPostPlace? (parentHtmlElement: HTMLElement, htmlElement: HTMLElement): HTMLElement;\n\t/**\n\t * Execute after placing the DOM element onto the newly created parent.\n\t */\n\tonParentPlace? (parentHtmlElement: HTMLElement, htmlElement: HTMLElement): void;\n\n\tconstructor (copy: IHotComponent | HotStaq, api: HotAPI = null)\n\t{\n\t\tif ((copy instanceof HotStaq) || (copy == null))\n\t\t{\n\t\t\t// @ts-ignore\n\t\t\tthis.processor = copy;\n\t\t\tthis.htmlElements = [];\n\t\t\tthis.name = \"\";\n\t\t\tthis.tag = \"\";\n\t\t\tthis.api = null;\n\t\t\tthis.elementOptions = undefined;\n\t\t\tthis.observedAttributes = [];\n\t\t\tthis.type = \"\";\n\t\t\tthis.value = null;\n\t\t\tthis.inner = null;\n\t\t\tthis.events = {};\n\t\t}\n\t\telse\n\t\t{\n\t\t\tthis.processor = copy.processor;\n\t\t\tthis.htmlElements = copy.htmlElements || [];\n\t\t\tthis.name = copy.name || \"\";\n\t\t\tthis.tag = copy.tag || this.name;\n\t\t\tthis.api = copy.api || null;\n\t\t\tthis.elementOptions = copy.elementOptions || undefined;\n\t\t\tthis.observedAttributes = copy.observedAttributes || [];\n\t\t\tthis.type = copy.type || \"\";\n\t\t\tthis.value = copy.value || null;\n\t\t\tthis.inner = copy.inner || null;\n\t\t\tthis.events = {};\n\t\t}\n\n\t\tif (api != null)\n\t\t\tthis.api = api;\n\t}\n\n\t/**\n\t * Event that's called when this component's DOM element has been created.\n\t * \n\t * @returns The modified DOM element.\n\t */\n\tonCreated (element: HTMLElement): any\n\t{\n\t\treturn (element);\n\t}\n\n\t/**\n\t * Handle the attributes manually.\n\t */\n\thandleAttributes? (attributes: NamedNodeMap): void;\n\n\t/**\n\t * Handle a click event.\n\t */\n\tclick? (): Promise<void>;\n\n\t/**\n\t * Output the component.\n\t */\n\tabstract output (): string | HotComponentOutput[];\n}","import * as fs from \"fs\";\n\nimport fetch from \"node-fetch\";\n\nimport { DeveloperMode, Hot } from \"./Hot\";\nimport { HotPage } from \"./HotPage\";\nimport { HotTestElement } from \"./HotTestElement\";\n\n/**\n * A file to process.\n */\nexport interface IHotFile\n{\n\t/**\n\t * The parent page.\n\t */\n\tpage?: HotPage;\n\t/**\n\t * The name of the file.\n\t */\n\tname?: string;\n\t/**\n\t * The url to the file to get.\n\t */\n\turl?: string;\n\t/**\n\t * The path to the local file to get.\n\t */\n\tlocalFile?: string;\n\t/**\n\t * The content of the file to process.\n\t */\n\tcontent?: string;\n\t/**\n\t * Force all errors to be thrown.\n\t */\n\tthrowAllErrors?: boolean;\n}\n\n/**\n * Parser options for when processing a string or file.\n */\nexport interface ParserOptions\n{\n\t/**\n\t * Output the commands generated from processing. Default: true\n\t */\n\toutputCommands?: boolean;\n\t/**\n\t * Allow JSON.stringify to be used during processing. Default: true\n\t */\n\tallowStringify?: boolean;\n}\n\n/**\n * A file to process.\n */\nexport class HotFile implements IHotFile\n{\n\t/**\n\t * The parent page.\n\t */\n\tpage: HotPage;\n\t/**\n\t * The name of the file.\n\t */\n\tname: string;\n\t/**\n\t * The url to the file to get.\n\t */\n\turl: string;\n\t/**\n\t * The path to the local file to get.\n\t */\n\tlocalFile: string;\n\t/**\n\t * The content of the file to process.\n\t */\n\tcontent: string;\n\t/**\n\t * Force all errors to be thrown.\n\t */\n\tthrowAllErrors: boolean;\n\n\tconstructor (copy: IHotFile = {})\n\t{\n\t\tthis.page = copy.page || null;\n\t\tthis.name = copy.name || \"\";\n\t\tthis.url = copy.url || \"\";\n\t\tthis.localFile = copy.localFile || \"\";\n\t\tthis.content = copy.content || \"\";\n\t\tthis.throwAllErrors = copy.throwAllErrors || false;\n\t}\n\n\t/**\n\t * Set the content of this file.\n\t */\n\tsetContent (content: string): void\n\t{\n\t\tthis.content = content;\n\t}\n\n\t/**\n\t * Get the content of this file.\n\t */\n\tgetContent (): string\n\t{\n\t\treturn (this.content);\n\t}\n\n\t/**\n\t * Make a HTTP get request.\n\t */\n\tstatic async httpGet (url: string): Promise<string>\n\t{\n\t\ttry\n\t\t{\n\t\t\tlet res = await fetch (url);\n\n\t\t\tif (res.ok === false)\n\t\t\t\tthrow new Error (`${res.status}: ${res.statusText}`);\n\n\t\t\tlet content: string = await res.text ();\n\n\t\t\treturn (content);\n\t\t}\n\t\tcatch (ex)\n\t\t{\n\t\t\treturn (JSON.stringify ({ \"error\": `${ex.message} - Could not fetch ${url}` }));\n\t\t}\n\t}\n\n\t/**\n\t * Load content from a url.\n\t */\n\tasync loadUrl (): Promise<string>\n\t{\n\t\tthis.content = await HotFile.httpGet (this.url);\n\n\t\treturn (this.content);\n\t}\n\n\t/**\n\t * Load content from a local file.\n\t */\n\tasync loadLocalFile (): Promise<string>\n\t{\n\t\tlet promise: Promise<string> = new Promise (\n\t\t\t(resolve: any, reject: any): void =>\n\t\t\t{\n\t\t\t\tfs.readFile (this.localFile, (err: NodeJS.ErrnoException, data: Buffer): void =>\n\t\t\t\t\t{\n\t\t\t\t\t\tif (err != null)\n\t\t\t\t\t\t\tthrow err;\n\n\t\t\t\t\t\tlet content: string = data.toString ();\n\t\t\t\t\t\tthis.content = content;\n\n\t\t\t\t\t\tresolve (this.content);\n\t\t\t\t\t});\n\t\t\t});\n\n\t\treturn (promise);\n\t}\n\n\t/**\n\t * Load the contents of the file.\n\t */\n\tasync load (): Promise<string>\n\t{\n\t\tlet content: string = \"\";\n\n\t\tif (this.url !== \"\")\n\t\t\tcontent = await this.loadUrl ();\n\n\t\tif (this.localFile !== \"\")\n\t\t\tcontent = await this.loadLocalFile ();\n\n\t\treturn (content);\n\t}\n\n\t/**\n\t * Process string content. This will take in a regular expression and \n\t * parse the content based on the regex. When the regex content is found \n\t * contentProcessor will be executed with the regex content found. When \n\t * the regex content is not found, offContentProcessor will be called with \n\t * the content outside of the regex.\n\t * \n\t * @param content The content to parse.\n\t * @param contentRegex The regex to use to parse the content.\n\t * @param contentProcessor The content found inside the regex.\n\t * @param offContentProcessor The content found outside of the regex.\n\t * @param numRemoveFromBeginning The number of characters to remove from the \n\t * beginning of the found content.\n\t * @param numRemoveFromEnd The number of characters to remove from the end of \n\t * the found content.\n\t */\n\tstatic processContent (content: string, contentRegex: RegExp,\n\t\tcontentProcessor: (regexFound: string) => string,\n\t\toffContentProcessor: (offContent: string) => string,\n\t\tnumRemoveFromBeginning: number = 2,\n\t\tnumRemoveFromEnd: number = 2): string\n\t{\n\t\tlet result: RegExpExecArray = contentRegex.exec (content);\n\t\tlet previousIndex: number = 0;\n\t\tlet output: string = \"\";\n\n\t\twhile (result != null)\n\t\t{\n\t\t\tlet start: number = result.index - numRemoveFromBeginning;\n\t\t\tlet end: number = contentRegex.lastIndex + numRemoveFromEnd;\n\n\t\t\t// Get the previous section.\n\t\t\tlet prevContent: string = content.substr (previousIndex, (start - previousIndex));\n\t\t\tpreviousIndex = end;\n\n\t\t\toutput += offContentProcessor (prevContent);\n\n\t\t\t// Process the content found from the regex\n\t\t\tlet contentFound: string = result[0];\n\t\t\toutput += contentProcessor (contentFound);\n\n\t\t\t// Move on to the next section to parse.\n\t\t\tresult = contentRegex.exec (content);\n\t\t}\n\n\t\t// Append whatever else is after the last parsed section.\n\t\tlet lastContent: string = content.substr (previousIndex);\n\n\t\toutput += offContentProcessor (lastContent);\n\n\t\treturn (output);\n\t}\n\n\t/**\n\t * Process any content that could have nested values. This will \n\t * take in a regular expression and \n\t * parse the content based on the regex. When the regex content is found \n\t * contentProcessor will be executed with the regex content found. When \n\t * the regex content is not found, offContentProcessor will be called with \n\t * the content outside of the regex.\n\t * \n\t * @fixme Needs to be able to ignore any characters found inside comments \n\t * or a string. For example, if the following is used ```${\"Test }\"}``` It \n\t * will error out.\n\t * \n\t * @param content The content to parse.\n\t * @param contentRegex The regex to use to parse the content.\n\t * @param contentProcessor The content found inside the regex.\n\t * @param offContentProcessor The content found outside of the regex.\n\t * @param numRemoveFromBeginning The number of characters to remove from the \n\t * beginning of the found content.\n\t * @param numRemoveFromEnd The number of characters to remove from the end of \n\t * the found content.\n\t */\n\tstatic processNestedContent (content: string, startChars: string, endChars: string, \n\t\ttriggerChar: string, contentProcessor: (regexFound: string) => string,\n\t\toffContentProcessor: (offContent: string) => string,\n\t\tnumRemoveFromBeginning: number = 2,\n\t\tnumRemoveFromEnd: number = 1): string\n\t{\n\t\tlet pos: number = content.indexOf (startChars);\n\t\tlet previousIndex: number = 0;\n\t\tlet startTriggerPos: number = content.indexOf (triggerChar, pos);\n\t\tlet output: string = \"\";\n\n\t\twhile (pos > -1)\n\t\t{\n\t\t\tlet end: number = content.indexOf (endChars, pos);\n\t\t\tlet nestedCounter: number = 0;\n\n\t\t\tif (triggerChar !== \"\")\n\t\t\t{\n\t\t\t\t// Reverse search the trigger characters and count the number of \n\t\t\t\t// occurrences.\n\t\t\t\tlet rpos: number = content.lastIndexOf (triggerChar, end - numRemoveFromEnd);\n\n\t\t\t\twhile (rpos > -1)\n\t\t\t\t{\n\t\t\t\t\tif (rpos === startTriggerPos)\n\t\t\t\t\t\tbreak;\n\n\t\t\t\t\trpos = content.lastIndexOf (triggerChar, rpos - numRemoveFromEnd);\n\t\t\t\t\tnestedCounter++;\n\t\t\t\t}\n\t\t\t}\n\n\t\t\t// If there's nested trigger characters, get the last occurrence of \n\t\t\t// the end character.\n\t\t\tif (nestedCounter > 0)\n\t\t\t{\n\t\t\t\tlet epos: number = content.indexOf (endChars, end + numRemoveFromEnd);\n\t\t\t\tlet tempepos: number = epos;\n\n\t\t\t\twhile ((epos > -1) && (nestedCounter > 0))\n\t\t\t\t{\n\t\t\t\t\tif (tempepos < 0)\n\t\t\t\t\t\tbreak;\n\n\t\t\t\t\t// Make sure we aren't discovering endChars that we shouldn't be.\n\t\t\t\t\tlet posOutsideOfContent: number = content.lastIndexOf (startChars, tempepos - numRemoveFromEnd);\n\n\t\t\t\t\tif (posOutsideOfContent > epos)\n\t\t\t\t\t\tbreak;\n\n\t\t\t\t\tepos = tempepos;\n\n\t\t\t\t\ttempepos = content.indexOf (endChars, epos + numRemoveFromEnd);\n\t\t\t\t\tnestedCounter--;\n\t\t\t\t}\n\n\t\t\t\tend = epos;\n\t\t\t}\n\n\t\t\tlet offContentStr: string = content.substr (previousIndex, (pos - previousIndex));\n\t\t\toutput += offContentProcessor (offContentStr);\n\n\t\t\tlet foundContent: string = content.substr (\n\t\t\t\tpos + numRemoveFromBeginning, (end - (pos + numRemoveFromBeginning)));\n\t\t\toutput += contentProcessor (foundContent);\n\n\t\t\t// Get the next content\n\t\t\tpos = content.indexOf (startChars, end + numRemoveFromEnd);\n\t\t\tstartTriggerPos = content.indexOf (triggerChar, pos);\n\t\t\tpreviousIndex = end + numRemoveFromEnd;\n\t\t}\n\n\t\t// Append whatever else is after the last parsed section.\n\t\tlet lastContent: string = content.substr (previousIndex);\n\n\t\toutput += offContentProcessor (lastContent);\n\n\t\treturn (output);\n\t}\n\n\t/**\n\t * Parse content.\n\t * \n\t * @param thisContent The content to parse.\n\t * @param throwAllErrors If set to true, any error that occurs will be thrown as an exception.\n\t * @param options The options to use when parsing the content.\n\t */\n\tstatic parseContent (thisContent: string, throwAllErrors: boolean, parserOptions: ParserOptions = null): string\n\t{\n\t\tif (parserOptions == null)\n\t\t{\n\t\t\tparserOptions = {\n\t\t\t\t\toutputCommands: true,\n\t\t\t\t\tallowStringify: true\n\t\t\t\t};\n\t\t}\n\n\t\tlet STRINGIFY_START: string = \"JSON.stringify (\";\n\t\tlet STRINGIFY_END: string = \")\";\n\n\t\tif (parserOptions.allowStringify === false)\n\t\t{\n\t\t\tSTRINGIFY_START = \"\";\n\t\t\tSTRINGIFY_END = \"\";\n\t\t}\n\n\t\t// Assemble the JS to evaluate. This will take all content outside of \n\t\t// <* and *> and wrap a Hot.echo around it. Any JS found inside of the \n\t\t// <* and *> will be executed as is.\n\t\tlet output: string = HotFile.processContent (thisContent, \n\t\t\tnew RegExp (\"(?=\\\\<\\\\*)([\\\\s\\\\S]*?)(?=\\\\*\\\\>)\", \"g\"), \n\t\t\t(regexFound: string): string =>\n\t\t\t{\n\t\t\t\t// A little hack, since I suck at Regex :(\n\t\t\t\tregexFound = regexFound.substr (2);\n\n\t\t\t\treturn (`${regexFound}`);\n\t\t\t}, \n\t\t\t(offContent: string): string =>\n\t\t\t{\n\t\t\t\tif (offContent === \"\")\n\t\t\t\t\treturn (\"\");\n\n\t\t\t\tlet tempOutput: string = HotFile.processNestedContent (\n\t\t\t\t\toffContent, \"!{\", \"}\", \"{\", \n\t\t\t\t\t(regexFound2: string): string =>\n\t\t\t\t\t{\n\t\t\t\t\t\tlet out: string = `*&&%*%@#@!${regexFound2}*&!#%@!@*!`;\n\n\t\t\t\t\t\treturn (out);\n\t\t\t\t\t}, \n\t\t\t\t\t(offContent3: string): string =>\n\t\t\t\t\t{\n\t\t\t\t\t\treturn (offContent3);\n\t\t\t\t\t});\n\t\t\t\tlet tempOutput2: string = HotFile.processNestedContent (\n\t\t\t\t\ttempOutput, \"STR{\", \"}\", \"{\", \n\t\t\t\t\t(regexFound2: string): string =>\n\t\t\t\t\t{\n\t\t\t\t\t\tlet out: string = \"\";\n\n\t\t\t\t\t\tif (parserOptions.outputCommands === true)\n\t\t\t\t\t\t\tout = `*&&%*%@#@!echoOutput (JSON.stringify(${regexFound2}), ${throwAllErrors});*&!#%@!@*!`;\n\t\t\t\t\t\telse\n\t\t\t\t\t\t\tout = `*&&%*%@#@!${STRINGIFY_START}${regexFound2}${STRINGIFY_END}, ${throwAllErrors});*&!#%@!@*!`;\n\n\t\t\t\t\t\treturn (out);\n\t\t\t\t\t}, \n\t\t\t\t\t(offContent3: string): string =>\n\t\t\t\t\t{\n\t\t\t\t\t\treturn (offContent3);\n\t\t\t\t\t}, 4, 1);\n\t\t\t\tlet tempOutput3: string = HotFile.processNestedContent (\n\t\t\t\t\ttempOutput2, \"${\", \"}\", \"{\", \n\t\t\t\t\t(regexFound2: string): string =>\n\t\t\t\t\t{\n\t\t\t\t\t\tlet out: string = \"\";\n\n\t\t\t\t\t\tif (parserOptions.outputCommands === true)\n\t\t\t\t\t\t{\n\t\t\t\t\t\t\tlet escapeOutput = (content: string): string =>\n\t\t\t\t\t\t\t\t{\n\t\t\t\t\t\t\t\t\treturn (content.replace(/[`]/g, '\\\\`'));\n\t\t\t\t\t\t\t\t};\n\n\t\t\t\t\t\t\tout = `*&&%*%@#@!try { Hot.echo (${regexFound2}); }catch (ex){Hot.echo (\\`\\\\\\${${escapeOutput (regexFound2)}}\\`);}*&!#%@!@*!`;\n\n\t\t\t\t\t\t\tif (throwAllErrors === true)\n\t\t\t\t\t\t\t\tout = `*&&%*%@#@!Hot.echo (${regexFound2});*&!#%@!@*!`;\n\t\t\t\t\t\t}\n\t\t\t\t\t\telse\n\t\t\t\t\t\t\tout = `*&&%*%@#@!${regexFound2}*&!#%@!@*!`;\n\n\t\t\t\t\t\treturn (out);\n\t\t\t\t\t}, \n\t\t\t\t\t(offContent3: string): string =>\n\t\t\t\t\t{\n\t\t\t\t\t\treturn (offContent3);\n\t\t\t\t\t\t/*let escapedContent: string = JSON.stringify (offContent3);\n\t\t\t\t\t\tlet out: string = `echoOutput (${escapedContent}, ${throwAllErrors});\\n`;\n\n\t\t\t\t\t\treturn (out);*/\n\t\t\t\t\t});\n\n\t\t\t\tlet tempOutput4: string = \"\";\n\n\t\t\t\t// Any ?() will be ignored in production mode.\n\t\t\t\tif (Hot.Mode === DeveloperMode.Production)\n\t\t\t\t{\n\t\t\t\t\ttempOutput4 = HotFile.processNestedContent (\n\t\t\t\t\t\ttempOutput3, \"?(\", \")\", \"(\", \n\t\t\t\t\t\t(regexFound2: string): string =>\n\t\t\t\t\t\t{\n\t\t\t\t\t\t\treturn (\"\");\n\t\t\t\t\t\t}, \n\t\t\t\t\t\t(offContent3: string): string =>\n\t\t\t\t\t\t{\n\t\t\t\t\t\t\treturn (offContent3);\n\t\t\t\t\t\t\t/*let out: string = `echoOutput (${offContent3}, ${throwAllErrors});\\n`;\n\n\t\t\t\t\t\t\treturn (out);*/\n\t\t\t\t\t\t});\n\t\t\t\t}\n\n\t\t\t\tif (Hot.Mode === DeveloperMode.Development)\n\t\t\t\t{\n\t\t\t\t\ttempOutput4 = HotFile.processNestedContent (\n\t\t\t\t\t\ttempOutput3, \"?(\", \")\", \"(\", \n\t\t\t\t\t\t(regexFound2: string): string =>\n\t\t\t\t\t\t{\n\t\t\t\t\t\t\tlet foundStr: string = \"\";\n\n\t\t\t\t\t\t\ttry\n\t\t\t\t\t\t\t{\n\t\t\t\t\t\t\t\t// Check to see if it be parsed. If so, stringify it.\n\t\t\t\t\t\t\t\tJSON.parse (regexFound2);\n\n\t\t\t\t\t\t\t\tif (parserOptions.allowStringify === true)\n\t\t\t\t\t\t\t\t\tfoundStr = JSON.stringify (regexFound2);\n\t\t\t\t\t\t\t\telse\n\t\t\t\t\t\t\t\t\tfoundStr = `${regexFound2}`;\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\tcatch (ex)\n\t\t\t\t\t\t\t{\n\t\t\t\t\t\t\t\t// If valid JSON is not received, don't worry about it, pass it \n\t\t\t\t\t\t\t\t// along to the function below for it to be parsed in the page.\n\t\t\t\t\t\t\t\t// The exception should be thrown there instead.\n\t\t\t\t\t\t\t\tfoundStr = `${regexFound2}`;\n\t\t\t\t\t\t\t}\n\n\t\t\t\t\t\t\t/// @fixme Make this a callable function and pass foundStr, etc.\n\t\t\t\t\t\t\tlet out: string = \"\";\n\n\t\t\t\t\t\t\tif (parserOptions.outputCommands === true)\n\t\t\t\t\t\t\t{\n\t\t\t\t\t\t\t\tout = `*&&%*%@#@!{\nconst testElm = createTestElement (${foundStr});\nHot.echo (\\`data-test-object-name = \"\\${testElm.name}\" data-test-object-func = \"\\${testElm.func}\" data-test-object-value = \"\\${testElm.value}\"\\`);\n}*&!#%@!@*!\\n`;\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\telse\n\t\t\t\t\t\t\t{\n\t\t\t\t\t\t\t\tlet createTestElement = (foundStr2: any) =>\n\t\t\t\t\t\t\t\t{\n\t\t\t\t\t\t\t\t\tlet testElm = null;\n\n\t\t\t\t\t\t\t\t\ttry\n\t\t\t\t\t\t\t\t\t{\n\t\t\t\t\t\t\t\t\t\tlet obj = foundStr2;\n\n\t\t\t\t\t\t\t\t\t\tif (typeof (foundStr2) === \"string\")\n\t\t\t\t\t\t\t\t\t\t\tobj = JSON.parse (foundStr2);\n\n\t\t\t\t\t\t\t\t\t\tif (typeof (obj) === \"string\")\n\t\t\t\t\t\t\t\t\t\t\ttestElm = new Hot.HotTestElement (obj);\n\n\t\t\t\t\t\t\t\t\t\tif (obj instanceof Array)\n\t\t\t\t\t\t\t\t\t\t\ttestElm = new Hot.HotTestElement (obj[0], obj[1], obj[2]);\n\n\t\t\t\t\t\t\t\t\t\tif (obj[\"name\"] != null)\n\t\t\t\t\t\t\t\t\t\t\ttestElm = new Hot.HotTestElement (obj);\n\n\t\t\t\t\t\t\t\t\t\tif (Hot.CurrentPage.testElements[testElm.name] != null)\n\t\t\t\t\t\t\t\t\t\t\tthrow new Error (`Test element ${testElm.name} already exists!`);\n\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t\tcatch (ex)\n\t\t\t\t\t\t\t\t\t{\n\t\t\t\t\t\t\t\t\t\tthrow new Error (\n\t\t\t\t\t\t\t\t`Error processing test element ${foundStr2} in ${Hot.CurrentPage.name}. Error: ${ex.message}`\n\t\t\t\t\t\t\t\t\t\t\t);\n\t\t\t\t\t\t\t\t\t}\n\n\t\t\t\t\t\t\t\t\treturn (testElm);\n\t\t\t\t\t\t\t\t}\n\n\t\t\t\t\t\t\t\tconst testElm = createTestElement (foundStr);\n\t\t\t\t\t\t\t\tout = `*&&%*%@#@!data-test-object-name = \"${testElm.name}\" data-test-object-func = \"${testElm.func}\" data-test-object-value = \"${testElm.value}\"*&!#%@!@*!`;\n\t\t\t\t\t\t\t}\n\n\t\t\t\t\t\t\treturn (out);\n\t\t\t\t\t\t}, \n\t\t\t\t\t\t(offContent3: string): string =>\n\t\t\t\t\t\t{\n\t\t\t\t\t\t\treturn (offContent3);\n\t\t\t\t\t\t\t/*let out: string = `echoOutput (${offContent3}, ${throwAllErrors});\\n`;\n\n\t\t\t\t\t\t\treturn (out);*/\n\t\t\t\t\t\t});\n\t\t\t\t}\n\n\t\t\t\tlet tempOutput5: string = HotFile.processNestedContent (\n\t\t\t\t\ttempOutput4, \"*&&%*%@#@!\", \"*&!#%@!@*!\", \"*&&%*%@#@!\", \n\t\t\t\t\t(regexFound: string): string =>\n\t\t\t\t\t{\n\t\t\t\t\t\treturn (regexFound);\n\t\t\t\t\t}, \n\t\t\t\t\t(offContent: string): string =>\n\t\t\t\t\t{\n\t\t\t\t\t\tlet escapedContent: string = \"\";\n\n\t\t\t\t\t\tif (parserOptions.allowStringify === true)\n\t\t\t\t\t\t\tescapedContent = JSON.stringify (offContent);\n\t\t\t\t\t\telse\n\t\t\t\t\t\t\tescapedContent = offContent;\n\n\t\t\t\t\t\tlet out: string = \"\";\n\t\t\t\t\t\t\n\t\t\t\t\t\tif (parserOptions.outputCommands === true)\n\t\t\t\t\t\t\tout = `echoOutput (${escapedContent}, ${throwAllErrors});\\n`;\n\t\t\t\t\t\telse\n\t\t\t\t\t\t\tout = escapedContent;\n\n\t\t\t\t\t\treturn (out);\n\t\t\t\t\t}, \n\t\t\t\t\t\"*&&%*%@#@!\".length, \"*&!#%@!@*!\".length);\n\n\t\t\t\t/// @fixme Temporary hack. These delimiters should be removed from tempOutput when \n\t\t\t\t/// executing processNestedContent.\n\t\t\t\ttempOutput5 = tempOutput5.replace (/\\*\\&\\&\\%\\*\\%\\@\\#\\@\\!/g, \"\");\n\t\t\t\ttempOutput5 = tempOutput5.replace (/\\*\\&\\!\\#\\%\\@\\!\\@\\*\\!/g, \"\");\n\n\t\t\t\treturn (tempOutput5);\n\t\t\t}, 0);\n\n\t\treturn (output);\n\t}\n\n\t/**\n\t * Process the content in this file. This treats each file as one large JavaScript\n\t * file. Any text outside of the <* *> areas will be treated as:\n\t * \n\t * \t\tHot.echo (\"text\");\n\t * \n\t * @fixme The regex's in the offContent functions need to be fixed. There's several \n\t * test cases where they will fail.\n\t */\n\tasync process (args: any = null): Promise<string>\n\t{\n\t\tlet thisContent: string = this.content;\n\n\t\tif (args != null)\n\t\t{\n\t\t\tif (args instanceof Array)\n\t\t\t\tthrow new Error (`In ${this.name}, the passed arguments received cannot be an array!`);\n\t\t}\n\n\t\tHot.Mode = this.page.processor.mode;\n\t\tHot.Arguments = args;\n\t\tHot.CurrentPage = this.page;\n\t\tHot.PublicKeys = this.page.processor.publicKeys;\n\t\tHot.API = this.page.getAPI ();\n\t\tHot.TesterAPI = this.page.getTesterAPI ();\n\n\t\tlet output: string = HotFile.parseContent (thisContent, this.throwAllErrors);\n\n\t\t// Execute the assembled JS file.\n\t\tlet returnedOutput: any = null;\n\n\t\ttry\n\t\t{\n\t\t\tlet executionContent: string = `\n\t\t\tvar Hot = arguments[0];\n\t\t\tvar PassedHotFile = arguments[1];\n\n\t\t\t`;\n\n\t\t\t// Output the arguments so it's usable in the entire document.\n\t\t\tif (typeof (args) === \"string\")\n\t\t\t\tthrow new Error (`The passing arguments cannot be a string!`);\n\n\t\t\tfor (let key in args)\n\t\t\t{\n\t\t\t\tlet newVar: string = \"\";\n\t\t\t\tlet newVarValue: any = args[key];\n\t\t\t\tlet newVarValueStr: string = JSON.stringify (newVarValue);\n\n\t\t\t\tnewVar = `var ${key} = ${newVarValueStr};\\n`;\n\n\t\t\t\texecutionContent += newVar;\n\t\t\t}\n\n\t\t\tlet contentName: string = this.name;\n\n\t\t\tif (contentName === \"\")\n\t\t\t\tcontentName = this.localFile;\n\n\t\t\tif (contentName === \"\")\n\t\t\t\tcontentName = this.url;\n\n\t\t\texecutionContent += `\n\t\t\tfunction echoOutput (content, throwErrors)\n\t\t\t{\n\t\t\t\tif (throwErrors == null)\n\t\t\t\t\tthrowErrors = true;\n\n\t\t\t\tif (throwErrors === true)\n\t\t\t\t{\n\t\t\t\t\tHot.echo (content);\n\n\t\t\t\t\treturn;\n\t\t\t\t}\n\n\t\t\t\ttry\n\t\t\t\t{\n\t\t\t\t\tHot.echo (content);\n\t\t\t\t}\n\t\t\t\tcatch (ex)\n\t\t\t\t{\n\t\t\t\t\tHot.echo (\"\");\n\t\t\t\t}\n\t\t\t}\n\n\t\t\tfunction createTestElement (foundStr)\n\t\t\t{\n\t\t\t\tlet testElm = null;\n\n\t\t\t\ttry\n\t\t\t\t{\n\t\t\t\t\tlet obj = foundStr;\n\n\t\t\t\t\tif (typeof (foundStr) === \"string\")\n\t\t\t\t\t\tobj = JSON.parse (foundStr);\n\n\t\t\t\t\tif (typeof (obj) === \"string\")\n\t\t\t\t\t\ttestElm = new Hot.HotTestElement (obj);\n\n\t\t\t\t\tif (obj instanceof Array)\n\t\t\t\t\t\ttestElm = new Hot.HotTestElement (obj[0], obj[1], obj[2]);\n\n\t\t\t\t\tif (obj[\"name\"] != null)\n\t\t\t\t\t\ttestElm = new Hot.HotTestElement (obj);\n\n\t\t\t\t\tif (Hot.CurrentPage.testElements[testElm.name] != null)\n\t\t\t\t\t\tthrow new Error (\\`Test element \\${testElm.name} already exists!\\`);\n\n\t\t\t\t\tHot.CurrentPage.addTestElement (testElm);\n\t\t\t\t}\n\t\t\t\tcatch (ex)\n\t\t\t\t{\n\t\t\t\t\tthrow new Error (\n\t\t\t\\`Error processing test element \\${foundStr} in \\${Hot.CurrentPage.name}. Error: \\${ex.message}\\`\n\t\t\t\t\t\t);\n\t\t\t\t}\n\n\t\t\t\treturn (testElm);\n\t\t\t}\n\n\t\t\tasync function runContent (CurrentHotFile)\n\t\t\t{\\n`;\n\t\t\texecutionContent += output;\n\t\t\texecutionContent += `\n\t\t\t}\n\n\t\t\treturn (runContent (PassedHotFile).then (() =>\n\t\t\t{\n\t\t\t\treturn ({\n\t\t\t\t\t\thot: Hot,\n\t\t\t\t\t\toutput: Hot.Output,\n\t\t\t\t\t\tdata: JSON.stringify (Hot.Data)\n\t\t\t\t\t});\n\t\t\t}));`;\n\n\t\t\t/// @fixme Prior to execution compile any TypeScript and make it ES5 compatible.\n\t\t\tlet func: Function = new Function (executionContent);\n\t\t\treturnedOutput = await func.apply (this, [Hot, this]);\n\t\t}\n\t\tcatch (ex)\n\t\t{\n\t\t\tif (ex instanceof SyntaxError)\n\t\t\t{\n\t\t\t\t/// @fixme Put what's in the content variable into a prev content variable?\n\t\t\t\t/// Then once there's no longer any syntax errors being thrown, execute the \n\t\t\t\t/// code? This would also require saving any HTML outside of the *> and <* \n\t\t\t\t/// then echoing it out. The throw below would have to be removed as well.\n\t\t\t\tthrow ex;\n\t\t\t}\n\t\t\telse\n\t\t\t\tthrow ex;\n\t\t}\n\n\t\tHot.Data = returnedOutput.hot.Data;\n\t\tlet finalOutput: string = returnedOutput.output;\n\t\tHot.Output = \"\";\n\n\t\treturn (finalOutput);\n\t}\n}","/**\n * The logging level.\n */\nexport enum HotLogLevel\n{\n\t/**\n\t * Prints only info messages.\n\t */\n\tInfo,\n\t/**\n\t * Prints only warning messages.\n\t */\n\tWarning,\n\t/**\n\t * Prints only error messages.\n\t */\n\tError,\n\t/**\n\t * Prints all messages.\n\t */\n\tVerbose,\n\t/**\n\t * Prints all messages, except verbose.\n\t */\n\tAll,\n\t/**\n\t * Doesn't print any message.\n\t */\n\tNone\n}\n\n/**\n * The logger.\n */\nexport class HotLog\n{\n\t/**\n\t * The logging level.\n\t */\n\tlogLevel: HotLogLevel;\n\n\tconstructor (logLevel: HotLogLevel = HotLogLevel.All)\n\t{\n\t\tthis.logLevel = logLevel;\n\t}\n\n\t/**\n\t * Parse the logging level.\n\t */\n\tstatic parse (logLevel: string): HotLogLevel\n\t{\n\t\tlet level: HotLogLevel = HotLogLevel.All;\n\n\t\tif (logLevel === \"info\")\n\t\t\tlevel = HotLogLevel.Info;\n\n\t\tif (logLevel === \"warning\")\n\t\t\tlevel = HotLogLevel.Warning;\n\n\t\tif (logLevel === \"error\")\n\t\t\tlevel = HotLogLevel.Error;\n\n\t\tif (logLevel === \"verbose\")\n\t\t\tlevel = HotLogLevel.Verbose;\n\n\t\tif (logLevel === \"all\")\n\t\t\tlevel = HotLogLevel.All;\n\n\t\tif (logLevel === \"none\")\n\t\t\tlevel = HotLogLevel.None;\n\n\t\treturn (level);\n\t}\n\n\t/**\n\t * Log a message.\n\t */\n\tlog (level: HotLogLevel, message: string)\n\t{\n\t\tif (this.logLevel === HotLogLevel.Verbose)\n\t\t{\n\t\t\tif (level === HotLogLevel.Error)\n\t\t\t\tthis.error (message);\n\n\t\t\tif (level === HotLogLevel.Warning)\n\t\t\t\tthis.warning (message);\n\n\t\t\tif ((level === HotLogLevel.Info) || \n\t\t\t\t(level === HotLogLevel.Verbose))\n\t\t\t{\n\t\t\t\tthis.info (message);\n\t\t\t}\n\t\t}\n\n\t\tif (this.logLevel === HotLogLevel.All)\n\t\t{\n\t\t\tif (level === HotLogLevel.Error)\n\t\t\t\tthis.error (message);\n\n\t\t\tif (level === HotLogLevel.Warning)\n\t\t\t\tthis.warning (message);\n\n\t\t\tif (level === HotLogLevel.Info)\n\t\t\t\tthis.info (message);\n\t\t}\n\n\t\tif (this.logLevel === HotLogLevel.Error)\n\t\t{\n\t\t\tif (level === HotLogLevel.Error)\n\t\t\t\tthis.error (message);\n\t\t}\n\n\t\tif (this.logLevel === HotLogLevel.Warning)\n\t\t{\n\t\t\tif (level === HotLogLevel.Warning)\n\t\t\t\tthis.warning (message);\n\t\t}\n\n\t\tif (this.logLevel === HotLogLevel.Info)\n\t\t{\n\t\t\tif (level === HotLogLevel.Info)\n\t\t\t\tthis.info (message);\n\t\t}\n\t}\n\n\t/**\n\t * Log a verbose message.\n\t */\n\tverbose (message: string | Function)\n\t{\n\t\tif (this.logLevel === HotLogLevel.Verbose)\n\t\t{\n\t\t\tif (typeof (message) === \"string\")\n\t\t\t\tconsole.info (message);\n\t\t\telse\n\t\t\t\tconsole.info (message ());\n\t\t}\n\t}\n\n\t/**\n\t * Log a message.\n\t */\n\tinfo (message: string)\n\t{\n\t\tif ((this.logLevel === HotLogLevel.All) || \n\t\t\t(this.logLevel === HotLogLevel.Verbose) || \n\t\t\t(this.logLevel === HotLogLevel.Info))\n\t\t{\n\t\t\tconsole.info (message);\n\t\t}\n\t}\n\n\t/**\n\t * Log a warning.\n\t */\n\twarning (message: string)\n\t{\n\t\tif ((this.logLevel === HotLogLevel.All) || \n\t\t\t(this.logLevel === HotLogLevel.Verbose) || \n\t\t\t(this.logLevel === HotLogLevel.Warning))\n\t\t{\n\t\t\tconsole.warn (message);\n\t\t}\n\t}\n\n\t/**\n\t * Log an error message.\n\t */\n\terror (message: string | Error)\n\t{\n\t\tif ((this.logLevel === HotLogLevel.All) || \n\t\t\t(this.logLevel === HotLogLevel.Verbose) || \n\t\t\t(this.logLevel === HotLogLevel.Error))\n\t\t{\n\t\t\tlet msg: string = \"\";\n\n\t\t\tif (typeof (message) === \"string\")\n\t\t\t\tmsg = message;\n\t\t\telse\n\t\t\t{\n\t\t\t\tif (message.message != null)\n\t\t\t\t\tmsg = message.message;\n\n\t\t\t\tif (message.stack != null)\n\t\t\t\t\tmsg = message.stack;\n\t\t\t}\n\n\t\t\tconsole.error (msg);\n\t\t}\n\t}\n}","import { Hot } from \"./Hot\";\nimport { HotAPI } from \"./HotAPI\";\nimport { HotAsset } from \"./HotAsset\";\nimport { HotComponent, IHotComponent } from \"./HotComponent\";\nimport { HotStaq } from \"./HotStaq\";\n\n/**\n * Load a module that contains the assets to load for the frontend.\n */\nexport class HotModule\n{\n\t/**\n\t * The name of the module.\n\t */\n\tname: string;\n\t/**\n\t * The list of NPM modules to import.\n\t */\n\timport?: string[];\n\t/**\n\t * The HTML files to load.\n\t */\n\thtml?: (string | HotAsset)[];\n\t/**\n\t * The CSS files to load.\n\t */\n\tcss?: (string | HotAsset)[];\n\t/**\n\t * The JS files to load.\n\t */\n\tjs?: (string | HotAsset)[];\n\t/**\n\t * The exported component library that contains all the components to load.\n\t */\n\tcomponentLibrary?: string;\n\t/**\n\t * The components to load.\n\t */\n\tcomponents?: (new (copy: IHotComponent | HotStaq, api?: HotAPI) => HotComponent)[];\n\n\tconstructor (name: string)\n\t{\n\t\tthis.name = name;\n\t\tthis.import = [];\n\t\tthis.html = [];\n\t\tthis.css = [];\n\t\tthis.js = [];\n\t\tthis.componentLibrary = \"\";\n\t\tthis.components = [];\n\t}\n\n\t/**\n\t * Output CSS.\n\t */\n\toutputCSS (echoOut: boolean = true): string\n\t{\n\t\tif (this.css == null)\n\t\t\treturn;\n\n\t\tlet output: string = \"\";\n\n\t\tthis.outputAsset (\"css\", this.css, (asset: HotAsset) =>\n\t\t\t{\n\t\t\t\tconst content: string | any = asset.output ();\n\t\t\t\toutput += `${content}\\n`;\n\t\t\t});\n\n\t\tif (echoOut === true)\n\t\t\tHot.echo (output);\n\n\t\treturn (output);\n\t}\n\n\t/**\n\t * Output JS.\n\t */\n\toutputJS (echoOut: boolean = true): string\n\t{\n\t\tif (this.js == null)\n\t\t\treturn;\n\n\t\tlet output: string = \"\";\n\n\t\tthis.outputAsset (\"js\", this.js, (asset: HotAsset) =>\n\t\t\t{\n\t\t\t\tconst content: string | any = asset.output ();\n\t\t\t\toutput += `${content}\\n`;\n\t\t\t});\n\n\t\tif (echoOut === true)\n\t\t\tHot.echo (output);\n\n\t\treturn (output);\n\t}\n\n\t/**\n\t * Output a loaded HTML asset.\n\t */\n\tasync output (assetName: string, args: any[] = null): Promise<void>\n\t{\n\t\tawait Hot.include (`${this.name}/${assetName}.hott`, args);\n\t}\n\n\t/**\n\t * Load HTML assets.\n\t */\n\tasync loadHTML (): Promise<void>\n\t{\n\t\tif (this.html == null)\n\t\t\treturn;\n\n\t\tlet files: any = {};\n\n\t\tthis.outputAsset (\"html\", this.html, (asset: HotAsset) =>\n\t\t\t{\n\t\t\t\tconst file = asset.output ();\n\n\t\t\t\tif (typeof (file) === \"string\")\n\t\t\t\t\tthrow new Error (`HTML assets cannot be outputted using only a string!`);\n\n\t\t\t\tfiles[file.name] = file;\n\t\t\t});\n\n\t\tawait Hot.CurrentPage.processor.loadHotFiles (files);\n\t}\n\n\t/**\n\t * Output components assets.\n\t */\n\toutputComponents (echoOut: boolean = true): string\n\t{\n\t\tif (this.components == null)\n\t\t\treturn (\"\");\n\n\t\tif (this.components.length < 1)\n\t\t\treturn (\"\");\n\n\t\tlet output: string = `<script type = \"text/javascript\">`;\n\t\tlet componentLibrary: string = \"\";\n\n\t\tif (this.componentLibrary != null)\n\t\t{\n\t\t\tif (this.componentLibrary !== \"\")\n\t\t\t\tcomponentLibrary = `${this.componentLibrary}.`;\n\t\t}\n\n\t\tfor (let iIdx = 0; iIdx < this.components.length; iIdx++)\n\t\t{\n\t\t\tlet component = this.components[iIdx];\n\n\t\t\toutput += `Hot.CurrentPage.processor.addComponent (${componentLibrary}${component});\\n`;\n\t\t}\n\n\t\toutput += `</script>`;\n\n\t\tif (echoOut === true)\n\t\t\tHot.echo (output);\n\n\t\treturn (output);\n\t}\n\n\t/**\n\t * Output an asset to HTML.\n\t */\n\tprotected outputAsset (assetType: string, assets: (string | HotAsset)[] = [], \n\t\tcallback: (asset: HotAsset) => void): void\n\t{\n\t\tfor (let iIdx = 0; iIdx < assets.length; iIdx++)\n\t\t{\n\t\t\tlet asset: string | HotAsset = assets[iIdx];\n\t\t\tlet loadAsset: HotAsset = null;\n\t\t\tloadAsset = new HotAsset (assetType);\n\n\t\t\tif (typeof (asset) === \"string\")\n\t\t\t\tloadAsset.path = asset;\n\t\t\telse\n\t\t\t{\n\t\t\t\tif (asset.name != null)\n\t\t\t\t\tloadAsset.name = asset.name;\n\n\t\t\t\tif (asset.path != null)\n\t\t\t\t\tloadAsset.path = asset.path;\n\n\t\t\t\tif (asset.content != null)\n\t\t\t\t\tloadAsset.content = asset.content;\n\t\t\t}\n\n\t\t\tcallback (loadAsset);\n\t\t}\n\t}\n}","import { Hot } from \"./Hot\";\nimport { HotFile } from \"./HotFile\";\nimport { HotStaq } from \"./HotStaq\";\nimport { HotAPI } from \"./HotAPI\";\nimport { HotTestElement } from \"./HotTestElement\";\nimport { HotTestMap, HotTestPath } from \"./HotTestMap\";\nimport { HotComponent } from \"./HotComponent\";\n\n/**\n * A page to preprocess.\n */\nexport interface IHotPage\n{\n\t/**\n\t * The processor to use.\n\t */\n\tprocessor: HotStaq;\n\t/**\n\t * The name of the page.\n\t */\n\tname?: string;\n\t/**\n\t * The route used to get to this page.\n\t */\n\troute?: string;\n\t/**\n\t * The components added to this page.\n\t */\n\tcomponents?: { [name: string]: HotComponent };\n\t/**\n\t * The name of the page. File ordering matters here.\n\t * Every file is processed incrementally.\n\t */\n\tfiles?: HotFile[];\n\t/**\n\t * The associated tester name.\n\t */\n\ttesterName?: string;\n\t/**\n\t * The associated tester map.\n\t */\n\ttesterMap?: string;\n\t/**\n\t * The elements to test on this page.\n\t */\n\ttestElements?: { [name: string]: HotTestElement; };\n\t/**\n\t * The test paths to test on this page.\n\t */\n\ttestPaths?: { [name: string]: HotTestPath; };\n}\n\n/**\n * A page to preprocess.\n */\nexport class HotPage implements IHotPage\n{\n\t/**\n\t * The processor to use.\n\t */\n\tprocessor: HotStaq;\n\t/**\n\t * The name of the page.\n\t */\n\tname: string;\n\t/**\n\t * The route used to get to this page.\n\t */\n\troute: string;\n\t/**\n\t * The components added to this page.\n\t */\n\tcomponents: { [name: string]: HotComponent };\n\t/**\n\t * The name of the page. File ordering matters here.\n\t * Every file is processed incrementally.\n\t */\n\tfiles: HotFile[];\n\t/**\n\t * The associated tester name.\n\t */\n\ttesterName: string;\n\t/**\n\t * The associated tester map.\n\t */\n\ttesterMap: string;\n\t/**\n\t * The elements to test on this page.\n\t */\n\ttestElements: { [name: string]: HotTestElement; };\n\t/**\n\t * The test paths to test on this page.\n\t */\n\ttestPaths: { [name: string]: HotTestPath; };\n\n\tconstructor (copy: IHotPage | HotStaq)\n\t{\n\t\tif (copy instanceof HotStaq)\n\t\t{\n\t\t\tthis.processor = copy;\n\t\t\tthis.name = \"\";\n\t\t\tthis.testerName = \"HotTesterMochaSelenium\";\n\t\t\tthis.testerMap = \"\";\n\t\t\tthis.route = \"\";\n\t\t\tthis.components = {};\n\t\t\tthis.files = [];\n\t\t\tthis.testElements = {};\n\t\t\tthis.testPaths = {};\n\t\t}\n\t\telse\n\t\t{\n\t\t\tthis.processor = copy.processor;\n\t\t\tthis.name = copy.name || \"\";\n\t\t\tthis.testerName = copy.testerName || \"HotTesterMochaSelenium\";\n\t\t\tthis.testerMap = copy.testerMap || \"\";\n\t\t\tthis.route = copy.route || \"\";\n\t\t\tthis.components = copy.components || {};\n\t\t\tthis.files = copy.files || [];\n\t\t\tthis.testElements = copy.testElements || {};\n\t\t\tthis.testPaths = copy.testPaths || {};\n\t\t}\n\t}\n\n\t/**\n\t * Add a file to process. It's recommend to load the file prior to \n\t * adding it to a page if it's about to be used.\n\t */\n\tasync addFile (file: HotFile): Promise<void>\n\t{\n\t\tfile.page = this;\n\n\t\tthis.files.push (file);\n\t}\n\n\t/**\n\t * Get the API associated with this page.\n\t */\n\tgetAPI (): HotAPI\n\t{\n\t\treturn (this.processor.api);\n\t}\n\n\t/**\n\t * Get the tester API associated with this page.\n\t */\n\tgetTesterAPI (): HotAPI\n\t{\n\t\treturn (this.processor.testerAPI);\n\t}\n\n\t/**\n\t * Add all files in the page. Could decrease page loading performance.\n\t * It's recommend to load the file prior to adding it to a page.\n\t */\n\tasync load (file: HotFile): Promise<void>\n\t{\n\t\tfor (let iIdx = 0; iIdx < this.files.length; iIdx++)\n\t\t{\n\t\t\tlet file: HotFile = this.files[iIdx];\n\n\t\t\tawait file.load ();\n\t\t}\n\t}\n\n\t/**\n\t * Process a page and get the result.\n\t */\n\tasync process (args: any = null): Promise<string>\n\t{\n\t\tlet output: string = \"\";\n\n\t\tfor (let iIdx = 0; iIdx < this.files.length; iIdx++)\n\t\t{\n\t\t\tlet file: HotFile = this.files[iIdx];\n\n\t\t\tHot.Output = \"\";\n\t\t\tfile.page = this;\n\n\t\t\toutput += await file.process (args);\n\t\t}\n\n\t\treturn (output);\n\t}\n\n\t/**\n\t * Add a test element.\n\t */\n\taddTestElement (elm: HotTestElement): void\n\t{\n\t\tif (this.testElements[elm.name] != null)\n\t\t\tthrow new Error (`Test element ${elm.name} already exists!`);\n\n\t\tthis.testElements[elm.name] = elm;\n\t}\n\n\t/**\n\t * Get a test element.\n\t */\n\tgetTestElement (name: string): HotTestElement\n\t{\n\t\tif (this.testElements[name] == null)\n\t\t\tthrow new Error (`Test element ${name} doest not exist!`);\n\n\t\treturn (this.testElements[name]);\n\t}\n\n\t/**\n\t * Create a test path.\n\t */\n\tcreateTestPath (pathName: string, driverFunc: HotTestPath): void\n\t{\n\t\tif (this.testPaths[pathName] != null)\n\t\t\tthrow new Error (`Test path ${pathName} already exists!`);\n\n\t\tthis.testPaths[pathName] = driverFunc;\n\t}\n}","import { HotServer } from \"./HotServer\";\nimport { HotRouteMethod, HotEventMethod, IHotRouteMethod, \n\tServerExecutionFunction, TestCaseFunction, TestCaseObject, ServerRequest } from \"./HotRouteMethod\";\nimport { HotClient } from \"./HotClient\";\nimport { HotLog } from \"./HotLog\";\n\n/**\n * The route to use.\n */\nexport class HotRoute\n{\n\t/**\n\t * The server that maintains the connections.\n\t */\n\tconnection: HotServer | HotClient;\n\t/**\n\t * The associated logger.\n\t */\n\tlogger: HotLog;\n\t/**\n\t * The route.\n\t */\n\troute: string;\n\t/**\n\t * The description of the route.\n\t */\n\tdescription: string;\n\t/**\n\t * The version.\n\t */\n\tversion: string;\n\t/**\n\t * The prefix to add to the beginning of each route method.\n\t */\n\tprefix: string;\n\t/**\n\t * The authorization credentials to be used by the client \n\t * when connecting to the server.\n\t */\n\tauthCredentials: any;\n\t/**\n\t * The calls that can be made.\n\t */\n\tmethods: HotRouteMethod[];\n\t/**\n\t * The errors and their JSON that can be thrown. Can be:\n\t * * not_authorized\n\t * * no_server_execute_function\n\t */\n\terrors: { [error: string]: any };\n\n\tconstructor (connection: HotServer | HotClient, route: string, methods: HotRouteMethod[] = [])\n\t{\n\t\tthis.connection = connection;\n\t\tthis.logger = null;\n\n\t\tif (this.connection != null)\n\t\t{\n\t\t\tif (this.connection.processor != null)\n\t\t\t\tthis.logger = this.connection.processor.logger;\n\t\t}\n\n\t\tthis.route = route;\n\t\tthis.description = \"\";\n\t\tthis.version = \"v1\";\n\t\tthis.prefix = \"\";\n\t\tthis.authCredentials = null;\n\t\tthis.methods = methods;\n\t\tthis.errors = {\n\t\t\t\t\"not_authorized\": HotRoute.createError (\"Not authorized.\"),\n\t\t\t\t\"no_server_execute_function\": HotRoute.createError (\"Missing server execute function.\"),\n\t\t\t};\n\t}\n\n\t/**\n\t * Create an error JSON object.\n\t */\n\tstatic createError (message: string): any\n\t{\n\t\treturn ({ error: message });\n\t}\n\n\t/**\n\t * Add an API method to this route.\n\t * \n\t * @param method The name of the method to add. If a HotRouteMethod is supplied, the \n\t * rest of the arguments supplied will be ignored.\n\t */\n\taddMethod (\n\t\tmethod: HotRouteMethod | IHotRouteMethod | string,\n\t\texecuteFunction: ServerExecutionFunction = null,\n\t\ttype: HotEventMethod = HotEventMethod.POST,\n\t\ttestCases: (string | TestCaseFunction)[] | TestCaseFunction[] | TestCaseObject[] = null\n\t\t): void\n\t{\n\t\tif (typeof (method) === \"string\")\n\t\t\tmethod = new HotRouteMethod (this, method, executeFunction, type, null, null, null, testCases);\n\n\t\tif (method instanceof HotRouteMethod)\n\t\t\tthis.methods.push (method);\n\t\telse\n\t\t{\n\t\t\tif (method.route == null)\n\t\t\t\tmethod.route = this;\n\n\t\t\tmethod = new HotRouteMethod (method);\n\t\t\tthis.methods.push ((<HotRouteMethod>method));\n\t\t}\n\t}\n\n\t/**\n\t * Get a method by it's name.\n\t */\n\tgetMethod (name: string): HotRouteMethod\n\t{\n\t\tlet foundMethod: HotRouteMethod = null;\n\n\t\tfor (let iIdx = 0; iIdx < this.methods.length; iIdx++)\n\t\t{\n\t\t\tlet method: HotRouteMethod = this.methods[iIdx];\n\n\t\t\tif (method.name === name)\n\t\t\t{\n\t\t\t\tfoundMethod = method;\n\n\t\t\t\tbreak;\n\t\t\t}\n\t\t}\n\n\t\treturn (foundMethod);\n\t}\n\n\t/**\n\t * Executes before all routes have been registered.\n\t */\n\tonPreRegister: () => Promise<void> = null;\n\t/**\n\t * Executes when first registering this route with Express. If \n\t * this returns false, the route will not be registered.\n\t */\n\tonRegister: () => Promise<boolean> = null;\n\t/**\n\t * Executes after all routes have been registered.\n\t */\n\tonPostRegister: () => Promise<void> = null;\n\n\t/**\n\t * Executes when authorizing a called method.\n\t * The value returned from here will be passed to onExecute in the \n\t * called HotRouteMethod. Undefined returning from here will mean \n\t * the authorization failed.\n\t */\n\tonAuthorizeUser: (req: ServerRequest) => Promise<any> = null;\n}","import { DeveloperMode } from \"./Hot\";\nimport { HotTestDriver } from \"./HotTestDriver\";\nimport { HotRoute } from \"./HotRoute\";\nimport { HotServer } from \"./HotServer\";\n\nimport express from \"express\";\nimport { HotWebSocketClient } from \"./HotWebSocketClient\";\n\n/**\n * The available event methods.\n */\nexport enum HotEventMethod\n{\n\t/**\n\t * A HTTP GET request.\n\t */\n\tGET = \"get\",\n\t/**\n\t * A HTTP POST request.\n\t */\n\tPOST = \"post\",\n\t/**\n\t * This will upload a file, then post the json request afterwards.\n\t */\n\tFILE_UPLOAD = \"file_upload_then_post_json\",\n\t/**\n\t * A websocket event.\n\t */\n\tWEBSOCKET_CLIENT_PUB_EVENT = \"websocket_client_pub_event\"\n}\n\n/**\n * The request that came from a client.\n */\nexport interface IServerRequest\n{\n\t/**\n\t * The express request received from the client. Will be set to null if using worker \n\t * threads or if this request was received from a websocket connection.\n\t */\n\treq?: express.Request;\n\t/**\n\t * The express response to send to the client. Will be set to null if using worker \n\t * threads or if this request was received from a websocket connection.\n\t */\n\tres?: express.Response;\n\t/**\n\t * The client websocket that was used to send the message. Will be set to null if using worker \n\t * threads or if this request was received from a HTTP connection.\n\t */\n\twsSocket?: HotWebSocketClient;\n\t/**\n\t * The response received from authorizing a client. Can be a JWT token, api key, etc.\n\t * Will be null if this request was received from a websocket connection.\n\t */\n\tauthorizedValue?: any;\n\t/**\n\t * The JSON received from the client.\n\t */\n\tjsonObj?: any;\n\t/**\n\t * Any query variables received from the client. Will be null if this request was \n\t * received from a websocket connection.\n\t */\n\tqueryObj?: any;\n\t/**\n\t * Any files received from the client. Will be null if no files were sent.\n\t * Once a file is uploaded, you can access it at the temporary path found in: \n\t * files[uploadId].path\n\t */\n\tfiles?: {\n\t\t[key: string]: {\n\t\t\tname: string;\n\t\t\tsize: number;\n\t\t\tpath: string;\n\t\t}\n\t};\n}\n\n/**\n * The request that came from a client.\n */\nexport class ServerRequest implements IServerRequest\n{\n\t/**\n\t * The express request received from the client. Will be set to null if using worker \n\t * threads or if this request was received from a websocket connection.\n\t */\n\treq: express.Request;\n\t/**\n\t * The express response to send to the client. Will be set to null if using worker \n\t * threads or if this request was received from a websocket connection.\n\t */\n\tres: express.Response;\n\t/**\n\t * The client websocket that was used to send the message. Will be set to null if using worker \n\t * threads or if this request was received from a HTTP connection.\n\t */\n\twsSocket: HotWebSocketClient;\n\t/**\n\t * The response received from authorizing a client. Can be a JWT token, api key, etc.\n\t * Will be null if this request was received from a websocket connection.\n\t */\n\tauthorizedValue: any;\n\t/**\n\t * The JSON received from the client.\n\t */\n\tjsonObj: any;\n\t/**\n\t * Any query variables received from the client. Will be null if this request was \n\t * received from a websocket connection.\n\t */\n\tqueryObj: any;\n\t/**\n\t * Any files received from the client. Will be null if no files were sent.\n\t * Once a file is uploaded, you can access it at the temporary path found in: \n\t * files[uploadId].path\n\t */\n\tfiles: {\n\t\t[key: string]: {\n\t\t\tname: string;\n\t\t\tsize: number;\n\t\t\tpath: string;\n\t\t}\n\t};\n\n\tconstructor (obj: IServerRequest = null)\n\t{\n\t\tif (obj == null)\n\t\t\tobj = {};\n\n\t\tthis.req = obj.req || null;\n\t\tthis.res = obj.res || null;\n\t\tthis.wsSocket = obj.wsSocket || null;\n\t\tthis.authorizedValue = obj.authorizedValue || null;\n\t\tthis.jsonObj = obj.jsonObj || null;\n\t\tthis.queryObj = obj.queryObj || null;\n\t\tthis.files = obj.files || null;\n\t}\n}\n\n/**\n * A function that will be executed by the server when first registering with Express.\n * If this returns false, this route method will not be registered.\n */\nexport type ServerRegistrationFunction = () => Promise<boolean>;\n/**\n * A function that will be executed by the server.\n */\nexport type ServerExecutionFunction = (request: ServerRequest) => Promise<any>;\n/**\n * A function that will be executed by the client.\n */\nexport type ClientExecutionFunction = (...args: any[]) => Promise<any>;\n/**\n * A function that will be executed by the server for authorization. Any value \n * returned from this function will be passed to the ServerExecutionFunction.\n * If an undefined value is returned, this indicates the server was not able \n * to authenticate the user, so the ServerExecutionFunction will not be \n * executed.\n */\nexport type ServerAuthorizationFunction = (request: ServerRequest) => Promise<any>;\n/**\n * The test case function to execute.\n */\nexport type TestCaseFunction = ((driver: HotTestDriver) => Promise<any>) | ((driver: HotTestDriver) => any);\n/**\n * The test case object to pass.\n */\nexport interface TestCaseObject\n{\n\t/**\n\t * The name of the test case.\n\t */\n\tname: string;\n\t/**\n\t * The function to execute.\n\t */\n\tfunc: TestCaseFunction;\n}\n\n/**\n * A method parameter.\n */\nexport interface HotRouteMethodParameter\n{\n\t/**\n\t * The type of parameter. Default: string\n\t * Can be:\n\t * * string\n\t * * integer\n\t * * number\n\t * * boolean\n\t * * array\n\t * * object\n\t */\n\ttype?: string;\n\t/**\n\t * The description of the parameter. Default: \"\"\n\t */\n\tdescription?: string;\n\t/**\n\t * Is this parameter required? Default: false\n\t */\n\trequired?: boolean;\n\t/**\n\t * The parameters in the object.\n\t */\n\tparameters?: { [name: string]: string | HotRouteMethodParameter; };\n}\n\n/**\n * An API method to make.\n */\nexport interface IHotRouteMethod\n{\n\t/**\n\t * The parent route.\n\t */\n\troute?: HotRoute;\n\t/**\n\t * The api call name.\n\t */\n\tname: string;\n\t/**\n\t * The description of the api method.\n\t */\n\tdescription?: string;\n\t/**\n\t * The description of what returns from the api method.\n\t */\n\treturns?: string | HotRouteMethodParameter;\n\t/**\n\t * The parameters in the api method.\n\t */\n\tparameters?: { [name: string]: string | HotRouteMethodParameter; };\n\t/**\n\t * The api call name.\n\t */\n\ttype?: HotEventMethod;\n\t/**\n\t * The authorization credentials to be used by the client \n\t * when connecting to the server.\n\t */\n\tauthCredentials?: any;\n\t/**\n\t * The test case objects to execute during tests.\n\t */\n\ttestCases?: {\n\t\t\t[name: string]: TestCaseObject;\n\t\t} | (string | TestCaseFunction)[] | TestCaseFunction[] | TestCaseObject[];\n\t/**\n\t * Executes before all routes have been registered.\n\t */\n\tonPreRegister?: () => Promise<void>;\n\t/**\n\t * Executes when first registering this method with Express. If \n\t * this returns false, the method will not be registered.\n\t */\n\tonRegister?: ServerRegistrationFunction;\n\t/**\n\t * Executes after all routes have been registered.\n\t */\n\tonPostRegister?: () => Promise<void>;\n\n\t/**\n\t * Executes when authorizing a called method. If this method \n\t * is set, this will not call onAuthorize for the parent HotRoute.\n\t * The value returned from here will be passed to onExecute. \n\t * Undefined returning from here will mean the authorization failed.\n\t * If any exceptions are thrown from this function, they will be sent \n\t * to the server as an { error: string; } object with the exception \n\t * message as the error.\n\t * \n\t * Currently this has no effect when using websockets.\n\t */\n\tonServerAuthorize?: ServerAuthorizationFunction;\n\n\t/**\n\t * Executes when executing a called method from the server side. \n\t * This will stringify any JSON object and send it as a JSON response. \n\t * If undefined is returned no response will be sent to the server. \n\t * So the developer would have to send a response using \"res\".\n\t * If any exceptions are thrown from this function, they will be sent \n\t * to the server as an { error: string; } object with the exception \n\t * message as the error.\n\t */\n\tonServerExecute?: ServerExecutionFunction;\n\t/**\n\t * Executes when executing a called method from the client side.\n\t * @fixme Is this necessary?\n\t */\n\tonClientExecute?: ClientExecutionFunction;\n}\n\n/**\n * An API method to make.\n */\nexport class HotRouteMethod implements IHotRouteMethod\n{\n\t/**\n\t * The parent route.\n\t */\n\troute: HotRoute;\n\t/**\n\t * The api call name.\n\t */\n\tname: string;\n\t/**\n\t * The description of the api method.\n\t */\n\tdescription: string;\n\t/**\n\t * The description of what returns from the api method.\n\t */\n\treturns: HotRouteMethodParameter;\n\t/**\n\t * The parameters in the api method.\n\t */\n\tparameters: { [name: string]: HotRouteMethodParameter; };\n\t/**\n\t * The api call name.\n\t */\n\ttype: HotEventMethod;\n\t/**\n\t * Has this method been registered with the server? This \n\t * prevents the method from being reregistered.\n\t */\n\tisRegistered: boolean;\n\t/**\n\t * Has this method been registered with the server? This \n\t * prevents the method from being reregistered.\n\t */\n\texecuteSetup: boolean;\n\t/**\n\t * The authorization credentials to be used by the client \n\t * when connecting to the server.\n\t */\n\tauthCredentials: any;\n\t/**\n\t * The test case objects to execute during tests.\n\t */\n\ttestCases: {\n\t\t\t[name: string]: TestCaseObject;\n\t\t};\n\t/**\n\t * Executes before all routes have been registered.\n\t */\n\tonPreRegister?: () => Promise<void>;\n\t/**\n\t * Executes when first registering this method with Express. If \n\t * this returns false, the method will not be registered.\n\t */\n\tonRegister?: ServerRegistrationFunction;\n\t/**\n\t * Executes after all routes have been registered.\n\t */\n\tonPostRegister?: () => Promise<void>;\n\n\t/**\n\t * Executes when authorizing a called method. If this method \n\t * is set, this will not call onAuthorize for the parent HotRoute.\n\t * The value returned from here will be passed to onServerExecute. \n\t * Undefined returning from here will mean the authorization failed.\n\t * If any exceptions are thrown from this function, they will be sent \n\t * to the client as an { error: string; } object with the exception \n\t * message as the error.\n\t */\n\tonServerAuthorize?: ServerAuthorizationFunction;\n\n\t/**\n\t * Executes when executing a called method from the server side. \n\t * This will stringify any JSON object and send it as a JSON response. \n\t * If undefined is returned no response will be sent to the server. \n\t * So the developer would have to send a response using \"res\".\n\t * If any exceptions are thrown from this function, they will be sent \n\t * to the server as an { error: string; } object with the exception \n\t * message as the error.\n\t */\n\tonServerExecute?: ServerExecutionFunction;\n\t/**\n\t * Executes when executing a called method from the client side.\n\t * @fixme Is this necessary?\n\t */\n\tonClientExecute?: ClientExecutionFunction;\n\n\tconstructor (route: HotRoute | IHotRouteMethod, name: string = \"\", \n\t\tonExecute: ServerExecutionFunction | ClientExecutionFunction = null, \n\t\ttype: HotEventMethod = HotEventMethod.POST, onServerAuthorize: ServerAuthorizationFunction = null, \n\t\tonRegister: ServerRegistrationFunction = null, authCredentials: any = null, \n\t\ttestCases: { [name: string]: TestCaseObject; } | (string | TestCaseFunction)[] | TestCaseFunction[] | TestCaseObject[] = null)\n\t{\n\t\tlet newRoute: HotRoute = null;\n\n\t\tif (route instanceof HotRoute)\n\t\t\tnewRoute = route;\n\t\telse\n\t\t{\n\t\t\tnewRoute = route.route;\n\n\t\t\tif (route.type != null)\n\t\t\t\ttype = route.type;\n\n\t\t\tif (route.name != null)\n\t\t\t\tname = route.name;\n\n\t\t\tif (route.description != null)\n\t\t\t\tthis.description = route.description;\n\n\t\t\tif (route.returns != null)\n\t\t\t{\n\t\t\t\tif (typeof (route.returns) === \"string\")\n\t\t\t\t{\n\t\t\t\t\tthis.returns = {\n\t\t\t\t\t\t\t\"type\": \"string\",\n\t\t\t\t\t\t\t\"required\": true,\n\t\t\t\t\t\t\t\"description\": route.returns\n\t\t\t\t\t\t};\n\t\t\t\t}\n\t\t\t\telse\n\t\t\t\t\tthis.returns = route.returns;\n\t\t\t}\n\n\t\t\tif (route.parameters != null)\n\t\t\t{\n\t\t\t\tthis.parameters = {};\n\n\t\t\t\tfor (let key in route.parameters)\n\t\t\t\t{\n\t\t\t\t\tlet param = route.parameters[key];\n\n\t\t\t\t\tif (typeof (param) === \"string\")\n\t\t\t\t\t{\n\t\t\t\t\t\tthis.parameters[key] = {\n\t\t\t\t\t\t\t\t\"type\": param,\n\t\t\t\t\t\t\t\t\"required\": false,\n\t\t\t\t\t\t\t\t\"description\": \"\"\n\t\t\t\t\t\t\t};\n\t\t\t\t\t}\n\t\t\t\t\telse\n\t\t\t\t\t{\n\t\t\t\t\t\tif (param.type == null)\n\t\t\t\t\t\t\tparam.type = \"string\";\n\n\t\t\t\t\t\tthis.parameters[key] = param;\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t}\n\n\t\t\tif (route.authCredentials != null)\n\t\t\t\tauthCredentials = route.authCredentials;\n\n\t\t\tif (route.onServerExecute != null)\n\t\t\t\tonExecute = route.onServerExecute;\n\n\t\t\tif (route.onServerAuthorize != null)\n\t\t\t\tonServerAuthorize = route.onServerAuthorize;\n\n\t\t\tif (route.onRegister != null)\n\t\t\t\tonRegister = route.onRegister;\n\n\t\t\tif (route.onPostRegister != null)\n\t\t\t\tthis.onPostRegister = route.onPostRegister;\n\n\t\t\tif (route.onServerExecute != null)\n\t\t\t\tthis.onServerExecute = route.onServerExecute;\n\n\t\t\tif (route.onClientExecute != null)\n\t\t\t\tthis.onClientExecute = route.onClientExecute;\n\n\t\t\tif (route.testCases != null)\n\t\t\t\ttestCases = route.testCases;\n\t\t}\n\n\t\tif (name === \"\")\n\t\t\tthrow new Error (`All route methods must have a name!`);\n\n\t\tthis.route = newRoute;\n\t\tthis.name = name;\n\t\tthis.type = type;\n\t\tthis.isRegistered = false;\n\t\tthis.executeSetup = false;\n\t\tthis.authCredentials = authCredentials;\n\t\tthis.onServerAuthorize = onServerAuthorize;\n\t\tthis.onRegister = onRegister;\n\t\tthis.testCases = {};\n\n\t\tif (this.route.connection.processor.mode === DeveloperMode.Development)\n\t\t{\n\t\t\tif (testCases != null)\n\t\t\t{\n\t\t\t\tif (testCases instanceof Array)\n\t\t\t\t{\n\t\t\t\t\tfor (let iIdx = 0; iIdx < testCases.length; iIdx++)\n\t\t\t\t\t{\n\t\t\t\t\t\tlet obj = testCases[iIdx];\n\n\t\t\t\t\t\tif (typeof (obj) === \"string\")\n\t\t\t\t\t\t{\n\t\t\t\t\t\t\tconst testCaseName: string = obj;\n\t\t\t\t\t\t\tconst func: TestCaseFunction = (<TestCaseFunction>testCases[iIdx + 1]);\n\n\t\t\t\t\t\t\tthis.addTestCase (testCaseName, func);\n\t\t\t\t\t\t\tiIdx++;\n\t\t\t\t\t\t}\n\t\t\t\t\t\telse\n\t\t\t\t\t\t\tthis.addTestCase (obj);\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t\telse\n\t\t\t\t{\n\t\t\t\t\tfor (let key in testCases)\n\t\t\t\t\t{\n\t\t\t\t\t\tlet obj = testCases[key];\n\n\t\t\t\t\t\tthis.addTestCase (obj);\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\n\t\tif (this.route.connection instanceof HotServer)\n\t\t\tthis.onServerExecute = onExecute;\n\t\t//else\n\t\t\t//this.onClientExecute = onExecute;\n\t}\n\n\t/**\n\t * Add a new test case.\n\t */\n\taddTestCase (newTestCase: TestCaseObject | string | TestCaseFunction, \n\t\t\ttestCaseFunction: TestCaseFunction = null): void\n\t{\n\t\tif (typeof (newTestCase) === \"string\")\n\t\t{\n\t\t\tconst name: string = newTestCase;\n\t\t\tconst func: TestCaseFunction = testCaseFunction;\n\n\t\t\tthis.testCases[name] = {\n\t\t\t\t\tname: name,\n\t\t\t\t\tfunc: func\n\t\t\t\t};\n\n\t\t\treturn;\n\t\t}\n\n\t\tif (typeof (newTestCase) === \"function\")\n\t\t{\n\t\t\tconst testCaseId: number = Object.keys (this.testCases).length;\n\t\t\tconst name: string = `${this.route.route}/${this.name} test case ${testCaseId}`;\n\t\t\tconst func: TestCaseFunction = (<TestCaseFunction>newTestCase);\n\n\t\t\tthis.testCases[name] = {\n\t\t\t\t\tname: name,\n\t\t\t\t\tfunc: func\n\t\t\t\t};\n\n\t\t\treturn;\n\t\t}\n\n\t\tconst testCase: TestCaseObject = (<TestCaseObject>newTestCase);\n\t\tthis.testCases[testCase.name] = testCase;\n\t}\n\n\t/**\n\t * Get the relative url from this method and its route.\n\t */\n\tgetRouteUrl (): string\n\t{\n\t\tif (this.route == null)\n\t\t\tthrow new Error (`Route method ${this.name} does not have a parent route!`);\n\n\t\tlet methodName: string = \"/\";\n\n\t\tif (this.route.version !== \"\")\n\t\t\tmethodName += `${this.route.version}/`;\n\n\t\tif (this.route.prefix !== \"\")\n\t\t\tmethodName += `${this.route.prefix}/`;\n\n\t\tif (this.route.route !== \"\")\n\t\t\tmethodName += `${this.route.route}/`;\n\n\t\tmethodName += this.name;\n\n\t\treturn (methodName);\n\t}\n}","import { HotStaq } from \"./HotStaq\";\nimport { HotLog } from \"./HotLog\";\nimport { HotAPI } from \"./HotAPI\";\nimport { HotRoute } from \"./HotRoute\";\n\n/**\n * The type of server.\n */\nexport enum HotServerType\n{\n\tHTTP,\n\tWebSockets,\n\tGenerate,\n\tWebTesting,\n\tAPITesting\n}\n\n/**\n * The server.\n */\nexport interface IHotServer\n{\n\t/**\n\t * The processor to use.\n\t */\n\tprocessor: HotStaq;\n\t/**\n\t * The server type.\n\t */\n\tserverType: string;\n\t/**\n\t * The API to use.\n\t */\n\tapi: HotAPI;\n\t/**\n\t * The network address to listen on.\n\t */\n\tlistenAddress: string;\n\t/**\n\t * The ports to use.\n\t */\n\tports: {\n\t\t\thttp: number;\n\t\t\thttps: number;\n\t\t};\n\t/**\n\t * SSL settings.\n\t */\n\tssl: {\n\t\t\t/**\n\t\t\t * The SSL certificate to use.\n\t\t\t */\n\t\t\tcert: string;\n\t\t\t/**\n\t\t\t * The SSL certificate key to use.\n\t\t\t */\n\t\t\tkey: string;\n\t\t\t/**\n\t\t\t * The SSL certificate CA to use.\n\t\t\t */\n\t\t\tca: string;\n\t\t};\n\t/**\n\t * Redirect HTTP traffic to HTTPS.\n\t */\n\tredirectHTTPtoHTTPS: boolean;\n\t/**\n\t * The type of server.\n\t */\n\ttype: HotServerType;\n\t/**\n\t * The logger.\n\t */\n\tlogger: HotLog;\n\t/**\n\t * Any secrets associated with this server.\n\t */\n\tsecrets: any;\n}\n\n/**\n * The server.\n */\nexport class HotServer implements IHotServer\n{\n\t/**\n\t * The processor to use.\n\t */\n\tprocessor: HotStaq;\n\t/**\n\t * The server type.\n\t */\n\tserverType: string;\n\t/**\n\t * The API to use.\n\t */\n\tapi: HotAPI;\n\t/**\n\t * The network address to listen on.\n\t */\n\tlistenAddress: string;\n\t/**\n\t * The ports to use.\n\t */\n\tports: {\n\t\t\thttp: number;\n\t\t\thttps: number;\n\t\t};\n\t/**\n\t * SSL settings.\n\t */\n\tssl: {\n\t\t\t/**\n\t\t\t * The SSL certificate to use.\n\t\t\t */\n\t\t\tcert: string;\n\t\t\t/**\n\t\t\t * The SSL certificate key to use.\n\t\t\t */\n\t\t\tkey: string;\n\t\t\t/**\n\t\t\t * The SSL certificate CA to use.\n\t\t\t */\n\t\t\tca: string;\n\t\t};\n\t/**\n\t * Redirect HTTP traffic to HTTPS.\n\t */\n\tredirectHTTPtoHTTPS: boolean;\n\t/**\n\t * The type of server.\n\t */\n\ttype: HotServerType;\n\t/**\n\t * The logger.\n\t */\n\tlogger: HotLog;\n\t/**\n\t * Any secrets associated with this server.\n\t */\n\tsecrets: any;\n\n\tconstructor (processor: HotStaq | HotServer)\n\t{\n\t\tif (processor instanceof HotStaq)\n\t\t{\n\t\t\tthis.processor = processor;\n\t\t\tthis.serverType = \"Server\";\n\t\t\tthis.api = null;\n\t\t\tthis.listenAddress = \"0.0.0.0\";\n\t\t\tthis.ports = {\n\t\t\t\t\thttp: 5000,\n\t\t\t\t\thttps: 443\n\t\t\t\t};\n\t\t\tthis.ssl = {\n\t\t\t\t\tcert: \"\",\n\t\t\t\t\tkey: \"\",\n\t\t\t\t\tca: \"\"\n\t\t\t\t};\n\t\t\tthis.redirectHTTPtoHTTPS = true;\n\t\t\tthis.type = HotServerType.HTTP;\n\t\t\tthis.logger = processor.logger;\n\t\t\tthis.secrets = {};\n\t\t}\n\t\telse\n\t\t{\n\t\t\tthis.processor = processor.processor;\n\t\t\tthis.serverType = processor.serverType || \"Server\";\n\t\t\tthis.api = processor.api || null;\n\t\t\tthis.listenAddress = processor.listenAddress || \"0.0.0.0\";\n\t\t\tthis.ports = processor.ports || {\n\t\t\t\t\thttp: 5000,\n\t\t\t\t\thttps: 443\n\t\t\t\t};\n\t\t\tthis.ssl = processor.ssl || {\n\t\t\t\t\tcert: \"\",\n\t\t\t\t\tkey: \"\",\n\t\t\t\t\tca: \"\"\n\t\t\t\t};\n\t\t\tthis.redirectHTTPtoHTTPS = processor.redirectHTTPtoHTTPS != null ? processor.redirectHTTPtoHTTPS : true;\n\t\t\tthis.type = processor.type || HotServerType.HTTP;\n\t\t\tthis.logger = processor.logger;\n\t\t\tthis.secrets = processor.secrets || {};\n\t\t}\n\t}\n\n\t/**\n\t * Set an API to this server. This will also set the associated \n\t * processor to this API as well.\n\t */\n\tasync setAPI (api: HotAPI): Promise<void>\n\t{\n\t\tthis.processor.api = api;\n\t\tthis.api = api;\n\n\t\t//if (registerRoutes === true)\n\t\t\t//await this.api.registerRoutes ();\n\t}\n\n\t/**\n\t * Register a route with the server.\n\t */\n\tasync registerRoute? (route: HotRoute): Promise<void>;\n\n\t/**\n\t * Start listening for requests.\n\t */\n\tasync listen? (): Promise<void>;\n\n\t/**\n\t * Shutdown the server.\n\t */\n\tasync shutdown? (): Promise<void>;\n}","import * as ppath from \"path\";\n\nimport fetch from \"node-fetch\";\nimport validateModuleName from \"validate-npm-package-name\";\n\nimport { HotPage } from \"./HotPage\";\nimport { HotFile } from \"./HotFile\";\n\nimport { HotComponent, HotComponentOutput, IHotComponent } from \"./HotComponent\";\nimport { HotLog, HotLogLevel } from \"./HotLog\";\nimport { HotAPI } from \"./HotAPI\";\nimport { HotServer } from \"./HotServer\";\nimport { DeveloperMode } from \"./Hot\";\nimport { HotAsset } from \"./HotAsset\";\nimport { HotModule } from \"./HotModule\";\nimport { HotClient } from \"./HotClient\";\n\nimport { HotTester } from \"./HotTester\";\nimport { HotTesterAPI } from \"./HotTesterAPI\";\nimport { HotTestDriver } from \"./HotTestDriver\";\nimport { HotTestMap } from \"./HotTestMap\";\nimport { HotTestDestination} from \"./HotTestDestination\";\n\nimport { HotSite, HotSiteRoute } from \"./HotSite\";\n\nimport { registerComponent } from \"./HotStaqRegisterComponent\";\nimport { hotStaqWebStart } from \"./HotStaqWebStart\";\n\nvar HotTesterMocha: any = null;\nvar HotTesterMochaSelenium: any = null;\nvar HotTestSeleniumDriver: any = null;\n\n/**\n * The options to use when starting a page.\n */\nexport interface HotStartOptions\n{\n\t/**\n\t * The Hott site to load.\n\t */\n\turl?: string;\n\t/**\n\t * The content to display.\n\t */\n\tcontent?: string;\n\t/**\n\t * The name of the page to load.\n\t */\n\tname?: string;\n\t/**\n\t * The processor to use to load the page.\n\t */\n\tprocessor?: HotStaq;\n\t/**\n\t * Any arguments to pass to the new page.\n\t */\n\targs?: any;\n\t/**\n\t * The name of the tester to use.\n\t */\n\ttesterName?: string;\n\t/**\n\t * The name of the tester map to use.\n\t */\n\ttesterMap?: string;\n\t/**\n\t * The base url for the tester api.\n\t */\n\ttesterAPIBaseUrl?: string;\n\t/**\n\t * The url to the html that loads the hott file that's \n\t * pointed at the url above.\n\t */\n\ttesterLaunchpadUrl?: string;\n}\n\n/**\n * The main class that handles all HTML preprocessing, then outputs the \n * results.\n */\nexport interface IHotStaq\n{\n\t/**\n\t * The api that's used to communicate with.\n\t */\n\tapi?: HotAPI;\n\t/**\n\t * The tester api that's used to communicate with.\n\t */\n\ttesterAPI?: HotAPI;\n\t/**\n\t * Indicates what type of execution this is.\n\t */\n\tmode?: DeveloperMode;\n\t/**\n\t * The pages that can be constructed.\n\t */\n\tpages?: { [name: string]: HotPage };\n\t/**\n\t * The imported modules.\n\t */\n\tmodules?: { [name: string]: HotModule };\n\t/**\n\t * The components that can be constructed.\n\t * \n\t * @fixme Rename this to componentTags.\n\t */\n\tcomponents?: {\n\t\t[tagName: string]: {\n\t\t\t\tcomponentType: (new  (copy: IHotComponent | HotStaq, api?: HotAPI) => HotComponent), \n\t\t\t\tprocessor: HotStaq, \n\t\t\t\tapi: HotAPI\n\t\t\t}\n\t\t};\n\t/**\n\t * The files that can be stored for later use.\n\t */\n\tfiles?: { [name: string]: HotFile };\n\t/**\n\t * The loaded hotsite.\n\t */\n\thotSite?: HotSite;\n}\n\n/**\n * The main class that handles all HTML preprocessing, then outputs the \n * results.\n */\nexport class HotStaq implements IHotStaq\n{\n\t/**\n\t * The current version of HotStaq.\n\t */\n\tstatic version: string = \"0.8.21\";\n\t/**\n\t * Indicates if this is a web build.\n\t */\n\tstatic isWeb: boolean = false;\n\t/**\n\t * Indicates if this is ready for testing.\n\t */\n\tstatic isReadyForTesting: boolean = false;\n\t/**\n\t * Executes this event when this page is ready for testing.\n\t */\n\tstatic onReadyForTesting: () => Promise<void> = null;\n\t/**\n\t * Errors to execute when something goes wrong.\n\t */\n\tstatic errors: { [name: string]: { redirectToUrl?: string; func?: (errType: string) => void; }; } = {};\n\t/**\n\t * Indicates what type of execution this is.\n\t */\n\tmode: DeveloperMode;\n\t/**\n\t * The api that's used to communicate with.\n\t */\n\tapi: HotAPI;\n\t/**\n\t * The tester api that's used to communicate with.\n\t */\n\ttesterAPI: HotAPI;\n\t/**\n\t * The pages that can be constructed.\n\t */\n\tpages: { [name: string]: HotPage };\n\t/**\n\t * The imported modules.\n\t */\n\tmodules: { [name: string]: HotModule };\n\t/**\n\t * The components that can be constructed.\n\t * \n\t * @fixme Rename this to componentTags.\n\t */\n\tcomponents: {\n\t\t[tagName: string]: {\n\t\t\t\tcomponentType: (new  (copy: IHotComponent | HotStaq, api?: HotAPI) => HotComponent), \n\t\t\t\tprocessor: HotStaq, \n\t\t\t\tapi: HotAPI\n\t\t\t}\n\t\t};\n\t/**\n\t * The files that can be stored for later use.\n\t */\n\tfiles: { [name: string]: HotFile };\n\t/**\n\t * The loaded hotsite.\n\t */\n\thotSite: HotSite;\n\t/**\n\t * The api content to use when about to load HotStaq.\n\t */\n\tapiContent: string;\n\t/**\n\t * The tester api content to use when about to load HotStaq.\n\t */\n\ttesterApiContent: string;\n\t/**\n\t * The page content to use when about to load HotStaq.\n\t */\n\tpageContent: string;\n\t/**\n\t * The logger.\n\t */\n\tlogger: HotLog;\n\t/**\n\t * Add a start delay before starting. This is for debugging purposes mostly.\n\t */\n\tstartDelay: number;\n\t/**\n\t * The public keys to be exposed.\n\t */\n\tpublicKeys: any;\n\t/**\n\t * The testers that will be used to execute tests.\n\t */\n\ttesters: { [name: string]: HotTester };\n\n\tconstructor (copy: IHotStaq = {})\n\t{\n\t\tthis.logger = new HotLog (HotLogLevel.All);\n\t\tthis.startDelay = 0;\n\t\tthis.api = copy.api || null;\n\t\tthis.testerAPI = copy.testerAPI || null;\n\t\tthis.mode = copy.mode || DeveloperMode.Production;\n\t\tthis.pages = copy.pages || {};\n\t\tthis.modules = copy.modules || {};\n\t\tthis.components = copy.components || {};\n\t\tthis.files = copy.files || {};\n\t\tthis.hotSite = copy.hotSite || null;\n\t\tthis.apiContent = `\n\t\t\t{\n\t\t\t\tvar %api_name% = %api_exported_name%.%api_name%;\n\t\t\t\tvar newHotClient = new HotClient (processor);\n\t\t\t\tvar newapi = new %api_name% (%base_url%, newHotClient);\n\t\t\t\tnewHotClient.api = newapi;\n\t\t\t\tprocessor.api = newapi;\n\t\t\t}`;\n\t\tthis.testerApiContent = `\n\t\t\tvar HotTesterAPI = HotStaqWeb.HotTesterAPI;\n\t\t\tvar newHotTesterClient = new HotClient (processor);\n\t\t\tvar newtesterapi = new HotTesterAPI (%base_tester_url%, newHotTesterClient);\n\t\t\tnewHotTesterClient.testerAPI = newtesterapi;\n\t\t\tprocessor.testerAPI = newtesterapi;`;\n\t\tthis.pageContent = \n`<!DOCTYPE html>\n<html>\n\n<head>\n\t<title>%title%</title>\n\n\t<script type = \"text/javascript\" src = \"%hotstaq_js_src%\"></script>\n\t<script type = \"text/javascript\">\n\t\tfor (let key in HotStaqWeb)\n\t\t\twindow[key] = HotStaqWeb[key];\n\t</script>\n\n%apis_to_load%\n\n\t<script type = \"text/javascript\">\n\t\tasync function hotstaq_startApp ()\n\t\t{\n\t\t\tlet tempMode = 0;\n\n\t\t\tif (window[\"Hot\"] != null)\n\t\t\t\ttempMode = Hot.Mode;\n\n\t\t\t%start_delay%\n\n\t\t\tvar processor = new HotStaq ();\n\t\t\tprocessor.logger.logLevel = %logging_level%;\n\n\t\t\tvar promises = [];\n\t\t\t%developer_mode%\n\n\t\t\t%api_code%\n\n\t\t\t%public_secrets%\n\t\t\t%tester_api%\n\t\t\t%load_files%\n\n\t\t\tprocessor.mode = tempMode;\n\n\t\t\tPromise.all (promises).then (function ()\n\t\t\t\t{\n\t\t\t\t\tHotStaq.displayUrl ({\n\t\t\t\t\t\t\turl: \"%url%\",\n\t\t\t\t\t\t\tname: \"%title%\",\n\t\t\t\t\t\t\tprocessor: processor,\n\t\t\t\t\t\t\targs: %args%,\n\t\t\t\t\t\t\ttesterName: %tester_name%,\n\t\t\t\t\t\t\ttesterMap: %tester_map%,\n\t\t\t\t\t\t\ttesterAPIBaseUrl: %tester_api_base_url%,\n\t\t\t\t\t\t\ttesterLaunchpadUrl: %tester_launchpad_url%\n\t\t\t\t\t\t});\n\t\t\t\t});\n\t\t}\n\n\t\thotstaq_startApp ();\n\t</script>\n</head>\n\n<body>\n</body>\n\n</html>`;\n\t\tthis.publicKeys = {};\n\t\tthis.testers = {};\n\t}\n\n\t/**\n\t * Parse a boolean value.\n\t */\n\tstatic parseBoolean (value: string): boolean\n\t{\n\t\tvalue = value.toLowerCase ();\n\n\t\tif (value === \"true\")\n\t\t\treturn (true);\n\n\t\tif (value === \"false\")\n\t\t\treturn (false);\n\n\t\tif (value === \"yes\")\n\t\t\treturn (true);\n\n\t\tif (value === \"no\")\n\t\t\treturn (false);\n\n\t\tif (value === \"yep\")\n\t\t\treturn (true);\n\n\t\tif (value === \"nah\")\n\t\t\treturn (false);\n\n\t\treturn (false);\n\t}\n\n\t/**\n\t * Check if a required parameter exists inside an object. If it exists, return the value.\n\t */\n\tstatic getParam (name: string, objWithParam: any, required: boolean = true, throwException: boolean = true): any\n\t{\n\t\tlet value: any = objWithParam[name];\n\n\t\tif (value == null)\n\t\t{\n\t\t\tif (required === true)\n\t\t\t{\n\t\t\t\tif (throwException === true)\n\t\t\t\t\tthrow new Error (`Missing required parameter ${name}.`);\n\t\t\t}\n\t\t}\n\n\t\tif (typeof (value) === \"string\")\n\t\t{\n\t\t\tif (required === true)\n\t\t\t{\n\t\t\t\tif (value === \"\")\n\t\t\t\t{\n\t\t\t\t\tif (throwException === true)\n\t\t\t\t\t\tthrow new Error (`Missing required parameter ${name}.`);\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\n\t\treturn (value);\n\t}\n\n\t/**\n\t * Check if a required parameter exists inside an object. If it exists, return the value.\n\t * If it does not exist, return a default value instead.\n\t */\n\tstatic getParamDefault (name: string, objWithParam: any, defaultValue: any): any\n\t{\n\t\tlet value: any = objWithParam[name];\n\n\t\tif (value == null)\n\t\t\treturn (defaultValue);\n\n\t\tif (typeof (value) === \"string\")\n\t\t{\n\t\t\tif (value === \"\")\n\t\t\t\treturn (defaultValue);\n\t\t}\n\n\t\treturn (value);\n\t}\n\n\t/**\n\t * Execute an error. This cannot be an async function due to the nature of how this works.\n\t */\n\tstatic executeError (errType: string)\n\t{\n\t\tif (HotStaq.errors[errType] != null)\n\t\t{\n\t\t\tlet url: string = HotStaq.errors[errType].redirectToUrl;\n\n\t\t\tif (url != null)\n\t\t\t{\n\t\t\t\tif (url !== \"\")\n\t\t\t\t{\n\t\t\t\t\twindow.location.href = url;\n\n\t\t\t\t\treturn;\n\t\t\t\t}\n\t\t\t}\n\n\t\t\tlet func = HotStaq.errors[errType].func;\n\n\t\t\tif (func != null)\n\t\t\t\tfunc (errType);\n\t\t}\n\t}\n\n\t/**\n\t * Wait for a number of milliseconds.\n\t */\n\tstatic async wait (numMilliseconds: number): Promise<void>\n\t{\n\t\treturn (await new Promise ((resolve, reject) =>\n\t\t\t{\n\t\t\t\tsetTimeout (() =>\n\t\t\t\t\t{\n\t\t\t\t\t\tresolve ();\n\t\t\t\t\t}, numMilliseconds);\n\t\t\t}));\n\t}\n\n\t/**\n\t * Add a page.\n\t */\n\taddPage (page: HotPage): void\n\t{\n\t\tthis.pages[page.name] = page;\n\t}\n\n\t/**\n\t * Get a page to process.\n\t */\n\tgetPage (pageName: string): HotPage\n\t{\n\t\treturn (this.pages[pageName]);\n\t}\n\n\t/**\n\t * Add an imported module.\n\t */\n\taddModule (name: string, module: HotModule): void\n\t{\n\t\tthis.modules[name] = module;\n\t}\n\n\t/**\n\t * Get an imported module.\n\t */\n\tgetModule (name: string): HotModule\n\t{\n\t\treturn (this.modules[name]);\n\t}\n\n\t/**\n\t * Add a file.\n\t */\n\taddFile (file: HotFile): void\n\t{\n\t\tlet name: string = file.name;\n\n\t\tif (name === \"\")\n\t\t\tname = file.localFile;\n\n\t\tif (name === \"\")\n\t\t\tname = file.url;\n\n\t\tthis.files[name] = file;\n\t}\n\n\t/**\n\t * Get a file.\n\t */\n\tgetFile (name: string, throwEx: boolean = true): HotFile\n\t{\n\t\tif (this.files[name] == null)\n\t\t{\n\t\t\tlet pos: number = name.indexOf (\"?hstqserve=\");\n\t\t\tlet tempName: string = name;\n\n\t\t\tif (pos > -1)\n\t\t\t\ttempName = name.substring (0, pos);\n\n\t\t\tif (this.files[tempName] != null)\n\t\t\t\treturn (this.files[tempName]);\n\n\t\t\tif (throwEx === true)\n\t\t\t\tthrow new Error (`Unable to find file ${name}`);\n\n\t\t\treturn (null);\n\t\t}\n\n\t\treturn (this.files[name]);\n\t}\n\n\t/** \n\t * Keep the context the object is currently in.\n\t * \n\t * @param func The document element's id.\n\t * @param context The object to remain in context.\n\t * @param [val=undefined] An additional value to pass to the context.\n\t * @return The returned result from the function func.\n\t */\n\tstatic keepContext(func: Function, context: any, val?: any): any\n\t{\n\t\tvar objReturn = function()\n\t\t\t{\n\t\t\t\tvar aryArgs = Array.prototype.slice.call(arguments);\n\n\t\t\t\tif (val != undefined)\n\t\t\t\t\taryArgs.push(val);\n\n\t\t\t\tif (context == null)\n\t\t\t\t\treturn func.apply(this, aryArgs);\n\t\t\t\telse\n\t\t\t\t\treturn func.apply(context, aryArgs);\n\t\t\t};\n\n\t\treturn objReturn;\n\t}\n\n\t/**\n\t * Add and register a component.\n\t */\n\taddComponent (ComponentType: (new (copy: IHotComponent | HotStaq, api?: HotAPI) => HotComponent), api: HotAPI = null, \n\t\telementOptions: ElementDefinitionOptions = undefined): void\n\t{\n\t\tlet tempApi = this.api\n\n\t\tif (api != null)\n\t\t\ttempApi = api;\n\n\t\tlet tempComponentObj = new ComponentType (this, tempApi);\n\n\t\tif (this.components[tempComponentObj.tag] != null)\n\t\t\tthrow new Error (`Component ${tempComponentObj.tag} already exists!`);\n\n\t\tthis.components[tempComponentObj.tag] = { componentType: ComponentType, processor: this, api: tempApi };\n\t\tregisterComponent.call (this, tempComponentObj.tag, elementOptions);\n\t}\n\n\t/**\n\t * Correct any HTML prior to DOM parsing. This only accounts for <tr> currently.\n\t */\n\tstatic fixHTML (str: string): { fixedStr: string, querySelector: string; }\n\t{\n\t\t// Take into account the difference between XML and HTML.\n\t\tconst tempStr: string = str.replace(/ \\/>/g, '>').replace(\n\t\t\t/(<(area|base|br|col|command|embed|hr|img|input|keygen|link|meta|param|source|track|wbr).*?>)/g, '$1</$2>');\n\t\tconst parsedXML = new DOMParser ().parseFromString (`<xml>${tempStr}</xml>`, \"text/xml\");\n\t\tlet querySelector: string = \"\";\n\n\t\tif (parsedXML.documentElement.children.length > 0)\n\t\t{\n\t\t\tconst tagName: string = parsedXML.documentElement.children[0].tagName.toLowerCase ();\n\n\t\t\tif (tagName === \"tr\")\n\t\t\t{\n\t\t\t\tstr = `<table>${str}</table>`;\n\t\t\t\tquerySelector = \"tbody\";\n\t\t\t}\n\n\t\t\tif (tagName === \"th\")\n\t\t\t{\n\t\t\t\tstr = `<table>${str}</table>`;\n\t\t\t\tquerySelector = tagName;\n\t\t\t}\n\t\t}\n\n\t\treturn ({ fixedStr: str, querySelector: querySelector });\n\t}\n\n\t/**\n\t * Add a new HTML element(s) to the current document.\n\t */\n\tstatic addHtml (parent: string | HTMLElement, html: string | HTMLElement): HTMLElement | HTMLElement[]\n\t{\n\t\tlet foundParent: HTMLElement = null;\n\n\t\tif (typeof (parent) === \"string\")\n\t\t\tfoundParent = document.querySelector (parent);\n\t\telse\n\t\t\tfoundParent = parent;\n\n\t\tif (foundParent == null)\n\t\t\tthrow new Error (`Unable to find parent ${parent}!`);\n\n\t\tlet result: HTMLElement = null;\n\n\t\tif (typeof (html) === \"string\")\n\t\t{\n\t\t\tlet htmlHandler = HotStaq.fixHTML (html);\n\t\t\tlet newDOM: Document = new DOMParser ().parseFromString (htmlHandler.fixedStr, \"text/html\");\n\t\t\tlet children: any = null;\n\n\t\t\tif (htmlHandler.querySelector === \"\")\n\t\t\t\tchildren = newDOM.body.children;\n\t\t\telse\n\t\t\t\tchildren = newDOM.querySelector (htmlHandler.querySelector).children;\n\n\t\t\tlet results: HTMLElement[] = [];\n\n\t\t\tfor (let iIdx = 0; iIdx < children.length; iIdx++)\n\t\t\t{\n\t\t\t\tlet child: HTMLElement = (<HTMLElement>children[iIdx]);\n\n\t\t\t\tresults.push (foundParent.appendChild (child));\n\t\t\t}\n\n\t\t\treturn (results);\n\t\t}\n\t\telse\n\t\t\tresult = foundParent.appendChild (html);\n\n\t\treturn (result);\n\t}\n\n\t/**\n\t * Check if a HotSite's name is valid.\n\t */\n\tstatic checkHotSiteName (hotsiteName: string, throwException: boolean = false): boolean\n\t{\n\t\tlet results = validateModuleName (hotsiteName);\n\t\tlet isValid: boolean = true;\n\n\t\tif (results.validForNewPackages === false)\n\t\t\tisValid = false;\n\n\t\tif (results.errors != null)\n\t\t{\n\t\t\tif (results.errors.length > 0)\n\t\t\t\tisValid = false;\n\t\t}\n\n\t\tif (isValid === false)\n\t\t{\n\t\t\tif (throwException === true)\n\t\t\t\tthrow new Error (`HotSite ${hotsiteName} has an invalid name! The name cannot be empty and must have a valid NPM module name.`);\n\t\t}\n\n\t\treturn (isValid);\n\t}\n\n\t/**\n\t * In the supplied content, replace a key in a ${KEY} with a value.\n\t * \n\t * @returns The content with the correct values.\n\t */\n\tstatic replaceKey (content: string, key: string, value: string): string\n\t{\n\t\tconst finalStr: string = content.replace (new RegExp (`\\\\$\\\\{${key}\\\\}`, \"g\"), value);\n\n\t\treturn (finalStr);\n\t}\n\n\t/**\n\t * Get a value from a HotSite object.\n\t * \n\t * @returns Returns the value from the hotsite object. Returns null if it doesn't exist.\n\t */\n\tstatic getValueFromHotSiteObj (hotsite: HotSite, params: string[]): any\n\t{\n\t\tlet value: any = null;\n\n\t\tif (hotsite != null)\n\t\t{\n\t\t\tlet prevValue: any = hotsite;\n\n\t\t\t// Go through each object in the list of parameters and \n\t\t\t// get the value of the final parameter.\n\t\t\tfor (let iIdx = 0; iIdx < params.length; iIdx++)\n\t\t\t{\n\t\t\t\tlet param: string = params[iIdx];\n\n\t\t\t\tif (prevValue[param] == null)\n\t\t\t\t{\n\t\t\t\t\tprevValue = null;\n\n\t\t\t\t\tbreak;\n\t\t\t\t}\n\n\t\t\t\tprevValue = prevValue[param];\n\t\t\t}\n\n\t\t\tif (prevValue != null)\n\t\t\t\tvalue = prevValue;\n\t\t}\n\n\t\treturn (value);\n\t}\n\n\t/**\n\t * Process a HotSite.\n\t */\n\tasync processHotSite (tester: HotTester = null): Promise<void>\n\t{\n\t\tHotStaq.checkHotSiteName (this.hotSite.name, true);\n\n\t\tlet routes = this.hotSite.routes;\n\n\t\tif (routes != null)\n\t\t{\n\t\t\tfor (let key in routes)\n\t\t\t{\n\t\t\t\tlet route: HotSiteRoute = routes[key];\n\t\t\t\tlet file: HotFile = new HotFile (route);\n\t\t\t\tlet page: HotPage = new HotPage ({\n\t\t\t\t\t\tprocessor: this,\n\t\t\t\t\t\tname: route.name || \"\",\n\t\t\t\t\t\troute: key,\n\t\t\t\t\t\tfiles: [file]\n\t\t\t\t\t});\n\n\t\t\t\tif (tester != null)\n\t\t\t\t{\n\t\t\t\t\tif (this.mode === DeveloperMode.Development)\n\t\t\t\t\t{\n\t\t\t\t\t\tlet mapName: string = route.name;\n\t\t\t\t\t\tlet testMap: HotTestMap = null;\n\n\t\t\t\t\t\tif (route.map != null)\n\t\t\t\t\t\t{\n\t\t\t\t\t\t\tif (typeof (route.map) === \"string\")\n\t\t\t\t\t\t\t{\n\t\t\t\t\t\t\t\tif (tester.testMaps[route.map] == null)\n\t\t\t\t\t\t\t\t\tthrow new Error (`Test map ${route.map} does not exist!`);\n\n\t\t\t\t\t\t\t\ttester.testMaps[mapName] = tester.testMaps[route.map];\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\telse\n\t\t\t\t\t\t\t{\n\t\t\t\t\t\t\t\ttestMap = new HotTestMap ();\n\t\t\t\t\t\t\t\tlet destinations: HotTestDestination[] | { [name: string]: HotTestDestination } = null;\n\n\t\t\t\t\t\t\t\tif (route.map instanceof Array)\n\t\t\t\t\t\t\t\t{\n\t\t\t\t\t\t\t\t\tdestinations = [];\n\n\t\t\t\t\t\t\t\t\tfor (let iIdx = 0; iIdx < route.map.length; iIdx++)\n\t\t\t\t\t\t\t\t\t{\n\t\t\t\t\t\t\t\t\t\tlet dest = route.map[iIdx];\n\n\t\t\t\t\t\t\t\t\t\tdestinations.push (new HotTestDestination (dest));\n\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\telse\n\t\t\t\t\t\t\t\t{\n\t\t\t\t\t\t\t\t\tdestinations = {};\n\n\t\t\t\t\t\t\t\t\tfor (let key2 in route.map)\n\t\t\t\t\t\t\t\t\t{\n\t\t\t\t\t\t\t\t\t\tlet dest = route.map[key2];\n\n\t\t\t\t\t\t\t\t\t\tdestinations[key2] = new HotTestDestination (dest);\n\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t}\n\n\t\t\t\t\t\t\t\ttestMap.destinations = destinations;\n\t\t\t\t\t\t\t}\n\n\t\t\t\t\t\t\ttester.testMaps[mapName] = testMap;\n\t\t\t\t\t\t}\n\n\t\t\t\t\t\tif (route.destinationOrder != null)\n\t\t\t\t\t\t\ttester.testMaps[mapName].destinationOrder = route.destinationOrder;\n\t\t\t\t\t}\n\t\t\t\t}\n\n\t\t\t\tthis.addPage (page);\n\t\t\t}\n\t\t}\n\n\t\tif (this.hotSite.apis != null)\n\t\t{\n\t\t\tfor (let key in this.hotSite.apis)\n\t\t\t{\n\t\t\t\tlet api = this.hotSite.apis[key];\n\n\t\t\t\tif (api.map == null)\n\t\t\t\t\tcontinue;\n\n\t\t\t\tif (HotStaq.isWeb === false)\n\t\t\t\t{\n\t\t\t\t\tif (this.mode === DeveloperMode.Development)\n\t\t\t\t\t{\n\t\t\t\t\t\tlet mapName: string = key;\n\t\t\t\t\t\tlet testMap: HotTestMap = new HotTestMap ();\n\n\t\t\t\t\t\ttestMap.destinations = [];\n\n\t\t\t\t\t\tfor (let iIdx = 0; iIdx < api.map.length; iIdx++)\n\t\t\t\t\t\t{\n\t\t\t\t\t\t\tlet map: string = api.map[iIdx];\n\n\t\t\t\t\t\t\ttestMap.destinations.push (new HotTestDestination (map));\n\t\t\t\t\t\t}\n\n\t\t\t\t\t\tif (tester != null)\n\t\t\t\t\t\t\ttester.testMaps[mapName] = testMap;\n\t\t\t\t\t\telse\n\t\t\t\t\t\t\tthis.logger.warning (\"A tester was not created first! You must specify one in the CLI.\");\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\n\t\t/// @fixme Allow this to work for server-side as well...\n\t\tif (HotStaq.isWeb === true)\n\t\t{\n\t\t\tfor (let key in this.hotSite.components)\n\t\t\t{\n\t\t\t\tlet component = this.hotSite.components[key];\n\t\t\t\tlet componentUrl: string = component.url;\n\n\t\t\t\t/// @fixme Create unit test for fetching, loading, and registering.\n\t\t\t\tlet res: any = await fetch (componentUrl);\n\t\t\t\tlet ComponentClass = eval (res);\n\n\t\t\t\tthis.addComponent (ComponentClass);\n\t\t\t}\n\t\t}\n\n\t\tif (this.hotSite.routes == null)\n\t\t\tthis.hotSite.routes = {};\n\n\t\tlet disableFileLoading: boolean = false;\n\n\t\tif (this.hotSite.disableFileLoading != null)\n\t\t\tdisableFileLoading = this.hotSite.disableFileLoading;\n\n\t\tif (disableFileLoading === false)\n\t\t\tawait this.loadHotFiles (this.hotSite.files, false, false);\n\t\telse\n\t\t\tthis.logger.verbose (`Hotsite has file loading disabled...`);\n\n\t\tif (tester != null)\n\t\t\tthis.addTester (tester);\n\n\t\tthis.logger.verbose (`Processed HotSite ${this.hotSite.name}`);\n\t}\n\n\t/**\n\t * Load from a HotSite.json file. Be sure to load and attach any testers before \n\t * loading a HotSite.\n\t */\n\tasync loadHotSite (path: string): Promise<void>\n\t{\n\t\tlet jsonStr: string = \"\";\n\t\tconst ext: string = ppath.extname (path).toLowerCase ();\n\n\t\tif (HotStaq.isWeb === true)\n\t\t{\n\t\t\tthis.logger.verbose (`Downloading HotSite ${path}`);\n\n\t\t\tlet res: any = await fetch (path);\n\n\t\t\tthis.logger.verbose (`Downloaded site ${path}`);\n\n\t\t\tjsonStr = res.text ();\n\t\t}\n\t\telse\n\t\t{\n\t\t\tpath = ppath.normalize (path);\n\n\t\t\tthis.logger.verbose (`Accessing HotSite ${path}`);\n\n\t\t\tlet HotIO = eval (\"require\")(\"./HotIO\").HotIO; // Hack to get around Webpack.\n\t\t\tjsonStr = await HotIO.readTextFile (path);\n\t\t\tthis.logger.verbose (`Accessed site ${path}`);\n\t\t}\n\n\t\tif ((ext === \".yaml\") || (ext === \".yml\"))\n\t\t{\n\t\t\tif (HotStaq.isWeb === true)\n\t\t\t\tthrow new Error (`YAML support for HotSites is not available on the web yet!`);\n\n\t\t\tlet yaml = eval (\"require\")(\"yaml\"); // Hack to get around Webpack.\n\t\t\tthis.hotSite = yaml.parse (jsonStr);\n\t\t}\n\t\telse\n\t\t\tthis.hotSite = JSON.parse (jsonStr);\n\n\t\tif (this.hotSite == null)\n\t\t\tthrow new Error (`HotSite ${path} cannot be null!`);\n\n\t\tthis.hotSite.hotsitePath = path;\n\t}\n\n\t/**\n\t * Save the current HotSite to a file.\n\t */\n\tasync saveHotSite (path: string): Promise<void>\n\t{\n\t\tif (HotStaq.isWeb === true)\n\t\t\tthrow new Error (`Cannot save a HotSite on the web!`);\n\n\t\tconst hotsiteStr: string = JSON.stringify (this.hotSite, null, 2);\n\n\t\tlet HotIO = eval (\"require\")(\"./HotIO\").HotIO; // Hack to get around Webpack.\n\t\tawait HotIO.writeTextFile (path, hotsiteStr);\n\t\tthis.logger.verbose (`Saved site ${path}`);\n\t}\n\n\t/**\n\t * Load an array of files. If a file already has content, it will not be reloaded \n\t * unless forceContentLoading is set to true.\n\t */\n\tasync loadHotFiles (files: { [name: string]: { url?: string; localFile?: string; content?: string; } }, \n\t\t\tforceContentLoading: boolean = false, loadUrlContent: boolean = true): Promise<void>\n\t{\n\t\tthis.logger.verbose (`Loading Hott files...`);\n\n\t\tfor (let key in files)\n\t\t{\n\t\t\tlet file = files[key];\n\t\t\tlet newFile: HotFile = null;\n\n\t\t\tif (HotStaq.isWeb === true)\n\t\t\t{\n\t\t\t\tnewFile = new HotFile ({\n\t\t\t\t\t\t\"name\": key\n\t\t\t\t\t});\n\t\t\t}\n\t\t\telse\n\t\t\t{\n\t\t\t\tnewFile = new HotFile ({\n\t\t\t\t\t\t\"name\": key\n\t\t\t\t\t});\n\t\t\t}\n\n\t\t\tif (file.url != null)\n\t\t\t{\n\t\t\t\tif (HotStaq.isWeb === true)\n\t\t\t\t\tnewFile.url = `${file.url}?hstqserve=nahfam`;\n\t\t\t\telse\n\t\t\t\t\tnewFile.url = file.url;\n\t\t\t}\n\n\t\t\tif (HotStaq.isWeb === false)\n\t\t\t{\n\t\t\t\tif (file.localFile != null)\n\t\t\t\t\tnewFile.localFile = file.localFile;\n\t\t\t}\n\n\t\t\tlet loadContent: boolean = true;\n\n\t\t\tif (file.content != null)\n\t\t\t{\n\t\t\t\tnewFile.content = file.content;\n\t\t\t\tloadContent = false;\n\t\t\t}\n\n\t\t\tif (forceContentLoading === true)\n\t\t\t\tloadContent = true;\n\n\t\t\tif (loadUrlContent === false)\n\t\t\t{\n\t\t\t\tif (newFile.url !== \"\")\n\t\t\t\t\tloadContent = false;\n\t\t\t}\n\n\t\t\tif (loadContent === true)\n\t\t\t{\n\t\t\t\tthis.logger.verbose (`Loading Hott file: ${newFile.url}`);\n\t\t\t\tawait newFile.load ();\n\t\t\t\tthis.logger.verbose (`Finished loading Hott file: ${newFile.url}`);\n\t\t\t}\n\n\t\t\tthis.addFile (newFile);\n\t\t}\n\n\t\tthis.logger.verbose (`Finished loading Hott files...`);\n\t}\n\n\t/**\n\t * Generate the content to send to a client.\n\t */\n\tasync generateContent (routeKey: string, name: string = \"\", url: string = \"./\",\n\t\t\tjsSrcPath: string = \"./js/HotStaq.min.js\", passArgs: boolean = true, \n\t\t\targs: any = null): Promise<string>\n\t{\n\t\tlet apiScripts: string = \"\";\n\t\tlet apiCode: string = \"\";\n\t\tlet publicKeys: string = \"\";\n\n\t\t/// @todo Optimize this function as much as possible.\n\n\t\t// Load the API string.\n\t\tif (this.hotSite != null)\n\t\t{\n\t\t\tif (this.hotSite.server.globalApi != null)\n\t\t\t{\n\t\t\t\tif (this.hotSite.server.globalApi !== \"\")\n\t\t\t\t{\n\t\t\t\t\tconst globalApi = this.hotSite.apis[this.hotSite.server.globalApi];\n\n\t\t\t\t\tif (globalApi == null)\n\t\t\t\t\t\tthis.logger.warning (`API with name ${this.hotSite.server.globalApi} doesn't exist!`);\n\t\t\t\t\telse\n\t\t\t\t\t{\n\t\t\t\t\t\tlet sendJSContent: boolean = true;\n\n\t\t\t\t\t\tif (globalApi.jsapi == null)\n\t\t\t\t\t\t{\n\t\t\t\t\t\t\tsendJSContent = false;\n\t\t\t\t\t\t\tthis.logger.warning (`API with name ${this.hotSite.server.globalApi} doesn't have a jsapi set. Will not send js content to client.`);\n\t\t\t\t\t\t}\n\n\t\t\t\t\t\tif (globalApi.libraryName == null)\n\t\t\t\t\t\t{\n\t\t\t\t\t\t\tsendJSContent = false;\n\t\t\t\t\t\t\tthis.logger.warning (`API with name ${this.hotSite.server.globalApi} doesn't have a libraryName set. Will not send js content to client.`);\n\t\t\t\t\t\t}\n\n\t\t\t\t\t\tif (globalApi.apiName == null)\n\t\t\t\t\t\t{\n\t\t\t\t\t\t\tsendJSContent = false;\n\t\t\t\t\t\t\tthis.logger.warning (`API with name ${this.hotSite.server.globalApi} doesn't have a apiName set. Will not send js content to client.`);\n\t\t\t\t\t\t}\n\n\t\t\t\t\t\tif (sendJSContent === true)\n\t\t\t\t\t\t{\n\t\t\t\t\t\t\tapiScripts += `\\t<script type = \"text/javascript\" src = \"${globalApi.jsapi}\"></script>\\n`;\n\n\t\t\t\t\t\t\tlet baseUrl: string = \"\\\"\\\"\";\n\n\t\t\t\t\t\t\tif (globalApi.url != null)\n\t\t\t\t\t\t\t\tbaseUrl = `\\\"${globalApi.url}\\\"`;\n\n\t\t\t\t\t\t\tif (this.api != null)\n\t\t\t\t\t\t\t\tbaseUrl = `\\\"${this.api.baseUrl}\\\"`;\n\n\t\t\t\t\t\t\tlet tempAPIContent: string = this.apiContent;\n\t\t\t\t\t\t\ttempAPIContent = tempAPIContent.replace (/\\%api\\_name\\%/g, globalApi.apiName);\n\t\t\t\t\t\t\ttempAPIContent = tempAPIContent.replace (/\\%api\\_exported\\_name\\%/g, globalApi.libraryName);\n\t\t\t\t\t\t\ttempAPIContent = tempAPIContent.replace (/\\%base\\_url\\%/g, baseUrl);\n\n\t\t\t\t\t\t\tapiCode += tempAPIContent;\n\t\t\t\t\t\t}\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t}\n\n\t\t\tif (this.hotSite.apis != null)\n\t\t\t{\n\t\t\t\tlet route = this.hotSite.routes[routeKey];\n\n\t\t\t\tif (route != null)\n\t\t\t\t{\n\t\t\t\t\tif (route.api != null)\n\t\t\t\t\t{\n\t\t\t\t\t\tlet api = this.hotSite.apis[route.api];\n\n\t\t\t\t\t\tif (api == null)\n\t\t\t\t\t\t\tthrow new Error (`Unable to find API ${route.api}`);\n\n\t\t\t\t\t\tif (route.api !== this.hotSite.server.globalApi)\n\t\t\t\t\t\t{\n\t\t\t\t\t\t\tlet sendJSContent: boolean = true;\n\n\t\t\t\t\t\t\tif (api.jsapi == null)\n\t\t\t\t\t\t\t{\n\t\t\t\t\t\t\t\tsendJSContent = false;\n\t\t\t\t\t\t\t\tthis.logger.warning (`API with name ${route.api} doesn't have a jsapi set. Will not send js content to client.`);\n\t\t\t\t\t\t\t}\n\n\t\t\t\t\t\t\tif (api.libraryName == null)\n\t\t\t\t\t\t\t{\n\t\t\t\t\t\t\t\tsendJSContent = false;\n\t\t\t\t\t\t\t\tthis.logger.warning (`API with name ${route.api} doesn't have a libraryName set. Will not send js content to client.`);\n\t\t\t\t\t\t\t}\n\n\t\t\t\t\t\t\tif (api.apiName == null)\n\t\t\t\t\t\t\t{\n\t\t\t\t\t\t\t\tsendJSContent = false;\n\t\t\t\t\t\t\t\tthis.logger.warning (`API with name ${route.api} doesn't have a apiName set. Will not send js content to client.`);\n\t\t\t\t\t\t\t}\n\n\t\t\t\t\t\t\tif (sendJSContent === true)\n\t\t\t\t\t\t\t{\n\t\t\t\t\t\t\t\tlet jsapipath = api.jsapi;\n\t\t\t\t\t\t\t\tapiScripts += `\\t<script type = \"text/javascript\" src = \"${jsapipath}\"></script>\\n`;\n\n\t\t\t\t\t\t\t\tlet baseUrl: string = \"\\\"\\\"\";\n\n\t\t\t\t\t\t\t\tif (api.url != null)\n\t\t\t\t\t\t\t\t\tbaseUrl = `\\\"${api.url}\\\"`;\n\n\t\t\t\t\t\t\t\tif (this.api != null)\n\t\t\t\t\t\t\t\t\tbaseUrl = `\\\"${this.api.baseUrl}\\\"`;\n\n\t\t\t\t\t\t\t\tlet tempAPIContent: string = this.apiContent;\n\t\t\t\t\t\t\t\ttempAPIContent = tempAPIContent.replace (/\\%api\\_name\\%/g, api.apiName);\n\t\t\t\t\t\t\t\ttempAPIContent = tempAPIContent.replace (/\\%api\\_exported\\_name\\%/g, api.libraryName);\n\t\t\t\t\t\t\t\ttempAPIContent = tempAPIContent.replace (/\\%base\\_url\\%/g, baseUrl);\n\n\t\t\t\t\t\t\t\tapiCode += tempAPIContent;\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t}\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t}\n\n\t\t\tif (this.hotSite.server != null)\n\t\t\t{\n\t\t\t\tif (this.hotSite.server.jsSrcPath != null)\n\t\t\t\t\tjsSrcPath = this.hotSite.server.jsSrcPath;\n\t\t\t}\n\n\t\t\tif (this.hotSite.publicKeys != null)\n\t\t\t{\n\t\t\t\tfor (let key in this.hotSite.publicKeys)\n\t\t\t\t{\n\t\t\t\t\tlet secret = this.hotSite.publicKeys[key];\n\t\t\t\t\tlet value: string = undefined;\n\n\t\t\t\t\tif (typeof (secret) === \"string\")\n\t\t\t\t\t\tvalue = JSON.stringify (secret);\n\t\t\t\t\telse\n\t\t\t\t\t{\n\t\t\t\t\t\tif (HotStaq.isWeb === false)\n\t\t\t\t\t\t{\n\t\t\t\t\t\t\tif (this.api != null)\n\t\t\t\t\t\t\t{\n\t\t\t\t\t\t\t\tif (this.api.connection == null)\n\t\t\t\t\t\t\t\t\tthrow new Error (`Cannot pass secrets from the API if there's no connection!`);\n\n\t\t\t\t\t\t\t\tlet serverConn: HotServer = (<HotServer>this.api.connection);\n\n\t\t\t\t\t\t\t\tif (secret.passSecretFromAPI != null)\n\t\t\t\t\t\t\t\t\tvalue = JSON.stringify (serverConn.secrets[key]);\n\t\t\t\t\t\t\t}\n\n\t\t\t\t\t\t\tif (secret.env != null)\n\t\t\t\t\t\t\t{\n\t\t\t\t\t\t\t\t/// @fixme @secvul Is this a security vulnerability? Need to verify that \n\t\t\t\t\t\t\t\t/// only the server has access to this. At this point, I think only the \n\t\t\t\t\t\t\t\t/// server has access.\n\t\t\t\t\t\t\t\tconst envKey: string = secret.env;\n\n\t\t\t\t\t\t\t\tvalue = JSON.stringify (process.env[envKey]);\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t}\n\t\t\t\t\t}\n\n\t\t\t\t\tpublicKeys += `processor.publicKeys[\"${key}\"] = ${value};\\n`;\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\n\t\tlet content: string = this.pageContent;\n\t\tlet fixContent = async (tempContent: string) =>\n\t\t\t{\n\t\t\t\tlet developerModeStr: string = \"\";\n\t\t\t\tlet testerAPIStr: string = \"\";\n\n\t\t\t\tif (this.mode === DeveloperMode.Development)\n\t\t\t\t{\n\t\t\t\t\tdeveloperModeStr = `tempMode = HotStaqWeb.DeveloperMode.Development;`;\n\n\t\t\t\t\tif (this.hotSite != null)\n\t\t\t\t\t{\n\t\t\t\t\t\tif (this.hotSite.testing != null)\n\t\t\t\t\t\t{\n\t\t\t\t\t\t\tif (this.hotSite.testing.web != null)\n\t\t\t\t\t\t\t{\n\t\t\t\t\t\t\t\ttesterAPIStr = this.testerApiContent;\n\n\t\t\t\t\t\t\t\tif (this.hotSite.testing.web.testerAPIUrl == null)\n\t\t\t\t\t\t\t\t\tthis.hotSite.testing.web.testerAPIUrl = \"http://127.0.0.1:8182\";\n\n\t\t\t\t\t\t\t\ttesterAPIStr = testerAPIStr.replace (/\\%base\\_tester\\_url\\%/g, `\\\"${this.hotSite.testing.web.testerAPIUrl}\\\"`);\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t}\n\t\t\t\t\t}\n\t\t\t\t}\n\n\t\t\t\tlet loadFiles: string = \"\";\n\n\t\t\t\tif (Object.keys (this.files).length > 0)\n\t\t\t\t{\n\t\t\t\t\tloadFiles += `var files = {};\\n\\n`;\n\n\t\t\t\t\tfor (let key in this.files)\n\t\t\t\t\t{\n\t\t\t\t\t\tlet file = this.files[key];\n\t\t\t\t\t\tlet asset: HotAsset = new HotAsset (\"html\", key);\n\n\t\t\t\t\t\tif (file.localFile !== \"\")\n\t\t\t\t\t\t\tasset.path = file.localFile;\n\n\t\t\t\t\t\tif (file.url !== \"\")\n\t\t\t\t\t\t\tasset.path = file.url;\n\n\t\t\t\t\t\tif (file.content !== \"\")\n\t\t\t\t\t\t{\n\t\t\t\t\t\t\tasset.path = \"\";\n\t\t\t\t\t\t\tasset.content = file.content;\n\t\t\t\t\t\t}\n\n\t\t\t\t\t\tlet output = await asset.output ();\n\n\t\t\t\t\t\tif (typeof (output) === \"string\")\n\t\t\t\t\t\t\tthrow new Error (`During initial load, HTML assets cannot be outputted using only a string!`);\n\n\t\t\t\t\t\tlet fileUrl: string = \"\";\n\t\t\t\t\t\tlet fileContent: string = \"\";\n\n\t\t\t\t\t\tif (output.url != null)\n\t\t\t\t\t\t\tfileUrl = `\"url\": \"${output.url}\", `;\n\n\t\t\t\t\t\tif (output.content != null)\n\t\t\t\t\t\t\tfileContent = `\"content\": ${output.content}`; // May have to escape the content?\n\n\t\t\t\t\t\tloadFiles += `\\t\\t\\tfiles[\"${output.name}\"] = { ${fileUrl}${fileContent} };\\n`;\n\t\t\t\t\t}\n\n\t\t\t\t\tloadFiles += `\\t\\t\\tpromises.push (processor.loadHotFiles (files));\\n`;\n\t\t\t\t}\n\n\t\t\t\ttempContent = tempContent.replace (/\\%title\\%/g, name);\n\n\t\t\t\tif (passArgs === true)\n\t\t\t\t\ttempContent = tempContent.replace (/\\%args\\%/g, \"Hot.Arguments\");\n\n\t\t\t\tif (args != null)\n\t\t\t\t\ttempContent = tempContent.replace (/\\%args\\%/g, JSON.stringify (args));\n\n\t\t\t\tlet testerMap: string = routeKey;\n\t\t\t\tlet testerUrl: string = \"\";\n\t\t\t\tlet testerLaunchpadUrl: string = \"\";\n\t\t\t\tlet testerName: string = \"HotTesterMochaSelenium\";\n\n\t\t\t\tfor (let key in this.testers)\n\t\t\t\t{\n\t\t\t\t\ttesterName = key;\n\t\t\t\t\tbreak;\n\t\t\t\t}\n\n\t\t\t\tif (this.hotSite != null)\n\t\t\t\t{\n\t\t\t\t\tif (this.hotSite.testing != null)\n\t\t\t\t\t{\n\t\t\t\t\t\tif (this.hotSite.testing.web != null)\n\t\t\t\t\t\t{\n\t\t\t\t\t\t\tif (this.hotSite.testing.web.testerName != null)\n\t\t\t\t\t\t\t\ttesterName = this.hotSite.testing.web.testerName;\n\n\t\t\t\t\t\t\tif (this.hotSite.testing.web.testerAPIUrl != null)\n\t\t\t\t\t\t\t\ttesterUrl = this.hotSite.testing.web.testerAPIUrl;\n\n\t\t\t\t\t\t\tif (this.hotSite.testing.web.launchpadUrl != null)\n\t\t\t\t\t\t\t\ttesterLaunchpadUrl = this.hotSite.testing.web.launchpadUrl;\n\t\t\t\t\t\t}\n\t\t\t\t\t}\n\n\t\t\t\t\tif (this.hotSite.routes != null)\n\t\t\t\t\t{\n\t\t\t\t\t\tif (this.hotSite.routes[routeKey] != null)\n\t\t\t\t\t\t{\n\t\t\t\t\t\t\tlet route = this.hotSite.routes[routeKey];\n\t\t\t\t\t\t\ttesterMap = route.name;\n\t\t\t\t\t\t}\n\t\t\t\t\t}\n\t\t\t\t}\n\n\t\t\t\tlet startDelayStr: string = \"\";\n\n\t\t\t\tif (this.startDelay !== 0)\n\t\t\t\t\tstartDelayStr = `await HotStaq.wait (${this.startDelay});`;\n\n\t\t\t\ttempContent = tempContent.replace (/\\%start\\_delay\\%/g, startDelayStr);\n\t\t\t\ttempContent = tempContent.replace (/\\%logging\\_level\\%/g, `HotLogLevel.${HotLogLevel[this.logger.logLevel]}`);\n\t\t\t\ttempContent = tempContent.replace (/\\%hotstaq\\_js\\_src\\%/g, jsSrcPath);\n\t\t\t\ttempContent = tempContent.replace (/\\%developer\\_mode\\%/g, developerModeStr);\n\t\t\t\ttempContent = tempContent.replace (/\\%tester\\_api\\%/g, testerAPIStr);\n\t\t\t\ttempContent = tempContent.replace (/\\%apis\\_to\\_load\\%/g, apiScripts);\n\t\t\t\ttempContent = tempContent.replace (/\\%load\\_files\\%/g, loadFiles);\n\t\t\t\ttempContent = tempContent.replace (/\\%api\\_code\\%/g, apiCode);\n\t\t\t\ttempContent = tempContent.replace (/\\%public\\_secrets\\%/g, publicKeys);\n\t\t\t\ttempContent = tempContent.replace (/\\%url\\%/g, url);\n\t\t\t\ttempContent = tempContent.replace (/\\%tester\\_name\\%/g, `\"${testerName}\"`);\n\t\t\t\ttempContent = tempContent.replace (/\\%tester\\_map\\%/g, `\"${testerMap}\"`);\n\t\t\t\ttempContent = tempContent.replace (/\\%tester\\_api\\_base\\_url\\%/g, `\"${testerUrl}\"`);\n\t\t\t\ttempContent = tempContent.replace (/\\%tester\\_launchpad\\_url\\%/g, `\"${testerLaunchpadUrl}\"`);\n\n\t\t\t\treturn (tempContent);\n\t\t\t};\n\t\tcontent = await fixContent (content);\n\n\t\treturn (content);\n\t}\n\n\t/**\n\t * Create the Express routes from the given pages. Be sure to load the \n\t * pages first before doing this. This method is meant to be used for \n\t * customized Express applications. If you wish to use the loaded routes \n\t * from this HotStaq object with HotHTTPServer, be sure to use \n\t * the loadHotSite method in HotHTTPServer.\n\t */\n\tasync createExpressRoutes (expressApp: any, jsSrcPath: string = \"./js/HotStaq.min.js\"): Promise<void>\n\t{\n\t\tfor (let key in this.pages)\n\t\t{\n\t\t\tlet page: HotPage = this.pages[key];\n\t\t\tconst content: string = await this.generateContent (page.route, page.name, page.files[0].url, jsSrcPath);\n\n\t\t\texpressApp.get (page.route, (req: any, res: any) =>\n\t\t\t\t{\n\t\t\t\t\tthis.logger.verbose (`Sending custom Express content.`);\n\t\t\t\t\tres.status (200).send (content);\n\t\t\t\t});\n\t\t}\n\t}\n\n\t/**\n\t * Add a tester for use later.\n\t */\n\taddTester (tester: HotTester): void\n\t{\n\t\tthis.testers[tester.name] = tester;\n\t}\n\n\t/**\n\t * Get the list of maps for testing from the HotSite.\n\t */\n\tgetWebTestingMaps (): string[]\n\t{\n\t\tif (this.hotSite == null)\n\t\t\tthrow new Error (\"No HotSite was loaded!\");\n\n\t\tif (this.hotSite.testing == null)\n\t\t\tthrow new Error (\"The HotSite does not have a testing object!\");\n\n\t\tif (this.hotSite.testing.web == null)\n\t\t\tthrow new Error (\"The HotSite does not have a testing web object!\");\n\n\t\tif (this.hotSite.testing.web.maps == null)\n\t\t\tthrow new Error (\"The HotSite testing object does not have any maps!\");\n\n\t\treturn (this.hotSite.testing.web.maps);\n\t}\n\n\t/**\n\t * Get the list of maps for testing from the HotSite.\n\t */\n\tgetAPITestingMaps (): string[]\n\t{\n\t\tif (this.hotSite == null)\n\t\t\tthrow new Error (\"No HotSite was loaded!\");\n\n\t\tif (this.hotSite.testing == null)\n\t\t\tthrow new Error (\"The HotSite does not have a testing object!\");\n\n\t\tif (this.hotSite.testing.api == null)\n\t\t\tthrow new Error (\"The HotSite does not have a testing api object!\");\n\n\t\tif (this.hotSite.testing.api.maps == null)\n\t\t\tthrow new Error (\"The HotSite testing object does not have any maps!\");\n\n\t\treturn (this.hotSite.testing.api.maps);\n\t}\n\n\t/**\n\t * Get a route's key from a route's name.\n\t */\n\tgetRouteKeyFromName (name: string): string\n\t{\n\t\tlet foundKey: string = \"\";\n\n\t\tif (this.hotSite != null)\n\t\t{\n\t\t\tif (this.hotSite.routes != null)\n\t\t\t{\n\t\t\t\tfor (let key in this.hotSite.routes)\n\t\t\t\t{\n\t\t\t\t\tlet route: HotSiteRoute = this.hotSite.routes[key];\n\n\t\t\t\t\tif (route.name === name)\n\t\t\t\t\t{\n\t\t\t\t\t\tfoundKey = key;\n\n\t\t\t\t\t\tbreak;\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\n\t\treturn (foundKey);\n\t}\n\n\t/**\n\t * Get a route from a route's name.\n\t */\n\tgetRouteFromName (name: string): HotSiteRoute\n\t{\n\t\tlet foundRoute: HotSiteRoute = null;\n\t\tlet foundKey: string = this.getRouteKeyFromName (name);\n\n\t\tif (foundKey !== \"\")\n\t\t\tfoundRoute = this.hotSite.routes[foundKey];\n\n\t\treturn (foundRoute);\n\t}\n\n\t/**\n\t * Execute tests.\n\t * \n\t * @param testerName The tester to use to execute tests.\n\t * @param mapName The map or maps to use to navigate through tests.\n\t */\n\tasync executeTests (testerName: string, mapName: string): Promise<void>\n\t{\n\t\tlet tester: HotTester = this.testers[testerName];\n\n\t\tif (tester == null)\n\t\t\tthrow new Error (`Unable to execute tests. Tester ${testerName} does not exist!`);\n\n\t\treturn (tester.execute (mapName));\n\t}\n\n\t/**\n\t * Execute all web tests from the HotSite testing web object.\n\t * \n\t * @param testerName The tester to use to execute tests.\n\t */\n\tasync executeAllWebTests (testerName: string): Promise<void>\n\t{\n\t\tlet maps: string[] = this.getWebTestingMaps ();\n\t\tlet tester: HotTester = this.testers[testerName];\n\n\t\tif (tester == null)\n\t\t\tthrow new Error (`Unable to execute tests. Tester ${testerName} does not exist!`);\n\n\t\tfor (let iIdx = 0; iIdx < maps.length; iIdx++)\n\t\t{\n\t\t\tlet mapName: string = maps[iIdx];\n\n\t\t\tawait this.executeTests (testerName, mapName);\n\t\t}\n\t}\n\n\t/**\n\t * Execute all api tests from the HotSite testing api object.\n\t * \n\t * @param testerName The tester to use to execute tests.\n\t */\n\tasync executeAllAPITests (testerName: string): Promise<void>\n\t{\n\t\tlet maps: string[] = this.getAPITestingMaps ();\n\t\tlet tester: HotTester = this.testers[testerName];\n\n\t\tif (tester == null)\n\t\t\tthrow new Error (`Unable to execute tests. Tester ${testerName} does not exist!`);\n\n\t\tthis.logger.verbose (() => `Executing all API tests for tester ${testerName}. Maps: ${JSON.stringify (maps)}`);\n\n\t\tfor (let iIdx = 0; iIdx < maps.length; iIdx++)\n\t\t{\n\t\t\tlet mapName: string = maps[iIdx];\n\n\t\t\tawait this.executeTests (testerName, mapName);\n\t\t}\n\t}\n\n\t/**\n\t * Process a page and get the result.\n\t */\n\tasync process (pageName: string, args: any = null): Promise<string>\n\t{\n\t\tlet page: HotPage = this.getPage (pageName);\n\t\tlet result: string = await page.process (args);\n\n\t\treturn (result);\n\t}\n\n\t/**\n\t * Process a local file and get the result.\n\t */\n\tstatic async processLocalFile (localFilepath: string, name: string = localFilepath, args: any = null): Promise<string>\n\t{\n\t\tlet processor: HotStaq = new HotStaq ();\n\t\tlet file: HotFile = new HotFile ({\n\t\t\t\"localFile\": localFilepath\n\t\t});\n\t\tawait file.load ();\n\t\tlet page: HotPage = new HotPage ({\n\t\t\t\t\"processor\": processor,\n\t\t\t\t\"name\": name,\n\t\t\t\t\"files\": [file]\n\t\t\t});\n\t\tprocessor.addPage (page);\n\t\tlet result: string = await processor.process (name, args);\n\n\t\treturn (result);\n\t}\n\n\t/**\n\t * Process a url and get the result.\n\t */\n\tstatic async processUrl (options: HotStartOptions): Promise<string>\n\t{\n\t\tlet file: HotFile = new HotFile ({\n\t\t\t\"url\": options.url\n\t\t});\n\n\t\tawait file.load ();\n\t\tlet page: HotPage = new HotPage ({\n\t\t\t\t\"processor\": options.processor,\n\t\t\t\t\"name\": options.name,\n\t\t\t\t\"files\": [file],\n\t\t\t\t\"testerName\": options.testerName,\n\t\t\t\t\"testerMap\": options.testerMap\n\t\t\t});\n\t\toptions.processor.addPage (page);\n\t\tlet result: string = await options.processor.process (options.name, options.args);\n\n\t\treturn (result);\n\t}\n\n\t/**\n\t * Process content and get the result.\n\t */\n\tstatic async processContent (options: HotStartOptions): Promise<string>\n\t{\n\t\tlet file: HotFile = new HotFile ({\n\t\t\t\"content\": options.content\n\t\t});\n\t\tawait file.load ();\n\t\tlet page: HotPage = new HotPage ({\n\t\t\t\t\"processor\": options.processor,\n\t\t\t\t\"name\": options.name,\n\t\t\t\t\"files\": [file]\n\t\t\t});\n\t\toptions.processor.addPage (page);\n\t\tlet result: string = await options.processor.process (options.name, options.args);\n\n\t\treturn (result);\n\t}\n\n\t/**\n\t * When the window has finished loading, execute the function.\n\t * This is meant for web browser use only.\n\t */\n\tstatic onReady (readyFunc: () => void): void\n\t{\n\t\tif ((document.readyState === \"complete\") || (document.readyState === \"interactive\"))\n\t\t\treadyFunc ();\n\t\telse\n\t\t\twindow.addEventListener (\"load\", readyFunc);\n\t}\n\n\t/**\n\t * Replace the current HTML page with the output.\n\t * This is meant for web browser use only.\n\t */\n\tstatic async useOutput (output: string): Promise<void>\n\t{\n\t\tlet parser = new DOMParser ();\n\t\tlet child = parser.parseFromString (output, \"text/html\");\n\t\tlet htmlObj: HTMLHtmlElement = document.getElementsByTagName('html')[0];\n\n\t\thtmlObj.innerHTML = child.getElementsByTagName('html')[0].innerHTML;\n\n\t\t// Thanks to newfurniturey at: \n\t\t// https://stackoverflow.com/questions/22945884/domparser-appending-script-tags-to-head-body-but-not-executing\n\t\tlet tmpScripts = document.getElementsByTagName('script');\n\t\tif (tmpScripts.length > 0) {\n\t\t\t// push all of the document's script tags into an array\n\t\t\t// (to prevent dom manipulation while iterating over dom nodes)\n\t\t\tlet scripts: HTMLScriptElement[] = [];\n\t\t\tfor (let i = 0; i < tmpScripts.length; i++) {\n\t\t\t\tscripts.push(tmpScripts[i]);\n\t\t\t}\n\n\t\t\t// iterate over all script tags and create duplicate tags for each\n\t\t\tfor (let i = 0; i < scripts.length; i++) {\n\t\t\t\tlet s: HTMLScriptElement = document.createElement('script');\n\n\t\t\t\t// add the new node to the page\n\t\t\t\tscripts[i].parentNode.appendChild(s);\n\n\t\t\t\t// remove the original (non-executing) node from the page\n\t\t\t\tscripts[i].parentNode.removeChild(scripts[i]);\n\n\t\t\t\tawait new Promise<void> ((resolve2, reject2) =>\n\t\t\t\t\t{\n\t\t\t\t\t\ts.onload = () =>\n\t\t\t\t\t\t\t{\n\t\t\t\t\t\t\t\tresolve2 ();\n\t\t\t\t\t\t\t};\n\n\t\t\t\t\t\tlet hasSrc: boolean = false;\n\n\t\t\t\t\t\tif (scripts[i].getAttribute (\"src\") != null)\n\t\t\t\t\t\t{\n\t\t\t\t\t\t\tif (scripts[i].getAttribute (\"src\") !== \"\")\n\t\t\t\t\t\t\t{\n\t\t\t\t\t\t\t\ts.setAttribute (\"src\", scripts[i].getAttribute (\"src\"));\n\t\t\t\t\t\t\t\thasSrc = true;\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t}\n\n\t\t\t\t\t\tif (scripts[i].getAttribute (\"type\") != null)\n\t\t\t\t\t\t{\n\t\t\t\t\t\t\tif (scripts[i].getAttribute (\"type\") !== \"\")\n\t\t\t\t\t\t\t\ts.setAttribute (\"type\", scripts[i].getAttribute (\"type\"));\n\t\t\t\t\t\t}\n\n\t\t\t\t\t\ts.innerHTML = scripts[i].innerHTML;\n\n\t\t\t\t\t\tif (hasSrc === false)\n\t\t\t\t\t\t\tresolve2 ();\n\t\t\t\t\t});\n\t\t\t}\n\t\t}\n\t}\n\n\t/**\n\t * Wait for testers to load.\n\t * \n\t * @fixme This does not wait for ALL testers to finish loading. Only \n\t * the first one.\n\t */\n\tstatic async waitForTesters (): Promise<void>\n\t{\n\t\twhile (HotStaq.isReadyForTesting === false)\n\t\t\tawait HotStaq.wait (10);\n\n\t\tif (HotStaq.onReadyForTesting != null)\n\t\t\tawait HotStaq.onReadyForTesting ();\n\t}\n\n\t/**\n\t * Setup the testers api, if any.\n\t */\n\tstatic setupTesters (processor: HotStaq, options: HotStartOptions)\n\t{\n\t\tif (processor.mode === DeveloperMode.Development)\n\t\t{\n\t\t\tif (processor.testerAPI == null)\n\t\t\t{\n\t\t\t\tif (options.testerAPIBaseUrl == null)\n\t\t\t\t\toptions.testerAPIBaseUrl = \"\";\n\n\t\t\t\tif (options.testerAPIBaseUrl === \"\")\n\t\t\t\t\toptions.testerAPIBaseUrl = \"http://127.0.0.1:8182\";\n\n\t\t\t\tlet client: HotClient = new HotClient (processor);\n\t\t\t\tlet testerAPI: HotTesterAPI = new HotTesterAPI (options.testerAPIBaseUrl, client);\n\t\t\t\ttesterAPI.connection.api = testerAPI;\n\t\t\t\tprocessor.testerAPI = testerAPI;\n\t\t\t}\n\t\t}\n\t}\n\n\t/**\n\t * Setup the testers api on the client, if needed.\n\t */\n\tstatic setupClientTesters (processor: HotStaq): string\n\t{\n\t\tlet output: string = \"\";\n\n\t\tif (processor.mode === DeveloperMode.Development)\n\t\t{\n\t\t\toutput += \n`<script type = \"text/javascript\">\nfunction hotstaq_isDocumentReady ()\n{\nif (window[\"Hot\"] != null)\n{\nif (Hot.Mode === HotStaqWeb.DeveloperMode.Development)\n{\nlet func = function ()\n\t{\n\t\tif (Hot.TesterAPI != null)\n\t\t{\n\t\t\tlet testPaths = {};\n\t\t\tlet testElements = JSON.stringify (Hot.CurrentPage.testElements);\n\t\t\tlet testMaps = JSON.stringify (Hot.CurrentPage.testMaps);\n\n\t\t\tfor (let key in Hot.CurrentPage.testPaths)\n\t\t\t{\n\t\t\t\tlet testPath = Hot.CurrentPage.testPaths[key];\n\n\t\t\t\ttestPaths[key] = testPath.toString ();\n\t\t\t}\n\n\t\t\tlet testPathsStr = JSON.stringify (testPaths);\n\n\t\t\tHot.TesterAPI.tester.pageLoaded ({\n\t\t\t\t\ttesterName: Hot.CurrentPage.testerName,\n\t\t\t\t\ttesterMap: Hot.CurrentPage.testerMap,\n\t\t\t\t\tpageName: Hot.CurrentPage.name,\n\t\t\t\t\ttestElements: testElements,\n\t\t\t\t\ttestPaths: testPathsStr\n\t\t\t\t}).then (function (resp)\n\t\t\t\t\t{\n\t\t\t\t\t\tif (resp.error != null)\n\t\t\t\t\t\t{\n\t\t\t\t\t\t\tif (resp.error !== \"\")\n\t\t\t\t\t\t\t\tthrow new Error (resp.error);\n\t\t\t\t\t\t}\n\n\t\t\t\t\t\tHotStaqWeb.HotStaq.isReadyForTesting = true;\n\t\t\t\t\t});\n\t\t}\n\t};\n\nif ((document.readyState === \"complete\") || (document.readyState === \"interactive\"))\n\tfunc ();\nelse\n\tdocument.addEventListener (\"DOMContentLoaded\", func);\n}\n}\n}\n\nhotstaq_isDocumentReady ();\n</script>`;\n\t\t}\n\n\t\treturn (output);\n\t}\n\n\t/**\n\t * Process and replace the current HTML page with the hott script from the given url.\n\t * This is meant for web browser use only.\n\t */\n\tstatic async displayUrl (url: string | HotStartOptions, name: string = null, \n\t\tprocessor: HotStaq = null, args: any = null): Promise<HotStaq>\n\t{\n\t\treturn (new Promise<HotStaq> ((resolve, reject) =>\n\t\t\t{\n\t\t\t\tHotStaq.onReady (async () =>\n\t\t\t\t\t{\n\t\t\t\t\t\tlet options: HotStartOptions = {\n\t\t\t\t\t\t\t\t\"url\": \"\"\n\t\t\t\t\t\t\t};\n\n\t\t\t\t\t\tif (name == null)\n\t\t\t\t\t\t{\n\t\t\t\t\t\t\tif (typeof (url) === \"string\")\n\t\t\t\t\t\t\t\toptions.name = url;\n\t\t\t\t\t\t\telse\n\t\t\t\t\t\t\t\toptions.name = url.name;\n\t\t\t\t\t\t}\n\t\t\t\t\t\telse\n\t\t\t\t\t\t\toptions.name = name;\n\n\t\t\t\t\t\tif (options.name === \"\")\n\t\t\t\t\t\t{\n\t\t\t\t\t\t\tif (typeof (url) === \"string\")\n\t\t\t\t\t\t\t\toptions.name = url;\n\t\t\t\t\t\t\telse\n\t\t\t\t\t\t\t\toptions.name = url.name;\n\t\t\t\t\t\t}\n\n\t\t\t\t\t\tif (typeof (url) === \"string\")\n\t\t\t\t\t\t\toptions.url = url;\n\t\t\t\t\t\telse\n\t\t\t\t\t\t{\n\t\t\t\t\t\t\toptions.url = url.url;\n\n\t\t\t\t\t\t\tif (processor == null)\n\t\t\t\t\t\t\t{\n\t\t\t\t\t\t\t\tif (url.processor != null)\n\t\t\t\t\t\t\t\t\tprocessor = url.processor;\n\t\t\t\t\t\t\t}\n\n\t\t\t\t\t\t\tif (args == null)\n\t\t\t\t\t\t\t{\n\t\t\t\t\t\t\t\tif (url.args != null)\n\t\t\t\t\t\t\t\t\targs = url.args;\n\t\t\t\t\t\t\t}\n\n\t\t\t\t\t\t\tif (url.testerMap != null)\n\t\t\t\t\t\t\t\toptions.testerMap = url.testerMap;\n\n\t\t\t\t\t\t\tif (url.testerName != null)\n\t\t\t\t\t\t\t\toptions.testerName = url.testerName;\n\n\t\t\t\t\t\t\tif (url.testerAPIBaseUrl != null)\n\t\t\t\t\t\t\t\toptions.testerAPIBaseUrl = url.testerAPIBaseUrl;\n\t\t\t\t\t\t}\n\n\t\t\t\t\t\tif (processor == null)\n\t\t\t\t\t\t\tprocessor = new HotStaq ();\n\n\t\t\t\t\t\tHotStaq.setupTesters (processor, options);\n\n\t\t\t\t\t\toptions.processor = processor;\n\t\t\t\t\t\toptions.args = args;\n\n\t\t\t\t\t\tif (options.url.indexOf (\"hstqserve\") < 0)\n\t\t\t\t\t\t\toptions.url += \"?hstqserve=nahfam\";\n\n\t\t\t\t\t\tlet output: string = await HotStaq.processUrl (options);\n\n\t\t\t\t\t\toutput += HotStaq.setupClientTesters (processor);\n\n\t\t\t\t\t\tawait HotStaq.useOutput (output);\n\t\t\t\t\t\tresolve (processor);\n\t\t\t\t\t});\n\t\t\t}));\n\t}\n\n\t/**\n\t * Process and replace the current HTML page with the hott script.\n\t * This is meant for web browser use only.\n\t */\n\tstatic async displayContent (content: string | HotStartOptions, name: string = null, \n\t\t\tprocessor: HotStaq = null, args: any = null): Promise<HotStaq>\n\t{\n\t\treturn (new Promise<HotStaq> ((resolve, reject) =>\n\t\t\t{\n\t\t\t\tHotStaq.onReady (async () =>\n\t\t\t\t\t{\n\t\t\t\t\t\tlet options: HotStartOptions = {\n\t\t\t\t\t\t\t\t\"content\": \"\"\n\t\t\t\t\t\t\t};\n\n\t\t\t\t\t\tif (name == null)\n\t\t\t\t\t\t{\n\t\t\t\t\t\t\tif (typeof (content) === \"string\")\n\t\t\t\t\t\t\t\toptions.name = \"\";\n\t\t\t\t\t\t\telse\n\t\t\t\t\t\t\t\toptions.name = content.name;\n\t\t\t\t\t\t}\n\t\t\t\t\t\telse\n\t\t\t\t\t\t\toptions.name = name;\n\n\t\t\t\t\t\tif (options.name === \"\")\n\t\t\t\t\t\t{\n\t\t\t\t\t\t\tif (typeof (content) === \"string\")\n\t\t\t\t\t\t\t\toptions.name = \"\"; /// @fixme Is this ok to do?\n\t\t\t\t\t\t\telse\n\t\t\t\t\t\t\t\toptions.name = content.name;\n\t\t\t\t\t\t}\n\n\t\t\t\t\t\tif (typeof (content) === \"string\")\n\t\t\t\t\t\t\toptions.content = content;\n\t\t\t\t\t\telse\n\t\t\t\t\t\t{\n\t\t\t\t\t\t\toptions.content = content.content;\n\n\t\t\t\t\t\t\tif (processor == null)\n\t\t\t\t\t\t\t{\n\t\t\t\t\t\t\t\tif (content.processor != null)\n\t\t\t\t\t\t\t\t\tprocessor = content.processor;\n\t\t\t\t\t\t\t}\n\n\t\t\t\t\t\t\tif (args == null)\n\t\t\t\t\t\t\t{\n\t\t\t\t\t\t\t\tif (content.args != null)\n\t\t\t\t\t\t\t\t\targs = content.args;\n\t\t\t\t\t\t\t}\n\n\t\t\t\t\t\t\tif (content.testerMap != null)\n\t\t\t\t\t\t\t\toptions.testerMap = content.testerMap;\n\n\t\t\t\t\t\t\tif (content.testerName != null)\n\t\t\t\t\t\t\t\toptions.testerName = content.testerName;\n\n\t\t\t\t\t\t\tif (content.testerAPIBaseUrl != null)\n\t\t\t\t\t\t\t\toptions.testerAPIBaseUrl = content.testerAPIBaseUrl;\n\t\t\t\t\t\t}\n\n\t\t\t\t\t\tif (processor == null)\n\t\t\t\t\t\t\tprocessor = new HotStaq ();\n\n\t\t\t\t\t\tHotStaq.setupTesters (processor, options);\n\n\t\t\t\t\t\toptions.processor = processor;\n\t\t\t\t\t\toptions.args = args;\n\n\t\t\t\t\t\tlet output: string = await HotStaq.processContent (options);\n\n\t\t\t\t\t\tawait HotStaq.useOutput (output);\n\t\t\t\t\t\tresolve (processor);\n\t\t\t\t\t});\n\t\t\t}));\n\t}\n}\n\nif (typeof (document) !== \"undefined\")\n\twindow.addEventListener (\"load\", hotStaqWebStart);\n","import { HotFile } from \"./HotFile\";\nimport { HotComponent, HotComponentOutput } from \"./HotComponent\";\nimport { HotStaq } from \"./HotStaq\";\nimport { Hot } from \"./Hot\";\n\n/**\n * Register a component for use as a HTML tag.\n */\nexport function registerComponent (tag: string, elementOptions: ElementDefinitionOptions = undefined): void\n{\n\tif ((tag == null) || (tag === \"\"))\n\t\tthrow new Error (`All components must have a tag!`);\n\n\tif (customElements.get (tag) !== undefined)\n\t{\n\t\t/// @fixme This element has already been defined. Should this throw an error or warning? I don't think it should...\n\n\t\treturn;\n\t}\n\n\tlet processorComponents = this.components;\n\n\tcustomElements.define (tag, class extends HTMLElement\n\t\t{\n\t\t\t/**\n\t\t\t * The connected HotComponent.\n\t\t\t */\n\t\t\tcomponent: HotComponent;\n\t\t\n\t\t\tconstructor ()\n\t\t\t{\n\t\t\t\tsuper ();\n\n\t\t\t\tlet componentInfo = processorComponents[tag];\n\t\t\t\tthis.component = new componentInfo.componentType (componentInfo.processor, componentInfo.api);\n\n\t\t\t\tlet compHtmlElement = this;\n\t\t\n\t\t\t\t// @ts-ignore\n\t\t\t\tcompHtmlElement.hotComponent = this.component;\n\t\t\n\t\t\t\tthis.component.htmlElements = [compHtmlElement];\n\t\t\t\tthis.component.inner = this.innerHTML;\n\t\t\n\t\t\t\tif (this.component.handleAttributes != null)\n\t\t\t\t\tthis.component.handleAttributes (this.attributes);\n\t\t\t\telse\n\t\t\t\t{\n\t\t\t\t\tfor (let iIdx = 0; iIdx < this.attributes.length; iIdx++)\n\t\t\t\t\t{\n\t\t\t\t\t\tconst attr: Attr = this.attributes[iIdx];\n\t\t\t\t\t\tconst attrName: string = attr.name.toLowerCase ();\n\t\t\t\t\t\tconst attrValue: string = attr.value;\n\t\t\n\t\t\t\t\t\tif (attrName === \"id\")\n\t\t\t\t\t\t\tthis.component.name = attrValue;\n\t\t\n\t\t\t\t\t\tif (attrName === \"name\")\n\t\t\t\t\t\t\tthis.component.name = attrValue;\n\t\t\n\t\t\t\t\t\tif (attrName === \"value\")\n\t\t\t\t\t\t\tthis.component.value = attrValue;\n\t\t\n\t\t\t\t\t\tif (attrName.indexOf (\"hot-\") > -1)\n\t\t\t\t\t\t{\n\t\t\t\t\t\t\tconst attrTempName: string = attrName.substring (4);\n\t\t\n\t\t\t\t\t\t\t/// @ts-ignore\n\t\t\t\t\t\t\tthis.component[attrTempName] = attrValue;\n\t\t\t\t\t\t}\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\n\t\t\t\tif (this.component.onPreOutput != null)\n\t\t\t\t{\n\t\t\t\t\tif (this.component.onPreOutput () === false)\n\t\t\t\t\t\treturn;\n\t\t\t\t}\n\n\t\t\t\tlet outputs = this.component.output ();\n\t\t\n\t\t\t\tif (this.component.onPostOutput != null)\n\t\t\t\t\toutputs = this.component.onPostOutput (outputs);\n\t\t\n\t\t\t\tlet componentOutputs: HotComponentOutput[] = [];\n\t\t\n\t\t\t\tif (typeof (outputs) === \"string\")\n\t\t\t\t\tcomponentOutputs.push ({ html: outputs });\n\t\t\t\telse\n\t\t\t\t{\n\t\t\t\t\tif (outputs instanceof Array)\n\t\t\t\t\t\tcomponentOutputs = outputs;\n\t\t\t\t\telse\n\t\t\t\t\t\tcomponentOutputs = [outputs];\n\t\t\t\t}\n\t\t\n\t\t\t\tfor (let iKdx = 0; iKdx < componentOutputs.length; iKdx++)\n\t\t\t\t{\n\t\t\t\t\tlet output = componentOutputs[iKdx];\n\t\t\t\t\tlet htmlStr: string = output.html;\n\t\t\t\t\tlet addFunctionsTo: string = \"\";\n\t\t\n\t\t\t\t\tif (output.addFunctionsTo != null)\n\t\t\t\t\t\taddFunctionsTo = output.addFunctionsTo;\n\t\t\n\t\t\t\t\tlet str: string = HotFile.parseContent (htmlStr, true, { \"outputCommands\": false });\n\t\t\n\t\t\t\t\tif (this.component.onParsed != null)\n\t\t\t\t\t\tstr = this.component.onParsed (str);\n\t\t\n\t\t\t\t\tlet htmlHandler: { fixedStr: string, querySelector: string; } = { fixedStr: \"\", querySelector: \"\" };\n\t\t\n\t\t\t\t\tif (this.component.onFixHTML != null)\n\t\t\t\t\t\thtmlHandler = this.component.onFixHTML (str);\n\t\t\t\t\telse\n\t\t\t\t\t\thtmlHandler = HotStaq.fixHTML (str);\n\n\t\t\t\t\tlet childrenToReadd: Node[] = [];\n\t\t\n\t\t\t\t\t// Save the children from being replaced.\n\t\t\t\t\tfor (let iIdx = (this.children.length - 1); iIdx > -1; iIdx--)\n\t\t\t\t\t{\n\t\t\t\t\t\tlet child: Node = this.children[iIdx];\n\t\t\n\t\t\t\t\t\tchildrenToReadd.push (this.removeChild (child));\n\t\t\t\t\t}\n\t\t\n\t\t\t\t\tlet newDOM: Document = null;\n\t\t\t\t\tlet newObj: HTMLElement = null;\n\t\t\n\t\t\t\t\tif (this.component.onParseDOM != null)\n\t\t\t\t\t\tnewDOM = this.component.onParseDOM (htmlHandler.fixedStr);\n\t\t\t\t\telse\n\t\t\t\t\t{\n\t\t\t\t\t\t/// @ts-ignore\n\t\t\t\t\t\t//newDOM = this.looseParseFromString (new DOMParser (), str);\n\t\t\t\t\t\tnewDOM = new DOMParser ().parseFromString (htmlHandler.fixedStr, \"text/html\");\n\t\t\t\t\t}\n\n\t\t\t\t\tif (newDOM.body.children.length < 1)\n\t\t\t\t\t\tthrow new Error (`No component output from ${this.component.name} with tag ${this.component.tag}`);\n\n\t\t\t\t\tif (newDOM.body.children.length > 1)\n\t\t\t\t\t{\n\t\t\t\t\t\tlet throwErr: boolean = true;\n\t\t\n\t\t\t\t\t\tfor (let iIdx = 0; iIdx < newDOM.body.children.length; iIdx++)\n\t\t\t\t\t\t{\n\t\t\t\t\t\t\tlet child = newDOM.body.children[iIdx];\n\t\t\n\t\t\t\t\t\t\tif (child instanceof HTMLElement)\n\t\t\t\t\t\t\t{\n\t\t\t\t\t\t\t\tif (child.tagName.toLowerCase () === \"parsererror\")\n\t\t\t\t\t\t\t\t{\n\t\t\t\t\t\t\t\t\tnewObj = child;\n\t\t\t\t\t\t\t\t\tthrowErr = false;\n\t\t\n\t\t\t\t\t\t\t\t\tbreak;\n\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t}\n\t\t\n\t\t\t\t\t\tif (throwErr === true)\n\t\t\t\t\t\t\tthrow new Error (`Only a single html element can come from component ${this.component.name}, multiple elements were detected.`);\n\t\t\t\t\t}\n\n\t\t\t\t\tif (htmlHandler.querySelector === \"\")\n\t\t\t\t\t\tnewObj = (<HTMLElement>newDOM.body.children[0]);\n\t\t\t\t\telse\n\t\t\t\t\t\tnewObj = newDOM.querySelector (htmlHandler.querySelector);\n\t\t\n\t\t\t\t\tthis.replaceWith (newObj);\n\t\t\n\t\t\t\t\tif (this.component.click != null)\n\t\t\t\t\t\tnewObj.addEventListener (\"click\", this.component.click.bind (this.component));\n\t\t\n\t\t\t\t\tfor (let key in this.component.events)\n\t\t\t\t\t{\n\t\t\t\t\t\tlet event = this.component.events[key];\n\t\t\n\t\t\t\t\t\t// @ts-ignore\n\t\t\t\t\t\tnewObj.addEventListener (event.type, event.func, event.options);\n\t\t\t\t\t}\n\t\t\n\t\t\t\t\tlet objectFunctions: string[] = Object.getOwnPropertyNames (this.component.constructor.prototype);\n\t\t\n\t\t\t\t\t// Associate any functions to the newly created element.\n\t\t\t\t\tfor (let iIdx = 0; iIdx < objectFunctions.length; iIdx++)\n\t\t\t\t\t{\n\t\t\t\t\t\tlet objFunc: string = objectFunctions[iIdx];\n\t\t\n\t\t\t\t\t\tif (objFunc === \"constructor\")\n\t\t\t\t\t\t\tcontinue;\n\t\t\n\t\t\t\t\t\t// @ts-ignore\n\t\t\t\t\t\tlet prop = this.component[objFunc];\n\t\t\n\t\t\t\t\t\tif (typeof (prop) === \"function\")\n\t\t\t\t\t\t{\n\t\t\t\t\t\t\tlet isNewFunction: boolean = true;\n\t\t\n\t\t\t\t\t\t\t// Go through each function in the base HotComponent and see \n\t\t\t\t\t\t\t// if there's any matches. If there's a match, that means \n\t\t\t\t\t\t\t// we're trying to add an existing function, and we don't\n\t\t\t\t\t\t\t// wanna do that. Skip it.\n\t\t\t\t\t\t\tfor (let key2 in HotComponent.prototype)\n\t\t\t\t\t\t\t{\n\t\t\t\t\t\t\t\tif (objFunc === key2)\n\t\t\t\t\t\t\t\t{\n\t\t\t\t\t\t\t\t\tisNewFunction = false;\n\t\t\n\t\t\t\t\t\t\t\t\tbreak;\n\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t}\n\n\t\t\t\t\t\t\tif (isNewFunction === true)\n\t\t\t\t\t\t\t{\n\t\t\t\t\t\t\t\t// @ts-ignore\n\t\t\t\t\t\t\t\tnewObj[objFunc] = HotStaq.keepContext (this.component[objFunc], this.component);\n\n\t\t\t\t\t\t\t\tif (addFunctionsTo !== \"\")\n\t\t\t\t\t\t\t\t{\n\t\t\t\t\t\t\t\t\tlet query: HTMLElement = document.querySelector (addFunctionsTo);\n\t\t\n\t\t\t\t\t\t\t\t\t// @ts-ignore\n\t\t\t\t\t\t\t\t\tquery[objFunc] = HotStaq.keepContext (this.component[objFunc], this.component);\n\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t}\n\t\t\t\t\t}\n\t\t\n\t\t\t\t\tif (this.component.onPrePlace != null)\n\t\t\t\t\t\tnewObj = this.component.onPrePlace (newObj);\n\t\t\n\t\t\t\t\tlet compHtmlElement2: HTMLElement = this.component.onCreated (newObj);\n\t\t\n\t\t\t\t\tif (this.component.onParentPlace != null)\n\t\t\t\t\t{\n\t\t\t\t\t\t// @ts-ignore\n\t\t\t\t\t\tcompHtmlElement2.onParentPlace = this.component.onParentPlace;\n\t\t\t\t\t}\n\t\t\n\t\t\t\t\t// @ts-ignore\n\t\t\t\t\tcompHtmlElement2.hotComponent = this.component;\n\t\t\t\t\tthis.component.htmlElements.push (compHtmlElement2);\n\t\t\n\t\t\t\t\tif (output.closestSelector != null)\n\t\t\t\t\t{\n\t\t\t\t\t\tlet parentElm: HTMLElement = compHtmlElement2;\n\n\t\t\t\t\t\twhile (parentElm)\n\t\t\t\t\t\t{\n\t\t\t\t\t\t\tlet foundNode: Node = parentElm.querySelector (output.closestSelector);\n\n\t\t\t\t\t\t\tif (foundNode != null)\n\t\t\t\t\t\t\t{\n\t\t\t\t\t\t\t\tparentElm = (<HTMLElement>foundNode);\n\t\t\t\t\t\t\t\tbreak;\n\t\t\t\t\t\t\t}\n\n\t\t\t\t\t\t\tparentElm = parentElm.parentElement;\n\t\t\t\t\t\t}\n\n\t\t\t\t\t\tif (parentElm == null)\n\t\t\t\t\t\t\tthrow new Error (`Unable to find closest node with selector '${output.closestSelector}'`);\n\t\t\n\t\t\t\t\t\tcompHtmlElement2.parentElement.removeChild (compHtmlElement2);\n\t\t\t\t\t\tparentElm.appendChild (compHtmlElement2);\n\t\t\n\t\t\t\t\t\t// @ts-ignore\n\t\t\t\t\t\tif (compHtmlElement2.onParentPlace != null)\n\t\t\t\t\t\t{\n\t\t\t\t\t\t\t// @ts-ignore\n\t\t\t\t\t\t\tcompHtmlElement2.hotComponent.onParentPlace (parentNode, compHtmlElement2);\n\t\t\t\t\t\t}\n\t\t\t\t\t}\n\t\t\n\t\t\t\t\tif (output.documentSelector != null)\n\t\t\t\t\t{\n\t\t\t\t\t\tlet parentNode: Node = document.querySelector (output.documentSelector);\n\n\t\t\t\t\t\tif (parentNode == null)\n\t\t\t\t\t\t\tthrow new Error (`Unable to find document node with selector '${output.documentSelector}'`);\n\t\t\n\t\t\t\t\t\tcompHtmlElement2.parentElement.removeChild (compHtmlElement2);\n\t\t\t\t\t\tparentNode.appendChild (compHtmlElement2);\n\t\t\n\t\t\t\t\t\t// @ts-ignore\n\t\t\t\t\t\tif (compHtmlElement2.onParentPlace != null)\n\t\t\t\t\t\t{\n\t\t\t\t\t\t\t// @ts-ignore\n\t\t\t\t\t\t\tcompHtmlElement2.hotComponent.onParentPlace (parentNode, compHtmlElement2);\n\t\t\t\t\t\t}\n\t\t\t\t\t}\n\n\t\t\t\t\tlet placeElmInParent = (parentNodeToCheck: ParentNode, placeHereParent: string, childToPlace: Node): ParentNode =>\n\t\t\t\t\t{\n\t\t\t\t\t\tlet parentNodeCheckCounter: number = 0;\n\t\t\n\t\t\t\t\t\twhile (parentNodeCheckCounter < 10) /// @todo Make this controllable with a variable from the component.\n\t\t\t\t\t\t{\n\t\t\t\t\t\t\tif (parentNodeToCheck == null)\n\t\t\t\t\t\t\t\tbreak;\n\t\t\n\t\t\t\t\t\t\tif (parentNodeToCheck instanceof HTMLHtmlElement)\n\t\t\t\t\t\t\t\tbreak;\n\t\t\n\t\t\t\t\t\t\t// If the hot-place-here exists, place the children there. If not, place it under the \n\t\t\t\t\t\t\t// new element.\n\t\t\t\t\t\t\tlet placeHereArray = parentNodeToCheck.querySelectorAll (`hot-place-here[name=\"${placeHereParent}\"]`);\n\t\t\n\t\t\t\t\t\t\tif (placeHereArray.length > 0)\n\t\t\t\t\t\t\t{\n\t\t\t\t\t\t\t\tlet placeHere = placeHereArray[0];\n\t\t\n\t\t\t\t\t\t\t\tif (childToPlace.parentNode != null)\n\t\t\t\t\t\t\t\t\tchildToPlace.parentNode.removeChild (childToPlace);\n\n\t\t\t\t\t\t\t\tplaceHere.appendChild (childToPlace);\n\t\t\n\t\t\t\t\t\t\t\t// @ts-ignore\n\t\t\t\t\t\t\t\tif (childToPlace.onParentPlace != null)\n\t\t\t\t\t\t\t\t{\n\t\t\t\t\t\t\t\t\t// @ts-ignore\n\t\t\t\t\t\t\t\t\tchildToPlace.hotComponent.onParentPlace (placeHere, childToPlace);\n\t\t\t\t\t\t\t\t}\n\t\t\n\t\t\t\t\t\t\t\tbreak;\n\t\t\t\t\t\t\t}\n\t\t\n\t\t\t\t\t\t\tif (placeHereArray.length < 1)\n\t\t\t\t\t\t\t{\n\t\t\t\t\t\t\t\tlet placeHereAttrArray = parentNodeToCheck.querySelectorAll (`[hot-place-here=\"${placeHereParent}\"]`);\n\t\t\n\t\t\t\t\t\t\t\tif (placeHereAttrArray.length > 0)\n\t\t\t\t\t\t\t\t{\n\t\t\t\t\t\t\t\t\tlet placeHere = placeHereAttrArray[0];\n\n\t\t\t\t\t\t\t\t\tif (childToPlace.parentNode != null)\n\t\t\t\t\t\t\t\t\t\tchildToPlace.parentNode.removeChild (childToPlace);\n\n\t\t\t\t\t\t\t\t\tplaceHere.appendChild (childToPlace);\n\t\t\n\t\t\t\t\t\t\t\t\t// @ts-ignore\n\t\t\t\t\t\t\t\t\tif (childToPlace.onParentPlace != null)\n\t\t\t\t\t\t\t\t\t{\n\t\t\t\t\t\t\t\t\t\t// @ts-ignore\n\t\t\t\t\t\t\t\t\t\tchildToPlace.hotComponent.onParentPlace (placeHere, childToPlace);\n\t\t\t\t\t\t\t\t\t}\n\t\t\n\t\t\t\t\t\t\t\t\tbreak;\n\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t}\n\t\t\n\t\t\t\t\t\t\tparentNodeToCheck = parentNodeToCheck.parentNode;\n\t\t\t\t\t\t\tparentNodeCheckCounter++;\n\t\t\t\t\t\t}\n\n\t\t\t\t\t\treturn (parentNodeToCheck);\n\t\t\t\t\t};\n\t\t\n\t\t\t\t\tif (output.placeHereParent != null)\n\t\t\t\t\t{\n\t\t\t\t\t\tlet parentNodeToCheck = compHtmlElement2.parentNode;\n\t\t\t\t\t\tparentNodeToCheck = placeElmInParent (parentNodeToCheck, output.placeHereParent, compHtmlElement2);\n\n\t\t\t\t\t\tif (parentNodeToCheck == null)\n\t\t\t\t\t\t\tthrow new Error (`Unable to find parent node with hot-place-here attribute '${output.placeHereParent}'`);\n\t\t\t\t\t}\n\t\t\n\t\t\t\t\t// Append the children to the newly created HTML element.\n\t\t\t\t\tfor (let iIdx = 0; iIdx < childrenToReadd.length; iIdx++)\n\t\t\t\t\t{\n\t\t\t\t\t\tconst child: HTMLElement = (<HTMLElement>childrenToReadd[iIdx]);\n\t\t\t\t\t\tlet placedChild: boolean = false;\n\n\t\t\t\t\t\t// Get the attribute hot-place-parent in child.\n\t\t\t\t\t\tif (typeof (child.getAttribute) !== \"undefined\")\n\t\t\t\t\t\t{\n\t\t\t\t\t\t\tlet placeHereParentAttr = child.getAttribute (\"hot-place-parent\");\n\n\t\t\t\t\t\t\tif ((placeHereParentAttr != null) && (placeHereParentAttr !== \"\"))\n\t\t\t\t\t\t\t{\n\t\t\t\t\t\t\t\tlet parentNodeToCheck: ParentNode = compHtmlElement2;\n\t\t\t\t\t\t\t\tparentNodeToCheck = placeElmInParent (parentNodeToCheck, placeHereParentAttr, child);\n\t\t\n\t\t\t\t\t\t\t\tif (parentNodeToCheck == null)\n\t\t\t\t\t\t\t\t\tthrow new Error (`Unable to find parent node with hot-place-here attribute '${output.placeHereParent}'`);\n\t\t\t\t\t\t\t\telse\n\t\t\t\t\t\t\t\t\tplacedChild = true;\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t}\n\t\t\n\t\t\t\t\t\tif (placedChild === false)\n\t\t\t\t\t\t\tcompHtmlElement2.appendChild (child);\n\n\t\t\t\t\t\t// @ts-ignore\n\t\t\t\t\t\tif (child.onParentPlace != null)\n\t\t\t\t\t\t{\n\t\t\t\t\t\t\t// @ts-ignore\n\t\t\t\t\t\t\tchild.hotComponent.onParentPlace (compHtmlElement2, child);\n\t\t\t\t\t\t}\n\t\t\t\t\t}\n\t\t\n\t\t\t\t\tif (this.component.onPostPlace != null)\n\t\t\t\t\t{\n\t\t\t\t\t\tlet temp: HTMLElement = this.component.onPostPlace (compHtmlElement2.parentElement, compHtmlElement2);\n\n\t\t\t\t\t\tif (temp != null)\n\t\t\t\t\t\t\tcompHtmlElement2 = temp;\n\t\t\t\t\t}\n\n\t\t\t\t\tif (typeof (Hot) !== \"undefined\")\n\t\t\t\t\t{\n\t\t\t\t\t\tif (Hot.CurrentPage != null)\n\t\t\t\t\t\t{\n\t\t\t\t\t\t\tlet componentName: string = \"\";\n\n\t\t\t\t\t\t\tif (this.component.name != null)\n\t\t\t\t\t\t\t\tcomponentName = this.component.name;\n\n\t\t\t\t\t\t\tif ((componentName == null) || (componentName === \"\"))\n\t\t\t\t\t\t\t\tcomponentName = this.id;\n\n\t\t\t\t\t\t\tif (componentName !== \"\")\n\t\t\t\t\t\t\t\tHot.CurrentPage.components[componentName] = this.component;\n\t\t\t\t\t\t}\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t}\n\t\t\n\t\t\t/**\n\t\t\t * This helps parse <tr> and other tags that do not have a parent.\n\t\t\t * \n\t\t\t * Thanks Brandon McConnell!\n\t\t\t * \n\t\t\t * From: https://stackoverflow.com/questions/67313479/make-parsefromstring-parse-without-validation\n\t\t\t * \n\t\t\t * @todo May remove this as it does not seem to work well in a lot of edge cases.\n\t\t\t */\n\t\t\tprotected looseParseFromString (parser: DOMParser, str: string) {\n\t\t\t\tstr = str.replace(/ \\/>/g, '>').replace(/(<(area|base|br|col|command|embed|hr|img|input|keygen|link|meta|param|source|track|wbr).*?>)/g, '$1</$2>');\n\t\t\t\tconst xdom = parser.parseFromString('<xml>'+str+'</xml>', 'text/xml');\n\t\t\t\tconst hdom = parser.parseFromString('', 'text/html');\n\t\t\t\tfor (let elem of Array.from(xdom.documentElement.children)) {\n\t\t\t\t\t/// @ts-ignore\n\t\t\t\t\thdom.body.appendChild(elem);\n\t\t\t\t}\n\t\t\t\tfor (let elem of Array.from(hdom.querySelectorAll('area,base,br,col,command,embed,hr,img,input,keygen,link,meta,param,source,track,wbr'))) {\n\t\t\t\t\t/// @ts-ignore\n\t\t\t\t\telem.outerHTML = '<'+elem.outerHTML.slice(1).split('<')[0];\n\t\t\t\t}\n\t\t\t\treturn hdom;\n\t\t\t}\n\n\t\t\tget observedAttributes(): string[] /// @fixme Does this REALLY have to be static? Awful if it does...\n\t\t\t{\n\t\t\t\treturn (this.component.observedAttributes);\n\t\t\t}\n\t\t}, elementOptions);\n}","import { Hot } from \"./Hot\";\nimport { HotClient } from \"./HotClient\";\nimport { HotLog } from \"./HotLog\";\nimport { HotStaq, HotStartOptions } from \"./HotStaq\";\n\n/**\n * If running in a browser, this will start HotStaq.\n */\nexport function hotStaqWebStart ()\n{\n    let hotstaqElms = document.getElementsByTagName (\"hotstaq\");\n\n    // Set this to true, just in case...\n    HotStaq.isWeb = true;\n\n    // @ts-ignore\n    if (typeof (HotStaqWeb) !== \"undefined\")\n    {\n        // @ts-ignore\n\t\tfor (let key in HotStaqWeb)\n        {\n            // @ts-ignore\n            window[key] = HotStaqWeb[key];\n        }\n    }\n\n    if (hotstaqElms.length > 0)\n    {\n        let hotstaqElm: HTMLElement = (<HTMLElement>hotstaqElms[0]);\n\n        setTimeout (async function ()\n            {\n                let getAttr = (elm: HTMLElement, attrNames: string[]) =>\n                    {\n                        for (let iIdx = 0; iIdx < attrNames.length; iIdx++)\n                        {\n                            let attrName: string = attrNames[iIdx];\n\n                            if (elm.getAttribute (attrName) != null)\n                                return (elm.getAttribute (attrName));\n\n                            if (elm.getAttribute (`data-${attrName}`) != null)\n                                return (elm.getAttribute (`data-${attrName}`));\n                        }\n\n                        return (undefined);\n                    };\n\n                let loadPage: string = getAttr (hotstaqElm, [\"load-page\", \"loadPage\", \"src\"]) || \"\";\n                let loggingLevel: string = getAttr (hotstaqElm, [\"logging-level\", \"loggingLevel\"]) || null;\n                let startDelay: string = getAttr (hotstaqElm, [\"start-delay\", \"startDelay\"]) || null;\n                let router: string = getAttr (hotstaqElm, [\"router\"]) || \"\";\n                let name: string = getAttr (hotstaqElm, [\"name\"]) || \"default\";\n                let args: string = getAttr (hotstaqElm, [\"args\"]) || null;\n                let apiLibrary: string = getAttr (hotstaqElm, [\"api-library\", \"apiLibrary\"]) || null;\n                let apiName: string = getAttr (hotstaqElm, [\"api-name\", \"apiName\"]) || null;\n                let apiUrl: string = getAttr (hotstaqElm, [\"api-url\", \"apiUrl\"]) || null;\n                let testerName: string = getAttr (hotstaqElm, [\"tester-name\", \"testerName\"]) || \"HotTesterMochaSelenium\";\n                let testerMap: string = getAttr (hotstaqElm, [\"tester-map\", \"testerMap\"]) || null;\n                let testerApiBaseUrl: string = getAttr (hotstaqElm, [\"tester-api-base-url\", \"testerApiBaseUrl\"]) || null;\n                let testerLaunchpadUrl: string = getAttr (hotstaqElm, [\"tester-launchpad-url\", \"testerLaunchpadUrl\"]) || null;\n                let dontReuseProcessor: boolean = false;\n                let passRawUrl: boolean = false;\n                let htmlSource: string = hotstaqElm.innerHTML || \"\";\n                let routerManager: { [path: string]: { redirect: string; baseRedirect: string; base: string; src: string; } } = {};\n                let routerWildcards: string[] = [];\n                let search: URLSearchParams = new URLSearchParams (window.location.search);\n\n                if (startDelay != null)\n                    await HotStaq.wait (parseInt (startDelay));\n\n                if (getAttr (hotstaqElm, [\"src\"]) != null)\n                    loadPage = getAttr (hotstaqElm, [\"src\"]);\n\n                if (getAttr (hotstaqElm, [\"passRawUrl\"]) != null)\n                    passRawUrl = true;\n\n                if (getAttr (hotstaqElm, [\"dont-reuse-processor\", \"dontReuseProcessor\"]) != null)\n                    dontReuseProcessor = true;\n\n                let hstqbaseredirect: string = search.get (\"hstqbaseredirect\");\n\n                if (hstqbaseredirect != null)\n                {\n                    hstqbaseredirect = decodeURI (hstqbaseredirect);\n                    window.history.replaceState (\"\", \"\", hstqbaseredirect);\n                    loadPage = hstqbaseredirect;\n                }\n\n                let hotstaqErrors = document.getElementsByTagName (\"hotstaq-error\");\n\n                for (let iIdx = 0; iIdx < hotstaqErrors.length; iIdx++)\n                {\n                    // @ts-ignore\n                    let hotstaqErrorElm: HTMLElement = hotstaqErrors[iIdx];\n                    let errorStatus: string = getAttr (hotstaqErrorElm, [\"status\"]);\n                    let unsupportedBrowser: string = getAttr (hotstaqErrorElm, [\"unsupported-browser-redirect\"]);\n\n                    if (unsupportedBrowser != null)\n                        HotStaq.errors[\"unsupportedBrowser\"] = { redirectToUrl: unsupportedBrowser };\n                    else\n                        HotStaq.errors[`${errorStatus}`] = { redirectToUrl: unsupportedBrowser };\n                }\n\n                // Check if async/await is available.\n                try\n                {\n                    eval (\"async () => {}\");\n                }\n                catch (ex)\n                {\n                    HotStaq.executeError (\"unsupportedBrowser\");\n                }\n\n                if (router !== \"\")\n                {\n                    let hotstaqRouterElms = document.getElementsByTagName (\"hotstaq-router\");\n\n                    for (let iIdx = 0; iIdx < hotstaqRouterElms.length; iIdx++)\n                    {\n                        // @ts-ignore\n                        let hotstaqRouterElm: HTMLElement = hotstaqRouterElms[iIdx];\n                        let routerName: string = getAttr (hotstaqRouterElm, [\"name\"]);\n                        let serveLocally: string = getAttr (hotstaqRouterElm, [\"serve-local\", \"serveLocally\"]);\n\n                        // @ts-ignore\n                        if (routerName === router)\n                        {\n                            // Load all routes from the router.\n                            for (let iJdx = 0; iJdx < hotstaqRouterElm.childNodes.length; iJdx++)\n                            {\n                                // @ts-ignore\n                                let routerElm: HTMLElement = hotstaqRouterElm.childNodes[iJdx];\n\n                                if (routerElm instanceof HTMLElement)\n                                {\n                                    if (routerElm.tagName.toUpperCase () === \"ROUTE\")\n                                    {\n                                        let routerPath: string = getAttr (routerElm, [\"path\"]);\n                                        let redirect: string = getAttr (routerElm, [\"redirect\"]);\n                                        let baseRedirect: string = getAttr (routerElm, [\"base-redirect\", \"baseRedirect\"]);\n                                        let base: string = getAttr (routerElm, [\"base\"]);\n                                        let routerSrc: string = getAttr (routerElm, [\"src\"]);\n\n                                        if (routerPath.indexOf (\"*\") > -1)\n                                            routerWildcards.push (routerPath);\n\n                                        routerManager[routerPath] = {\n                                                redirect: redirect || undefined, \n                                                baseRedirect: baseRedirect || undefined, \n                                                base: base || undefined, \n                                                src: routerSrc || undefined\n                                            };\n                                    }\n                                }\n                            }\n\n                            let checkPath: string = window.location.pathname;\n                            let gotoPath: string = window.location.pathname;\n\n                            if (serveLocally != null)\n                            {\n                                const lowerServeLocally: string = serveLocally.toLowerCase ();\n\n                                if ((lowerServeLocally === \"true\") ||\n                                    (lowerServeLocally === \"yes\") ||\n                                    (lowerServeLocally === \"1\"))\n                                {\n                                    const lastSlashPos: number = checkPath.lastIndexOf (\"/\");\n\n                                    if (lastSlashPos > -1)\n                                    {\n                                        checkPath = checkPath.substring (lastSlashPos);\n                                        gotoPath = gotoPath.substring (lastSlashPos);\n                                    }\n                                }\n                            }\n\n                            if (routerWildcards.length > 0)\n                            {\n                                // Serve locally doesn't really work with wildcards\n                                /// @fixme This isn't actually working like a wildcard should. This needs to be improved.\n                                for (let iJdx = 0; iJdx < routerWildcards.length; iJdx++)\n                                {\n                                    let routeWildcard: string = routerWildcards[iJdx];\n                                    let tempRouteWildcard: string = routeWildcard.replace (\"*\", \"\");\n\n                                    if (checkPath.indexOf (tempRouteWildcard) > -1)\n                                    {\n                                        // This simply returns the key in the routerManager to access.\n                                        checkPath = routeWildcard;\n\n                                        break;\n                                    }\n                                }\n                            }\n\n                            // Find the correct route and load it.\n                            if (routerManager[checkPath] != null)\n                            {\n                                if (routerManager[checkPath].redirect != null)\n                                {\n                                    window.location.href = routerManager[checkPath].redirect;\n\n                                    return;\n                                }\n\n                                if (routerManager[checkPath].baseRedirect != null)\n                                {\n                                    const searchParams = window.location.search;\n                                    let modifiedSearchParams = \"\";\n\n                                    if ((searchParams !== \"\") && (searchParams !== \"?\"))\n                                        modifiedSearchParams = `&${searchParams.substring (1)}`;\n\n                                    window.location.href = `${routerManager[checkPath].baseRedirect}?hstqbaseredirect=${encodeURI (gotoPath + searchParams)}${modifiedSearchParams}`;\n\n                                    return;\n                                }\n\n                                if (routerManager[checkPath].src != null)\n                                    loadPage = routerManager[checkPath].src;\n                            }\n\n                            break;\n                        }\n                    }\n                }\n\n                if (args != null)\n                    args = JSON.parse (args);\n                else\n                    args = Hot.Arguments;\n\n                let hasHtmlSource: boolean = false;\n\n                if (htmlSource !== \"\")\n                {\n                    const htmlSourceCheck: string = htmlSource.replace (/\\s/g,'');\n\n                    if (htmlSourceCheck !== \"\")\n                        hasHtmlSource = true;\n                }\n\n                let tempMode = 0;\n\n                // @ts-ignore\n                if (window[\"Hot\"] != null)\n                    tempMode = Hot.Mode;\n        \n                let processor: HotStaq = null;\n\n                if (dontReuseProcessor === false)\n                {\n                    if (typeof (Hot) !== \"undefined\")\n                    {\n                        if (Hot.CurrentPage != null)\n                        {\n                            if (Hot.CurrentPage.processor != null)\n                                processor = Hot.CurrentPage.processor;\n                        }\n                    }\n                }\n\n                if (processor == null)\n                    processor = new HotStaq ();\n\n                if (loggingLevel != null)\n                    processor.logger.logLevel = HotLog.parse (loggingLevel);\n\n                processor.mode = tempMode;\n\n                let options: HotStartOptions = {\n                        name: name,\n                        processor: processor,\n                        args: args\n                    };\n\n                if (loadPage !== \"\")\n                {\n                    if (passRawUrl === false)\n                    {\n                        if (loadPage.indexOf (\"hstqserve\") < 0)\n                            loadPage += \"?hstqserve=nahfam\";\n                    }\n\n                    options.url = loadPage;\n                }\n\n                if (testerMap != null)\n                {\n                    options.testerMap = testerMap;\n                    options.testerName = testerName;\n                }\n\n                if (testerName != null)\n                    options.testerName = testerName;\n\n                if (testerApiBaseUrl != null)\n                    options.testerAPIBaseUrl = testerApiBaseUrl;\n\n                if (testerLaunchpadUrl != null)\n                    options.testerLaunchpadUrl = testerLaunchpadUrl;\n\n                if (apiName != null)\n                {\n                    let client = new HotClient (processor);\n\n                    if (apiUrl === \"\")\n                        throw new Error (`api-url was not set!`);\n\n                    let parentLib: any = window;\n\n                    if (apiLibrary != null)\n                    {\n                        // @ts-ignore\n                        parentLib = window[apiLibrary];\n                    }\n\n                    let newAPI = new parentLib[apiName] (apiUrl, client);\n                    newAPI.connection.api = newAPI;\n                    processor.api = newAPI;\n                }\n\n                if (hasHtmlSource === false)\n                {\n                    if (loadPage === \"\")\n                        throw new Error (`The hotstaq tag must have a src, HTML contents inside it, or a router set.`);\n\n                    HotStaq.displayUrl (options);\n                }\n                else\n                {\n                    HotStaq.displayContent (options);\n                }\n            }, 50);\n    }\n}","import { HotSiteMapPath } from \"./HotSite\";\n\n/**\n * The destination to take in a map.\n */\nexport class HotTestDestination\n{\n\t/**\n\t * The destination to take.\n\t */\n\tdestination: string;\n\t/**\n\t * If set to true, this will automatically start executing it's \n\t * tests when it's time.\n\t */\n\tautoStart: boolean;\n\n\tconstructor (destination: string | HotTestDestination | HotSiteMapPath = \"\", autoStart: boolean = true)\n\t{\n\t\tif (typeof (destination) === \"string\")\n\t\t{\n\t\t\tthis.destination = destination;\n\t\t\tthis.autoStart = autoStart;\n\t\t}\n\t\telse\n\t\t{\n\t\t\tif (destination instanceof HotTestDestination)\n\t\t\t{\n\t\t\t\tthis.destination = destination.destination;\n\t\t\t\tthis.autoStart = destination.autoStart;\n\t\t\t}\n\t\t\telse\n\t\t\t{\n\t\t\t\tthis.destination = destination.path;\n\t\t\t\tthis.autoStart = destination.autoStart;\n\t\t\t}\n\t\t}\n\t}\n}","import { HotStaq } from \"./HotStaq\";\nimport { HotTestElement, HotTestElementOptions } from \"./HotTestElement\";\nimport { HotTestPage } from \"./HotTestPage\";\n\n/**\n * This actually executes the tests.\n */\nexport class HotTestDriver\n{\n\t/**\n\t * The current page.\n\t */\n\tprocessor: HotStaq;\n\t/**\n\t * The current page.\n\t */\n\tpage: HotTestPage;\n\t/**\n\t * The delay in milliseconds between each executed command.\n\t */\n\tcommandDelay: number;\n\t/**\n\t * Any data that needs to be saved between the different testing runs.\n\t */\n\tpersistentData: any;\n\n\tconstructor (processor: HotStaq, page: HotTestPage | null = null)\n\t{\n\t\tthis.processor = processor;\n\t\tthis.page = page;\n\t\tthis.commandDelay = 20;\n\t\tthis.persistentData = {};\n\t}\n\n\t/**\n\t * Get a test object by it's name. If a * is used, it will be used as a \n\t * wildcard for the object's name. If a > is used, then the name will \n\t * be treated as a CSS selector.\n\t */\n\tparseTestObject (name: string): string\n\t{\n\t\tlet pos: number = name.indexOf (\"*\");\n\t\tlet wildcard: string = \"\";\n\n\t\tif (pos > -1)\n\t\t{\n\t\t\tname = name.replace (/\\*/, \"\");\n\t\t\twildcard = \"*\";\n\t\t}\n\n\t\tlet selector: string = `[data-test-object-name${wildcard}='${name}']`;\n\t\tpos = name.indexOf (\">\");\n\n\t\tif (pos > -1)\n\t\t{\n\t\t\tname = name.replace (/\\>/, \"\");\n\t\t\tselector = name;\n\t\t}\n\n\t\treturn (selector);\n\t}\n\n\t/**\n\t * Wait for a number of milliseconds.\n\t */\n\tasync wait (numMilliseconds: number): Promise<void>\n\t{\n\t\treturn (await new Promise ((resolve, reject) =>\n\t\t\t{\n\t\t\t\tsetTimeout (() =>\n\t\t\t\t\t{\n\t\t\t\t\t\tresolve ();\n\t\t\t\t\t}, numMilliseconds);\n\t\t\t}));\n\t}\n\n\t/**\n\t * Print a message.\n\t */\n\tasync print (message: string): Promise<void>\n\t{\n\t\tprocess.stdout.write (message);\n\t}\n\n\t/**\n\t * Print a message line.\n\t */\n\tasync println (message: string): Promise<void>\n\t{\n\t\tawait this.print (`${message}\\n`);\n\t}\n\n\t/**\n\t * Disconnect this server or destroy anything associated with this HotTestDriver.\n\t */\n\tasync destroy (): Promise<void>\n\t{\n\t}\n\n\t/**\n\t * An expression to test.\n\t */\n\tasync assert (value: any, errorMessage: string = \"\"): Promise<any>\n\t{\n\t\tif (! (value))\n\t\t\tthrow new Error (errorMessage);\n\t}\n}","/**\n * Hot test element options.\n */\nexport interface IHotTestElementOptions\n{\n\t/**\n\t * Indicates that the test element must be visible in \n\t * order to select it.\n\t */\n\tmustBeVisible?: boolean;\n\t/**\n\t * If the test element is missing, ignore the error. This \n\t * will cause the rest of the function to return immediately \n\t * without any exceptions being thrown.\n\t */\n\tignoreMissingElementError?: boolean;\n}\n\n/**\n * Hot test element options.\n */\nexport class HotTestElementOptions implements IHotTestElementOptions\n{\n\t/**\n\t * Indicates that the test element must be visible in \n\t * order to select it.\n\t */\n\tmustBeVisible: boolean;\n\t/**\n\t * If the test element is missing, ignore the error. This \n\t * will cause the rest of the function to return immediately \n\t * without any exceptions being thrown.\n\t */\n\tignoreMissingElementError: boolean;\n\n\tconstructor (copy: IHotTestElementOptions = {})\n\t{\n\t\tthis.mustBeVisible = copy.mustBeVisible || true;\n\t\tthis.ignoreMissingElementError = copy.ignoreMissingElementError || false;\n\t}\n}\n\n/**\n * A test element.\n */\nexport interface IHotTestElement\n{\n\t/**\n\t * The name of the element.\n\t */\n\tname: string;\n\t/**\n\t * The name of the function to execute \n\t * while executing the test.\n\t */\n\tfunc?: string;\n\t/**\n\t * The value to use.\n\t */\n\tvalue?: any;\n}\n\n/**\n * A test element.\n */\nexport class HotTestElement implements IHotTestElement\n{\n\t/**\n\t * The name of the element.\n\t */\n\tname: string;\n\t/**\n\t * The name of the function to execute \n\t * while executing the test.\n\t */\n\tfunc: string;\n\t/**\n\t * The value to use.\n\t */\n\tvalue: any;\n\n\tconstructor (name: string | IHotTestElement, func: string = \"\", value: any = null)\n\t{\n\t\tif (typeof (name) === \"string\")\n\t\t{\n\t\t\tthis.name = name;\n\t\t\tthis.func = func;\n\t\t\tthis.value = value;\n\t\t}\n\t\telse\n\t\t{\n\t\t\tthis.name = name.name;\n\t\t\tthis.func = name.func || func;\n\t\t\tthis.value = name.value || value;\n\t\t}\n\t}\n}","import { HotTestDriver } from \"./HotTestDriver\";\nimport { HotTestDestination } from \"./HotTestDestination\";\nimport { HotTestPage } from \"./HotTestPage\";\n\n/**\n * Create a test path for later execution.\n */\nexport type HotTestPath = (driver: HotTestDriver) => Promise<any>;\n\n/**\n * Maps the paths that are taken to complete a test.\n */\nexport class HotTestMap\n{\n\t/**\n\t * The order in which paths are to be taken. Each destination is a string \n\t * in a type -> path order. The type could be either a page or api route. \n\t * For example:\n\t * ```\n\t * [\n\t *      \"page:signin_page -> signin_path\",\n\t *      \"page:account_page -> change_username_path\",\n\t *      \"page:account_page -> change_password_path\",\n\t *      \"page:account_page -> change_name_path -> change_address_path\",\n\t * \t\t\"page:account_page -> signout_path\",\n\t * \t\t\"api:account_api_route -> signout_route_method -> signout_test_path\"\n\t * ]\n\t * ```\n\t * \n\t * The first string to the left of the -> will always be the type, such as a \n\t * page or an api route. Any strings to the right of the -> will be a path, even \n\t * when chaining addtional ->'s.\n\t */\n\tdestinations: HotTestDestination[] | { [name: string]: HotTestDestination; };\n\t/**\n\t * The order in which destinations are supposed to execute. This is \n\t * ignored if the destinations are an array.\n\t */\n\tdestinationOrder: string[];\n\t/**\n\t * The test pages to execute.\n\t */\n\tpages: {\n\t\t\t[name: string]: HotTestPage\n\t\t};\n\n\tconstructor (destinations: string[] | HotTestDestination[] | { [name: string]: string | HotTestDestination; } = [], \n\t\tpages: { [name: string]: HotTestPage } = {}, destinationOrder: string[] = [])\n\t{\n\t\t// Go through and convert any strings into HotTestDestinations.\n\t\tif (destinations instanceof Array)\n\t\t{\n\t\t\tthis.destinations = [];\n\n\t\t\tfor (let iIdx = 0; iIdx < destinations.length; iIdx++)\n\t\t\t{\n\t\t\t\tlet dest = destinations[iIdx];\n\n\t\t\t\tthis.destinations.push (new HotTestDestination (dest));\n\t\t\t}\n\t\t}\n\t\telse\n\t\t{\n\t\t\tthis.destinations = {};\n\n\t\t\tfor (let key in destinations)\n\t\t\t{\n\t\t\t\tlet dest = destinations[key];\n\n\t\t\t\tthis.destinations[key] = new HotTestDestination (dest);\n\t\t\t}\n\t\t}\n\n\t\tthis.destinationOrder = destinationOrder;\n\t\tthis.pages = pages;\n\t}\n}","import { HotStaq } from \"./HotStaq\";\nimport { HotRoute } from \"./HotRoute\";\nimport { HotRouteMethod, TestCaseObject } from \"./HotRouteMethod\";\nimport { HotTestDriver } from \"./HotTestDriver\";\nimport { HotTestMap, HotTestPath } from \"./HotTestMap\";\nimport { HotTestDestination } from \"./HotTestDestination\";\nimport { HotTestPage } from \"./HotTestPage\";\nimport { HotDestination } from \"./HotDestination\";\nimport { HotTestStop } from \"./HotTestStop\";\n\n/**\n * Executes tests.\n */\nexport abstract class HotTester\n{\n\t/**\n\t * The tester name.\n\t */\n\tname: string;\n\t/**\n\t * The timeout for each test.\n\t */\n\ttimeout: number;\n\t/**\n\t * The base url that will construct future urls.\n\t */\n\tbaseUrl: string;\n\t/**\n\t * The associated processor.\n\t */\n\tprocessor: HotStaq;\n\t/**\n\t * The test maps to test.\n\t */\n\ttestMaps: { [name: string]: HotTestMap; };\n\t/**\n\t * The driver to use when running tests.\n\t */\n\tdriver: HotTestDriver;\n\t/**\n\t * Has this tester finished loading?\n\t */\n\tfinishedLoading: boolean;\n\t/**\n\t * Has this tester finished setting up?\n\t */\n\thasBeenSetup: boolean;\n\t/**\n\t * Has this tester finished setting up?\n\t */\n\thasBeenDestroyed: boolean;\n\n\tconstructor (processor: HotStaq, name: string, baseUrl: string, \n\t\tdriver: HotTestDriver, testMaps: { [name: string]: HotTestMap; } = {})\n\t{\n\t\tif (testMaps == null)\n\t\t\tthrow new Error (`The testMaps parameter can be an empty object, but cannot be null! It is set to null.`);\n\n\t\tthis.processor = processor;\n\t\tthis.name = name;\n        this.timeout = 10000;\n\t\tthis.baseUrl = baseUrl;\n\t\tthis.testMaps = testMaps;\n\t\tthis.driver = driver;\n\t\tthis.finishedLoading = false;\n\t\tthis.hasBeenSetup = false;\n\t\tthis.hasBeenDestroyed = false;\n\t}\n\n\t/**\n\t * Executed when setting up the tester.\n\t */\n\tasync setup (isWebRoute: boolean, url: string, destinationKey?: string): Promise<void>\n\t{\n\t}\n\n\t/**\n\t * Executed when destroying up the tester.\n\t */\n\tasync destroy (): Promise<void>\n\t{\n\t}\n\n\t/**\n\t * Executed when tests are started. If this returns true, it will \n\t * continue and execute all test paths. If this returns it will \n\t * skip all test paths and execute onTestEnd instead.\n\t */\n\tasync onTestStart? (destination: HotDestination, url: string, destinationKey?: string): Promise<boolean>;\n\t/**\n\t * Executed when an API test path has started. If this returns false, \n\t * the testPath will not be immediately executed afterwards.\n\t */\n\tasync onTestAPIPathStart? (destination: HotDestination, method: HotRouteMethod, \n\t\ttestName: string, continueWhenTestIsComplete?: boolean): Promise<boolean>;\n\t/**\n\t * Executed when an API test path has ended.\n\t */\n\tasync onTestAPIPathEnd? (destination: HotDestination, method: HotRouteMethod, \n\t\ttestName: string, result: any, continueWhenTestIsComplete?: boolean): Promise<void>;\n\t/**\n\t * Executed when page tests are started. If this returns false, the testPath will not be \n\t * immediately executed afterwards.\n\t */\n\tasync onTestPagePathStart? (destination: HotDestination, page: HotTestPage, \n\t\tstop: HotTestStop, continueWhenTestIsComplete?: boolean): Promise<boolean>;\n\t/**\n\t * Executed when a page test has ended.\n\t */\n\tasync onTestPagePathEnd? (destination: HotDestination, testPath: HotTestPath, \n\t\tresult: any, continueWhenTestIsComplete?: boolean): Promise<void>;\n\t/**\n\t * Executed when a command is executed.\n\t */\n\tasync onCommand? (destination: HotDestination, page: HotTestPage, stop: HotTestStop, \n\t\tcmd: string, args: string[], cmdFunc: ((cmdArgs: string[]) => Promise<void>)): Promise<void>;\n\t/**\n\t * Executed when tests are finished.\n\t */\n\tasync onTestEnd? (destination: HotDestination): Promise<void>;\n\n\t/**\n\t * Executed when this tester has been executed from the API.\n\t */\n\tasync onExecute? (): Promise<void>;\n\t/**\n\t * Executed when this tester has finished loading all data from the API.\n\t */\n\tasync onFinishedLoading? (): Promise<void>;\n\n\t/**\n\t * Waits for the API to finish loading all data.\n\t */\n\tasync waitForData (): Promise<void>\n\t{\n\t\twhile (this.finishedLoading === false)\n\t\t\tawait HotStaq.wait (10);\n\t}\n\n\t/**\n\t * Get a test page.\n\t */\n\tgetTestPage (destination: HotDestination): HotTestPage\n\t{\n\t\tlet page = this.testMaps[destination.mapName].pages[destination.page];\n\n\t\treturn (page);\n\t}\n\n\t/**\n\t * Get a test path.\n\t */\n\tgetTestPath (destination: HotDestination, pathName: string): HotTestPath\n\t{\n\t\tlet page = this.testMaps[destination.mapName].pages[destination.page];\n\n\t\treturn (page.testPaths[pathName]);\n\t}\n\n\t/**\n\t * Get a destination JSON object to use.\n\t */\n\tstatic interpretDestination (mapName: string, testDest: HotTestDestination): HotDestination\n\t{\n\t\tlet destination: string = testDest.destination;\n\t\tlet newDestination: HotDestination = {\n\t\t\t\tmapName: mapName,\n\t\t\t\tpage: \"\",\n\t\t\t\tapi: \"\",\n\t\t\t\tpaths: []\n\t\t\t};\n\t\tlet strs: string[] = destination.split (/\\-\\>/g);\n\t\tlet type: string = strs[0];\n\n\t\tif (type.length < 2)\n\t\t\treturn (null);\n\n\t\tif ((type[0] === \"/\") && (type[1] === \"/\"))\n\t\t\treturn (null);\n\n\t\tlet getType: (typeStr: string, typeDelimiter: string) => string = \n\t\t\t(typeStr: string, typeDelimiter: string): string =>\n\t\t\t{\n\t\t\t\tlet pos: number = typeStr.indexOf (typeDelimiter);\n\t\t\t\tlet typeValue: string = \"\";\n\t\t\n\t\t\t\tif (pos > -1)\n\t\t\t\t{\n\t\t\t\t\ttypeValue = typeStr.substr (pos + typeDelimiter.length);\n\t\t\t\t\ttypeValue = typeValue.trim ();\n\t\t\t\t}\n\n\t\t\t\treturn (typeValue);\n\t\t\t};\n\n\t\tnewDestination.page = getType (type, \"page:\");\n\t\tnewDestination.api = getType (type, \"api:\");\n\n\t\tfor (let iIdx = 1; iIdx < strs.length; iIdx++)\n\t\t{\n\t\t\tlet newPathStr: string = strs[iIdx];\n\t\t\tlet newPath: HotTestStop = {\n\t\t\t\t\tcmd: \"\",\n\t\t\t\t\tdest: \"\",\n\t\t\t\t\tpath: \"\"\n\t\t\t\t};\n\n\t\t\tnewPathStr = newPathStr.trim ();\n\t\t\tnewPath.dest = getType (newPathStr, \"dest:\");\n\t\t\tnewPath.cmd = getType (newPathStr, \"cmd:\");\n\t\t\tnewPath.path = getType (newPathStr, \"path:\");\n\n\t\t\tif ((newPath.dest == \"\") && (newPath.cmd == \"\") && (newPath.path == \"\"))\n\t\t\t\tnewPath.path = newPathStr;\n\n\t\t\tnewDestination.paths.push (newPath);\n\t\t}\n\n\t\treturn (newDestination);\n\t}\n\n\t/**\n\t * Execute an API's test path.\n\t */\n\tasync executeTestAPIPath (destination: HotDestination, method: HotRouteMethod, \n\t\ttestName: string, skipEventCalls: boolean = false, continueWhenTestIsComplete: boolean = false): Promise<any>\n\t{\n\t\tlet runTestPath: boolean = true;\n\n\t\tif (method == null)\n\t\t\tthrow new Error (`Trying to access null method on destination map ${destination.mapName}.`);\n\n\t\t// A dumb hack to prevent any recursion that could occur.\n\t\tif (skipEventCalls === false)\n\t\t{\n\t\t\tif (this.onTestAPIPathStart != null)\n\t\t\t\trunTestPath = await this.onTestAPIPathStart (destination, method, testName, continueWhenTestIsComplete);\n\t\t}\n\n\t\tlet result: any = null;\n\n\t\tif (runTestPath === true)\n\t\t{\n\t\t\tlet testCaseObject: TestCaseObject = method.testCases[testName];\n\n\t\t\tif (testCaseObject == null)\n\t\t\t\tthrow new Error (`HotTester: Test case object ${testName} does not exist!`);\n\n\t\t\tresult = await testCaseObject.func (this.driver);\n\t\t}\n\n\t\tif (skipEventCalls === false)\n\t\t{\n\t\t\tif (this.onTestAPIPathEnd != null)\n\t\t\t\tawait this.onTestAPIPathEnd (destination, method, testName, result, continueWhenTestIsComplete);\n\t\t}\n\n\t\treturn (result);\n\t}\n\n\t/**\n\t * Execute all test paths in an API route.\n\t * \n\t * @fixme This needs a better implementation...\n\t */\n\tasync executeTestAPIPaths (destination: HotDestination): Promise<any[]>\n\t{\n\t\tlet results: any[] = [];\n\t\tlet testMap: HotTestMap = this.testMaps[destination.mapName];\n\n\t\tif (testMap == null)\n\t\t\tthrow new Error (`HotTester: API Map ${destination.mapName} does not exist!`);\n\n\t\tif (this.processor.api == null)\n\t\t\tthrow new Error (`HotTester: Associated processor does not have an API!`);\n\n\t\tlet route: HotRoute = this.processor.api.routes[destination.api];\n\n\t\tif (route == null)\n\t\t\tthrow new Error (`HotTester: API does not have route ${destination.api}!`);\n\n\t\t// Iterate through each path in the destination until complete.\n\t\tfor (let iIdx = 0; iIdx < destination.paths.length; iIdx += 2)\n\t\t{\n\t\t\tlet stop: HotTestStop = destination.paths[iIdx];\n\t\t\tlet pathName: string = stop.path;\n\t\t\tlet method: HotRouteMethod = route.getMethod (pathName);\n\t\t\tlet nextStop: HotTestStop = destination.paths[iIdx + 1];\n\t\t\tlet testName: string = nextStop.path;\n\n\t\t\tif (method == null)\n\t\t\t\tthrow new Error (`Unable to find method related to path ${pathName} in map ${destination.mapName}`);\n\n\t\t\tlet result: any = await this.executeTestAPIPath (destination, method, testName);\n\n\t\t\tresults.push (result);\n\t\t}\n\n\t\treturn (results);\n\t}\n\n\t/**\n\t * Execute a test page path.\n\t */\n\tasync executeTestPagePath (destination: HotDestination, stop: HotTestStop, \n\t\tskipEventCalls: boolean = false, continueWhenTestIsComplete: boolean = false): Promise<any>\n\t{\n\t\tlet runTestPath: boolean = true;\n\t\tlet testMap: HotTestMap = this.testMaps[destination.mapName];\n\n\t\t/// @fixme For some reason the errors being thrown here are not being thrown.\n\t\tif (testMap == null)\n\t\t\tthrow new Error (`HotTester: Web Map ${destination.mapName} does not exist!`);\n\n\t\tlet page: HotTestPage = testMap.pages[destination.page];\n\n\t\tif (page == null)\n\t\t\tthrow new Error (`HotTester: Page ${destination.page} does not exist!`);\n\n\t\tthis.driver.page = page;\n\n\t\tlet testPathName: string = stop.path;\n\t\tlet testPath: HotTestPath = page.testPaths[testPathName];\n\n\t\t// A dumb hack to prevent any recursion that could occur.\n\t\tif (skipEventCalls === false)\n\t\t{\n\t\t\tif (this.onTestPagePathStart != null)\n\t\t\t\trunTestPath = await this.onTestPagePathStart (destination, page, stop, continueWhenTestIsComplete);\n\t\t}\n\n\t\tlet result: any = null;\n\n\t\tif (runTestPath === true)\n\t\t{\n\t\t\tif (testPath == null)\n\t\t\t\tthrow new Error (`HotTester: Test path ${testPathName} does not have a function!`);\n\n\t\t\tresult = await testPath (this.driver);\n\t\t}\n\n\t\tif (skipEventCalls === false)\n\t\t{\n\t\t\tif (this.onTestPagePathEnd != null)\n\t\t\t\tawait this.onTestPagePathEnd (destination, testPath, result, continueWhenTestIsComplete);\n\t\t}\n\n\t\treturn (result);\n\t}\n\n\t/**\n\t * Execute a command.\n\t */\n\tasync executeCommand (destination: HotDestination, page: HotTestPage, stop: HotTestStop, cmd: string): Promise<void>\n\t{\n\t\t/**\n\t\t * Check if the input command matches.\n\t\t */\n\t\tlet hasCmd: (input: string, cmd: string, hasArguments: boolean) => boolean = \n\t\t\t(input: string, cmd: string, hasArguments: boolean): boolean =>\n\t\t\t{\n\t\t\t\tlet result: boolean = false;\n\n\t\t\t\tif (stop.cmd === cmd)\n\t\t\t\t\tresult = true;\n\n\t\t\t\tconst pos: number = stop.cmd.indexOf (\"(\");\n\n\t\t\t\t// If there's parenthesis, get the incoming command.\n\t\t\t\tif (pos > -1)\n\t\t\t\t{\n\t\t\t\t\tlet inputCmd: string = stop.cmd.substr (0, pos);\n\n\t\t\t\t\tif (inputCmd === cmd)\n\t\t\t\t\t\tresult = true;\n\t\t\t\t}\n\n\t\t\t\treturn (result);\n\t\t\t};\n\t\t/**\n\t\t * Get the arguments in a command. This will only return a \n\t\t * single argument for now.\n\t\t * \n\t\t * @fixme Add support for multiple arguments.\n\t\t */\n\t\tlet getCmdArgs: (input: string) => string[] = \n\t\t\t(input: string): string[] =>\n\t\t\t{\n\t\t\t\tlet results: string[] = [];\n\t\t\t\tlet matches = input.match (/(?=\\()(.*?)(?=\\))/g);\n\n\t\t\t\tif (matches != null)\n\t\t\t\t{\n\t\t\t\t\tlet tempMatch = matches[0];\n\n\t\t\t\t\t// A little hack, since I suck at Regex :(\n\t\t\t\t\ttempMatch = tempMatch.substr (2, tempMatch.length);\n\n\t\t\t\t\tresults.push (tempMatch);\n\t\t\t\t}\n\n\t\t\t\tif (results.length < 1)\n\t\t\t\t\tthrow new Error (`HotTester: Command ${input} requires arguments, but none were supplied.`);\n\n\t\t\t\treturn (results);\n\t\t\t};\n\n\t\tlet seleniumTester: any = null;\n\t\tlet cmdFunc: ((cmdArgs: string[]) => Promise<void>) = null;\n\t\tlet args: string[] = [];\n\n\t\t// @ts-ignore\n\t\tif (typeof (HotTesterMochaSelenium) != \"undefined\")\n\t\t{// @ts-ignore\n\t\t\t// @ts-ignore - Hack to prevent recursive importing.\n\t\t\tif (this instanceof HotTesterMochaSelenium)\n\t\t\t\tseleniumTester = this;\n\t\t}\n\n\t\tif (seleniumTester != null)\n\t\t{\n\t\t\tif (hasCmd (stop.cmd, \"url\", true) === true)\n\t\t\t{\n\t\t\t\targs = getCmdArgs (stop.cmd);\n\n\t\t\t\tcmdFunc = async (cmdArgs: string[]): Promise<void> =>\n\t\t\t\t\t{\n\t\t\t\t\t\tlet input: string = cmdArgs[0];\n\n\t\t\t\t\t\tawait seleniumTester.driver.navigateToUrl (input);\n\t\t\t\t\t};\n\t\t\t}\n\n\t\t\tif (hasCmd (stop.cmd, \"waitForTestObject\", true) === true)\n\t\t\t{\n\t\t\t\targs = getCmdArgs (stop.cmd);\n\t\n\t\t\t\tcmdFunc = async (cmdArgs: string[]): Promise<void> =>\n\t\t\t\t\t{\n\t\t\t\t\t\tlet testObject: string = JSON.parse (cmdArgs[0]);\n\t\n\t\t\t\t\t\tawait seleniumTester.driver.waitForTestElement (testObject);\n\t\t\t\t\t};\n\t\t\t}\n\t\t}\n\n\t\tif (hasCmd (stop.cmd, \"waitForTesterAPIData\", false) === true)\n\t\t{\n\t\t\tcmdFunc = async (cmdArgs: string[]): Promise<void> =>\n\t\t\t\t{\n\t\t\t\t\tthis.finishedLoading = false;\n\t\t\t\t\tawait this.waitForData ();\n\t\t\t\t};\n\t\t}\n\n\t\tif (hasCmd (stop.cmd, \"wait\", true) === true)\n\t\t{\n\t\t\targs = getCmdArgs (stop.cmd);\n\n\t\t\tcmdFunc = async (cmdArgs: string[]): Promise<void> =>\n\t\t\t\t{\n\t\t\t\t\tlet numMilliseconds: number = parseInt (cmdArgs[0]);\n\n\t\t\t\t\tawait HotStaq.wait (numMilliseconds);\n\t\t\t\t};\n\t\t}\n\n\t\tif (hasCmd (stop.cmd, \"print\", true) === true)\n\t\t{\n\t\t\targs = getCmdArgs (stop.cmd);\n\n\t\t\tcmdFunc = async (cmdArgs: string[]): Promise<void> =>\n\t\t\t\t{\n\t\t\t\t\tlet input: string = cmdArgs[0];\n\n\t\t\t\t\tawait this.driver.print (input);\n\t\t\t\t};\n\t\t}\n\n\t\tif (hasCmd (stop.cmd, \"println\", true) === true)\n\t\t{\n\t\t\targs = getCmdArgs (stop.cmd);\n\n\t\t\tcmdFunc = async (cmdArgs: string[]): Promise<void> =>\n\t\t\t\t{\n\t\t\t\t\tlet input: string = cmdArgs[0];\n\n\t\t\t\t\tawait this.driver.println (input);\n\t\t\t\t};\n\t\t}\n\n\t\tif (cmdFunc == null)\n\t\t\tthrow new Error (`HotTester: Command ${stop.cmd} does not exist!`);\n\n\t\tawait this.onCommand (destination, page, stop, cmd, args, cmdFunc);\n\t}\n\n\t/**\n\t * Execute all test paths in a page.\n\t */\n\tasync executeTestPagePaths (destination: HotDestination, continueWhenTestIsComplete: boolean = false): Promise<any[]>\n\t{\n\t\tlet results: any[] = [];\n\t\tlet testMap: HotTestMap = this.testMaps[destination.mapName];\n\n\t\t/// @fixme For some reason the errors being thrown here are not being thrown.\n\t\tif (testMap == null)\n\t\t\tthrow new Error (`HotTester: Web Map ${destination.mapName} does not exist!`);\n\n\t\t// Iterate through each path in the destination until complete.\n\t\tfor (let iIdx = 0; iIdx < destination.paths.length; iIdx++)\n\t\t{\n\t\t\tlet stop: HotTestStop = destination.paths[iIdx];\n\t\t\tlet result: any = null;\n\t\t\tlet page: HotTestPage = testMap.pages[destination.page];\n\t\n\t\t\tif (page == null)\n\t\t\t\tthrow new Error (`HotTester: Page ${destination.page} does not exist!`);\n\n\t\t\tif (stop.dest !== \"\")\n\t\t\t{\n\t\t\t\tif (testMap.destinations instanceof Array)\n\t\t\t\t\tthrow new Error (`HotTester: When using type 'dest' in a destination string, all destinations in map ${destination.mapName} must be named.`);\n\n\t\t\t\tlet testDest: HotTestDestination = testMap.destinations[stop.dest];\n\t\t\t\tlet newDestination: HotDestination = HotTester.interpretDestination (\n\t\t\t\t\t\t\t\t\t\t\t\t\tdestination.mapName, testDest);\n\n\t\t\t\tif (newDestination != null)\n\t\t\t\t\tresult = await this.executeTestPagePaths (newDestination);\n\t\t\t}\n\n\t\t\tif (stop.cmd !== \"\")\n\t\t\t\tawait this.executeCommand (destination, page, stop, stop.cmd);\n\n\t\t\tif (stop.path !== \"\")\n\t\t\t\tresult = await this.executeTestPagePath (destination, stop, false, continueWhenTestIsComplete);\n\n\t\t\tresults.push (result);\n\t\t}\n\n\t\treturn (results);\n\t}\n\n\t/**\n\t * Execute the tests.\n\t */\n\tasync execute (mapName: string): Promise<void>\n\t{\n\t\tlet map: HotTestMap = this.testMaps[mapName];\n\n\t\tif (map == null)\n\t\t\tthrow new Error (`HotTester: Map ${mapName} does not exist!`);\n\n\t\tthis.processor.logger.verbose (`HotTester: Executing map ${mapName}...`);\n\n\t\t// Process routes testing first.\n\t\tlet routeKey: string = this.processor.getRouteKeyFromName (mapName);\n\t\tlet url: string = \"\";\n\n\t\tif (this.baseUrl === \"\")\n\t\t{\n\t\t\t\n\t\t}\n\n\t\tif (routeKey !== \"\")\n\t\t\turl = `${this.baseUrl}${routeKey}`;\n\n\t\tlet executeDestination: (testDest: HotTestDestination, destinationKey?: string) => Promise<void> = \n\t\t\tasync (testDest: HotTestDestination, destinationKey: string = \"\") =>\n\t\t\t{\n\t\t\t\tif (testDest.autoStart === false)\n\t\t\t\t\treturn;\n\n\t\t\t\ttry\n\t\t\t\t{\n\t\t\t\t\tthis.processor.logger.verbose (() => `HotTester: Executing ${mapName} destination ${JSON.stringify (testDest)}...`);\n\t\t\t\t\tlet destination: HotDestination = HotTester.interpretDestination (mapName, testDest);\n\t\t\t\t\tlet isWebRoute: boolean = false;\n\t\t\t\t\tlet runTestPaths: boolean = true;\n\n\t\t\t\t\tif (destination.page !== \"\")\n\t\t\t\t\t\tisWebRoute = true;\n\n\t\t\t\t\tif (this.setup != null)\n\t\t\t\t\t{\n\t\t\t\t\t\tif (this.hasBeenSetup === false)\n\t\t\t\t\t\t{\n\t\t\t\t\t\t\tawait this.setup (isWebRoute, url, destinationKey);\n\t\t\t\t\t\t\tthis.hasBeenSetup = true;\n\t\t\t\t\t\t\tthis.hasBeenDestroyed = false;\n\t\t\t\t\t\t}\n\t\t\t\t\t}\n\t\t\n\t\t\t\t\tif (this.onTestStart != null)\n\t\t\t\t\t\trunTestPaths = await this.onTestStart (destination, url, destinationKey);\n\t\t\n\t\t\t\t\tif (runTestPaths === true)\n\t\t\t\t\t{\n\t\t\t\t\t\tif (destination.page !== \"\")\n\t\t\t\t\t\t\tawait this.executeTestPagePaths (destination);\n\t\t\n\t\t\t\t\t\tif (destination.api !== \"\")\n\t\t\t\t\t\t\tawait this.executeTestAPIPaths (destination);\n\t\t\t\t\t}\n\t\t\t\n\t\t\t\t\tif (this.onTestEnd != null)\n\t\t\t\t\t\tawait this.onTestEnd (destination);\n\n\t\t\t\t\tif (this.destroy != null)\n\t\t\t\t\t{\n\t\t\t\t\t\tif (this.hasBeenDestroyed === false)\n\t\t\t\t\t\t{\n\t\t\t\t\t\t\tawait this.destroy ();\n\t\t\t\t\t\t\tthis.hasBeenDestroyed = true;\n\t\t\t\t\t\t\tthis.hasBeenSetup = false;\n\t\t\t\t\t\t}\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t\tcatch (ex)\n\t\t\t\t{\n\t\t\t\t\tthrow ex;\n\t\t\t\t}\n\t\t\t};\n\n\t\t// If the map destinations are in an array, just execute those in order.\n\t\tif (map.destinations instanceof Array)\n\t\t{\n\t\t\tfor (let iIdx = 0; iIdx < map.destinations.length; iIdx++)\n\t\t\t{\n\t\t\t\tlet testDest: HotTestDestination = map.destinations[iIdx];\n\n\t\t\t\tawait executeDestination (testDest);\n\t\t\t}\n\t\t}\n\t\telse\n\t\t{\n\t\t\t// If there's a destination order, use that.\n\t\t\tif (map.destinationOrder.length > 0)\n\t\t\t{\n\t\t\t\tlet hasExecutedKeys: string[] = [];\n\n\t\t\t\t// Go through the destination order and execute each one.\n\t\t\t\tfor (let iIdx = 0; iIdx < map.destinationOrder.length; iIdx++)\n\t\t\t\t{\n\t\t\t\t\tlet orderKey: string = map.destinationOrder[iIdx];\n\t\t\t\t\tlet testDest: HotTestDestination = map.destinations[orderKey];\n\n\t\t\t\t\tif (testDest == null)\n\t\t\t\t\t\tthrow new Error (`HotTester: Destination ${orderKey} does not exist!`);\n\n\t\t\t\t\thasExecutedKeys.push (orderKey);\n\t\t\t\t\tawait executeDestination (testDest, orderKey);\n\t\t\t\t}\n\n\t\t\t\t// Execute the rest of the destinations that have not been executed yet.\n\t\t\t\tfor (let key in map.destinations)\n\t\t\t\t{\n\t\t\t\t\tlet executeDest: boolean = true;\n\n\t\t\t\t\tfor (let iIdx = 0; iIdx < hasExecutedKeys.length; iIdx++)\n\t\t\t\t\t{\n\t\t\t\t\t\tlet executedKey: string = hasExecutedKeys[iIdx];\n\n\t\t\t\t\t\tif (executedKey === key)\n\t\t\t\t\t\t{\n\t\t\t\t\t\t\texecuteDest = false;\n\n\t\t\t\t\t\t\tbreak;\n\t\t\t\t\t\t}\n\t\t\t\t\t}\n\n\t\t\t\t\tif (executeDest === true)\n\t\t\t\t\t{\n\t\t\t\t\t\tlet testDest: HotTestDestination = map.destinations[key];\n\n\t\t\t\t\t\tawait executeDestination (testDest, key);\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t}\n\t\t\telse\n\t\t\t{\n\t\t\t\t// Execute the destinations in any order.\n\t\t\t\tfor (let key in map.destinations)\n\t\t\t\t{\n\t\t\t\t\tlet testDest: HotTestDestination = map.destinations[key];\n\n\t\t\t\t\tawait executeDestination (testDest, key);\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\t}\n}","import { EventExecutionType, HotAPI } from \"./HotAPI\";\nimport { HotRoute } from \"./HotRoute\";\nimport { HotClient } from \"./HotClient\";\nimport { HotServer } from \"./HotServer\";\nimport { HotTestDriver } from \"./HotTestDriver\";\nimport { HotTester } from \"./HotTester\";\nimport { HotTestMap, HotTestPath } from \"./HotTestMap\";\nimport { HotEventMethod, ServerRequest } from \"./HotRouteMethod\";\n\nexport class HotTesterAPI extends HotAPI\n{\n\tconstructor (baseUrl: string, connection: HotServer | HotClient = null, db: any = null)\n\t{\n\t\tsuper(baseUrl, connection, db);\n\n\t\tthis.executeEventsUsing = EventExecutionType.HotAPI;\n\n\t\tlet route: HotRoute = new HotRoute (connection, \"tester\");\n\t\troute.addMethod ({\n\t\t\t\t\"name\": \"pageLoaded\", \n\t\t\t\t\"onServerExecute\": this.pageLoaded,\n\t\t\t\t\"parameters\": {\n\t\t\t\t\t\t\"testerName\": {\n\t\t\t\t\t\t\t\"required\": true,\n\t\t\t\t\t\t\t\"type\": \"string\",\n\t\t\t\t\t\t\t\"description\": \"The name of the tester executing the test.\"\n\t\t\t\t\t\t},\n\t\t\t\t\t\t\"testerMap\": {\n\t\t\t\t\t\t\t\"required\": true,\n\t\t\t\t\t\t\t\"type\": \"string\",\n\t\t\t\t\t\t\t\"description\": \"The tester map executing the test.\"\n\t\t\t\t\t\t},\n\t\t\t\t\t\t\"pageName\": {\n\t\t\t\t\t\t\t\"required\": true,\n\t\t\t\t\t\t\t\"type\": \"string\",\n\t\t\t\t\t\t\t\"description\": \"The name of the page executing the test.\"\n\t\t\t\t\t\t},\n\t\t\t\t\t\t\"testElements\": {\n\t\t\t\t\t\t\t\"required\": true,\n\t\t\t\t\t\t\t\"type\": \"array\",\n\t\t\t\t\t\t\t\"description\": \"The test elements on the page.\"\n\t\t\t\t\t\t},\n\t\t\t\t\t\t\"testPaths\": {\n\t\t\t\t\t\t\t\"required\": true,\n\t\t\t\t\t\t\t\"type\": \"array\",\n\t\t\t\t\t\t\t\"description\": \"The test paths on the page.\"\n\t\t\t\t\t\t}\n\t\t\t\t\t},\n\t\t\t\t\"returns\": \"Returns true as an acknowledgement.\"\n\t\t\t});\n\t\troute.addMethod ({\n\t\t\t\t\"name\": \"executeTests\",\n\t\t\t\t\"onServerExecute\": this.executeTests,\n\t\t\t\t\"parameters\": {\n\t\t\t\t\t\"testerName\": {\n\t\t\t\t\t\t\"required\": true,\n\t\t\t\t\t\t\"type\": \"string\",\n\t\t\t\t\t\t\"description\": \"The name of the tester executing the test.\"\n\t\t\t\t\t},\n\t\t\t\t\t\"testerMap\": {\n\t\t\t\t\t\t\"required\": true,\n\t\t\t\t\t\t\"type\": \"object\",\n\t\t\t\t\t\t\"description\": \"The tester map to execute.\"\n\t\t\t\t\t}\n\t\t\t\t},\n\t\t\t\t\"returns\": \"Returns true when tests are complete.\"\n\t\t\t});\n\t\troute.addMethod ({\n\t\t\t\t\"name\": \"heartbeat\",\n\t\t\t\t\"type\": HotEventMethod.GET,\n\t\t\t\t\"onServerExecute\": this.heartbeat,\n\t\t\t\t\"returns\": \"Returns true as an acknowledgement.\"\n\t\t\t});\n\t\tthis.addRoute (route);\n\t}\n\n\t/**\n\t * This is called when the page has finished loading in development mode.\n\t */\n\tasync pageLoaded (request: ServerRequest): Promise<any>\n\t{\n\t\tlet testerObj: {\n\t\t\t\ttesterName: string;\n\t\t\t\ttesterMap: string;\n\t\t\t\tpageName: string;\n\t\t\t\ttestElements: any;\n\t\t\t\ttestPathsStrs: any;\n\t\t\t} = {\n\t\t\t\ttesterName: request.jsonObj[\"testerName\"],\n\t\t\t\ttesterMap: request.jsonObj[\"testerMap\"],\n\t\t\t\tpageName: request.jsonObj[\"pageName\"],\n\t\t\t\ttestElements: request.jsonObj[\"testElements\"],\n\t\t\t\ttestPathsStrs: request.jsonObj[\"testPaths\"]\n\t\t\t};\n\n\t\tfor (let key in testerObj)\n\t\t{\n\t\t\t// @ts-ignore\n\t\t\tlet testObj: any = testerObj[key];\n\t\t\tlet throwError: boolean = false;\n\n\t\t\tif (testObj == null)\n\t\t\t\tthrowError = true;\n\n\t\t\tif ((testerObj.testerName == \"\") || \n\t\t\t\t(testerObj.testerMap === \"\") || \n\t\t\t\t(testerObj.testElements === \"\") || \n\t\t\t\t(testerObj.testPathsStrs === \"\"))\n\t\t\t{\n\t\t\t\tthrowError = true;\n\t\t\t}\n\n\t\t\tif (throwError === true)\n\t\t\t\tthrow new Error (`TesterAPI: Object ${key} was not passed.`);\n\t\t}\n\n\t\ttesterObj.testElements = JSON.parse (testerObj.testElements);\n\t\ttesterObj.testPathsStrs = JSON.parse (testerObj.testPathsStrs);\n\n\t\tlet testPaths: { [name: string]: HotTestPath; } = {};\n\n\t\tfor (let key in testerObj.testPathsStrs)\n\t\t{\n\t\t\tlet testPath: (driver: HotTestDriver, ...args: any) => Promise<any> = \n\t\t\t\teval (testerObj.testPathsStrs[key]);\n\n\t\t\ttestPaths[key] = testPath;\n\t\t}\n\n\t\tlet tester: HotTester = this.connection.processor.testers[testerObj.testerName];\n\n\t\tif (tester == null)\n\t\t\tthrow new Error (`TesterAPI: Tester ${testerObj.testerName} does not exist!`);\n\n\t\tlet testMap: HotTestMap = tester.testMaps[testerObj.testerMap];\n\n\t\tif (testMap == null)\n\t\t\tthrow new Error (`TesterAPI: Tester map ${testerObj.testerMap} does not exist!`);\n\n\t\ttestMap.pages[testerObj.pageName] = {\n\t\t\t\t\"testElements\": {},\n\t\t\t\t\"testPaths\": {}\n\t\t\t};\n\t\ttestMap.pages[testerObj.pageName].testElements = testerObj.testElements;\n\t\ttestMap.pages[testerObj.pageName].testPaths = testPaths;\n\n\t\ttester.finishedLoading = true;\n\n\t\tif (tester.onFinishedLoading != null)\n\t\t\tawait tester.onFinishedLoading ();\n\n\t\treturn (true);\n\t}\n\n\t/**\n\t * Execute the tests for a page.\n\t */\n\tasync executeTests (req: ServerRequest): Promise<any>\n\t{\n\t\tlet testerName: string = req.jsonObj[\"testerName\"];\n\t\tlet testerMap: string = req.jsonObj[\"testerMap\"];\n\n\t\tif ((testerName == null) || (testerMap == null))\n\t\t\tthrow new Error (\"TesterAPI: Not all required json objects were passed.\");\n\n\t\tif ((testerName === \"\") || (testerMap === \"\"))\n\t\t\tthrow new Error (\"TesterAPI: Not all required json objects were passed.\");\n\n\t\tlet server: HotServer = (<HotServer>this.connection);\n\n\t\t// @ts-ignore\n\t\tif (server.executeTests != null)\n\t\t{\n\t\t\t// @ts-ignore\n\t\t\tawait server.executeTests (testerName, testerMap);\n\t\t}\n\n\t\treturn (true);\n\t}\n\n\t/**\n\t * Responds with true to heartbeat requests.\n\t */\n\tasync heartbeat (req: ServerRequest): Promise<any>\n\t{\n\t\treturn (true);\n\t}\n}","module.exports = {};","// The module cache\nvar __webpack_module_cache__ = {};\n\n// The require function\nfunction __webpack_require__(moduleId) {\n\t// Check if module is in cache\n\tvar cachedModule = __webpack_module_cache__[moduleId];\n\tif (cachedModule !== undefined) {\n\t\treturn cachedModule.exports;\n\t}\n\t// Create a new module (and put it into the cache)\n\tvar module = __webpack_module_cache__[moduleId] = {\n\t\t// no module.id needed\n\t\t// no module.loaded needed\n\t\texports: {}\n\t};\n\n\t// Execute the module function\n\t__webpack_modules__[moduleId].call(module.exports, module, module.exports, __webpack_require__);\n\n\t// Return the exports of the module\n\treturn module.exports;\n}\n\n","__webpack_require__.g = (function() {\n\tif (typeof globalThis === 'object') return globalThis;\n\ttry {\n\t\treturn this || new Function('return this')();\n\t} catch (e) {\n\t\tif (typeof window === 'object') return window;\n\t}\n})();","import { HotStaq, HotStartOptions, IHotStaq } from \"./HotStaq\";\nimport { HotSite, HotSiteRoute, HotSiteMapPath } from \"./HotSite\";\nimport { Hot, DeveloperMode } from \"./Hot\";\nimport { HotAsset } from \"./HotAsset\";\nimport { HotModule } from \"./HotModule\";\nimport { HotComponent, HotComponentOutput, IHotComponent } from \"./HotComponent\";\nimport { HotFile } from \"./HotFile\";\nimport { HotLog, HotLogLevel } from \"./HotLog\";\nimport { HotPage } from \"./HotPage\";\n\n// Server stuff\nimport { HotAPI, EventExecutionType, APItoLoad } from \"./HotAPI\";\nimport { HotRoute } from \"./HotRoute\";\nimport { HotRouteMethod, HotEventMethod, ServerRequest } from \"./HotRouteMethod\";\nimport { HotServer, HotServerType } from \"./HotServer\";\nimport { HotClient } from \"./HotClient\";\n\n// Testing stuff\nimport { HotTestDriver } from \"./HotTestDriver\";\nimport { IHotTestElement, HotTestElement, HotTestElementOptions, IHotTestElementOptions } from \"./HotTestElement\";\nimport { HotTester } from \"./HotTester\";\nimport { HotTestStop } from \"./HotTestStop\";\nimport { HotDestination } from \"./HotDestination\";\n//import { HotTesterMocha } from \"./HotTesterMocha\";\n//import { HotTesterMochaSelenium } from \"./HotTesterMochaSelenium\";\nimport { HotTesterAPI } from \"./HotTesterAPI\";\nimport { HotTestMap, HotTestPath } from \"./HotTestMap\";\nimport { HotTestDestination } from \"./HotTestDestination\";\nimport { HotTestPage } from \"./HotTestPage\";\n\nHotStaq.isWeb = true;\n\n// Can't export interfaces from here :(\n\nexport {\n    HotStaq,\n    Hot,\n    HotModule,\n    HotAsset,\n    DeveloperMode,\n    HotComponent,\n    HotAPI,\n    EventExecutionType,\n    HotFile,\n    HotLog,\n    HotLogLevel,\n    HotPage,\n    HotRoute,\n    HotRouteMethod,\n    HotEventMethod,\n    ServerRequest,\n    HotServer,\n    HotServerType,\n    HotClient,\n    HotTester,\n    HotTesterAPI,\n    HotTestMap,\n    HotTestDestination,\n    HotTestElement,\n    HotTestElementOptions,\n    HotTestDriver\n};"],"names":["module","exports","self","FormData","window","assign","target","i","arguments","length","source","key","init","converter","defaultAttributes","set","value","attributes","document","expires","Date","now","toUTCString","encodeURIComponent","replace","decodeURIComponent","escape","stringifiedAttributes","attributeName","split","cookie","write","Object","create","get","cookies","jar","parts","slice","join","foundKey","read","e","remove","withAttributes","this","withConverter","freeze","path","factory","global","Error","getGlobal","fetch","bind","Headers","Request","Response","DeveloperMode","Hot","static","file","args","HotStaq","isWeb","lowerFile","toLowerCase","indexOf","echo","getFile","parentObject","output","g","eval","apply","moduleName","foundModule","CurrentPage","processor","getModule","newModule","Function","loadHTML","addModule","fileName","tempFile","page","content","process","HotFile","name","url","localFile","checkFile","load","route","data","httpMethod","HotEventMethod","POST","files","result","api","makeCall","jsonRequest","GET","fetchObj","JSON","stringify","res","ok","status","statusText","json","ex","message","requestInit","Output","iIdx","CSS","cssFile","cssOut","cssStr","JSFiles","jsFile","jsFileOut","jsFileStr","JSScripts","jsScript","jsScriptOut","jsScriptsStr","Arguments","HotTestElement","Mode","Production","API","TesterAPI","Data","Cookies","PublicKeys","EventExecutionType","constructor","baseUrl","connection","db","description","createFunctions","executeEventsUsing","HotRoute","authCredentials","userAuth","routes","onPreRegister","onPostRegister","setDBSchema","schema","getDB","getDBSchema","addRoute","routeMethod","executeFunction","routeName","addMethod","HotRouteMethod","newRoute","methods","currentRoute","newRouteMethod","type","routeStr","getRouteUrl","authCredential","registerRoute","HotServer","registerRoutes","httpMethodStr","toUpperCase","substr","keys","formData","append","method","body","jsonRes","headers","Promise","resolve","reject","then","jsonObj","catch","reason","escapedContent","fileUrl","fileContent","RegExp","testerAPI","HotServerType","HTTP","logger","copy","htmlElements","tag","elementOptions","undefined","observedAttributes","inner","events","onCreated","element","throwAllErrors","setContent","getContent","text","loadUrl","httpGet","loadLocalFile","fs","readFile","err","toString","contentRegex","contentProcessor","offContentProcessor","numRemoveFromBeginning","numRemoveFromEnd","exec","previousIndex","start","index","end","lastIndex","prevContent","startChars","endChars","triggerChar","pos","startTriggerPos","nestedCounter","rpos","lastIndexOf","epos","tempepos","thisContent","parserOptions","outputCommands","allowStringify","STRINGIFY_START","STRINGIFY_END","processContent","regexFound","offContent","tempOutput","processNestedContent","regexFound2","offContent3","tempOutput2","out","tempOutput3","tempOutput4","Development","foundStr","parse","createTestElement","foundStr2","testElm","obj","Array","testElements","func","tempOutput5","mode","publicKeys","getAPI","getTesterAPI","parseContent","returnedOutput","executionContent","newVar","newVarValue","contentName","SyntaxError","hot","finalOutput","HotLogLevel","logLevel","All","level","Info","Warning","Verbose","None","log","error","warning","info","verbose","console","warn","msg","stack","import","html","css","js","componentLibrary","components","outputCSS","echoOut","outputAsset","asset","outputJS","assetName","include","loadHotFiles","outputComponents","assetType","assets","callback","loadAsset","HotAsset","testerName","testerMap","testPaths","addFile","push","addTestElement","elm","getTestElement","createTestPath","pathName","driverFunc","onRegister","onAuthorizeUser","version","prefix","errors","createError","testCases","getMethod","foundMethod","req","wsSocket","authorizedValue","queryObj","onExecute","onServerAuthorize","returns","parameters","param","onServerExecute","onClientExecute","isRegistered","executeSetup","testCaseName","addTestCase","newTestCase","testCaseFunction","testCaseId","testCase","methodName","serverType","listenAddress","ports","http","https","ssl","cert","ca","redirectHTTPtoHTTPS","secrets","setAPI","HotTesterMocha","HotTesterMochaSelenium","HotTestSeleniumDriver","HotLog","startDelay","pages","modules","hotSite","apiContent","testerApiContent","pageContent","testers","objWithParam","required","throwException","defaultValue","errType","redirectToUrl","location","href","numMilliseconds","setTimeout","addPage","getPage","pageName","throwEx","tempName","substring","context","val","aryArgs","prototype","call","addComponent","ComponentType","tempApi","tempComponentObj","componentType","registerComponent","str","tempStr","parsedXML","DOMParser","parseFromString","querySelector","documentElement","children","tagName","fixedStr","parent","foundParent","htmlHandler","fixHTML","newDOM","results","child","appendChild","hotsiteName","isValid","validForNewPackages","hotsite","params","prevValue","processHotSite","tester","checkHotSiteName","HotPage","mapName","testMap","map","testMaps","HotTestMap","destinations","dest","HotTestDestination","key2","destinationOrder","apis","component","componentUrl","ComponentClass","disableFileLoading","addTester","loadHotSite","jsonStr","ext","ppath","extname","normalize","HotIO","readTextFile","yaml","hotsitePath","saveHotSite","hotsiteStr","writeTextFile","forceContentLoading","loadUrlContent","newFile","loadContent","generateContent","routeKey","jsSrcPath","passArgs","apiScripts","apiCode","server","globalApi","sendJSContent","jsapi","libraryName","apiName","tempAPIContent","jsapipath","secret","serverConn","passSecretFromAPI","env","envKey","tempContent","developerModeStr","testerAPIStr","testing","web","testerAPIUrl","loadFiles","testerUrl","testerLaunchpadUrl","launchpadUrl","startDelayStr","fixContent","createExpressRoutes","expressApp","send","getWebTestingMaps","maps","getAPITestingMaps","getRouteKeyFromName","getRouteFromName","foundRoute","executeTests","execute","executeAllWebTests","executeAllAPITests","localFilepath","options","readyFunc","readyState","addEventListener","getElementsByTagName","innerHTML","tmpScripts","scripts","s","createElement","parentNode","removeChild","resolve2","reject2","onload","hasSrc","getAttribute","setAttribute","isReadyForTesting","wait","onReadyForTesting","testerAPIBaseUrl","client","HotClient","HotTesterAPI","onReady","setupTesters","processUrl","setupClientTesters","useOutput","hotStaqWebStart","customElements","processorComponents","define","HTMLElement","super","componentInfo","hotComponent","handleAttributes","attr","attrName","attrValue","attrTempName","onPreOutput","outputs","onPostOutput","componentOutputs","iKdx","htmlStr","addFunctionsTo","onParsed","onFixHTML","childrenToReadd","newObj","onParseDOM","throwErr","replaceWith","click","event","objectFunctions","getOwnPropertyNames","objFunc","isNewFunction","HotComponent","keepContext","onPrePlace","compHtmlElement2","onParentPlace","closestSelector","parentElm","foundNode","parentElement","documentSelector","placeElmInParent","parentNodeToCheck","placeHereParent","childToPlace","parentNodeCheckCounter","HTMLHtmlElement","placeHereArray","querySelectorAll","placeHere","placeHereAttrArray","placedChild","placeHereParentAttr","onPostPlace","temp","componentName","id","looseParseFromString","parser","xdom","hdom","elem","from","outerHTML","hotstaqElms","HotStaqWeb","hotstaqElm","getAttr","attrNames","loadPage","loggingLevel","router","apiLibrary","apiUrl","testerApiBaseUrl","dontReuseProcessor","passRawUrl","htmlSource","routerManager","routerWildcards","search","URLSearchParams","parseInt","hstqbaseredirect","decodeURI","history","replaceState","hotstaqErrors","hotstaqErrorElm","errorStatus","unsupportedBrowser","executeError","hotstaqRouterElms","hotstaqRouterElm","routerName","serveLocally","iJdx","childNodes","routerElm","routerPath","redirect","baseRedirect","base","routerSrc","src","checkPath","pathname","gotoPath","lowerServeLocally","lastSlashPos","routeWildcard","tempRouteWildcard","searchParams","modifiedSearchParams","encodeURI","hasHtmlSource","htmlSourceCheck","tempMode","parentLib","newAPI","displayUrl","displayContent","destination","autoStart","commandDelay","persistentData","parseTestObject","wildcard","selector","print","stdout","println","destroy","assert","errorMessage","mustBeVisible","ignoreMissingElementError","HotTester","driver","timeout","finishedLoading","hasBeenSetup","hasBeenDestroyed","setup","isWebRoute","destinationKey","waitForData","getTestPage","getTestPath","testDest","newDestination","paths","strs","getType","typeStr","typeDelimiter","typeValue","trim","newPathStr","newPath","cmd","executeTestAPIPath","testName","skipEventCalls","continueWhenTestIsComplete","runTestPath","onTestAPIPathStart","testCaseObject","onTestAPIPathEnd","executeTestAPIPaths","executeTestPagePath","stop","testPathName","testPath","onTestPagePathStart","onTestPagePathEnd","executeCommand","hasCmd","input","hasArguments","getCmdArgs","matches","match","tempMatch","seleniumTester","cmdFunc","cmdArgs","navigateToUrl","testObject","waitForTestElement","onCommand","executeTestPagePaths","interpretDestination","executeDestination","runTestPaths","onTestStart","onTestEnd","hasExecutedKeys","orderKey","executeDest","HotAPI","pageLoaded","heartbeat","request","testerObj","testPathsStrs","testObj","throwError","onFinishedLoading","__webpack_module_cache__","__webpack_require__","moduleId","cachedModule","__webpack_modules__","globalThis","HotModule","ServerRequest","HotTestDriver","HotTestElementOptions"],"sourceRoot":""}
1
+ var HotStaqWeb;(()=>{var __webpack_modules__={230:t=>{t.exports="object"==typeof self?self.FormData:window.FormData},646:function(t){t.exports=function(){"use strict";function t(t){for(var e=1;e<arguments.length;e++){var n=arguments[e];for(var r in n)t[r]=n[r]}return t}return function e(n,r){function o(e,o,s){if("undefined"!=typeof document){"number"==typeof(s=t({},r,s)).expires&&(s.expires=new Date(Date.now()+864e5*s.expires)),s.expires&&(s.expires=s.expires.toUTCString()),e=encodeURIComponent(e).replace(/%(2[346B]|5E|60|7C)/g,decodeURIComponent).replace(/[()]/g,escape);var i="";for(var l in s)s[l]&&(i+="; "+l,!0!==s[l]&&(i+="="+s[l].split(";")[0]));return document.cookie=e+"="+n.write(o,e)+i}}return Object.create({set:o,get:function(t){if("undefined"!=typeof document&&(!arguments.length||t)){for(var e=document.cookie?document.cookie.split("; "):[],r={},o=0;o<e.length;o++){var s=e[o].split("="),i=s.slice(1).join("=");try{var l=decodeURIComponent(s[0]);if(r[l]=n.read(i,l),t===l)break}catch(t){}}return t?r[t]:r}},remove:function(e,n){o(e,"",t({},n,{expires:-1}))},withAttributes:function(n){return e(this.converter,t({},this.attributes,n))},withConverter:function(n){return e(t({},this.converter,n),this.attributes)}},{attributes:{value:Object.freeze(r)},converter:{value:Object.freeze(n)}})}({read:function(t){return'"'===t[0]&&(t=t.slice(1,-1)),t.replace(/(%[\dA-F]{2})+/gi,decodeURIComponent)},write:function(t){return encodeURIComponent(t).replace(/%(2[346BF]|3[AC-F]|40|5[BDE]|60|7[BCD])/g,decodeURIComponent)}},{path:"/"})}()},300:(t,e)=>{"use strict";var n=function(){if("undefined"!=typeof self)return self;if("undefined"!=typeof window)return window;if(void 0!==n)return n;throw new Error("unable to locate global object")}();t.exports=e=n.fetch,n.fetch&&(e.default=n.fetch.bind(n)),e.Headers=n.Headers,e.Request=n.Request,e.Response=n.Response},507:function(t,e,n){"use strict";var r=this&&this.__awaiter||function(t,e,n,r){return new(n||(n=Promise))((function(o,s){function i(t){try{a(r.next(t))}catch(t){s(t)}}function l(t){try{a(r.throw(t))}catch(t){s(t)}}function a(t){var e;t.done?o(t.value):(e=t.value,e instanceof n?e:new n((function(t){t(e)}))).then(i,l)}a((r=r.apply(t,e||[])).next())}))},o=this&&this.__importDefault||function(t){return t&&t.__esModule?t:{default:t}};Object.defineProperty(e,"__esModule",{value:!0}),e.Hot=e.DeveloperMode=void 0;const s=n(732),i=n(243),l=n(967),a=o(n(646)),u=o(n(300)),c=n(70);var h;!function(t){t[t.Production=0]="Production",t[t.Development=1]="Development"}(h=e.DeveloperMode||(e.DeveloperMode={}));class p{static include(t,e=null){return r(this,void 0,void 0,(function*(){if(!0===i.HotStaq.isWeb&&"string"==typeof t){const e=t.toLowerCase();e.indexOf(".hott")>-1&&e.indexOf("nahfam")<0&&(t+="?hstqserve=nahfam")}p.echo(yield p.getFile(t,e))}))}static includeJS(t,e=null,o=null){return r(this,void 0,void 0,(function*(){const r=yield p.getFile(t,e);return!0===i.HotStaq.isWeb?null==o&&(o=window):null==o&&(o=n.g),eval.apply(o,[r])}))}static import(t,e=null,o=null){return r(this,void 0,void 0,(function*(){let r=p.CurrentPage.processor.getModule(t);if(null!=r)return r;const s=`./hotstaq_modules/${t}/index.js`,l=yield p.getFile(s,e);!0===i.HotStaq.isWeb?null==o&&(o=window):null==o&&(o=n.g);let a=new Function(l).apply(o);return null!=a.loadHTML&&(yield a.loadHTML()),p.CurrentPage.processor.addModule(t,a),a}))}static runFile(t,e=null){return r(this,void 0,void 0,(function*(){let n=p.CurrentPage.processor.getFile(t);n.page=this.CurrentPage;let r=yield n.process(e);p.echo(r)}))}static getFile(t,e=null){return r(this,void 0,void 0,(function*(){let n=null;"string"==typeof t?(n=new s.HotFile,n.name=t,!0===i.HotStaq.isWeb?n.url=t:n.localFile=t):n=t;let r=p.CurrentPage.processor.getFile(n.name,!1);return null!=r&&(n=r),yield n.load(),n.page=this.CurrentPage,yield n.process(e)}))}static apiCall(t,e=null,n=c.HotEventMethod.POST,o={}){return r(this,void 0,void 0,(function*(){let r=null;if(null==p.CurrentPage)throw new Error("Current page is null!");if(null==p.CurrentPage.processor)throw new Error("Current page's processor is null!");if(null==p.CurrentPage.processor.api)throw new Error("Current page's processor api is null! Did you forget to set the API name or URL?");return null!=p.CurrentPage.processor.api&&(r=yield p.CurrentPage.processor.api.makeCall(t,e,n,o)),r}))}static getJSON(t){return r(this,void 0,void 0,(function*(){return p.jsonRequest(t,null,c.HotEventMethod.GET)}))}static jsonRequest(t,e=null,n=c.HotEventMethod.POST){return r(this,void 0,void 0,(function*(){try{let r={method:n,headers:{Accept:"application/json","Content-Type":"application/json"}};n===c.HotEventMethod.POST&&(r.body=JSON.stringify(e));let o=yield(0,u.default)(t,r);if(!1===o.ok)throw new Error(`${o.status}: ${o.statusText}`);return yield o.json()}catch(e){return JSON.stringify({error:`${e.message} - Could not fetch ${t}`})}}))}static httpRequest(t,e){return r(this,void 0,void 0,(function*(){return yield(0,u.default)(t,e)}))}static echo(t){p.Output+=t}static displayCSS(){for(let t=0;t<p.CSS.length;t++){let e=p.CSS[t],n=p.cssStr;n=n.replace(/\%CSS_FILE\%/g,e),p.echo(n)}}static displayJSFiles(){for(let t=0;t<p.JSFiles.length;t++){let e=p.JSFiles[t],n=p.jsFileStr;n=n.replace(/\%JS_FILE\%/g,e),p.echo(n)}}static displayJSScripts(){for(let t=0;t<p.JSScripts.length;t++){let e=p.JSScripts[t],n=p.jsScriptsStr;n=n.replace(/\%JS_CODE\%/g,e),p.echo(n)}}}e.Hot=p,p.CurrentPage=null,p.Arguments=null,p.DeveloperMode=h,p.HotTestElement=l.HotTestElement,p.Mode=h.Production,p.API=null,p.TesterAPI=null,p.Output="",p.Data={},p.Cookies=a.default,p.PublicKeys={},p.cssStr='<link rel = "stylesheet" href = "%CSS_FILE%" />',p.CSS=[],p.JSFiles=[],p.JSScripts=[],p.jsFileStr='<script type = "text/javascript" src = "%JS_FILE%"><\/script>',p.jsScriptsStr='<script type = "text/javascript">%JS_CODE%<\/script>'},233:function(t,e,n){"use strict";var r=this&&this.__awaiter||function(t,e,n,r){return new(n||(n=Promise))((function(o,s){function i(t){try{a(r.next(t))}catch(t){s(t)}}function l(t){try{a(r.throw(t))}catch(t){s(t)}}function a(t){var e;t.done?o(t.value):(e=t.value,e instanceof n?e:new n((function(t){t(e)}))).then(i,l)}a((r=r.apply(t,e||[])).next())}))},o=this&&this.__importDefault||function(t){return t&&t.__esModule?t:{default:t}};Object.defineProperty(e,"__esModule",{value:!0}),e.HotAPI=e.EventExecutionType=void 0;const s=o(n(300)),i=o(n(230)),l=n(810),a=n(761),u=n(70);var c;!function(t){t[t.HotRoute=0]="HotRoute",t[t.HotMethod=1]="HotMethod",t[t.HotAPI=2]="HotAPI"}(c=e.EventExecutionType||(e.EventExecutionType={})),e.HotAPI=class{constructor(t,e,n=null){if(null==e)throw new Error(`No server attached to api with baseUrl: ${t}`);this.connection=e,this.description="",this.baseUrl=t,this.createFunctions=!0,this.executeEventsUsing=c.HotRoute,this.db=n,this.authCredentials=null,this.userAuth=null,this.routes={},this.onPreRegister=null,this.onPostRegister=null}setDBSchema(t){if(null==this.connection.api)throw new Error("No API has been set!");if(null==this.connection.api.db)throw new Error(`No database has been set for API base url ${this.connection.api.baseUrl}`);this.connection.api.db.schema=t}getDB(){if(null==this.connection.api.db)throw new Error(`No database has been set for API base url ${this.connection.api.baseUrl}`);return this.connection.api.db}getDBSchema(){if(null==this.connection.api.db)throw new Error(`No database has been set for API base url ${this.connection.api.baseUrl}`);return this.connection.api.db.schema}addRoute(t,e=null,n=null){let r="";if("string"==typeof t?(r=t,null==this.routes[r]&&(this.routes[r]=new a.HotRoute(this.connection,r)),"string"==typeof e?this.routes[r].addMethod(new u.HotRouteMethod(this.routes[r],e,n)):this.routes[r].addMethod(e)):(r=t.route,this.routes[t.route]=t),this.routes[r].connection=this.connection,!0===this.createFunctions){let t=this[r];null==t&&(t={});for(let e=0;e<this.routes[r].methods.length;e++){let n=this.routes[r],o=this.routes[r].methods[e];t[o.name]=(t,e)=>{let r=o.type,s=o.getRouteUrl(),i=null;if(null!=this.authCredentials&&(i=this.authCredentials),null!=o.authCredentials?i=o.authCredentials:null!=o.route.authCredentials&&(i=o.route.authCredentials),null==i&&"undefined"!=typeof Hot&&null!=Hot&&null!=Hot.API&&null!=Hot.API[n.route]&&null!=Hot.API[n.route].authCredentials&&(i=Hot.API[n.route].authCredentials),null!=i)for(let e in i){let n=i[e];null==t[e]&&(t[e]=n)}let l=[s,t,r,e];return this.makeCall.apply(this,l)}}this[r]=t}}registerRoute(t){return r(this,void 0,void 0,(function*(){this.connection instanceof l.HotServer&&(yield this.connection.registerRoute(t))}))}registerRoutes(){return r(this,void 0,void 0,(function*(){for(let t in this.routes){let e=this.routes[t];yield this.registerRoute(e)}}))}makeCall(t,e,n=u.HotEventMethod.POST,o={}){return r(this,void 0,void 0,(function*(){let l=this.baseUrl;const a=n.toUpperCase();if("/"===l[l.length-1]&&(l=l.substr(0,l.length-1)),"/"!==t[0]&&(l+="/"),l+=t,Object.keys(o).length>0){if("POST"!==a)throw new Error("To upload files, you must set the httpMethod to POST.");const r=new i.default;for(let t in o)r.append(t,o[t]);let u=yield(0,s.default)(l,{method:"POST",body:r}),c=yield u.json();return null==e.hotstaq&&(e.hotstaq={}),null==e.hotstaq.uploads&&(e.hotstaq.uploads={}),e.hotstaq.uploads.uploadId=c.hotstaq.uploads.uploadId,yield this.makeCall(t,e,n)}let u={method:n,headers:{Accept:"application/json","Content-Type":"application/json"}};return"GET"!==a&&"HEAD"!==a&&(u.body=JSON.stringify(e)),new Promise(((t,e)=>{(0,s.default)(l,u).then((e=>r(this,void 0,void 0,(function*(){e.json().then((e=>{t(e)})).catch((t=>{throw new Error(`${l}: ${t.message}`)}))})))).catch((t=>{throw new Error(`${l}: ${t.message}`)}))}))}))}}},316:(t,e)=>{"use strict";Object.defineProperty(e,"__esModule",{value:!0}),e.HotAsset=void 0,e.HotAsset=class{constructor(t,e=""){this.type=t,this.name=e,this.path="",this.content=""}load(){}output(){if(null==this.path&&null==this.content)throw new Error(`HotAsset ${this.name} of type ${this.type} does not have a path or content set!`);let t="";if(null!=this.path&&""!==this.path&&("js"===this.type&&(t=`<script type = "text/javascript" src = "${this.path}"><\/script>`),"css"===this.type&&(t=`<link href = "${this.path}" rel = "stylesheet" />`),"html"===this.type||"component"===this.type)){if(""===this.name)throw new Error("Loading an HTML or component asset requires a name to be set!");this.path,t={name:this.name,url:this.path}}if(null!=this.content&&""!==this.content){if("js"===this.type)throw new Error("Loading JS assets using content is not supported yet!");if("css"===this.type)throw new Error("Loading CSS assets using content is not supported yet!");if("html"===this.type){if(""===this.name)throw new Error("Loading an HTML asset requires a name to be set!");let e=JSON.stringify(this.content),n=this.path,r="";e=e.replace(new RegExp("\\<script","gmi"),'<scr" + "ipt'),e=e.replace(new RegExp("\\<\\/script","gmi"),'</scr" + "ipt'),r=e,t={name:this.name,url:n,content:e}}}return t}}},957:(t,e,n)=>{"use strict";Object.defineProperty(e,"__esModule",{value:!0}),e.HotClient=void 0;const r=n(810);e.HotClient=class{constructor(t){this.processor=t,this.api=null,this.testerAPI=null,this.type=r.HotServerType.HTTP,this.logger=t.logger}}},260:(t,e,n)=>{"use strict";Object.defineProperty(e,"__esModule",{value:!0}),e.HotComponent=void 0;const r=n(243);e.HotComponent=class{constructor(t,e=null){t instanceof r.HotStaq||null==t?(this.processor=t,this.htmlElements=[],this.name="",this.tag="",this.api=null,this.elementOptions=void 0,this.observedAttributes=[],this.type="",this.value=null,this.inner=null,this.events={}):(this.processor=t.processor,this.htmlElements=t.htmlElements||[],this.name=t.name||"",this.tag=t.tag||this.name,this.api=t.api||null,this.elementOptions=t.elementOptions||void 0,this.observedAttributes=t.observedAttributes||[],this.type=t.type||"",this.value=t.value||null,this.inner=t.inner||null,this.events={}),null!=e&&(this.api=e)}onCreated(t){return t}}},732:function(t,e,n){"use strict";var r=this&&this.__createBinding||(Object.create?function(t,e,n,r){void 0===r&&(r=n),Object.defineProperty(t,r,{enumerable:!0,get:function(){return e[n]}})}:function(t,e,n,r){void 0===r&&(r=n),t[r]=e[n]}),o=this&&this.__setModuleDefault||(Object.create?function(t,e){Object.defineProperty(t,"default",{enumerable:!0,value:e})}:function(t,e){t.default=e}),s=this&&this.__importStar||function(t){if(t&&t.__esModule)return t;var e={};if(null!=t)for(var n in t)"default"!==n&&Object.prototype.hasOwnProperty.call(t,n)&&r(e,t,n);return o(e,t),e},i=this&&this.__awaiter||function(t,e,n,r){return new(n||(n=Promise))((function(o,s){function i(t){try{a(r.next(t))}catch(t){s(t)}}function l(t){try{a(r.throw(t))}catch(t){s(t)}}function a(t){var e;t.done?o(t.value):(e=t.value,e instanceof n?e:new n((function(t){t(e)}))).then(i,l)}a((r=r.apply(t,e||[])).next())}))},l=this&&this.__importDefault||function(t){return t&&t.__esModule?t:{default:t}};Object.defineProperty(e,"__esModule",{value:!0}),e.HotFile=void 0;const a=s(n(351)),u=l(n(300)),c=n(507);class h{constructor(t={}){this.page=t.page||null,this.name=t.name||"",this.url=t.url||"",this.localFile=t.localFile||"",this.content=t.content||"",this.throwAllErrors=t.throwAllErrors||!1}setContent(t){this.content=t}getContent(){return this.content}static httpGet(t){return i(this,void 0,void 0,(function*(){try{let e=yield(0,u.default)(t);if(!1===e.ok)throw new Error(`${e.status}: ${e.statusText}`);return yield e.text()}catch(e){return JSON.stringify({error:`${e.message} - Could not fetch ${t}`})}}))}loadUrl(){return i(this,void 0,void 0,(function*(){return this.content=yield h.httpGet(this.url),this.content}))}loadLocalFile(){return i(this,void 0,void 0,(function*(){return new Promise(((t,e)=>{a.readFile(this.localFile,((e,n)=>{if(null!=e)throw e;let r=n.toString();this.content=r,t(this.content)}))}))}))}load(){return i(this,void 0,void 0,(function*(){let t="";return""!==this.url&&(t=yield this.loadUrl()),""!==this.localFile&&(t=yield this.loadLocalFile()),t}))}static processContent(t,e,n,r,o=2,s=2){let i=e.exec(t),l=0,a="";for(;null!=i;){let u=i.index-o,c=e.lastIndex+s,h=t.substr(l,u-l);l=c,a+=r(h),a+=n(i[0]),i=e.exec(t)}return a+=r(t.substr(l)),a}static processNestedContent(t,e,n,r,o,s,i=2,l=1){let a=t.indexOf(e),u=0,c=t.indexOf(r,a),h="";for(;a>-1;){let p=t.indexOf(n,a),d=0;if(""!==r){let e=t.lastIndexOf(r,p-l);for(;e>-1&&e!==c;)e=t.lastIndexOf(r,e-l),d++}if(d>0){let r=t.indexOf(n,p+l),o=r;for(;r>-1&&d>0&&!(o<0)&&!(t.lastIndexOf(e,o-l)>r);)r=o,o=t.indexOf(n,r+l),d--;p=r}h+=s(t.substr(u,a-u)),h+=o(t.substr(a+i,p-(a+i))),a=t.indexOf(e,p+l),c=t.indexOf(r,a),u=p+l}return h+=s(t.substr(u)),h}static parseContent(t,e,n=null){null==n&&(n={outputCommands:!0,allowStringify:!0});let r="JSON.stringify (",o=")";return!1===n.allowStringify&&(r="",o=""),h.processContent(t,new RegExp("(?=\\<\\*)([\\s\\S]*?)(?=\\*\\>)","g"),(t=>`${t=t.substr(2)}`),(t=>{if(""===t)return"";let s=h.processNestedContent(t,"!{","}","{",(t=>`*&&%*%@#@!${t}*&!#%@!@*!`),(t=>t)),i=h.processNestedContent(s,"STR{","}","{",(t=>{let s="";return s=!0===n.outputCommands?`*&&%*%@#@!echoOutput (JSON.stringify(${t}), ${e});*&!#%@!@*!`:`*&&%*%@#@!${r}${t}${o}, ${e});*&!#%@!@*!`,s}),(t=>t),4,1),l=h.processNestedContent(i,"${","}","{",(t=>{let r="";var o;return!0===n.outputCommands?(r=`*&&%*%@#@!try { Hot.echo (${t}); }catch (ex){Hot.echo (\`\\\${${o=t,o.replace(/[`]/g,"\\`")}}\`);}*&!#%@!@*!`,!0===e&&(r=`*&&%*%@#@!Hot.echo (${t});*&!#%@!@*!`)):r=`*&&%*%@#@!${t}*&!#%@!@*!`,r}),(t=>t)),a="";c.Hot.Mode===c.DeveloperMode.Production&&(a=h.processNestedContent(l,"?(",")","(",(t=>""),(t=>t))),c.Hot.Mode===c.DeveloperMode.Development&&(a=h.processNestedContent(l,"?(",")","(",(t=>{let e="";try{JSON.parse(t),e=!0===n.allowStringify?JSON.stringify(t):`${t}`}catch(n){e=`${t}`}let r="";if(!0===n.outputCommands)r=`*&&%*%@#@!{\nconst testElm = createTestElement (${e});\nHot.echo (\`data-test-object-name = "\${testElm.name}" data-test-object-func = "\${testElm.func}" data-test-object-value = "\${testElm.value}"\`);\n}*&!#%@!@*!\n`;else{let t=t=>{let e=null;try{let n=t;if("string"==typeof t&&(n=JSON.parse(t)),"string"==typeof n&&(e=new c.Hot.HotTestElement(n)),n instanceof Array&&(e=new c.Hot.HotTestElement(n[0],n[1],n[2])),null!=n.name&&(e=new c.Hot.HotTestElement(n)),null!=c.Hot.CurrentPage.testElements[e.name])throw new Error(`Test element ${e.name} already exists!`)}catch(e){throw new Error(`Error processing test element ${t} in ${c.Hot.CurrentPage.name}. Error: ${e.message}`)}return e};const n=t(e);r=`*&&%*%@#@!data-test-object-name = "${n.name}" data-test-object-func = "${n.func}" data-test-object-value = "${n.value}"*&!#%@!@*!`}return r}),(t=>t)));let u=h.processNestedContent(a,"*&&%*%@#@!","*&!#%@!@*!","*&&%*%@#@!",(t=>t),(t=>{let r="";r=!0===n.allowStringify?JSON.stringify(t):t;let o="";return o=!0===n.outputCommands?`echoOutput (${r}, ${e});\n`:r,o}),"*&&%*%@#@!".length,"*&!#%@!@*!".length);return u=u.replace(/\*\&\&\%\*\%\@\#\@\!/g,""),u=u.replace(/\*\&\!\#\%\@\!\@\*\!/g,""),u}),0)}process(t=null){return i(this,void 0,void 0,(function*(){let e=this.content;if(null!=t&&t instanceof Array)throw new Error(`In ${this.name}, the passed arguments received cannot be an array!`);c.Hot.Mode=this.page.processor.mode,c.Hot.Arguments=t,c.Hot.CurrentPage=this.page,c.Hot.PublicKeys=this.page.processor.publicKeys,c.Hot.API=this.page.getAPI(),c.Hot.TesterAPI=this.page.getTesterAPI();let n=h.parseContent(e,this.throwAllErrors),r=null;try{let e="\n\t\t\tvar Hot = arguments[0];\n\t\t\tvar PassedHotFile = arguments[1];\n\n\t\t\t";if("string"==typeof t)throw new Error("The passing arguments cannot be a string!");for(let n in t){let r="",o=t[n];r=`var ${n} = ${JSON.stringify(o)};\n`,e+=r}let o=this.name;""===o&&(o=this.localFile),""===o&&(o=this.url),e+='\n\t\t\tfunction echoOutput (content, throwErrors)\n\t\t\t{\n\t\t\t\tif (throwErrors == null)\n\t\t\t\t\tthrowErrors = true;\n\n\t\t\t\tif (throwErrors === true)\n\t\t\t\t{\n\t\t\t\t\tHot.echo (content);\n\n\t\t\t\t\treturn;\n\t\t\t\t}\n\n\t\t\t\ttry\n\t\t\t\t{\n\t\t\t\t\tHot.echo (content);\n\t\t\t\t}\n\t\t\t\tcatch (ex)\n\t\t\t\t{\n\t\t\t\t\tHot.echo ("");\n\t\t\t\t}\n\t\t\t}\n\n\t\t\tfunction createTestElement (foundStr)\n\t\t\t{\n\t\t\t\tlet testElm = null;\n\n\t\t\t\ttry\n\t\t\t\t{\n\t\t\t\t\tlet obj = foundStr;\n\n\t\t\t\t\tif (typeof (foundStr) === "string")\n\t\t\t\t\t\tobj = JSON.parse (foundStr);\n\n\t\t\t\t\tif (typeof (obj) === "string")\n\t\t\t\t\t\ttestElm = new Hot.HotTestElement (obj);\n\n\t\t\t\t\tif (obj instanceof Array)\n\t\t\t\t\t\ttestElm = new Hot.HotTestElement (obj[0], obj[1], obj[2]);\n\n\t\t\t\t\tif (obj["name"] != null)\n\t\t\t\t\t\ttestElm = new Hot.HotTestElement (obj);\n\n\t\t\t\t\tif (Hot.CurrentPage.testElements[testElm.name] != null)\n\t\t\t\t\t\tthrow new Error (`Test element ${testElm.name} already exists!`);\n\n\t\t\t\t\tHot.CurrentPage.addTestElement (testElm);\n\t\t\t\t}\n\t\t\t\tcatch (ex)\n\t\t\t\t{\n\t\t\t\t\tthrow new Error (\n\t\t\t`Error processing test element ${foundStr} in ${Hot.CurrentPage.name}. Error: ${ex.message}`\n\t\t\t\t\t\t);\n\t\t\t\t}\n\n\t\t\t\treturn (testElm);\n\t\t\t}\n\n\t\t\tasync function runContent (CurrentHotFile)\n\t\t\t{\n',e+=n,e+="\n\t\t\t}\n\n\t\t\treturn (runContent (PassedHotFile).then (() =>\n\t\t\t{\n\t\t\t\treturn ({\n\t\t\t\t\t\thot: Hot,\n\t\t\t\t\t\toutput: Hot.Output,\n\t\t\t\t\t\tdata: JSON.stringify (Hot.Data)\n\t\t\t\t\t});\n\t\t\t}));";let s=new Function(e);r=yield s.apply(this,[c.Hot,this])}catch(t){throw SyntaxError,t}c.Hot.Data=r.hot.Data;let o=r.output;return c.Hot.Output="",o}))}}e.HotFile=h},802:(t,e)=>{"use strict";var n;Object.defineProperty(e,"__esModule",{value:!0}),e.HotLog=e.HotLogLevel=void 0,function(t){t[t.Info=0]="Info",t[t.Warning=1]="Warning",t[t.Error=2]="Error",t[t.Verbose=3]="Verbose",t[t.All=4]="All",t[t.None=5]="None"}(n=e.HotLogLevel||(e.HotLogLevel={})),e.HotLog=class{constructor(t=n.All){this.logLevel=t}static parse(t){let e=n.All;return"info"===t&&(e=n.Info),"warning"===t&&(e=n.Warning),"error"===t&&(e=n.Error),"verbose"===t&&(e=n.Verbose),"all"===t&&(e=n.All),"none"===t&&(e=n.None),e}log(t,e){this.logLevel===n.Verbose&&(t===n.Error&&this.error(e),t===n.Warning&&this.warning(e),t!==n.Info&&t!==n.Verbose||this.info(e)),this.logLevel===n.All&&(t===n.Error&&this.error(e),t===n.Warning&&this.warning(e),t===n.Info&&this.info(e)),this.logLevel===n.Error&&t===n.Error&&this.error(e),this.logLevel===n.Warning&&t===n.Warning&&this.warning(e),this.logLevel===n.Info&&t===n.Info&&this.info(e)}verbose(t){this.logLevel===n.Verbose&&("string"==typeof t?console.info(t):console.info(t()))}info(t){this.logLevel!==n.All&&this.logLevel!==n.Verbose&&this.logLevel!==n.Info||console.info(t)}warning(t){this.logLevel!==n.All&&this.logLevel!==n.Verbose&&this.logLevel!==n.Warning||console.warn(t)}error(t){if(this.logLevel===n.All||this.logLevel===n.Verbose||this.logLevel===n.Error){let e="";"string"==typeof t?e=t:(null!=t.message&&(e=t.message),null!=t.stack&&(e=t.stack)),console.error(e)}}}},202:function(t,e,n){"use strict";var r=this&&this.__awaiter||function(t,e,n,r){return new(n||(n=Promise))((function(o,s){function i(t){try{a(r.next(t))}catch(t){s(t)}}function l(t){try{a(r.throw(t))}catch(t){s(t)}}function a(t){var e;t.done?o(t.value):(e=t.value,e instanceof n?e:new n((function(t){t(e)}))).then(i,l)}a((r=r.apply(t,e||[])).next())}))};Object.defineProperty(e,"__esModule",{value:!0}),e.HotModule=void 0;const o=n(507),s=n(316);e.HotModule=class{constructor(t){this.name=t,this.import=[],this.html=[],this.css=[],this.js=[],this.componentLibrary="",this.components=[]}outputCSS(t=!0){if(null==this.css)return;let e="";return this.outputAsset("css",this.css,(t=>{const n=t.output();e+=`${n}\n`})),!0===t&&o.Hot.echo(e),e}outputJS(t=!0){if(null==this.js)return;let e="";return this.outputAsset("js",this.js,(t=>{const n=t.output();e+=`${n}\n`})),!0===t&&o.Hot.echo(e),e}output(t,e=null){return r(this,void 0,void 0,(function*(){yield o.Hot.include(`${this.name}/${t}.hott`,e)}))}loadHTML(){return r(this,void 0,void 0,(function*(){if(null==this.html)return;let t={};this.outputAsset("html",this.html,(e=>{const n=e.output();if("string"==typeof n)throw new Error("HTML assets cannot be outputted using only a string!");t[n.name]=n})),yield o.Hot.CurrentPage.processor.loadHotFiles(t)}))}outputComponents(t=!0){if(null==this.components)return"";if(this.components.length<1)return"";let e='<script type = "text/javascript">',n="";null!=this.componentLibrary&&""!==this.componentLibrary&&(n=`${this.componentLibrary}.`);for(let t=0;t<this.components.length;t++)e+=`Hot.CurrentPage.processor.addComponent (${n}${this.components[t]});\n`;return e+="<\/script>",!0===t&&o.Hot.echo(e),e}outputAsset(t,e=[],n){for(let r=0;r<e.length;r++){let o=e[r],i=null;i=new s.HotAsset(t),"string"==typeof o?i.path=o:(null!=o.name&&(i.name=o.name),null!=o.path&&(i.path=o.path),null!=o.content&&(i.content=o.content)),n(i)}}}},136:function(t,e,n){"use strict";var r=this&&this.__awaiter||function(t,e,n,r){return new(n||(n=Promise))((function(o,s){function i(t){try{a(r.next(t))}catch(t){s(t)}}function l(t){try{a(r.throw(t))}catch(t){s(t)}}function a(t){var e;t.done?o(t.value):(e=t.value,e instanceof n?e:new n((function(t){t(e)}))).then(i,l)}a((r=r.apply(t,e||[])).next())}))};Object.defineProperty(e,"__esModule",{value:!0}),e.HotPage=void 0;const o=n(507),s=n(243);e.HotPage=class{constructor(t){t instanceof s.HotStaq?(this.processor=t,this.name="",this.testerName="HotTesterMochaSelenium",this.testerMap="",this.route="",this.components={},this.files=[],this.testElements={},this.testPaths={}):(this.processor=t.processor,this.name=t.name||"",this.testerName=t.testerName||"HotTesterMochaSelenium",this.testerMap=t.testerMap||"",this.route=t.route||"",this.components=t.components||{},this.files=t.files||[],this.testElements=t.testElements||{},this.testPaths=t.testPaths||{})}addFile(t){return r(this,void 0,void 0,(function*(){t.page=this,this.files.push(t)}))}getAPI(){return this.processor.api}getTesterAPI(){return this.processor.testerAPI}load(t){return r(this,void 0,void 0,(function*(){for(let t=0;t<this.files.length;t++){let e=this.files[t];yield e.load()}}))}process(t=null){return r(this,void 0,void 0,(function*(){let e="";for(let n=0;n<this.files.length;n++){let r=this.files[n];o.Hot.Output="",r.page=this,e+=(yield r.process(t))}return e}))}addTestElement(t){if(null!=this.testElements[t.name])throw new Error(`Test element ${t.name} already exists!`);this.testElements[t.name]=t}getTestElement(t){if(null==this.testElements[t])throw new Error(`Test element ${t} doest not exist!`);return this.testElements[t]}createTestPath(t,e){if(null!=this.testPaths[t])throw new Error(`Test path ${t} already exists!`);this.testPaths[t]=e}}},761:(t,e,n)=>{"use strict";Object.defineProperty(e,"__esModule",{value:!0}),e.HotRoute=void 0;const r=n(70);class o{constructor(t,e,n=[]){this.onPreRegister=null,this.onRegister=null,this.onPostRegister=null,this.onAuthorizeUser=null,this.connection=t,this.logger=null,null!=this.connection&&null!=this.connection.processor&&(this.logger=this.connection.processor.logger),this.route=e,this.description="",this.version="v1",this.prefix="",this.authCredentials=null,this.methods=n,this.errors={not_authorized:o.createError("Not authorized."),no_server_execute_function:o.createError("Missing server execute function.")}}static createError(t){return{error:t}}addMethod(t,e=null,n=r.HotEventMethod.POST,o=null){"string"==typeof t&&(t=new r.HotRouteMethod(this,t,e,n,null,null,null,o)),t instanceof r.HotRouteMethod||(null==t.route&&(t.route=this),t=new r.HotRouteMethod(t)),this.methods.push(t)}getMethod(t){let e=null;for(let n=0;n<this.methods.length;n++){let r=this.methods[n];if(r.name===t){e=r;break}}return e}}e.HotRoute=o},70:(t,e,n)=>{"use strict";Object.defineProperty(e,"__esModule",{value:!0}),e.HotRouteMethod=e.ServerRequest=e.HotEventMethod=void 0;const r=n(507),o=n(761),s=n(810);var i;!function(t){t.GET="get",t.POST="post",t.FILE_UPLOAD="file_upload_then_post_json",t.WEBSOCKET_CLIENT_PUB_EVENT="websocket_client_pub_event"}(i=e.HotEventMethod||(e.HotEventMethod={})),e.ServerRequest=class{constructor(t=null){null==t&&(t={}),this.req=t.req||null,this.res=t.res||null,this.wsSocket=t.wsSocket||null,this.authorizedValue=t.authorizedValue||null,this.jsonObj=t.jsonObj||null,this.queryObj=t.queryObj||null,this.files=t.files||null}},e.HotRouteMethod=class{constructor(t,e="",n=null,l=i.POST,a=null,u=null,c=null,h=null){let p=null;if(t instanceof o.HotRoute)p=t;else{if(p=t.route,null!=t.type&&(l=t.type),null!=t.name&&(e=t.name),null!=t.description&&(this.description=t.description),null!=t.returns&&("string"==typeof t.returns?this.returns={type:"string",required:!0,description:t.returns}:this.returns=t.returns),null!=t.parameters){this.parameters={};for(let e in t.parameters){let n=t.parameters[e];"string"==typeof n?this.parameters[e]={type:n,required:!1,description:""}:(null==n.type&&(n.type="string"),this.parameters[e]=n)}}null!=t.authCredentials&&(c=t.authCredentials),null!=t.onServerExecute&&(n=t.onServerExecute),null!=t.onServerAuthorize&&(a=t.onServerAuthorize),null!=t.onRegister&&(u=t.onRegister),null!=t.onPostRegister&&(this.onPostRegister=t.onPostRegister),null!=t.onServerExecute&&(this.onServerExecute=t.onServerExecute),null!=t.onClientExecute&&(this.onClientExecute=t.onClientExecute),null!=t.testCases&&(h=t.testCases)}if(""===e)throw new Error("All route methods must have a name!");if(this.route=p,this.name=e,this.type=l,this.isRegistered=!1,this.executeSetup=!1,this.authCredentials=c,this.onServerAuthorize=a,this.onRegister=u,this.testCases={},this.route.connection.processor.mode===r.DeveloperMode.Development&&null!=h)if(h instanceof Array)for(let t=0;t<h.length;t++){let e=h[t];if("string"==typeof e){const n=e,r=h[t+1];this.addTestCase(n,r),t++}else this.addTestCase(e)}else for(let t in h){let e=h[t];this.addTestCase(e)}this.route.connection instanceof s.HotServer&&(this.onServerExecute=n)}addTestCase(t,e=null){if("string"==typeof t){const n=t,r=e;return void(this.testCases[n]={name:n,func:r})}if("function"==typeof t){const e=Object.keys(this.testCases).length,n=`${this.route.route}/${this.name} test case ${e}`,r=t;return void(this.testCases[n]={name:n,func:r})}const n=t;this.testCases[n.name]=n}getRouteUrl(){if(null==this.route)throw new Error(`Route method ${this.name} does not have a parent route!`);let t="/";return""!==this.route.version&&(t+=`${this.route.version}/`),""!==this.route.prefix&&(t+=`${this.route.prefix}/`),""!==this.route.route&&(t+=`${this.route.route}/`),t+=this.name,t}}},810:function(t,e,n){"use strict";var r=this&&this.__awaiter||function(t,e,n,r){return new(n||(n=Promise))((function(o,s){function i(t){try{a(r.next(t))}catch(t){s(t)}}function l(t){try{a(r.throw(t))}catch(t){s(t)}}function a(t){var e;t.done?o(t.value):(e=t.value,e instanceof n?e:new n((function(t){t(e)}))).then(i,l)}a((r=r.apply(t,e||[])).next())}))};Object.defineProperty(e,"__esModule",{value:!0}),e.HotServer=e.HotServerType=void 0;const o=n(243);var s;!function(t){t[t.HTTP=0]="HTTP",t[t.WebSockets=1]="WebSockets",t[t.Generate=2]="Generate",t[t.WebTesting=3]="WebTesting",t[t.APITesting=4]="APITesting"}(s=e.HotServerType||(e.HotServerType={})),e.HotServer=class{constructor(t){t instanceof o.HotStaq?(this.processor=t,this.serverType="Server",this.api=null,this.listenAddress="0.0.0.0",this.ports={http:5e3,https:443},this.ssl={cert:"",key:"",ca:""},this.redirectHTTPtoHTTPS=!0,this.type=s.HTTP,this.logger=t.logger,this.secrets={}):(this.processor=t.processor,this.serverType=t.serverType||"Server",this.api=t.api||null,this.listenAddress=t.listenAddress||"0.0.0.0",this.ports=t.ports||{http:5e3,https:443},this.ssl=t.ssl||{cert:"",key:"",ca:""},this.redirectHTTPtoHTTPS=null==t.redirectHTTPtoHTTPS||t.redirectHTTPtoHTTPS,this.type=t.type||s.HTTP,this.logger=t.logger,this.secrets=t.secrets||{})}setAPI(t){return r(this,void 0,void 0,(function*(){this.processor.api=t,this.api=t}))}}},243:function(__unused_webpack_module,exports,__webpack_require__){"use strict";var __createBinding=this&&this.__createBinding||(Object.create?function(t,e,n,r){void 0===r&&(r=n),Object.defineProperty(t,r,{enumerable:!0,get:function(){return e[n]}})}:function(t,e,n,r){void 0===r&&(r=n),t[r]=e[n]}),__setModuleDefault=this&&this.__setModuleDefault||(Object.create?function(t,e){Object.defineProperty(t,"default",{enumerable:!0,value:e})}:function(t,e){t.default=e}),__importStar=this&&this.__importStar||function(t){if(t&&t.__esModule)return t;var e={};if(null!=t)for(var n in t)"default"!==n&&Object.prototype.hasOwnProperty.call(t,n)&&__createBinding(e,t,n);return __setModuleDefault(e,t),e},__awaiter=this&&this.__awaiter||function(t,e,n,r){return new(n||(n=Promise))((function(o,s){function i(t){try{a(r.next(t))}catch(t){s(t)}}function l(t){try{a(r.throw(t))}catch(t){s(t)}}function a(t){var e;t.done?o(t.value):(e=t.value,e instanceof n?e:new n((function(t){t(e)}))).then(i,l)}a((r=r.apply(t,e||[])).next())}))},__importDefault=this&&this.__importDefault||function(t){return t&&t.__esModule?t:{default:t}};Object.defineProperty(exports,"__esModule",{value:!0}),exports.HotStaq=void 0;const ppath=__importStar(__webpack_require__(606)),node_fetch_1=__importDefault(__webpack_require__(300)),validate_npm_package_name_1=__importDefault(__webpack_require__(651)),HotPage_1=__webpack_require__(136),HotFile_1=__webpack_require__(732),HotLog_1=__webpack_require__(802),Hot_1=__webpack_require__(507),HotAsset_1=__webpack_require__(316),HotClient_1=__webpack_require__(957),HotTesterAPI_1=__webpack_require__(414),HotTestMap_1=__webpack_require__(985),HotTestDestination_1=__webpack_require__(473),HotStaqRegisterComponent_1=__webpack_require__(638),HotStaqWebStart_1=__webpack_require__(23);var HotTesterMocha=null,HotTesterMochaSelenium=null,HotTestSeleniumDriver=null;class HotStaq{constructor(t={}){this.logger=new HotLog_1.HotLog(HotLog_1.HotLogLevel.All),this.startDelay=0,this.api=t.api||null,this.testerAPI=t.testerAPI||null,this.mode=t.mode||Hot_1.DeveloperMode.Production,this.pages=t.pages||{},this.modules=t.modules||{},this.components=t.components||{},this.files=t.files||{},this.hotSite=t.hotSite||null,this.apiContent="\n\t\t\t{\n\t\t\t\tvar %api_name% = %api_exported_name%.%api_name%;\n\t\t\t\tvar newHotClient = new HotClient (processor);\n\t\t\t\tvar newapi = new %api_name% (%base_url%, newHotClient);\n\t\t\t\tnewHotClient.api = newapi;\n\t\t\t\tprocessor.api = newapi;\n\t\t\t}",this.testerApiContent="\n\t\t\tvar HotTesterAPI = HotStaqWeb.HotTesterAPI;\n\t\t\tvar newHotTesterClient = new HotClient (processor);\n\t\t\tvar newtesterapi = new HotTesterAPI (%base_tester_url%, newHotTesterClient);\n\t\t\tnewHotTesterClient.testerAPI = newtesterapi;\n\t\t\tprocessor.testerAPI = newtesterapi;",this.pageContent='<!DOCTYPE html>\n<html>\n\n<head>\n\t<title>%title%</title>\n\n\t<script type = "text/javascript" src = "%hotstaq_js_src%"><\/script>\n\t<script type = "text/javascript">\n\t\tfor (let key in HotStaqWeb)\n\t\t\twindow[key] = HotStaqWeb[key];\n\t<\/script>\n\n%apis_to_load%\n\n\t<script type = "text/javascript">\n\t\tasync function hotstaq_startApp ()\n\t\t{\n\t\t\tlet tempMode = 0;\n\n\t\t\tif (window["Hot"] != null)\n\t\t\t\ttempMode = Hot.Mode;\n\n\t\t\t%start_delay%\n\n\t\t\tvar processor = new HotStaq ();\n\t\t\tprocessor.logger.logLevel = %logging_level%;\n\n\t\t\tvar promises = [];\n\t\t\t%developer_mode%\n\n\t\t\t%api_code%\n\n\t\t\t%public_secrets%\n\t\t\t%tester_api%\n\t\t\t%load_files%\n\n\t\t\tprocessor.mode = tempMode;\n\n\t\t\tPromise.all (promises).then (function ()\n\t\t\t\t{\n\t\t\t\t\tHotStaq.displayUrl ({\n\t\t\t\t\t\t\turl: "%url%",\n\t\t\t\t\t\t\tname: "%title%",\n\t\t\t\t\t\t\tprocessor: processor,\n\t\t\t\t\t\t\targs: %args%,\n\t\t\t\t\t\t\ttesterName: %tester_name%,\n\t\t\t\t\t\t\ttesterMap: %tester_map%,\n\t\t\t\t\t\t\ttesterAPIBaseUrl: %tester_api_base_url%,\n\t\t\t\t\t\t\ttesterLaunchpadUrl: %tester_launchpad_url%\n\t\t\t\t\t\t});\n\t\t\t\t});\n\t\t}\n\n\t\thotstaq_startApp ();\n\t<\/script>\n</head>\n\n<body>\n</body>\n\n</html>',this.publicKeys={},this.testers={}}static parseBoolean(t){return"true"===(t=t.toLowerCase())||"false"!==t&&("yes"===t||"no"!==t&&"yep"===t)}static getParam(t,e,n=!0,r=!0){let o=e[t];if(null==o&&!0===n&&!0===r)throw new Error(`Missing required parameter ${t}.`);if("string"==typeof o&&!0===n&&""===o&&!0===r)throw new Error(`Missing required parameter ${t}.`);return o}static getParamDefault(t,e,n){let r=e[t];return null==r||"string"==typeof r&&""===r?n:r}static executeError(t){if(null!=HotStaq.errors[t]){let e=HotStaq.errors[t].redirectToUrl;if(null!=e&&""!==e)return void(window.location.href=e);let n=HotStaq.errors[t].func;null!=n&&n(t)}}static wait(t){return __awaiter(this,void 0,void 0,(function*(){return yield new Promise(((e,n)=>{setTimeout((()=>{e()}),t)}))}))}addPage(t){this.pages[t.name]=t}getPage(t){return this.pages[t]}addModule(t,e){this.modules[t]=e}getModule(t){return this.modules[t]}addFile(t){let e=t.name;""===e&&(e=t.localFile),""===e&&(e=t.url),this.files[e]=t}getFile(t,e=!0){if(null==this.files[t]){let n=t.indexOf("?hstqserve="),r=t;if(n>-1&&(r=t.substring(0,n)),null!=this.files[r])return this.files[r];if(!0===e)throw new Error(`Unable to find file ${t}`);return null}return this.files[t]}static keepContext(t,e,n){return function(){var r=Array.prototype.slice.call(arguments);return null!=n&&r.push(n),null==e?t.apply(this,r):t.apply(e,r)}}addComponent(t,e=null,n){let r=this.api;null!=e&&(r=e);let o=new t(this,r);if(null!=this.components[o.tag])throw new Error(`Component ${o.tag} already exists!`);this.components[o.tag]={componentType:t,processor:this,api:r},HotStaqRegisterComponent_1.registerComponent.call(this,o.tag,n)}static fixHTML(t){const e=t.replace(/ \/>/g,">").replace(/(<(area|base|br|col|command|embed|hr|img|input|keygen|link|meta|param|source|track|wbr).*?>)/g,"$1</$2>"),n=(new DOMParser).parseFromString(`<xml>${e}</xml>`,"text/xml");let r="";if(n.documentElement.children.length>0){const e=n.documentElement.children[0].tagName.toLowerCase();"tr"===e&&(t=`<table>${t}</table>`,r="tbody"),"th"===e&&(t=`<table>${t}</table>`,r=e)}return{fixedStr:t,querySelector:r}}static addHtml(t,e){let n=null;if(n="string"==typeof t?document.querySelector(t):t,null==n)throw new Error(`Unable to find parent ${t}!`);let r=null;if("string"==typeof e){let t=HotStaq.fixHTML(e),r=(new DOMParser).parseFromString(t.fixedStr,"text/html"),o=null;o=""===t.querySelector?r.body.children:r.querySelector(t.querySelector).children;let s=[];for(let t=0;t<o.length;t++){let e=o[t];s.push(n.appendChild(e))}return s}return r=n.appendChild(e),r}static checkHotSiteName(t,e=!1){let n=(0,validate_npm_package_name_1.default)(t),r=!0;if(!1===n.validForNewPackages&&(r=!1),null!=n.errors&&n.errors.length>0&&(r=!1),!1===r&&!0===e)throw new Error(`HotSite ${t} has an invalid name! The name cannot be empty and must have a valid NPM module name.`);return r}static replaceKey(t,e,n){return t.replace(new RegExp(`\\$\\{${e}\\}`,"g"),n)}static getValueFromHotSiteObj(t,e){let n=null;if(null!=t){let r=t;for(let t=0;t<e.length;t++){let n=e[t];if(null==r[n]){r=null;break}r=r[n]}null!=r&&(n=r)}return n}processHotSite(tester=null){return __awaiter(this,void 0,void 0,(function*(){HotStaq.checkHotSiteName(this.hotSite.name,!0);let routes=this.hotSite.routes;if(null!=routes)for(let t in routes){let e=routes[t],n=new HotFile_1.HotFile(e),r=new HotPage_1.HotPage({processor:this,name:e.name||"",route:t,files:[n]});if(null!=tester&&this.mode===Hot_1.DeveloperMode.Development){let t=e.name,n=null;if(null!=e.map){if("string"==typeof e.map){if(null==tester.testMaps[e.map])throw new Error(`Test map ${e.map} does not exist!`);tester.testMaps[t]=tester.testMaps[e.map]}else{n=new HotTestMap_1.HotTestMap;let t=null;if(e.map instanceof Array){t=[];for(let n=0;n<e.map.length;n++){let r=e.map[n];t.push(new HotTestDestination_1.HotTestDestination(r))}}else{t={};for(let n in e.map){let r=e.map[n];t[n]=new HotTestDestination_1.HotTestDestination(r)}}n.destinations=t}tester.testMaps[t]=n}null!=e.destinationOrder&&(tester.testMaps[t].destinationOrder=e.destinationOrder)}this.addPage(r)}if(null!=this.hotSite.apis)for(let t in this.hotSite.apis){let e=this.hotSite.apis[t];if(null!=e.map&&!1===HotStaq.isWeb&&this.mode===Hot_1.DeveloperMode.Development){let n=t,r=new HotTestMap_1.HotTestMap;r.destinations=[];for(let t=0;t<e.map.length;t++){let n=e.map[t];r.destinations.push(new HotTestDestination_1.HotTestDestination(n))}null!=tester?tester.testMaps[n]=r:this.logger.warning("A tester was not created first! You must specify one in the CLI.")}}if(!0===HotStaq.isWeb)for(let key in this.hotSite.components){let component=this.hotSite.components[key],componentUrl=component.url,res=yield(0,node_fetch_1.default)(componentUrl),ComponentClass=eval(res);this.addComponent(ComponentClass)}null==this.hotSite.routes&&(this.hotSite.routes={});let disableFileLoading=!1;null!=this.hotSite.disableFileLoading&&(disableFileLoading=this.hotSite.disableFileLoading),!1===disableFileLoading?yield this.loadHotFiles(this.hotSite.files,!1,!1):this.logger.verbose("Hotsite has file loading disabled..."),null!=tester&&this.addTester(tester),this.logger.verbose(`Processed HotSite ${this.hotSite.name}`)}))}loadHotSite(path){return __awaiter(this,void 0,void 0,(function*(){let jsonStr="";const ext=ppath.extname(path).toLowerCase();if(!0===HotStaq.isWeb){this.logger.verbose(`Downloading HotSite ${path}`);let t=yield(0,node_fetch_1.default)(path);this.logger.verbose(`Downloaded site ${path}`),jsonStr=t.text()}else{path=ppath.normalize(path),this.logger.verbose(`Accessing HotSite ${path}`);let HotIO=eval("require")("./HotIO").HotIO;jsonStr=yield HotIO.readTextFile(path),this.logger.verbose(`Accessed site ${path}`)}if(".yaml"===ext||".yml"===ext){if(!0===HotStaq.isWeb)throw new Error("YAML support for HotSites is not available on the web yet!");let yaml=eval("require")("yaml");this.hotSite=yaml.parse(jsonStr)}else this.hotSite=JSON.parse(jsonStr);if(null==this.hotSite)throw new Error(`HotSite ${path} cannot be null!`);this.hotSite.hotsitePath=path}))}saveHotSite(path){return __awaiter(this,void 0,void 0,(function*(){if(!0===HotStaq.isWeb)throw new Error("Cannot save a HotSite on the web!");const hotsiteStr=JSON.stringify(this.hotSite,null,2);let HotIO=eval("require")("./HotIO").HotIO;yield HotIO.writeTextFile(path,hotsiteStr),this.logger.verbose(`Saved site ${path}`)}))}loadHotFiles(t,e=!1,n=!0){return __awaiter(this,void 0,void 0,(function*(){this.logger.verbose("Loading Hott files...");for(let r in t){let o=t[r],s=null;HotStaq.isWeb,s=new HotFile_1.HotFile({name:r}),null!=o.url&&(!0===HotStaq.isWeb?s.url=`${o.url}?hstqserve=nahfam`:s.url=o.url),!1===HotStaq.isWeb&&null!=o.localFile&&(s.localFile=o.localFile);let i=!0;null!=o.content&&(s.content=o.content,i=!1),!0===e&&(i=!0),!1===n&&""!==s.url&&(i=!1),!0===i&&(this.logger.verbose(`Loading Hott file: ${s.url}`),yield s.load(),this.logger.verbose(`Finished loading Hott file: ${s.url}`)),this.addFile(s)}this.logger.verbose("Finished loading Hott files...")}))}generateContent(t,e="",n="./",r="./js/HotStaq.min.js",o=!0,s=null){return __awaiter(this,void 0,void 0,(function*(){let i="",l="",a="";if(null!=this.hotSite){if(null!=this.hotSite.server.globalApi&&""!==this.hotSite.server.globalApi){const t=this.hotSite.apis[this.hotSite.server.globalApi];if(null==t)this.logger.warning(`API with name ${this.hotSite.server.globalApi} doesn't exist!`);else{let e=!0;if(null==t.jsapi&&(e=!1,this.logger.warning(`API with name ${this.hotSite.server.globalApi} doesn't have a jsapi set. Will not send js content to client.`)),null==t.libraryName&&(e=!1,this.logger.warning(`API with name ${this.hotSite.server.globalApi} doesn't have a libraryName set. Will not send js content to client.`)),null==t.apiName&&(e=!1,this.logger.warning(`API with name ${this.hotSite.server.globalApi} doesn't have a apiName set. Will not send js content to client.`)),!0===e){i+=`\t<script type = "text/javascript" src = "${t.jsapi}"><\/script>\n`;let e='""';null!=t.url&&(e=`"${t.url}"`),null!=this.api&&(e=`"${this.api.baseUrl}"`);let n=this.apiContent;n=n.replace(/\%api\_name\%/g,t.apiName),n=n.replace(/\%api\_exported\_name\%/g,t.libraryName),n=n.replace(/\%base\_url\%/g,e),l+=n}}}if(null!=this.hotSite.apis){let e=this.hotSite.routes[t];if(null!=e&&null!=e.api){let t=this.hotSite.apis[e.api];if(null==t)throw new Error(`Unable to find API ${e.api}`);if(e.api!==this.hotSite.server.globalApi){let n=!0;if(null==t.jsapi&&(n=!1,this.logger.warning(`API with name ${e.api} doesn't have a jsapi set. Will not send js content to client.`)),null==t.libraryName&&(n=!1,this.logger.warning(`API with name ${e.api} doesn't have a libraryName set. Will not send js content to client.`)),null==t.apiName&&(n=!1,this.logger.warning(`API with name ${e.api} doesn't have a apiName set. Will not send js content to client.`)),!0===n){let e=t.jsapi;i+=`\t<script type = "text/javascript" src = "${e}"><\/script>\n`;let n='""';null!=t.url&&(n=`"${t.url}"`),null!=this.api&&(n=`"${this.api.baseUrl}"`);let r=this.apiContent;r=r.replace(/\%api\_name\%/g,t.apiName),r=r.replace(/\%api\_exported\_name\%/g,t.libraryName),r=r.replace(/\%base\_url\%/g,n),l+=r}}}}if(null!=this.hotSite.server&&null!=this.hotSite.server.jsSrcPath&&(r=this.hotSite.server.jsSrcPath),null!=this.hotSite.publicKeys)for(let t in this.hotSite.publicKeys){let e,n=this.hotSite.publicKeys[t];if("string"==typeof n)e=JSON.stringify(n);else if(!1===HotStaq.isWeb){if(null!=this.api){if(null==this.api.connection)throw new Error("Cannot pass secrets from the API if there's no connection!");let r=this.api.connection;null!=n.passSecretFromAPI&&(e=JSON.stringify(r.secrets[t]))}if(null!=n.env){const t=n.env;e=JSON.stringify(process.env[t])}}a+=`processor.publicKeys["${t}"] = ${e};\n`}}let u=this.pageContent;return u=yield(u=>__awaiter(this,void 0,void 0,(function*(){let c="",h="";this.mode===Hot_1.DeveloperMode.Development&&(c="tempMode = HotStaqWeb.DeveloperMode.Development;",null!=this.hotSite&&null!=this.hotSite.testing&&null!=this.hotSite.testing.web&&(h=this.testerApiContent,null==this.hotSite.testing.web.testerAPIUrl&&(this.hotSite.testing.web.testerAPIUrl="http://127.0.0.1:8182"),h=h.replace(/\%base\_tester\_url\%/g,`"${this.hotSite.testing.web.testerAPIUrl}"`)));let p="";if(Object.keys(this.files).length>0){p+="var files = {};\n\n";for(let t in this.files){let e=this.files[t],n=new HotAsset_1.HotAsset("html",t);""!==e.localFile&&(n.path=e.localFile),""!==e.url&&(n.path=e.url),""!==e.content&&(n.path="",n.content=e.content);let r=yield n.output();if("string"==typeof r)throw new Error("During initial load, HTML assets cannot be outputted using only a string!");let o="",s="";null!=r.url&&(o=`"url": "${r.url}", `),null!=r.content&&(s=`"content": ${r.content}`),p+=`\t\t\tfiles["${r.name}"] = { ${o}${s} };\n`}p+="\t\t\tpromises.push (processor.loadHotFiles (files));\n"}u=u.replace(/\%title\%/g,e),!0===o&&(u=u.replace(/\%args\%/g,"Hot.Arguments")),null!=s&&(u=u.replace(/\%args\%/g,JSON.stringify(s)));let d=t,f="",m="",g="HotTesterMochaSelenium";for(let t in this.testers){g=t;break}null!=this.hotSite&&(null!=this.hotSite.testing&&null!=this.hotSite.testing.web&&(null!=this.hotSite.testing.web.testerName&&(g=this.hotSite.testing.web.testerName),null!=this.hotSite.testing.web.testerAPIUrl&&(f=this.hotSite.testing.web.testerAPIUrl),null!=this.hotSite.testing.web.launchpadUrl&&(m=this.hotSite.testing.web.launchpadUrl)),null!=this.hotSite.routes&&null!=this.hotSite.routes[t])&&(d=this.hotSite.routes[t].name);let _="";return 0!==this.startDelay&&(_=`await HotStaq.wait (${this.startDelay});`),u=(u=(u=(u=(u=(u=(u=(u=(u=(u=(u=(u=(u=(u=u.replace(/\%start\_delay\%/g,_)).replace(/\%logging\_level\%/g,`HotLogLevel.${HotLog_1.HotLogLevel[this.logger.logLevel]}`)).replace(/\%hotstaq\_js\_src\%/g,r)).replace(/\%developer\_mode\%/g,c)).replace(/\%tester\_api\%/g,h)).replace(/\%apis\_to\_load\%/g,i)).replace(/\%load\_files\%/g,p)).replace(/\%api\_code\%/g,l)).replace(/\%public\_secrets\%/g,a)).replace(/\%url\%/g,n)).replace(/\%tester\_name\%/g,`"${g}"`)).replace(/\%tester\_map\%/g,`"${d}"`)).replace(/\%tester\_api\_base\_url\%/g,`"${f}"`)).replace(/\%tester\_launchpad\_url\%/g,`"${m}"`)})))(u),u}))}createExpressRoutes(t,e="./js/HotStaq.min.js"){return __awaiter(this,void 0,void 0,(function*(){for(let n in this.pages){let r=this.pages[n];const o=yield this.generateContent(r.route,r.name,r.files[0].url,e);t.get(r.route,((t,e)=>{this.logger.verbose("Sending custom Express content."),e.status(200).send(o)}))}}))}addTester(t){this.testers[t.name]=t}getWebTestingMaps(){if(null==this.hotSite)throw new Error("No HotSite was loaded!");if(null==this.hotSite.testing)throw new Error("The HotSite does not have a testing object!");if(null==this.hotSite.testing.web)throw new Error("The HotSite does not have a testing web object!");if(null==this.hotSite.testing.web.maps)throw new Error("The HotSite testing object does not have any maps!");return this.hotSite.testing.web.maps}getAPITestingMaps(){if(null==this.hotSite)throw new Error("No HotSite was loaded!");if(null==this.hotSite.testing)throw new Error("The HotSite does not have a testing object!");if(null==this.hotSite.testing.api)throw new Error("The HotSite does not have a testing api object!");if(null==this.hotSite.testing.api.maps)throw new Error("The HotSite testing object does not have any maps!");return this.hotSite.testing.api.maps}getRouteKeyFromName(t){let e="";if(null!=this.hotSite&&null!=this.hotSite.routes)for(let n in this.hotSite.routes)if(this.hotSite.routes[n].name===t){e=n;break}return e}getRouteFromName(t){let e=null,n=this.getRouteKeyFromName(t);return""!==n&&(e=this.hotSite.routes[n]),e}executeTests(t,e){return __awaiter(this,void 0,void 0,(function*(){let n=this.testers[t];if(null==n)throw new Error(`Unable to execute tests. Tester ${t} does not exist!`);return n.execute(e)}))}executeAllWebTests(t){return __awaiter(this,void 0,void 0,(function*(){let e=this.getWebTestingMaps();if(null==this.testers[t])throw new Error(`Unable to execute tests. Tester ${t} does not exist!`);for(let n=0;n<e.length;n++){let r=e[n];yield this.executeTests(t,r)}}))}executeAllAPITests(t){return __awaiter(this,void 0,void 0,(function*(){let e=this.getAPITestingMaps();if(null==this.testers[t])throw new Error(`Unable to execute tests. Tester ${t} does not exist!`);this.logger.verbose((()=>`Executing all API tests for tester ${t}. Maps: ${JSON.stringify(e)}`));for(let n=0;n<e.length;n++){let r=e[n];yield this.executeTests(t,r)}}))}process(t,e=null){return __awaiter(this,void 0,void 0,(function*(){let n=this.getPage(t);return yield n.process(e)}))}static processLocalFile(t,e=t,n=null){return __awaiter(this,void 0,void 0,(function*(){let r=new HotStaq,o=new HotFile_1.HotFile({localFile:t});yield o.load();let s=new HotPage_1.HotPage({processor:r,name:e,files:[o]});return r.addPage(s),yield r.process(e,n)}))}static processUrl(t){return __awaiter(this,void 0,void 0,(function*(){let e=new HotFile_1.HotFile({url:t.url});yield e.load();let n=new HotPage_1.HotPage({processor:t.processor,name:t.name,files:[e],testerName:t.testerName,testerMap:t.testerMap});return t.processor.addPage(n),yield t.processor.process(t.name,t.args)}))}static processContent(t){return __awaiter(this,void 0,void 0,(function*(){let e=new HotFile_1.HotFile({content:t.content});yield e.load();let n=new HotPage_1.HotPage({processor:t.processor,name:t.name,files:[e]});return t.processor.addPage(n),yield t.processor.process(t.name,t.args)}))}static onReady(t){"complete"===document.readyState||"interactive"===document.readyState?t():window.addEventListener("load",t)}static useOutput(t){return __awaiter(this,void 0,void 0,(function*(){let e=(new DOMParser).parseFromString(t,"text/html");document.getElementsByTagName("html")[0].innerHTML=e.getElementsByTagName("html")[0].innerHTML;let n=document.getElementsByTagName("script");if(n.length>0){let t=[];for(let e=0;e<n.length;e++)t.push(n[e]);for(let e=0;e<t.length;e++){let n=document.createElement("script");t[e].parentNode.appendChild(n),t[e].parentNode.removeChild(t[e]),yield new Promise(((r,o)=>{n.onload=()=>{r()};let s=!1;null!=t[e].getAttribute("src")&&""!==t[e].getAttribute("src")&&(n.setAttribute("src",t[e].getAttribute("src")),s=!0),null!=t[e].getAttribute("type")&&""!==t[e].getAttribute("type")&&n.setAttribute("type",t[e].getAttribute("type")),n.innerHTML=t[e].innerHTML,!1===s&&r()}))}}}))}static waitForTesters(){return __awaiter(this,void 0,void 0,(function*(){for(;!1===HotStaq.isReadyForTesting;)yield HotStaq.wait(10);null!=HotStaq.onReadyForTesting&&(yield HotStaq.onReadyForTesting())}))}static setupTesters(t,e){if(t.mode===Hot_1.DeveloperMode.Development&&null==t.testerAPI){null==e.testerAPIBaseUrl&&(e.testerAPIBaseUrl=""),""===e.testerAPIBaseUrl&&(e.testerAPIBaseUrl="http://127.0.0.1:8182");let n=new HotClient_1.HotClient(t),r=new HotTesterAPI_1.HotTesterAPI(e.testerAPIBaseUrl,n);r.connection.api=r,t.testerAPI=r}}static setupClientTesters(t){let e="";return t.mode===Hot_1.DeveloperMode.Development&&(e+='<script type = "text/javascript">\nfunction hotstaq_isDocumentReady ()\n{\nif (window["Hot"] != null)\n{\nif (Hot.Mode === HotStaqWeb.DeveloperMode.Development)\n{\nlet func = function ()\n\t{\n\t\tif (Hot.TesterAPI != null)\n\t\t{\n\t\t\tlet testPaths = {};\n\t\t\tlet testElements = JSON.stringify (Hot.CurrentPage.testElements);\n\t\t\tlet testMaps = JSON.stringify (Hot.CurrentPage.testMaps);\n\n\t\t\tfor (let key in Hot.CurrentPage.testPaths)\n\t\t\t{\n\t\t\t\tlet testPath = Hot.CurrentPage.testPaths[key];\n\n\t\t\t\ttestPaths[key] = testPath.toString ();\n\t\t\t}\n\n\t\t\tlet testPathsStr = JSON.stringify (testPaths);\n\n\t\t\tHot.TesterAPI.tester.pageLoaded ({\n\t\t\t\t\ttesterName: Hot.CurrentPage.testerName,\n\t\t\t\t\ttesterMap: Hot.CurrentPage.testerMap,\n\t\t\t\t\tpageName: Hot.CurrentPage.name,\n\t\t\t\t\ttestElements: testElements,\n\t\t\t\t\ttestPaths: testPathsStr\n\t\t\t\t}).then (function (resp)\n\t\t\t\t\t{\n\t\t\t\t\t\tif (resp.error != null)\n\t\t\t\t\t\t{\n\t\t\t\t\t\t\tif (resp.error !== "")\n\t\t\t\t\t\t\t\tthrow new Error (resp.error);\n\t\t\t\t\t\t}\n\n\t\t\t\t\t\tHotStaqWeb.HotStaq.isReadyForTesting = true;\n\t\t\t\t\t});\n\t\t}\n\t};\n\nif ((document.readyState === "complete") || (document.readyState === "interactive"))\n\tfunc ();\nelse\n\tdocument.addEventListener ("DOMContentLoaded", func);\n}\n}\n}\n\nhotstaq_isDocumentReady ();\n<\/script>'),e}static displayUrl(t,e=null,n=null,r=null){return __awaiter(this,void 0,void 0,(function*(){return new Promise(((o,s)=>{HotStaq.onReady((()=>__awaiter(this,void 0,void 0,(function*(){let s={url:""};s.name=null==e?"string"==typeof t?t:t.name:e,""===s.name&&(s.name="string"==typeof t?t:t.name),"string"==typeof t?s.url=t:(s.url=t.url,null==n&&null!=t.processor&&(n=t.processor),null==r&&null!=t.args&&(r=t.args),null!=t.testerMap&&(s.testerMap=t.testerMap),null!=t.testerName&&(s.testerName=t.testerName),null!=t.testerAPIBaseUrl&&(s.testerAPIBaseUrl=t.testerAPIBaseUrl)),null==n&&(n=new HotStaq),HotStaq.setupTesters(n,s),s.processor=n,s.args=r,s.url.indexOf("hstqserve")<0&&(s.url+="?hstqserve=nahfam");let i=yield HotStaq.processUrl(s);i+=HotStaq.setupClientTesters(n),yield HotStaq.useOutput(i),o(n)}))))}))}))}static displayContent(t,e=null,n=null,r=null){return __awaiter(this,void 0,void 0,(function*(){return new Promise(((o,s)=>{HotStaq.onReady((()=>__awaiter(this,void 0,void 0,(function*(){let s={content:""};s.name=null==e?"string"==typeof t?"":t.name:e,""===s.name&&(s.name="string"==typeof t?"":t.name),"string"==typeof t?s.content=t:(s.content=t.content,null==n&&null!=t.processor&&(n=t.processor),null==r&&null!=t.args&&(r=t.args),null!=t.testerMap&&(s.testerMap=t.testerMap),null!=t.testerName&&(s.testerName=t.testerName),null!=t.testerAPIBaseUrl&&(s.testerAPIBaseUrl=t.testerAPIBaseUrl)),null==n&&(n=new HotStaq),HotStaq.setupTesters(n,s),s.processor=n,s.args=r;let i=yield HotStaq.processContent(s);yield HotStaq.useOutput(i),o(n)}))))}))}))}}exports.HotStaq=HotStaq,HotStaq.version="0.8.23",HotStaq.isWeb=!1,HotStaq.isReadyForTesting=!1,HotStaq.onReadyForTesting=null,HotStaq.errors={},"undefined"!=typeof document&&window.addEventListener("load",HotStaqWebStart_1.hotStaqWebStart)},638:(t,e,n)=>{"use strict";Object.defineProperty(e,"__esModule",{value:!0}),e.registerComponent=void 0;const r=n(732),o=n(260),s=n(243),i=n(507);e.registerComponent=function(t,e){if(null==t||""===t)throw new Error("All components must have a tag!");if(void 0!==customElements.get(t))return;let n=this.components;customElements.define(t,class extends HTMLElement{constructor(){super();let e=n[t];if(this.component=new e.componentType(e.processor,e.api),this.hotComponent=this.component,this.component.htmlElements=[this],this.component.inner=this.innerHTML,null!=this.component.handleAttributes)this.component.handleAttributes(this.attributes);else for(let t=0;t<this.attributes.length;t++){const e=this.attributes[t],n=e.name.toLowerCase(),r=e.value;if("id"===n&&(this.component.name=r),"name"===n&&(this.component.name=r),"value"===n&&(this.component.value=r),n.indexOf("hot-")>-1){const t=n.substring(4);this.component[t]=r}}if(null!=this.component.onPreOutput&&!1===this.component.onPreOutput())return;let l=this.component.output();null!=this.component.onPostOutput&&(l=this.component.onPostOutput(l));let a=[];"string"==typeof l?a.push({html:l}):a=l instanceof Array?l:[l];for(let t=0;t<a.length;t++){let e=a[t],n=e.html,l="";null!=e.addFunctionsTo&&(l=e.addFunctionsTo);let u=r.HotFile.parseContent(n,!0,{outputCommands:!1});null!=this.component.onParsed&&(u=this.component.onParsed(u));let c={fixedStr:"",querySelector:""};c=null!=this.component.onFixHTML?this.component.onFixHTML(u):s.HotStaq.fixHTML(u);let h=[];for(let t=this.children.length-1;t>-1;t--){let e=this.children[t];h.push(this.removeChild(e))}let p=null,d=null;if(p=null!=this.component.onParseDOM?this.component.onParseDOM(c.fixedStr):(new DOMParser).parseFromString(c.fixedStr,"text/html"),p.body.children.length<1)throw new Error(`No component output from ${this.component.name} with tag ${this.component.tag}`);if(p.body.children.length>1){let t=!0;for(let e=0;e<p.body.children.length;e++){let n=p.body.children[e];if(n instanceof HTMLElement&&"parsererror"===n.tagName.toLowerCase()){d=n,t=!1;break}}if(!0===t)throw new Error(`Only a single html element can come from component ${this.component.name}, multiple elements were detected.`)}d=""===c.querySelector?p.body.children[0]:p.querySelector(c.querySelector),this.replaceWith(d),null!=this.component.click&&d.addEventListener("click",this.component.click.bind(this.component));for(let t in this.component.events){let e=this.component.events[t];d.addEventListener(e.type,e.func,e.options)}let f=Object.getOwnPropertyNames(this.component.constructor.prototype);for(let t=0;t<f.length;t++){let e=f[t];if("constructor"!==e&&"function"==typeof this.component[e]){let t=!0;for(let n in o.HotComponent.prototype)if(e===n){t=!1;break}!0===t&&(d[e]=s.HotStaq.keepContext(this.component[e],this.component),""!==l)&&(document.querySelector(l)[e]=s.HotStaq.keepContext(this.component[e],this.component))}}null!=this.component.onPrePlace&&(d=this.component.onPrePlace(d));let m=this.component.onCreated(d);if(null!=this.component.onParentPlace&&(m.onParentPlace=this.component.onParentPlace),m.hotComponent=this.component,this.component.htmlElements.push(m),null!=e.closestSelector){let t=m;for(;t;){let n=t.querySelector(e.closestSelector);if(null!=n){t=n;break}t=t.parentElement}if(null==t)throw new Error(`Unable to find closest node with selector '${e.closestSelector}'`);m.parentElement.removeChild(m),t.appendChild(m),null!=m.onParentPlace&&m.hotComponent.onParentPlace(parentNode,m)}if(null!=e.documentSelector){let t=document.querySelector(e.documentSelector);if(null==t)throw new Error(`Unable to find document node with selector '${e.documentSelector}'`);m.parentElement.removeChild(m),t.appendChild(m),null!=m.onParentPlace&&m.hotComponent.onParentPlace(t,m)}let g=(t,e,n)=>{let r=0;for(;r<10&&null!=t&&!(t instanceof HTMLHtmlElement);){let o=t.querySelectorAll(`hot-place-here[name="${e}"]`);if(o.length>0){let t=o[0];null!=n.parentNode&&n.parentNode.removeChild(n),t.appendChild(n),null!=n.onParentPlace&&n.hotComponent.onParentPlace(t,n);break}if(o.length<1){let r=t.querySelectorAll(`[hot-place-here="${e}"]`);if(r.length>0){let t=r[0];null!=n.parentNode&&n.parentNode.removeChild(n),t.appendChild(n),null!=n.onParentPlace&&n.hotComponent.onParentPlace(t,n);break}}t=t.parentNode,r++}return t};if(null!=e.placeHereParent){let t=m.parentNode;if(t=g(t,e.placeHereParent,m),null==t)throw new Error(`Unable to find parent node with hot-place-here attribute '${e.placeHereParent}'`)}for(let t=0;t<h.length;t++){const n=h[t];let r=!1;if(void 0!==n.getAttribute){let t=n.getAttribute("hot-place-parent");if(null!=t&&""!==t){let o=m;if(o=g(o,t,n),null==o)throw new Error(`Unable to find parent node with hot-place-here attribute '${e.placeHereParent}'`);r=!0}}!1===r&&m.appendChild(n),null!=n.onParentPlace&&n.hotComponent.onParentPlace(m,n)}if(null!=this.component.onPostPlace){let t=this.component.onPostPlace(m.parentElement,m);null!=t&&(m=t)}if(void 0!==i.Hot&&null!=i.Hot.CurrentPage){let t="";null!=this.component.name&&(t=this.component.name),null!=t&&""!==t||(t=this.id),""!==t&&(i.Hot.CurrentPage.components[t]=this.component)}}}looseParseFromString(t,e){e=e.replace(/ \/>/g,">").replace(/(<(area|base|br|col|command|embed|hr|img|input|keygen|link|meta|param|source|track|wbr).*?>)/g,"$1</$2>");const n=t.parseFromString("<xml>"+e+"</xml>","text/xml"),r=t.parseFromString("","text/html");for(let t of Array.from(n.documentElement.children))r.body.appendChild(t);for(let t of Array.from(r.querySelectorAll("area,base,br,col,command,embed,hr,img,input,keygen,link,meta,param,source,track,wbr")))t.outerHTML="<"+t.outerHTML.slice(1).split("<")[0];return r}get observedAttributes(){return this.component.observedAttributes}},e)}},23:function(__unused_webpack_module,exports,__webpack_require__){"use strict";var __awaiter=this&&this.__awaiter||function(t,e,n,r){return new(n||(n=Promise))((function(o,s){function i(t){try{a(r.next(t))}catch(t){s(t)}}function l(t){try{a(r.throw(t))}catch(t){s(t)}}function a(t){var e;t.done?o(t.value):(e=t.value,e instanceof n?e:new n((function(t){t(e)}))).then(i,l)}a((r=r.apply(t,e||[])).next())}))};Object.defineProperty(exports,"__esModule",{value:!0}),exports.hotStaqWebStart=void 0;const Hot_1=__webpack_require__(507),HotClient_1=__webpack_require__(957),HotLog_1=__webpack_require__(802),HotStaq_1=__webpack_require__(243);function hotStaqWebStart(){let hotstaqElms=document.getElementsByTagName("hotstaq");if(HotStaq_1.HotStaq.isWeb=!0,void 0!==HotStaqWeb)for(let t in HotStaqWeb)window[t]=HotStaqWeb[t];if(hotstaqElms.length>0){let hotstaqElm=hotstaqElms[0];setTimeout((function(){return __awaiter(this,void 0,void 0,(function*(){let getAttr=(t,e)=>{for(let n=0;n<e.length;n++){let r=e[n];if(null!=t.getAttribute(r))return t.getAttribute(r);if(null!=t.getAttribute(`data-${r}`))return t.getAttribute(`data-${r}`)}},loadPage=getAttr(hotstaqElm,["load-page","loadPage","src"])||"",loggingLevel=getAttr(hotstaqElm,["logging-level","loggingLevel"])||null,startDelay=getAttr(hotstaqElm,["start-delay","startDelay"])||null,router=getAttr(hotstaqElm,["router"])||"",name=getAttr(hotstaqElm,["name"])||"default",args=getAttr(hotstaqElm,["args"])||null,apiLibrary=getAttr(hotstaqElm,["api-library","apiLibrary"])||null,apiName=getAttr(hotstaqElm,["api-name","apiName"])||null,apiUrl=getAttr(hotstaqElm,["api-url","apiUrl"])||null,testerName=getAttr(hotstaqElm,["tester-name","testerName"])||"HotTesterMochaSelenium",testerMap=getAttr(hotstaqElm,["tester-map","testerMap"])||null,testerApiBaseUrl=getAttr(hotstaqElm,["tester-api-base-url","testerApiBaseUrl"])||null,testerLaunchpadUrl=getAttr(hotstaqElm,["tester-launchpad-url","testerLaunchpadUrl"])||null,dontReuseProcessor=!1,passRawUrl=!1,htmlSource=hotstaqElm.innerHTML||"",routerManager={},routerWildcards=[],search=new URLSearchParams(window.location.search);null!=startDelay&&(yield HotStaq_1.HotStaq.wait(parseInt(startDelay))),null!=getAttr(hotstaqElm,["src"])&&(loadPage=getAttr(hotstaqElm,["src"])),null!=getAttr(hotstaqElm,["passRawUrl"])&&(passRawUrl=!0),null!=getAttr(hotstaqElm,["dont-reuse-processor","dontReuseProcessor"])&&(dontReuseProcessor=!0);let hstqbaseredirect=search.get("hstqbaseredirect");null!=hstqbaseredirect&&(hstqbaseredirect=decodeURI(hstqbaseredirect),window.history.replaceState("","",hstqbaseredirect),loadPage=hstqbaseredirect);let hotstaqErrors=document.getElementsByTagName("hotstaq-error");for(let t=0;t<hotstaqErrors.length;t++){let e=hotstaqErrors[t],n=getAttr(e,["status"]),r=getAttr(e,["unsupported-browser-redirect"]);null!=r?HotStaq_1.HotStaq.errors.unsupportedBrowser={redirectToUrl:r}:HotStaq_1.HotStaq.errors[`${n}`]={redirectToUrl:r}}try{eval("async () => {}")}catch(t){HotStaq_1.HotStaq.executeError("unsupportedBrowser")}if(""!==router){let t=document.getElementsByTagName("hotstaq-router");for(let e=0;e<t.length;e++){let n=t[e],r=getAttr(n,["name"]),o=getAttr(n,["serve-local","serveLocally"]);if(r===router){for(let t=0;t<n.childNodes.length;t++){let e=n.childNodes[t];if(e instanceof HTMLElement&&"ROUTE"===e.tagName.toUpperCase()){let t=getAttr(e,["path"]),n=getAttr(e,["redirect"]),r=getAttr(e,["base-redirect","baseRedirect"]),o=getAttr(e,["base"]),s=getAttr(e,["src"]);t.indexOf("*")>-1&&routerWildcards.push(t),routerManager[t]={redirect:n||void 0,baseRedirect:r||void 0,base:o||void 0,src:s||void 0}}}let t=window.location.pathname,e=window.location.pathname;if(null!=o){const n=o.toLowerCase();if("true"===n||"yes"===n||"1"===n){const n=t.lastIndexOf("/");n>-1&&(t=t.substring(n),e=e.substring(n))}}if(routerWildcards.length>0)for(let e=0;e<routerWildcards.length;e++){let n=routerWildcards[e],r=n.replace("*","");if(t.indexOf(r)>-1){t=n;break}}if(null!=routerManager[t]){if(null!=routerManager[t].redirect)return void(window.location.href=routerManager[t].redirect);if(null!=routerManager[t].baseRedirect){const n=window.location.search;let r="";return""!==n&&"?"!==n&&(r=`&${n.substring(1)}`),void(window.location.href=`${routerManager[t].baseRedirect}?hstqbaseredirect=${encodeURI(e+n)}${r}`)}null!=routerManager[t].src&&(loadPage=routerManager[t].src)}break}}}args=null!=args?JSON.parse(args):Hot_1.Hot.Arguments;let hasHtmlSource=!1;if(""!==htmlSource){const t=htmlSource.replace(/\s/g,"");""!==t&&(hasHtmlSource=!0)}let tempMode=0;null!=window.Hot&&(tempMode=Hot_1.Hot.Mode);let processor=null;!1===dontReuseProcessor&&void 0!==Hot_1.Hot&&null!=Hot_1.Hot.CurrentPage&&null!=Hot_1.Hot.CurrentPage.processor&&(processor=Hot_1.Hot.CurrentPage.processor),null==processor&&(processor=new HotStaq_1.HotStaq),null!=loggingLevel&&(processor.logger.logLevel=HotLog_1.HotLog.parse(loggingLevel)),processor.mode=tempMode;let options={name,processor,args};if(""!==loadPage&&(!1===passRawUrl&&loadPage.indexOf("hstqserve")<0&&(loadPage+="?hstqserve=nahfam"),options.url=loadPage),null!=testerMap&&(options.testerMap=testerMap,options.testerName=testerName),null!=testerName&&(options.testerName=testerName),null!=testerApiBaseUrl&&(options.testerAPIBaseUrl=testerApiBaseUrl),null!=testerLaunchpadUrl&&(options.testerLaunchpadUrl=testerLaunchpadUrl),null!=apiName){let t=new HotClient_1.HotClient(processor);if(""===apiUrl)throw new Error("api-url was not set!");let e=window;null!=apiLibrary&&(e=window[apiLibrary]);let n=new e[apiName](apiUrl,t);n.connection.api=n,processor.api=n}if(!1===hasHtmlSource){if(""===loadPage)throw new Error("The hotstaq tag must have a src, HTML contents inside it, or a router set.");HotStaq_1.HotStaq.displayUrl(options)}else HotStaq_1.HotStaq.displayContent(options)}))}),50)}}exports.hotStaqWebStart=hotStaqWebStart},473:(t,e)=>{"use strict";Object.defineProperty(e,"__esModule",{value:!0}),e.HotTestDestination=void 0;class n{constructor(t="",e=!0){"string"==typeof t?(this.destination=t,this.autoStart=e):t instanceof n?(this.destination=t.destination,this.autoStart=t.autoStart):(this.destination=t.path,this.autoStart=t.autoStart)}}e.HotTestDestination=n},628:function(t,e){"use strict";var n=this&&this.__awaiter||function(t,e,n,r){return new(n||(n=Promise))((function(o,s){function i(t){try{a(r.next(t))}catch(t){s(t)}}function l(t){try{a(r.throw(t))}catch(t){s(t)}}function a(t){var e;t.done?o(t.value):(e=t.value,e instanceof n?e:new n((function(t){t(e)}))).then(i,l)}a((r=r.apply(t,e||[])).next())}))};Object.defineProperty(e,"__esModule",{value:!0}),e.HotTestDriver=void 0,e.HotTestDriver=class{constructor(t,e=null){this.processor=t,this.page=e,this.commandDelay=20,this.persistentData={}}parseTestObject(t){let e=t.indexOf("*"),n="";e>-1&&(t=t.replace(/\*/,""),n="*");let r=`[data-test-object-name${n}='${t}']`;return e=t.indexOf(">"),e>-1&&(r=t=t.replace(/\>/,"")),r}wait(t){return n(this,void 0,void 0,(function*(){return yield new Promise(((e,n)=>{setTimeout((()=>{e()}),t)}))}))}print(t){return n(this,void 0,void 0,(function*(){process.stdout.write(t)}))}println(t){return n(this,void 0,void 0,(function*(){yield this.print(`${t}\n`)}))}destroy(){return n(this,void 0,void 0,(function*(){}))}assert(t,e=""){return n(this,void 0,void 0,(function*(){if(!t)throw new Error(e)}))}}},967:(t,e)=>{"use strict";Object.defineProperty(e,"__esModule",{value:!0}),e.HotTestElement=e.HotTestElementOptions=void 0,e.HotTestElementOptions=class{constructor(t={}){this.mustBeVisible=t.mustBeVisible||!0,this.ignoreMissingElementError=t.ignoreMissingElementError||!1}},e.HotTestElement=class{constructor(t,e="",n=null){"string"==typeof t?(this.name=t,this.func=e,this.value=n):(this.name=t.name,this.func=t.func||e,this.value=t.value||n)}}},985:(t,e,n)=>{"use strict";Object.defineProperty(e,"__esModule",{value:!0}),e.HotTestMap=void 0;const r=n(473);e.HotTestMap=class{constructor(t=[],e={},n=[]){if(t instanceof Array){this.destinations=[];for(let e=0;e<t.length;e++){let n=t[e];this.destinations.push(new r.HotTestDestination(n))}}else{this.destinations={};for(let e in t){let n=t[e];this.destinations[e]=new r.HotTestDestination(n)}}this.destinationOrder=n,this.pages=e}}},677:function(t,e,n){"use strict";var r=this&&this.__awaiter||function(t,e,n,r){return new(n||(n=Promise))((function(o,s){function i(t){try{a(r.next(t))}catch(t){s(t)}}function l(t){try{a(r.throw(t))}catch(t){s(t)}}function a(t){var e;t.done?o(t.value):(e=t.value,e instanceof n?e:new n((function(t){t(e)}))).then(i,l)}a((r=r.apply(t,e||[])).next())}))};Object.defineProperty(e,"__esModule",{value:!0}),e.HotTester=void 0;const o=n(243);class s{constructor(t,e,n,r,o={}){if(null==o)throw new Error("The testMaps parameter can be an empty object, but cannot be null! It is set to null.");this.processor=t,this.name=e,this.timeout=1e4,this.baseUrl=n,this.testMaps=o,this.driver=r,this.finishedLoading=!1,this.hasBeenSetup=!1,this.hasBeenDestroyed=!1}setup(t,e,n){return r(this,void 0,void 0,(function*(){}))}destroy(){return r(this,void 0,void 0,(function*(){}))}waitForData(){return r(this,void 0,void 0,(function*(){for(;!1===this.finishedLoading;)yield o.HotStaq.wait(10)}))}getTestPage(t){return this.testMaps[t.mapName].pages[t.page]}getTestPath(t,e){return this.testMaps[t.mapName].pages[t.page].testPaths[e]}static interpretDestination(t,e){let n={mapName:t,page:"",api:"",paths:[]},r=e.destination.split(/\-\>/g),o=r[0];if(o.length<2)return null;if("/"===o[0]&&"/"===o[1])return null;let s=(t,e)=>{let n=t.indexOf(e),r="";return n>-1&&(r=t.substr(n+e.length),r=r.trim()),r};n.page=s(o,"page:"),n.api=s(o,"api:");for(let t=1;t<r.length;t++){let e=r[t],o={cmd:"",dest:"",path:""};e=e.trim(),o.dest=s(e,"dest:"),o.cmd=s(e,"cmd:"),o.path=s(e,"path:"),""==o.dest&&""==o.cmd&&""==o.path&&(o.path=e),n.paths.push(o)}return n}executeTestAPIPath(t,e,n,o=!1,s=!1){return r(this,void 0,void 0,(function*(){let r=!0;if(null==e)throw new Error(`Trying to access null method on destination map ${t.mapName}.`);!1===o&&null!=this.onTestAPIPathStart&&(r=yield this.onTestAPIPathStart(t,e,n,s));let i=null;if(!0===r){let t=e.testCases[n];if(null==t)throw new Error(`HotTester: Test case object ${n} does not exist!`);i=yield t.func(this.driver)}return!1===o&&null!=this.onTestAPIPathEnd&&(yield this.onTestAPIPathEnd(t,e,n,i,s)),i}))}executeTestAPIPaths(t){return r(this,void 0,void 0,(function*(){let e=[];if(null==this.testMaps[t.mapName])throw new Error(`HotTester: API Map ${t.mapName} does not exist!`);if(null==this.processor.api)throw new Error("HotTester: Associated processor does not have an API!");let n=this.processor.api.routes[t.api];if(null==n)throw new Error(`HotTester: API does not have route ${t.api}!`);for(let r=0;r<t.paths.length;r+=2){let o=t.paths[r].path,s=n.getMethod(o),i=t.paths[r+1].path;if(null==s)throw new Error(`Unable to find method related to path ${o} in map ${t.mapName}`);let l=yield this.executeTestAPIPath(t,s,i);e.push(l)}return e}))}executeTestPagePath(t,e,n=!1,o=!1){return r(this,void 0,void 0,(function*(){let r=!0,s=this.testMaps[t.mapName];if(null==s)throw new Error(`HotTester: Web Map ${t.mapName} does not exist!`);let i=s.pages[t.page];if(null==i)throw new Error(`HotTester: Page ${t.page} does not exist!`);this.driver.page=i;let l=e.path,a=i.testPaths[l];!1===n&&null!=this.onTestPagePathStart&&(r=yield this.onTestPagePathStart(t,i,e,o));let u=null;if(!0===r){if(null==a)throw new Error(`HotTester: Test path ${l} does not have a function!`);u=yield a(this.driver)}return!1===n&&null!=this.onTestPagePathEnd&&(yield this.onTestPagePathEnd(t,a,u,o)),u}))}executeCommand(t,e,n,s){return r(this,void 0,void 0,(function*(){let i=(t,e,r)=>{let o=!1;n.cmd===e&&(o=!0);const s=n.cmd.indexOf("(");return s>-1&&n.cmd.substr(0,s)===e&&(o=!0),o},l=t=>{let e=[],n=t.match(/(?=\()(.*?)(?=\))/g);if(null!=n){let t=n[0];t=t.substr(2,t.length),e.push(t)}if(e.length<1)throw new Error(`HotTester: Command ${t} requires arguments, but none were supplied.`);return e},a=null,u=null,c=[];if("undefined"!=typeof HotTesterMochaSelenium&&this instanceof HotTesterMochaSelenium&&(a=this),null!=a&&(!0===i(n.cmd,"url")&&(c=l(n.cmd),u=t=>r(this,void 0,void 0,(function*(){let e=t[0];yield a.driver.navigateToUrl(e)}))),!0===i(n.cmd,"waitForTestObject")&&(c=l(n.cmd),u=t=>r(this,void 0,void 0,(function*(){let e=JSON.parse(t[0]);yield a.driver.waitForTestElement(e)})))),!0===i(n.cmd,"waitForTesterAPIData")&&(u=t=>r(this,void 0,void 0,(function*(){this.finishedLoading=!1,yield this.waitForData()}))),!0===i(n.cmd,"wait")&&(c=l(n.cmd),u=t=>r(this,void 0,void 0,(function*(){let e=parseInt(t[0]);yield o.HotStaq.wait(e)}))),!0===i(n.cmd,"print")&&(c=l(n.cmd),u=t=>r(this,void 0,void 0,(function*(){let e=t[0];yield this.driver.print(e)}))),!0===i(n.cmd,"println")&&(c=l(n.cmd),u=t=>r(this,void 0,void 0,(function*(){let e=t[0];yield this.driver.println(e)}))),null==u)throw new Error(`HotTester: Command ${n.cmd} does not exist!`);yield this.onCommand(t,e,n,s,c,u)}))}executeTestPagePaths(t,e=!1){return r(this,void 0,void 0,(function*(){let n=[],r=this.testMaps[t.mapName];if(null==r)throw new Error(`HotTester: Web Map ${t.mapName} does not exist!`);for(let o=0;o<t.paths.length;o++){let i=t.paths[o],l=null,a=r.pages[t.page];if(null==a)throw new Error(`HotTester: Page ${t.page} does not exist!`);if(""!==i.dest){if(r.destinations instanceof Array)throw new Error(`HotTester: When using type 'dest' in a destination string, all destinations in map ${t.mapName} must be named.`);let e=r.destinations[i.dest],n=s.interpretDestination(t.mapName,e);null!=n&&(l=yield this.executeTestPagePaths(n))}""!==i.cmd&&(yield this.executeCommand(t,a,i,i.cmd)),""!==i.path&&(l=yield this.executeTestPagePath(t,i,!1,e)),n.push(l)}return n}))}execute(t){return r(this,void 0,void 0,(function*(){let e=this.testMaps[t];if(null==e)throw new Error(`HotTester: Map ${t} does not exist!`);this.processor.logger.verbose(`HotTester: Executing map ${t}...`);let n=this.processor.getRouteKeyFromName(t),o="";this.baseUrl,""!==n&&(o=`${this.baseUrl}${n}`);let i=(e,n="")=>r(this,void 0,void 0,(function*(){if(!1!==e.autoStart)try{this.processor.logger.verbose((()=>`HotTester: Executing ${t} destination ${JSON.stringify(e)}...`));let r=s.interpretDestination(t,e),i=!1,l=!0;""!==r.page&&(i=!0),null!=this.setup&&!1===this.hasBeenSetup&&(yield this.setup(i,o,n),this.hasBeenSetup=!0,this.hasBeenDestroyed=!1),null!=this.onTestStart&&(l=yield this.onTestStart(r,o,n)),!0===l&&(""!==r.page&&(yield this.executeTestPagePaths(r)),""!==r.api&&(yield this.executeTestAPIPaths(r))),null!=this.onTestEnd&&(yield this.onTestEnd(r)),null!=this.destroy&&!1===this.hasBeenDestroyed&&(yield this.destroy(),this.hasBeenDestroyed=!0,this.hasBeenSetup=!1)}catch(t){throw t}}));if(e.destinations instanceof Array)for(let t=0;t<e.destinations.length;t++){let n=e.destinations[t];yield i(n)}else if(e.destinationOrder.length>0){let t=[];for(let n=0;n<e.destinationOrder.length;n++){let r=e.destinationOrder[n],o=e.destinations[r];if(null==o)throw new Error(`HotTester: Destination ${r} does not exist!`);t.push(r),yield i(o,r)}for(let n in e.destinations){let r=!0;for(let e=0;e<t.length;e++)if(t[e]===n){r=!1;break}if(!0===r){let t=e.destinations[n];yield i(t,n)}}}else for(let t in e.destinations){let n=e.destinations[t];yield i(n,t)}}))}}e.HotTester=s},414:function(__unused_webpack_module,exports,__webpack_require__){"use strict";var __awaiter=this&&this.__awaiter||function(t,e,n,r){return new(n||(n=Promise))((function(o,s){function i(t){try{a(r.next(t))}catch(t){s(t)}}function l(t){try{a(r.throw(t))}catch(t){s(t)}}function a(t){var e;t.done?o(t.value):(e=t.value,e instanceof n?e:new n((function(t){t(e)}))).then(i,l)}a((r=r.apply(t,e||[])).next())}))};Object.defineProperty(exports,"__esModule",{value:!0}),exports.HotTesterAPI=void 0;const HotAPI_1=__webpack_require__(233),HotRoute_1=__webpack_require__(761),HotRouteMethod_1=__webpack_require__(70);class HotTesterAPI extends HotAPI_1.HotAPI{constructor(t,e=null,n=null){super(t,e,n),this.executeEventsUsing=HotAPI_1.EventExecutionType.HotAPI;let r=new HotRoute_1.HotRoute(e,"tester");r.addMethod({name:"pageLoaded",onServerExecute:this.pageLoaded,parameters:{testerName:{required:!0,type:"string",description:"The name of the tester executing the test."},testerMap:{required:!0,type:"string",description:"The tester map executing the test."},pageName:{required:!0,type:"string",description:"The name of the page executing the test."},testElements:{required:!0,type:"array",description:"The test elements on the page."},testPaths:{required:!0,type:"array",description:"The test paths on the page."}},returns:"Returns true as an acknowledgement."}),r.addMethod({name:"executeTests",onServerExecute:this.executeTests,parameters:{testerName:{required:!0,type:"string",description:"The name of the tester executing the test."},testerMap:{required:!0,type:"object",description:"The tester map to execute."}},returns:"Returns true when tests are complete."}),r.addMethod({name:"heartbeat",type:HotRouteMethod_1.HotEventMethod.GET,onServerExecute:this.heartbeat,returns:"Returns true as an acknowledgement."}),this.addRoute(r)}pageLoaded(request){return __awaiter(this,void 0,void 0,(function*(){let testerObj={testerName:request.jsonObj.testerName,testerMap:request.jsonObj.testerMap,pageName:request.jsonObj.pageName,testElements:request.jsonObj.testElements,testPathsStrs:request.jsonObj.testPaths};for(let t in testerObj){let e=testerObj[t],n=!1;if(null==e&&(n=!0),""!=testerObj.testerName&&""!==testerObj.testerMap&&""!==testerObj.testElements&&""!==testerObj.testPathsStrs||(n=!0),!0===n)throw new Error(`TesterAPI: Object ${t} was not passed.`)}testerObj.testElements=JSON.parse(testerObj.testElements),testerObj.testPathsStrs=JSON.parse(testerObj.testPathsStrs);let testPaths={};for(let key in testerObj.testPathsStrs){let testPath=eval(testerObj.testPathsStrs[key]);testPaths[key]=testPath}let tester=this.connection.processor.testers[testerObj.testerName];if(null==tester)throw new Error(`TesterAPI: Tester ${testerObj.testerName} does not exist!`);let testMap=tester.testMaps[testerObj.testerMap];if(null==testMap)throw new Error(`TesterAPI: Tester map ${testerObj.testerMap} does not exist!`);return testMap.pages[testerObj.pageName]={testElements:{},testPaths:{}},testMap.pages[testerObj.pageName].testElements=testerObj.testElements,testMap.pages[testerObj.pageName].testPaths=testPaths,tester.finishedLoading=!0,null!=tester.onFinishedLoading&&(yield tester.onFinishedLoading()),!0}))}executeTests(t){return __awaiter(this,void 0,void 0,(function*(){let e=t.jsonObj.testerName,n=t.jsonObj.testerMap;if(null==e||null==n)throw new Error("TesterAPI: Not all required json objects were passed.");if(""===e||""===n)throw new Error("TesterAPI: Not all required json objects were passed.");let r=this.connection;return null!=r.executeTests&&(yield r.executeTests(e,n)),!0}))}heartbeat(t){return __awaiter(this,void 0,void 0,(function*(){return!0}))}}exports.HotTesterAPI=HotTesterAPI},651:t=>{"use strict";t.exports={}},351:()=>{},606:()=>{}},__webpack_module_cache__={};function __webpack_require__(t){var e=__webpack_module_cache__[t];if(void 0!==e)return e.exports;var n=__webpack_module_cache__[t]={exports:{}};return __webpack_modules__[t].call(n.exports,n,n.exports,__webpack_require__),n.exports}__webpack_require__.g=function(){if("object"==typeof globalThis)return globalThis;try{return this||new Function("return this")()}catch(t){if("object"==typeof window)return window}}();var __webpack_exports__={};(()=>{"use strict";var t=__webpack_exports__;Object.defineProperty(t,"__esModule",{value:!0}),t.HotTestDriver=t.HotTestElementOptions=t.HotTestElement=t.HotTestDestination=t.HotTestMap=t.HotTesterAPI=t.HotTester=t.HotClient=t.HotServerType=t.HotServer=t.ServerRequest=t.HotEventMethod=t.HotRouteMethod=t.HotRoute=t.HotPage=t.HotLogLevel=t.HotLog=t.HotFile=t.EventExecutionType=t.HotAPI=t.HotComponent=t.DeveloperMode=t.HotAsset=t.HotModule=t.Hot=t.HotStaq=void 0;const e=__webpack_require__(243);Object.defineProperty(t,"HotStaq",{enumerable:!0,get:function(){return e.HotStaq}});const n=__webpack_require__(507);Object.defineProperty(t,"Hot",{enumerable:!0,get:function(){return n.Hot}}),Object.defineProperty(t,"DeveloperMode",{enumerable:!0,get:function(){return n.DeveloperMode}});const r=__webpack_require__(316);Object.defineProperty(t,"HotAsset",{enumerable:!0,get:function(){return r.HotAsset}});const o=__webpack_require__(202);Object.defineProperty(t,"HotModule",{enumerable:!0,get:function(){return o.HotModule}});const s=__webpack_require__(260);Object.defineProperty(t,"HotComponent",{enumerable:!0,get:function(){return s.HotComponent}});const i=__webpack_require__(732);Object.defineProperty(t,"HotFile",{enumerable:!0,get:function(){return i.HotFile}});const l=__webpack_require__(802);Object.defineProperty(t,"HotLog",{enumerable:!0,get:function(){return l.HotLog}}),Object.defineProperty(t,"HotLogLevel",{enumerable:!0,get:function(){return l.HotLogLevel}});const a=__webpack_require__(136);Object.defineProperty(t,"HotPage",{enumerable:!0,get:function(){return a.HotPage}});const u=__webpack_require__(233);Object.defineProperty(t,"HotAPI",{enumerable:!0,get:function(){return u.HotAPI}}),Object.defineProperty(t,"EventExecutionType",{enumerable:!0,get:function(){return u.EventExecutionType}});const c=__webpack_require__(761);Object.defineProperty(t,"HotRoute",{enumerable:!0,get:function(){return c.HotRoute}});const h=__webpack_require__(70);Object.defineProperty(t,"HotRouteMethod",{enumerable:!0,get:function(){return h.HotRouteMethod}}),Object.defineProperty(t,"HotEventMethod",{enumerable:!0,get:function(){return h.HotEventMethod}}),Object.defineProperty(t,"ServerRequest",{enumerable:!0,get:function(){return h.ServerRequest}});const p=__webpack_require__(810);Object.defineProperty(t,"HotServer",{enumerable:!0,get:function(){return p.HotServer}}),Object.defineProperty(t,"HotServerType",{enumerable:!0,get:function(){return p.HotServerType}});const d=__webpack_require__(957);Object.defineProperty(t,"HotClient",{enumerable:!0,get:function(){return d.HotClient}});const f=__webpack_require__(628);Object.defineProperty(t,"HotTestDriver",{enumerable:!0,get:function(){return f.HotTestDriver}});const m=__webpack_require__(967);Object.defineProperty(t,"HotTestElement",{enumerable:!0,get:function(){return m.HotTestElement}}),Object.defineProperty(t,"HotTestElementOptions",{enumerable:!0,get:function(){return m.HotTestElementOptions}});const g=__webpack_require__(677);Object.defineProperty(t,"HotTester",{enumerable:!0,get:function(){return g.HotTester}});const _=__webpack_require__(414);Object.defineProperty(t,"HotTesterAPI",{enumerable:!0,get:function(){return _.HotTesterAPI}});const v=__webpack_require__(985);Object.defineProperty(t,"HotTestMap",{enumerable:!0,get:function(){return v.HotTestMap}});const w=__webpack_require__(473);Object.defineProperty(t,"HotTestDestination",{enumerable:!0,get:function(){return w.HotTestDestination}}),e.HotStaq.isWeb=!0})(),HotStaqWeb=__webpack_exports__})();
2
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"HotStaq.js","mappings":"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","sources":["webpack://HotStaqWeb/./node_modules/form-data/lib/browser.js","webpack://HotStaqWeb/./node_modules/js-cookie/dist/js.cookie.js","webpack://HotStaqWeb/./node_modules/node-fetch/browser.js","webpack://HotStaqWeb/./src/Hot.ts","webpack://HotStaqWeb/./src/HotAPI.ts","webpack://HotStaqWeb/./src/HotAsset.ts","webpack://HotStaqWeb/./src/HotClient.ts","webpack://HotStaqWeb/./src/HotComponent.ts","webpack://HotStaqWeb/./src/HotFile.ts","webpack://HotStaqWeb/./src/HotLog.ts","webpack://HotStaqWeb/./src/HotModule.ts","webpack://HotStaqWeb/./src/HotPage.ts","webpack://HotStaqWeb/./src/HotRoute.ts","webpack://HotStaqWeb/./src/HotRouteMethod.ts","webpack://HotStaqWeb/./src/HotServer.ts","webpack://HotStaqWeb/./src/HotStaq.ts","webpack://HotStaqWeb/./src/HotStaqRegisterComponent.ts","webpack://HotStaqWeb/./src/HotStaqWebStart.ts","webpack://HotStaqWeb/./src/HotTestDestination.ts","webpack://HotStaqWeb/./src/HotTestDriver.ts","webpack://HotStaqWeb/./src/HotTestElement.ts","webpack://HotStaqWeb/./src/HotTestMap.ts","webpack://HotStaqWeb/./src/HotTester.ts","webpack://HotStaqWeb/./src/HotTesterAPI.ts","webpack://HotStaqWeb/external var \"{}\"","webpack://HotStaqWeb/webpack/bootstrap","webpack://HotStaqWeb/webpack/runtime/global","webpack://HotStaqWeb/./src/api-web.ts"],"sourcesContent":["/* eslint-env browser */\nmodule.exports = typeof self == 'object' ? self.FormData : window.FormData;\n","/*! js-cookie v3.0.1 | MIT */\n;\n(function (global, factory) {\n  typeof exports === 'object' && typeof module !== 'undefined' ? module.exports = factory() :\n  typeof define === 'function' && define.amd ? define(factory) :\n  (global = global || self, (function () {\n    var current = global.Cookies;\n    var exports = global.Cookies = factory();\n    exports.noConflict = function () { global.Cookies = current; return exports; };\n  }()));\n}(this, (function () { 'use strict';\n\n  /* eslint-disable no-var */\n  function assign (target) {\n    for (var i = 1; i < arguments.length; i++) {\n      var source = arguments[i];\n      for (var key in source) {\n        target[key] = source[key];\n      }\n    }\n    return target\n  }\n  /* eslint-enable no-var */\n\n  /* eslint-disable no-var */\n  var defaultConverter = {\n    read: function (value) {\n      if (value[0] === '\"') {\n        value = value.slice(1, -1);\n      }\n      return value.replace(/(%[\\dA-F]{2})+/gi, decodeURIComponent)\n    },\n    write: function (value) {\n      return encodeURIComponent(value).replace(\n        /%(2[346BF]|3[AC-F]|40|5[BDE]|60|7[BCD])/g,\n        decodeURIComponent\n      )\n    }\n  };\n  /* eslint-enable no-var */\n\n  /* eslint-disable no-var */\n\n  function init (converter, defaultAttributes) {\n    function set (key, value, attributes) {\n      if (typeof document === 'undefined') {\n        return\n      }\n\n      attributes = assign({}, defaultAttributes, attributes);\n\n      if (typeof attributes.expires === 'number') {\n        attributes.expires = new Date(Date.now() + attributes.expires * 864e5);\n      }\n      if (attributes.expires) {\n        attributes.expires = attributes.expires.toUTCString();\n      }\n\n      key = encodeURIComponent(key)\n        .replace(/%(2[346B]|5E|60|7C)/g, decodeURIComponent)\n        .replace(/[()]/g, escape);\n\n      var stringifiedAttributes = '';\n      for (var attributeName in attributes) {\n        if (!attributes[attributeName]) {\n          continue\n        }\n\n        stringifiedAttributes += '; ' + attributeName;\n\n        if (attributes[attributeName] === true) {\n          continue\n        }\n\n        // Considers RFC 6265 section 5.2:\n        // ...\n        // 3.  If the remaining unparsed-attributes contains a %x3B (\";\")\n        //     character:\n        // Consume the characters of the unparsed-attributes up to,\n        // not including, the first %x3B (\";\") character.\n        // ...\n        stringifiedAttributes += '=' + attributes[attributeName].split(';')[0];\n      }\n\n      return (document.cookie =\n        key + '=' + converter.write(value, key) + stringifiedAttributes)\n    }\n\n    function get (key) {\n      if (typeof document === 'undefined' || (arguments.length && !key)) {\n        return\n      }\n\n      // To prevent the for loop in the first place assign an empty array\n      // in case there are no cookies at all.\n      var cookies = document.cookie ? document.cookie.split('; ') : [];\n      var jar = {};\n      for (var i = 0; i < cookies.length; i++) {\n        var parts = cookies[i].split('=');\n        var value = parts.slice(1).join('=');\n\n        try {\n          var foundKey = decodeURIComponent(parts[0]);\n          jar[foundKey] = converter.read(value, foundKey);\n\n          if (key === foundKey) {\n            break\n          }\n        } catch (e) {}\n      }\n\n      return key ? jar[key] : jar\n    }\n\n    return Object.create(\n      {\n        set: set,\n        get: get,\n        remove: function (key, attributes) {\n          set(\n            key,\n            '',\n            assign({}, attributes, {\n              expires: -1\n            })\n          );\n        },\n        withAttributes: function (attributes) {\n          return init(this.converter, assign({}, this.attributes, attributes))\n        },\n        withConverter: function (converter) {\n          return init(assign({}, this.converter, converter), this.attributes)\n        }\n      },\n      {\n        attributes: { value: Object.freeze(defaultAttributes) },\n        converter: { value: Object.freeze(converter) }\n      }\n    )\n  }\n\n  var api = init(defaultConverter, { path: '/' });\n  /* eslint-enable no-var */\n\n  return api;\n\n})));\n","\"use strict\";\n\n// ref: https://github.com/tc39/proposal-global\nvar getGlobal = function () {\n\t// the only reliable means to get the global object is\n\t// `Function('return this')()`\n\t// However, this causes CSP violations in Chrome apps.\n\tif (typeof self !== 'undefined') { return self; }\n\tif (typeof window !== 'undefined') { return window; }\n\tif (typeof global !== 'undefined') { return global; }\n\tthrow new Error('unable to locate global object');\n}\n\nvar global = getGlobal();\n\nmodule.exports = exports = global.fetch;\n\n// Needed for TypeScript and Webpack.\nif (global.fetch) {\n\texports.default = global.fetch.bind(global);\n}\n\nexports.Headers = global.Headers;\nexports.Request = global.Request;\nexports.Response = global.Response;","import { HotFile } from \"./HotFile\";\nimport { HotPage } from \"./HotPage\";\nimport { HotStaq } from \"./HotStaq\";\nimport { HotAPI } from \"./HotAPI\";\nimport { HotTestElement } from \"./HotTestElement\";\n\nimport Cookies from \"js-cookie\";\nimport fetch from \"node-fetch\";\nimport { HotEventMethod } from \"./HotRouteMethod\";\nimport { HotComponent, IHotComponent } from \"./HotComponent\";\nimport { HotModule } from \"./HotModule\";\n\n/**\n * The available developer modes.\n */\nexport enum DeveloperMode\n{\n\t/**\n\t * The default developer mode. No tests will be executed and \n\t * any test related data will be ignored.\n\t */\n\tProduction,\n\t/**\n\t * For use during development/debugging. All test data will \n\t * be collected and executed if necessary.\n\t */\n\tDevelopment\n}\n\n/**\n * A CSS object to embed.\n */\nexport interface CSSObject\n{\n\t/**\n\t * The url to the CSS file to embed.\n\t */\n\turl: string;\n\t/**\n\t * The integrity hash to generate during initial compilation.\n\t */\n\tintegrityHash: string;\n}\n\n/**\n * The api used during processing.\n */\nexport class Hot\n{\n\t/**\n\t * The currently generated page being displayed. This is cleared between every file processed.\n\t */\n\tstatic CurrentPage: HotPage = null;\n\t/**\n\t * The arguments passed.\n\t */\n\tstatic Arguments: any = null;\n\t/**\n\t * The mode in which this application is running. If it's set to development mode, all testing\n\t * related data will be collected, parsed, and executed if necessary.\n\t */\n\tstatic DeveloperMode = DeveloperMode;\n\t/**\n\t * The mode in which this application is running. If it's set to development mode, all testing\n\t * related data will be collected, parsed, and executed if necessary.\n\t */\n\tstatic HotTestElement = HotTestElement;\n\t/**\n\t * The mode in which this application is running. If it's set to development mode, all testing\n\t * related data will be collected, parsed, and executed if necessary.\n\t */\n\tstatic Mode: DeveloperMode = DeveloperMode.Production;\n\t/**\n\t *The current API used on this page. This is cleared between every file processed.\n\t */\n\tstatic API: HotAPI = null;\n\t/**\n\t * The API being used by the tester.\n\t */\n\tstatic TesterAPI: HotAPI = null;\n\t/**\n\t * Contains the buffer to output. This is cleared between every file processed.\n\t */\n\tstatic Output: string = \"\";\n\t/**\n\t * The data to share across all the different files and pages. This data will be public.\n\t */\n\tstatic Data: any = {};\n\t/**\n\t * The cookies to use between pages.\n\t */\n\tstatic Cookies: Cookies.CookiesStatic = Cookies;\n\t/**\n\t * Any public keys that need to be shown. These can be passed from HotSite.json.\n\t */\n\tstatic PublicKeys: any = {};\n\t/**\n\t * The CSS string to use when echoing out the CSS files.\n\t */\n\tstatic cssStr: string = `<link rel = \"stylesheet\" href = \"%CSS_FILE%\" />`;\n\t/**\n\t * The CSS files to use in the current page being generated.\n\t * \n\t * @todo Make this a \"string | CSSObject\" data type so it can also include \n\t * the integrity hashes as well.\n\t */\n\tstatic CSS: string[] = [];\n\t/**\n\t * The JavaScript files to use in the current page being generated.\n\t * \n\t * @todo Make this a \"string | JSFileObject\" data type so it can also include \n\t * the integrity hashes as well.\n\t */\n\tstatic JSFiles: any[] = [];\n\t/**\n\t * The JavaScript inline code to use in the current page being generated.\n\t */\n\tstatic JSScripts: any[] = [];\n\t/**\n\t * The JavaScript string to use when echoing out the Scripts files.\n\t */\n\tstatic jsFileStr: string = `<script type = \"text/javascript\" src = \"%JS_FILE%\"></script>`;\n\t/**\n\t * The JavaScript string to use when echoing out the Scripts files.\n\t */\n\tstatic jsScriptsStr: string = `<script type = \"text/javascript\">%JS_CODE%</script>`;\n\n\t/**\n\t * Retrieve a file and echo out it's contents.\n\t */\n\tstatic async include (file: HotFile | string, args: any[] = null): Promise<void>\n\t{\n\t\tif (HotStaq.isWeb === true)\n\t\t{\n\t\t\tif (typeof (file) === \"string\")\n\t\t\t{\n\t\t\t\tconst lowerFile: string = file.toLowerCase ();\n\n\t\t\t\t// If the file to be included does not have a nahfam, add it. This \n\t\t\t\t// will ensure the server sends only the file content.\n\t\t\t\tif (lowerFile.indexOf (\".hott\") > -1)\n\t\t\t\t{\n\t\t\t\t\tif (lowerFile.indexOf (\"nahfam\") < 0)\n\t\t\t\t\t\tfile += \"?hstqserve=nahfam\";\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\n\t\tHot.echo (await Hot.getFile (file, args));\n\t}\n\n\t/**\n\t * Include and execute JavaScript for use when running the preprocessor.\n\t */\n\tstatic async includeJS (file: HotFile | string, args: any[] = null, parentObject: any = null): Promise<any>\n\t{\n\t\tconst output: string = await Hot.getFile (file, args);\n\n\t\tif (HotStaq.isWeb === true)\n\t\t{\n\t\t\tif (parentObject == null)\n\t\t\t\tparentObject = window;\n\t\t}\n\t\telse\n\t\t{\n\t\t\tif (parentObject == null)\n\t\t\t\tparentObject = global;\n\t\t}\n\n\t\treturn (eval.apply (parentObject, [output]));\n\t}\n\n\t/**\n\t * Retrieve a file and echo out it's contents.\n\t */\n\tstatic async import (moduleName: string, args: any[] = null, parentObject: any = null): Promise<any>\n\t{\n\t\tlet foundModule: HotModule = Hot.CurrentPage.processor.getModule (moduleName);\n\n\t\tif (foundModule != null)\n\t\t\treturn (foundModule);\n\n\t\tconst file: string = `./hotstaq_modules/${moduleName}/index.js`;\n\t\tconst output: string = await Hot.getFile (file, args);\n\n\t\tif (HotStaq.isWeb === true)\n\t\t{\n\t\t\tif (parentObject == null)\n\t\t\t\tparentObject = window;\n\t\t}\n\t\telse\n\t\t{\n\t\t\tif (parentObject == null)\n\t\t\t\tparentObject = global;\n\t\t}\n\n\t\tlet newModule = new Function (output).apply (parentObject);\n\n\t\tif (newModule.loadHTML != null)\n\t\t\tawait newModule.loadHTML ();\n\n\t\tHot.CurrentPage.processor.addModule (moduleName, newModule);\n\n\t\treturn (newModule);\n\t}\n\n\t/**\n\t * Run an already loaded file and echo out it's contents.\n\t */\n\tstatic async runFile (fileName: string, args: any[] = null): Promise<void>\n\t{\n\t\tlet file: HotFile = Hot.CurrentPage.processor.getFile (fileName);\n\t\t/// @fixme Does the file need to be deep cloned first?\n\t\t//let clonedFile: HotFile = new HotFile (Object.assign ({}, file));\n\t\tlet tempFile: HotFile = file;\n\n\t\ttempFile.page = this.CurrentPage;\n\t\tlet content: string = await tempFile.process (args);\n\n\t\tHot.echo (content);\n\t}\n\n\t/**\n\t * Get the content of a file.\n\t */\n\tstatic async getFile (path: HotFile | string, args: any[] = null): Promise<string>\n\t{\n\t\tlet tempFile: HotFile = null;\n\n\t\tif (typeof (path) === \"string\")\n\t\t{\n\t\t\ttempFile = new HotFile ();\n\t\t\ttempFile.name = path;\n\n\t\t\tif (HotStaq.isWeb === true)\n\t\t\t\ttempFile.url = path;\n\t\t\telse\n\t\t\t\ttempFile.localFile = path;\n\t\t}\n\t\telse\n\t\t\ttempFile = path;\n\n\t\tlet checkFile: HotFile = Hot.CurrentPage.processor.getFile (tempFile.name, false);\n\n\t\tif (checkFile != null)\n\t\t\ttempFile = checkFile;\n\n\t\tawait tempFile.load ();\n\n\t\ttempFile.page = this.CurrentPage;\n\t\tlet content: string = await tempFile.process (args);\n\n\t\treturn (content);\n\t}\n\n\t/**\n\t * Make an api call.\n\t */\n\tstatic async apiCall (route: string, data: any = null, \n\t\thttpMethod: HotEventMethod = HotEventMethod.POST, \n\t\tfiles: { [name: string]: any } = {}): Promise<any>\n\t{\n\t\tlet result: any = null;\n\n\t\tif (Hot.CurrentPage == null)\n\t\t\tthrow new Error (\"Current page is null!\");\n\n\t\tif (Hot.CurrentPage.processor == null)\n\t\t\tthrow new Error (\"Current page's processor is null!\");\n\n\t\tif (Hot.CurrentPage.processor.api == null)\n\t\t\tthrow new Error (\"Current page's processor api is null! Did you forget to set the API name or URL?\");\n\n\t\tif (Hot.CurrentPage.processor.api != null)\n\t\t{\n\t\t\tresult = await Hot.CurrentPage.processor.api.makeCall (route, \n\t\t\t\t\t\t\tdata, httpMethod, files);\n\t\t}\n\n\t\treturn (result);\n\t}\n\n\t/**\n\t * Get a HTTP JSON file or request.\n\t * \n\t * @param url The full url to make the HTTP call.\n\t * \n\t * @returns The parsed JSON object.\n\t */\n\tstatic async getJSON (url: string): Promise<any>\n\t{\n\t\treturn (Hot.jsonRequest (url, null, HotEventMethod.GET));\n\t}\n\n\t/**\n\t * Make a HTTP JSON request.\n\t * \n\t * @param url The full url to make the HTTP call.\n\t * @param data The data to JSON.stringify and send.\n\t * @param httpMethod The HTTP method to use to send the data.\n\t * \n\t * @returns The parsed JSON object.\n\t */\n\tstatic async jsonRequest (url: string, data: any = null, httpMethod: HotEventMethod = HotEventMethod.POST): Promise<any>\n\t{\n\t\ttry\n\t\t{\n\t\t\tlet fetchObj = {\n\t\t\t\t\"method\": httpMethod,\n\t\t\t\t\"headers\": {\n\t\t\t\t\t\t\"Accept\": \"application/json\",\n\t\t\t\t\t\t\"Content-Type\": \"application/json\"\n\t\t\t\t\t}\n\t\t\t}\n\n\t\t\tif (httpMethod === HotEventMethod.POST)\n\t\t\t{\n\t\t\t\t/// @ts-ignore\n\t\t\t\tfetchObj[\"body\"] = JSON.stringify (data);\n\t\t\t}\n\n\t\t\tlet res = await fetch (url, fetchObj);\n\n\t\t\tif (res.ok === false)\n\t\t\t\tthrow new Error (`${res.status}: ${res.statusText}`);\n\n\t\t\tlet result: any = await res.json ();\n\n\t\t\treturn (result);\n\t\t}\n\t\tcatch (ex)\n\t\t{\n\t\t\treturn (JSON.stringify ({ \"error\": `${ex.message} - Could not fetch ${url}` }));\n\t\t}\n\t}\n\n\t/**\n\t * Make a HTTP request. This is basically just a wrapper for fetch.\n\t * \n\t * @param {string} url The full url to make the HTTP call.\n\t * @param {RequestInit} requestInit The request parameters to send.\n\t * \n\t * @returns The HTTP response.\n\t */\n\tstatic async httpRequest (url: string, requestInit: any = undefined): Promise<any>\n\t{\n\t\tlet res = await fetch (url, requestInit);\n\n\t\treturn (res);\n\t}\n\n\t/**\n\t * Echo out some output.\n\t */\n\tstatic echo (message: string): void\n\t{\n\t\tHot.Output += message;\n\t}\n\n\t/**\n\t * Echo out the CSS for the current page being generated.\n\t */\n\tstatic displayCSS (): void\n\t{\n\t\tfor (let iIdx = 0; iIdx < Hot.CSS.length; iIdx++)\n\t\t{\n\t\t\tlet cssFile: string = Hot.CSS[iIdx];\n\t\t\tlet cssOut: string = Hot.cssStr;\n\n\t\t\tcssOut = cssOut.replace (/\\%CSS_FILE\\%/g, cssFile);\n\n\t\t\tHot.echo (cssOut);\n\t\t}\n\t}\n\n\t/**\n\t * Echo out the JS files for the current page being generated.\n\t */\n\tstatic displayJSFiles (): void\n\t{\n\t\tfor (let iIdx = 0; iIdx < Hot.JSFiles.length; iIdx++)\n\t\t{\n\t\t\tlet jsFile: string = Hot.JSFiles[iIdx];\n\t\t\tlet jsFileOut: string = Hot.jsFileStr;\n\n\t\t\tjsFileOut = jsFileOut.replace (/\\%JS_FILE\\%/g, jsFile);\n\n\t\t\tHot.echo (jsFileOut);\n\t\t}\n\t}\n\n\t/**\n\t * Echo out the JS scripts for the current page being generated.\n\t */\n\tstatic displayJSScripts (): void\n\t{\n\t\tfor (let iIdx = 0; iIdx < Hot.JSScripts.length; iIdx++)\n\t\t{\n\t\t\tlet jsScript: string = Hot.JSScripts[iIdx];\n\t\t\tlet jsScriptOut: string = Hot.jsScriptsStr;\n\n\t\t\tjsScriptOut = jsScriptOut.replace (/\\%JS_CODE\\%/g, jsScript);\n\n\t\t\tHot.echo (jsScriptOut);\n\t\t}\n\t}\n}","import fetch from \"node-fetch\";\nimport FormData from \"form-data\";\n\nimport { HotServer } from \"./HotServer\";\nimport { HotRoute } from \"./HotRoute\";\nimport { HotClient } from \"./HotClient\";\nimport { HotEventMethod, HotRouteMethod, ServerAuthorizationFunction } from \"./HotRouteMethod\";\nimport { HotDB } from \"./HotDB\";\n\nimport { HotDBSchema } from \"./schemas/HotDBSchema\";\nimport { HotWebSocketServer } from \"./HotWebSocketServer\";\nimport { HotHTTPServer } from \"./HotHTTPServer\";\n\n/**\n * The API to load.\n */\nexport type APItoLoad = {\n\t/**\n\t * The imported class to load.\n\t */\n\timportedAPIClass: any;\n\t/**\n\t * The exported class name to import and instantiate.\n\t */\n\texportedClassName: string;\n\t/**\n\t * The path to the HotAPI class to load.\n\t */\n\tpath: string;\n };\n\n/**\n * The type of object to use during event executions.\n */\nexport enum EventExecutionType\n{\n\tHotRoute,\n\tHotMethod,\n\tHotAPI\n}\n\n/**\n * The API to use.\n */\nexport abstract class HotAPI\n{\n\t/**\n\t * The server connection.\n\t */\n\tconnection: HotServer | HotClient;\n\t/**\n\t * The description of the API.\n\t */\n\tdescription: string;\n\t/**\n\t * The base url for the server.\n\t */\n\tbaseUrl: string;\n\t/**\n\t * If set, this will create the route variables and functions for \n\t * easy client/server calling.\n\t */\n\tcreateFunctions: boolean;\n\t/**\n\t * The database connection.\n\t */\n\texecuteEventsUsing: EventExecutionType;\n\t/**\n\t * The database connection.\n\t */\n\tdb: HotDB;\n\t/**\n\t * The authorization credentials the client uses throughout the application. If using \n\t * basic authentication for HTTP requests, be sure to override the \n\t * `toAuthorizationHeaderString` in this object.\n\t * \n\t * Example of this object:\n\t * ```ts\n\t * this.authCredentials = {\n\t * \t\tuser: \"username\",\n\t * \t\tpassword: \"password\",\n\t * \t\ttoAuthorizationHeaderString: function ()\n\t * \t\t\t{\n\t * \t\t\t\treturn (btoa (this.user + \":\" + this.password));\n\t * \t\t\t}\n\t * \t};\n\t * ```\n\t */\n\tauthCredentials: any;\n\t/**\n\t * The function used for user authentication.\n\t */\n\tuserAuth: ServerAuthorizationFunction;\n\t/**\n\t * The database connection.\n\t */\n\troutes: { [name: string]: HotRoute };\n\t/**\n\t * Executed when the API is about to start registering routes. If \n\t * this function returns false, the server will not start.\n\t */\n\tonPreRegister: () => Promise<boolean>;\n\t/**\n\t * Executed when the API has finished registering routes. If \n\t * this function returns false, the server will not start.\n\t */\n\tonPostRegister: () => Promise<boolean>;\n\n\tconstructor (baseUrl: string, connection: HotServer | HotClient, db: HotDB = null)\n\t{\n\t\tif (connection == null)\n\t\t\tthrow new Error (`No server attached to api with baseUrl: ${baseUrl}`);\n\n\t\tthis.connection = connection;\n\t\tthis.description = \"\";\n\t\tthis.baseUrl = baseUrl;\n\t\tthis.createFunctions = true;\n\t\tthis.executeEventsUsing = EventExecutionType.HotRoute;\n\t\tthis.db = db;\n\t\tthis.authCredentials = null;\n\t\tthis.userAuth = null;\n\t\tthis.routes = {};\n\t\tthis.onPreRegister = null;\n\t\tthis.onPostRegister = null;\n\t}\n\n\t/**\n\t * Set the database schema for use.\n\t */\n\tsetDBSchema (schema: HotDBSchema): void\n\t{\n\t\tif (this.connection.api == null)\n\t\t\tthrow new Error (`No API has been set!`);\n\n\t\tif (this.connection.api.db == null)\n\t\t\tthrow new Error (`No database has been set for API base url ${this.connection.api.baseUrl}`);\n\n\t\tthis.connection.api.db.schema = schema;\n\t}\n\n\t/**\n\t * Get the database being used.\n\t */\n\tgetDB (): HotDB\n\t{\n\t\tif (this.connection.api.db == null)\n\t\t\tthrow new Error (`No database has been set for API base url ${this.connection.api.baseUrl}`);\n\n\t\treturn (this.connection.api.db);\n\t}\n\n\t/**\n\t * Get the database schema being used.\n\t */\n\tgetDBSchema (): HotDBSchema\n\t{\n\t\tif (this.connection.api.db == null)\n\t\t\tthrow new Error (`No database has been set for API base url ${this.connection.api.baseUrl}`);\n\n\t\treturn (this.connection.api.db.schema);\n\t}\n\n\t/**\n\t * Add a route. If this.createFunctions is set to true (which is default), this will take the incoming \n\t * route and create an object in this HotAPI object using the name of the route. If there's \n\t * any HotRouteMethods inside of the incoming HotRoute, it will create the methods \n\t * and attach them to the newly created HotRoute object.\n\t * \n\t * @example\n\t * ```ts\n\t * import { HotAPI, HotRoute } from \"hotstaq\";\n\t * \n\t * class AppAPI extends HotAPI\n\t * {\n\t * \t\tconstructor (baseUrl: string, connection: HotServer | HotClient = null, db: any = null)\n\t * \t\t{\n\t * \t\t\tsuper(baseUrl, connection, db);\n\t * \n\t * \t\t\t// Creates the route http://127.0.0.1:8080/v1/hello_world/\n\t * \t\t\tthis.addRoute (new ExampleRoute (this));\n\t * \t\t}\n\t * }\n\t * \n\t * class ExampleRoute extends HotRoute\n\t * {\n\t * \t\tconstructor (api: AppAPI)\n\t * \t\t{\n\t * \t\t\tsuper (api.connection, \"hello_world\");\n\t * \n\t * \t\t\t// Creates the HTTP GET endpoint: http://127.0.0.1:8080/v1/hello_world/hi\n\t * \t\t\t// When this endpoint is accessed, the JSON response will return \"hello\"\n\t * \t\t\tthis.addMethod (\"hi\", async () =>\n\t * \t\t\t{\n\t * \t\t\t\treturn (\"hello\");\n\t * \t\t\t});\n\t * \t\t}\n\t * }\n\t * ```\n\t * \n\t * In the client browser, this would be used like so:\n\t * ```\n\t * await Hot.API.hello_world.hi ();\n\t * ```\n\t * \n\t * @param route The route to add. Can be either a full HotRoute object, or just \n\t * the route's name. If a HotRoute object is supplied, the rest of the parameters \n\t * will be ignored.\n\t * @param routeMethod The route's method to add. If the route parameter is a string, \n\t * it will be interpreted as the route's name, and this will be the method added to \n\t * the new route.\n\t * @param executeFunction The function to execute when routeMethod is called by the API.\n\t */\n\taddRoute (\n\t\troute: HotRoute | string,\n\t\trouteMethod: HotRouteMethod | string = null,\n\t\texecuteFunction: (req: any, res: any, authorizedValue: any, jsonObj: any, queryObj: any) => Promise<any> = null\n\t\t): void\n\t{\n\t\tlet routeName: string = \"\";\n\n\t\tif (typeof (route) === \"string\")\n\t\t{\n\t\t\trouteName = route;\n\n\t\t\tif (this.routes[routeName] == null)\n\t\t\t\tthis.routes[routeName] = new HotRoute (this.connection, routeName);\n\n\t\t\tif (typeof (routeMethod) === \"string\")\n\t\t\t{\n\t\t\t\tthis.routes[routeName].addMethod (new HotRouteMethod (\n\t\t\t\t\tthis.routes[routeName], routeMethod, executeFunction));\n\t\t\t}\n\t\t\telse\n\t\t\t\tthis.routes[routeName].addMethod (routeMethod);\n\t\t}\n\t\telse\n\t\t{\n\t\t\trouteName = route.route;\n\t\t\tthis.routes[route.route] = route;\n\t\t}\n\n\t\tthis.routes[routeName].connection = this.connection;\n\n\t\t// Create the route functions for the server/client.\n\t\tif (this.createFunctions === true)\n\t\t{\n\t\t\t// @ts-ignore\n\t\t\tlet newRoute: { [name: string]: Function } = this[routeName];\n\n\t\t\tif (newRoute == null)\n\t\t\t\tnewRoute = {};\n\n\t\t\tfor (let iIdx = 0; iIdx < this.routes[routeName].methods.length; iIdx++)\n\t\t\t{\n\t\t\t\tlet currentRoute: HotRoute = this.routes[routeName];\n\t\t\t\tlet newRouteMethod: HotRouteMethod = this.routes[routeName].methods[iIdx];\n\n\t\t\t\t/*\n\t\t\t\t/// @fixme Is this really necessary? A HTTP call is much more preferable, \n\t\t\t\t/// especially for accruate testing.\n\t\t\t\tif (this.connection instanceof HotServer)\n\t\t\t\t{\n\t\t\t\t\tif (newRouteMethod.onServerExecute != null)\n\t\t\t\t\t\tnewRoute[newRouteMethod.name] = newRouteMethod.onServerExecute;\n\t\t\t\t}\n\t\t\t\telse*/\n\t\t\t\t{\n\t\t\t\t\t/*\n\t\t\t\t\t/// @fixme Is onClientExecute necessary? I'm thinking the dev can just simply create \n\t\t\t\t\t/// their own function to call.\n\t\t\t\t\tif (newRouteMethod.onClientExecute != null)\n\t\t\t\t\t\tnewRoute[newRouteMethod.name] = newRouteMethod.onClientExecute;\n\t\t\t\t\telse\n\t\t\t\t\t{*/\n\t\t\t\t\t\tnewRoute[newRouteMethod.name] = (data: any, files: any): any =>\n\t\t\t\t\t\t\t{\n\t\t\t\t\t\t\t\tlet httpMethod: string = newRouteMethod.type;\n\t\t\t\t\t\t\t\t// Construct the url here. Base + route + route method\n\t\t\t\t\t\t\t\tlet routeStr: string = newRouteMethod.getRouteUrl ();\n\t\t\t\t\t\t\t\tlet authCredentials: any = null;\n\n\t\t\t\t\t\t\t\t// Getting the authorization credentials from the API is the lowest \n\t\t\t\t\t\t\t\t// priority for getting credentials. The priorities are in this order: \n\t\t\t\t\t\t\t\t// 1. HotRouteMethod\n\t\t\t\t\t\t\t\t// 2. HotRoute\n\t\t\t\t\t\t\t\t// 3. HotAPI\n\t\t\t\t\t\t\t\tif (this.authCredentials != null)\n\t\t\t\t\t\t\t\t\tauthCredentials = this.authCredentials;\n\n\t\t\t\t\t\t\t\t// Find the authorization credentials. Prioritize them when they're \n\t\t\t\t\t\t\t\t// in the method. Only add the ones from the route if the ones from \n\t\t\t\t\t\t\t\t// the method are missing.\n\t\t\t\t\t\t\t\tif (newRouteMethod.authCredentials != null)\n\t\t\t\t\t\t\t\t\tauthCredentials = newRouteMethod.authCredentials;\n\t\t\t\t\t\t\t\telse\n\t\t\t\t\t\t\t\t{\n\t\t\t\t\t\t\t\t\tif (newRouteMethod.route.authCredentials != null)\n\t\t\t\t\t\t\t\t\t\tauthCredentials = newRouteMethod.route.authCredentials;\n\t\t\t\t\t\t\t\t}\n\n\t\t\t\t\t\t\t\tif (authCredentials == null)\n\t\t\t\t\t\t\t\t{\n\t\t\t\t\t\t\t\t\t// @ts-ignore\n\t\t\t\t\t\t\t\t\tif (typeof (Hot) !== \"undefined\")\n\t\t\t\t\t\t\t\t\t{\n\t\t\t\t\t\t\t\t\t\t// @ts-ignore\n\t\t\t\t\t\t\t\t\t\tif (Hot != null)\n\t\t\t\t\t\t\t\t\t\t{\n\t\t\t\t\t\t\t\t\t\t\t// @ts-ignore\n\t\t\t\t\t\t\t\t\t\t\tif (Hot.API != null)\n\t\t\t\t\t\t\t\t\t\t\t{\n\t\t\t\t\t\t\t\t\t\t\t\t// @ts-ignore\n\t\t\t\t\t\t\t\t\t\t\t\tif (Hot.API[currentRoute.route] != null)\n\t\t\t\t\t\t\t\t\t\t\t\t{\n\t\t\t\t\t\t\t\t\t\t\t\t\t// @ts-ignore\n\t\t\t\t\t\t\t\t\t\t\t\t\tif (Hot.API[currentRoute.route].authCredentials != null)\n\t\t\t\t\t\t\t\t\t\t\t\t\t{\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t// @ts-ignore\n\t\t\t\t\t\t\t\t\t\t\t\t\t\tauthCredentials = Hot.API[currentRoute.route].authCredentials;\n\t\t\t\t\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t}\n\n\t\t\t\t\t\t\t\tif (authCredentials != null)\n\t\t\t\t\t\t\t\t{\n\t\t\t\t\t\t\t\t\t// Add the authorization credentials to the data being sent.\n\t\t\t\t\t\t\t\t\tfor (let key in authCredentials)\n\t\t\t\t\t\t\t\t\t{\n\t\t\t\t\t\t\t\t\t\tlet authCredential: any = authCredentials[key];\n\n\t\t\t\t\t\t\t\t\t\t// Do not overwrite any existing keys in the data about \n\t\t\t\t\t\t\t\t\t\t// to be sent.\n\t\t\t\t\t\t\t\t\t\tif (data[key] == null)\n\t\t\t\t\t\t\t\t\t\t\tdata[key] = authCredential;\n\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t}\n\n\t\t\t\t\t\t\t\tlet args: any[] = [routeStr, data, httpMethod, files];\n\n\t\t\t\t\t\t\t\treturn (this.makeCall.apply (this, args));\n\t\t\t\t\t\t\t};\n\t\t\t\t\t//}\n\t\t\t\t}\n\t\t\t}\n\n\t\t\t// @ts-ignore\n\t\t\tthis[routeName] = newRoute;\n\t\t}\n\t}\n\n\t/**\n\t * Register a route with the server.\n\t */\n\tasync registerRoute (route: HotRoute): Promise<void>\n\t{\n\t\tif (this.connection instanceof HotServer)\n\t\t\tawait this.connection.registerRoute (route);\n\t}\n\n\t/**\n\t * Register all routes with the server.\n\t */\n\tasync registerRoutes (): Promise<void>\n\t{\n\t\tfor (let key in this.routes)\n\t\t{\n\t\t\tlet route: HotRoute = this.routes[key];\n\n\t\t\tawait this.registerRoute (route);\n\t\t}\n\t}\n\n\t/**\n\t * Make a call to the API.\n\t */\n\tasync makeCall (route: string, data: any, httpMethod: HotEventMethod = HotEventMethod.POST, \n\t\tfiles: { [name: string]: any } = {}): Promise<any>\n\t{\n\t\tlet url: string = this.baseUrl;\n\n\t\tconst httpMethodStr: string = httpMethod.toUpperCase ();\n\n\t\tif (url[(url.length - 1)] === \"/\")\n\t\t\turl = url.substr (0, (url.length - 1));\n\n\t\tif (route[0] !== \"/\")\n\t\t\turl += \"/\";\n\n\t\turl += route;\n\n\t\tconst numFiles: number = Object.keys (files).length;\n\n\t\tif (numFiles > 0)\n\t\t{\n\t\t\tif (httpMethodStr !== \"POST\")\n\t\t\t\tthrow new Error (`To upload files, you must set the httpMethod to POST.`);\n\n\t\t\tconst formData: FormData = new FormData ();\n\n\t\t\tfor (let key in files)\n\t\t\t\tformData.append (key, files[key]);\n\n\t\t\tlet res = await fetch (url, {\n\t\t\t\t\tmethod: \"POST\",\n\t\t\t\t\t// @ts-ignore\n\t\t\t\t\tbody: formData\n\t\t\t\t});\n\t\t\tlet jsonRes: any = await res.json ();\n\n\t\t\tif (data[\"hotstaq\"] == null)\n\t\t\t\tdata[\"hotstaq\"] = {};\n\n\t\t\tif (data[\"hotstaq\"][\"uploads\"] == null)\n\t\t\t\tdata[\"hotstaq\"][\"uploads\"] = {};\n\n\t\t\tdata[\"hotstaq\"][\"uploads\"][\"uploadId\"] = \n\t\t\t\t\tjsonRes[\"hotstaq\"][\"uploads\"][\"uploadId\"];\n\n\t\t\t// After the upload, make the actual JSON call. Do not pass files again.\n\t\t\tconst result: any = await this.makeCall (route, data, httpMethod);\n\n\t\t\treturn (result);\n\t\t}\n\n\t\tlet fetchObj: any = {\n\t\t\t\tmethod: httpMethod,\n\t\t\t\theaders: {\n\t\t\t\t\t\t\"Accept\": \"application/json\",\n\t\t\t\t\t\t\"Content-Type\": \"application/json\"\n\t\t\t\t\t}\n\t\t\t};\n\n\t\tif ((httpMethodStr !== \"GET\") && \n\t\t\t(httpMethodStr !== \"HEAD\"))\n\t\t{\n\t\t\tfetchObj[\"body\"] = JSON.stringify (data);\n\t\t}\n\n\t\tlet promise = new Promise ((resolve, reject) => \n\t\t\t{\n\t\t\t\tfetch (url, fetchObj).then (async (res) =>\n\t\t\t\t\t{\n\t\t\t\t\t\tres.json ().then ((jsonObj: any) =>\n\t\t\t\t\t\t\t{\n\t\t\t\t\t\t\t\tresolve (jsonObj);\n\t\t\t\t\t\t\t})\n\t\t\t\t\t\t\t.catch ((reason: any) =>\n\t\t\t\t\t\t\t{\n\t\t\t\t\t\t\t\tthrow new Error (`${url}: ${reason.message}`);\n\t\t\t\t\t\t\t});\n\t\t\t\t\t})\n\t\t\t\t\t.catch ((reason: any) =>\n\t\t\t\t\t{\n\t\t\t\t\t\tthrow new Error (`${url}: ${reason.message}`);\n\t\t\t\t\t});\n\t\t\t});\n\n\t\treturn (promise);\n\t}\n}\n","/**\n * An asset to load.\n */\nexport class HotAsset\n{\n\t/**\n\t * The type of asset. Can be:\n\t * * js\n\t * * css\n\t * * html\n\t * * component\n\t */\n\ttype: string;\n\t/**\n\t * The name of the asset to load.\n\t */\n\tname?: string;\n\t/**\n\t * The path to the assets to load.\n\t */\n\tpath?: string;\n\t/**\n\t * The preloaded content to load. Requires name to be set.\n\t */\n\tcontent?: string;\n\n\tconstructor (type: string, name: string = \"\")\n\t{\n\t\tthis.type = type;\n\t\tthis.name = name;\n\t\tthis.path = \"\";\n\t\tthis.content = \"\";\n\t}\n\n\tload (): void\n\t{\n\t}\n\n\t/**\n\t * Load the asset.\n\t */\n\toutput (): string | { name: string; url?: string; content?: string; }\n\t{\n\t\tif ((this.path == null) && (this.content == null))\n\t\t\tthrow new Error (`HotAsset ${this.name} of type ${this.type} does not have a path or content set!`);\n\n\t\tlet output: string | { name: string; url?: string; content?: string; } = \"\";\n\n\t\tif (this.path != null)\n\t\t{\n\t\t\tif (this.path !== \"\")\n\t\t\t{\n\t\t\t\tif (this.type === \"js\")\n\t\t\t\t\toutput = `<script type = \"text/javascript\" src = \"${this.path}\"></script>`;\n\n\t\t\t\tif (this.type === \"css\")\n\t\t\t\t\toutput = `<link href = \"${this.path}\" rel = \"stylesheet\" />`;\n\n\t\t\t\tif ((this.type === \"html\") || \n\t\t\t\t\t(this.type === \"component\"))\n\t\t\t\t{\n\t\t\t\t\tif (this.name === \"\")\n\t\t\t\t\t\tthrow new Error (`Loading an HTML or component asset requires a name to be set!`);\n\n\t\t\t\t\tlet fileUrl: string = `\"${this.path}\"`;\n\t\t\t\t\toutput = { name: this.name, url: this.path };\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\n\t\tif (this.content != null)\n\t\t{\n\t\t\tif (this.content !== \"\")\n\t\t\t{\n\t\t\t\tif (this.type === \"js\")\n\t\t\t\t\tthrow new Error (`Loading JS assets using content is not supported yet!`);\n\n\t\t\t\tif (this.type === \"css\")\n\t\t\t\t\tthrow new Error (`Loading CSS assets using content is not supported yet!`);\n\n\t\t\t\tif (this.type === \"html\")\n\t\t\t\t{\n\t\t\t\t\tif (this.name === \"\")\n\t\t\t\t\t\tthrow new Error (`Loading an HTML asset requires a name to be set!`);\n\n\t\t\t\t\tlet escapedContent: string = JSON.stringify (this.content);\n\t\t\t\t\tlet fileUrl: string = this.path;\n\t\t\t\t\tlet fileContent: string = \"\";\n\n\t\t\t\t\t// Find any script tags and interrupt them so the HTML parsers \n\t\t\t\t\t// don't get confused.\n\t\t\t\t\tescapedContent = escapedContent.replace (new RegExp (\"\\\\<script\", \"gmi\"), \"<scr\\\" + \\\"ipt\");\n\t\t\t\t\tescapedContent = escapedContent.replace (new RegExp (\"\\\\<\\\\/script\", \"gmi\"), \"</scr\\\" + \\\"ipt\");\n\n\t\t\t\t\tfileContent = escapedContent;\n\n\t\t\t\t\toutput = { name: this.name, url: fileUrl, content: escapedContent };\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\n\t\treturn (output);\n\t}\n}","import { HotStaq } from \"./HotStaq\";\nimport { HotAPI } from \"./HotAPI\";\nimport { HotServerType } from \"./HotServer\";\nimport { HotLog } from \"./HotLog\";\n\n/**\n * A client connected to a server.\n */\nexport class HotClient\n{\n\t/**\n\t * The processor to use.\n\t */\n\tprocessor: HotStaq;\n\t/**\n\t * The API to use.\n\t */\n\tapi: HotAPI;\n\t/**\n\t * The tester API to use.\n\t */\n\ttesterAPI: HotAPI;\n\t/**\n\t * The type of server.\n\t */\n\ttype: HotServerType;\n\t/**\n\t * The logger.\n\t */\n\tlogger: HotLog;\n\n\tconstructor (processor: HotStaq)\n\t{\n\t\tthis.processor = processor;\n\t\tthis.api = null;\n\t\tthis.testerAPI = null;\n\t\tthis.type = HotServerType.HTTP;\n\t\tthis.logger = processor.logger;\n\t}\n}","import { HotAPI } from \"./HotAPI\";\nimport { HotStaq } from \"./HotStaq\";\n\nexport interface HotComponentOutput\n{\n\t/**\n\t * The HTML to output.\n\t */\n\thtml: string;\n\t/**\n\t * The query selector to add this component's functions to.\n\t * \n\t * @example #objectId\n\t */\n\taddFunctionsTo?: string;\n\t/**\n\t * The place here parent name to attach this html to.\n\t * \n\t * @example top\n\t */\n\tplaceHereParent?: string;\n\t/**\n\t * Append the output to an existing element using a CSS selector that is \n\t * the closest.\n\t * \n\t * @example div .testClass\n\t */\n\tclosestSelector?: string;\n\t/**\n\t * Append the output to an existing element somewhere on the document.\n\t * \n\t * @example div .testClass\n\t */\n\tdocumentSelector?: string;\n}\n\n/**\n * A component to preprocess.\n */\nexport interface IHotComponent\n{\n\t/**\n\t * The processor to use.\n\t */\n\tprocessor: HotStaq;\n\t/**\n\t * The associated HTMLElements.\n\t */\n\thtmlElements?: HTMLElement[];\n\t/**\n\t * The name of the page.\n\t */\n\tname?: string;\n\t/**\n\t * The name of the tag.\n\t */\n\ttag?: string;\n\t/**\n\t * The connected API.\n\t */\n\tapi?: HotAPI;\n\t/**\n\t * The options to include with registering this component.\n\t */\n\telementOptions?: ElementDefinitionOptions;\n\t/**\n\t * Any extra attributes to register.\n\t */\n\tobservedAttributes?: string[];\n\t/**\n\t * The type of component.\n\t */\n\ttype?: string;\n\t/**\n\t * The value of the component.\n\t */\n\tvalue?: any;\n\t/**\n\t * The inner HTML or value of the component.\n\t */\n\tinner: any;\n\t/**\n\t * The events to trigger.\n\t */\n\tevents?: {\n\t\t\t[name: string]: {\n\t\t\t\ttype: string;\n\t\t\t\tfunc: Function;\n\t\t\t\toptions?: any;\n\t\t\t}\n\t\t};\n\t/**\n\t * Execute prior to output.\n\t * \n\t * @returns If set to false, the component will not be registered.\n\t */\n\tonPreOutput?: () => boolean;\n\t/**\n\t * Execute after getting the output, but before the DOM parsing.\n\t * \n\t * @param output The output from the component to register. Can be manipulated one last time prior to \n\t * being parsed into a DOM element.\n\t * \n\t * @returns The final output to be parsed as a DOM element.\n\t */\n\tonPostOutput?: (output: (string | HotComponentOutput[])) => (string | HotComponentOutput[]);\n\t/**\n\t * Execute when its time to fix the HTML prior to DOM parsing. This will skip the HotStaq default fixing.\n\t */\n\tonFixHTML?: (output: string) => { fixedStr: string, querySelector: string; };\n\t/**\n\t * Execute a custom DOM parser.\n\t */\n\tonParseDOM?: (output: string) => Document;\n\t/**\n\t * Execute after the output has been parsed and is ready to be placed into the DOM.\n\t */\n\tonParsed?: (output: string) => string;\n\t/**\n\t * Execute prior to placing the new DOM element.\n\t */\n\tonPrePlace?: (htmlElement: HTMLElement) => HTMLElement;\n\t/**\n\t * Execute after placing the new DOM element. Can be manipulated one final time prior to being rendered.\n\t */\n\tonPostPlace?: (parentHtmlElement: HTMLElement, htmlElement: HTMLElement) => HTMLElement;\n\t/**\n\t * Execute after placing the DOM element onto the newly created parent.\n\t */\n\tonParentPlace?: (parentHtmlElement: HTMLElement, htmlElement: HTMLElement) => void;\n}\n\n/**\n * A component to preprocess.\n */\nexport abstract class HotComponent implements IHotComponent\n{\n\t/**\n\t * The processor to use.\n\t */\n\tprocessor: HotStaq;\n\t/**\n\t * The associated HTMLElements.\n\t */\n\thtmlElements: HTMLElement[];\n\t/**\n\t * The name of the component.\n\t */\n\tname: string;\n\t/**\n\t * The name of the tag.\n\t */\n\ttag: string;\n\t/**\n\t * The connected API.\n\t */\n\tapi: HotAPI;\n\t/**\n\t * The options to include with registering this component.\n\t */\n\telementOptions: ElementDefinitionOptions;\n\t/**\n\t * Any extra attributes to register.\n\t */\n\tobservedAttributes: string[];\n\t/**\n\t * The type of component.\n\t */\n\ttype: string;\n\t/**\n\t * The value of the component.\n\t */\n\tvalue: any;\n\t/**\n\t * The inner HTML or value of the component.\n\t */\n\tinner: any;\n\t/**\n\t * The events to trigger.\n\t */\n\tevents: {\n\t\t[name: string]: {\n\t\t\t\ttype: string;\n\t\t\t\tfunc: Function;\n\t\t\t\toptions: any;\n\t\t\t}\n\t\t};\n\t/**\n\t * Execute prior to output.\n\t * \n\t * @returns If set to false, the component will not be registered.\n\t */\n\tonPreOutput? (): boolean;\n\t/**\n\t * Execute after getting the output, but before the DOM parsing.\n\t * \n\t * @param output The output from the component to register. Can be manipulated one last time prior to \n\t * being parsed into a DOM element.\n\t * \n\t * @returns The final output to be parsed as a DOM element.\n\t */\n\tonPostOutput? (output: (string | HotComponentOutput[])): (string | HotComponentOutput[]);\n\t/**\n\t * Execute when its time to fix the HTML prior to DOM parsing. This will skip the HotStaq default fixing.\n\t */\n\tonFixHTML? (output: string): { fixedStr: string, querySelector: string; };\n\t/**\n\t * Execute a custom DOM parser.\n\t */\n\tonParseDOM? (output: string): Document;\n\t/**\n\t * Execute after the output has been parsed and is ready to be placed into the DOM.\n\t */\n\tonParsed? (output: string): string;\n\t/**\n\t * Execute prior to placing the new DOM element.\n\t */\n\tonPrePlace? (htmlElement: HTMLElement): HTMLElement;\n\t/**\n\t * Execute after placing the new DOM element. Can be manipulated one final time prior to being rendered.\n\t */\n\tonPostPlace? (parentHtmlElement: HTMLElement, htmlElement: HTMLElement): HTMLElement;\n\t/**\n\t * Execute after placing the DOM element onto the newly created parent.\n\t */\n\tonParentPlace? (parentHtmlElement: HTMLElement, htmlElement: HTMLElement): void;\n\n\tconstructor (copy: IHotComponent | HotStaq, api: HotAPI = null)\n\t{\n\t\tif ((copy instanceof HotStaq) || (copy == null))\n\t\t{\n\t\t\t// @ts-ignore\n\t\t\tthis.processor = copy;\n\t\t\tthis.htmlElements = [];\n\t\t\tthis.name = \"\";\n\t\t\tthis.tag = \"\";\n\t\t\tthis.api = null;\n\t\t\tthis.elementOptions = undefined;\n\t\t\tthis.observedAttributes = [];\n\t\t\tthis.type = \"\";\n\t\t\tthis.value = null;\n\t\t\tthis.inner = null;\n\t\t\tthis.events = {};\n\t\t}\n\t\telse\n\t\t{\n\t\t\tthis.processor = copy.processor;\n\t\t\tthis.htmlElements = copy.htmlElements || [];\n\t\t\tthis.name = copy.name || \"\";\n\t\t\tthis.tag = copy.tag || this.name;\n\t\t\tthis.api = copy.api || null;\n\t\t\tthis.elementOptions = copy.elementOptions || undefined;\n\t\t\tthis.observedAttributes = copy.observedAttributes || [];\n\t\t\tthis.type = copy.type || \"\";\n\t\t\tthis.value = copy.value || null;\n\t\t\tthis.inner = copy.inner || null;\n\t\t\tthis.events = {};\n\t\t}\n\n\t\tif (api != null)\n\t\t\tthis.api = api;\n\t}\n\n\t/**\n\t * Event that's called when this component's DOM element has been created.\n\t * \n\t * @returns The modified DOM element.\n\t */\n\tonCreated (element: HTMLElement): any\n\t{\n\t\treturn (element);\n\t}\n\n\t/**\n\t * Handle the attributes manually.\n\t */\n\thandleAttributes? (attributes: NamedNodeMap): void;\n\n\t/**\n\t * Handle a click event.\n\t */\n\tclick? (): Promise<void>;\n\n\t/**\n\t * Output the component.\n\t */\n\tabstract output (): string | HotComponentOutput[];\n}","import * as fs from \"fs\";\n\nimport fetch from \"node-fetch\";\n\nimport { DeveloperMode, Hot } from \"./Hot\";\nimport { HotPage } from \"./HotPage\";\n\n/**\n * A file to process.\n */\nexport interface IHotFile\n{\n\t/**\n\t * The parent page.\n\t */\n\tpage?: HotPage;\n\t/**\n\t * The name of the file.\n\t */\n\tname?: string;\n\t/**\n\t * The url to the file to get.\n\t */\n\turl?: string;\n\t/**\n\t * The path to the local file to get.\n\t */\n\tlocalFile?: string;\n\t/**\n\t * The content of the file to process.\n\t */\n\tcontent?: string;\n\t/**\n\t * Force all errors to be thrown.\n\t */\n\tthrowAllErrors?: boolean;\n}\n\n/**\n * Parser options for when processing a string or file.\n */\nexport interface ParserOptions\n{\n\t/**\n\t * Output the commands generated from processing. Default: true\n\t */\n\toutputCommands?: boolean;\n\t/**\n\t * Allow JSON.stringify to be used during processing. Default: true\n\t */\n\tallowStringify?: boolean;\n}\n\n/**\n * A file to process.\n */\nexport class HotFile implements IHotFile\n{\n\t/**\n\t * The parent page.\n\t */\n\tpage: HotPage;\n\t/**\n\t * The name of the file.\n\t */\n\tname: string;\n\t/**\n\t * The url to the file to get.\n\t */\n\turl: string;\n\t/**\n\t * The path to the local file to get.\n\t */\n\tlocalFile: string;\n\t/**\n\t * The content of the file to process.\n\t */\n\tcontent: string;\n\t/**\n\t * Force all errors to be thrown.\n\t */\n\tthrowAllErrors: boolean;\n\n\tconstructor (copy: IHotFile = {})\n\t{\n\t\tthis.page = copy.page || null;\n\t\tthis.name = copy.name || \"\";\n\t\tthis.url = copy.url || \"\";\n\t\tthis.localFile = copy.localFile || \"\";\n\t\tthis.content = copy.content || \"\";\n\t\tthis.throwAllErrors = copy.throwAllErrors || false;\n\t}\n\n\t/**\n\t * Set the content of this file.\n\t */\n\tsetContent (content: string): void\n\t{\n\t\tthis.content = content;\n\t}\n\n\t/**\n\t * Get the content of this file.\n\t */\n\tgetContent (): string\n\t{\n\t\treturn (this.content);\n\t}\n\n\t/**\n\t * Make a HTTP get request.\n\t */\n\tstatic async httpGet (url: string): Promise<string>\n\t{\n\t\ttry\n\t\t{\n\t\t\tlet res = await fetch (url);\n\n\t\t\tif (res.ok === false)\n\t\t\t\tthrow new Error (`${res.status}: ${res.statusText}`);\n\n\t\t\tlet content: string = await res.text ();\n\n\t\t\treturn (content);\n\t\t}\n\t\tcatch (ex)\n\t\t{\n\t\t\treturn (JSON.stringify ({ \"error\": `${ex.message} - Could not fetch ${url}` }));\n\t\t}\n\t}\n\n\t/**\n\t * Load content from a url.\n\t */\n\tasync loadUrl (): Promise<string>\n\t{\n\t\tthis.content = await HotFile.httpGet (this.url);\n\n\t\treturn (this.content);\n\t}\n\n\t/**\n\t * Load content from a local file.\n\t */\n\tasync loadLocalFile (): Promise<string>\n\t{\n\t\tlet promise: Promise<string> = new Promise (\n\t\t\t(resolve: any, reject: any): void =>\n\t\t\t{\n\t\t\t\tfs.readFile (this.localFile, (err: NodeJS.ErrnoException, data: Buffer): void =>\n\t\t\t\t\t{\n\t\t\t\t\t\tif (err != null)\n\t\t\t\t\t\t\tthrow err;\n\n\t\t\t\t\t\tlet content: string = data.toString ();\n\t\t\t\t\t\tthis.content = content;\n\n\t\t\t\t\t\tresolve (this.content);\n\t\t\t\t\t});\n\t\t\t});\n\n\t\treturn (promise);\n\t}\n\n\t/**\n\t * Load the contents of the file.\n\t */\n\tasync load (): Promise<string>\n\t{\n\t\tlet content: string = \"\";\n\n\t\tif (this.url !== \"\")\n\t\t\tcontent = await this.loadUrl ();\n\n\t\tif (this.localFile !== \"\")\n\t\t\tcontent = await this.loadLocalFile ();\n\n\t\treturn (content);\n\t}\n\n\t/**\n\t * Process string content. This will take in a regular expression and \n\t * parse the content based on the regex. When the regex content is found \n\t * contentProcessor will be executed with the regex content found. When \n\t * the regex content is not found, offContentProcessor will be called with \n\t * the content outside of the regex.\n\t * \n\t * @param content The content to parse.\n\t * @param contentRegex The regex to use to parse the content.\n\t * @param contentProcessor The content found inside the regex.\n\t * @param offContentProcessor The content found outside of the regex.\n\t * @param numRemoveFromBeginning The number of characters to remove from the \n\t * beginning of the found content.\n\t * @param numRemoveFromEnd The number of characters to remove from the end of \n\t * the found content.\n\t */\n\tstatic processContent (content: string, contentRegex: RegExp,\n\t\tcontentProcessor: (regexFound: string) => string,\n\t\toffContentProcessor: (offContent: string) => string,\n\t\tnumRemoveFromBeginning: number = 2,\n\t\tnumRemoveFromEnd: number = 2): string\n\t{\n\t\tlet result: RegExpExecArray = contentRegex.exec (content);\n\t\tlet previousIndex: number = 0;\n\t\tlet output: string = \"\";\n\n\t\twhile (result != null)\n\t\t{\n\t\t\tlet start: number = result.index - numRemoveFromBeginning;\n\t\t\tlet end: number = contentRegex.lastIndex + numRemoveFromEnd;\n\n\t\t\t// Get the previous section.\n\t\t\tlet prevContent: string = content.substr (previousIndex, (start - previousIndex));\n\t\t\tpreviousIndex = end;\n\n\t\t\toutput += offContentProcessor (prevContent);\n\n\t\t\t// Process the content found from the regex\n\t\t\tlet contentFound: string = result[0];\n\t\t\toutput += contentProcessor (contentFound);\n\n\t\t\t// Move on to the next section to parse.\n\t\t\tresult = contentRegex.exec (content);\n\t\t}\n\n\t\t// Append whatever else is after the last parsed section.\n\t\tlet lastContent: string = content.substr (previousIndex);\n\n\t\toutput += offContentProcessor (lastContent);\n\n\t\treturn (output);\n\t}\n\n\t/**\n\t * Process any content that could have nested values. This will \n\t * take in a regular expression and \n\t * parse the content based on the regex. When the regex content is found \n\t * contentProcessor will be executed with the regex content found. When \n\t * the regex content is not found, offContentProcessor will be called with \n\t * the content outside of the regex.\n\t * \n\t * @fixme Needs to be able to ignore any characters found inside comments \n\t * or a string. For example, if the following is used ```${\"Test }\"}``` It \n\t * will error out.\n\t * \n\t * @param content The content to parse.\n\t * @param contentRegex The regex to use to parse the content.\n\t * @param contentProcessor The content found inside the regex.\n\t * @param offContentProcessor The content found outside of the regex.\n\t * @param numRemoveFromBeginning The number of characters to remove from the \n\t * beginning of the found content.\n\t * @param numRemoveFromEnd The number of characters to remove from the end of \n\t * the found content.\n\t */\n\tstatic processNestedContent (content: string, startChars: string, endChars: string, \n\t\ttriggerChar: string, contentProcessor: (regexFound: string) => string,\n\t\toffContentProcessor: (offContent: string) => string,\n\t\tnumRemoveFromBeginning: number = 2,\n\t\tnumRemoveFromEnd: number = 1): string\n\t{\n\t\tlet pos: number = content.indexOf (startChars);\n\t\tlet previousIndex: number = 0;\n\t\tlet startTriggerPos: number = content.indexOf (triggerChar, pos);\n\t\tlet output: string = \"\";\n\n\t\twhile (pos > -1)\n\t\t{\n\t\t\tlet end: number = content.indexOf (endChars, pos);\n\t\t\tlet nestedCounter: number = 0;\n\n\t\t\tif (triggerChar !== \"\")\n\t\t\t{\n\t\t\t\t// Reverse search the trigger characters and count the number of \n\t\t\t\t// occurrences.\n\t\t\t\tlet rpos: number = content.lastIndexOf (triggerChar, end - numRemoveFromEnd);\n\n\t\t\t\twhile (rpos > -1)\n\t\t\t\t{\n\t\t\t\t\tif (rpos === startTriggerPos)\n\t\t\t\t\t\tbreak;\n\n\t\t\t\t\trpos = content.lastIndexOf (triggerChar, rpos - numRemoveFromEnd);\n\t\t\t\t\tnestedCounter++;\n\t\t\t\t}\n\t\t\t}\n\n\t\t\t// If there's nested trigger characters, get the last occurrence of \n\t\t\t// the end character.\n\t\t\tif (nestedCounter > 0)\n\t\t\t{\n\t\t\t\tlet epos: number = content.indexOf (endChars, end + numRemoveFromEnd);\n\t\t\t\tlet tempepos: number = epos;\n\n\t\t\t\twhile ((epos > -1) && (nestedCounter > 0))\n\t\t\t\t{\n\t\t\t\t\tif (tempepos < 0)\n\t\t\t\t\t\tbreak;\n\n\t\t\t\t\t// Make sure we aren't discovering endChars that we shouldn't be.\n\t\t\t\t\tlet posOutsideOfContent: number = content.lastIndexOf (startChars, tempepos - numRemoveFromEnd);\n\n\t\t\t\t\tif (posOutsideOfContent > epos)\n\t\t\t\t\t\tbreak;\n\n\t\t\t\t\tepos = tempepos;\n\n\t\t\t\t\ttempepos = content.indexOf (endChars, epos + numRemoveFromEnd);\n\t\t\t\t\tnestedCounter--;\n\t\t\t\t}\n\n\t\t\t\tend = epos;\n\t\t\t}\n\n\t\t\tlet offContentStr: string = content.substr (previousIndex, (pos - previousIndex));\n\t\t\toutput += offContentProcessor (offContentStr);\n\n\t\t\tlet foundContent: string = content.substr (\n\t\t\t\tpos + numRemoveFromBeginning, (end - (pos + numRemoveFromBeginning)));\n\t\t\toutput += contentProcessor (foundContent);\n\n\t\t\t// Get the next content\n\t\t\tpos = content.indexOf (startChars, end + numRemoveFromEnd);\n\t\t\tstartTriggerPos = content.indexOf (triggerChar, pos);\n\t\t\tpreviousIndex = end + numRemoveFromEnd;\n\t\t}\n\n\t\t// Append whatever else is after the last parsed section.\n\t\tlet lastContent: string = content.substr (previousIndex);\n\n\t\toutput += offContentProcessor (lastContent);\n\n\t\treturn (output);\n\t}\n\n\t/**\n\t * Parse content.\n\t * \n\t * @param thisContent The content to parse.\n\t * @param throwAllErrors If set to true, any error that occurs will be thrown as an exception.\n\t * @param options The options to use when parsing the content.\n\t */\n\tstatic parseContent (thisContent: string, throwAllErrors: boolean, parserOptions: ParserOptions = null): string\n\t{\n\t\tif (parserOptions == null)\n\t\t{\n\t\t\tparserOptions = {\n\t\t\t\t\toutputCommands: true,\n\t\t\t\t\tallowStringify: true\n\t\t\t\t};\n\t\t}\n\n\t\tlet STRINGIFY_START: string = \"JSON.stringify (\";\n\t\tlet STRINGIFY_END: string = \")\";\n\n\t\tif (parserOptions.allowStringify === false)\n\t\t{\n\t\t\tSTRINGIFY_START = \"\";\n\t\t\tSTRINGIFY_END = \"\";\n\t\t}\n\n\t\t// Assemble the JS to evaluate. This will take all content outside of \n\t\t// <* and *> and wrap a Hot.echo around it. Any JS found inside of the \n\t\t// <* and *> will be executed as is.\n\t\tlet output: string = HotFile.processContent (thisContent, \n\t\t\tnew RegExp (\"(?=\\\\<\\\\*)([\\\\s\\\\S]*?)(?=\\\\*\\\\>)\", \"g\"), \n\t\t\t(regexFound: string): string =>\n\t\t\t{\n\t\t\t\t// A little hack, since I suck at Regex :(\n\t\t\t\tregexFound = regexFound.substr (2);\n\n\t\t\t\treturn (`${regexFound}`);\n\t\t\t}, \n\t\t\t(offContent: string): string =>\n\t\t\t{\n\t\t\t\tif (offContent === \"\")\n\t\t\t\t\treturn (\"\");\n\n\t\t\t\tlet tempOutput: string = HotFile.processNestedContent (\n\t\t\t\t\toffContent, \"!{\", \"}\", \"{\", \n\t\t\t\t\t(regexFound2: string): string =>\n\t\t\t\t\t{\n\t\t\t\t\t\tlet out: string = `*&&%*%@#@!${regexFound2}*&!#%@!@*!`;\n\n\t\t\t\t\t\treturn (out);\n\t\t\t\t\t}, \n\t\t\t\t\t(offContent3: string): string =>\n\t\t\t\t\t{\n\t\t\t\t\t\treturn (offContent3);\n\t\t\t\t\t});\n\t\t\t\tlet tempOutput2: string = HotFile.processNestedContent (\n\t\t\t\t\ttempOutput, \"STR{\", \"}\", \"{\", \n\t\t\t\t\t(regexFound2: string): string =>\n\t\t\t\t\t{\n\t\t\t\t\t\tlet out: string = \"\";\n\n\t\t\t\t\t\tif (parserOptions.outputCommands === true)\n\t\t\t\t\t\t\tout = `*&&%*%@#@!echoOutput (JSON.stringify(${regexFound2}), ${throwAllErrors});*&!#%@!@*!`;\n\t\t\t\t\t\telse\n\t\t\t\t\t\t\tout = `*&&%*%@#@!${STRINGIFY_START}${regexFound2}${STRINGIFY_END}, ${throwAllErrors});*&!#%@!@*!`;\n\n\t\t\t\t\t\treturn (out);\n\t\t\t\t\t}, \n\t\t\t\t\t(offContent3: string): string =>\n\t\t\t\t\t{\n\t\t\t\t\t\treturn (offContent3);\n\t\t\t\t\t}, 4, 1);\n\t\t\t\tlet tempOutput3: string = HotFile.processNestedContent (\n\t\t\t\t\ttempOutput2, \"${\", \"}\", \"{\", \n\t\t\t\t\t(regexFound2: string): string =>\n\t\t\t\t\t{\n\t\t\t\t\t\tlet out: string = \"\";\n\n\t\t\t\t\t\tif (parserOptions.outputCommands === true)\n\t\t\t\t\t\t{\n\t\t\t\t\t\t\tlet escapeOutput = (content: string): string =>\n\t\t\t\t\t\t\t\t{\n\t\t\t\t\t\t\t\t\treturn (content.replace(/[`]/g, '\\\\`'));\n\t\t\t\t\t\t\t\t};\n\n\t\t\t\t\t\t\tout = `*&&%*%@#@!try { Hot.echo (${regexFound2}); }catch (ex){Hot.echo (\\`\\\\\\${${escapeOutput (regexFound2)}}\\`);}*&!#%@!@*!`;\n\n\t\t\t\t\t\t\tif (throwAllErrors === true)\n\t\t\t\t\t\t\t\tout = `*&&%*%@#@!Hot.echo (${regexFound2});*&!#%@!@*!`;\n\t\t\t\t\t\t}\n\t\t\t\t\t\telse\n\t\t\t\t\t\t\tout = `*&&%*%@#@!${regexFound2}*&!#%@!@*!`;\n\n\t\t\t\t\t\treturn (out);\n\t\t\t\t\t}, \n\t\t\t\t\t(offContent3: string): string =>\n\t\t\t\t\t{\n\t\t\t\t\t\treturn (offContent3);\n\t\t\t\t\t\t/*let escapedContent: string = JSON.stringify (offContent3);\n\t\t\t\t\t\tlet out: string = `echoOutput (${escapedContent}, ${throwAllErrors});\\n`;\n\n\t\t\t\t\t\treturn (out);*/\n\t\t\t\t\t});\n\n\t\t\t\tlet tempOutput4: string = \"\";\n\n\t\t\t\t// Any ?() will be ignored in production mode.\n\t\t\t\tif (Hot.Mode === DeveloperMode.Production)\n\t\t\t\t{\n\t\t\t\t\ttempOutput4 = HotFile.processNestedContent (\n\t\t\t\t\t\ttempOutput3, \"?(\", \")\", \"(\", \n\t\t\t\t\t\t(regexFound2: string): string =>\n\t\t\t\t\t\t{\n\t\t\t\t\t\t\treturn (\"\");\n\t\t\t\t\t\t}, \n\t\t\t\t\t\t(offContent3: string): string =>\n\t\t\t\t\t\t{\n\t\t\t\t\t\t\treturn (offContent3);\n\t\t\t\t\t\t\t/*let out: string = `echoOutput (${offContent3}, ${throwAllErrors});\\n`;\n\n\t\t\t\t\t\t\treturn (out);*/\n\t\t\t\t\t\t});\n\t\t\t\t}\n\n\t\t\t\tif (Hot.Mode === DeveloperMode.Development)\n\t\t\t\t{\n\t\t\t\t\ttempOutput4 = HotFile.processNestedContent (\n\t\t\t\t\t\ttempOutput3, \"?(\", \")\", \"(\", \n\t\t\t\t\t\t(regexFound2: string): string =>\n\t\t\t\t\t\t{\n\t\t\t\t\t\t\tlet foundStr: string = \"\";\n\n\t\t\t\t\t\t\ttry\n\t\t\t\t\t\t\t{\n\t\t\t\t\t\t\t\t// Check to see if it be parsed. If so, stringify it.\n\t\t\t\t\t\t\t\tJSON.parse (regexFound2);\n\n\t\t\t\t\t\t\t\tif (parserOptions.allowStringify === true)\n\t\t\t\t\t\t\t\t\tfoundStr = JSON.stringify (regexFound2);\n\t\t\t\t\t\t\t\telse\n\t\t\t\t\t\t\t\t\tfoundStr = `${regexFound2}`;\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\tcatch (ex)\n\t\t\t\t\t\t\t{\n\t\t\t\t\t\t\t\t// If valid JSON is not received, don't worry about it, pass it \n\t\t\t\t\t\t\t\t// along to the function below for it to be parsed in the page.\n\t\t\t\t\t\t\t\t// The exception should be thrown there instead.\n\t\t\t\t\t\t\t\tfoundStr = `${regexFound2}`;\n\t\t\t\t\t\t\t}\n\n\t\t\t\t\t\t\t/// @fixme Make this a callable function and pass foundStr, etc.\n\t\t\t\t\t\t\tlet out: string = \"\";\n\n\t\t\t\t\t\t\tif (parserOptions.outputCommands === true)\n\t\t\t\t\t\t\t{\n\t\t\t\t\t\t\t\tout = `*&&%*%@#@!{\nconst testElm = createTestElement (${foundStr});\nHot.echo (\\`data-test-object-name = \"\\${testElm.name}\" data-test-object-func = \"\\${testElm.func}\" data-test-object-value = \"\\${testElm.value}\"\\`);\n}*&!#%@!@*!\\n`;\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\telse\n\t\t\t\t\t\t\t{\n\t\t\t\t\t\t\t\tlet createTestElement = (foundStr2: any) =>\n\t\t\t\t\t\t\t\t{\n\t\t\t\t\t\t\t\t\tlet testElm = null;\n\n\t\t\t\t\t\t\t\t\ttry\n\t\t\t\t\t\t\t\t\t{\n\t\t\t\t\t\t\t\t\t\tlet obj = foundStr2;\n\n\t\t\t\t\t\t\t\t\t\tif (typeof (foundStr2) === \"string\")\n\t\t\t\t\t\t\t\t\t\t\tobj = JSON.parse (foundStr2);\n\n\t\t\t\t\t\t\t\t\t\tif (typeof (obj) === \"string\")\n\t\t\t\t\t\t\t\t\t\t\ttestElm = new Hot.HotTestElement (obj);\n\n\t\t\t\t\t\t\t\t\t\tif (obj instanceof Array)\n\t\t\t\t\t\t\t\t\t\t\ttestElm = new Hot.HotTestElement (obj[0], obj[1], obj[2]);\n\n\t\t\t\t\t\t\t\t\t\tif (obj[\"name\"] != null)\n\t\t\t\t\t\t\t\t\t\t\ttestElm = new Hot.HotTestElement (obj);\n\n\t\t\t\t\t\t\t\t\t\tif (Hot.CurrentPage.testElements[testElm.name] != null)\n\t\t\t\t\t\t\t\t\t\t\tthrow new Error (`Test element ${testElm.name} already exists!`);\n\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t\tcatch (ex)\n\t\t\t\t\t\t\t\t\t{\n\t\t\t\t\t\t\t\t\t\tthrow new Error (\n\t\t\t\t\t\t\t\t`Error processing test element ${foundStr2} in ${Hot.CurrentPage.name}. Error: ${ex.message}`\n\t\t\t\t\t\t\t\t\t\t\t);\n\t\t\t\t\t\t\t\t\t}\n\n\t\t\t\t\t\t\t\t\treturn (testElm);\n\t\t\t\t\t\t\t\t}\n\n\t\t\t\t\t\t\t\tconst testElm = createTestElement (foundStr);\n\t\t\t\t\t\t\t\tout = `*&&%*%@#@!data-test-object-name = \"${testElm.name}\" data-test-object-func = \"${testElm.func}\" data-test-object-value = \"${testElm.value}\"*&!#%@!@*!`;\n\t\t\t\t\t\t\t}\n\n\t\t\t\t\t\t\treturn (out);\n\t\t\t\t\t\t}, \n\t\t\t\t\t\t(offContent3: string): string =>\n\t\t\t\t\t\t{\n\t\t\t\t\t\t\treturn (offContent3);\n\t\t\t\t\t\t\t/*let out: string = `echoOutput (${offContent3}, ${throwAllErrors});\\n`;\n\n\t\t\t\t\t\t\treturn (out);*/\n\t\t\t\t\t\t});\n\t\t\t\t}\n\n\t\t\t\tlet tempOutput5: string = HotFile.processNestedContent (\n\t\t\t\t\ttempOutput4, \"*&&%*%@#@!\", \"*&!#%@!@*!\", \"*&&%*%@#@!\", \n\t\t\t\t\t(regexFound: string): string =>\n\t\t\t\t\t{\n\t\t\t\t\t\treturn (regexFound);\n\t\t\t\t\t}, \n\t\t\t\t\t(offContent: string): string =>\n\t\t\t\t\t{\n\t\t\t\t\t\tlet escapedContent: string = \"\";\n\n\t\t\t\t\t\tif (parserOptions.allowStringify === true)\n\t\t\t\t\t\t\tescapedContent = JSON.stringify (offContent);\n\t\t\t\t\t\telse\n\t\t\t\t\t\t\tescapedContent = offContent;\n\n\t\t\t\t\t\tlet out: string = \"\";\n\t\t\t\t\t\t\n\t\t\t\t\t\tif (parserOptions.outputCommands === true)\n\t\t\t\t\t\t\tout = `echoOutput (${escapedContent}, ${throwAllErrors});\\n`;\n\t\t\t\t\t\telse\n\t\t\t\t\t\t\tout = escapedContent;\n\n\t\t\t\t\t\treturn (out);\n\t\t\t\t\t}, \n\t\t\t\t\t\"*&&%*%@#@!\".length, \"*&!#%@!@*!\".length);\n\n\t\t\t\t/// @fixme Temporary hack. These delimiters should be removed from tempOutput when \n\t\t\t\t/// executing processNestedContent.\n\t\t\t\ttempOutput5 = tempOutput5.replace (/\\*\\&\\&\\%\\*\\%\\@\\#\\@\\!/g, \"\");\n\t\t\t\ttempOutput5 = tempOutput5.replace (/\\*\\&\\!\\#\\%\\@\\!\\@\\*\\!/g, \"\");\n\n\t\t\t\treturn (tempOutput5);\n\t\t\t}, 0);\n\n\t\treturn (output);\n\t}\n\n\t/**\n\t * Process the content in this file. This treats each file as one large JavaScript\n\t * file. Any text outside of the <* *> areas will be treated as:\n\t * \n\t * \t\tHot.echo (\"text\");\n\t * \n\t * @fixme The regex's in the offContent functions need to be fixed. There's several \n\t * test cases where they will fail.\n\t */\n\tasync process (args: any = null): Promise<string>\n\t{\n\t\tlet thisContent: string = this.content;\n\n\t\tif (args != null)\n\t\t{\n\t\t\tif (args instanceof Array)\n\t\t\t\tthrow new Error (`In ${this.name}, the passed arguments received cannot be an array!`);\n\t\t}\n\n\t\tHot.Mode = this.page.processor.mode;\n\t\tHot.Arguments = args;\n\t\tHot.CurrentPage = this.page;\n\t\tHot.PublicKeys = this.page.processor.publicKeys;\n\t\tHot.API = this.page.getAPI ();\n\t\tHot.TesterAPI = this.page.getTesterAPI ();\n\n\t\tlet output: string = HotFile.parseContent (thisContent, this.throwAllErrors);\n\n\t\t// Execute the assembled JS file.\n\t\tlet returnedOutput: any = null;\n\n\t\ttry\n\t\t{\n\t\t\tlet executionContent: string = `\n\t\t\tvar Hot = arguments[0];\n\t\t\tvar PassedHotFile = arguments[1];\n\n\t\t\t`;\n\n\t\t\t// Output the arguments so it's usable in the entire document.\n\t\t\tif (typeof (args) === \"string\")\n\t\t\t\tthrow new Error (`The passing arguments cannot be a string!`);\n\n\t\t\tfor (let key in args)\n\t\t\t{\n\t\t\t\tlet newVar: string = \"\";\n\t\t\t\tlet newVarValue: any = args[key];\n\t\t\t\tlet newVarValueStr: string = JSON.stringify (newVarValue);\n\n\t\t\t\tnewVar = `var ${key} = ${newVarValueStr};\\n`;\n\n\t\t\t\texecutionContent += newVar;\n\t\t\t}\n\n\t\t\tlet contentName: string = this.name;\n\n\t\t\tif (contentName === \"\")\n\t\t\t\tcontentName = this.localFile;\n\n\t\t\tif (contentName === \"\")\n\t\t\t\tcontentName = this.url;\n\n\t\t\texecutionContent += `\n\t\t\tfunction echoOutput (content, throwErrors)\n\t\t\t{\n\t\t\t\tif (throwErrors == null)\n\t\t\t\t\tthrowErrors = true;\n\n\t\t\t\tif (throwErrors === true)\n\t\t\t\t{\n\t\t\t\t\tHot.echo (content);\n\n\t\t\t\t\treturn;\n\t\t\t\t}\n\n\t\t\t\ttry\n\t\t\t\t{\n\t\t\t\t\tHot.echo (content);\n\t\t\t\t}\n\t\t\t\tcatch (ex)\n\t\t\t\t{\n\t\t\t\t\tHot.echo (\"\");\n\t\t\t\t}\n\t\t\t}\n\n\t\t\tfunction createTestElement (foundStr)\n\t\t\t{\n\t\t\t\tlet testElm = null;\n\n\t\t\t\ttry\n\t\t\t\t{\n\t\t\t\t\tlet obj = foundStr;\n\n\t\t\t\t\tif (typeof (foundStr) === \"string\")\n\t\t\t\t\t\tobj = JSON.parse (foundStr);\n\n\t\t\t\t\tif (typeof (obj) === \"string\")\n\t\t\t\t\t\ttestElm = new Hot.HotTestElement (obj);\n\n\t\t\t\t\tif (obj instanceof Array)\n\t\t\t\t\t\ttestElm = new Hot.HotTestElement (obj[0], obj[1], obj[2]);\n\n\t\t\t\t\tif (obj[\"name\"] != null)\n\t\t\t\t\t\ttestElm = new Hot.HotTestElement (obj);\n\n\t\t\t\t\tif (Hot.CurrentPage.testElements[testElm.name] != null)\n\t\t\t\t\t\tthrow new Error (\\`Test element \\${testElm.name} already exists!\\`);\n\n\t\t\t\t\tHot.CurrentPage.addTestElement (testElm);\n\t\t\t\t}\n\t\t\t\tcatch (ex)\n\t\t\t\t{\n\t\t\t\t\tthrow new Error (\n\t\t\t\\`Error processing test element \\${foundStr} in \\${Hot.CurrentPage.name}. Error: \\${ex.message}\\`\n\t\t\t\t\t\t);\n\t\t\t\t}\n\n\t\t\t\treturn (testElm);\n\t\t\t}\n\n\t\t\tasync function runContent (CurrentHotFile)\n\t\t\t{\\n`;\n\t\t\texecutionContent += output;\n\t\t\texecutionContent += `\n\t\t\t}\n\n\t\t\treturn (runContent (PassedHotFile).then (() =>\n\t\t\t{\n\t\t\t\treturn ({\n\t\t\t\t\t\thot: Hot,\n\t\t\t\t\t\toutput: Hot.Output,\n\t\t\t\t\t\tdata: JSON.stringify (Hot.Data)\n\t\t\t\t\t});\n\t\t\t}));`;\n\n\t\t\t/// @fixme Prior to execution compile any TypeScript and make it ES5 compatible.\n\t\t\tlet func: Function = new Function (executionContent);\n\t\t\treturnedOutput = await func.apply (this, [Hot, this]);\n\t\t}\n\t\tcatch (ex)\n\t\t{\n\t\t\tif (ex instanceof SyntaxError)\n\t\t\t{\n\t\t\t\t/// @fixme Put what's in the content variable into a prev content variable?\n\t\t\t\t/// Then once there's no longer any syntax errors being thrown, execute the \n\t\t\t\t/// code? This would also require saving any HTML outside of the *> and <* \n\t\t\t\t/// then echoing it out. The throw below would have to be removed as well.\n\t\t\t\tthrow ex;\n\t\t\t}\n\t\t\telse\n\t\t\t\tthrow ex;\n\t\t}\n\n\t\tHot.Data = returnedOutput.hot.Data;\n\t\tlet finalOutput: string = returnedOutput.output;\n\t\tHot.Output = \"\";\n\n\t\treturn (finalOutput);\n\t}\n}","/**\n * The logging level.\n */\nexport enum HotLogLevel\n{\n\t/**\n\t * Prints only info messages.\n\t */\n\tInfo,\n\t/**\n\t * Prints only warning messages.\n\t */\n\tWarning,\n\t/**\n\t * Prints only error messages.\n\t */\n\tError,\n\t/**\n\t * Prints all messages.\n\t */\n\tVerbose,\n\t/**\n\t * Prints all messages, except verbose.\n\t */\n\tAll,\n\t/**\n\t * Doesn't print any message.\n\t */\n\tNone\n}\n\n/**\n * The logger.\n */\nexport class HotLog\n{\n\t/**\n\t * The logging level.\n\t */\n\tlogLevel: HotLogLevel;\n\n\tconstructor (logLevel: HotLogLevel = HotLogLevel.All)\n\t{\n\t\tthis.logLevel = logLevel;\n\t}\n\n\t/**\n\t * Parse the logging level.\n\t */\n\tstatic parse (logLevel: string): HotLogLevel\n\t{\n\t\tlet level: HotLogLevel = HotLogLevel.All;\n\n\t\tif (logLevel === \"info\")\n\t\t\tlevel = HotLogLevel.Info;\n\n\t\tif (logLevel === \"warning\")\n\t\t\tlevel = HotLogLevel.Warning;\n\n\t\tif (logLevel === \"error\")\n\t\t\tlevel = HotLogLevel.Error;\n\n\t\tif (logLevel === \"verbose\")\n\t\t\tlevel = HotLogLevel.Verbose;\n\n\t\tif (logLevel === \"all\")\n\t\t\tlevel = HotLogLevel.All;\n\n\t\tif (logLevel === \"none\")\n\t\t\tlevel = HotLogLevel.None;\n\n\t\treturn (level);\n\t}\n\n\t/**\n\t * Log a message.\n\t */\n\tlog (level: HotLogLevel, message: string)\n\t{\n\t\tif (this.logLevel === HotLogLevel.Verbose)\n\t\t{\n\t\t\tif (level === HotLogLevel.Error)\n\t\t\t\tthis.error (message);\n\n\t\t\tif (level === HotLogLevel.Warning)\n\t\t\t\tthis.warning (message);\n\n\t\t\tif ((level === HotLogLevel.Info) || \n\t\t\t\t(level === HotLogLevel.Verbose))\n\t\t\t{\n\t\t\t\tthis.info (message);\n\t\t\t}\n\t\t}\n\n\t\tif (this.logLevel === HotLogLevel.All)\n\t\t{\n\t\t\tif (level === HotLogLevel.Error)\n\t\t\t\tthis.error (message);\n\n\t\t\tif (level === HotLogLevel.Warning)\n\t\t\t\tthis.warning (message);\n\n\t\t\tif (level === HotLogLevel.Info)\n\t\t\t\tthis.info (message);\n\t\t}\n\n\t\tif (this.logLevel === HotLogLevel.Error)\n\t\t{\n\t\t\tif (level === HotLogLevel.Error)\n\t\t\t\tthis.error (message);\n\t\t}\n\n\t\tif (this.logLevel === HotLogLevel.Warning)\n\t\t{\n\t\t\tif (level === HotLogLevel.Warning)\n\t\t\t\tthis.warning (message);\n\t\t}\n\n\t\tif (this.logLevel === HotLogLevel.Info)\n\t\t{\n\t\t\tif (level === HotLogLevel.Info)\n\t\t\t\tthis.info (message);\n\t\t}\n\t}\n\n\t/**\n\t * Log a verbose message.\n\t */\n\tverbose (message: string | Function)\n\t{\n\t\tif (this.logLevel === HotLogLevel.Verbose)\n\t\t{\n\t\t\tif (typeof (message) === \"string\")\n\t\t\t\tconsole.info (message);\n\t\t\telse\n\t\t\t\tconsole.info (message ());\n\t\t}\n\t}\n\n\t/**\n\t * Log a message.\n\t */\n\tinfo (message: string)\n\t{\n\t\tif ((this.logLevel === HotLogLevel.All) || \n\t\t\t(this.logLevel === HotLogLevel.Verbose) || \n\t\t\t(this.logLevel === HotLogLevel.Info))\n\t\t{\n\t\t\tconsole.info (message);\n\t\t}\n\t}\n\n\t/**\n\t * Log a warning.\n\t */\n\twarning (message: string)\n\t{\n\t\tif ((this.logLevel === HotLogLevel.All) || \n\t\t\t(this.logLevel === HotLogLevel.Verbose) || \n\t\t\t(this.logLevel === HotLogLevel.Warning))\n\t\t{\n\t\t\tconsole.warn (message);\n\t\t}\n\t}\n\n\t/**\n\t * Log an error message.\n\t */\n\terror (message: string | Error)\n\t{\n\t\tif ((this.logLevel === HotLogLevel.All) || \n\t\t\t(this.logLevel === HotLogLevel.Verbose) || \n\t\t\t(this.logLevel === HotLogLevel.Error))\n\t\t{\n\t\t\tlet msg: string = \"\";\n\n\t\t\tif (typeof (message) === \"string\")\n\t\t\t\tmsg = message;\n\t\t\telse\n\t\t\t{\n\t\t\t\tif (message.message != null)\n\t\t\t\t\tmsg = message.message;\n\n\t\t\t\tif (message.stack != null)\n\t\t\t\t\tmsg = message.stack;\n\t\t\t}\n\n\t\t\tconsole.error (msg);\n\t\t}\n\t}\n}","import { Hot } from \"./Hot\";\nimport { HotAPI } from \"./HotAPI\";\nimport { HotAsset } from \"./HotAsset\";\nimport { HotComponent, IHotComponent } from \"./HotComponent\";\nimport { HotStaq } from \"./HotStaq\";\n\n/**\n * Load a module that contains the assets to load for the frontend.\n */\nexport class HotModule\n{\n\t/**\n\t * The name of the module.\n\t */\n\tname: string;\n\t/**\n\t * The list of NPM modules to import.\n\t */\n\timport?: string[];\n\t/**\n\t * The HTML files to load.\n\t */\n\thtml?: (string | HotAsset)[];\n\t/**\n\t * The CSS files to load.\n\t */\n\tcss?: (string | HotAsset)[];\n\t/**\n\t * The JS files to load.\n\t */\n\tjs?: (string | HotAsset)[];\n\t/**\n\t * The exported component library that contains all the components to load.\n\t */\n\tcomponentLibrary?: string;\n\t/**\n\t * The components to load.\n\t */\n\tcomponents?: (new (copy: IHotComponent | HotStaq, api?: HotAPI) => HotComponent)[];\n\n\tconstructor (name: string)\n\t{\n\t\tthis.name = name;\n\t\tthis.import = [];\n\t\tthis.html = [];\n\t\tthis.css = [];\n\t\tthis.js = [];\n\t\tthis.componentLibrary = \"\";\n\t\tthis.components = [];\n\t}\n\n\t/**\n\t * Output CSS.\n\t */\n\toutputCSS (echoOut: boolean = true): string\n\t{\n\t\tif (this.css == null)\n\t\t\treturn;\n\n\t\tlet output: string = \"\";\n\n\t\tthis.outputAsset (\"css\", this.css, (asset: HotAsset) =>\n\t\t\t{\n\t\t\t\tconst content: string | any = asset.output ();\n\t\t\t\toutput += `${content}\\n`;\n\t\t\t});\n\n\t\tif (echoOut === true)\n\t\t\tHot.echo (output);\n\n\t\treturn (output);\n\t}\n\n\t/**\n\t * Output JS.\n\t */\n\toutputJS (echoOut: boolean = true): string\n\t{\n\t\tif (this.js == null)\n\t\t\treturn;\n\n\t\tlet output: string = \"\";\n\n\t\tthis.outputAsset (\"js\", this.js, (asset: HotAsset) =>\n\t\t\t{\n\t\t\t\tconst content: string | any = asset.output ();\n\t\t\t\toutput += `${content}\\n`;\n\t\t\t});\n\n\t\tif (echoOut === true)\n\t\t\tHot.echo (output);\n\n\t\treturn (output);\n\t}\n\n\t/**\n\t * Output a loaded HTML asset.\n\t */\n\tasync output (assetName: string, args: any[] = null): Promise<void>\n\t{\n\t\tawait Hot.include (`${this.name}/${assetName}.hott`, args);\n\t}\n\n\t/**\n\t * Load HTML assets.\n\t */\n\tasync loadHTML (): Promise<void>\n\t{\n\t\tif (this.html == null)\n\t\t\treturn;\n\n\t\tlet files: any = {};\n\n\t\tthis.outputAsset (\"html\", this.html, (asset: HotAsset) =>\n\t\t\t{\n\t\t\t\tconst file = asset.output ();\n\n\t\t\t\tif (typeof (file) === \"string\")\n\t\t\t\t\tthrow new Error (`HTML assets cannot be outputted using only a string!`);\n\n\t\t\t\tfiles[file.name] = file;\n\t\t\t});\n\n\t\tawait Hot.CurrentPage.processor.loadHotFiles (files);\n\t}\n\n\t/**\n\t * Output components assets.\n\t */\n\toutputComponents (echoOut: boolean = true): string\n\t{\n\t\tif (this.components == null)\n\t\t\treturn (\"\");\n\n\t\tif (this.components.length < 1)\n\t\t\treturn (\"\");\n\n\t\tlet output: string = `<script type = \"text/javascript\">`;\n\t\tlet componentLibrary: string = \"\";\n\n\t\tif (this.componentLibrary != null)\n\t\t{\n\t\t\tif (this.componentLibrary !== \"\")\n\t\t\t\tcomponentLibrary = `${this.componentLibrary}.`;\n\t\t}\n\n\t\tfor (let iIdx = 0; iIdx < this.components.length; iIdx++)\n\t\t{\n\t\t\tlet component = this.components[iIdx];\n\n\t\t\toutput += `Hot.CurrentPage.processor.addComponent (${componentLibrary}${component});\\n`;\n\t\t}\n\n\t\toutput += `</script>`;\n\n\t\tif (echoOut === true)\n\t\t\tHot.echo (output);\n\n\t\treturn (output);\n\t}\n\n\t/**\n\t * Output an asset to HTML.\n\t */\n\tprotected outputAsset (assetType: string, assets: (string | HotAsset)[] = [], \n\t\tcallback: (asset: HotAsset) => void): void\n\t{\n\t\tfor (let iIdx = 0; iIdx < assets.length; iIdx++)\n\t\t{\n\t\t\tlet asset: string | HotAsset = assets[iIdx];\n\t\t\tlet loadAsset: HotAsset = null;\n\t\t\tloadAsset = new HotAsset (assetType);\n\n\t\t\tif (typeof (asset) === \"string\")\n\t\t\t\tloadAsset.path = asset;\n\t\t\telse\n\t\t\t{\n\t\t\t\tif (asset.name != null)\n\t\t\t\t\tloadAsset.name = asset.name;\n\n\t\t\t\tif (asset.path != null)\n\t\t\t\t\tloadAsset.path = asset.path;\n\n\t\t\t\tif (asset.content != null)\n\t\t\t\t\tloadAsset.content = asset.content;\n\t\t\t}\n\n\t\t\tcallback (loadAsset);\n\t\t}\n\t}\n}","import { Hot } from \"./Hot\";\nimport { HotFile } from \"./HotFile\";\nimport { HotStaq } from \"./HotStaq\";\nimport { HotAPI } from \"./HotAPI\";\nimport { HotTestElement } from \"./HotTestElement\";\nimport { HotTestMap, HotTestPath } from \"./HotTestMap\";\nimport { HotComponent } from \"./HotComponent\";\n\n/**\n * A page to preprocess.\n */\nexport interface IHotPage\n{\n\t/**\n\t * The processor to use.\n\t */\n\tprocessor: HotStaq;\n\t/**\n\t * The name of the page.\n\t */\n\tname?: string;\n\t/**\n\t * The route used to get to this page.\n\t */\n\troute?: string;\n\t/**\n\t * The components added to this page.\n\t */\n\tcomponents?: { [name: string]: HotComponent };\n\t/**\n\t * The name of the page. File ordering matters here.\n\t * Every file is processed incrementally.\n\t */\n\tfiles?: HotFile[];\n\t/**\n\t * The associated tester name.\n\t */\n\ttesterName?: string;\n\t/**\n\t * The associated tester map.\n\t */\n\ttesterMap?: string;\n\t/**\n\t * The elements to test on this page.\n\t */\n\ttestElements?: { [name: string]: HotTestElement; };\n\t/**\n\t * The test paths to test on this page.\n\t */\n\ttestPaths?: { [name: string]: HotTestPath; };\n}\n\n/**\n * A page to preprocess.\n */\nexport class HotPage implements IHotPage\n{\n\t/**\n\t * The processor to use.\n\t */\n\tprocessor: HotStaq;\n\t/**\n\t * The name of the page.\n\t */\n\tname: string;\n\t/**\n\t * The route used to get to this page.\n\t */\n\troute: string;\n\t/**\n\t * The components added to this page.\n\t */\n\tcomponents: { [name: string]: HotComponent };\n\t/**\n\t * The name of the page. File ordering matters here.\n\t * Every file is processed incrementally.\n\t */\n\tfiles: HotFile[];\n\t/**\n\t * The associated tester name.\n\t */\n\ttesterName: string;\n\t/**\n\t * The associated tester map.\n\t */\n\ttesterMap: string;\n\t/**\n\t * The elements to test on this page.\n\t */\n\ttestElements: { [name: string]: HotTestElement; };\n\t/**\n\t * The test paths to test on this page.\n\t */\n\ttestPaths: { [name: string]: HotTestPath; };\n\n\tconstructor (copy: IHotPage | HotStaq)\n\t{\n\t\tif (copy instanceof HotStaq)\n\t\t{\n\t\t\tthis.processor = copy;\n\t\t\tthis.name = \"\";\n\t\t\tthis.testerName = \"HotTesterMochaSelenium\";\n\t\t\tthis.testerMap = \"\";\n\t\t\tthis.route = \"\";\n\t\t\tthis.components = {};\n\t\t\tthis.files = [];\n\t\t\tthis.testElements = {};\n\t\t\tthis.testPaths = {};\n\t\t}\n\t\telse\n\t\t{\n\t\t\tthis.processor = copy.processor;\n\t\t\tthis.name = copy.name || \"\";\n\t\t\tthis.testerName = copy.testerName || \"HotTesterMochaSelenium\";\n\t\t\tthis.testerMap = copy.testerMap || \"\";\n\t\t\tthis.route = copy.route || \"\";\n\t\t\tthis.components = copy.components || {};\n\t\t\tthis.files = copy.files || [];\n\t\t\tthis.testElements = copy.testElements || {};\n\t\t\tthis.testPaths = copy.testPaths || {};\n\t\t}\n\t}\n\n\t/**\n\t * Add a file to process. It's recommend to load the file prior to \n\t * adding it to a page if it's about to be used.\n\t */\n\tasync addFile (file: HotFile): Promise<void>\n\t{\n\t\tfile.page = this;\n\n\t\tthis.files.push (file);\n\t}\n\n\t/**\n\t * Get the API associated with this page.\n\t */\n\tgetAPI (): HotAPI\n\t{\n\t\treturn (this.processor.api);\n\t}\n\n\t/**\n\t * Get the tester API associated with this page.\n\t */\n\tgetTesterAPI (): HotAPI\n\t{\n\t\treturn (this.processor.testerAPI);\n\t}\n\n\t/**\n\t * Add all files in the page. Could decrease page loading performance.\n\t * It's recommend to load the file prior to adding it to a page.\n\t */\n\tasync load (file: HotFile): Promise<void>\n\t{\n\t\tfor (let iIdx = 0; iIdx < this.files.length; iIdx++)\n\t\t{\n\t\t\tlet file: HotFile = this.files[iIdx];\n\n\t\t\tawait file.load ();\n\t\t}\n\t}\n\n\t/**\n\t * Process a page and get the result.\n\t */\n\tasync process (args: any = null): Promise<string>\n\t{\n\t\tlet output: string = \"\";\n\n\t\tfor (let iIdx = 0; iIdx < this.files.length; iIdx++)\n\t\t{\n\t\t\tlet file: HotFile = this.files[iIdx];\n\n\t\t\tHot.Output = \"\";\n\t\t\tfile.page = this;\n\n\t\t\toutput += await file.process (args);\n\t\t}\n\n\t\treturn (output);\n\t}\n\n\t/**\n\t * Add a test element.\n\t */\n\taddTestElement (elm: HotTestElement): void\n\t{\n\t\tif (this.testElements[elm.name] != null)\n\t\t\tthrow new Error (`Test element ${elm.name} already exists!`);\n\n\t\tthis.testElements[elm.name] = elm;\n\t}\n\n\t/**\n\t * Get a test element.\n\t */\n\tgetTestElement (name: string): HotTestElement\n\t{\n\t\tif (this.testElements[name] == null)\n\t\t\tthrow new Error (`Test element ${name} doest not exist!`);\n\n\t\treturn (this.testElements[name]);\n\t}\n\n\t/**\n\t * Create a test path.\n\t */\n\tcreateTestPath (pathName: string, driverFunc: HotTestPath): void\n\t{\n\t\tif (this.testPaths[pathName] != null)\n\t\t\tthrow new Error (`Test path ${pathName} already exists!`);\n\n\t\tthis.testPaths[pathName] = driverFunc;\n\t}\n}","import { HotServer } from \"./HotServer\";\nimport { HotRouteMethod, HotEventMethod, IHotRouteMethod, \n\tServerExecutionFunction, TestCaseFunction, TestCaseObject, ServerRequest } from \"./HotRouteMethod\";\nimport { HotClient } from \"./HotClient\";\nimport { HotLog } from \"./HotLog\";\n\n/**\n * The route to use.\n */\nexport class HotRoute\n{\n\t/**\n\t * The server that maintains the connections.\n\t */\n\tconnection: HotServer | HotClient;\n\t/**\n\t * The associated logger.\n\t */\n\tlogger: HotLog;\n\t/**\n\t * The route.\n\t */\n\troute: string;\n\t/**\n\t * The description of the route.\n\t */\n\tdescription: string;\n\t/**\n\t * The version.\n\t */\n\tversion: string;\n\t/**\n\t * The prefix to add to the beginning of each route method.\n\t */\n\tprefix: string;\n\t/**\n\t * The authorization credentials to be used by the client \n\t * when connecting to the server.\n\t */\n\tauthCredentials: any;\n\t/**\n\t * The calls that can be made.\n\t */\n\tmethods: HotRouteMethod[];\n\t/**\n\t * The errors and their JSON that can be thrown. Can be:\n\t * * not_authorized\n\t * * no_server_execute_function\n\t */\n\terrors: { [error: string]: any };\n\n\tconstructor (connection: HotServer | HotClient, route: string, methods: HotRouteMethod[] = [])\n\t{\n\t\tthis.connection = connection;\n\t\tthis.logger = null;\n\n\t\tif (this.connection != null)\n\t\t{\n\t\t\tif (this.connection.processor != null)\n\t\t\t\tthis.logger = this.connection.processor.logger;\n\t\t}\n\n\t\tthis.route = route;\n\t\tthis.description = \"\";\n\t\tthis.version = \"v1\";\n\t\tthis.prefix = \"\";\n\t\tthis.authCredentials = null;\n\t\tthis.methods = methods;\n\t\tthis.errors = {\n\t\t\t\t\"not_authorized\": HotRoute.createError (\"Not authorized.\"),\n\t\t\t\t\"no_server_execute_function\": HotRoute.createError (\"Missing server execute function.\"),\n\t\t\t};\n\t}\n\n\t/**\n\t * Create an error JSON object.\n\t */\n\tstatic createError (message: string): any\n\t{\n\t\treturn ({ error: message });\n\t}\n\n\t/**\n\t * Add an API method to this route.\n\t * \n\t * @param method The name of the method to add. If a HotRouteMethod is supplied, the \n\t * rest of the arguments supplied will be ignored.\n\t */\n\taddMethod (\n\t\tmethod: HotRouteMethod | IHotRouteMethod | string,\n\t\texecuteFunction: ServerExecutionFunction = null,\n\t\ttype: HotEventMethod = HotEventMethod.POST,\n\t\ttestCases: (string | TestCaseFunction)[] | TestCaseFunction[] | TestCaseObject[] = null\n\t\t): void\n\t{\n\t\tif (typeof (method) === \"string\")\n\t\t\tmethod = new HotRouteMethod (this, method, executeFunction, type, null, null, null, testCases);\n\n\t\tif (method instanceof HotRouteMethod)\n\t\t\tthis.methods.push (method);\n\t\telse\n\t\t{\n\t\t\tif (method.route == null)\n\t\t\t\tmethod.route = this;\n\n\t\t\tmethod = new HotRouteMethod (method);\n\t\t\tthis.methods.push ((<HotRouteMethod>method));\n\t\t}\n\t}\n\n\t/**\n\t * Get a method by it's name.\n\t */\n\tgetMethod (name: string): HotRouteMethod\n\t{\n\t\tlet foundMethod: HotRouteMethod = null;\n\n\t\tfor (let iIdx = 0; iIdx < this.methods.length; iIdx++)\n\t\t{\n\t\t\tlet method: HotRouteMethod = this.methods[iIdx];\n\n\t\t\tif (method.name === name)\n\t\t\t{\n\t\t\t\tfoundMethod = method;\n\n\t\t\t\tbreak;\n\t\t\t}\n\t\t}\n\n\t\treturn (foundMethod);\n\t}\n\n\t/**\n\t * Executes before all routes have been registered.\n\t */\n\tonPreRegister: () => Promise<void> = null;\n\t/**\n\t * Executes when first registering this route with Express. If \n\t * this returns false, the route will not be registered.\n\t */\n\tonRegister: () => Promise<boolean> = null;\n\t/**\n\t * Executes after all routes have been registered.\n\t */\n\tonPostRegister: () => Promise<void> = null;\n\n\t/**\n\t * Executes when authorizing a called method.\n\t * The value returned from here will be passed to onExecute in the \n\t * called HotRouteMethod. Undefined returning from here will mean \n\t * the authorization failed.\n\t */\n\tonAuthorizeUser: (req: ServerRequest) => Promise<any> = null;\n}","import { DeveloperMode } from \"./Hot\";\nimport { HotTestDriver } from \"./HotTestDriver\";\nimport { HotRoute } from \"./HotRoute\";\nimport { HotServer } from \"./HotServer\";\n\nimport express from \"express\";\nimport { HotWebSocketClient } from \"./HotWebSocketClient\";\n\n/**\n * The available event methods.\n */\nexport enum HotEventMethod\n{\n\t/**\n\t * A HTTP GET request.\n\t */\n\tGET = \"get\",\n\t/**\n\t * A HTTP POST request.\n\t */\n\tPOST = \"post\",\n\t/**\n\t * This will upload a file, then post the json request afterwards.\n\t */\n\tFILE_UPLOAD = \"file_upload_then_post_json\",\n\t/**\n\t * A websocket event.\n\t */\n\tWEBSOCKET_CLIENT_PUB_EVENT = \"websocket_client_pub_event\"\n}\n\n/**\n * The request that came from a client.\n */\nexport interface IServerRequest\n{\n\t/**\n\t * The express request received from the client. Will be set to null if using worker \n\t * threads or if this request was received from a websocket connection.\n\t */\n\treq?: express.Request;\n\t/**\n\t * The express response to send to the client. Will be set to null if using worker \n\t * threads or if this request was received from a websocket connection.\n\t */\n\tres?: express.Response;\n\t/**\n\t * The client websocket that was used to send the message. Will be set to null if using worker \n\t * threads or if this request was received from a HTTP connection.\n\t */\n\twsSocket?: HotWebSocketClient;\n\t/**\n\t * The response received from authorizing a client. Can be a JWT token, api key, etc.\n\t * Will be null if this request was received from a websocket connection.\n\t */\n\tauthorizedValue?: any;\n\t/**\n\t * The JSON received from the client.\n\t */\n\tjsonObj?: any;\n\t/**\n\t * Any query variables received from the client. Will be null if this request was \n\t * received from a websocket connection.\n\t */\n\tqueryObj?: any;\n\t/**\n\t * Any files received from the client. Will be null if no files were sent.\n\t * Once a file is uploaded, you can access it at the temporary path found in: \n\t * files[uploadId].path\n\t */\n\tfiles?: {\n\t\t[key: string]: {\n\t\t\tname: string;\n\t\t\tsize: number;\n\t\t\tpath: string;\n\t\t}\n\t};\n}\n\n/**\n * The request that came from a client.\n */\nexport class ServerRequest implements IServerRequest\n{\n\t/**\n\t * The express request received from the client. Will be set to null if using worker \n\t * threads or if this request was received from a websocket connection.\n\t */\n\treq: express.Request;\n\t/**\n\t * The express response to send to the client. Will be set to null if using worker \n\t * threads or if this request was received from a websocket connection.\n\t */\n\tres: express.Response;\n\t/**\n\t * The client websocket that was used to send the message. Will be set to null if using worker \n\t * threads or if this request was received from a HTTP connection.\n\t */\n\twsSocket: HotWebSocketClient;\n\t/**\n\t * The response received from authorizing a client. Can be a JWT token, api key, etc.\n\t * Will be null if this request was received from a websocket connection.\n\t */\n\tauthorizedValue: any;\n\t/**\n\t * The JSON received from the client.\n\t */\n\tjsonObj: any;\n\t/**\n\t * Any query variables received from the client. Will be null if this request was \n\t * received from a websocket connection.\n\t */\n\tqueryObj: any;\n\t/**\n\t * Any files received from the client. Will be null if no files were sent.\n\t * Once a file is uploaded, you can access it at the temporary path found in: \n\t * files[uploadId].path\n\t */\n\tfiles: {\n\t\t[key: string]: {\n\t\t\tname: string;\n\t\t\tsize: number;\n\t\t\tpath: string;\n\t\t}\n\t};\n\n\tconstructor (obj: IServerRequest = null)\n\t{\n\t\tif (obj == null)\n\t\t\tobj = {};\n\n\t\tthis.req = obj.req || null;\n\t\tthis.res = obj.res || null;\n\t\tthis.wsSocket = obj.wsSocket || null;\n\t\tthis.authorizedValue = obj.authorizedValue || null;\n\t\tthis.jsonObj = obj.jsonObj || null;\n\t\tthis.queryObj = obj.queryObj || null;\n\t\tthis.files = obj.files || null;\n\t}\n}\n\n/**\n * A function that will be executed by the server when first registering with Express.\n * If this returns false, this route method will not be registered.\n */\nexport type ServerRegistrationFunction = () => Promise<boolean>;\n/**\n * A function that will be executed by the server.\n */\nexport type ServerExecutionFunction = (request: ServerRequest) => Promise<any>;\n/**\n * A function that will be executed by the client.\n */\nexport type ClientExecutionFunction = (...args: any[]) => Promise<any>;\n/**\n * A function that will be executed by the server for authorization. Any value \n * returned from this function will be passed to the ServerExecutionFunction.\n * If an undefined value is returned, this indicates the server was not able \n * to authenticate the user, so the ServerExecutionFunction will not be \n * executed.\n */\nexport type ServerAuthorizationFunction = (request: ServerRequest) => Promise<any>;\n/**\n * The test case function to execute.\n */\nexport type TestCaseFunction = ((driver: HotTestDriver) => Promise<any>) | ((driver: HotTestDriver) => any);\n/**\n * The test case object to pass.\n */\nexport interface TestCaseObject\n{\n\t/**\n\t * The name of the test case.\n\t */\n\tname: string;\n\t/**\n\t * The function to execute.\n\t */\n\tfunc: TestCaseFunction;\n}\n\n/**\n * A method parameter.\n */\nexport interface HotRouteMethodParameter\n{\n\t/**\n\t * The type of parameter. Default: string\n\t * Can be:\n\t * * string\n\t * * integer\n\t * * number\n\t * * boolean\n\t * * array\n\t * * object\n\t */\n\ttype?: string;\n\t/**\n\t * The description of the parameter. Default: \"\"\n\t */\n\tdescription?: string;\n\t/**\n\t * Is this parameter required? Default: false\n\t */\n\trequired?: boolean;\n\t/**\n\t * The parameters in the object.\n\t */\n\tparameters?: { [name: string]: string | HotRouteMethodParameter; };\n}\n\n/**\n * An API method to make.\n */\nexport interface IHotRouteMethod\n{\n\t/**\n\t * The parent route.\n\t */\n\troute?: HotRoute;\n\t/**\n\t * The api call name.\n\t */\n\tname: string;\n\t/**\n\t * The description of the api method.\n\t */\n\tdescription?: string;\n\t/**\n\t * The description of what returns from the api method.\n\t */\n\treturns?: string | HotRouteMethodParameter;\n\t/**\n\t * The parameters in the api method.\n\t */\n\tparameters?: { [name: string]: string | HotRouteMethodParameter; };\n\t/**\n\t * The api call name.\n\t */\n\ttype?: HotEventMethod;\n\t/**\n\t * The authorization credentials to be used by the client \n\t * when connecting to the server.\n\t */\n\tauthCredentials?: any;\n\t/**\n\t * The test case objects to execute during tests.\n\t */\n\ttestCases?: {\n\t\t\t[name: string]: TestCaseObject;\n\t\t} | (string | TestCaseFunction)[] | TestCaseFunction[] | TestCaseObject[];\n\t/**\n\t * Executes before all routes have been registered.\n\t */\n\tonPreRegister?: () => Promise<void>;\n\t/**\n\t * Executes when first registering this method with Express. If \n\t * this returns false, the method will not be registered.\n\t */\n\tonRegister?: ServerRegistrationFunction;\n\t/**\n\t * Executes after all routes have been registered.\n\t */\n\tonPostRegister?: () => Promise<void>;\n\n\t/**\n\t * Executes when authorizing a called method. If this method \n\t * is set, this will not call onAuthorize for the parent HotRoute.\n\t * The value returned from here will be passed to onExecute. \n\t * Undefined returning from here will mean the authorization failed.\n\t * If any exceptions are thrown from this function, they will be sent \n\t * to the server as an { error: string; } object with the exception \n\t * message as the error.\n\t * \n\t * Currently this has no effect when using websockets.\n\t */\n\tonServerAuthorize?: ServerAuthorizationFunction;\n\n\t/**\n\t * Executes when executing a called method from the server side. \n\t * This will stringify any JSON object and send it as a JSON response. \n\t * If undefined is returned no response will be sent to the server. \n\t * So the developer would have to send a response using \"res\".\n\t * If any exceptions are thrown from this function, they will be sent \n\t * to the server as an { error: string; } object with the exception \n\t * message as the error.\n\t */\n\tonServerExecute?: ServerExecutionFunction;\n\t/**\n\t * Executes when executing a called method from the client side.\n\t * @fixme Is this necessary?\n\t */\n\tonClientExecute?: ClientExecutionFunction;\n}\n\n/**\n * An API method to make.\n */\nexport class HotRouteMethod implements IHotRouteMethod\n{\n\t/**\n\t * The parent route.\n\t */\n\troute: HotRoute;\n\t/**\n\t * The api call name.\n\t */\n\tname: string;\n\t/**\n\t * The description of the api method.\n\t */\n\tdescription: string;\n\t/**\n\t * The description of what returns from the api method.\n\t */\n\treturns: HotRouteMethodParameter;\n\t/**\n\t * The parameters in the api method.\n\t */\n\tparameters: { [name: string]: HotRouteMethodParameter; };\n\t/**\n\t * The api call name.\n\t */\n\ttype: HotEventMethod;\n\t/**\n\t * Has this method been registered with the server? This \n\t * prevents the method from being reregistered.\n\t */\n\tisRegistered: boolean;\n\t/**\n\t * Has this method been registered with the server? This \n\t * prevents the method from being reregistered.\n\t */\n\texecuteSetup: boolean;\n\t/**\n\t * The authorization credentials to be used by the client \n\t * when connecting to the server.\n\t */\n\tauthCredentials: any;\n\t/**\n\t * The test case objects to execute during tests.\n\t */\n\ttestCases: {\n\t\t\t[name: string]: TestCaseObject;\n\t\t};\n\t/**\n\t * Executes before all routes have been registered.\n\t */\n\tonPreRegister?: () => Promise<void>;\n\t/**\n\t * Executes when first registering this method with Express. If \n\t * this returns false, the method will not be registered.\n\t */\n\tonRegister?: ServerRegistrationFunction;\n\t/**\n\t * Executes after all routes have been registered.\n\t */\n\tonPostRegister?: () => Promise<void>;\n\n\t/**\n\t * Executes when authorizing a called method. If this method \n\t * is set, this will not call onAuthorize for the parent HotRoute.\n\t * The value returned from here will be passed to onServerExecute. \n\t * Undefined returning from here will mean the authorization failed.\n\t * If any exceptions are thrown from this function, they will be sent \n\t * to the client as an { error: string; } object with the exception \n\t * message as the error.\n\t */\n\tonServerAuthorize?: ServerAuthorizationFunction;\n\n\t/**\n\t * Executes when executing a called method from the server side. \n\t * This will stringify any JSON object and send it as a JSON response. \n\t * If undefined is returned no response will be sent to the server. \n\t * So the developer would have to send a response using \"res\".\n\t * If any exceptions are thrown from this function, they will be sent \n\t * to the server as an { error: string; } object with the exception \n\t * message as the error.\n\t */\n\tonServerExecute?: ServerExecutionFunction;\n\t/**\n\t * Executes when executing a called method from the client side.\n\t * @fixme Is this necessary?\n\t */\n\tonClientExecute?: ClientExecutionFunction;\n\n\tconstructor (route: HotRoute | IHotRouteMethod, name: string = \"\", \n\t\tonExecute: ServerExecutionFunction | ClientExecutionFunction = null, \n\t\ttype: HotEventMethod = HotEventMethod.POST, onServerAuthorize: ServerAuthorizationFunction = null, \n\t\tonRegister: ServerRegistrationFunction = null, authCredentials: any = null, \n\t\ttestCases: { [name: string]: TestCaseObject; } | (string | TestCaseFunction)[] | TestCaseFunction[] | TestCaseObject[] = null)\n\t{\n\t\tlet newRoute: HotRoute = null;\n\n\t\tif (route instanceof HotRoute)\n\t\t\tnewRoute = route;\n\t\telse\n\t\t{\n\t\t\tnewRoute = route.route;\n\n\t\t\tif (route.type != null)\n\t\t\t\ttype = route.type;\n\n\t\t\tif (route.name != null)\n\t\t\t\tname = route.name;\n\n\t\t\tif (route.description != null)\n\t\t\t\tthis.description = route.description;\n\n\t\t\tif (route.returns != null)\n\t\t\t{\n\t\t\t\tif (typeof (route.returns) === \"string\")\n\t\t\t\t{\n\t\t\t\t\tthis.returns = {\n\t\t\t\t\t\t\t\"type\": \"string\",\n\t\t\t\t\t\t\t\"required\": true,\n\t\t\t\t\t\t\t\"description\": route.returns\n\t\t\t\t\t\t};\n\t\t\t\t}\n\t\t\t\telse\n\t\t\t\t\tthis.returns = route.returns;\n\t\t\t}\n\n\t\t\tif (route.parameters != null)\n\t\t\t{\n\t\t\t\tthis.parameters = {};\n\n\t\t\t\tfor (let key in route.parameters)\n\t\t\t\t{\n\t\t\t\t\tlet param = route.parameters[key];\n\n\t\t\t\t\tif (typeof (param) === \"string\")\n\t\t\t\t\t{\n\t\t\t\t\t\tthis.parameters[key] = {\n\t\t\t\t\t\t\t\t\"type\": param,\n\t\t\t\t\t\t\t\t\"required\": false,\n\t\t\t\t\t\t\t\t\"description\": \"\"\n\t\t\t\t\t\t\t};\n\t\t\t\t\t}\n\t\t\t\t\telse\n\t\t\t\t\t{\n\t\t\t\t\t\tif (param.type == null)\n\t\t\t\t\t\t\tparam.type = \"string\";\n\n\t\t\t\t\t\tthis.parameters[key] = param;\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t}\n\n\t\t\tif (route.authCredentials != null)\n\t\t\t\tauthCredentials = route.authCredentials;\n\n\t\t\tif (route.onServerExecute != null)\n\t\t\t\tonExecute = route.onServerExecute;\n\n\t\t\tif (route.onServerAuthorize != null)\n\t\t\t\tonServerAuthorize = route.onServerAuthorize;\n\n\t\t\tif (route.onRegister != null)\n\t\t\t\tonRegister = route.onRegister;\n\n\t\t\tif (route.onPostRegister != null)\n\t\t\t\tthis.onPostRegister = route.onPostRegister;\n\n\t\t\tif (route.onServerExecute != null)\n\t\t\t\tthis.onServerExecute = route.onServerExecute;\n\n\t\t\tif (route.onClientExecute != null)\n\t\t\t\tthis.onClientExecute = route.onClientExecute;\n\n\t\t\tif (route.testCases != null)\n\t\t\t\ttestCases = route.testCases;\n\t\t}\n\n\t\tif (name === \"\")\n\t\t\tthrow new Error (`All route methods must have a name!`);\n\n\t\tthis.route = newRoute;\n\t\tthis.name = name;\n\t\tthis.type = type;\n\t\tthis.isRegistered = false;\n\t\tthis.executeSetup = false;\n\t\tthis.authCredentials = authCredentials;\n\t\tthis.onServerAuthorize = onServerAuthorize;\n\t\tthis.onRegister = onRegister;\n\t\tthis.testCases = {};\n\n\t\tif (this.route.connection.processor.mode === DeveloperMode.Development)\n\t\t{\n\t\t\tif (testCases != null)\n\t\t\t{\n\t\t\t\tif (testCases instanceof Array)\n\t\t\t\t{\n\t\t\t\t\tfor (let iIdx = 0; iIdx < testCases.length; iIdx++)\n\t\t\t\t\t{\n\t\t\t\t\t\tlet obj = testCases[iIdx];\n\n\t\t\t\t\t\tif (typeof (obj) === \"string\")\n\t\t\t\t\t\t{\n\t\t\t\t\t\t\tconst testCaseName: string = obj;\n\t\t\t\t\t\t\tconst func: TestCaseFunction = (<TestCaseFunction>testCases[iIdx + 1]);\n\n\t\t\t\t\t\t\tthis.addTestCase (testCaseName, func);\n\t\t\t\t\t\t\tiIdx++;\n\t\t\t\t\t\t}\n\t\t\t\t\t\telse\n\t\t\t\t\t\t\tthis.addTestCase (obj);\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t\telse\n\t\t\t\t{\n\t\t\t\t\tfor (let key in testCases)\n\t\t\t\t\t{\n\t\t\t\t\t\tlet obj = testCases[key];\n\n\t\t\t\t\t\tthis.addTestCase (obj);\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\n\t\tif (this.route.connection instanceof HotServer)\n\t\t\tthis.onServerExecute = onExecute;\n\t\t//else\n\t\t\t//this.onClientExecute = onExecute;\n\t}\n\n\t/**\n\t * Add a new test case.\n\t */\n\taddTestCase (newTestCase: TestCaseObject | string | TestCaseFunction, \n\t\t\ttestCaseFunction: TestCaseFunction = null): void\n\t{\n\t\tif (typeof (newTestCase) === \"string\")\n\t\t{\n\t\t\tconst name: string = newTestCase;\n\t\t\tconst func: TestCaseFunction = testCaseFunction;\n\n\t\t\tthis.testCases[name] = {\n\t\t\t\t\tname: name,\n\t\t\t\t\tfunc: func\n\t\t\t\t};\n\n\t\t\treturn;\n\t\t}\n\n\t\tif (typeof (newTestCase) === \"function\")\n\t\t{\n\t\t\tconst testCaseId: number = Object.keys (this.testCases).length;\n\t\t\tconst name: string = `${this.route.route}/${this.name} test case ${testCaseId}`;\n\t\t\tconst func: TestCaseFunction = (<TestCaseFunction>newTestCase);\n\n\t\t\tthis.testCases[name] = {\n\t\t\t\t\tname: name,\n\t\t\t\t\tfunc: func\n\t\t\t\t};\n\n\t\t\treturn;\n\t\t}\n\n\t\tconst testCase: TestCaseObject = (<TestCaseObject>newTestCase);\n\t\tthis.testCases[testCase.name] = testCase;\n\t}\n\n\t/**\n\t * Get the relative url from this method and its route.\n\t */\n\tgetRouteUrl (): string\n\t{\n\t\tif (this.route == null)\n\t\t\tthrow new Error (`Route method ${this.name} does not have a parent route!`);\n\n\t\tlet methodName: string = \"/\";\n\n\t\tif (this.route.version !== \"\")\n\t\t\tmethodName += `${this.route.version}/`;\n\n\t\tif (this.route.prefix !== \"\")\n\t\t\tmethodName += `${this.route.prefix}/`;\n\n\t\tif (this.route.route !== \"\")\n\t\t\tmethodName += `${this.route.route}/`;\n\n\t\tmethodName += this.name;\n\n\t\treturn (methodName);\n\t}\n}","import { HotStaq } from \"./HotStaq\";\nimport { HotLog } from \"./HotLog\";\nimport { HotAPI } from \"./HotAPI\";\nimport { HotRoute } from \"./HotRoute\";\n\n/**\n * The type of server.\n */\nexport enum HotServerType\n{\n\tHTTP,\n\tWebSockets,\n\tGenerate,\n\tWebTesting,\n\tAPITesting\n}\n\n/**\n * The server.\n */\nexport interface IHotServer\n{\n\t/**\n\t * The processor to use.\n\t */\n\tprocessor: HotStaq;\n\t/**\n\t * The server type.\n\t */\n\tserverType: string;\n\t/**\n\t * The API to use.\n\t */\n\tapi: HotAPI;\n\t/**\n\t * The network address to listen on.\n\t */\n\tlistenAddress: string;\n\t/**\n\t * The ports to use.\n\t */\n\tports: {\n\t\t\thttp: number;\n\t\t\thttps: number;\n\t\t};\n\t/**\n\t * SSL settings.\n\t */\n\tssl: {\n\t\t\t/**\n\t\t\t * The SSL certificate to use.\n\t\t\t */\n\t\t\tcert: string;\n\t\t\t/**\n\t\t\t * The SSL certificate key to use.\n\t\t\t */\n\t\t\tkey: string;\n\t\t\t/**\n\t\t\t * The SSL certificate CA to use.\n\t\t\t */\n\t\t\tca: string;\n\t\t};\n\t/**\n\t * Redirect HTTP traffic to HTTPS.\n\t */\n\tredirectHTTPtoHTTPS: boolean;\n\t/**\n\t * The type of server.\n\t */\n\ttype: HotServerType;\n\t/**\n\t * The logger.\n\t */\n\tlogger: HotLog;\n\t/**\n\t * Any secrets associated with this server.\n\t */\n\tsecrets: any;\n}\n\n/**\n * The server.\n */\nexport class HotServer implements IHotServer\n{\n\t/**\n\t * The processor to use.\n\t */\n\tprocessor: HotStaq;\n\t/**\n\t * The server type.\n\t */\n\tserverType: string;\n\t/**\n\t * The API to use.\n\t */\n\tapi: HotAPI;\n\t/**\n\t * The network address to listen on.\n\t */\n\tlistenAddress: string;\n\t/**\n\t * The ports to use.\n\t */\n\tports: {\n\t\t\thttp: number;\n\t\t\thttps: number;\n\t\t};\n\t/**\n\t * SSL settings.\n\t */\n\tssl: {\n\t\t\t/**\n\t\t\t * The SSL certificate to use.\n\t\t\t */\n\t\t\tcert: string;\n\t\t\t/**\n\t\t\t * The SSL certificate key to use.\n\t\t\t */\n\t\t\tkey: string;\n\t\t\t/**\n\t\t\t * The SSL certificate CA to use.\n\t\t\t */\n\t\t\tca: string;\n\t\t};\n\t/**\n\t * Redirect HTTP traffic to HTTPS.\n\t */\n\tredirectHTTPtoHTTPS: boolean;\n\t/**\n\t * The type of server.\n\t */\n\ttype: HotServerType;\n\t/**\n\t * The logger.\n\t */\n\tlogger: HotLog;\n\t/**\n\t * Any secrets associated with this server.\n\t */\n\tsecrets: any;\n\n\tconstructor (processor: HotStaq | HotServer)\n\t{\n\t\tif (processor instanceof HotStaq)\n\t\t{\n\t\t\tthis.processor = processor;\n\t\t\tthis.serverType = \"Server\";\n\t\t\tthis.api = null;\n\t\t\tthis.listenAddress = \"0.0.0.0\";\n\t\t\tthis.ports = {\n\t\t\t\t\thttp: 5000,\n\t\t\t\t\thttps: 443\n\t\t\t\t};\n\t\t\tthis.ssl = {\n\t\t\t\t\tcert: \"\",\n\t\t\t\t\tkey: \"\",\n\t\t\t\t\tca: \"\"\n\t\t\t\t};\n\t\t\tthis.redirectHTTPtoHTTPS = true;\n\t\t\tthis.type = HotServerType.HTTP;\n\t\t\tthis.logger = processor.logger;\n\t\t\tthis.secrets = {};\n\t\t}\n\t\telse\n\t\t{\n\t\t\tthis.processor = processor.processor;\n\t\t\tthis.serverType = processor.serverType || \"Server\";\n\t\t\tthis.api = processor.api || null;\n\t\t\tthis.listenAddress = processor.listenAddress || \"0.0.0.0\";\n\t\t\tthis.ports = processor.ports || {\n\t\t\t\t\thttp: 5000,\n\t\t\t\t\thttps: 443\n\t\t\t\t};\n\t\t\tthis.ssl = processor.ssl || {\n\t\t\t\t\tcert: \"\",\n\t\t\t\t\tkey: \"\",\n\t\t\t\t\tca: \"\"\n\t\t\t\t};\n\t\t\tthis.redirectHTTPtoHTTPS = processor.redirectHTTPtoHTTPS != null ? processor.redirectHTTPtoHTTPS : true;\n\t\t\tthis.type = processor.type || HotServerType.HTTP;\n\t\t\tthis.logger = processor.logger;\n\t\t\tthis.secrets = processor.secrets || {};\n\t\t}\n\t}\n\n\t/**\n\t * Set an API to this server. This will also set the associated \n\t * processor to this API as well.\n\t */\n\tasync setAPI (api: HotAPI): Promise<void>\n\t{\n\t\tthis.processor.api = api;\n\t\tthis.api = api;\n\n\t\t//if (registerRoutes === true)\n\t\t\t//await this.api.registerRoutes ();\n\t}\n\n\t/**\n\t * Register a route with the server.\n\t */\n\tasync registerRoute? (route: HotRoute): Promise<void>;\n\n\t/**\n\t * Start listening for requests.\n\t */\n\tasync listen? (): Promise<void>;\n\n\t/**\n\t * Shutdown the server.\n\t */\n\tasync shutdown? (): Promise<void>;\n}","import * as ppath from \"path\";\n\nimport fetch from \"node-fetch\";\nimport validateModuleName from \"validate-npm-package-name\";\n\nimport { HotPage } from \"./HotPage\";\nimport { HotFile } from \"./HotFile\";\n\nimport { HotComponent, HotComponentOutput, IHotComponent } from \"./HotComponent\";\nimport { HotLog, HotLogLevel } from \"./HotLog\";\nimport { HotAPI } from \"./HotAPI\";\nimport { HotServer } from \"./HotServer\";\nimport { DeveloperMode } from \"./Hot\";\nimport { HotAsset } from \"./HotAsset\";\nimport { HotModule } from \"./HotModule\";\nimport { HotClient } from \"./HotClient\";\n\nimport { HotTester } from \"./HotTester\";\nimport { HotTesterAPI } from \"./HotTesterAPI\";\nimport { HotTestDriver } from \"./HotTestDriver\";\nimport { HotTestMap } from \"./HotTestMap\";\nimport { HotTestDestination} from \"./HotTestDestination\";\n\nimport { HotSite, HotSiteRoute } from \"./HotSite\";\n\nimport { registerComponent } from \"./HotStaqRegisterComponent\";\nimport { hotStaqWebStart } from \"./HotStaqWebStart\";\n\nvar HotTesterMocha: any = null;\nvar HotTesterMochaSelenium: any = null;\nvar HotTestSeleniumDriver: any = null;\n\n/**\n * The options to use when starting a page.\n */\nexport interface HotStartOptions\n{\n\t/**\n\t * The Hott site to load.\n\t */\n\turl?: string;\n\t/**\n\t * The content to display.\n\t */\n\tcontent?: string;\n\t/**\n\t * The name of the page to load.\n\t */\n\tname?: string;\n\t/**\n\t * The processor to use to load the page.\n\t */\n\tprocessor?: HotStaq;\n\t/**\n\t * Any arguments to pass to the new page.\n\t */\n\targs?: any;\n\t/**\n\t * The name of the tester to use.\n\t */\n\ttesterName?: string;\n\t/**\n\t * The name of the tester map to use.\n\t */\n\ttesterMap?: string;\n\t/**\n\t * The base url for the tester api.\n\t */\n\ttesterAPIBaseUrl?: string;\n\t/**\n\t * The url to the html that loads the hott file that's \n\t * pointed at the url above.\n\t */\n\ttesterLaunchpadUrl?: string;\n}\n\n/**\n * The main class that handles all HTML preprocessing, then outputs the \n * results.\n */\nexport interface IHotStaq\n{\n\t/**\n\t * The api that's used to communicate with.\n\t */\n\tapi?: HotAPI;\n\t/**\n\t * The tester api that's used to communicate with.\n\t */\n\ttesterAPI?: HotAPI;\n\t/**\n\t * Indicates what type of execution this is.\n\t */\n\tmode?: DeveloperMode;\n\t/**\n\t * The pages that can be constructed.\n\t */\n\tpages?: { [name: string]: HotPage };\n\t/**\n\t * The imported modules.\n\t */\n\tmodules?: { [name: string]: HotModule };\n\t/**\n\t * The components that can be constructed.\n\t * \n\t * @fixme Rename this to componentTags.\n\t */\n\tcomponents?: {\n\t\t[tagName: string]: {\n\t\t\t\tcomponentType: (new  (copy: IHotComponent | HotStaq, api?: HotAPI) => HotComponent), \n\t\t\t\tprocessor: HotStaq, \n\t\t\t\tapi: HotAPI\n\t\t\t}\n\t\t};\n\t/**\n\t * The files that can be stored for later use.\n\t */\n\tfiles?: { [name: string]: HotFile };\n\t/**\n\t * The loaded hotsite.\n\t */\n\thotSite?: HotSite;\n}\n\n/**\n * The main class that handles all HTML preprocessing, then outputs the \n * results.\n */\nexport class HotStaq implements IHotStaq\n{\n\t/**\n\t * The current version of HotStaq.\n\t */\n\tstatic version: string = \"0.8.23\";\n\t/**\n\t * Indicates if this is a web build.\n\t */\n\tstatic isWeb: boolean = false;\n\t/**\n\t * Indicates if this is ready for testing.\n\t */\n\tstatic isReadyForTesting: boolean = false;\n\t/**\n\t * Executes this event when this page is ready for testing.\n\t */\n\tstatic onReadyForTesting: () => Promise<void> = null;\n\t/**\n\t * Errors to execute when something goes wrong.\n\t */\n\tstatic errors: { [name: string]: { redirectToUrl?: string; func?: (errType: string) => void; }; } = {};\n\t/**\n\t * Indicates what type of execution this is.\n\t */\n\tmode: DeveloperMode;\n\t/**\n\t * The api that's used to communicate with.\n\t */\n\tapi: HotAPI;\n\t/**\n\t * The tester api that's used to communicate with.\n\t */\n\ttesterAPI: HotAPI;\n\t/**\n\t * The pages that can be constructed.\n\t */\n\tpages: { [name: string]: HotPage };\n\t/**\n\t * The imported modules.\n\t */\n\tmodules: { [name: string]: HotModule };\n\t/**\n\t * The components that can be constructed.\n\t * \n\t * @fixme Rename this to componentTags.\n\t */\n\tcomponents: {\n\t\t[tagName: string]: {\n\t\t\t\tcomponentType: (new  (copy: IHotComponent | HotStaq, api?: HotAPI) => HotComponent), \n\t\t\t\tprocessor: HotStaq, \n\t\t\t\tapi: HotAPI\n\t\t\t}\n\t\t};\n\t/**\n\t * The files that can be stored for later use.\n\t */\n\tfiles: { [name: string]: HotFile };\n\t/**\n\t * The loaded hotsite.\n\t */\n\thotSite: HotSite;\n\t/**\n\t * The api content to use when about to load HotStaq.\n\t */\n\tapiContent: string;\n\t/**\n\t * The tester api content to use when about to load HotStaq.\n\t */\n\ttesterApiContent: string;\n\t/**\n\t * The page content to use when about to load HotStaq.\n\t */\n\tpageContent: string;\n\t/**\n\t * The logger.\n\t */\n\tlogger: HotLog;\n\t/**\n\t * Add a start delay before starting. This is for debugging purposes mostly.\n\t */\n\tstartDelay: number;\n\t/**\n\t * The public keys to be exposed.\n\t */\n\tpublicKeys: any;\n\t/**\n\t * The testers that will be used to execute tests.\n\t */\n\ttesters: { [name: string]: HotTester };\n\n\tconstructor (copy: IHotStaq = {})\n\t{\n\t\tthis.logger = new HotLog (HotLogLevel.All);\n\t\tthis.startDelay = 0;\n\t\tthis.api = copy.api || null;\n\t\tthis.testerAPI = copy.testerAPI || null;\n\t\tthis.mode = copy.mode || DeveloperMode.Production;\n\t\tthis.pages = copy.pages || {};\n\t\tthis.modules = copy.modules || {};\n\t\tthis.components = copy.components || {};\n\t\tthis.files = copy.files || {};\n\t\tthis.hotSite = copy.hotSite || null;\n\t\tthis.apiContent = `\n\t\t\t{\n\t\t\t\tvar %api_name% = %api_exported_name%.%api_name%;\n\t\t\t\tvar newHotClient = new HotClient (processor);\n\t\t\t\tvar newapi = new %api_name% (%base_url%, newHotClient);\n\t\t\t\tnewHotClient.api = newapi;\n\t\t\t\tprocessor.api = newapi;\n\t\t\t}`;\n\t\tthis.testerApiContent = `\n\t\t\tvar HotTesterAPI = HotStaqWeb.HotTesterAPI;\n\t\t\tvar newHotTesterClient = new HotClient (processor);\n\t\t\tvar newtesterapi = new HotTesterAPI (%base_tester_url%, newHotTesterClient);\n\t\t\tnewHotTesterClient.testerAPI = newtesterapi;\n\t\t\tprocessor.testerAPI = newtesterapi;`;\n\t\tthis.pageContent = \n`<!DOCTYPE html>\n<html>\n\n<head>\n\t<title>%title%</title>\n\n\t<script type = \"text/javascript\" src = \"%hotstaq_js_src%\"></script>\n\t<script type = \"text/javascript\">\n\t\tfor (let key in HotStaqWeb)\n\t\t\twindow[key] = HotStaqWeb[key];\n\t</script>\n\n%apis_to_load%\n\n\t<script type = \"text/javascript\">\n\t\tasync function hotstaq_startApp ()\n\t\t{\n\t\t\tlet tempMode = 0;\n\n\t\t\tif (window[\"Hot\"] != null)\n\t\t\t\ttempMode = Hot.Mode;\n\n\t\t\t%start_delay%\n\n\t\t\tvar processor = new HotStaq ();\n\t\t\tprocessor.logger.logLevel = %logging_level%;\n\n\t\t\tvar promises = [];\n\t\t\t%developer_mode%\n\n\t\t\t%api_code%\n\n\t\t\t%public_secrets%\n\t\t\t%tester_api%\n\t\t\t%load_files%\n\n\t\t\tprocessor.mode = tempMode;\n\n\t\t\tPromise.all (promises).then (function ()\n\t\t\t\t{\n\t\t\t\t\tHotStaq.displayUrl ({\n\t\t\t\t\t\t\turl: \"%url%\",\n\t\t\t\t\t\t\tname: \"%title%\",\n\t\t\t\t\t\t\tprocessor: processor,\n\t\t\t\t\t\t\targs: %args%,\n\t\t\t\t\t\t\ttesterName: %tester_name%,\n\t\t\t\t\t\t\ttesterMap: %tester_map%,\n\t\t\t\t\t\t\ttesterAPIBaseUrl: %tester_api_base_url%,\n\t\t\t\t\t\t\ttesterLaunchpadUrl: %tester_launchpad_url%\n\t\t\t\t\t\t});\n\t\t\t\t});\n\t\t}\n\n\t\thotstaq_startApp ();\n\t</script>\n</head>\n\n<body>\n</body>\n\n</html>`;\n\t\tthis.publicKeys = {};\n\t\tthis.testers = {};\n\t}\n\n\t/**\n\t * Parse a boolean value.\n\t */\n\tstatic parseBoolean (value: string): boolean\n\t{\n\t\tvalue = value.toLowerCase ();\n\n\t\tif (value === \"true\")\n\t\t\treturn (true);\n\n\t\tif (value === \"false\")\n\t\t\treturn (false);\n\n\t\tif (value === \"yes\")\n\t\t\treturn (true);\n\n\t\tif (value === \"no\")\n\t\t\treturn (false);\n\n\t\tif (value === \"yep\")\n\t\t\treturn (true);\n\n\t\tif (value === \"nah\")\n\t\t\treturn (false);\n\n\t\treturn (false);\n\t}\n\n\t/**\n\t * Check if a required parameter exists inside an object. If it exists, return the value.\n\t */\n\tstatic getParam (name: string, objWithParam: any, required: boolean = true, throwException: boolean = true): any\n\t{\n\t\tlet value: any = objWithParam[name];\n\n\t\tif (value == null)\n\t\t{\n\t\t\tif (required === true)\n\t\t\t{\n\t\t\t\tif (throwException === true)\n\t\t\t\t\tthrow new Error (`Missing required parameter ${name}.`);\n\t\t\t}\n\t\t}\n\n\t\tif (typeof (value) === \"string\")\n\t\t{\n\t\t\tif (required === true)\n\t\t\t{\n\t\t\t\tif (value === \"\")\n\t\t\t\t{\n\t\t\t\t\tif (throwException === true)\n\t\t\t\t\t\tthrow new Error (`Missing required parameter ${name}.`);\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\n\t\treturn (value);\n\t}\n\n\t/**\n\t * Check if a required parameter exists inside an object. If it exists, return the value.\n\t * If it does not exist, return a default value instead.\n\t */\n\tstatic getParamDefault (name: string, objWithParam: any, defaultValue: any): any\n\t{\n\t\tlet value: any = objWithParam[name];\n\n\t\tif (value == null)\n\t\t\treturn (defaultValue);\n\n\t\tif (typeof (value) === \"string\")\n\t\t{\n\t\t\tif (value === \"\")\n\t\t\t\treturn (defaultValue);\n\t\t}\n\n\t\treturn (value);\n\t}\n\n\t/**\n\t * Execute an error. This cannot be an async function due to the nature of how this works.\n\t */\n\tstatic executeError (errType: string)\n\t{\n\t\tif (HotStaq.errors[errType] != null)\n\t\t{\n\t\t\tlet url: string = HotStaq.errors[errType].redirectToUrl;\n\n\t\t\tif (url != null)\n\t\t\t{\n\t\t\t\tif (url !== \"\")\n\t\t\t\t{\n\t\t\t\t\twindow.location.href = url;\n\n\t\t\t\t\treturn;\n\t\t\t\t}\n\t\t\t}\n\n\t\t\tlet func = HotStaq.errors[errType].func;\n\n\t\t\tif (func != null)\n\t\t\t\tfunc (errType);\n\t\t}\n\t}\n\n\t/**\n\t * Wait for a number of milliseconds.\n\t */\n\tstatic async wait (numMilliseconds: number): Promise<void>\n\t{\n\t\treturn (await new Promise ((resolve, reject) =>\n\t\t\t{\n\t\t\t\tsetTimeout (() =>\n\t\t\t\t\t{\n\t\t\t\t\t\tresolve ();\n\t\t\t\t\t}, numMilliseconds);\n\t\t\t}));\n\t}\n\n\t/**\n\t * Add a page.\n\t */\n\taddPage (page: HotPage): void\n\t{\n\t\tthis.pages[page.name] = page;\n\t}\n\n\t/**\n\t * Get a page to process.\n\t */\n\tgetPage (pageName: string): HotPage\n\t{\n\t\treturn (this.pages[pageName]);\n\t}\n\n\t/**\n\t * Add an imported module.\n\t */\n\taddModule (name: string, module: HotModule): void\n\t{\n\t\tthis.modules[name] = module;\n\t}\n\n\t/**\n\t * Get an imported module.\n\t */\n\tgetModule (name: string): HotModule\n\t{\n\t\treturn (this.modules[name]);\n\t}\n\n\t/**\n\t * Add a file.\n\t */\n\taddFile (file: HotFile): void\n\t{\n\t\tlet name: string = file.name;\n\n\t\tif (name === \"\")\n\t\t\tname = file.localFile;\n\n\t\tif (name === \"\")\n\t\t\tname = file.url;\n\n\t\tthis.files[name] = file;\n\t}\n\n\t/**\n\t * Get a file.\n\t */\n\tgetFile (name: string, throwEx: boolean = true): HotFile\n\t{\n\t\tif (this.files[name] == null)\n\t\t{\n\t\t\tlet pos: number = name.indexOf (\"?hstqserve=\");\n\t\t\tlet tempName: string = name;\n\n\t\t\tif (pos > -1)\n\t\t\t\ttempName = name.substring (0, pos);\n\n\t\t\tif (this.files[tempName] != null)\n\t\t\t\treturn (this.files[tempName]);\n\n\t\t\tif (throwEx === true)\n\t\t\t\tthrow new Error (`Unable to find file ${name}`);\n\n\t\t\treturn (null);\n\t\t}\n\n\t\treturn (this.files[name]);\n\t}\n\n\t/** \n\t * Keep the context the object is currently in.\n\t * \n\t * @param func The document element's id.\n\t * @param context The object to remain in context.\n\t * @param [val=undefined] An additional value to pass to the context.\n\t * @return The returned result from the function func.\n\t */\n\tstatic keepContext(func: Function, context: any, val?: any): any\n\t{\n\t\tvar objReturn = function()\n\t\t\t{\n\t\t\t\tvar aryArgs = Array.prototype.slice.call(arguments);\n\n\t\t\t\tif (val != undefined)\n\t\t\t\t\taryArgs.push(val);\n\n\t\t\t\tif (context == null)\n\t\t\t\t\treturn func.apply(this, aryArgs);\n\t\t\t\telse\n\t\t\t\t\treturn func.apply(context, aryArgs);\n\t\t\t};\n\n\t\treturn objReturn;\n\t}\n\n\t/**\n\t * Add and register a component.\n\t */\n\taddComponent (ComponentType: (new (copy: IHotComponent | HotStaq, api?: HotAPI) => HotComponent), api: HotAPI = null, \n\t\telementOptions: ElementDefinitionOptions = undefined): void\n\t{\n\t\tlet tempApi = this.api\n\n\t\tif (api != null)\n\t\t\ttempApi = api;\n\n\t\tlet tempComponentObj = new ComponentType (this, tempApi);\n\n\t\tif (this.components[tempComponentObj.tag] != null)\n\t\t\tthrow new Error (`Component ${tempComponentObj.tag} already exists!`);\n\n\t\tthis.components[tempComponentObj.tag] = { componentType: ComponentType, processor: this, api: tempApi };\n\t\tregisterComponent.call (this, tempComponentObj.tag, elementOptions);\n\t}\n\n\t/**\n\t * Correct any HTML prior to DOM parsing. This only accounts for <tr> currently.\n\t */\n\tstatic fixHTML (str: string): { fixedStr: string, querySelector: string; }\n\t{\n\t\t// Take into account the difference between XML and HTML.\n\t\tconst tempStr: string = str.replace(/ \\/>/g, '>').replace(\n\t\t\t/(<(area|base|br|col|command|embed|hr|img|input|keygen|link|meta|param|source|track|wbr).*?>)/g, '$1</$2>');\n\t\tconst parsedXML = new DOMParser ().parseFromString (`<xml>${tempStr}</xml>`, \"text/xml\");\n\t\tlet querySelector: string = \"\";\n\n\t\tif (parsedXML.documentElement.children.length > 0)\n\t\t{\n\t\t\tconst tagName: string = parsedXML.documentElement.children[0].tagName.toLowerCase ();\n\n\t\t\tif (tagName === \"tr\")\n\t\t\t{\n\t\t\t\tstr = `<table>${str}</table>`;\n\t\t\t\tquerySelector = \"tbody\";\n\t\t\t}\n\n\t\t\tif (tagName === \"th\")\n\t\t\t{\n\t\t\t\tstr = `<table>${str}</table>`;\n\t\t\t\tquerySelector = tagName;\n\t\t\t}\n\t\t}\n\n\t\treturn ({ fixedStr: str, querySelector: querySelector });\n\t}\n\n\t/**\n\t * Add a new HTML element(s) to the current document.\n\t */\n\tstatic addHtml (parent: string | HTMLElement, html: string | HTMLElement): HTMLElement | HTMLElement[]\n\t{\n\t\tlet foundParent: HTMLElement = null;\n\n\t\tif (typeof (parent) === \"string\")\n\t\t\tfoundParent = document.querySelector (parent);\n\t\telse\n\t\t\tfoundParent = parent;\n\n\t\tif (foundParent == null)\n\t\t\tthrow new Error (`Unable to find parent ${parent}!`);\n\n\t\tlet result: HTMLElement = null;\n\n\t\tif (typeof (html) === \"string\")\n\t\t{\n\t\t\tlet htmlHandler = HotStaq.fixHTML (html);\n\t\t\tlet newDOM: Document = new DOMParser ().parseFromString (htmlHandler.fixedStr, \"text/html\");\n\t\t\tlet children: any = null;\n\n\t\t\tif (htmlHandler.querySelector === \"\")\n\t\t\t\tchildren = newDOM.body.children;\n\t\t\telse\n\t\t\t\tchildren = newDOM.querySelector (htmlHandler.querySelector).children;\n\n\t\t\tlet results: HTMLElement[] = [];\n\n\t\t\tfor (let iIdx = 0; iIdx < children.length; iIdx++)\n\t\t\t{\n\t\t\t\tlet child: HTMLElement = (<HTMLElement>children[iIdx]);\n\n\t\t\t\tresults.push (foundParent.appendChild (child));\n\t\t\t}\n\n\t\t\treturn (results);\n\t\t}\n\t\telse\n\t\t\tresult = foundParent.appendChild (html);\n\n\t\treturn (result);\n\t}\n\n\t/**\n\t * Check if a HotSite's name is valid.\n\t */\n\tstatic checkHotSiteName (hotsiteName: string, throwException: boolean = false): boolean\n\t{\n\t\tlet results = validateModuleName (hotsiteName);\n\t\tlet isValid: boolean = true;\n\n\t\tif (results.validForNewPackages === false)\n\t\t\tisValid = false;\n\n\t\tif (results.errors != null)\n\t\t{\n\t\t\tif (results.errors.length > 0)\n\t\t\t\tisValid = false;\n\t\t}\n\n\t\tif (isValid === false)\n\t\t{\n\t\t\tif (throwException === true)\n\t\t\t\tthrow new Error (`HotSite ${hotsiteName} has an invalid name! The name cannot be empty and must have a valid NPM module name.`);\n\t\t}\n\n\t\treturn (isValid);\n\t}\n\n\t/**\n\t * In the supplied content, replace a key in a ${KEY} with a value.\n\t * \n\t * @returns The content with the correct values.\n\t */\n\tstatic replaceKey (content: string, key: string, value: string): string\n\t{\n\t\tconst finalStr: string = content.replace (new RegExp (`\\\\$\\\\{${key}\\\\}`, \"g\"), value);\n\n\t\treturn (finalStr);\n\t}\n\n\t/**\n\t * Get a value from a HotSite object.\n\t * \n\t * @returns Returns the value from the hotsite object. Returns null if it doesn't exist.\n\t */\n\tstatic getValueFromHotSiteObj (hotsite: HotSite, params: string[]): any\n\t{\n\t\tlet value: any = null;\n\n\t\tif (hotsite != null)\n\t\t{\n\t\t\tlet prevValue: any = hotsite;\n\n\t\t\t// Go through each object in the list of parameters and \n\t\t\t// get the value of the final parameter.\n\t\t\tfor (let iIdx = 0; iIdx < params.length; iIdx++)\n\t\t\t{\n\t\t\t\tlet param: string = params[iIdx];\n\n\t\t\t\tif (prevValue[param] == null)\n\t\t\t\t{\n\t\t\t\t\tprevValue = null;\n\n\t\t\t\t\tbreak;\n\t\t\t\t}\n\n\t\t\t\tprevValue = prevValue[param];\n\t\t\t}\n\n\t\t\tif (prevValue != null)\n\t\t\t\tvalue = prevValue;\n\t\t}\n\n\t\treturn (value);\n\t}\n\n\t/**\n\t * Process a HotSite.\n\t */\n\tasync processHotSite (tester: HotTester = null): Promise<void>\n\t{\n\t\tHotStaq.checkHotSiteName (this.hotSite.name, true);\n\n\t\tlet routes = this.hotSite.routes;\n\n\t\tif (routes != null)\n\t\t{\n\t\t\tfor (let key in routes)\n\t\t\t{\n\t\t\t\tlet route: HotSiteRoute = routes[key];\n\t\t\t\tlet file: HotFile = new HotFile (route);\n\t\t\t\tlet page: HotPage = new HotPage ({\n\t\t\t\t\t\tprocessor: this,\n\t\t\t\t\t\tname: route.name || \"\",\n\t\t\t\t\t\troute: key,\n\t\t\t\t\t\tfiles: [file]\n\t\t\t\t\t});\n\n\t\t\t\tif (tester != null)\n\t\t\t\t{\n\t\t\t\t\tif (this.mode === DeveloperMode.Development)\n\t\t\t\t\t{\n\t\t\t\t\t\tlet mapName: string = route.name;\n\t\t\t\t\t\tlet testMap: HotTestMap = null;\n\n\t\t\t\t\t\tif (route.map != null)\n\t\t\t\t\t\t{\n\t\t\t\t\t\t\tif (typeof (route.map) === \"string\")\n\t\t\t\t\t\t\t{\n\t\t\t\t\t\t\t\tif (tester.testMaps[route.map] == null)\n\t\t\t\t\t\t\t\t\tthrow new Error (`Test map ${route.map} does not exist!`);\n\n\t\t\t\t\t\t\t\ttester.testMaps[mapName] = tester.testMaps[route.map];\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\telse\n\t\t\t\t\t\t\t{\n\t\t\t\t\t\t\t\ttestMap = new HotTestMap ();\n\t\t\t\t\t\t\t\tlet destinations: HotTestDestination[] | { [name: string]: HotTestDestination } = null;\n\n\t\t\t\t\t\t\t\tif (route.map instanceof Array)\n\t\t\t\t\t\t\t\t{\n\t\t\t\t\t\t\t\t\tdestinations = [];\n\n\t\t\t\t\t\t\t\t\tfor (let iIdx = 0; iIdx < route.map.length; iIdx++)\n\t\t\t\t\t\t\t\t\t{\n\t\t\t\t\t\t\t\t\t\tlet dest = route.map[iIdx];\n\n\t\t\t\t\t\t\t\t\t\tdestinations.push (new HotTestDestination (dest));\n\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\telse\n\t\t\t\t\t\t\t\t{\n\t\t\t\t\t\t\t\t\tdestinations = {};\n\n\t\t\t\t\t\t\t\t\tfor (let key2 in route.map)\n\t\t\t\t\t\t\t\t\t{\n\t\t\t\t\t\t\t\t\t\tlet dest = route.map[key2];\n\n\t\t\t\t\t\t\t\t\t\tdestinations[key2] = new HotTestDestination (dest);\n\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t}\n\n\t\t\t\t\t\t\t\ttestMap.destinations = destinations;\n\t\t\t\t\t\t\t}\n\n\t\t\t\t\t\t\ttester.testMaps[mapName] = testMap;\n\t\t\t\t\t\t}\n\n\t\t\t\t\t\tif (route.destinationOrder != null)\n\t\t\t\t\t\t\ttester.testMaps[mapName].destinationOrder = route.destinationOrder;\n\t\t\t\t\t}\n\t\t\t\t}\n\n\t\t\t\tthis.addPage (page);\n\t\t\t}\n\t\t}\n\n\t\tif (this.hotSite.apis != null)\n\t\t{\n\t\t\tfor (let key in this.hotSite.apis)\n\t\t\t{\n\t\t\t\tlet api = this.hotSite.apis[key];\n\n\t\t\t\tif (api.map == null)\n\t\t\t\t\tcontinue;\n\n\t\t\t\tif (HotStaq.isWeb === false)\n\t\t\t\t{\n\t\t\t\t\tif (this.mode === DeveloperMode.Development)\n\t\t\t\t\t{\n\t\t\t\t\t\tlet mapName: string = key;\n\t\t\t\t\t\tlet testMap: HotTestMap = new HotTestMap ();\n\n\t\t\t\t\t\ttestMap.destinations = [];\n\n\t\t\t\t\t\tfor (let iIdx = 0; iIdx < api.map.length; iIdx++)\n\t\t\t\t\t\t{\n\t\t\t\t\t\t\tlet map: string = api.map[iIdx];\n\n\t\t\t\t\t\t\ttestMap.destinations.push (new HotTestDestination (map));\n\t\t\t\t\t\t}\n\n\t\t\t\t\t\tif (tester != null)\n\t\t\t\t\t\t\ttester.testMaps[mapName] = testMap;\n\t\t\t\t\t\telse\n\t\t\t\t\t\t\tthis.logger.warning (\"A tester was not created first! You must specify one in the CLI.\");\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\n\t\t/// @fixme Allow this to work for server-side as well...\n\t\tif (HotStaq.isWeb === true)\n\t\t{\n\t\t\tfor (let key in this.hotSite.components)\n\t\t\t{\n\t\t\t\tlet component = this.hotSite.components[key];\n\t\t\t\tlet componentUrl: string = component.url;\n\n\t\t\t\t/// @fixme Create unit test for fetching, loading, and registering.\n\t\t\t\tlet res: any = await fetch (componentUrl);\n\t\t\t\tlet ComponentClass = eval (res);\n\n\t\t\t\tthis.addComponent (ComponentClass);\n\t\t\t}\n\t\t}\n\n\t\tif (this.hotSite.routes == null)\n\t\t\tthis.hotSite.routes = {};\n\n\t\tlet disableFileLoading: boolean = false;\n\n\t\tif (this.hotSite.disableFileLoading != null)\n\t\t\tdisableFileLoading = this.hotSite.disableFileLoading;\n\n\t\tif (disableFileLoading === false)\n\t\t\tawait this.loadHotFiles (this.hotSite.files, false, false);\n\t\telse\n\t\t\tthis.logger.verbose (`Hotsite has file loading disabled...`);\n\n\t\tif (tester != null)\n\t\t\tthis.addTester (tester);\n\n\t\tthis.logger.verbose (`Processed HotSite ${this.hotSite.name}`);\n\t}\n\n\t/**\n\t * Load from a HotSite.json file. Be sure to load and attach any testers before \n\t * loading a HotSite.\n\t */\n\tasync loadHotSite (path: string): Promise<void>\n\t{\n\t\tlet jsonStr: string = \"\";\n\t\tconst ext: string = ppath.extname (path).toLowerCase ();\n\n\t\tif (HotStaq.isWeb === true)\n\t\t{\n\t\t\tthis.logger.verbose (`Downloading HotSite ${path}`);\n\n\t\t\tlet res: any = await fetch (path);\n\n\t\t\tthis.logger.verbose (`Downloaded site ${path}`);\n\n\t\t\tjsonStr = res.text ();\n\t\t}\n\t\telse\n\t\t{\n\t\t\tpath = ppath.normalize (path);\n\n\t\t\tthis.logger.verbose (`Accessing HotSite ${path}`);\n\n\t\t\tlet HotIO = eval (\"require\")(\"./HotIO\").HotIO; // Hack to get around Webpack.\n\t\t\tjsonStr = await HotIO.readTextFile (path);\n\t\t\tthis.logger.verbose (`Accessed site ${path}`);\n\t\t}\n\n\t\tif ((ext === \".yaml\") || (ext === \".yml\"))\n\t\t{\n\t\t\tif (HotStaq.isWeb === true)\n\t\t\t\tthrow new Error (`YAML support for HotSites is not available on the web yet!`);\n\n\t\t\tlet yaml = eval (\"require\")(\"yaml\"); // Hack to get around Webpack.\n\t\t\tthis.hotSite = yaml.parse (jsonStr);\n\t\t}\n\t\telse\n\t\t\tthis.hotSite = JSON.parse (jsonStr);\n\n\t\tif (this.hotSite == null)\n\t\t\tthrow new Error (`HotSite ${path} cannot be null!`);\n\n\t\tthis.hotSite.hotsitePath = path;\n\t}\n\n\t/**\n\t * Save the current HotSite to a file.\n\t */\n\tasync saveHotSite (path: string): Promise<void>\n\t{\n\t\tif (HotStaq.isWeb === true)\n\t\t\tthrow new Error (`Cannot save a HotSite on the web!`);\n\n\t\tconst hotsiteStr: string = JSON.stringify (this.hotSite, null, 2);\n\n\t\tlet HotIO = eval (\"require\")(\"./HotIO\").HotIO; // Hack to get around Webpack.\n\t\tawait HotIO.writeTextFile (path, hotsiteStr);\n\t\tthis.logger.verbose (`Saved site ${path}`);\n\t}\n\n\t/**\n\t * Load an array of files. If a file already has content, it will not be reloaded \n\t * unless forceContentLoading is set to true.\n\t */\n\tasync loadHotFiles (files: { [name: string]: { url?: string; localFile?: string; content?: string; } }, \n\t\t\tforceContentLoading: boolean = false, loadUrlContent: boolean = true): Promise<void>\n\t{\n\t\tthis.logger.verbose (`Loading Hott files...`);\n\n\t\tfor (let key in files)\n\t\t{\n\t\t\tlet file = files[key];\n\t\t\tlet newFile: HotFile = null;\n\n\t\t\tif (HotStaq.isWeb === true)\n\t\t\t{\n\t\t\t\tnewFile = new HotFile ({\n\t\t\t\t\t\t\"name\": key\n\t\t\t\t\t});\n\t\t\t}\n\t\t\telse\n\t\t\t{\n\t\t\t\tnewFile = new HotFile ({\n\t\t\t\t\t\t\"name\": key\n\t\t\t\t\t});\n\t\t\t}\n\n\t\t\tif (file.url != null)\n\t\t\t{\n\t\t\t\tif (HotStaq.isWeb === true)\n\t\t\t\t\tnewFile.url = `${file.url}?hstqserve=nahfam`;\n\t\t\t\telse\n\t\t\t\t\tnewFile.url = file.url;\n\t\t\t}\n\n\t\t\tif (HotStaq.isWeb === false)\n\t\t\t{\n\t\t\t\tif (file.localFile != null)\n\t\t\t\t\tnewFile.localFile = file.localFile;\n\t\t\t}\n\n\t\t\tlet loadContent: boolean = true;\n\n\t\t\tif (file.content != null)\n\t\t\t{\n\t\t\t\tnewFile.content = file.content;\n\t\t\t\tloadContent = false;\n\t\t\t}\n\n\t\t\tif (forceContentLoading === true)\n\t\t\t\tloadContent = true;\n\n\t\t\tif (loadUrlContent === false)\n\t\t\t{\n\t\t\t\tif (newFile.url !== \"\")\n\t\t\t\t\tloadContent = false;\n\t\t\t}\n\n\t\t\tif (loadContent === true)\n\t\t\t{\n\t\t\t\tthis.logger.verbose (`Loading Hott file: ${newFile.url}`);\n\t\t\t\tawait newFile.load ();\n\t\t\t\tthis.logger.verbose (`Finished loading Hott file: ${newFile.url}`);\n\t\t\t}\n\n\t\t\tthis.addFile (newFile);\n\t\t}\n\n\t\tthis.logger.verbose (`Finished loading Hott files...`);\n\t}\n\n\t/**\n\t * Generate the content to send to a client.\n\t */\n\tasync generateContent (routeKey: string, name: string = \"\", url: string = \"./\",\n\t\t\tjsSrcPath: string = \"./js/HotStaq.min.js\", passArgs: boolean = true, \n\t\t\targs: any = null): Promise<string>\n\t{\n\t\tlet apiScripts: string = \"\";\n\t\tlet apiCode: string = \"\";\n\t\tlet publicKeys: string = \"\";\n\n\t\t/// @todo Optimize this function as much as possible.\n\n\t\t// Load the API string.\n\t\tif (this.hotSite != null)\n\t\t{\n\t\t\tif (this.hotSite.server.globalApi != null)\n\t\t\t{\n\t\t\t\tif (this.hotSite.server.globalApi !== \"\")\n\t\t\t\t{\n\t\t\t\t\tconst globalApi = this.hotSite.apis[this.hotSite.server.globalApi];\n\n\t\t\t\t\tif (globalApi == null)\n\t\t\t\t\t\tthis.logger.warning (`API with name ${this.hotSite.server.globalApi} doesn't exist!`);\n\t\t\t\t\telse\n\t\t\t\t\t{\n\t\t\t\t\t\tlet sendJSContent: boolean = true;\n\n\t\t\t\t\t\tif (globalApi.jsapi == null)\n\t\t\t\t\t\t{\n\t\t\t\t\t\t\tsendJSContent = false;\n\t\t\t\t\t\t\tthis.logger.warning (`API with name ${this.hotSite.server.globalApi} doesn't have a jsapi set. Will not send js content to client.`);\n\t\t\t\t\t\t}\n\n\t\t\t\t\t\tif (globalApi.libraryName == null)\n\t\t\t\t\t\t{\n\t\t\t\t\t\t\tsendJSContent = false;\n\t\t\t\t\t\t\tthis.logger.warning (`API with name ${this.hotSite.server.globalApi} doesn't have a libraryName set. Will not send js content to client.`);\n\t\t\t\t\t\t}\n\n\t\t\t\t\t\tif (globalApi.apiName == null)\n\t\t\t\t\t\t{\n\t\t\t\t\t\t\tsendJSContent = false;\n\t\t\t\t\t\t\tthis.logger.warning (`API with name ${this.hotSite.server.globalApi} doesn't have a apiName set. Will not send js content to client.`);\n\t\t\t\t\t\t}\n\n\t\t\t\t\t\tif (sendJSContent === true)\n\t\t\t\t\t\t{\n\t\t\t\t\t\t\tapiScripts += `\\t<script type = \"text/javascript\" src = \"${globalApi.jsapi}\"></script>\\n`;\n\n\t\t\t\t\t\t\tlet baseUrl: string = \"\\\"\\\"\";\n\n\t\t\t\t\t\t\tif (globalApi.url != null)\n\t\t\t\t\t\t\t\tbaseUrl = `\\\"${globalApi.url}\\\"`;\n\n\t\t\t\t\t\t\tif (this.api != null)\n\t\t\t\t\t\t\t\tbaseUrl = `\\\"${this.api.baseUrl}\\\"`;\n\n\t\t\t\t\t\t\tlet tempAPIContent: string = this.apiContent;\n\t\t\t\t\t\t\ttempAPIContent = tempAPIContent.replace (/\\%api\\_name\\%/g, globalApi.apiName);\n\t\t\t\t\t\t\ttempAPIContent = tempAPIContent.replace (/\\%api\\_exported\\_name\\%/g, globalApi.libraryName);\n\t\t\t\t\t\t\ttempAPIContent = tempAPIContent.replace (/\\%base\\_url\\%/g, baseUrl);\n\n\t\t\t\t\t\t\tapiCode += tempAPIContent;\n\t\t\t\t\t\t}\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t}\n\n\t\t\tif (this.hotSite.apis != null)\n\t\t\t{\n\t\t\t\tlet route = this.hotSite.routes[routeKey];\n\n\t\t\t\tif (route != null)\n\t\t\t\t{\n\t\t\t\t\tif (route.api != null)\n\t\t\t\t\t{\n\t\t\t\t\t\tlet api = this.hotSite.apis[route.api];\n\n\t\t\t\t\t\tif (api == null)\n\t\t\t\t\t\t\tthrow new Error (`Unable to find API ${route.api}`);\n\n\t\t\t\t\t\tif (route.api !== this.hotSite.server.globalApi)\n\t\t\t\t\t\t{\n\t\t\t\t\t\t\tlet sendJSContent: boolean = true;\n\n\t\t\t\t\t\t\tif (api.jsapi == null)\n\t\t\t\t\t\t\t{\n\t\t\t\t\t\t\t\tsendJSContent = false;\n\t\t\t\t\t\t\t\tthis.logger.warning (`API with name ${route.api} doesn't have a jsapi set. Will not send js content to client.`);\n\t\t\t\t\t\t\t}\n\n\t\t\t\t\t\t\tif (api.libraryName == null)\n\t\t\t\t\t\t\t{\n\t\t\t\t\t\t\t\tsendJSContent = false;\n\t\t\t\t\t\t\t\tthis.logger.warning (`API with name ${route.api} doesn't have a libraryName set. Will not send js content to client.`);\n\t\t\t\t\t\t\t}\n\n\t\t\t\t\t\t\tif (api.apiName == null)\n\t\t\t\t\t\t\t{\n\t\t\t\t\t\t\t\tsendJSContent = false;\n\t\t\t\t\t\t\t\tthis.logger.warning (`API with name ${route.api} doesn't have a apiName set. Will not send js content to client.`);\n\t\t\t\t\t\t\t}\n\n\t\t\t\t\t\t\tif (sendJSContent === true)\n\t\t\t\t\t\t\t{\n\t\t\t\t\t\t\t\tlet jsapipath = api.jsapi;\n\t\t\t\t\t\t\t\tapiScripts += `\\t<script type = \"text/javascript\" src = \"${jsapipath}\"></script>\\n`;\n\n\t\t\t\t\t\t\t\tlet baseUrl: string = \"\\\"\\\"\";\n\n\t\t\t\t\t\t\t\tif (api.url != null)\n\t\t\t\t\t\t\t\t\tbaseUrl = `\\\"${api.url}\\\"`;\n\n\t\t\t\t\t\t\t\tif (this.api != null)\n\t\t\t\t\t\t\t\t\tbaseUrl = `\\\"${this.api.baseUrl}\\\"`;\n\n\t\t\t\t\t\t\t\tlet tempAPIContent: string = this.apiContent;\n\t\t\t\t\t\t\t\ttempAPIContent = tempAPIContent.replace (/\\%api\\_name\\%/g, api.apiName);\n\t\t\t\t\t\t\t\ttempAPIContent = tempAPIContent.replace (/\\%api\\_exported\\_name\\%/g, api.libraryName);\n\t\t\t\t\t\t\t\ttempAPIContent = tempAPIContent.replace (/\\%base\\_url\\%/g, baseUrl);\n\n\t\t\t\t\t\t\t\tapiCode += tempAPIContent;\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t}\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t}\n\n\t\t\tif (this.hotSite.server != null)\n\t\t\t{\n\t\t\t\tif (this.hotSite.server.jsSrcPath != null)\n\t\t\t\t\tjsSrcPath = this.hotSite.server.jsSrcPath;\n\t\t\t}\n\n\t\t\tif (this.hotSite.publicKeys != null)\n\t\t\t{\n\t\t\t\tfor (let key in this.hotSite.publicKeys)\n\t\t\t\t{\n\t\t\t\t\tlet secret = this.hotSite.publicKeys[key];\n\t\t\t\t\tlet value: string = undefined;\n\n\t\t\t\t\tif (typeof (secret) === \"string\")\n\t\t\t\t\t\tvalue = JSON.stringify (secret);\n\t\t\t\t\telse\n\t\t\t\t\t{\n\t\t\t\t\t\tif (HotStaq.isWeb === false)\n\t\t\t\t\t\t{\n\t\t\t\t\t\t\tif (this.api != null)\n\t\t\t\t\t\t\t{\n\t\t\t\t\t\t\t\tif (this.api.connection == null)\n\t\t\t\t\t\t\t\t\tthrow new Error (`Cannot pass secrets from the API if there's no connection!`);\n\n\t\t\t\t\t\t\t\tlet serverConn: HotServer = (<HotServer>this.api.connection);\n\n\t\t\t\t\t\t\t\tif (secret.passSecretFromAPI != null)\n\t\t\t\t\t\t\t\t\tvalue = JSON.stringify (serverConn.secrets[key]);\n\t\t\t\t\t\t\t}\n\n\t\t\t\t\t\t\tif (secret.env != null)\n\t\t\t\t\t\t\t{\n\t\t\t\t\t\t\t\t/// @fixme @secvul Is this a security vulnerability? Need to verify that \n\t\t\t\t\t\t\t\t/// only the server has access to this. At this point, I think only the \n\t\t\t\t\t\t\t\t/// server has access.\n\t\t\t\t\t\t\t\tconst envKey: string = secret.env;\n\n\t\t\t\t\t\t\t\tvalue = JSON.stringify (process.env[envKey]);\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t}\n\t\t\t\t\t}\n\n\t\t\t\t\tpublicKeys += `processor.publicKeys[\"${key}\"] = ${value};\\n`;\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\n\t\tlet content: string = this.pageContent;\n\t\tlet fixContent = async (tempContent: string) =>\n\t\t\t{\n\t\t\t\tlet developerModeStr: string = \"\";\n\t\t\t\tlet testerAPIStr: string = \"\";\n\n\t\t\t\tif (this.mode === DeveloperMode.Development)\n\t\t\t\t{\n\t\t\t\t\tdeveloperModeStr = `tempMode = HotStaqWeb.DeveloperMode.Development;`;\n\n\t\t\t\t\tif (this.hotSite != null)\n\t\t\t\t\t{\n\t\t\t\t\t\tif (this.hotSite.testing != null)\n\t\t\t\t\t\t{\n\t\t\t\t\t\t\tif (this.hotSite.testing.web != null)\n\t\t\t\t\t\t\t{\n\t\t\t\t\t\t\t\ttesterAPIStr = this.testerApiContent;\n\n\t\t\t\t\t\t\t\tif (this.hotSite.testing.web.testerAPIUrl == null)\n\t\t\t\t\t\t\t\t\tthis.hotSite.testing.web.testerAPIUrl = \"http://127.0.0.1:8182\";\n\n\t\t\t\t\t\t\t\ttesterAPIStr = testerAPIStr.replace (/\\%base\\_tester\\_url\\%/g, `\\\"${this.hotSite.testing.web.testerAPIUrl}\\\"`);\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t}\n\t\t\t\t\t}\n\t\t\t\t}\n\n\t\t\t\tlet loadFiles: string = \"\";\n\n\t\t\t\tif (Object.keys (this.files).length > 0)\n\t\t\t\t{\n\t\t\t\t\tloadFiles += `var files = {};\\n\\n`;\n\n\t\t\t\t\tfor (let key in this.files)\n\t\t\t\t\t{\n\t\t\t\t\t\tlet file = this.files[key];\n\t\t\t\t\t\tlet asset: HotAsset = new HotAsset (\"html\", key);\n\n\t\t\t\t\t\tif (file.localFile !== \"\")\n\t\t\t\t\t\t\tasset.path = file.localFile;\n\n\t\t\t\t\t\tif (file.url !== \"\")\n\t\t\t\t\t\t\tasset.path = file.url;\n\n\t\t\t\t\t\tif (file.content !== \"\")\n\t\t\t\t\t\t{\n\t\t\t\t\t\t\tasset.path = \"\";\n\t\t\t\t\t\t\tasset.content = file.content;\n\t\t\t\t\t\t}\n\n\t\t\t\t\t\tlet output = await asset.output ();\n\n\t\t\t\t\t\tif (typeof (output) === \"string\")\n\t\t\t\t\t\t\tthrow new Error (`During initial load, HTML assets cannot be outputted using only a string!`);\n\n\t\t\t\t\t\tlet fileUrl: string = \"\";\n\t\t\t\t\t\tlet fileContent: string = \"\";\n\n\t\t\t\t\t\tif (output.url != null)\n\t\t\t\t\t\t\tfileUrl = `\"url\": \"${output.url}\", `;\n\n\t\t\t\t\t\tif (output.content != null)\n\t\t\t\t\t\t\tfileContent = `\"content\": ${output.content}`; // May have to escape the content?\n\n\t\t\t\t\t\tloadFiles += `\\t\\t\\tfiles[\"${output.name}\"] = { ${fileUrl}${fileContent} };\\n`;\n\t\t\t\t\t}\n\n\t\t\t\t\tloadFiles += `\\t\\t\\tpromises.push (processor.loadHotFiles (files));\\n`;\n\t\t\t\t}\n\n\t\t\t\ttempContent = tempContent.replace (/\\%title\\%/g, name);\n\n\t\t\t\tif (passArgs === true)\n\t\t\t\t\ttempContent = tempContent.replace (/\\%args\\%/g, \"Hot.Arguments\");\n\n\t\t\t\tif (args != null)\n\t\t\t\t\ttempContent = tempContent.replace (/\\%args\\%/g, JSON.stringify (args));\n\n\t\t\t\tlet testerMap: string = routeKey;\n\t\t\t\tlet testerUrl: string = \"\";\n\t\t\t\tlet testerLaunchpadUrl: string = \"\";\n\t\t\t\tlet testerName: string = \"HotTesterMochaSelenium\";\n\n\t\t\t\tfor (let key in this.testers)\n\t\t\t\t{\n\t\t\t\t\ttesterName = key;\n\t\t\t\t\tbreak;\n\t\t\t\t}\n\n\t\t\t\tif (this.hotSite != null)\n\t\t\t\t{\n\t\t\t\t\tif (this.hotSite.testing != null)\n\t\t\t\t\t{\n\t\t\t\t\t\tif (this.hotSite.testing.web != null)\n\t\t\t\t\t\t{\n\t\t\t\t\t\t\tif (this.hotSite.testing.web.testerName != null)\n\t\t\t\t\t\t\t\ttesterName = this.hotSite.testing.web.testerName;\n\n\t\t\t\t\t\t\tif (this.hotSite.testing.web.testerAPIUrl != null)\n\t\t\t\t\t\t\t\ttesterUrl = this.hotSite.testing.web.testerAPIUrl;\n\n\t\t\t\t\t\t\tif (this.hotSite.testing.web.launchpadUrl != null)\n\t\t\t\t\t\t\t\ttesterLaunchpadUrl = this.hotSite.testing.web.launchpadUrl;\n\t\t\t\t\t\t}\n\t\t\t\t\t}\n\n\t\t\t\t\tif (this.hotSite.routes != null)\n\t\t\t\t\t{\n\t\t\t\t\t\tif (this.hotSite.routes[routeKey] != null)\n\t\t\t\t\t\t{\n\t\t\t\t\t\t\tlet route = this.hotSite.routes[routeKey];\n\t\t\t\t\t\t\ttesterMap = route.name;\n\t\t\t\t\t\t}\n\t\t\t\t\t}\n\t\t\t\t}\n\n\t\t\t\tlet startDelayStr: string = \"\";\n\n\t\t\t\tif (this.startDelay !== 0)\n\t\t\t\t\tstartDelayStr = `await HotStaq.wait (${this.startDelay});`;\n\n\t\t\t\ttempContent = tempContent.replace (/\\%start\\_delay\\%/g, startDelayStr);\n\t\t\t\ttempContent = tempContent.replace (/\\%logging\\_level\\%/g, `HotLogLevel.${HotLogLevel[this.logger.logLevel]}`);\n\t\t\t\ttempContent = tempContent.replace (/\\%hotstaq\\_js\\_src\\%/g, jsSrcPath);\n\t\t\t\ttempContent = tempContent.replace (/\\%developer\\_mode\\%/g, developerModeStr);\n\t\t\t\ttempContent = tempContent.replace (/\\%tester\\_api\\%/g, testerAPIStr);\n\t\t\t\ttempContent = tempContent.replace (/\\%apis\\_to\\_load\\%/g, apiScripts);\n\t\t\t\ttempContent = tempContent.replace (/\\%load\\_files\\%/g, loadFiles);\n\t\t\t\ttempContent = tempContent.replace (/\\%api\\_code\\%/g, apiCode);\n\t\t\t\ttempContent = tempContent.replace (/\\%public\\_secrets\\%/g, publicKeys);\n\t\t\t\ttempContent = tempContent.replace (/\\%url\\%/g, url);\n\t\t\t\ttempContent = tempContent.replace (/\\%tester\\_name\\%/g, `\"${testerName}\"`);\n\t\t\t\ttempContent = tempContent.replace (/\\%tester\\_map\\%/g, `\"${testerMap}\"`);\n\t\t\t\ttempContent = tempContent.replace (/\\%tester\\_api\\_base\\_url\\%/g, `\"${testerUrl}\"`);\n\t\t\t\ttempContent = tempContent.replace (/\\%tester\\_launchpad\\_url\\%/g, `\"${testerLaunchpadUrl}\"`);\n\n\t\t\t\treturn (tempContent);\n\t\t\t};\n\t\tcontent = await fixContent (content);\n\n\t\treturn (content);\n\t}\n\n\t/**\n\t * Create the Express routes from the given pages. Be sure to load the \n\t * pages first before doing this. This method is meant to be used for \n\t * customized Express applications. If you wish to use the loaded routes \n\t * from this HotStaq object with HotHTTPServer, be sure to use \n\t * the loadHotSite method in HotHTTPServer.\n\t */\n\tasync createExpressRoutes (expressApp: any, jsSrcPath: string = \"./js/HotStaq.min.js\"): Promise<void>\n\t{\n\t\tfor (let key in this.pages)\n\t\t{\n\t\t\tlet page: HotPage = this.pages[key];\n\t\t\tconst content: string = await this.generateContent (page.route, page.name, page.files[0].url, jsSrcPath);\n\n\t\t\texpressApp.get (page.route, (req: any, res: any) =>\n\t\t\t\t{\n\t\t\t\t\tthis.logger.verbose (`Sending custom Express content.`);\n\t\t\t\t\tres.status (200).send (content);\n\t\t\t\t});\n\t\t}\n\t}\n\n\t/**\n\t * Add a tester for use later.\n\t */\n\taddTester (tester: HotTester): void\n\t{\n\t\tthis.testers[tester.name] = tester;\n\t}\n\n\t/**\n\t * Get the list of maps for testing from the HotSite.\n\t */\n\tgetWebTestingMaps (): string[]\n\t{\n\t\tif (this.hotSite == null)\n\t\t\tthrow new Error (\"No HotSite was loaded!\");\n\n\t\tif (this.hotSite.testing == null)\n\t\t\tthrow new Error (\"The HotSite does not have a testing object!\");\n\n\t\tif (this.hotSite.testing.web == null)\n\t\t\tthrow new Error (\"The HotSite does not have a testing web object!\");\n\n\t\tif (this.hotSite.testing.web.maps == null)\n\t\t\tthrow new Error (\"The HotSite testing object does not have any maps!\");\n\n\t\treturn (this.hotSite.testing.web.maps);\n\t}\n\n\t/**\n\t * Get the list of maps for testing from the HotSite.\n\t */\n\tgetAPITestingMaps (): string[]\n\t{\n\t\tif (this.hotSite == null)\n\t\t\tthrow new Error (\"No HotSite was loaded!\");\n\n\t\tif (this.hotSite.testing == null)\n\t\t\tthrow new Error (\"The HotSite does not have a testing object!\");\n\n\t\tif (this.hotSite.testing.api == null)\n\t\t\tthrow new Error (\"The HotSite does not have a testing api object!\");\n\n\t\tif (this.hotSite.testing.api.maps == null)\n\t\t\tthrow new Error (\"The HotSite testing object does not have any maps!\");\n\n\t\treturn (this.hotSite.testing.api.maps);\n\t}\n\n\t/**\n\t * Get a route's key from a route's name.\n\t */\n\tgetRouteKeyFromName (name: string): string\n\t{\n\t\tlet foundKey: string = \"\";\n\n\t\tif (this.hotSite != null)\n\t\t{\n\t\t\tif (this.hotSite.routes != null)\n\t\t\t{\n\t\t\t\tfor (let key in this.hotSite.routes)\n\t\t\t\t{\n\t\t\t\t\tlet route: HotSiteRoute = this.hotSite.routes[key];\n\n\t\t\t\t\tif (route.name === name)\n\t\t\t\t\t{\n\t\t\t\t\t\tfoundKey = key;\n\n\t\t\t\t\t\tbreak;\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\n\t\treturn (foundKey);\n\t}\n\n\t/**\n\t * Get a route from a route's name.\n\t */\n\tgetRouteFromName (name: string): HotSiteRoute\n\t{\n\t\tlet foundRoute: HotSiteRoute = null;\n\t\tlet foundKey: string = this.getRouteKeyFromName (name);\n\n\t\tif (foundKey !== \"\")\n\t\t\tfoundRoute = this.hotSite.routes[foundKey];\n\n\t\treturn (foundRoute);\n\t}\n\n\t/**\n\t * Execute tests.\n\t * \n\t * @param testerName The tester to use to execute tests.\n\t * @param mapName The map or maps to use to navigate through tests.\n\t */\n\tasync executeTests (testerName: string, mapName: string): Promise<void>\n\t{\n\t\tlet tester: HotTester = this.testers[testerName];\n\n\t\tif (tester == null)\n\t\t\tthrow new Error (`Unable to execute tests. Tester ${testerName} does not exist!`);\n\n\t\treturn (tester.execute (mapName));\n\t}\n\n\t/**\n\t * Execute all web tests from the HotSite testing web object.\n\t * \n\t * @param testerName The tester to use to execute tests.\n\t */\n\tasync executeAllWebTests (testerName: string): Promise<void>\n\t{\n\t\tlet maps: string[] = this.getWebTestingMaps ();\n\t\tlet tester: HotTester = this.testers[testerName];\n\n\t\tif (tester == null)\n\t\t\tthrow new Error (`Unable to execute tests. Tester ${testerName} does not exist!`);\n\n\t\tfor (let iIdx = 0; iIdx < maps.length; iIdx++)\n\t\t{\n\t\t\tlet mapName: string = maps[iIdx];\n\n\t\t\tawait this.executeTests (testerName, mapName);\n\t\t}\n\t}\n\n\t/**\n\t * Execute all api tests from the HotSite testing api object.\n\t * \n\t * @param testerName The tester to use to execute tests.\n\t */\n\tasync executeAllAPITests (testerName: string): Promise<void>\n\t{\n\t\tlet maps: string[] = this.getAPITestingMaps ();\n\t\tlet tester: HotTester = this.testers[testerName];\n\n\t\tif (tester == null)\n\t\t\tthrow new Error (`Unable to execute tests. Tester ${testerName} does not exist!`);\n\n\t\tthis.logger.verbose (() => `Executing all API tests for tester ${testerName}. Maps: ${JSON.stringify (maps)}`);\n\n\t\tfor (let iIdx = 0; iIdx < maps.length; iIdx++)\n\t\t{\n\t\t\tlet mapName: string = maps[iIdx];\n\n\t\t\tawait this.executeTests (testerName, mapName);\n\t\t}\n\t}\n\n\t/**\n\t * Process a page and get the result.\n\t */\n\tasync process (pageName: string, args: any = null): Promise<string>\n\t{\n\t\tlet page: HotPage = this.getPage (pageName);\n\t\tlet result: string = await page.process (args);\n\n\t\treturn (result);\n\t}\n\n\t/**\n\t * Process a local file and get the result.\n\t */\n\tstatic async processLocalFile (localFilepath: string, name: string = localFilepath, args: any = null): Promise<string>\n\t{\n\t\tlet processor: HotStaq = new HotStaq ();\n\t\tlet file: HotFile = new HotFile ({\n\t\t\t\"localFile\": localFilepath\n\t\t});\n\t\tawait file.load ();\n\t\tlet page: HotPage = new HotPage ({\n\t\t\t\t\"processor\": processor,\n\t\t\t\t\"name\": name,\n\t\t\t\t\"files\": [file]\n\t\t\t});\n\t\tprocessor.addPage (page);\n\t\tlet result: string = await processor.process (name, args);\n\n\t\treturn (result);\n\t}\n\n\t/**\n\t * Process a url and get the result.\n\t */\n\tstatic async processUrl (options: HotStartOptions): Promise<string>\n\t{\n\t\tlet file: HotFile = new HotFile ({\n\t\t\t\"url\": options.url\n\t\t});\n\n\t\tawait file.load ();\n\t\tlet page: HotPage = new HotPage ({\n\t\t\t\t\"processor\": options.processor,\n\t\t\t\t\"name\": options.name,\n\t\t\t\t\"files\": [file],\n\t\t\t\t\"testerName\": options.testerName,\n\t\t\t\t\"testerMap\": options.testerMap\n\t\t\t});\n\t\toptions.processor.addPage (page);\n\t\tlet result: string = await options.processor.process (options.name, options.args);\n\n\t\treturn (result);\n\t}\n\n\t/**\n\t * Process content and get the result.\n\t */\n\tstatic async processContent (options: HotStartOptions): Promise<string>\n\t{\n\t\tlet file: HotFile = new HotFile ({\n\t\t\t\"content\": options.content\n\t\t});\n\t\tawait file.load ();\n\t\tlet page: HotPage = new HotPage ({\n\t\t\t\t\"processor\": options.processor,\n\t\t\t\t\"name\": options.name,\n\t\t\t\t\"files\": [file]\n\t\t\t});\n\t\toptions.processor.addPage (page);\n\t\tlet result: string = await options.processor.process (options.name, options.args);\n\n\t\treturn (result);\n\t}\n\n\t/**\n\t * When the window has finished loading, execute the function.\n\t * This is meant for web browser use only.\n\t */\n\tstatic onReady (readyFunc: () => void): void\n\t{\n\t\tif ((document.readyState === \"complete\") || (document.readyState === \"interactive\"))\n\t\t\treadyFunc ();\n\t\telse\n\t\t\twindow.addEventListener (\"load\", readyFunc);\n\t}\n\n\t/**\n\t * Replace the current HTML page with the output.\n\t * This is meant for web browser use only.\n\t */\n\tstatic async useOutput (output: string): Promise<void>\n\t{\n\t\tlet parser = new DOMParser ();\n\t\tlet child = parser.parseFromString (output, \"text/html\");\n\t\tlet htmlObj: HTMLHtmlElement = document.getElementsByTagName('html')[0];\n\n\t\thtmlObj.innerHTML = child.getElementsByTagName('html')[0].innerHTML;\n\n\t\t// Thanks to newfurniturey at: \n\t\t// https://stackoverflow.com/questions/22945884/domparser-appending-script-tags-to-head-body-but-not-executing\n\t\tlet tmpScripts = document.getElementsByTagName('script');\n\t\tif (tmpScripts.length > 0) {\n\t\t\t// push all of the document's script tags into an array\n\t\t\t// (to prevent dom manipulation while iterating over dom nodes)\n\t\t\tlet scripts: HTMLScriptElement[] = [];\n\t\t\tfor (let i = 0; i < tmpScripts.length; i++) {\n\t\t\t\tscripts.push(tmpScripts[i]);\n\t\t\t}\n\n\t\t\t// iterate over all script tags and create duplicate tags for each\n\t\t\tfor (let i = 0; i < scripts.length; i++) {\n\t\t\t\tlet s: HTMLScriptElement = document.createElement('script');\n\n\t\t\t\t// add the new node to the page\n\t\t\t\tscripts[i].parentNode.appendChild(s);\n\n\t\t\t\t// remove the original (non-executing) node from the page\n\t\t\t\tscripts[i].parentNode.removeChild(scripts[i]);\n\n\t\t\t\tawait new Promise<void> ((resolve2, reject2) =>\n\t\t\t\t\t{\n\t\t\t\t\t\ts.onload = () =>\n\t\t\t\t\t\t\t{\n\t\t\t\t\t\t\t\tresolve2 ();\n\t\t\t\t\t\t\t};\n\n\t\t\t\t\t\tlet hasSrc: boolean = false;\n\n\t\t\t\t\t\tif (scripts[i].getAttribute (\"src\") != null)\n\t\t\t\t\t\t{\n\t\t\t\t\t\t\tif (scripts[i].getAttribute (\"src\") !== \"\")\n\t\t\t\t\t\t\t{\n\t\t\t\t\t\t\t\ts.setAttribute (\"src\", scripts[i].getAttribute (\"src\"));\n\t\t\t\t\t\t\t\thasSrc = true;\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t}\n\n\t\t\t\t\t\tif (scripts[i].getAttribute (\"type\") != null)\n\t\t\t\t\t\t{\n\t\t\t\t\t\t\tif (scripts[i].getAttribute (\"type\") !== \"\")\n\t\t\t\t\t\t\t\ts.setAttribute (\"type\", scripts[i].getAttribute (\"type\"));\n\t\t\t\t\t\t}\n\n\t\t\t\t\t\ts.innerHTML = scripts[i].innerHTML;\n\n\t\t\t\t\t\tif (hasSrc === false)\n\t\t\t\t\t\t\tresolve2 ();\n\t\t\t\t\t});\n\t\t\t}\n\t\t}\n\t}\n\n\t/**\n\t * Wait for testers to load.\n\t * \n\t * @fixme This does not wait for ALL testers to finish loading. Only \n\t * the first one.\n\t */\n\tstatic async waitForTesters (): Promise<void>\n\t{\n\t\twhile (HotStaq.isReadyForTesting === false)\n\t\t\tawait HotStaq.wait (10);\n\n\t\tif (HotStaq.onReadyForTesting != null)\n\t\t\tawait HotStaq.onReadyForTesting ();\n\t}\n\n\t/**\n\t * Setup the testers api, if any.\n\t */\n\tstatic setupTesters (processor: HotStaq, options: HotStartOptions)\n\t{\n\t\tif (processor.mode === DeveloperMode.Development)\n\t\t{\n\t\t\tif (processor.testerAPI == null)\n\t\t\t{\n\t\t\t\tif (options.testerAPIBaseUrl == null)\n\t\t\t\t\toptions.testerAPIBaseUrl = \"\";\n\n\t\t\t\tif (options.testerAPIBaseUrl === \"\")\n\t\t\t\t\toptions.testerAPIBaseUrl = \"http://127.0.0.1:8182\";\n\n\t\t\t\tlet client: HotClient = new HotClient (processor);\n\t\t\t\tlet testerAPI: HotTesterAPI = new HotTesterAPI (options.testerAPIBaseUrl, client);\n\t\t\t\ttesterAPI.connection.api = testerAPI;\n\t\t\t\tprocessor.testerAPI = testerAPI;\n\t\t\t}\n\t\t}\n\t}\n\n\t/**\n\t * Setup the testers api on the client, if needed.\n\t */\n\tstatic setupClientTesters (processor: HotStaq): string\n\t{\n\t\tlet output: string = \"\";\n\n\t\tif (processor.mode === DeveloperMode.Development)\n\t\t{\n\t\t\toutput += \n`<script type = \"text/javascript\">\nfunction hotstaq_isDocumentReady ()\n{\nif (window[\"Hot\"] != null)\n{\nif (Hot.Mode === HotStaqWeb.DeveloperMode.Development)\n{\nlet func = function ()\n\t{\n\t\tif (Hot.TesterAPI != null)\n\t\t{\n\t\t\tlet testPaths = {};\n\t\t\tlet testElements = JSON.stringify (Hot.CurrentPage.testElements);\n\t\t\tlet testMaps = JSON.stringify (Hot.CurrentPage.testMaps);\n\n\t\t\tfor (let key in Hot.CurrentPage.testPaths)\n\t\t\t{\n\t\t\t\tlet testPath = Hot.CurrentPage.testPaths[key];\n\n\t\t\t\ttestPaths[key] = testPath.toString ();\n\t\t\t}\n\n\t\t\tlet testPathsStr = JSON.stringify (testPaths);\n\n\t\t\tHot.TesterAPI.tester.pageLoaded ({\n\t\t\t\t\ttesterName: Hot.CurrentPage.testerName,\n\t\t\t\t\ttesterMap: Hot.CurrentPage.testerMap,\n\t\t\t\t\tpageName: Hot.CurrentPage.name,\n\t\t\t\t\ttestElements: testElements,\n\t\t\t\t\ttestPaths: testPathsStr\n\t\t\t\t}).then (function (resp)\n\t\t\t\t\t{\n\t\t\t\t\t\tif (resp.error != null)\n\t\t\t\t\t\t{\n\t\t\t\t\t\t\tif (resp.error !== \"\")\n\t\t\t\t\t\t\t\tthrow new Error (resp.error);\n\t\t\t\t\t\t}\n\n\t\t\t\t\t\tHotStaqWeb.HotStaq.isReadyForTesting = true;\n\t\t\t\t\t});\n\t\t}\n\t};\n\nif ((document.readyState === \"complete\") || (document.readyState === \"interactive\"))\n\tfunc ();\nelse\n\tdocument.addEventListener (\"DOMContentLoaded\", func);\n}\n}\n}\n\nhotstaq_isDocumentReady ();\n</script>`;\n\t\t}\n\n\t\treturn (output);\n\t}\n\n\t/**\n\t * Process and replace the current HTML page with the hott script from the given url.\n\t * This is meant for web browser use only.\n\t */\n\tstatic async displayUrl (url: string | HotStartOptions, name: string = null, \n\t\tprocessor: HotStaq = null, args: any = null): Promise<HotStaq>\n\t{\n\t\treturn (new Promise<HotStaq> ((resolve, reject) =>\n\t\t\t{\n\t\t\t\tHotStaq.onReady (async () =>\n\t\t\t\t\t{\n\t\t\t\t\t\tlet options: HotStartOptions = {\n\t\t\t\t\t\t\t\t\"url\": \"\"\n\t\t\t\t\t\t\t};\n\n\t\t\t\t\t\tif (name == null)\n\t\t\t\t\t\t{\n\t\t\t\t\t\t\tif (typeof (url) === \"string\")\n\t\t\t\t\t\t\t\toptions.name = url;\n\t\t\t\t\t\t\telse\n\t\t\t\t\t\t\t\toptions.name = url.name;\n\t\t\t\t\t\t}\n\t\t\t\t\t\telse\n\t\t\t\t\t\t\toptions.name = name;\n\n\t\t\t\t\t\tif (options.name === \"\")\n\t\t\t\t\t\t{\n\t\t\t\t\t\t\tif (typeof (url) === \"string\")\n\t\t\t\t\t\t\t\toptions.name = url;\n\t\t\t\t\t\t\telse\n\t\t\t\t\t\t\t\toptions.name = url.name;\n\t\t\t\t\t\t}\n\n\t\t\t\t\t\tif (typeof (url) === \"string\")\n\t\t\t\t\t\t\toptions.url = url;\n\t\t\t\t\t\telse\n\t\t\t\t\t\t{\n\t\t\t\t\t\t\toptions.url = url.url;\n\n\t\t\t\t\t\t\tif (processor == null)\n\t\t\t\t\t\t\t{\n\t\t\t\t\t\t\t\tif (url.processor != null)\n\t\t\t\t\t\t\t\t\tprocessor = url.processor;\n\t\t\t\t\t\t\t}\n\n\t\t\t\t\t\t\tif (args == null)\n\t\t\t\t\t\t\t{\n\t\t\t\t\t\t\t\tif (url.args != null)\n\t\t\t\t\t\t\t\t\targs = url.args;\n\t\t\t\t\t\t\t}\n\n\t\t\t\t\t\t\tif (url.testerMap != null)\n\t\t\t\t\t\t\t\toptions.testerMap = url.testerMap;\n\n\t\t\t\t\t\t\tif (url.testerName != null)\n\t\t\t\t\t\t\t\toptions.testerName = url.testerName;\n\n\t\t\t\t\t\t\tif (url.testerAPIBaseUrl != null)\n\t\t\t\t\t\t\t\toptions.testerAPIBaseUrl = url.testerAPIBaseUrl;\n\t\t\t\t\t\t}\n\n\t\t\t\t\t\tif (processor == null)\n\t\t\t\t\t\t\tprocessor = new HotStaq ();\n\n\t\t\t\t\t\tHotStaq.setupTesters (processor, options);\n\n\t\t\t\t\t\toptions.processor = processor;\n\t\t\t\t\t\toptions.args = args;\n\n\t\t\t\t\t\tif (options.url.indexOf (\"hstqserve\") < 0)\n\t\t\t\t\t\t\toptions.url += \"?hstqserve=nahfam\";\n\n\t\t\t\t\t\tlet output: string = await HotStaq.processUrl (options);\n\n\t\t\t\t\t\toutput += HotStaq.setupClientTesters (processor);\n\n\t\t\t\t\t\tawait HotStaq.useOutput (output);\n\t\t\t\t\t\tresolve (processor);\n\t\t\t\t\t});\n\t\t\t}));\n\t}\n\n\t/**\n\t * Process and replace the current HTML page with the hott script.\n\t * This is meant for web browser use only.\n\t */\n\tstatic async displayContent (content: string | HotStartOptions, name: string = null, \n\t\t\tprocessor: HotStaq = null, args: any = null): Promise<HotStaq>\n\t{\n\t\treturn (new Promise<HotStaq> ((resolve, reject) =>\n\t\t\t{\n\t\t\t\tHotStaq.onReady (async () =>\n\t\t\t\t\t{\n\t\t\t\t\t\tlet options: HotStartOptions = {\n\t\t\t\t\t\t\t\t\"content\": \"\"\n\t\t\t\t\t\t\t};\n\n\t\t\t\t\t\tif (name == null)\n\t\t\t\t\t\t{\n\t\t\t\t\t\t\tif (typeof (content) === \"string\")\n\t\t\t\t\t\t\t\toptions.name = \"\";\n\t\t\t\t\t\t\telse\n\t\t\t\t\t\t\t\toptions.name = content.name;\n\t\t\t\t\t\t}\n\t\t\t\t\t\telse\n\t\t\t\t\t\t\toptions.name = name;\n\n\t\t\t\t\t\tif (options.name === \"\")\n\t\t\t\t\t\t{\n\t\t\t\t\t\t\tif (typeof (content) === \"string\")\n\t\t\t\t\t\t\t\toptions.name = \"\"; /// @fixme Is this ok to do?\n\t\t\t\t\t\t\telse\n\t\t\t\t\t\t\t\toptions.name = content.name;\n\t\t\t\t\t\t}\n\n\t\t\t\t\t\tif (typeof (content) === \"string\")\n\t\t\t\t\t\t\toptions.content = content;\n\t\t\t\t\t\telse\n\t\t\t\t\t\t{\n\t\t\t\t\t\t\toptions.content = content.content;\n\n\t\t\t\t\t\t\tif (processor == null)\n\t\t\t\t\t\t\t{\n\t\t\t\t\t\t\t\tif (content.processor != null)\n\t\t\t\t\t\t\t\t\tprocessor = content.processor;\n\t\t\t\t\t\t\t}\n\n\t\t\t\t\t\t\tif (args == null)\n\t\t\t\t\t\t\t{\n\t\t\t\t\t\t\t\tif (content.args != null)\n\t\t\t\t\t\t\t\t\targs = content.args;\n\t\t\t\t\t\t\t}\n\n\t\t\t\t\t\t\tif (content.testerMap != null)\n\t\t\t\t\t\t\t\toptions.testerMap = content.testerMap;\n\n\t\t\t\t\t\t\tif (content.testerName != null)\n\t\t\t\t\t\t\t\toptions.testerName = content.testerName;\n\n\t\t\t\t\t\t\tif (content.testerAPIBaseUrl != null)\n\t\t\t\t\t\t\t\toptions.testerAPIBaseUrl = content.testerAPIBaseUrl;\n\t\t\t\t\t\t}\n\n\t\t\t\t\t\tif (processor == null)\n\t\t\t\t\t\t\tprocessor = new HotStaq ();\n\n\t\t\t\t\t\tHotStaq.setupTesters (processor, options);\n\n\t\t\t\t\t\toptions.processor = processor;\n\t\t\t\t\t\toptions.args = args;\n\n\t\t\t\t\t\tlet output: string = await HotStaq.processContent (options);\n\n\t\t\t\t\t\tawait HotStaq.useOutput (output);\n\t\t\t\t\t\tresolve (processor);\n\t\t\t\t\t});\n\t\t\t}));\n\t}\n}\n\nif (typeof (document) !== \"undefined\")\n\twindow.addEventListener (\"load\", hotStaqWebStart);\n","import { HotFile } from \"./HotFile\";\nimport { HotComponent, HotComponentOutput } from \"./HotComponent\";\nimport { HotStaq } from \"./HotStaq\";\nimport { Hot } from \"./Hot\";\n\n/**\n * Register a component for use as a HTML tag.\n */\nexport function registerComponent (tag: string, elementOptions: ElementDefinitionOptions = undefined): void\n{\n\tif ((tag == null) || (tag === \"\"))\n\t\tthrow new Error (`All components must have a tag!`);\n\n\tif (customElements.get (tag) !== undefined)\n\t{\n\t\t/// @fixme This element has already been defined. Should this throw an error or warning? I don't think it should...\n\n\t\treturn;\n\t}\n\n\tlet processorComponents = this.components;\n\n\tcustomElements.define (tag, class extends HTMLElement\n\t\t{\n\t\t\t/**\n\t\t\t * The connected HotComponent.\n\t\t\t */\n\t\t\tcomponent: HotComponent;\n\t\t\n\t\t\tconstructor ()\n\t\t\t{\n\t\t\t\tsuper ();\n\n\t\t\t\tlet componentInfo = processorComponents[tag];\n\t\t\t\tthis.component = new componentInfo.componentType (componentInfo.processor, componentInfo.api);\n\n\t\t\t\tlet compHtmlElement = this;\n\t\t\n\t\t\t\t// @ts-ignore\n\t\t\t\tcompHtmlElement.hotComponent = this.component;\n\t\t\n\t\t\t\tthis.component.htmlElements = [compHtmlElement];\n\t\t\t\tthis.component.inner = this.innerHTML;\n\t\t\n\t\t\t\tif (this.component.handleAttributes != null)\n\t\t\t\t\tthis.component.handleAttributes (this.attributes);\n\t\t\t\telse\n\t\t\t\t{\n\t\t\t\t\tfor (let iIdx = 0; iIdx < this.attributes.length; iIdx++)\n\t\t\t\t\t{\n\t\t\t\t\t\tconst attr: Attr = this.attributes[iIdx];\n\t\t\t\t\t\tconst attrName: string = attr.name.toLowerCase ();\n\t\t\t\t\t\tconst attrValue: string = attr.value;\n\t\t\n\t\t\t\t\t\tif (attrName === \"id\")\n\t\t\t\t\t\t\tthis.component.name = attrValue;\n\t\t\n\t\t\t\t\t\tif (attrName === \"name\")\n\t\t\t\t\t\t\tthis.component.name = attrValue;\n\t\t\n\t\t\t\t\t\tif (attrName === \"value\")\n\t\t\t\t\t\t\tthis.component.value = attrValue;\n\t\t\n\t\t\t\t\t\tif (attrName.indexOf (\"hot-\") > -1)\n\t\t\t\t\t\t{\n\t\t\t\t\t\t\tconst attrTempName: string = attrName.substring (4);\n\t\t\n\t\t\t\t\t\t\t/// @ts-ignore\n\t\t\t\t\t\t\tthis.component[attrTempName] = attrValue;\n\t\t\t\t\t\t}\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\n\t\t\t\tif (this.component.onPreOutput != null)\n\t\t\t\t{\n\t\t\t\t\tif (this.component.onPreOutput () === false)\n\t\t\t\t\t\treturn;\n\t\t\t\t}\n\n\t\t\t\tlet outputs = this.component.output ();\n\t\t\n\t\t\t\tif (this.component.onPostOutput != null)\n\t\t\t\t\toutputs = this.component.onPostOutput (outputs);\n\t\t\n\t\t\t\tlet componentOutputs: HotComponentOutput[] = [];\n\t\t\n\t\t\t\tif (typeof (outputs) === \"string\")\n\t\t\t\t\tcomponentOutputs.push ({ html: outputs });\n\t\t\t\telse\n\t\t\t\t{\n\t\t\t\t\tif (outputs instanceof Array)\n\t\t\t\t\t\tcomponentOutputs = outputs;\n\t\t\t\t\telse\n\t\t\t\t\t\tcomponentOutputs = [outputs];\n\t\t\t\t}\n\t\t\n\t\t\t\tfor (let iKdx = 0; iKdx < componentOutputs.length; iKdx++)\n\t\t\t\t{\n\t\t\t\t\tlet output = componentOutputs[iKdx];\n\t\t\t\t\tlet htmlStr: string = output.html;\n\t\t\t\t\tlet addFunctionsTo: string = \"\";\n\t\t\n\t\t\t\t\tif (output.addFunctionsTo != null)\n\t\t\t\t\t\taddFunctionsTo = output.addFunctionsTo;\n\t\t\n\t\t\t\t\tlet str: string = HotFile.parseContent (htmlStr, true, { \"outputCommands\": false });\n\t\t\n\t\t\t\t\tif (this.component.onParsed != null)\n\t\t\t\t\t\tstr = this.component.onParsed (str);\n\t\t\n\t\t\t\t\tlet htmlHandler: { fixedStr: string, querySelector: string; } = { fixedStr: \"\", querySelector: \"\" };\n\t\t\n\t\t\t\t\tif (this.component.onFixHTML != null)\n\t\t\t\t\t\thtmlHandler = this.component.onFixHTML (str);\n\t\t\t\t\telse\n\t\t\t\t\t\thtmlHandler = HotStaq.fixHTML (str);\n\n\t\t\t\t\tlet childrenToReadd: Node[] = [];\n\t\t\n\t\t\t\t\t// Save the children from being replaced.\n\t\t\t\t\tfor (let iIdx = (this.children.length - 1); iIdx > -1; iIdx--)\n\t\t\t\t\t{\n\t\t\t\t\t\tlet child: Node = this.children[iIdx];\n\t\t\n\t\t\t\t\t\tchildrenToReadd.push (this.removeChild (child));\n\t\t\t\t\t}\n\t\t\n\t\t\t\t\tlet newDOM: Document = null;\n\t\t\t\t\tlet newObj: HTMLElement = null;\n\t\t\n\t\t\t\t\tif (this.component.onParseDOM != null)\n\t\t\t\t\t\tnewDOM = this.component.onParseDOM (htmlHandler.fixedStr);\n\t\t\t\t\telse\n\t\t\t\t\t{\n\t\t\t\t\t\t/// @ts-ignore\n\t\t\t\t\t\t//newDOM = this.looseParseFromString (new DOMParser (), str);\n\t\t\t\t\t\tnewDOM = new DOMParser ().parseFromString (htmlHandler.fixedStr, \"text/html\");\n\t\t\t\t\t}\n\n\t\t\t\t\tif (newDOM.body.children.length < 1)\n\t\t\t\t\t\tthrow new Error (`No component output from ${this.component.name} with tag ${this.component.tag}`);\n\n\t\t\t\t\tif (newDOM.body.children.length > 1)\n\t\t\t\t\t{\n\t\t\t\t\t\tlet throwErr: boolean = true;\n\t\t\n\t\t\t\t\t\tfor (let iIdx = 0; iIdx < newDOM.body.children.length; iIdx++)\n\t\t\t\t\t\t{\n\t\t\t\t\t\t\tlet child = newDOM.body.children[iIdx];\n\t\t\n\t\t\t\t\t\t\tif (child instanceof HTMLElement)\n\t\t\t\t\t\t\t{\n\t\t\t\t\t\t\t\tif (child.tagName.toLowerCase () === \"parsererror\")\n\t\t\t\t\t\t\t\t{\n\t\t\t\t\t\t\t\t\tnewObj = child;\n\t\t\t\t\t\t\t\t\tthrowErr = false;\n\t\t\n\t\t\t\t\t\t\t\t\tbreak;\n\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t}\n\t\t\n\t\t\t\t\t\tif (throwErr === true)\n\t\t\t\t\t\t\tthrow new Error (`Only a single html element can come from component ${this.component.name}, multiple elements were detected.`);\n\t\t\t\t\t}\n\n\t\t\t\t\tif (htmlHandler.querySelector === \"\")\n\t\t\t\t\t\tnewObj = (<HTMLElement>newDOM.body.children[0]);\n\t\t\t\t\telse\n\t\t\t\t\t\tnewObj = newDOM.querySelector (htmlHandler.querySelector);\n\t\t\n\t\t\t\t\tthis.replaceWith (newObj);\n\t\t\n\t\t\t\t\tif (this.component.click != null)\n\t\t\t\t\t\tnewObj.addEventListener (\"click\", this.component.click.bind (this.component));\n\t\t\n\t\t\t\t\tfor (let key in this.component.events)\n\t\t\t\t\t{\n\t\t\t\t\t\tlet event = this.component.events[key];\n\t\t\n\t\t\t\t\t\t// @ts-ignore\n\t\t\t\t\t\tnewObj.addEventListener (event.type, event.func, event.options);\n\t\t\t\t\t}\n\t\t\n\t\t\t\t\tlet objectFunctions: string[] = Object.getOwnPropertyNames (this.component.constructor.prototype);\n\t\t\n\t\t\t\t\t// Associate any functions to the newly created element.\n\t\t\t\t\tfor (let iIdx = 0; iIdx < objectFunctions.length; iIdx++)\n\t\t\t\t\t{\n\t\t\t\t\t\tlet objFunc: string = objectFunctions[iIdx];\n\t\t\n\t\t\t\t\t\tif (objFunc === \"constructor\")\n\t\t\t\t\t\t\tcontinue;\n\t\t\n\t\t\t\t\t\t// @ts-ignore\n\t\t\t\t\t\tlet prop = this.component[objFunc];\n\t\t\n\t\t\t\t\t\tif (typeof (prop) === \"function\")\n\t\t\t\t\t\t{\n\t\t\t\t\t\t\tlet isNewFunction: boolean = true;\n\t\t\n\t\t\t\t\t\t\t// Go through each function in the base HotComponent and see \n\t\t\t\t\t\t\t// if there's any matches. If there's a match, that means \n\t\t\t\t\t\t\t// we're trying to add an existing function, and we don't\n\t\t\t\t\t\t\t// wanna do that. Skip it.\n\t\t\t\t\t\t\tfor (let key2 in HotComponent.prototype)\n\t\t\t\t\t\t\t{\n\t\t\t\t\t\t\t\tif (objFunc === key2)\n\t\t\t\t\t\t\t\t{\n\t\t\t\t\t\t\t\t\tisNewFunction = false;\n\t\t\n\t\t\t\t\t\t\t\t\tbreak;\n\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t}\n\n\t\t\t\t\t\t\tif (isNewFunction === true)\n\t\t\t\t\t\t\t{\n\t\t\t\t\t\t\t\t// @ts-ignore\n\t\t\t\t\t\t\t\tnewObj[objFunc] = HotStaq.keepContext (this.component[objFunc], this.component);\n\n\t\t\t\t\t\t\t\tif (addFunctionsTo !== \"\")\n\t\t\t\t\t\t\t\t{\n\t\t\t\t\t\t\t\t\tlet query: HTMLElement = document.querySelector (addFunctionsTo);\n\t\t\n\t\t\t\t\t\t\t\t\t// @ts-ignore\n\t\t\t\t\t\t\t\t\tquery[objFunc] = HotStaq.keepContext (this.component[objFunc], this.component);\n\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t}\n\t\t\t\t\t}\n\t\t\n\t\t\t\t\tif (this.component.onPrePlace != null)\n\t\t\t\t\t\tnewObj = this.component.onPrePlace (newObj);\n\t\t\n\t\t\t\t\tlet compHtmlElement2: HTMLElement = this.component.onCreated (newObj);\n\t\t\n\t\t\t\t\tif (this.component.onParentPlace != null)\n\t\t\t\t\t{\n\t\t\t\t\t\t// @ts-ignore\n\t\t\t\t\t\tcompHtmlElement2.onParentPlace = this.component.onParentPlace;\n\t\t\t\t\t}\n\t\t\n\t\t\t\t\t// @ts-ignore\n\t\t\t\t\tcompHtmlElement2.hotComponent = this.component;\n\t\t\t\t\tthis.component.htmlElements.push (compHtmlElement2);\n\t\t\n\t\t\t\t\tif (output.closestSelector != null)\n\t\t\t\t\t{\n\t\t\t\t\t\tlet parentElm: HTMLElement = compHtmlElement2;\n\n\t\t\t\t\t\twhile (parentElm)\n\t\t\t\t\t\t{\n\t\t\t\t\t\t\tlet foundNode: Node = parentElm.querySelector (output.closestSelector);\n\n\t\t\t\t\t\t\tif (foundNode != null)\n\t\t\t\t\t\t\t{\n\t\t\t\t\t\t\t\tparentElm = (<HTMLElement>foundNode);\n\t\t\t\t\t\t\t\tbreak;\n\t\t\t\t\t\t\t}\n\n\t\t\t\t\t\t\tparentElm = parentElm.parentElement;\n\t\t\t\t\t\t}\n\n\t\t\t\t\t\tif (parentElm == null)\n\t\t\t\t\t\t\tthrow new Error (`Unable to find closest node with selector '${output.closestSelector}'`);\n\t\t\n\t\t\t\t\t\tcompHtmlElement2.parentElement.removeChild (compHtmlElement2);\n\t\t\t\t\t\tparentElm.appendChild (compHtmlElement2);\n\t\t\n\t\t\t\t\t\t// @ts-ignore\n\t\t\t\t\t\tif (compHtmlElement2.onParentPlace != null)\n\t\t\t\t\t\t{\n\t\t\t\t\t\t\t// @ts-ignore\n\t\t\t\t\t\t\tcompHtmlElement2.hotComponent.onParentPlace (parentNode, compHtmlElement2);\n\t\t\t\t\t\t}\n\t\t\t\t\t}\n\t\t\n\t\t\t\t\tif (output.documentSelector != null)\n\t\t\t\t\t{\n\t\t\t\t\t\tlet parentNode: Node = document.querySelector (output.documentSelector);\n\n\t\t\t\t\t\tif (parentNode == null)\n\t\t\t\t\t\t\tthrow new Error (`Unable to find document node with selector '${output.documentSelector}'`);\n\t\t\n\t\t\t\t\t\tcompHtmlElement2.parentElement.removeChild (compHtmlElement2);\n\t\t\t\t\t\tparentNode.appendChild (compHtmlElement2);\n\t\t\n\t\t\t\t\t\t// @ts-ignore\n\t\t\t\t\t\tif (compHtmlElement2.onParentPlace != null)\n\t\t\t\t\t\t{\n\t\t\t\t\t\t\t// @ts-ignore\n\t\t\t\t\t\t\tcompHtmlElement2.hotComponent.onParentPlace (parentNode, compHtmlElement2);\n\t\t\t\t\t\t}\n\t\t\t\t\t}\n\n\t\t\t\t\tlet placeElmInParent = (parentNodeToCheck: ParentNode, placeHereParent: string, childToPlace: Node): ParentNode =>\n\t\t\t\t\t{\n\t\t\t\t\t\tlet parentNodeCheckCounter: number = 0;\n\t\t\n\t\t\t\t\t\twhile (parentNodeCheckCounter < 10) /// @todo Make this controllable with a variable from the component.\n\t\t\t\t\t\t{\n\t\t\t\t\t\t\tif (parentNodeToCheck == null)\n\t\t\t\t\t\t\t\tbreak;\n\t\t\n\t\t\t\t\t\t\tif (parentNodeToCheck instanceof HTMLHtmlElement)\n\t\t\t\t\t\t\t\tbreak;\n\t\t\n\t\t\t\t\t\t\t// If the hot-place-here exists, place the children there. If not, place it under the \n\t\t\t\t\t\t\t// new element.\n\t\t\t\t\t\t\tlet placeHereArray = parentNodeToCheck.querySelectorAll (`hot-place-here[name=\"${placeHereParent}\"]`);\n\t\t\n\t\t\t\t\t\t\tif (placeHereArray.length > 0)\n\t\t\t\t\t\t\t{\n\t\t\t\t\t\t\t\tlet placeHere = placeHereArray[0];\n\t\t\n\t\t\t\t\t\t\t\tif (childToPlace.parentNode != null)\n\t\t\t\t\t\t\t\t\tchildToPlace.parentNode.removeChild (childToPlace);\n\n\t\t\t\t\t\t\t\tplaceHere.appendChild (childToPlace);\n\t\t\n\t\t\t\t\t\t\t\t// @ts-ignore\n\t\t\t\t\t\t\t\tif (childToPlace.onParentPlace != null)\n\t\t\t\t\t\t\t\t{\n\t\t\t\t\t\t\t\t\t// @ts-ignore\n\t\t\t\t\t\t\t\t\tchildToPlace.hotComponent.onParentPlace (placeHere, childToPlace);\n\t\t\t\t\t\t\t\t}\n\t\t\n\t\t\t\t\t\t\t\tbreak;\n\t\t\t\t\t\t\t}\n\t\t\n\t\t\t\t\t\t\tif (placeHereArray.length < 1)\n\t\t\t\t\t\t\t{\n\t\t\t\t\t\t\t\tlet placeHereAttrArray = parentNodeToCheck.querySelectorAll (`[hot-place-here=\"${placeHereParent}\"]`);\n\t\t\n\t\t\t\t\t\t\t\tif (placeHereAttrArray.length > 0)\n\t\t\t\t\t\t\t\t{\n\t\t\t\t\t\t\t\t\tlet placeHere = placeHereAttrArray[0];\n\n\t\t\t\t\t\t\t\t\tif (childToPlace.parentNode != null)\n\t\t\t\t\t\t\t\t\t\tchildToPlace.parentNode.removeChild (childToPlace);\n\n\t\t\t\t\t\t\t\t\tplaceHere.appendChild (childToPlace);\n\t\t\n\t\t\t\t\t\t\t\t\t// @ts-ignore\n\t\t\t\t\t\t\t\t\tif (childToPlace.onParentPlace != null)\n\t\t\t\t\t\t\t\t\t{\n\t\t\t\t\t\t\t\t\t\t// @ts-ignore\n\t\t\t\t\t\t\t\t\t\tchildToPlace.hotComponent.onParentPlace (placeHere, childToPlace);\n\t\t\t\t\t\t\t\t\t}\n\t\t\n\t\t\t\t\t\t\t\t\tbreak;\n\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t}\n\t\t\n\t\t\t\t\t\t\tparentNodeToCheck = parentNodeToCheck.parentNode;\n\t\t\t\t\t\t\tparentNodeCheckCounter++;\n\t\t\t\t\t\t}\n\n\t\t\t\t\t\treturn (parentNodeToCheck);\n\t\t\t\t\t};\n\t\t\n\t\t\t\t\tif (output.placeHereParent != null)\n\t\t\t\t\t{\n\t\t\t\t\t\tlet parentNodeToCheck = compHtmlElement2.parentNode;\n\t\t\t\t\t\tparentNodeToCheck = placeElmInParent (parentNodeToCheck, output.placeHereParent, compHtmlElement2);\n\n\t\t\t\t\t\tif (parentNodeToCheck == null)\n\t\t\t\t\t\t\tthrow new Error (`Unable to find parent node with hot-place-here attribute '${output.placeHereParent}'`);\n\t\t\t\t\t}\n\t\t\n\t\t\t\t\t// Append the children to the newly created HTML element.\n\t\t\t\t\tfor (let iIdx = 0; iIdx < childrenToReadd.length; iIdx++)\n\t\t\t\t\t{\n\t\t\t\t\t\tconst child: HTMLElement = (<HTMLElement>childrenToReadd[iIdx]);\n\t\t\t\t\t\tlet placedChild: boolean = false;\n\n\t\t\t\t\t\t// Get the attribute hot-place-parent in child.\n\t\t\t\t\t\tif (typeof (child.getAttribute) !== \"undefined\")\n\t\t\t\t\t\t{\n\t\t\t\t\t\t\tlet placeHereParentAttr = child.getAttribute (\"hot-place-parent\");\n\n\t\t\t\t\t\t\tif ((placeHereParentAttr != null) && (placeHereParentAttr !== \"\"))\n\t\t\t\t\t\t\t{\n\t\t\t\t\t\t\t\tlet parentNodeToCheck: ParentNode = compHtmlElement2;\n\t\t\t\t\t\t\t\tparentNodeToCheck = placeElmInParent (parentNodeToCheck, placeHereParentAttr, child);\n\t\t\n\t\t\t\t\t\t\t\tif (parentNodeToCheck == null)\n\t\t\t\t\t\t\t\t\tthrow new Error (`Unable to find parent node with hot-place-here attribute '${output.placeHereParent}'`);\n\t\t\t\t\t\t\t\telse\n\t\t\t\t\t\t\t\t\tplacedChild = true;\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t}\n\t\t\n\t\t\t\t\t\tif (placedChild === false)\n\t\t\t\t\t\t\tcompHtmlElement2.appendChild (child);\n\n\t\t\t\t\t\t// @ts-ignore\n\t\t\t\t\t\tif (child.onParentPlace != null)\n\t\t\t\t\t\t{\n\t\t\t\t\t\t\t// @ts-ignore\n\t\t\t\t\t\t\tchild.hotComponent.onParentPlace (compHtmlElement2, child);\n\t\t\t\t\t\t}\n\t\t\t\t\t}\n\t\t\n\t\t\t\t\tif (this.component.onPostPlace != null)\n\t\t\t\t\t{\n\t\t\t\t\t\tlet temp: HTMLElement = this.component.onPostPlace (compHtmlElement2.parentElement, compHtmlElement2);\n\n\t\t\t\t\t\tif (temp != null)\n\t\t\t\t\t\t\tcompHtmlElement2 = temp;\n\t\t\t\t\t}\n\n\t\t\t\t\tif (typeof (Hot) !== \"undefined\")\n\t\t\t\t\t{\n\t\t\t\t\t\tif (Hot.CurrentPage != null)\n\t\t\t\t\t\t{\n\t\t\t\t\t\t\tlet componentName: string = \"\";\n\n\t\t\t\t\t\t\tif (this.component.name != null)\n\t\t\t\t\t\t\t\tcomponentName = this.component.name;\n\n\t\t\t\t\t\t\tif ((componentName == null) || (componentName === \"\"))\n\t\t\t\t\t\t\t\tcomponentName = this.id;\n\n\t\t\t\t\t\t\tif (componentName !== \"\")\n\t\t\t\t\t\t\t\tHot.CurrentPage.components[componentName] = this.component;\n\t\t\t\t\t\t}\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t}\n\t\t\n\t\t\t/**\n\t\t\t * This helps parse <tr> and other tags that do not have a parent.\n\t\t\t * \n\t\t\t * Thanks Brandon McConnell!\n\t\t\t * \n\t\t\t * From: https://stackoverflow.com/questions/67313479/make-parsefromstring-parse-without-validation\n\t\t\t * \n\t\t\t * @todo May remove this as it does not seem to work well in a lot of edge cases.\n\t\t\t */\n\t\t\tprotected looseParseFromString (parser: DOMParser, str: string) {\n\t\t\t\tstr = str.replace(/ \\/>/g, '>').replace(/(<(area|base|br|col|command|embed|hr|img|input|keygen|link|meta|param|source|track|wbr).*?>)/g, '$1</$2>');\n\t\t\t\tconst xdom = parser.parseFromString('<xml>'+str+'</xml>', 'text/xml');\n\t\t\t\tconst hdom = parser.parseFromString('', 'text/html');\n\t\t\t\tfor (let elem of Array.from(xdom.documentElement.children)) {\n\t\t\t\t\t/// @ts-ignore\n\t\t\t\t\thdom.body.appendChild(elem);\n\t\t\t\t}\n\t\t\t\tfor (let elem of Array.from(hdom.querySelectorAll('area,base,br,col,command,embed,hr,img,input,keygen,link,meta,param,source,track,wbr'))) {\n\t\t\t\t\t/// @ts-ignore\n\t\t\t\t\telem.outerHTML = '<'+elem.outerHTML.slice(1).split('<')[0];\n\t\t\t\t}\n\t\t\t\treturn hdom;\n\t\t\t}\n\n\t\t\tget observedAttributes(): string[] /// @fixme Does this REALLY have to be static? Awful if it does...\n\t\t\t{\n\t\t\t\treturn (this.component.observedAttributes);\n\t\t\t}\n\t\t}, elementOptions);\n}","import { Hot } from \"./Hot\";\nimport { HotClient } from \"./HotClient\";\nimport { HotLog } from \"./HotLog\";\nimport { HotStaq, HotStartOptions } from \"./HotStaq\";\n\n/**\n * If running in a browser, this will start HotStaq.\n */\nexport function hotStaqWebStart ()\n{\n    let hotstaqElms = document.getElementsByTagName (\"hotstaq\");\n\n    // Set this to true, just in case...\n    HotStaq.isWeb = true;\n\n    // @ts-ignore\n    if (typeof (HotStaqWeb) !== \"undefined\")\n    {\n        // @ts-ignore\n\t\tfor (let key in HotStaqWeb)\n        {\n            // @ts-ignore\n            window[key] = HotStaqWeb[key];\n        }\n    }\n\n    if (hotstaqElms.length > 0)\n    {\n        let hotstaqElm: HTMLElement = (<HTMLElement>hotstaqElms[0]);\n\n        setTimeout (async function ()\n            {\n                let getAttr = (elm: HTMLElement, attrNames: string[]) =>\n                    {\n                        for (let iIdx = 0; iIdx < attrNames.length; iIdx++)\n                        {\n                            let attrName: string = attrNames[iIdx];\n\n                            if (elm.getAttribute (attrName) != null)\n                                return (elm.getAttribute (attrName));\n\n                            if (elm.getAttribute (`data-${attrName}`) != null)\n                                return (elm.getAttribute (`data-${attrName}`));\n                        }\n\n                        return (undefined);\n                    };\n\n                let loadPage: string = getAttr (hotstaqElm, [\"load-page\", \"loadPage\", \"src\"]) || \"\";\n                let loggingLevel: string = getAttr (hotstaqElm, [\"logging-level\", \"loggingLevel\"]) || null;\n                let startDelay: string = getAttr (hotstaqElm, [\"start-delay\", \"startDelay\"]) || null;\n                let router: string = getAttr (hotstaqElm, [\"router\"]) || \"\";\n                let name: string = getAttr (hotstaqElm, [\"name\"]) || \"default\";\n                let args: string = getAttr (hotstaqElm, [\"args\"]) || null;\n                let apiLibrary: string = getAttr (hotstaqElm, [\"api-library\", \"apiLibrary\"]) || null;\n                let apiName: string = getAttr (hotstaqElm, [\"api-name\", \"apiName\"]) || null;\n                let apiUrl: string = getAttr (hotstaqElm, [\"api-url\", \"apiUrl\"]) || null;\n                let testerName: string = getAttr (hotstaqElm, [\"tester-name\", \"testerName\"]) || \"HotTesterMochaSelenium\";\n                let testerMap: string = getAttr (hotstaqElm, [\"tester-map\", \"testerMap\"]) || null;\n                let testerApiBaseUrl: string = getAttr (hotstaqElm, [\"tester-api-base-url\", \"testerApiBaseUrl\"]) || null;\n                let testerLaunchpadUrl: string = getAttr (hotstaqElm, [\"tester-launchpad-url\", \"testerLaunchpadUrl\"]) || null;\n                let dontReuseProcessor: boolean = false;\n                let passRawUrl: boolean = false;\n                let htmlSource: string = hotstaqElm.innerHTML || \"\";\n                let routerManager: { [path: string]: { redirect: string; baseRedirect: string; base: string; src: string; } } = {};\n                let routerWildcards: string[] = [];\n                let search: URLSearchParams = new URLSearchParams (window.location.search);\n\n                if (startDelay != null)\n                    await HotStaq.wait (parseInt (startDelay));\n\n                if (getAttr (hotstaqElm, [\"src\"]) != null)\n                    loadPage = getAttr (hotstaqElm, [\"src\"]);\n\n                if (getAttr (hotstaqElm, [\"passRawUrl\"]) != null)\n                    passRawUrl = true;\n\n                if (getAttr (hotstaqElm, [\"dont-reuse-processor\", \"dontReuseProcessor\"]) != null)\n                    dontReuseProcessor = true;\n\n                let hstqbaseredirect: string = search.get (\"hstqbaseredirect\");\n\n                if (hstqbaseredirect != null)\n                {\n                    hstqbaseredirect = decodeURI (hstqbaseredirect);\n                    window.history.replaceState (\"\", \"\", hstqbaseredirect);\n                    loadPage = hstqbaseredirect;\n                }\n\n                let hotstaqErrors = document.getElementsByTagName (\"hotstaq-error\");\n\n                for (let iIdx = 0; iIdx < hotstaqErrors.length; iIdx++)\n                {\n                    // @ts-ignore\n                    let hotstaqErrorElm: HTMLElement = hotstaqErrors[iIdx];\n                    let errorStatus: string = getAttr (hotstaqErrorElm, [\"status\"]);\n                    let unsupportedBrowser: string = getAttr (hotstaqErrorElm, [\"unsupported-browser-redirect\"]);\n\n                    if (unsupportedBrowser != null)\n                        HotStaq.errors[\"unsupportedBrowser\"] = { redirectToUrl: unsupportedBrowser };\n                    else\n                        HotStaq.errors[`${errorStatus}`] = { redirectToUrl: unsupportedBrowser };\n                }\n\n                // Check if async/await is available.\n                try\n                {\n                    eval (\"async () => {}\");\n                }\n                catch (ex)\n                {\n                    HotStaq.executeError (\"unsupportedBrowser\");\n                }\n\n                if (router !== \"\")\n                {\n                    let hotstaqRouterElms = document.getElementsByTagName (\"hotstaq-router\");\n\n                    for (let iIdx = 0; iIdx < hotstaqRouterElms.length; iIdx++)\n                    {\n                        // @ts-ignore\n                        let hotstaqRouterElm: HTMLElement = hotstaqRouterElms[iIdx];\n                        let routerName: string = getAttr (hotstaqRouterElm, [\"name\"]);\n                        let serveLocally: string = getAttr (hotstaqRouterElm, [\"serve-local\", \"serveLocally\"]);\n\n                        // @ts-ignore\n                        if (routerName === router)\n                        {\n                            // Load all routes from the router.\n                            for (let iJdx = 0; iJdx < hotstaqRouterElm.childNodes.length; iJdx++)\n                            {\n                                // @ts-ignore\n                                let routerElm: HTMLElement = hotstaqRouterElm.childNodes[iJdx];\n\n                                if (routerElm instanceof HTMLElement)\n                                {\n                                    if (routerElm.tagName.toUpperCase () === \"ROUTE\")\n                                    {\n                                        let routerPath: string = getAttr (routerElm, [\"path\"]);\n                                        let redirect: string = getAttr (routerElm, [\"redirect\"]);\n                                        let baseRedirect: string = getAttr (routerElm, [\"base-redirect\", \"baseRedirect\"]);\n                                        let base: string = getAttr (routerElm, [\"base\"]);\n                                        let routerSrc: string = getAttr (routerElm, [\"src\"]);\n\n                                        if (routerPath.indexOf (\"*\") > -1)\n                                            routerWildcards.push (routerPath);\n\n                                        routerManager[routerPath] = {\n                                                redirect: redirect || undefined, \n                                                baseRedirect: baseRedirect || undefined, \n                                                base: base || undefined, \n                                                src: routerSrc || undefined\n                                            };\n                                    }\n                                }\n                            }\n\n                            let checkPath: string = window.location.pathname;\n                            let gotoPath: string = window.location.pathname;\n\n                            if (serveLocally != null)\n                            {\n                                const lowerServeLocally: string = serveLocally.toLowerCase ();\n\n                                if ((lowerServeLocally === \"true\") ||\n                                    (lowerServeLocally === \"yes\") ||\n                                    (lowerServeLocally === \"1\"))\n                                {\n                                    const lastSlashPos: number = checkPath.lastIndexOf (\"/\");\n\n                                    if (lastSlashPos > -1)\n                                    {\n                                        checkPath = checkPath.substring (lastSlashPos);\n                                        gotoPath = gotoPath.substring (lastSlashPos);\n                                    }\n                                }\n                            }\n\n                            if (routerWildcards.length > 0)\n                            {\n                                // Serve locally doesn't really work with wildcards\n                                /// @fixme This isn't actually working like a wildcard should. This needs to be improved.\n                                for (let iJdx = 0; iJdx < routerWildcards.length; iJdx++)\n                                {\n                                    let routeWildcard: string = routerWildcards[iJdx];\n                                    let tempRouteWildcard: string = routeWildcard.replace (\"*\", \"\");\n\n                                    if (checkPath.indexOf (tempRouteWildcard) > -1)\n                                    {\n                                        // This simply returns the key in the routerManager to access.\n                                        checkPath = routeWildcard;\n\n                                        break;\n                                    }\n                                }\n                            }\n\n                            // Find the correct route and load it.\n                            if (routerManager[checkPath] != null)\n                            {\n                                if (routerManager[checkPath].redirect != null)\n                                {\n                                    window.location.href = routerManager[checkPath].redirect;\n\n                                    return;\n                                }\n\n                                if (routerManager[checkPath].baseRedirect != null)\n                                {\n                                    const searchParams = window.location.search;\n                                    let modifiedSearchParams = \"\";\n\n                                    if ((searchParams !== \"\") && (searchParams !== \"?\"))\n                                        modifiedSearchParams = `&${searchParams.substring (1)}`;\n\n                                    window.location.href = `${routerManager[checkPath].baseRedirect}?hstqbaseredirect=${encodeURI (gotoPath + searchParams)}${modifiedSearchParams}`;\n\n                                    return;\n                                }\n\n                                if (routerManager[checkPath].src != null)\n                                    loadPage = routerManager[checkPath].src;\n                            }\n\n                            break;\n                        }\n                    }\n                }\n\n                if (args != null)\n                    args = JSON.parse (args);\n                else\n                    args = Hot.Arguments;\n\n                let hasHtmlSource: boolean = false;\n\n                if (htmlSource !== \"\")\n                {\n                    const htmlSourceCheck: string = htmlSource.replace (/\\s/g,'');\n\n                    if (htmlSourceCheck !== \"\")\n                        hasHtmlSource = true;\n                }\n\n                let tempMode = 0;\n\n                // @ts-ignore\n                if (window[\"Hot\"] != null)\n                    tempMode = Hot.Mode;\n        \n                let processor: HotStaq = null;\n\n                if (dontReuseProcessor === false)\n                {\n                    if (typeof (Hot) !== \"undefined\")\n                    {\n                        if (Hot.CurrentPage != null)\n                        {\n                            if (Hot.CurrentPage.processor != null)\n                                processor = Hot.CurrentPage.processor;\n                        }\n                    }\n                }\n\n                if (processor == null)\n                    processor = new HotStaq ();\n\n                if (loggingLevel != null)\n                    processor.logger.logLevel = HotLog.parse (loggingLevel);\n\n                processor.mode = tempMode;\n\n                let options: HotStartOptions = {\n                        name: name,\n                        processor: processor,\n                        args: args\n                    };\n\n                if (loadPage !== \"\")\n                {\n                    if (passRawUrl === false)\n                    {\n                        if (loadPage.indexOf (\"hstqserve\") < 0)\n                            loadPage += \"?hstqserve=nahfam\";\n                    }\n\n                    options.url = loadPage;\n                }\n\n                if (testerMap != null)\n                {\n                    options.testerMap = testerMap;\n                    options.testerName = testerName;\n                }\n\n                if (testerName != null)\n                    options.testerName = testerName;\n\n                if (testerApiBaseUrl != null)\n                    options.testerAPIBaseUrl = testerApiBaseUrl;\n\n                if (testerLaunchpadUrl != null)\n                    options.testerLaunchpadUrl = testerLaunchpadUrl;\n\n                if (apiName != null)\n                {\n                    let client = new HotClient (processor);\n\n                    if (apiUrl === \"\")\n                        throw new Error (`api-url was not set!`);\n\n                    let parentLib: any = window;\n\n                    if (apiLibrary != null)\n                    {\n                        // @ts-ignore\n                        parentLib = window[apiLibrary];\n                    }\n\n                    let newAPI = new parentLib[apiName] (apiUrl, client);\n                    newAPI.connection.api = newAPI;\n                    processor.api = newAPI;\n                }\n\n                if (hasHtmlSource === false)\n                {\n                    if (loadPage === \"\")\n                        throw new Error (`The hotstaq tag must have a src, HTML contents inside it, or a router set.`);\n\n                    HotStaq.displayUrl (options);\n                }\n                else\n                {\n                    HotStaq.displayContent (options);\n                }\n            }, 50);\n    }\n}","import { HotSiteMapPath } from \"./HotSite\";\n\n/**\n * The destination to take in a map.\n */\nexport class HotTestDestination\n{\n\t/**\n\t * The destination to take.\n\t */\n\tdestination: string;\n\t/**\n\t * If set to true, this will automatically start executing it's \n\t * tests when it's time.\n\t */\n\tautoStart: boolean;\n\n\tconstructor (destination: string | HotTestDestination | HotSiteMapPath = \"\", autoStart: boolean = true)\n\t{\n\t\tif (typeof (destination) === \"string\")\n\t\t{\n\t\t\tthis.destination = destination;\n\t\t\tthis.autoStart = autoStart;\n\t\t}\n\t\telse\n\t\t{\n\t\t\tif (destination instanceof HotTestDestination)\n\t\t\t{\n\t\t\t\tthis.destination = destination.destination;\n\t\t\t\tthis.autoStart = destination.autoStart;\n\t\t\t}\n\t\t\telse\n\t\t\t{\n\t\t\t\tthis.destination = destination.path;\n\t\t\t\tthis.autoStart = destination.autoStart;\n\t\t\t}\n\t\t}\n\t}\n}","import { HotStaq } from \"./HotStaq\";\nimport { HotTestElement, HotTestElementOptions } from \"./HotTestElement\";\nimport { HotTestPage } from \"./HotTestPage\";\n\n/**\n * This actually executes the tests.\n */\nexport class HotTestDriver\n{\n\t/**\n\t * The current page.\n\t */\n\tprocessor: HotStaq;\n\t/**\n\t * The current page.\n\t */\n\tpage: HotTestPage;\n\t/**\n\t * The delay in milliseconds between each executed command.\n\t */\n\tcommandDelay: number;\n\t/**\n\t * Any data that needs to be saved between the different testing runs.\n\t */\n\tpersistentData: any;\n\n\tconstructor (processor: HotStaq, page: HotTestPage | null = null)\n\t{\n\t\tthis.processor = processor;\n\t\tthis.page = page;\n\t\tthis.commandDelay = 20;\n\t\tthis.persistentData = {};\n\t}\n\n\t/**\n\t * Get a test object by it's name. If a * is used, it will be used as a \n\t * wildcard for the object's name. If a > is used, then the name will \n\t * be treated as a CSS selector.\n\t */\n\tparseTestObject (name: string): string\n\t{\n\t\tlet pos: number = name.indexOf (\"*\");\n\t\tlet wildcard: string = \"\";\n\n\t\tif (pos > -1)\n\t\t{\n\t\t\tname = name.replace (/\\*/, \"\");\n\t\t\twildcard = \"*\";\n\t\t}\n\n\t\tlet selector: string = `[data-test-object-name${wildcard}='${name}']`;\n\t\tpos = name.indexOf (\">\");\n\n\t\tif (pos > -1)\n\t\t{\n\t\t\tname = name.replace (/\\>/, \"\");\n\t\t\tselector = name;\n\t\t}\n\n\t\treturn (selector);\n\t}\n\n\t/**\n\t * Wait for a number of milliseconds.\n\t */\n\tasync wait (numMilliseconds: number): Promise<void>\n\t{\n\t\treturn (await new Promise ((resolve, reject) =>\n\t\t\t{\n\t\t\t\tsetTimeout (() =>\n\t\t\t\t\t{\n\t\t\t\t\t\tresolve ();\n\t\t\t\t\t}, numMilliseconds);\n\t\t\t}));\n\t}\n\n\t/**\n\t * Print a message.\n\t */\n\tasync print (message: string): Promise<void>\n\t{\n\t\tprocess.stdout.write (message);\n\t}\n\n\t/**\n\t * Print a message line.\n\t */\n\tasync println (message: string): Promise<void>\n\t{\n\t\tawait this.print (`${message}\\n`);\n\t}\n\n\t/**\n\t * Disconnect this server or destroy anything associated with this HotTestDriver.\n\t */\n\tasync destroy (): Promise<void>\n\t{\n\t}\n\n\t/**\n\t * An expression to test.\n\t */\n\tasync assert (value: any, errorMessage: string = \"\"): Promise<any>\n\t{\n\t\tif (! (value))\n\t\t\tthrow new Error (errorMessage);\n\t}\n}","/**\n * Hot test element options.\n */\nexport interface IHotTestElementOptions\n{\n\t/**\n\t * Indicates that the test element must be visible in \n\t * order to select it.\n\t */\n\tmustBeVisible?: boolean;\n\t/**\n\t * If the test element is missing, ignore the error. This \n\t * will cause the rest of the function to return immediately \n\t * without any exceptions being thrown.\n\t */\n\tignoreMissingElementError?: boolean;\n}\n\n/**\n * Hot test element options.\n */\nexport class HotTestElementOptions implements IHotTestElementOptions\n{\n\t/**\n\t * Indicates that the test element must be visible in \n\t * order to select it.\n\t */\n\tmustBeVisible: boolean;\n\t/**\n\t * If the test element is missing, ignore the error. This \n\t * will cause the rest of the function to return immediately \n\t * without any exceptions being thrown.\n\t */\n\tignoreMissingElementError: boolean;\n\n\tconstructor (copy: IHotTestElementOptions = {})\n\t{\n\t\tthis.mustBeVisible = copy.mustBeVisible || true;\n\t\tthis.ignoreMissingElementError = copy.ignoreMissingElementError || false;\n\t}\n}\n\n/**\n * A test element.\n */\nexport interface IHotTestElement\n{\n\t/**\n\t * The name of the element.\n\t */\n\tname: string;\n\t/**\n\t * The name of the function to execute \n\t * while executing the test.\n\t */\n\tfunc?: string;\n\t/**\n\t * The value to use.\n\t */\n\tvalue?: any;\n}\n\n/**\n * A test element.\n */\nexport class HotTestElement implements IHotTestElement\n{\n\t/**\n\t * The name of the element.\n\t */\n\tname: string;\n\t/**\n\t * The name of the function to execute \n\t * while executing the test.\n\t */\n\tfunc: string;\n\t/**\n\t * The value to use.\n\t */\n\tvalue: any;\n\n\tconstructor (name: string | IHotTestElement, func: string = \"\", value: any = null)\n\t{\n\t\tif (typeof (name) === \"string\")\n\t\t{\n\t\t\tthis.name = name;\n\t\t\tthis.func = func;\n\t\t\tthis.value = value;\n\t\t}\n\t\telse\n\t\t{\n\t\t\tthis.name = name.name;\n\t\t\tthis.func = name.func || func;\n\t\t\tthis.value = name.value || value;\n\t\t}\n\t}\n}","import { HotTestDriver } from \"./HotTestDriver\";\nimport { HotTestDestination } from \"./HotTestDestination\";\nimport { HotTestPage } from \"./HotTestPage\";\n\n/**\n * Create a test path for later execution.\n */\nexport type HotTestPath = (driver: HotTestDriver) => Promise<any>;\n\n/**\n * Maps the paths that are taken to complete a test.\n */\nexport class HotTestMap\n{\n\t/**\n\t * The order in which paths are to be taken. Each destination is a string \n\t * in a type -> path order. The type could be either a page or api route. \n\t * For example:\n\t * ```\n\t * [\n\t *      \"page:signin_page -> signin_path\",\n\t *      \"page:account_page -> change_username_path\",\n\t *      \"page:account_page -> change_password_path\",\n\t *      \"page:account_page -> change_name_path -> change_address_path\",\n\t * \t\t\"page:account_page -> signout_path\",\n\t * \t\t\"api:account_api_route -> signout_route_method -> signout_test_path\"\n\t * ]\n\t * ```\n\t * \n\t * The first string to the left of the -> will always be the type, such as a \n\t * page or an api route. Any strings to the right of the -> will be a path, even \n\t * when chaining addtional ->'s.\n\t */\n\tdestinations: HotTestDestination[] | { [name: string]: HotTestDestination; };\n\t/**\n\t * The order in which destinations are supposed to execute. This is \n\t * ignored if the destinations are an array.\n\t */\n\tdestinationOrder: string[];\n\t/**\n\t * The test pages to execute.\n\t */\n\tpages: {\n\t\t\t[name: string]: HotTestPage\n\t\t};\n\n\tconstructor (destinations: string[] | HotTestDestination[] | { [name: string]: string | HotTestDestination; } = [], \n\t\tpages: { [name: string]: HotTestPage } = {}, destinationOrder: string[] = [])\n\t{\n\t\t// Go through and convert any strings into HotTestDestinations.\n\t\tif (destinations instanceof Array)\n\t\t{\n\t\t\tthis.destinations = [];\n\n\t\t\tfor (let iIdx = 0; iIdx < destinations.length; iIdx++)\n\t\t\t{\n\t\t\t\tlet dest = destinations[iIdx];\n\n\t\t\t\tthis.destinations.push (new HotTestDestination (dest));\n\t\t\t}\n\t\t}\n\t\telse\n\t\t{\n\t\t\tthis.destinations = {};\n\n\t\t\tfor (let key in destinations)\n\t\t\t{\n\t\t\t\tlet dest = destinations[key];\n\n\t\t\t\tthis.destinations[key] = new HotTestDestination (dest);\n\t\t\t}\n\t\t}\n\n\t\tthis.destinationOrder = destinationOrder;\n\t\tthis.pages = pages;\n\t}\n}","import { HotStaq } from \"./HotStaq\";\nimport { HotRoute } from \"./HotRoute\";\nimport { HotRouteMethod, TestCaseObject } from \"./HotRouteMethod\";\nimport { HotTestDriver } from \"./HotTestDriver\";\nimport { HotTestMap, HotTestPath } from \"./HotTestMap\";\nimport { HotTestDestination } from \"./HotTestDestination\";\nimport { HotTestPage } from \"./HotTestPage\";\nimport { HotDestination } from \"./HotDestination\";\nimport { HotTestStop } from \"./HotTestStop\";\n\n/**\n * Executes tests.\n */\nexport abstract class HotTester\n{\n\t/**\n\t * The tester name.\n\t */\n\tname: string;\n\t/**\n\t * The timeout for each test.\n\t */\n\ttimeout: number;\n\t/**\n\t * The base url that will construct future urls.\n\t */\n\tbaseUrl: string;\n\t/**\n\t * The associated processor.\n\t */\n\tprocessor: HotStaq;\n\t/**\n\t * The test maps to test.\n\t */\n\ttestMaps: { [name: string]: HotTestMap; };\n\t/**\n\t * The driver to use when running tests.\n\t */\n\tdriver: HotTestDriver;\n\t/**\n\t * Has this tester finished loading?\n\t */\n\tfinishedLoading: boolean;\n\t/**\n\t * Has this tester finished setting up?\n\t */\n\thasBeenSetup: boolean;\n\t/**\n\t * Has this tester finished setting up?\n\t */\n\thasBeenDestroyed: boolean;\n\n\tconstructor (processor: HotStaq, name: string, baseUrl: string, \n\t\tdriver: HotTestDriver, testMaps: { [name: string]: HotTestMap; } = {})\n\t{\n\t\tif (testMaps == null)\n\t\t\tthrow new Error (`The testMaps parameter can be an empty object, but cannot be null! It is set to null.`);\n\n\t\tthis.processor = processor;\n\t\tthis.name = name;\n        this.timeout = 10000;\n\t\tthis.baseUrl = baseUrl;\n\t\tthis.testMaps = testMaps;\n\t\tthis.driver = driver;\n\t\tthis.finishedLoading = false;\n\t\tthis.hasBeenSetup = false;\n\t\tthis.hasBeenDestroyed = false;\n\t}\n\n\t/**\n\t * Executed when setting up the tester.\n\t */\n\tasync setup (isWebRoute: boolean, url: string, destinationKey?: string): Promise<void>\n\t{\n\t}\n\n\t/**\n\t * Executed when destroying up the tester.\n\t */\n\tasync destroy (): Promise<void>\n\t{\n\t}\n\n\t/**\n\t * Executed when tests are started. If this returns true, it will \n\t * continue and execute all test paths. If this returns it will \n\t * skip all test paths and execute onTestEnd instead.\n\t */\n\tasync onTestStart? (destination: HotDestination, url: string, destinationKey?: string): Promise<boolean>;\n\t/**\n\t * Executed when an API test path has started. If this returns false, \n\t * the testPath will not be immediately executed afterwards.\n\t */\n\tasync onTestAPIPathStart? (destination: HotDestination, method: HotRouteMethod, \n\t\ttestName: string, continueWhenTestIsComplete?: boolean): Promise<boolean>;\n\t/**\n\t * Executed when an API test path has ended.\n\t */\n\tasync onTestAPIPathEnd? (destination: HotDestination, method: HotRouteMethod, \n\t\ttestName: string, result: any, continueWhenTestIsComplete?: boolean): Promise<void>;\n\t/**\n\t * Executed when page tests are started. If this returns false, the testPath will not be \n\t * immediately executed afterwards.\n\t */\n\tasync onTestPagePathStart? (destination: HotDestination, page: HotTestPage, \n\t\tstop: HotTestStop, continueWhenTestIsComplete?: boolean): Promise<boolean>;\n\t/**\n\t * Executed when a page test has ended.\n\t */\n\tasync onTestPagePathEnd? (destination: HotDestination, testPath: HotTestPath, \n\t\tresult: any, continueWhenTestIsComplete?: boolean): Promise<void>;\n\t/**\n\t * Executed when a command is executed.\n\t */\n\tasync onCommand? (destination: HotDestination, page: HotTestPage, stop: HotTestStop, \n\t\tcmd: string, args: string[], cmdFunc: ((cmdArgs: string[]) => Promise<void>)): Promise<void>;\n\t/**\n\t * Executed when tests are finished.\n\t */\n\tasync onTestEnd? (destination: HotDestination): Promise<void>;\n\n\t/**\n\t * Executed when this tester has been executed from the API.\n\t */\n\tasync onExecute? (): Promise<void>;\n\t/**\n\t * Executed when this tester has finished loading all data from the API.\n\t */\n\tasync onFinishedLoading? (): Promise<void>;\n\n\t/**\n\t * Waits for the API to finish loading all data.\n\t */\n\tasync waitForData (): Promise<void>\n\t{\n\t\twhile (this.finishedLoading === false)\n\t\t\tawait HotStaq.wait (10);\n\t}\n\n\t/**\n\t * Get a test page.\n\t */\n\tgetTestPage (destination: HotDestination): HotTestPage\n\t{\n\t\tlet page = this.testMaps[destination.mapName].pages[destination.page];\n\n\t\treturn (page);\n\t}\n\n\t/**\n\t * Get a test path.\n\t */\n\tgetTestPath (destination: HotDestination, pathName: string): HotTestPath\n\t{\n\t\tlet page = this.testMaps[destination.mapName].pages[destination.page];\n\n\t\treturn (page.testPaths[pathName]);\n\t}\n\n\t/**\n\t * Get a destination JSON object to use.\n\t */\n\tstatic interpretDestination (mapName: string, testDest: HotTestDestination): HotDestination\n\t{\n\t\tlet destination: string = testDest.destination;\n\t\tlet newDestination: HotDestination = {\n\t\t\t\tmapName: mapName,\n\t\t\t\tpage: \"\",\n\t\t\t\tapi: \"\",\n\t\t\t\tpaths: []\n\t\t\t};\n\t\tlet strs: string[] = destination.split (/\\-\\>/g);\n\t\tlet type: string = strs[0];\n\n\t\tif (type.length < 2)\n\t\t\treturn (null);\n\n\t\tif ((type[0] === \"/\") && (type[1] === \"/\"))\n\t\t\treturn (null);\n\n\t\tlet getType: (typeStr: string, typeDelimiter: string) => string = \n\t\t\t(typeStr: string, typeDelimiter: string): string =>\n\t\t\t{\n\t\t\t\tlet pos: number = typeStr.indexOf (typeDelimiter);\n\t\t\t\tlet typeValue: string = \"\";\n\t\t\n\t\t\t\tif (pos > -1)\n\t\t\t\t{\n\t\t\t\t\ttypeValue = typeStr.substr (pos + typeDelimiter.length);\n\t\t\t\t\ttypeValue = typeValue.trim ();\n\t\t\t\t}\n\n\t\t\t\treturn (typeValue);\n\t\t\t};\n\n\t\tnewDestination.page = getType (type, \"page:\");\n\t\tnewDestination.api = getType (type, \"api:\");\n\n\t\tfor (let iIdx = 1; iIdx < strs.length; iIdx++)\n\t\t{\n\t\t\tlet newPathStr: string = strs[iIdx];\n\t\t\tlet newPath: HotTestStop = {\n\t\t\t\t\tcmd: \"\",\n\t\t\t\t\tdest: \"\",\n\t\t\t\t\tpath: \"\"\n\t\t\t\t};\n\n\t\t\tnewPathStr = newPathStr.trim ();\n\t\t\tnewPath.dest = getType (newPathStr, \"dest:\");\n\t\t\tnewPath.cmd = getType (newPathStr, \"cmd:\");\n\t\t\tnewPath.path = getType (newPathStr, \"path:\");\n\n\t\t\tif ((newPath.dest == \"\") && (newPath.cmd == \"\") && (newPath.path == \"\"))\n\t\t\t\tnewPath.path = newPathStr;\n\n\t\t\tnewDestination.paths.push (newPath);\n\t\t}\n\n\t\treturn (newDestination);\n\t}\n\n\t/**\n\t * Execute an API's test path.\n\t */\n\tasync executeTestAPIPath (destination: HotDestination, method: HotRouteMethod, \n\t\ttestName: string, skipEventCalls: boolean = false, continueWhenTestIsComplete: boolean = false): Promise<any>\n\t{\n\t\tlet runTestPath: boolean = true;\n\n\t\tif (method == null)\n\t\t\tthrow new Error (`Trying to access null method on destination map ${destination.mapName}.`);\n\n\t\t// A dumb hack to prevent any recursion that could occur.\n\t\tif (skipEventCalls === false)\n\t\t{\n\t\t\tif (this.onTestAPIPathStart != null)\n\t\t\t\trunTestPath = await this.onTestAPIPathStart (destination, method, testName, continueWhenTestIsComplete);\n\t\t}\n\n\t\tlet result: any = null;\n\n\t\tif (runTestPath === true)\n\t\t{\n\t\t\tlet testCaseObject: TestCaseObject = method.testCases[testName];\n\n\t\t\tif (testCaseObject == null)\n\t\t\t\tthrow new Error (`HotTester: Test case object ${testName} does not exist!`);\n\n\t\t\tresult = await testCaseObject.func (this.driver);\n\t\t}\n\n\t\tif (skipEventCalls === false)\n\t\t{\n\t\t\tif (this.onTestAPIPathEnd != null)\n\t\t\t\tawait this.onTestAPIPathEnd (destination, method, testName, result, continueWhenTestIsComplete);\n\t\t}\n\n\t\treturn (result);\n\t}\n\n\t/**\n\t * Execute all test paths in an API route.\n\t * \n\t * @fixme This needs a better implementation...\n\t */\n\tasync executeTestAPIPaths (destination: HotDestination): Promise<any[]>\n\t{\n\t\tlet results: any[] = [];\n\t\tlet testMap: HotTestMap = this.testMaps[destination.mapName];\n\n\t\tif (testMap == null)\n\t\t\tthrow new Error (`HotTester: API Map ${destination.mapName} does not exist!`);\n\n\t\tif (this.processor.api == null)\n\t\t\tthrow new Error (`HotTester: Associated processor does not have an API!`);\n\n\t\tlet route: HotRoute = this.processor.api.routes[destination.api];\n\n\t\tif (route == null)\n\t\t\tthrow new Error (`HotTester: API does not have route ${destination.api}!`);\n\n\t\t// Iterate through each path in the destination until complete.\n\t\tfor (let iIdx = 0; iIdx < destination.paths.length; iIdx += 2)\n\t\t{\n\t\t\tlet stop: HotTestStop = destination.paths[iIdx];\n\t\t\tlet pathName: string = stop.path;\n\t\t\tlet method: HotRouteMethod = route.getMethod (pathName);\n\t\t\tlet nextStop: HotTestStop = destination.paths[iIdx + 1];\n\t\t\tlet testName: string = nextStop.path;\n\n\t\t\tif (method == null)\n\t\t\t\tthrow new Error (`Unable to find method related to path ${pathName} in map ${destination.mapName}`);\n\n\t\t\tlet result: any = await this.executeTestAPIPath (destination, method, testName);\n\n\t\t\tresults.push (result);\n\t\t}\n\n\t\treturn (results);\n\t}\n\n\t/**\n\t * Execute a test page path.\n\t */\n\tasync executeTestPagePath (destination: HotDestination, stop: HotTestStop, \n\t\tskipEventCalls: boolean = false, continueWhenTestIsComplete: boolean = false): Promise<any>\n\t{\n\t\tlet runTestPath: boolean = true;\n\t\tlet testMap: HotTestMap = this.testMaps[destination.mapName];\n\n\t\t/// @fixme For some reason the errors being thrown here are not being thrown.\n\t\tif (testMap == null)\n\t\t\tthrow new Error (`HotTester: Web Map ${destination.mapName} does not exist!`);\n\n\t\tlet page: HotTestPage = testMap.pages[destination.page];\n\n\t\tif (page == null)\n\t\t\tthrow new Error (`HotTester: Page ${destination.page} does not exist!`);\n\n\t\tthis.driver.page = page;\n\n\t\tlet testPathName: string = stop.path;\n\t\tlet testPath: HotTestPath = page.testPaths[testPathName];\n\n\t\t// A dumb hack to prevent any recursion that could occur.\n\t\tif (skipEventCalls === false)\n\t\t{\n\t\t\tif (this.onTestPagePathStart != null)\n\t\t\t\trunTestPath = await this.onTestPagePathStart (destination, page, stop, continueWhenTestIsComplete);\n\t\t}\n\n\t\tlet result: any = null;\n\n\t\tif (runTestPath === true)\n\t\t{\n\t\t\tif (testPath == null)\n\t\t\t\tthrow new Error (`HotTester: Test path ${testPathName} does not have a function!`);\n\n\t\t\tresult = await testPath (this.driver);\n\t\t}\n\n\t\tif (skipEventCalls === false)\n\t\t{\n\t\t\tif (this.onTestPagePathEnd != null)\n\t\t\t\tawait this.onTestPagePathEnd (destination, testPath, result, continueWhenTestIsComplete);\n\t\t}\n\n\t\treturn (result);\n\t}\n\n\t/**\n\t * Execute a command.\n\t */\n\tasync executeCommand (destination: HotDestination, page: HotTestPage, stop: HotTestStop, cmd: string): Promise<void>\n\t{\n\t\t/**\n\t\t * Check if the input command matches.\n\t\t */\n\t\tlet hasCmd: (input: string, cmd: string, hasArguments: boolean) => boolean = \n\t\t\t(input: string, cmd: string, hasArguments: boolean): boolean =>\n\t\t\t{\n\t\t\t\tlet result: boolean = false;\n\n\t\t\t\tif (stop.cmd === cmd)\n\t\t\t\t\tresult = true;\n\n\t\t\t\tconst pos: number = stop.cmd.indexOf (\"(\");\n\n\t\t\t\t// If there's parenthesis, get the incoming command.\n\t\t\t\tif (pos > -1)\n\t\t\t\t{\n\t\t\t\t\tlet inputCmd: string = stop.cmd.substr (0, pos);\n\n\t\t\t\t\tif (inputCmd === cmd)\n\t\t\t\t\t\tresult = true;\n\t\t\t\t}\n\n\t\t\t\treturn (result);\n\t\t\t};\n\t\t/**\n\t\t * Get the arguments in a command. This will only return a \n\t\t * single argument for now.\n\t\t * \n\t\t * @fixme Add support for multiple arguments.\n\t\t */\n\t\tlet getCmdArgs: (input: string) => string[] = \n\t\t\t(input: string): string[] =>\n\t\t\t{\n\t\t\t\tlet results: string[] = [];\n\t\t\t\tlet matches = input.match (/(?=\\()(.*?)(?=\\))/g);\n\n\t\t\t\tif (matches != null)\n\t\t\t\t{\n\t\t\t\t\tlet tempMatch = matches[0];\n\n\t\t\t\t\t// A little hack, since I suck at Regex :(\n\t\t\t\t\ttempMatch = tempMatch.substr (2, tempMatch.length);\n\n\t\t\t\t\tresults.push (tempMatch);\n\t\t\t\t}\n\n\t\t\t\tif (results.length < 1)\n\t\t\t\t\tthrow new Error (`HotTester: Command ${input} requires arguments, but none were supplied.`);\n\n\t\t\t\treturn (results);\n\t\t\t};\n\n\t\tlet seleniumTester: any = null;\n\t\tlet cmdFunc: ((cmdArgs: string[]) => Promise<void>) = null;\n\t\tlet args: string[] = [];\n\n\t\t// @ts-ignore\n\t\tif (typeof (HotTesterMochaSelenium) != \"undefined\")\n\t\t{// @ts-ignore\n\t\t\t// @ts-ignore - Hack to prevent recursive importing.\n\t\t\tif (this instanceof HotTesterMochaSelenium)\n\t\t\t\tseleniumTester = this;\n\t\t}\n\n\t\tif (seleniumTester != null)\n\t\t{\n\t\t\tif (hasCmd (stop.cmd, \"url\", true) === true)\n\t\t\t{\n\t\t\t\targs = getCmdArgs (stop.cmd);\n\n\t\t\t\tcmdFunc = async (cmdArgs: string[]): Promise<void> =>\n\t\t\t\t\t{\n\t\t\t\t\t\tlet input: string = cmdArgs[0];\n\n\t\t\t\t\t\tawait seleniumTester.driver.navigateToUrl (input);\n\t\t\t\t\t};\n\t\t\t}\n\n\t\t\tif (hasCmd (stop.cmd, \"waitForTestObject\", true) === true)\n\t\t\t{\n\t\t\t\targs = getCmdArgs (stop.cmd);\n\t\n\t\t\t\tcmdFunc = async (cmdArgs: string[]): Promise<void> =>\n\t\t\t\t\t{\n\t\t\t\t\t\tlet testObject: string = JSON.parse (cmdArgs[0]);\n\t\n\t\t\t\t\t\tawait seleniumTester.driver.waitForTestElement (testObject);\n\t\t\t\t\t};\n\t\t\t}\n\t\t}\n\n\t\tif (hasCmd (stop.cmd, \"waitForTesterAPIData\", false) === true)\n\t\t{\n\t\t\tcmdFunc = async (cmdArgs: string[]): Promise<void> =>\n\t\t\t\t{\n\t\t\t\t\tthis.finishedLoading = false;\n\t\t\t\t\tawait this.waitForData ();\n\t\t\t\t};\n\t\t}\n\n\t\tif (hasCmd (stop.cmd, \"wait\", true) === true)\n\t\t{\n\t\t\targs = getCmdArgs (stop.cmd);\n\n\t\t\tcmdFunc = async (cmdArgs: string[]): Promise<void> =>\n\t\t\t\t{\n\t\t\t\t\tlet numMilliseconds: number = parseInt (cmdArgs[0]);\n\n\t\t\t\t\tawait HotStaq.wait (numMilliseconds);\n\t\t\t\t};\n\t\t}\n\n\t\tif (hasCmd (stop.cmd, \"print\", true) === true)\n\t\t{\n\t\t\targs = getCmdArgs (stop.cmd);\n\n\t\t\tcmdFunc = async (cmdArgs: string[]): Promise<void> =>\n\t\t\t\t{\n\t\t\t\t\tlet input: string = cmdArgs[0];\n\n\t\t\t\t\tawait this.driver.print (input);\n\t\t\t\t};\n\t\t}\n\n\t\tif (hasCmd (stop.cmd, \"println\", true) === true)\n\t\t{\n\t\t\targs = getCmdArgs (stop.cmd);\n\n\t\t\tcmdFunc = async (cmdArgs: string[]): Promise<void> =>\n\t\t\t\t{\n\t\t\t\t\tlet input: string = cmdArgs[0];\n\n\t\t\t\t\tawait this.driver.println (input);\n\t\t\t\t};\n\t\t}\n\n\t\tif (cmdFunc == null)\n\t\t\tthrow new Error (`HotTester: Command ${stop.cmd} does not exist!`);\n\n\t\tawait this.onCommand (destination, page, stop, cmd, args, cmdFunc);\n\t}\n\n\t/**\n\t * Execute all test paths in a page.\n\t */\n\tasync executeTestPagePaths (destination: HotDestination, continueWhenTestIsComplete: boolean = false): Promise<any[]>\n\t{\n\t\tlet results: any[] = [];\n\t\tlet testMap: HotTestMap = this.testMaps[destination.mapName];\n\n\t\t/// @fixme For some reason the errors being thrown here are not being thrown.\n\t\tif (testMap == null)\n\t\t\tthrow new Error (`HotTester: Web Map ${destination.mapName} does not exist!`);\n\n\t\t// Iterate through each path in the destination until complete.\n\t\tfor (let iIdx = 0; iIdx < destination.paths.length; iIdx++)\n\t\t{\n\t\t\tlet stop: HotTestStop = destination.paths[iIdx];\n\t\t\tlet result: any = null;\n\t\t\tlet page: HotTestPage = testMap.pages[destination.page];\n\t\n\t\t\tif (page == null)\n\t\t\t\tthrow new Error (`HotTester: Page ${destination.page} does not exist!`);\n\n\t\t\tif (stop.dest !== \"\")\n\t\t\t{\n\t\t\t\tif (testMap.destinations instanceof Array)\n\t\t\t\t\tthrow new Error (`HotTester: When using type 'dest' in a destination string, all destinations in map ${destination.mapName} must be named.`);\n\n\t\t\t\tlet testDest: HotTestDestination = testMap.destinations[stop.dest];\n\t\t\t\tlet newDestination: HotDestination = HotTester.interpretDestination (\n\t\t\t\t\t\t\t\t\t\t\t\t\tdestination.mapName, testDest);\n\n\t\t\t\tif (newDestination != null)\n\t\t\t\t\tresult = await this.executeTestPagePaths (newDestination);\n\t\t\t}\n\n\t\t\tif (stop.cmd !== \"\")\n\t\t\t\tawait this.executeCommand (destination, page, stop, stop.cmd);\n\n\t\t\tif (stop.path !== \"\")\n\t\t\t\tresult = await this.executeTestPagePath (destination, stop, false, continueWhenTestIsComplete);\n\n\t\t\tresults.push (result);\n\t\t}\n\n\t\treturn (results);\n\t}\n\n\t/**\n\t * Execute the tests.\n\t */\n\tasync execute (mapName: string): Promise<void>\n\t{\n\t\tlet map: HotTestMap = this.testMaps[mapName];\n\n\t\tif (map == null)\n\t\t\tthrow new Error (`HotTester: Map ${mapName} does not exist!`);\n\n\t\tthis.processor.logger.verbose (`HotTester: Executing map ${mapName}...`);\n\n\t\t// Process routes testing first.\n\t\tlet routeKey: string = this.processor.getRouteKeyFromName (mapName);\n\t\tlet url: string = \"\";\n\n\t\tif (this.baseUrl === \"\")\n\t\t{\n\t\t\t\n\t\t}\n\n\t\tif (routeKey !== \"\")\n\t\t\turl = `${this.baseUrl}${routeKey}`;\n\n\t\tlet executeDestination: (testDest: HotTestDestination, destinationKey?: string) => Promise<void> = \n\t\t\tasync (testDest: HotTestDestination, destinationKey: string = \"\") =>\n\t\t\t{\n\t\t\t\tif (testDest.autoStart === false)\n\t\t\t\t\treturn;\n\n\t\t\t\ttry\n\t\t\t\t{\n\t\t\t\t\tthis.processor.logger.verbose (() => `HotTester: Executing ${mapName} destination ${JSON.stringify (testDest)}...`);\n\t\t\t\t\tlet destination: HotDestination = HotTester.interpretDestination (mapName, testDest);\n\t\t\t\t\tlet isWebRoute: boolean = false;\n\t\t\t\t\tlet runTestPaths: boolean = true;\n\n\t\t\t\t\tif (destination.page !== \"\")\n\t\t\t\t\t\tisWebRoute = true;\n\n\t\t\t\t\tif (this.setup != null)\n\t\t\t\t\t{\n\t\t\t\t\t\tif (this.hasBeenSetup === false)\n\t\t\t\t\t\t{\n\t\t\t\t\t\t\tawait this.setup (isWebRoute, url, destinationKey);\n\t\t\t\t\t\t\tthis.hasBeenSetup = true;\n\t\t\t\t\t\t\tthis.hasBeenDestroyed = false;\n\t\t\t\t\t\t}\n\t\t\t\t\t}\n\t\t\n\t\t\t\t\tif (this.onTestStart != null)\n\t\t\t\t\t\trunTestPaths = await this.onTestStart (destination, url, destinationKey);\n\t\t\n\t\t\t\t\tif (runTestPaths === true)\n\t\t\t\t\t{\n\t\t\t\t\t\tif (destination.page !== \"\")\n\t\t\t\t\t\t\tawait this.executeTestPagePaths (destination);\n\t\t\n\t\t\t\t\t\tif (destination.api !== \"\")\n\t\t\t\t\t\t\tawait this.executeTestAPIPaths (destination);\n\t\t\t\t\t}\n\t\t\t\n\t\t\t\t\tif (this.onTestEnd != null)\n\t\t\t\t\t\tawait this.onTestEnd (destination);\n\n\t\t\t\t\tif (this.destroy != null)\n\t\t\t\t\t{\n\t\t\t\t\t\tif (this.hasBeenDestroyed === false)\n\t\t\t\t\t\t{\n\t\t\t\t\t\t\tawait this.destroy ();\n\t\t\t\t\t\t\tthis.hasBeenDestroyed = true;\n\t\t\t\t\t\t\tthis.hasBeenSetup = false;\n\t\t\t\t\t\t}\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t\tcatch (ex)\n\t\t\t\t{\n\t\t\t\t\tthrow ex;\n\t\t\t\t}\n\t\t\t};\n\n\t\t// If the map destinations are in an array, just execute those in order.\n\t\tif (map.destinations instanceof Array)\n\t\t{\n\t\t\tfor (let iIdx = 0; iIdx < map.destinations.length; iIdx++)\n\t\t\t{\n\t\t\t\tlet testDest: HotTestDestination = map.destinations[iIdx];\n\n\t\t\t\tawait executeDestination (testDest);\n\t\t\t}\n\t\t}\n\t\telse\n\t\t{\n\t\t\t// If there's a destination order, use that.\n\t\t\tif (map.destinationOrder.length > 0)\n\t\t\t{\n\t\t\t\tlet hasExecutedKeys: string[] = [];\n\n\t\t\t\t// Go through the destination order and execute each one.\n\t\t\t\tfor (let iIdx = 0; iIdx < map.destinationOrder.length; iIdx++)\n\t\t\t\t{\n\t\t\t\t\tlet orderKey: string = map.destinationOrder[iIdx];\n\t\t\t\t\tlet testDest: HotTestDestination = map.destinations[orderKey];\n\n\t\t\t\t\tif (testDest == null)\n\t\t\t\t\t\tthrow new Error (`HotTester: Destination ${orderKey} does not exist!`);\n\n\t\t\t\t\thasExecutedKeys.push (orderKey);\n\t\t\t\t\tawait executeDestination (testDest, orderKey);\n\t\t\t\t}\n\n\t\t\t\t// Execute the rest of the destinations that have not been executed yet.\n\t\t\t\tfor (let key in map.destinations)\n\t\t\t\t{\n\t\t\t\t\tlet executeDest: boolean = true;\n\n\t\t\t\t\tfor (let iIdx = 0; iIdx < hasExecutedKeys.length; iIdx++)\n\t\t\t\t\t{\n\t\t\t\t\t\tlet executedKey: string = hasExecutedKeys[iIdx];\n\n\t\t\t\t\t\tif (executedKey === key)\n\t\t\t\t\t\t{\n\t\t\t\t\t\t\texecuteDest = false;\n\n\t\t\t\t\t\t\tbreak;\n\t\t\t\t\t\t}\n\t\t\t\t\t}\n\n\t\t\t\t\tif (executeDest === true)\n\t\t\t\t\t{\n\t\t\t\t\t\tlet testDest: HotTestDestination = map.destinations[key];\n\n\t\t\t\t\t\tawait executeDestination (testDest, key);\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t}\n\t\t\telse\n\t\t\t{\n\t\t\t\t// Execute the destinations in any order.\n\t\t\t\tfor (let key in map.destinations)\n\t\t\t\t{\n\t\t\t\t\tlet testDest: HotTestDestination = map.destinations[key];\n\n\t\t\t\t\tawait executeDestination (testDest, key);\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\t}\n}","import { EventExecutionType, HotAPI } from \"./HotAPI\";\nimport { HotRoute } from \"./HotRoute\";\nimport { HotClient } from \"./HotClient\";\nimport { HotServer } from \"./HotServer\";\nimport { HotTestDriver } from \"./HotTestDriver\";\nimport { HotTester } from \"./HotTester\";\nimport { HotTestMap, HotTestPath } from \"./HotTestMap\";\nimport { HotEventMethod, ServerRequest } from \"./HotRouteMethod\";\n\nexport class HotTesterAPI extends HotAPI\n{\n\tconstructor (baseUrl: string, connection: HotServer | HotClient = null, db: any = null)\n\t{\n\t\tsuper(baseUrl, connection, db);\n\n\t\tthis.executeEventsUsing = EventExecutionType.HotAPI;\n\n\t\tlet route: HotRoute = new HotRoute (connection, \"tester\");\n\t\troute.addMethod ({\n\t\t\t\t\"name\": \"pageLoaded\", \n\t\t\t\t\"onServerExecute\": this.pageLoaded,\n\t\t\t\t\"parameters\": {\n\t\t\t\t\t\t\"testerName\": {\n\t\t\t\t\t\t\t\"required\": true,\n\t\t\t\t\t\t\t\"type\": \"string\",\n\t\t\t\t\t\t\t\"description\": \"The name of the tester executing the test.\"\n\t\t\t\t\t\t},\n\t\t\t\t\t\t\"testerMap\": {\n\t\t\t\t\t\t\t\"required\": true,\n\t\t\t\t\t\t\t\"type\": \"string\",\n\t\t\t\t\t\t\t\"description\": \"The tester map executing the test.\"\n\t\t\t\t\t\t},\n\t\t\t\t\t\t\"pageName\": {\n\t\t\t\t\t\t\t\"required\": true,\n\t\t\t\t\t\t\t\"type\": \"string\",\n\t\t\t\t\t\t\t\"description\": \"The name of the page executing the test.\"\n\t\t\t\t\t\t},\n\t\t\t\t\t\t\"testElements\": {\n\t\t\t\t\t\t\t\"required\": true,\n\t\t\t\t\t\t\t\"type\": \"array\",\n\t\t\t\t\t\t\t\"description\": \"The test elements on the page.\"\n\t\t\t\t\t\t},\n\t\t\t\t\t\t\"testPaths\": {\n\t\t\t\t\t\t\t\"required\": true,\n\t\t\t\t\t\t\t\"type\": \"array\",\n\t\t\t\t\t\t\t\"description\": \"The test paths on the page.\"\n\t\t\t\t\t\t}\n\t\t\t\t\t},\n\t\t\t\t\"returns\": \"Returns true as an acknowledgement.\"\n\t\t\t});\n\t\troute.addMethod ({\n\t\t\t\t\"name\": \"executeTests\",\n\t\t\t\t\"onServerExecute\": this.executeTests,\n\t\t\t\t\"parameters\": {\n\t\t\t\t\t\"testerName\": {\n\t\t\t\t\t\t\"required\": true,\n\t\t\t\t\t\t\"type\": \"string\",\n\t\t\t\t\t\t\"description\": \"The name of the tester executing the test.\"\n\t\t\t\t\t},\n\t\t\t\t\t\"testerMap\": {\n\t\t\t\t\t\t\"required\": true,\n\t\t\t\t\t\t\"type\": \"object\",\n\t\t\t\t\t\t\"description\": \"The tester map to execute.\"\n\t\t\t\t\t}\n\t\t\t\t},\n\t\t\t\t\"returns\": \"Returns true when tests are complete.\"\n\t\t\t});\n\t\troute.addMethod ({\n\t\t\t\t\"name\": \"heartbeat\",\n\t\t\t\t\"type\": HotEventMethod.GET,\n\t\t\t\t\"onServerExecute\": this.heartbeat,\n\t\t\t\t\"returns\": \"Returns true as an acknowledgement.\"\n\t\t\t});\n\t\tthis.addRoute (route);\n\t}\n\n\t/**\n\t * This is called when the page has finished loading in development mode.\n\t */\n\tasync pageLoaded (request: ServerRequest): Promise<any>\n\t{\n\t\tlet testerObj: {\n\t\t\t\ttesterName: string;\n\t\t\t\ttesterMap: string;\n\t\t\t\tpageName: string;\n\t\t\t\ttestElements: any;\n\t\t\t\ttestPathsStrs: any;\n\t\t\t} = {\n\t\t\t\ttesterName: request.jsonObj[\"testerName\"],\n\t\t\t\ttesterMap: request.jsonObj[\"testerMap\"],\n\t\t\t\tpageName: request.jsonObj[\"pageName\"],\n\t\t\t\ttestElements: request.jsonObj[\"testElements\"],\n\t\t\t\ttestPathsStrs: request.jsonObj[\"testPaths\"]\n\t\t\t};\n\n\t\tfor (let key in testerObj)\n\t\t{\n\t\t\t// @ts-ignore\n\t\t\tlet testObj: any = testerObj[key];\n\t\t\tlet throwError: boolean = false;\n\n\t\t\tif (testObj == null)\n\t\t\t\tthrowError = true;\n\n\t\t\tif ((testerObj.testerName == \"\") || \n\t\t\t\t(testerObj.testerMap === \"\") || \n\t\t\t\t(testerObj.testElements === \"\") || \n\t\t\t\t(testerObj.testPathsStrs === \"\"))\n\t\t\t{\n\t\t\t\tthrowError = true;\n\t\t\t}\n\n\t\t\tif (throwError === true)\n\t\t\t\tthrow new Error (`TesterAPI: Object ${key} was not passed.`);\n\t\t}\n\n\t\ttesterObj.testElements = JSON.parse (testerObj.testElements);\n\t\ttesterObj.testPathsStrs = JSON.parse (testerObj.testPathsStrs);\n\n\t\tlet testPaths: { [name: string]: HotTestPath; } = {};\n\n\t\tfor (let key in testerObj.testPathsStrs)\n\t\t{\n\t\t\tlet testPath: (driver: HotTestDriver, ...args: any) => Promise<any> = \n\t\t\t\teval (testerObj.testPathsStrs[key]);\n\n\t\t\ttestPaths[key] = testPath;\n\t\t}\n\n\t\tlet tester: HotTester = this.connection.processor.testers[testerObj.testerName];\n\n\t\tif (tester == null)\n\t\t\tthrow new Error (`TesterAPI: Tester ${testerObj.testerName} does not exist!`);\n\n\t\tlet testMap: HotTestMap = tester.testMaps[testerObj.testerMap];\n\n\t\tif (testMap == null)\n\t\t\tthrow new Error (`TesterAPI: Tester map ${testerObj.testerMap} does not exist!`);\n\n\t\ttestMap.pages[testerObj.pageName] = {\n\t\t\t\t\"testElements\": {},\n\t\t\t\t\"testPaths\": {}\n\t\t\t};\n\t\ttestMap.pages[testerObj.pageName].testElements = testerObj.testElements;\n\t\ttestMap.pages[testerObj.pageName].testPaths = testPaths;\n\n\t\ttester.finishedLoading = true;\n\n\t\tif (tester.onFinishedLoading != null)\n\t\t\tawait tester.onFinishedLoading ();\n\n\t\treturn (true);\n\t}\n\n\t/**\n\t * Execute the tests for a page.\n\t */\n\tasync executeTests (req: ServerRequest): Promise<any>\n\t{\n\t\tlet testerName: string = req.jsonObj[\"testerName\"];\n\t\tlet testerMap: string = req.jsonObj[\"testerMap\"];\n\n\t\tif ((testerName == null) || (testerMap == null))\n\t\t\tthrow new Error (\"TesterAPI: Not all required json objects were passed.\");\n\n\t\tif ((testerName === \"\") || (testerMap === \"\"))\n\t\t\tthrow new Error (\"TesterAPI: Not all required json objects were passed.\");\n\n\t\tlet server: HotServer = (<HotServer>this.connection);\n\n\t\t// @ts-ignore\n\t\tif (server.executeTests != null)\n\t\t{\n\t\t\t// @ts-ignore\n\t\t\tawait server.executeTests (testerName, testerMap);\n\t\t}\n\n\t\treturn (true);\n\t}\n\n\t/**\n\t * Responds with true to heartbeat requests.\n\t */\n\tasync heartbeat (req: ServerRequest): Promise<any>\n\t{\n\t\treturn (true);\n\t}\n}","module.exports = {};","// The module cache\nvar __webpack_module_cache__ = {};\n\n// The require function\nfunction __webpack_require__(moduleId) {\n\t// Check if module is in cache\n\tvar cachedModule = __webpack_module_cache__[moduleId];\n\tif (cachedModule !== undefined) {\n\t\treturn cachedModule.exports;\n\t}\n\t// Create a new module (and put it into the cache)\n\tvar module = __webpack_module_cache__[moduleId] = {\n\t\t// no module.id needed\n\t\t// no module.loaded needed\n\t\texports: {}\n\t};\n\n\t// Execute the module function\n\t__webpack_modules__[moduleId].call(module.exports, module, module.exports, __webpack_require__);\n\n\t// Return the exports of the module\n\treturn module.exports;\n}\n\n","__webpack_require__.g = (function() {\n\tif (typeof globalThis === 'object') return globalThis;\n\ttry {\n\t\treturn this || new Function('return this')();\n\t} catch (e) {\n\t\tif (typeof window === 'object') return window;\n\t}\n})();","import { HotStaq, HotStartOptions, IHotStaq } from \"./HotStaq\";\nimport { HotSite, HotSiteRoute, HotSiteMapPath } from \"./HotSite\";\nimport { Hot, DeveloperMode } from \"./Hot\";\nimport { HotAsset } from \"./HotAsset\";\nimport { HotModule } from \"./HotModule\";\nimport { HotComponent, HotComponentOutput, IHotComponent } from \"./HotComponent\";\nimport { HotFile } from \"./HotFile\";\nimport { HotLog, HotLogLevel } from \"./HotLog\";\nimport { HotPage } from \"./HotPage\";\n\n// Server stuff\nimport { HotAPI, EventExecutionType, APItoLoad } from \"./HotAPI\";\nimport { HotRoute } from \"./HotRoute\";\nimport { HotRouteMethod, HotEventMethod, ServerRequest } from \"./HotRouteMethod\";\nimport { HotServer, HotServerType } from \"./HotServer\";\nimport { HotClient } from \"./HotClient\";\n\n// Testing stuff\nimport { HotTestDriver } from \"./HotTestDriver\";\nimport { IHotTestElement, HotTestElement, HotTestElementOptions, IHotTestElementOptions } from \"./HotTestElement\";\nimport { HotTester } from \"./HotTester\";\nimport { HotTestStop } from \"./HotTestStop\";\nimport { HotDestination } from \"./HotDestination\";\n//import { HotTesterMocha } from \"./HotTesterMocha\";\n//import { HotTesterMochaSelenium } from \"./HotTesterMochaSelenium\";\nimport { HotTesterAPI } from \"./HotTesterAPI\";\nimport { HotTestMap, HotTestPath } from \"./HotTestMap\";\nimport { HotTestDestination } from \"./HotTestDestination\";\nimport { HotTestPage } from \"./HotTestPage\";\n\nHotStaq.isWeb = true;\n\n// Can't export interfaces from here :(\n\nexport {\n    HotStaq,\n    Hot,\n    HotModule,\n    HotAsset,\n    DeveloperMode,\n    HotComponent,\n    HotAPI,\n    EventExecutionType,\n    HotFile,\n    HotLog,\n    HotLogLevel,\n    HotPage,\n    HotRoute,\n    HotRouteMethod,\n    HotEventMethod,\n    ServerRequest,\n    HotServer,\n    HotServerType,\n    HotClient,\n    HotTester,\n    HotTesterAPI,\n    HotTestMap,\n    HotTestDestination,\n    HotTestElement,\n    HotTestElementOptions,\n    HotTestDriver\n};"],"names":["module","exports","self","FormData","window","assign","target","i","arguments","length","source","key","init","converter","defaultAttributes","set","value","attributes","document","expires","Date","now","toUTCString","encodeURIComponent","replace","decodeURIComponent","escape","stringifiedAttributes","attributeName","split","cookie","write","Object","create","get","cookies","jar","parts","slice","join","foundKey","read","e","remove","withAttributes","this","withConverter","freeze","path","factory","global","Error","getGlobal","fetch","bind","Headers","Request","Response","DeveloperMode","Hot","static","file","args","HotStaq","isWeb","lowerFile","toLowerCase","indexOf","echo","getFile","parentObject","output","g","eval","apply","moduleName","foundModule","CurrentPage","processor","getModule","newModule","Function","loadHTML","addModule","fileName","tempFile","page","content","process","HotFile","name","url","localFile","checkFile","load","route","data","httpMethod","HotEventMethod","POST","files","result","api","makeCall","jsonRequest","GET","fetchObj","JSON","stringify","res","ok","status","statusText","json","ex","message","requestInit","Output","iIdx","CSS","cssFile","cssOut","cssStr","JSFiles","jsFile","jsFileOut","jsFileStr","JSScripts","jsScript","jsScriptOut","jsScriptsStr","Arguments","HotTestElement","Mode","Production","API","TesterAPI","Data","Cookies","PublicKeys","EventExecutionType","constructor","baseUrl","connection","db","description","createFunctions","executeEventsUsing","HotRoute","authCredentials","userAuth","routes","onPreRegister","onPostRegister","setDBSchema","schema","getDB","getDBSchema","addRoute","routeMethod","executeFunction","routeName","addMethod","HotRouteMethod","newRoute","methods","currentRoute","newRouteMethod","type","routeStr","getRouteUrl","authCredential","registerRoute","HotServer","registerRoutes","httpMethodStr","toUpperCase","substr","keys","formData","append","method","body","jsonRes","headers","Promise","resolve","reject","then","jsonObj","catch","reason","escapedContent","fileUrl","fileContent","RegExp","testerAPI","HotServerType","HTTP","logger","copy","htmlElements","tag","elementOptions","undefined","observedAttributes","inner","events","onCreated","element","throwAllErrors","setContent","getContent","text","loadUrl","httpGet","loadLocalFile","fs","readFile","err","toString","contentRegex","contentProcessor","offContentProcessor","numRemoveFromBeginning","numRemoveFromEnd","exec","previousIndex","start","index","end","lastIndex","prevContent","startChars","endChars","triggerChar","pos","startTriggerPos","nestedCounter","rpos","lastIndexOf","epos","tempepos","thisContent","parserOptions","outputCommands","allowStringify","STRINGIFY_START","STRINGIFY_END","processContent","regexFound","offContent","tempOutput","processNestedContent","regexFound2","offContent3","tempOutput2","out","tempOutput3","tempOutput4","Development","foundStr","parse","createTestElement","foundStr2","testElm","obj","Array","testElements","func","tempOutput5","mode","publicKeys","getAPI","getTesterAPI","parseContent","returnedOutput","executionContent","newVar","newVarValue","contentName","SyntaxError","hot","finalOutput","HotLogLevel","logLevel","All","level","Info","Warning","Verbose","None","log","error","warning","info","verbose","console","warn","msg","stack","import","html","css","js","componentLibrary","components","outputCSS","echoOut","outputAsset","asset","outputJS","assetName","include","loadHotFiles","outputComponents","assetType","assets","callback","loadAsset","HotAsset","testerName","testerMap","testPaths","addFile","push","addTestElement","elm","getTestElement","createTestPath","pathName","driverFunc","onRegister","onAuthorizeUser","version","prefix","errors","createError","testCases","getMethod","foundMethod","req","wsSocket","authorizedValue","queryObj","onExecute","onServerAuthorize","returns","parameters","param","onServerExecute","onClientExecute","isRegistered","executeSetup","testCaseName","addTestCase","newTestCase","testCaseFunction","testCaseId","testCase","methodName","serverType","listenAddress","ports","http","https","ssl","cert","ca","redirectHTTPtoHTTPS","secrets","setAPI","HotTesterMocha","HotTesterMochaSelenium","HotTestSeleniumDriver","HotLog","startDelay","pages","modules","hotSite","apiContent","testerApiContent","pageContent","testers","objWithParam","required","throwException","defaultValue","errType","redirectToUrl","location","href","numMilliseconds","setTimeout","addPage","getPage","pageName","throwEx","tempName","substring","context","val","aryArgs","prototype","call","addComponent","ComponentType","tempApi","tempComponentObj","componentType","registerComponent","str","tempStr","parsedXML","DOMParser","parseFromString","querySelector","documentElement","children","tagName","fixedStr","parent","foundParent","htmlHandler","fixHTML","newDOM","results","child","appendChild","hotsiteName","isValid","validForNewPackages","hotsite","params","prevValue","processHotSite","tester","checkHotSiteName","HotPage","mapName","testMap","map","testMaps","HotTestMap","destinations","dest","HotTestDestination","key2","destinationOrder","apis","component","componentUrl","ComponentClass","disableFileLoading","addTester","loadHotSite","jsonStr","ext","ppath","extname","normalize","HotIO","readTextFile","yaml","hotsitePath","saveHotSite","hotsiteStr","writeTextFile","forceContentLoading","loadUrlContent","newFile","loadContent","generateContent","routeKey","jsSrcPath","passArgs","apiScripts","apiCode","server","globalApi","sendJSContent","jsapi","libraryName","apiName","tempAPIContent","jsapipath","secret","serverConn","passSecretFromAPI","env","envKey","tempContent","developerModeStr","testerAPIStr","testing","web","testerAPIUrl","loadFiles","testerUrl","testerLaunchpadUrl","launchpadUrl","startDelayStr","fixContent","createExpressRoutes","expressApp","send","getWebTestingMaps","maps","getAPITestingMaps","getRouteKeyFromName","getRouteFromName","foundRoute","executeTests","execute","executeAllWebTests","executeAllAPITests","localFilepath","options","readyFunc","readyState","addEventListener","getElementsByTagName","innerHTML","tmpScripts","scripts","s","createElement","parentNode","removeChild","resolve2","reject2","onload","hasSrc","getAttribute","setAttribute","isReadyForTesting","wait","onReadyForTesting","testerAPIBaseUrl","client","HotClient","HotTesterAPI","onReady","setupTesters","processUrl","setupClientTesters","useOutput","hotStaqWebStart","customElements","processorComponents","define","HTMLElement","super","componentInfo","hotComponent","handleAttributes","attr","attrName","attrValue","attrTempName","onPreOutput","outputs","onPostOutput","componentOutputs","iKdx","htmlStr","addFunctionsTo","onParsed","onFixHTML","childrenToReadd","newObj","onParseDOM","throwErr","replaceWith","click","event","objectFunctions","getOwnPropertyNames","objFunc","isNewFunction","HotComponent","keepContext","onPrePlace","compHtmlElement2","onParentPlace","closestSelector","parentElm","foundNode","parentElement","documentSelector","placeElmInParent","parentNodeToCheck","placeHereParent","childToPlace","parentNodeCheckCounter","HTMLHtmlElement","placeHereArray","querySelectorAll","placeHere","placeHereAttrArray","placedChild","placeHereParentAttr","onPostPlace","temp","componentName","id","looseParseFromString","parser","xdom","hdom","elem","from","outerHTML","hotstaqElms","HotStaqWeb","hotstaqElm","getAttr","attrNames","loadPage","loggingLevel","router","apiLibrary","apiUrl","testerApiBaseUrl","dontReuseProcessor","passRawUrl","htmlSource","routerManager","routerWildcards","search","URLSearchParams","parseInt","hstqbaseredirect","decodeURI","history","replaceState","hotstaqErrors","hotstaqErrorElm","errorStatus","unsupportedBrowser","executeError","hotstaqRouterElms","hotstaqRouterElm","routerName","serveLocally","iJdx","childNodes","routerElm","routerPath","redirect","baseRedirect","base","routerSrc","src","checkPath","pathname","gotoPath","lowerServeLocally","lastSlashPos","routeWildcard","tempRouteWildcard","searchParams","modifiedSearchParams","encodeURI","hasHtmlSource","htmlSourceCheck","tempMode","parentLib","newAPI","displayUrl","displayContent","destination","autoStart","commandDelay","persistentData","parseTestObject","wildcard","selector","print","stdout","println","destroy","assert","errorMessage","mustBeVisible","ignoreMissingElementError","HotTester","driver","timeout","finishedLoading","hasBeenSetup","hasBeenDestroyed","setup","isWebRoute","destinationKey","waitForData","getTestPage","getTestPath","testDest","newDestination","paths","strs","getType","typeStr","typeDelimiter","typeValue","trim","newPathStr","newPath","cmd","executeTestAPIPath","testName","skipEventCalls","continueWhenTestIsComplete","runTestPath","onTestAPIPathStart","testCaseObject","onTestAPIPathEnd","executeTestAPIPaths","executeTestPagePath","stop","testPathName","testPath","onTestPagePathStart","onTestPagePathEnd","executeCommand","hasCmd","input","hasArguments","getCmdArgs","matches","match","tempMatch","seleniumTester","cmdFunc","cmdArgs","navigateToUrl","testObject","waitForTestElement","onCommand","executeTestPagePaths","interpretDestination","executeDestination","runTestPaths","onTestStart","onTestEnd","hasExecutedKeys","orderKey","executeDest","HotAPI","pageLoaded","heartbeat","request","testerObj","testPathsStrs","testObj","throwError","onFinishedLoading","__webpack_module_cache__","__webpack_require__","moduleId","cachedModule","__webpack_modules__","globalThis","HotModule","ServerRequest","HotTestDriver","HotTestElementOptions"],"sourceRoot":""}