projectrules.ai

Client-Side Coding Style Guidelines

FrontendHTMLCSSSecurityJavaScript

Description

Guidelines for 033-client-style

Globs

**/*.html**/*.sass**/*.css**/*.coffee
---
description: Guidelines for 033-client-style
globs: **/*.html,**/*.sass,**/*.css,**/*.coffee
---

# Client-Side Coding Style Guidelines

## Frontend Guidelines

- **Libraries**: Use Underscore.js for operations on JS data structures
- **Frontend**: Blaze framework for templates and UI components

## HTML/Blaze Guidelines

- Only use <a> tags for real links to other pages/external sources
- Never use `href="#"` without `e.preventDefault()` in event handler
- Templates naming: under_scored
- Boolean helpers should return true/false (not string classes)
- Use dash-separated attributes and class/id names in HTML

## CSS/SASS Guidelines

- Use 2-space indentation
- Prefer classes over IDs (except for form inputs with labels)
- Use hyphen-separated names for classes/IDs
- Avoid global rules (scope styles to specific containers)
- Avoid inline styling and `!important` unless absolutely necessary

## Security Guidelines

- Always use `xssGuard` helper with triple braces: `{{{xssGuard content}}}` instead of `{{{content}}}`