2020-11-05 16:58:23 +00:00
|
|
|
const shim = require('./shim').default;
|
|
|
|
const time = require('./time').default;
|
2019-07-20 15:13:10 -06:00
|
|
|
const Mustache = require('mustache');
|
|
|
|
|
|
|
|
const TemplateUtils = {};
|
|
|
|
|
|
|
|
|
|
|
|
// Mustache escapes strings (including /) with the html code by default
|
|
|
|
// This isn't useful for markdown so it's disabled
|
2020-05-21 09:14:33 +01:00
|
|
|
Mustache.escape = text => {
|
2019-07-29 15:43:53 +02:00
|
|
|
return text;
|
|
|
|
};
|
2019-07-20 15:13:10 -06:00
|
|
|
|
2020-11-12 13:41:37 -05:00
|
|
|
function beginningOfWeek(index) {
|
|
|
|
// index: 0 for Sunday, 1 for Monday
|
|
|
|
const thisDate = new Date();
|
|
|
|
const day = thisDate.getDay(),
|
|
|
|
diff = day >= index ? day - index : 6 - day;
|
|
|
|
|
|
|
|
return new Date().setDate(thisDate.getDate() - diff);
|
|
|
|
}
|
|
|
|
|
2019-07-20 15:13:10 -06:00
|
|
|
TemplateUtils.render = function(input) {
|
2019-08-29 10:35:43 -06:00
|
|
|
// new template variables can be added here
|
|
|
|
// If there are too many, this should be moved to a new file
|
|
|
|
// view needs to be set in this function so that the formats reflect settings
|
|
|
|
const view = {
|
|
|
|
date: time.formatMsToLocal(new Date().getTime(), time.dateFormat()),
|
|
|
|
time: time.formatMsToLocal(new Date().getTime(), time.timeFormat()),
|
|
|
|
datetime: time.formatMsToLocal(new Date().getTime()),
|
|
|
|
custom_datetime: () => {
|
|
|
|
return (text, render) => {
|
|
|
|
return render(time.formatMsToLocal(new Date().getTime(), text));
|
|
|
|
};
|
|
|
|
},
|
2020-11-12 13:41:37 -05:00
|
|
|
bowm: time.formatMsToLocal(beginningOfWeek(1), time.dateFormat()),
|
|
|
|
bows: time.formatMsToLocal(beginningOfWeek(0), time.dateFormat()),
|
2019-08-29 10:35:43 -06:00
|
|
|
};
|
|
|
|
|
2019-07-20 15:13:10 -06:00
|
|
|
return Mustache.render(input, view);
|
2019-07-29 15:43:53 +02:00
|
|
|
};
|
2019-07-20 15:13:10 -06:00
|
|
|
|
|
|
|
TemplateUtils.loadTemplates = async function(filePath) {
|
2020-03-13 23:46:14 +00:00
|
|
|
const templates = [];
|
2019-07-29 15:43:53 +02:00
|
|
|
let files = [];
|
|
|
|
|
|
|
|
if (await shim.fsDriver().exists(filePath)) {
|
|
|
|
try {
|
|
|
|
files = await shim.fsDriver().readDirStats(filePath);
|
|
|
|
} catch (error) {
|
|
|
|
let msg = error.message ? error.message : '';
|
2019-09-19 22:51:18 +01:00
|
|
|
msg = `Could not read template names from ${filePath}\n${msg}`;
|
2019-07-29 15:43:53 +02:00
|
|
|
error.message = msg;
|
|
|
|
throw error;
|
2019-07-20 15:13:10 -06:00
|
|
|
}
|
|
|
|
|
2019-08-29 10:34:54 -06:00
|
|
|
// Make sure templates are always in the same order
|
|
|
|
// sensitivity ensures that the sort will ignore case
|
2020-02-04 22:09:34 +00:00
|
|
|
files.sort((a, b) => { return a.path.localeCompare(b.path, undefined, { sensitivity: 'accent' }); });
|
2019-08-29 10:34:54 -06:00
|
|
|
|
2020-10-09 18:35:46 +01:00
|
|
|
for (const file of files) {
|
2019-07-29 15:43:53 +02:00
|
|
|
if (file.path.endsWith('.md')) {
|
|
|
|
try {
|
2020-03-13 23:46:14 +00:00
|
|
|
const fileString = await shim.fsDriver().readFile(`${filePath}/${file.path}`, 'utf-8');
|
2019-07-29 15:43:53 +02:00
|
|
|
templates.push({ label: file.path, value: fileString });
|
|
|
|
} catch (error) {
|
|
|
|
let msg = error.message ? error.message : '';
|
2019-09-19 22:51:18 +01:00
|
|
|
msg = `Could not load template ${file.path}\n${msg}`;
|
2019-07-29 15:43:53 +02:00
|
|
|
error.message = msg;
|
|
|
|
throw error;
|
|
|
|
}
|
|
|
|
}
|
2020-10-09 18:35:46 +01:00
|
|
|
}
|
2019-07-20 15:13:10 -06:00
|
|
|
}
|
|
|
|
|
2019-07-29 15:43:53 +02:00
|
|
|
return templates;
|
|
|
|
};
|
|
|
|
|
2019-07-20 15:13:10 -06:00
|
|
|
module.exports = TemplateUtils;
|