function ayRegisterHelpers() { Handlebars.registerHelper("ayCaps", function (aString) { return aString.toUpperCase(); }); Handlebars.registerHelper("ayMarkdown", function (astring) { return marked(astring, { breaks: true }); }); Handlebars.registerHelper("ayJSON", function (obj) { return JSON.stringify(obj, null, 3); }); Handlebars.registerHelper("ayLink", function (text, url) { var url = Handlebars.escapeExpression(url), text = Handlebars.escapeExpression(text); return new Handlebars.SafeString("" + text + ""); }); Handlebars.registerHelper("ayLogo", function (size) { var url = `${Handlebars.escapeExpression( this.ayServerMetaData.ayApiUrl )}logo/${size}`; return new Handlebars.SafeString(""); }); Handlebars.registerHelper("ayT", function (translationKey) { if (ayTranslationKeyCache[translationKey] == undefined) { return translationKey; } return ayTranslationKeyCache[translationKey]; }); } //eof async function ayPreRender(ayAllData) { if (typeof ayPrepareData === "function") { return await ayPrepareData(ayAllData); } else { return ayAllData; } } ////////////////////////////////// // cache to hold translations keys // var ayTranslationKeyCache = {}; /////////////////////////////////// // GET TRANSLATIONS FROM API SERVER // async function ayGetTranslations(keys) { try { let r = await fetch(route, { method: "get", mode: "cors", headers: { Accept: "application/json", "Content-Type": "application/json", Authorization: token } }); return await r.json(); } catch (error) { //fundamental error, can't proceed with this call // handleError("GET", error, route); //todo: deal with this properly throw error; } } /////////////////////////////////// // GET DATA FROM API SERVER // async function ayGetFromAPI(route, token) { token = token || AYMETA.ayClientMetaData.Authorization; try { let r = await fetch(route, { method: "get", mode: "cors", headers: { Accept: "application/json", "Content-Type": "application/json", Authorization: token } }); return await r.json(); } catch (error) { //fundamental error, can't proceed with this call // handleError("GET", error, route); //todo: deal with this properly throw error; } } /////////////////////////////////// // POST DATA TO API SERVER // async function ayPostToAPI(route, data, token) { token = token || AYMETA.ayClientMetaData.Authorization; try { fetchOptions = { method: "post", mode: "cors", headers: { Accept: "application/json", "Content-Type": "application/json", Authorization: token }, body: JSON.stringify(data) }; let r = await fetch(route, fetchOptions); return await r.json(); } catch (error) { //todo: better handle this throw error; } } /* async function ayPrepareData(reportData) { //this function (if present) is called with the report data //before the report is rendered //modify data as required here and return it to change the data before the report renders //Example of using API GET method to fetch data from API server and make it available to the report template let route=`${reportData.ayServerMetaData.ayApiUrl}server-info`; //Put the data into the main report data object so it's available to the template reportData.myData={ServerInfo:await ayGetFromAPI(route, reportData.ayClientMetaData.Authorization)}; //Example API POST method to fetch data from api server route=`${reportData.ayServerMetaData.ayApiUrl}search`; let searchPostData={phrase: "Fish"}; reportData.myData.SearchResults=await ayPostToAPI(route, reportData.ayClientMetaData.Authorization,searchPostData); return reportData; }

ayServerMetaData

{{ ayJSON ayServerMetaData }}

ayClientMetaData

{{ ayJSON ayClientMetaData }}

ayReportMetaData

{{ ayJSON ayReportMetaData }}

myData

(Fetched dynamically from API route enum-list/list/AyaType)
{{ ayJSON myData }}

ayReportData

{{#each ayReportData}}

{{ Name }}

Notes: {{ Notes }}
{{/each}}
*/