Templaty 1.0.1
dotnet add package Templaty --version 1.0.1
NuGet\Install-Package Templaty -Version 1.0.1
<PackageReference Include="Templaty" Version="1.0.1" />
<PackageVersion Include="Templaty" Version="1.0.1" />
<PackageReference Include="Templaty" />
paket add Templaty --version 1.0.1
#r "nuget: Templaty, 1.0.1"
#:package Templaty@1.0.1
#addin nuget:?package=Templaty&version=1.0.1
#tool nuget:?package=Templaty&version=1.0.1
Templaty - .net library for templating
1. Introduction
Templaty is a lightweight .net library based on Scriban library providing developers easy way to realize flexible templates feature into projects.
1.1 Use cases
- E-mailing message templates;
- Localization message templates;
- Text messages templates;
1.2 Concepts
Templaty is simple. It operates a few several concepts:
- Content - template content / message content;
- Template object - a
class
orrecord
that has[Template.Source(...)]
attribute and implementsITemplate
interface; - Store - service implements
ITemplateContentStore
where Content is storing; - Loader - service that realizes Content loading;
- Builder - main service builds result by Template object and Content;
2. Quick start
First of all, you need to import Templaty
as package;
dotnet add package Templaty
2.1 ASP.NET
To use Templaty into ASP.NET projects just using into Startup
or Program
:
builder.Services.UseTemplaty(configator => configator.AddResourceStoreAssembly(typeof(Program).Assembly));
By default Templaty provides only ResourceTemplateContentStore
that registering while UseTemplate
executing.
It allows you to use embedded resource files as templates and use it around project;
2.2 Make your own template
Let's look at an example into project Templaty.Simple
(see Samples
).
- Create template content file (example:
WheaterDistribution.txt
);
Date: {{date}}
Temperature: {{temperature}} °C
Summary: {{summary}}
Mark
WheaterDistribution.txt
asEmbedded Resource
(see: Build actions);Create a model with data
WheaterDistributionTemplate
;
[Template.Source("Templaty.Simple.Wheater.Notifications.WheaterDistribution.txt", Template.StoreType.Resources)]
internal sealed record WheaterDistributionTemplate(DateOnly Date, int Temperature, string? Summary) : ITemplate;
- Use
ITemplateBuilder
to get end-message from template;
var template = new WheaterDistributionTemplate(
DateOnly.FromDateTime(DateTime.Now.AddDays(2)),
Random.Shared.Next(-20, 55),
Summaries[Random.Shared.Next(Summaries.Length)]
);
var result = await _templateBuilder.LoadAndBuild(template);
Result will be something like that:
Date: 16.03.2025
Temperature: 8 °C
Summary: Balmy
3. Own store
Templaty allows you to make your own store that will contains template content whenever you want.
- Create new class that implements
ITemplateContentStore
;
internal sealed class LocalizableResourceStore : ITemplateContentStore
{
private readonly IStringLocalizer<Templates> _stringLocalizer;
public LocalizableResourceStore(IStringLocalizer<Templates> stringLocalizer)
{
_stringLocalizer = stringLocalizer;
}
public Template.StoreType Type => Template.StoreType.Localizations;
public Task<string> GetContent(string path, CancellationToken cancellationToken = default)
{
var localizedString = _stringLocalizer.GetString(path);
if (localizedString.ResourceNotFound)
{
throw new TemplateContentMissedException(path, Type, $"Localization '{path}' was not found.");
}
else if (string.IsNullOrWhiteSpace(localizedString))
{
return Task.FromResult(path);
}
return Task.FromResult(localizedString.Value);
}
}
- Create new class that implements
ITemplateContentStoreFactory
;
internal sealed class LocalizableResourceStoreFactory(IStringLocalizer<Templates> stringLocalizer) : ITemplateContentStoreFactory
{
public Template.StoreType Type => Template.StoreType.Localizations;
public string Name => "default";
public ITemplateContentStore Create() => new LocalizableResourceStore(stringLocalizer);
}
- Register created service-factory as
ITemplateContentStoreFactory
or configurator method.AddStore()
;
builder.Services.AddSingleton<LocalizableResourceStoreFactory>();
builder.Services.UseTemplaty(
configator => configator
.AddResourceStoreAssembly(typeof(Program).Assembly)
.AddStore(x => x.GetRequiredService<LocalizableResourceStoreFactory>())
);
Product | Versions Compatible and additional computed target framework versions. |
---|---|
.NET | net8.0 is compatible. net8.0-android was computed. net8.0-browser was computed. net8.0-ios was computed. net8.0-maccatalyst was computed. net8.0-macos was computed. net8.0-tvos was computed. net8.0-windows was computed. net9.0 was computed. net9.0-android was computed. net9.0-browser was computed. net9.0-ios was computed. net9.0-maccatalyst was computed. net9.0-macos was computed. net9.0-tvos was computed. net9.0-windows was computed. net10.0 was computed. net10.0-android was computed. net10.0-browser was computed. net10.0-ios was computed. net10.0-maccatalyst was computed. net10.0-macos was computed. net10.0-tvos was computed. net10.0-windows was computed. |
-
net8.0
- Microsoft.Extensions.DependencyInjection.Abstractions (>= 9.0.0)
- Scriban (>= 5.9.0)
- Templaty.Abstractions (>= 1.0.1)
NuGet packages (1)
Showing the top 1 NuGet packages that depend on Templaty:
Package | Downloads |
---|---|
Templaty.Postgres
Library with Postgres store for Templaty |
GitHub repositories
This package is not used by any popular GitHub repositories.