@ololoepepe/template-renderer 0.1.37 → 0.1.39
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.
- package/package.json +3 -3
- package/src/template-renderer.js +13 -3
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@ololoepepe/template-renderer",
|
|
3
|
-
"version": "0.1.
|
|
3
|
+
"version": "0.1.39",
|
|
4
4
|
"description": "Lodash-based template renderer",
|
|
5
5
|
"main": "index.js",
|
|
6
6
|
"scripts": {
|
|
@@ -21,8 +21,8 @@
|
|
|
21
21
|
},
|
|
22
22
|
"homepage": "https://gitlab.void-walkers.com/libs/node.js/template-renderer#README",
|
|
23
23
|
"devDependencies": {
|
|
24
|
-
"eslint": "8.
|
|
25
|
-
"eslint-config-xo": "^0.
|
|
24
|
+
"eslint": "8.18.0",
|
|
25
|
+
"eslint-config-xo": "^0.41.0",
|
|
26
26
|
"mocha": "^10.0.0"
|
|
27
27
|
},
|
|
28
28
|
"dependencies": {
|
package/src/template-renderer.js
CHANGED
|
@@ -120,6 +120,18 @@ class TemplateRenderer {
|
|
|
120
120
|
return template;
|
|
121
121
|
}
|
|
122
122
|
|
|
123
|
+
_preloadRecursiveSync(extension, prefix = '') {
|
|
124
|
+
const path = `${this.templatesDir}${prefix ? `/${prefix}` : ''}`;
|
|
125
|
+
|
|
126
|
+
const entries = fs.readdirSync(path);
|
|
127
|
+
|
|
128
|
+
entries.filter(entryName => entryName.endsWith(extension) && fs.statSync(`${path}/${entryName}`).isFile())
|
|
129
|
+
.forEach(fileName => this.getTemplateSync(`${prefix ? `${prefix}/` : ''}${fileName}`));
|
|
130
|
+
|
|
131
|
+
entries.filter(entryName => fs.statSync(`${path}/${entryName}`).isDirectory())
|
|
132
|
+
.forEach(dirName => this._preloadRecursiveSync(extension, `${prefix ? `${prefix}/` : ''}${dirName}`));
|
|
133
|
+
}
|
|
134
|
+
|
|
123
135
|
async getTemplate(name) {
|
|
124
136
|
if (this._templateCache.has(name)) {
|
|
125
137
|
return this._templateCache.get(name);
|
|
@@ -144,9 +156,7 @@ class TemplateRenderer {
|
|
|
144
156
|
this._templateStringCache.clear();
|
|
145
157
|
this._templateCache.clear();
|
|
146
158
|
|
|
147
|
-
|
|
148
|
-
.filter(entryName => entryName.endsWith(extension) && fs.statSync(`${this.templatesDir}/${entryName}`).isFile())
|
|
149
|
-
.forEach(fileName => this.getTemplateSync(fileName));
|
|
159
|
+
this._preloadRecursiveSync(extension);
|
|
150
160
|
}
|
|
151
161
|
|
|
152
162
|
async renderTemplate(templateName, variables) {
|