mirror of
https://github.com/hyperdxio/hyperdx
synced 2026-04-21 13:37:15 +00:00
## Summary - **Link colors**: Override `--mantine-color-anchor` in ClickStack so links use blue in light mode and yellow in dark mode instead of Mantine's default primary color derivation. - **Checkbox & Radio**: Use `vars` overrides to apply ClickStack accent color to active checkboxes and radios, with contrasting icon colors for readability in both themes. - **Slider styling**: Replace inline `styles` with semantic tokens (`--color-slider-bar`, `--color-slider-thumb`, `--color-slider-dot`, etc.) and CSS modules for consistent 6px solid dot marks and token-based thumb/mark colors across both ClickStack and HyperDX themes. - **Subtle Button variant**: Add `variant="subtle"` support to `Button` in both themes (transparent background, hover highlight, standard text color). - **Docs**: Update `code_style.md` to document `variant="subtle"` as accepted for both `Button` and `ActionIcon`. ### Before <img width="3896" height="1296" alt="image" src="https://github.com/user-attachments/assets/5a2f109a-88e3-46a1-8e38-95d51dfd5a6b" /> <img width="1806" height="2570" alt="image" src="https://github.com/user-attachments/assets/70cf6786-a487-477b-868f-7f2a18746053" /> ### After <img width="3596" height="1358" alt="image" src="https://github.com/user-attachments/assets/0ad3b885-e6b8-4edd-aade-97516740ed6b" /> <img width="1874" height="2684" alt="image" src="https://github.com/user-attachments/assets/fa00f2cc-49f8-4bd3-8379-3665b760bd4e" /> ## Test plan - [ ] Verify links are blue in ClickStack light mode and yellow in dark mode - [ ] Verify checkboxes and radio buttons use the accent color when active in both themes - [ ] Verify checkbox icon is dark in dark mode for contrast - [ ] Verify slider marks are solid 6px dots, with correct colors in both modes - [ ] Verify slider thumb uses theme-appropriate colors - [ ] Verify `<Button variant="subtle">` renders correctly in both themes - [ ] Verify no visual regressions in HyperDX theme slider styling
107 lines
4.5 KiB
Markdown
107 lines
4.5 KiB
Markdown
# Code Style & Best Practices
|
|
|
|
> **Note**: Pre-commit hooks handle formatting automatically. Focus on implementation patterns.
|
|
|
|
## TypeScript
|
|
|
|
- Avoid `any` - use proper typing
|
|
- Use Zod schemas for runtime validation
|
|
- Define clear interfaces for data structures
|
|
- Implement proper error boundaries
|
|
|
|
## Code Organization
|
|
|
|
- **Single Responsibility**: One clear purpose per component/function
|
|
- **File Size**: Max 300 lines - refactor when approaching limit
|
|
- **DRY**: Reuse existing functionality; consolidate duplicates
|
|
- **In-Context Learning**: Explore similar files before implementing
|
|
|
|
## React Patterns
|
|
|
|
- Functional components with hooks (not class components)
|
|
- Extract reusable logic into custom hooks
|
|
- Define TypeScript interfaces for props
|
|
- Use proper keys for lists, memoization for expensive computations
|
|
|
|
## Mantine UI Components
|
|
|
|
The project uses Mantine UI with **custom variants** defined in `packages/app/src/theme/mantineTheme.ts`.
|
|
|
|
### Button & ActionIcon Variants (REQUIRED)
|
|
|
|
**ONLY use these variants for Button and ActionIcon components:**
|
|
|
|
| Variant | Use Case | Example |
|
|
|---------|----------|---------|
|
|
| `variant="primary"` | Primary actions (Submit, Save, Create, Run) | `<Button variant="primary">Save</Button>` |
|
|
| `variant="secondary"` | Secondary actions (Cancel, Clear, auxiliary actions) | `<Button variant="secondary">Cancel</Button>` |
|
|
| `variant="danger"` | Destructive actions (Delete, Remove, Rotate API Key) | `<Button variant="danger">Delete</Button>` |
|
|
| `variant="link"` | Link-style actions with no background or border (View Details, navigation-style CTAs) | `<Button variant="link">View Details</Button>` |
|
|
| `variant="subtle"` | Transparent background with hover highlight; for toolbar/utility controls that shouldn't draw attention until hovered (collapse toggles, close buttons, auxiliary actions) | `<Button variant="subtle">Filter</Button>` |
|
|
|
|
### Correct Usage
|
|
|
|
```tsx
|
|
<Button variant="primary">Save</Button>
|
|
<Button variant="secondary">Cancel</Button>
|
|
<Button variant="danger">Delete</Button>
|
|
<Button variant="subtle">Filter</Button>
|
|
<Button variant="link">View Details</Button>
|
|
<ActionIcon variant="primary">...</ActionIcon>
|
|
<ActionIcon variant="secondary">...</ActionIcon>
|
|
<ActionIcon variant="danger">...</ActionIcon>
|
|
<ActionIcon variant="link">...</ActionIcon>
|
|
<ActionIcon variant="subtle">...</ActionIcon>
|
|
```
|
|
|
|
### DO NOT USE (Forbidden Patterns)
|
|
|
|
```tsx
|
|
<Button variant="light" color="green">Save</Button>
|
|
<Button variant="light" color="gray">Cancel</Button>
|
|
<Button variant="light" color="red">Delete</Button>
|
|
<Button variant="outline" color="green">Save</Button>
|
|
<Button variant="outline" color="gray">Cancel</Button>
|
|
<Button variant="outline" color="red">Delete</Button>
|
|
<Button variant="filled" color="gray">Cancel</Button>
|
|
<Button variant="default">Cancel</Button>
|
|
<ActionIcon variant="light" color="red">...</ActionIcon>
|
|
<ActionIcon variant="filled" color="gray">...</ActionIcon>
|
|
```
|
|
|
|
**Link variant details**: Renders with no background, no border, and muted text color. On hover, text brightens to full contrast. Use for link-style CTAs that should blend into surrounding content (e.g., "View Details", "View Full Trace").
|
|
|
|
**Subtle variant details**: Transparent background with standard text color. On hover, a subtle background highlight appears (`--color-bg-hover`). This is the **default** ActionIcon variant. Use for toolbar icons, collapse toggles, close buttons, and utility controls that should stay unobtrusive but reveal interactivity on hover. Unlike `link`, `subtle` shows a hover background rather than changing text color.
|
|
|
|
**Note**: `variant="filled"` is still valid for **form inputs** (Select, TextInput, etc.), just not for Button/ActionIcon.
|
|
|
|
### Icon-Only Buttons → ActionIcon
|
|
|
|
**If a Button only contains an icon (no text), use ActionIcon instead:**
|
|
|
|
```tsx
|
|
// ❌ WRONG - Button with only an icon
|
|
<Button variant="secondary" px="xs">
|
|
<IconRefresh size={18} />
|
|
</Button>
|
|
|
|
// ✅ CORRECT - Use ActionIcon for icon-only buttons
|
|
<ActionIcon variant="secondary" size="input-sm">
|
|
<IconRefresh size={18} />
|
|
</ActionIcon>
|
|
```
|
|
|
|
This pattern cannot be enforced by ESLint and requires manual code review.
|
|
|
|
## Refactoring
|
|
|
|
- Edit files directly - don't create `component-v2.tsx` copies
|
|
- Look for duplicate code across the affected area
|
|
- Verify all callers and integrations after changes
|
|
- Refactor to improve clarity or reduce complexity, not just to change
|
|
|
|
## File Naming
|
|
|
|
- Clear, descriptive names following package conventions
|
|
- Avoid "temp", "refactored", "improved" in permanent filenames
|
|
|