Blogs
📆 2025-12-22 19:34

Code Templates

Code generation templates are text template files written in razor syntax with a .razor suffix. They are used to generate specific code content or provide references for MCP tools.

Viewing Template Files

You can view template files through the Basic Data/Templates page in Studio.

Alternatively, you can view template files in the templates directory at the project root. The page will read and display templates from this directory.

Template Management

First, add a template category (corresponding to a directory name), then add template files within that category.

You can add templates through the UI page or directly in the templates directory.

Tip

When adding templates through UI, it will preliminarily verify whether your content conforms to the razor syntax specification.

Template Context and Variables

Template context and variables are data elements that can be used when writing templates. When creating a generation task, you can select the context type and custom variable list.

Context Structure

Property Description
Namespace @Namespace
Model Name @ModelName
Type Description @Description
New Line @NewLine
Entity Properties @PropertyInfos
Variable List @Variables

For entity data types, additionally includes:

Type Variable
Add DTO @AddPropertyInfos
Update DTO @UpdatePropertyInfos
List DTO @ItemPropertyInfos
Detail DTO @DetailPropertyInfos
Filter DTO @FilterPropertyInfos

The PropertyInfos structure of DTOs is the same as that of entities.

PropertyInfo Structure

Property Description
Type Type
Name Name
Display Name DisplayName
Is Array IsList
Is Public IsPublic
Is Navigation IsNavigation
Is Enum IsEnum
XML Comment CommentXml
Comment Summary CommentSummary
Is Required IsRequired
Is Nullable IsNullable
Min Length MinLength
Max Length MaxLength

Built-in Functions

Method Example
ToHyphen str.ToHyphen()
ToSnakeLower str.ToSnakeLower()
ToPascalCase str.ToPascalCase()
ToCamelCase str.ToCamelCase()

Path Variables

Variables that can be used in paths when defining generation steps:

Property Description
Model Name (CamelPascal) ModelName
Model Name (a-b-c) ModelNameHyphen

Template Example

Next, let's add a template.

  1. In the menu, find Basic Data/Templates, click the + sign on the right side of the directory to add a new template category, name it sample.

  2. Click the + sign on the right template list to add a new template, name it ModelDetail, with the following content:

    @foreach (var item in PropertyInfos)
    {
        <p>@item.Name</p>
    }
    

We will use this template in subsequent code generation tasks.

The template itself follows the razor syntax specification. You can create a templates/sample/ModelDetail.razor file in the project directory and edit it with tools like VS Code. After adding, refresh the list to see the template.

Tip

Writing templates is not straightforward. You need to understand what variables and data structures you can use. You can use MCP tools to generate a template as a starting point and modify it accordingly.