render-template
Render templates with variable substitution using {{variable}} or ${variable} syntax. Use for generating formatted output, reports, commit messages, or any text requiring variable interpolation.
$ Instalar
git clone https://github.com/maslennikov-ig/claude-code-orchestrator-kit /tmp/claude-code-orchestrator-kit && cp -r /tmp/claude-code-orchestrator-kit/.claude/skills/render-template ~/.claude/skills/claude-code-orchestrator-kit// tip: Run this command in your terminal to install the skill
name: render-template description: Render templates with variable substitution using {{variable}} or ${variable} syntax. Use for generating formatted output, reports, commit messages, or any text requiring variable interpolation.
Render Template
Render templates with variable substitution, supporting various syntax formats and helper functions.
When to Use
- Format commit messages with dynamic data
- Generate report sections with variables
- Create formatted outputs from templates
- Replace placeholders in text templates
- Consolidate formatting logic across Skills
Instructions
Step 1: Receive Template and Data
Accept template string and variable data.
Expected Input:
template: String (template with placeholders)variables: Object (key-value pairs for substitution)syntax: String (optional: mustache|shell|mixed, default: mustache)
Supported Syntax:
- Mustache:
{{variable}},{{object.property}} - Shell:
${variable},${VARIABLE} - Mixed: Supports both
Step 2: Parse Template
Identify all placeholders in template.
Placeholder Patterns:
{{variable}}: Simple variable{{object.property}}: Nested property{{#if condition}}...{{/if}}: Conditional (optional){{#each array}}...{{/each}}: Loop (optional)
Step 3: Resolve Variables
Replace placeholders with values from variables object.
Resolution Rules:
- Direct match:
{{name}}→variables.name - Nested property:
{{user.name}}→variables.user.name - Missing variable: Replace with empty string or keep placeholder (configurable)
- Undefined: Replace with empty string
Step 4: Apply Filters (Optional)
Support simple filters if specified.
Common Filters:
{{variable | uppercase}}: Convert to uppercase{{variable | lowercase}}: Convert to lowercase{{variable | capitalize}}: Capitalize first letter{{date | format:YYYY-MM-DD}}: Format date
Step 5: Return Rendered Output
Return final rendered string.
Expected Output: String (template with variables replaced)
Error Handling
- Missing Variables: Replace with empty string or warn (configurable)
- Invalid Template Syntax: Return error describing syntax issue
- Circular References: Detect and return error
- Type Mismatch: Convert to string automatically
Examples
Example 1: Simple Variable Substitution
Input:
{
"template": "Hello {{name}}, your score is {{score}}!",
"variables": {
"name": "Alice",
"score": 95
},
"syntax": "mustache"
}
Output:
Hello Alice, your score is 95!
Example 2: Nested Properties
Input:
{
"template": "User: {{user.name}} ({{user.email}})\nRole: {{user.role}}",
"variables": {
"user": {
"name": "Bob",
"email": "bob@example.com",
"role": "admin"
}
}
}
Output:
User: Bob (bob@example.com)
Role: admin
Example 3: Shell Syntax
Input:
{
"template": "Version: ${VERSION}\nDate: ${RELEASE_DATE}",
"variables": {
"VERSION": "0.8.0",
"RELEASE_DATE": "2025-10-17"
},
"syntax": "shell"
}
Output:
Version: 0.8.0
Date: 2025-10-17
Example 4: Commit Message Template
Input:
{
"template": "{{type}}({{scope}}): {{description}}\n\n{{body}}\n\n🤖 Generated with Claude Code\nCo-Authored-By: Claude <noreply@anthropic.com>",
"variables": {
"type": "feat",
"scope": "auth",
"description": "add OAuth2 support",
"body": "Implemented OAuth2 flow with token refresh.\nSupports Google and GitHub providers."
}
}
Output:
feat(auth): add OAuth2 support
Implemented OAuth2 flow with token refresh.
Supports Google and GitHub providers.
🤖 Generated with Claude Code
Co-Authored-By: Claude <noreply@anthropic.com>
Example 5: Missing Variables
Input:
{
"template": "Name: {{name}}\nAge: {{age}}\nCity: {{city}}",
"variables": {
"name": "Alice"
}
}
Output (with empty string replacement):
Name: Alice
Age:
City:
Output (with keep placeholder):
Name: Alice
Age: {{age}}
City: {{city}}
Example 6: Report Header Template
Input:
{
"template": "# {{reportType}} Report: {{version}}\n\n**Generated**: {{timestamp}}\n**Status**: {{statusEmoji}} {{status}}\n**Version**: {{version}}",
"variables": {
"reportType": "Bug Hunting",
"version": "2025-10-17",
"timestamp": "2025-10-17 14:30:00 UTC",
"statusEmoji": "✅",
"status": "success"
}
}
Output:
# Bug Hunting Report: 2025-10-17
**Generated**: 2025-10-17 14:30:00 UTC
**Status**: ✅ success
**Version**: 2025-10-17
Validation
- Replaces simple variables correctly
- Handles nested properties
- Supports multiple syntax formats
- Handles missing variables gracefully
- Converts types to strings
- Preserves formatting (line breaks, indentation)
- Detects circular references
- Returns clear error messages
Supporting Files
None required - pure template rendering logic.
Integration with Other Skills
This Skill consolidates formatting logic used by:
- format-commit-message: Use render-template for message formatting
- generate-report-header: Use render-template for header generation
- format-todo-list: Use render-template for activeForm generation
- generate-changelog: Use render-template for section formatting
Example Integration:
Instead of: Hard-coded string formatting in each Skill
Use: render-template Skill with predefined templates
Result: Consistent formatting, easier to maintain
Repository
