Files
ui-essentials/CONSUMER_INTEGRATION_GUIDE.md
Jules 2a28a8abbd Complete library submodule standardization and consumer integration
🎯 Major Achievements:
- Standardized 193+ SCSS imports across all libraries
- Created 12 independent Git repositories with clean submodule structure
- Eliminated relative path dependencies for true library portability
- Added comprehensive consumer integration documentation

📦 Libraries Successfully Published:
• ui-design-system (foundation)
• ui-essentials (components)
• shared-utils (utilities)
• auth-client (authentication)
• ui-landing-pages (marketing components)
• ui-code-display (syntax highlighting)
• ui-accessibility (WCAG compliance)
• hcl-studio (color management)
• ui-animations (CSS animations)
• ui-backgrounds (background effects)
• ui-font-manager (typography)
• ui-data-utils (data manipulation)

🔧 Technical Improvements:
- All SCSS imports now use standardized 'ui-design-system/' paths
- Libraries work independently as Git submodules
- Consumer projects can selectively include only needed libraries
- Professional Git history with initial commits for each library
- Updated integration guides with step-by-step workflows

📋 Documentation Added:
- CONSUMER_INTEGRATION_GUIDE.md - Complete setup instructions
- Updated SUBMODULE_INTEGRATION_GUIDE.md - Enhanced with dependency info
- Library-specific README files for all repositories

🚀 Ready for Production:
- All libraries pushed to https://git.sky-ai.com/jules/*
- Clean separation of concerns across library boundaries
- Independent versioning and release cycles possible
- Optimal structure for LLM analysis and maintenance

This completes the monorepo-to-submodule transformation, making the SSuite library ecosystem ready for professional distribution and consumption.

🤖 Generated with Claude Code (https://claude.ai/code)

Co-Authored-By: Claude <noreply@anthropic.com>
2025-09-12 14:42:01 +10:00

491 lines
14 KiB
Markdown

# Angular Library Consumer Integration Guide
## 🚀 Complete Guide: Creating a New Angular Project with SSuite Libraries
This guide shows you how to create a fresh Angular project and integrate any combination of the 12 SSuite libraries using Git submodules.
---
## 📋 Prerequisites
- **Node.js 18+** and npm
- **Angular CLI** (`npm install -g @angular/cli`)
- **Git** configured with access to `git.sky-ai.com`
---
## 🏗️ Step 1: Create New Angular Project
```bash
# Create new Angular project
ng new my-awesome-app
cd my-awesome-app
# Create libs directory for submodules
mkdir libs
```
---
## 📦 Step 2: Choose Your Libraries
Select libraries based on your needs:
### 🎨 **Foundation (Required for most projects)**
- **ui-design-system** - SCSS design tokens, colors, typography, fonts
### 🛠️ **Essential Components**
- **ui-essentials** - Buttons, forms, tables, cards, navigation, etc.
- **shared-utils** - Common utilities and shared services
### 🎯 **Specialized Libraries**
- **auth-client** - Authentication guards, services, interceptors
- **ui-landing-pages** - Hero sections, pricing tables, testimonials
- **ui-code-display** - Syntax highlighting for code blocks
- **ui-accessibility** - WCAG compliance tools and utilities
- **hcl-studio** - Advanced color management system
### 🎭 **Enhancement Libraries**
- **ui-animations** - CSS animation utilities
- **ui-backgrounds** - Background generators and effects
- **ui-font-manager** - Advanced font management
- **ui-data-utils** - Data manipulation utilities
---
## ⚡ Step 3: Add Libraries as Submodules
**IMPORTANT**: Always add `ui-design-system` first, as other libraries depend on it.
### Minimal Setup (Design System + Components):
```bash
# Add foundation (required)
git submodule add https://git.sky-ai.com/jules/ui-design-system.git libs/ui-design-system
# Add essential components
git submodule add https://git.sky-ai.com/jules/ui-essentials.git libs/ui-essentials
git submodule add https://git.sky-ai.com/jules/shared-utils.git libs/shared-utils
# Initialize submodules
git submodule update --init --recursive
```
### Full-Featured Setup (All Libraries):
```bash
# Foundation (required first)
git submodule add https://git.sky-ai.com/jules/ui-design-system.git libs/ui-design-system
# Core libraries
git submodule add https://git.sky-ai.com/jules/ui-essentials.git libs/ui-essentials
git submodule add https://git.sky-ai.com/jules/shared-utils.git libs/shared-utils
git submodule add https://git.sky-ai.com/jules/auth-client.git libs/auth-client
# Specialized libraries
git submodule add https://git.sky-ai.com/jules/ui-landing-pages.git libs/ui-landing-pages
git submodule add https://git.sky-ai.com/jules/ui-code-display.git libs/ui-code-display
git submodule add https://git.sky-ai.com/jules/ui-accessibility.git libs/ui-accessibility
git submodule add https://git.sky-ai.com/jules/hcl-studio.git libs/hcl-studio
# Enhancement libraries
git submodule add https://git.sky-ai.com/jules/ui-animations.git libs/ui-animations
git submodule add https://git.sky-ai.com/jules/ui-backgrounds.git libs/ui-backgrounds
git submodule add https://git.sky-ai.com/jules/ui-font-manager.git libs/ui-font-manager
git submodule add https://git.sky-ai.com/jules/ui-data-utils.git libs/ui-data-utils
# Initialize all submodules
git submodule update --init --recursive
```
---
## 🔨 Step 4: Build Libraries
Build libraries in dependency order:
```bash
# Build ui-design-system first (required by others)
cd libs/ui-design-system
npm install
npm run build
cd ../..
# Build other libraries
cd libs/ui-essentials && npm install && npm run build && cd ../..
cd libs/shared-utils && npm install && npm run build && cd ../..
cd libs/auth-client && npm install && npm run build && cd ../..
# Continue for other libraries as needed...
```
### 📜 Automation Script:
Create `build-libs.sh`:
```bash
#!/bin/bash
echo "🏗️ Building all libraries..."
# Array of libraries in dependency order
LIBS=("ui-design-system" "shared-utils" "ui-essentials" "auth-client" "ui-landing-pages" "ui-code-display" "ui-accessibility" "hcl-studio" "ui-animations" "ui-backgrounds" "ui-font-manager" "ui-data-utils")
for lib in "${LIBS[@]}"; do
if [ -d "libs/$lib" ]; then
echo "📦 Building $lib..."
cd libs/$lib
npm install
npm run build
cd ../..
echo "✅ $lib built successfully"
else
echo "⚠️ Skipping $lib (not found)"
fi
done
echo "🎉 All libraries built!"
```
Make executable: `chmod +x build-libs.sh && ./build-libs.sh`
---
## ⚙️ Step 5: Configure TypeScript Paths
Update `tsconfig.json`:
```json
{
"compilerOptions": {
"baseUrl": "./",
"paths": {
// Foundation (required)
"ui-design-system": ["./libs/ui-design-system/dist"],
"ui-design-system/*": ["./libs/ui-design-system/dist/*", "./libs/ui-design-system/src/*"],
// Core libraries
"ui-essentials": ["./libs/ui-essentials/dist"],
"ui-essentials/*": ["./libs/ui-essentials/dist/*"],
"shared-utils": ["./libs/shared-utils/dist"],
"shared-utils/*": ["./libs/shared-utils/dist/*"],
"auth-client": ["./libs/auth-client/dist"],
"auth-client/*": ["./libs/auth-client/dist/*"],
// Specialized libraries
"ui-landing-pages": ["./libs/ui-landing-pages/dist"],
"ui-landing-pages/*": ["./libs/ui-landing-pages/dist/*"],
"ui-code-display": ["./libs/ui-code-display/dist"],
"ui-code-display/*": ["./libs/ui-code-display/dist/*"],
"ui-accessibility": ["./libs/ui-accessibility/dist"],
"ui-accessibility/*": ["./libs/ui-accessibility/dist/*"],
"hcl-studio": ["./libs/hcl-studio/dist"],
"hcl-studio/*": ["./libs/hcl-studio/dist/*"],
// Enhancement libraries
"ui-animations": ["./libs/ui-animations/dist"],
"ui-animations/*": ["./libs/ui-animations/dist/*"],
"ui-backgrounds": ["./libs/ui-backgrounds/dist"],
"ui-backgrounds/*": ["./libs/ui-backgrounds/dist/*"],
"ui-font-manager": ["./libs/ui-font-manager/dist"],
"ui-font-manager/*": ["./libs/ui-font-manager/dist/*"],
"ui-data-utils": ["./libs/ui-data-utils/dist"],
"ui-data-utils/*": ["./libs/ui-data-utils/dist/*"]
}
}
}
```
**Note**: The `ui-design-system/*` includes both `dist/*` and `src/*` to support SCSS imports.
---
## 🎨 Step 6: Import Styles
### Option A: Complete Design System
In your `src/styles.scss`:
```scss
// Complete design system (includes all tokens + fonts)
@use 'ui-design-system/src/styles' as ui;
// Optional: Additional component styles
@use 'ui-animations/src/styles' as animations;
@use 'ui-backgrounds/src/styles' as backgrounds;
```
### Option B: Selective Imports
```scss
// Just semantic tokens (most common)
@use 'ui-design-system/src/styles/semantic' as tokens;
// Or just base tokens
@use 'ui-design-system/src/styles/base' as base;
// Add specific libraries
@use 'ui-accessibility/src/lib/utilities/a11y-utilities' as a11y;
```
---
## 💻 Step 7: Use Libraries in Your Components
### Example Component using multiple libraries:
```typescript
// src/app/app.component.ts
import { Component } from '@angular/core';
import { ButtonComponent } from 'ui-essentials';
import { AuthService } from 'auth-client';
import { HeroSectionComponent } from 'ui-landing-pages';
import { CodeSnippetComponent } from 'ui-code-display';
@Component({
selector: 'app-root',
standalone: true,
imports: [
ButtonComponent,
HeroSectionComponent,
CodeSnippetComponent
],
template: `
<div class="app-container">
<!-- Hero Section -->
<ui-hero-section
title="Welcome to My App"
subtitle="Built with SSuite Libraries"
[cta]="{ text: 'Get Started', action: 'primary' }">
</ui-hero-section>
<!-- Content Section -->
<main class="content">
<!-- Buttons from ui-essentials -->
<ui-button variant="primary" (click)="handleClick()">
Primary Action
</ui-button>
<ui-button variant="secondary" [disabled]="!isLoggedIn">
Secondary Action
</ui-button>
<!-- Code Display -->
<ui-code-snippet
language="typescript"
[code]="exampleCode">
</ui-code-snippet>
</main>
</div>
`,
styles: [`
.app-container {
min-height: 100vh;
}
.content {
padding: 2rem;
max-width: 1200px;
margin: 0 auto;
}
`]
})
export class AppComponent {
isLoggedIn = false;
exampleCode = `
import { ButtonComponent } from 'ui-essentials';
import { AuthService } from 'auth-client';
// Your code here...
`;
constructor(private auth: AuthService) {
this.isLoggedIn = this.auth.isAuthenticated();
}
handleClick() {
console.log('Button clicked!');
}
}
```
### Component with Authentication:
```typescript
// src/app/protected/dashboard.component.ts
import { Component } from '@angular/core';
import { AuthGuard } from 'auth-client';
import { TableComponent, CardComponent } from 'ui-essentials';
import { StatisticsDisplayComponent } from 'ui-landing-pages';
@Component({
selector: 'app-dashboard',
standalone: true,
imports: [TableComponent, CardComponent, StatisticsDisplayComponent],
template: `
<div class="dashboard">
<!-- Stats Cards -->
<div class="stats-grid">
<ui-statistics-display
[statistics]="stats"
variant="cards">
</ui-statistics-display>
</div>
<!-- Data Table -->
<ui-card>
<ui-enhanced-table
[data]="userData"
[columns]="tableColumns"
[searchable]="true"
[sortable]="true">
</ui-enhanced-table>
</ui-card>
</div>
`,
styles: [`
.dashboard {
padding: 1.5rem;
}
.stats-grid {
margin-bottom: 2rem;
}
`]
})
export class DashboardComponent {
stats = [
{ label: 'Users', value: '1,234', change: '+12%' },
{ label: 'Revenue', value: '$45,678', change: '+8%' },
{ label: 'Orders', value: '892', change: '+15%' }
];
userData = [
{ id: 1, name: 'John Doe', email: 'john@example.com', status: 'active' },
{ id: 2, name: 'Jane Smith', email: 'jane@example.com', status: 'inactive' }
];
tableColumns = [
{ key: 'id', label: 'ID' },
{ key: 'name', label: 'Name' },
{ key: 'email', label: 'Email' },
{ key: 'status', label: 'Status' }
];
}
```
---
## 🔄 Step 8: Library Management
### Update a Single Library:
```bash
cd libs/ui-essentials
git pull origin main
npm run build
cd ../..
```
### Update All Libraries:
```bash
git submodule update --remote
./build-libs.sh # Rebuild all libraries
```
### Lock Library to Specific Version:
```bash
cd libs/ui-essentials
git checkout v1.2.0 # Specific tag
cd ../..
git add libs/ui-essentials
git commit -m "Lock ui-essentials to v1.2.0"
```
### Remove Unused Library:
```bash
git submodule deinit libs/ui-backgrounds
git rm libs/ui-backgrounds
git commit -m "Remove ui-backgrounds library"
```
---
## 📁 Final Project Structure
```
my-awesome-app/
├── src/
│ ├── app/
│ │ ├── app.component.ts
│ │ ├── protected/
│ │ │ └── dashboard.component.ts
│ │ └── ...
│ ├── styles.scss
│ └── ...
├── libs/ # Git submodules
│ ├── ui-design-system/ # Foundation
│ ├── ui-essentials/ # Components
│ ├── auth-client/ # Authentication
│ ├── ui-landing-pages/ # Landing components
│ └── [other-libraries]/
├── package.json
├── tsconfig.json
├── angular.json
├── build-libs.sh # Build automation
├── .gitmodules # Auto-generated
└── README.md
```
---
## ⚡ Quick Start Commands
### Minimal Project (Design System + Components):
```bash
ng new my-app && cd my-app
mkdir libs
git submodule add https://git.sky-ai.com/jules/ui-design-system.git libs/ui-design-system
git submodule add https://git.sky-ai.com/jules/ui-essentials.git libs/ui-essentials
git submodule update --init --recursive
cd libs/ui-design-system && npm install && npm run build && cd ../..
cd libs/ui-essentials && npm install && npm run build && cd ../..
```
### Add TypeScript paths and styles, then start developing!
---
## 🎯 Common Patterns
### Landing Page Project:
```bash
# Essential for marketing sites
git submodule add https://git.sky-ai.com/jules/ui-design-system.git libs/ui-design-system
git submodule add https://git.sky-ai.com/jules/ui-essentials.git libs/ui-essentials
git submodule add https://git.sky-ai.com/jules/ui-landing-pages.git libs/ui-landing-pages
git submodule add https://git.sky-ai.com/jules/ui-animations.git libs/ui-animations
```
### Documentation Site:
```bash
# Perfect for docs with code examples
git submodule add https://git.sky-ai.com/jules/ui-design-system.git libs/ui-design-system
git submodule add https://git.sky-ai.com/jules/ui-essentials.git libs/ui-essentials
git submodule add https://git.sky-ai.com/jules/ui-code-display.git libs/ui-code-display
git submodule add https://git.sky-ai.com/jules/ui-accessibility.git libs/ui-accessibility
```
### Enterprise Application:
```bash
# Full-featured business app
git submodule add https://git.sky-ai.com/jules/ui-design-system.git libs/ui-design-system
git submodule add https://git.sky-ai.com/jules/ui-essentials.git libs/ui-essentials
git submodule add https://git.sky-ai.com/jules/shared-utils.git libs/shared-utils
git submodule add https://git.sky-ai.com/jules/auth-client.git libs/auth-client
git submodule add https://git.sky-ai.com/jules/ui-data-utils.git libs/ui-data-utils
```
---
## 🚀 You're Ready!
Your new Angular project is now set up with the SSuite library ecosystem. You have:
-**Modular architecture** - Only include libraries you need
-**Professional design system** - Consistent styling and components
-**Independent updates** - Update libraries separately
-**Clean imports** - TypeScript paths configured
-**Version control** - Lock libraries to specific versions
-**Scalable structure** - Add/remove libraries as needed
Happy coding! 🎉