@tstdl/base 0.84.23 → 0.84.24

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
- export declare const template: import("../../../templates/template.model.js").Template<import("../../../types.js").Record<string, boolean>, any, any>;
1
+ export declare const template: import("../../../templates/template.model.js").Template<import("../../../types.js").Record<string, boolean>, any, import("../../../types.js").Record>;
2
2
  export default template;
@@ -1,2 +1,2 @@
1
- declare const template: import("../../../templates/template.model.js").Template<import("../../../types.js").Record<string, boolean>, any, any>;
1
+ declare const template: import("../../../templates/template.model.js").Template<import("../../../types.js").Record<string, boolean>, any, import("../../../types.js").Record>;
2
2
  export default template;
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@tstdl/base",
3
- "version": "0.84.23",
3
+ "version": "0.84.24",
4
4
  "author": "Patrick Hein",
5
5
  "publishConfig": {
6
6
  "access": "public"
@@ -35,7 +35,7 @@
35
35
  "@types/nodemailer": "6.4",
36
36
  "@typescript-eslint/eslint-plugin": "5.59",
37
37
  "@typescript-eslint/parser": "5.59",
38
- "concurrently": "8.0",
38
+ "concurrently": "8.1",
39
39
  "esbuild": "0.17",
40
40
  "eslint": "8.41",
41
41
  "eslint-import-resolver-typescript": "3.5",
@@ -37,7 +37,7 @@ export declare class HandlebarsTemplateRenderer extends TemplateRenderer<'handle
37
37
  private readonly compileHandlebarsTemplate;
38
38
  constructor(templateResolverProvider: TemplateResolverProvider);
39
39
  canHandleType(type: string): boolean;
40
- _render(renderObject: HandlebarsTemplateRenderObject, context?: object): Promise<string>;
40
+ _render(renderObject: HandlebarsTemplateRenderObject, context: Record): Promise<string>;
41
41
  private _compileHandlebarsTemplate;
42
42
  private normalizePartial;
43
43
  }
@@ -1,3 +1,4 @@
1
+ import type { Record } from '../../types.js';
1
2
  import type { JsxTemplate } from '../resolvers/jsx.template-resolver.js';
2
3
  import type { TemplateRenderObject, TemplateRenderResult } from '../template.renderer.js';
3
4
  import { TemplateRenderer } from '../template.renderer.js';
@@ -5,5 +6,5 @@ export type JsxTemplateRenderObject = TemplateRenderObject<'jsx', undefined, Jsx
5
6
  export declare class JsxTemplateRenderer extends TemplateRenderer<'jsx', undefined> {
6
7
  constructor();
7
8
  canHandleType(type: string): boolean;
8
- _render({ template: TemplateComponent }: JsxTemplateRenderObject, context?: object): TemplateRenderResult;
9
+ _render({ template: TemplateComponent }: JsxTemplateRenderObject, context: Record): TemplateRenderResult;
9
10
  }
@@ -1,3 +1,4 @@
1
+ import type { Record } from '../../types.js';
1
2
  import type { MJMLParsingOptions } from 'mjml-core';
2
3
  import { TemplateRendererProvider } from '../template-renderer.provider.js';
3
4
  import type { TemplateRenderObject, TemplateRenderResult } from '../template.renderer.js';
@@ -11,5 +12,5 @@ export declare class MjmlTemplateRenderer extends TemplateRenderer<MjmlRendererS
11
12
  private readonly rendererProvider;
12
13
  constructor(rendererProvider: TemplateRendererProvider);
13
14
  canHandleType(type: string): boolean;
14
- _render({ renderer, template, options }: MjmlTemplateRenderObject, context?: object): Promise<TemplateRenderResult>;
15
+ _render({ renderer, template, options }: MjmlTemplateRenderObject, context: Record): Promise<TemplateRenderResult>;
15
16
  }
@@ -79,7 +79,7 @@ let MjmlTemplateRenderer = class MjmlTemplateRenderer2 extends import_template_r
79
79
  renderer: "mjml",
80
80
  template: result
81
81
  };
82
- return this._render(preprocessedTemplate);
82
+ return this._render(preprocessedTemplate, context);
83
83
  }
84
84
  return (0, import_mjml.default)(template).html;
85
85
  }
@@ -1,8 +1,10 @@
1
+ import type { Record } from '../../types.js';
2
+ import type { StringTemplate } from '../resolvers/string.template-resolver.js';
1
3
  import type { TemplateRenderObject, TemplateRenderResult } from '../template.renderer.js';
2
4
  import { TemplateRenderer } from '../template.renderer.js';
3
- export type StringTemplateRenderObject = TemplateRenderObject<'string', undefined, string>;
5
+ export type StringTemplateRenderObject = TemplateRenderObject<'string', undefined, StringTemplate>;
4
6
  export declare class StringTemplateRenderer extends TemplateRenderer<'string', undefined> {
5
7
  constructor();
6
8
  canHandleType(type: string): boolean;
7
- _render({ template }: StringTemplateRenderObject, _context?: object): TemplateRenderResult;
9
+ _render({ template }: StringTemplateRenderObject, context: Record): Promise<TemplateRenderResult>;
8
10
  }
@@ -22,6 +22,7 @@ __export(string_template_renderer_exports, {
22
22
  });
23
23
  module.exports = __toCommonJS(string_template_renderer_exports);
24
24
  var import_container = require("../../container/index.js");
25
+ var import_type_guards = require("../../utils/type-guards.js");
25
26
  var import_template_renderer = require("../template.renderer.js");
26
27
  var __decorate = function(decorators, target, key, desc) {
27
28
  var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
@@ -44,8 +45,11 @@ let StringTemplateRenderer = class StringTemplateRenderer2 extends import_templa
44
45
  canHandleType(type) {
45
46
  return type == "string";
46
47
  }
47
- _render({ template }, _context) {
48
- return template;
48
+ async _render({ template }, context) {
49
+ if ((0, import_type_guards.isString)(template)) {
50
+ return template;
51
+ }
52
+ return template(context);
49
53
  }
50
54
  };
51
55
  StringTemplateRenderer = __decorate([
@@ -1,13 +1,14 @@
1
- import type { TypedOmit } from '../../types.js';
1
+ import type { Record, TypedOmit } from '../../types.js';
2
2
  import { TemplateField } from '../template.model.js';
3
3
  import type { TemplateRenderer, TemplateRendererOptions, TemplateRendererString } from '../template.renderer.js';
4
4
  import { TemplateResolver } from '../template.resolver.js';
5
+ export type StringTemplate = string | ((context: Record) => string | Promise<string>);
5
6
  export declare class StringTemplateField<Renderer extends string = string, Options = any> extends TemplateField<'string', Renderer, Options> {
6
- template: string;
7
+ template: StringTemplate;
7
8
  }
8
9
  export declare class StringTemplateResolver extends TemplateResolver<StringTemplateField> {
9
10
  constructor();
10
11
  canHandle(resolver: string): boolean;
11
- resolve(field: StringTemplateField): string;
12
+ resolve(field: StringTemplateField): StringTemplate;
12
13
  }
13
14
  export declare function stringTemplateField<Renderer extends TemplateRenderer>(field: TypedOmit<StringTemplateField<Renderer[TemplateRendererString], Renderer[TemplateRendererOptions]>, 'resolver'>): StringTemplateField<Renderer[TemplateRendererString], Renderer[TemplateRendererOptions]>;
@@ -45,8 +45,8 @@ class StringTemplateField extends import_template_model.TemplateField {
45
45
  template;
46
46
  }
47
47
  __decorate([
48
- (0, import_schema.Property)(),
49
- __metadata("design:type", String)
48
+ (0, import_schema.Union)(String, Function),
49
+ __metadata("design:type", Object)
50
50
  ], StringTemplateField.prototype, "template", void 0);
51
51
  let StringTemplateResolver = class StringTemplateResolver2 extends import_template_resolver.TemplateResolver {
52
52
  constructor() {
@@ -11,7 +11,7 @@ export type TemplateFields<Fields extends Record<string, boolean>, Resolver exte
11
11
  } & {
12
12
  [P in keyof PickBy<Fields, false>]?: TemplateField<Resolver, Renderer, Options>;
13
13
  }>;
14
- export declare abstract class Template<Fields extends Record<string, boolean> = Record<string, boolean>, TemplateOptions = any, Context extends object = any> {
14
+ export declare abstract class Template<Fields extends Record<string, boolean> = Record<string, boolean>, TemplateOptions = any, Context extends Record = Record> {
15
15
  readonly [templateContext]?: Context;
16
16
  /** name of template */
17
17
  name: string;
@@ -14,7 +14,7 @@ export declare const templateRendererOptions: unique symbol;
14
14
  export declare abstract class TemplateRenderer<Renderer extends string = string, Options = any> {
15
15
  readonly [templateRendererString]: Renderer;
16
16
  readonly [templateRendererOptions]: Options;
17
- render(template: TemplateRenderObject<Renderer, Options>, context?: object): Promise<TemplateRenderResult>;
17
+ render(template: TemplateRenderObject<Renderer, Options>, context?: Record): Promise<TemplateRenderResult>;
18
18
  abstract canHandleType(type: string): boolean;
19
- protected abstract _render(renderObject: TemplateRenderObject<Renderer, Options>, context?: object): TemplateRenderResult | Promise<TemplateRenderResult>;
19
+ protected abstract _render(renderObject: TemplateRenderObject<Renderer, Options>, context: Record): TemplateRenderResult | Promise<TemplateRenderResult>;
20
20
  }
@@ -30,6 +30,6 @@ const templateRendererOptions = Symbol("templateRendererOptions");
30
30
  class TemplateRenderer {
31
31
  async render(template, context) {
32
32
  const parsedContext = (0, import_type_guards.isDefined)(template.contextSchema) ? import_schema.Schema.parse(template.contextSchema, context) : context;
33
- return this._render(template, parsedContext);
33
+ return this._render(template, parsedContext ?? {});
34
34
  }
35
35
  }