Skip to content

ng-zen is a versatile Angular library and CLI tool offering UI-kit Angular schematics for streamlined integration into projects.

License

Notifications You must be signed in to change notification settings

kstepien3/ng-zen

Folders and files

NameName
Last commit message
Last commit date

Latest commit

Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
@ng-zen/cli Logo

@ng-zen/cli

Build Status NPM Version License

Repository Storybook Demo

Generate production-ready, customizable Angular UI components directly into your project πŸš€

Stop wrestling with rigid UI libraries. @ng-zen/cli generates beautiful, modern Angular components as source code in your project, giving you complete control and ownership.

🎯 Why Choose @ng-zen/cli?

✨ Own Your Components

Unlike traditional UI libraries that give you <library-button> black boxes, @ng-zen generates actual TypeScript, HTML, and SCSS files directly into your project. You own the code, you control the future.

🏎️ Instant Productivity

  • Production-Ready Components: Avatar, Button, Checkbox, Divider, Form Control, Icon, Input, Skeleton, Switch, Textarea
  • Zero Configuration: Works with Angular 20+ out of the box
  • Complete Setup: Each component includes unit tests, Storybook stories, and documentation

🎨 Built for Customization

  • CSS Variables: Easy theming without touching component internals
  • Editable SCSS: Modify styles directly when you need deeper customization
  • Modern Architecture: Standalone components, OnPush change detection, Angular signals

πŸ“š Developer Experience First

  • Interactive Documentation: Live Storybook examples for every component
  • TypeScript Ready: Full type safety and IntelliSense support
  • Test Coverage: Generated components include comprehensive unit tests
  • JSDoc Annotations: Detailed inline documentation

Table of Contents

  1. Quick Start
  2. Installation
  3. Available Components
  4. Usage Examples
  5. Perfect For
  6. Advanced Features
  7. Documentation
  8. Project Status
  9. Contributing
  10. License
  11. Author
  12. See Also
  13. FAQ

πŸš€ Quick Start

The fastest way to get started:

ng add @ng-zen/cli

This command:

  • βœ… Installs the package
  • βœ… Sets up your project configuration
  • βœ… Ready to generate components

Then generate your first component:

ng generate @ng-zen/cli:component

Select components from an interactive menu and they'll be generated directly into your current directory! πŸŽ‰

πŸ“¦ Installation

Recommended: Using ng add

ng add @ng-zen/cli

Manual Installation

# Stable version
pnpm add -D @ng-zen/cli

# Latest features and fixes
pnpm add -D @ng-zen/cli@next

🧩 Available Components

Component Description Features
Avatar User profile images and initials Image fallback, size variants, rounded styles
Button Interactive buttons Primary/secondary variants, loading states, icons
Checkbox Form checkboxes Indeterminate state, custom styling, validation
Divider Visual separators Horizontal/vertical, with labels, custom thickness
Form Control Form field wrapper Labels, validation messages, required indicators
Icon SVG icon system Huge Icons integration, size variants, colors
Input Text input fields Validation states, prefixes/suffixes, types
Skeleton Loading placeholders Multiple shapes, animation, responsive
Switch Toggle controls On/off states, disabled state, custom labels
Textarea Multi-line text input Auto-resize, character counts, validation

πŸ’‘ More components coming soon! Planned: Directives, Pipes, Services, and additional UI elements.

πŸ’‘ Usage Examples

Basic Component Generation

# Interactive mode - choose components from a menu
ng generate @ng-zen/cli:component

# Generate specific components
ng generate @ng-zen/cli:component --components avatar button

# Custom location
ng generate @ng-zen/cli:component ./src/app/ui --components input checkbox

# Include Storybook stories
ng generate @ng-zen/cli:component --components button --stories

What Gets Generated

Each component set includes:

src/app/ui/
β”œβ”€β”€ button/
β”‚   β”œβ”€β”€ button.ts           # Component logic
β”‚   β”œβ”€β”€ button.scss         # Customizable styles
β”‚   β”œβ”€β”€ button.spec.ts      # Unit tests
β”‚   β”œβ”€β”€ button.stories.ts   # Storybook documentation
β”‚   β”œβ”€β”€ index.ts           # Barrel exports
β”‚   └── README.md          # Component-specific docs
└── input/
    β”œβ”€β”€ input.ts
    β”œβ”€β”€ input.scss
    β”œβ”€β”€ input.spec.ts
    β”œβ”€β”€ input.stories.ts
    β”œβ”€β”€ index.ts
    └── README.md

Real-World Usage

// After generation, import and use like any Angular component
import { ZenButton } from './ui/button';
import { ZenInput } from './ui/input';

@Component({
  selector: 'app-login',
  imports: [ZenButton, ZenInput],
  template: `
    <form>
      <zen-input placeholder="Enter email" type="email" />
      <button variant="primary" zen-button>Sign In</button>
    </form>
  `,
})
export class LoginComponent {}

🎯 Perfect For

🏒 Enterprise Teams

  • Build consistent internal component libraries
  • Maintain design system compliance across projects
  • Avoid vendor lock-in with owned source code

πŸš€ Startup Projects

  • Rapid prototyping with production-ready components
  • Easy customization as requirements evolve
  • No licensing concerns or bundle size bloat

πŸ‘©β€πŸ’» Angular Developers

  • Learn modern Angular patterns (signals, standalone components)
  • Speed up UI development workflow
  • Maintain full control over component behavior

🎨 Design Systems

  • Use as foundation for custom component libraries
  • Extend and modify components to match brand guidelines
  • Generate consistent documentation automatically

⚑ Advanced Features

Modern Angular Architecture

  • Standalone Components: No NgModule dependencies
  • OnPush Change Detection: Optimized performance
  • Angular Signals: Reactive state management
  • TypeScript 5.8+: Latest language features

Customization System

// Easy theming with CSS variables
:root {
  --zen-button-primary-bg: #your-brand-color;
  --zen-button-border-radius: 8px;
  --zen-button-font-weight: 600;
}

Testing Integration

  • Jest Ready: All tests use Jest framework
  • Component Testing: Isolated unit tests for each component
  • Storybook Testing: Visual testing and documentation

Development Tools

  • ESLint Integration: Code quality enforcement
  • Prettier Support: Consistent code formatting
  • Husky Hooks: Pre-commit validation

πŸ“š Documentation

  • πŸ“– Live Storybook Demo - Interactive component examples
  • πŸ”§ Development Guide - Setup and contribution workflow
  • 🀝 Contributing Guide - How to contribute to the project
  • πŸ“ Changelog - Version history and breaking changes
  • πŸ’¬ Component READMEs - Detailed docs generated with each component

🚧 Project Status

🟒 Actively Developed & Production Ready

  • βœ… Core Features: Component generation is stable and tested
  • βœ… Angular 20+ Support: Compatible with latest Angular versions
  • πŸ”„ Continuous Improvement: Regular updates and new components
  • πŸ“‹ Roadmap: Directives, pipes, services, and more UI components planned

Release Channels

  • @ng-zen/cli - Stable releases from master branch
  • @ng-zen/cli@next - Pre-releases from next branch with latest features

Important: Since @ng-zen/cli generates code into your project, you own that code completely. Updates to the CLI primarily add new features and components - they won't break your existing generated components.

🀝 Contributing

We welcome contributions! Whether it's:

  • πŸ› Bug Reports - Help us improve reliability
  • πŸ’‘ Feature Requests - Suggest new components or capabilities
  • πŸ”§ Code Contributions - Add features or fix issues
  • πŸ“š Documentation - Improve guides and examples

πŸš€ Do you urgently need some new features? Report them in the issues section! They will be scheduled for the next deployments.

Getting Started:

  1. Read our Contributing Guidelines
  2. Check the Development Setup
  3. Browse open issues
  4. Join the discussion!

License

This project is licensed under the BSD 2-Clause License πŸ“œ.

Author

Konrad StΔ™pieΕ„ - Creator & Maintainer

See Also

FAQ

❓ How is this different from Angular Material or PrimeNG?

Traditional UI libraries give you pre-compiled components that you can't modify. @ng-zen/cli generates the actual source code into your project, so you have complete control. You can modify the TypeScript, HTML, and SCSS files however you need.

❓ Can I customize the generated components?

Absolutely! That's the whole point. Every component is generated as editable source code in your project. You can:

  • Modify the TypeScript logic
  • Change the HTML templates
  • Customize the SCSS styles
  • Extend functionality as needed

❓ What happens when I update @ng-zen/cli?

Updates to the CLI add new features and components but don't affect your already-generated code. Your components belong to you and won't be overwritten. You can always generate new components with the latest features.

❓ Does this work with existing Angular projects?

Yes! @ng-zen/cli works with any Angular 20+ project. Just run ng add @ng-zen/cli in your existing project and start generating components.

❓ Can I use this in production?

Definitely! The generated components are production-ready with:

  • Full TypeScript type safety
  • Comprehensive unit tests
  • Optimized performance (OnPush change detection)
  • Accessibility considerations
  • Modern Angular best practices

❓ How do I theme the components?

Components use CSS variables for easy theming:

:root {
  --zen-primary-color: #your-brand-color;
  --zen-border-radius: 8px;
}

For deeper customization, edit the generated SCSS files directly.

❓ Why no Tailwind CSS?

You can tweak the code to use Tailwind if you want, but avoid adding extra libraries. Our goal is to create base components that are easy to improve later, work without any CSS libraries, and are fully customizable right out of the box.


Ready to take control of your Angular UI components? Get started now! πŸš€

About

ng-zen is a versatile Angular library and CLI tool offering UI-kit Angular schematics for streamlined integration into projects.

Resources

License

Code of conduct

Contributing

Stars

Watchers

Forks

Packages

No packages published

Contributors 3

  •  
  •  
  •