Files
alexei.dolgolyov 563716fa76 feat: entity cache system, nav UX improvements, split CLAUDE.md
- Add $state-based entity cache layer with 30s TTL, request deduplication,
  and local mutation helpers (entity-cache.svelte.ts + caches.svelte.ts)
- Wire all 10 page components to use shared caches for cross-page data
- Add slide animation for nav tree expand/collapse with rotating chevron
- Remove aggregate count badges from container nav nodes (keep on leaves)
- Convert Targets from flat leaf to group with per-type children
  (Telegram, Webhook, Email, Discord, Slack, ntfy, Matrix)
- Add URL-based type filtering on Targets page with per-type descriptions
- Add Bots group children for Email and Matrix alongside Telegram
- Tab-based routing for bots page (?tab=telegram/email/matrix)
- Add per-type target counts and email/matrix bot counts to /status/counts
- Split CLAUDE.md into focused context files under .claude/docs/
- Fix .gitignore: scope lib/ to root, allow .claude/docs/ tracking
- Clear all caches on logout
- Reset form state when switching target type tabs
2026-03-21 23:35:50 +03:00

1.4 KiB

Template System Sync Rules

IMPORTANT: When adding or changing template context variables, you MUST update ALL of these in sync:

  1. packages/core/.../templates/context.pybuild_template_context() where variables are computed
  2. packages/server/.../api/template_configs.py_SAMPLE_CONTEXT dict (for preview rendering)
  3. packages/server/.../api/template_configs.pyget_template_variables() endpoint (event_vars, asset_fields, album_fields, scheduled_vars, per-slot variable dicts)
  4. packages/core/.../templates/defaults/{en,ru}/*.jinja2 — default template files using the new variables
  5. packages/core/.../providers/immich/provider.pyIMMICH_VARIABLES list (provider-specific variable definitions)
  6. packages/server/.../api/command_template_configs.pyget_command_variables() endpoint (for command response templates)

IMPORTANT: Variable reference endpoints MUST document child/nested properties, not only top-level variables. When a variable is a list of dicts (e.g. assets, albums, events, commands), the endpoint MUST include a corresponding *_fields dict describing the child properties (e.g. asset_fields: {"id": "...", "filename": "..."}) so the frontend can show them (e.g. {{ asset.id }}, {{ album.name }}). Never list only "assets": "List of asset dicts" — always specify what fields each dict contains.