Convert Figma logo to code with AI

Ismaestro logoangular-example-app

Angular 17 Example App + Standalone Components + i18n + EsBuild

2,191
1,217
2,191
1

Top Related Projects

96,481

Deliver web apps with confidence 🚀

Angular, NgRx, Angular CLI & Angular Material Starter Project

Exemplary real world application built with Angular

25,308

Customizable admin dashboard template based on Angular 10+

Angular and TypeScript JumpStart example application

Quick Overview

Ismaestro/angular-example-app is a comprehensive Angular application showcasing best practices and modern development techniques. It serves as a learning resource and reference implementation for developers working with Angular, demonstrating various features and architectural patterns.

Pros

  • Implements a wide range of Angular features and best practices
  • Regularly updated to keep up with the latest Angular versions
  • Includes extensive documentation and comments for easy understanding
  • Demonstrates integration with external services and APIs

Cons

  • May be overwhelming for beginners due to its comprehensive nature
  • Some advanced concepts might require additional learning for full understanding
  • The large scope of the project could make it challenging to navigate for specific examples
  • Occasional delays in updates for the latest Angular versions

Code Examples

Here are a few code examples from the project:

  1. Component with dependency injection:
@Component({
  selector: 'app-hero-detail',
  templateUrl: './hero-detail.component.html',
  styleUrls: ['./hero-detail.component.scss']
})
export class HeroDetailComponent implements OnInit {
  @Input() hero: Hero;

  constructor(
    private heroService: HeroService,
    private route: ActivatedRoute,
    private location: Location
  ) {}

  ngOnInit(): void {
    this.getHero();
  }

  getHero(): void {
    const id = +this.route.snapshot.paramMap.get('id');
    this.heroService.getHero(id)
      .subscribe(hero => this.hero = hero);
  }
}
  1. Service with HTTP requests:
@Injectable({
  providedIn: 'root'
})
export class HeroService {
  private heroesUrl = 'api/heroes';

  constructor(
    private http: HttpClient,
    private messageService: MessageService
  ) {}

  getHeroes(): Observable<Hero[]> {
    return this.http.get<Hero[]>(this.heroesUrl)
      .pipe(
        tap(_ => this.log('fetched heroes')),
        catchError(this.handleError<Hero[]>('getHeroes', []))
      );
  }
}
  1. Reactive form example:
@Component({
  selector: 'app-hero-form',
  templateUrl: './hero-form.component.html'
})
export class HeroFormComponent implements OnInit {
  heroForm: FormGroup;

  constructor(private fb: FormBuilder) {}

  ngOnInit() {
    this.heroForm = this.fb.group({
      name: ['', Validators.required],
      power: ['', Validators.required],
      alterEgo: ''
    });
  }

  onSubmit() {
    if (this.heroForm.valid) {
      console.log(this.heroForm.value);
    }
  }
}

Getting Started

To get started with this project:

  1. Clone the repository:

    git clone https://github.com/Ismaestro/angular-example-app.git
    
  2. Install dependencies:

    cd angular-example-app
    npm install
    
  3. Run the development server:

    ng serve
    
  4. Open your browser and navigate to http://localhost:4200 to view the application.

Competitor Comparisons

96,481

Deliver web apps with confidence 🚀

Pros of angular

  • Official Angular framework repository with comprehensive documentation
  • Larger community support and more frequent updates
  • Contains core Angular libraries and tools for development

Cons of angular

  • More complex and overwhelming for beginners
  • Lacks practical, ready-to-use application examples
  • Steeper learning curve for new developers

Code comparison

angular-example-app:

@Component({
  selector: 'app-hero-detail',
  templateUrl: './hero-detail.component.html',
  styleUrls: ['./hero-detail.component.scss']
})
export class HeroDetailComponent implements OnInit {
  @Input() hero: Hero;

angular:

@Component({
  selector: 'example-component',
  template: `<h1>Hello, {{name}}!</h1>`,
  styles: [`h1 { font-family: Lato; }`]
})
export class ExampleComponent  {
  @Input() name: string;

The angular-example-app repository provides a more comprehensive, real-world example of component implementation, while the angular repository showcases a simpler, bare-bones component structure. This difference highlights how angular-example-app is more focused on practical application, whereas angular serves as the foundation for Angular development.

Angular, NgRx, Angular CLI & Angular Material Starter Project

Pros of angular-ngrx-material-starter

  • Implements NgRx for state management, providing a more robust solution for complex applications
  • Includes a wider range of Angular Material components and features
  • Offers more comprehensive documentation and a detailed wiki

Cons of angular-ngrx-material-starter

  • Higher learning curve due to NgRx integration
  • More complex project structure, which may be overwhelming for beginners
  • Less focus on internationalization (i18n) compared to angular-example-app

Code Comparison

angular-ngrx-material-starter:

@Effect()
login = this.actions$.pipe(
  ofType(AuthActionTypes.LOGIN),
  map((action: Login) => action.payload),
  exhaustMap((auth) =>
    this.authService.login(auth).pipe(
      map(user => new LoginSuccess({ user })),
      catchError(error => of(new LoginFailure({ error })))
    )
  )
);

angular-example-app:

login(email: string, password: string): Observable<User> {
  return this.http.post<User>(`${environment.apiUrl}/login`, { email, password })
    .pipe(
      tap(user => this.setSession(user)),
      shareReplay()
    );
}

The code snippets demonstrate the difference in state management approaches. angular-ngrx-material-starter uses NgRx effects for handling authentication, while angular-example-app uses a more straightforward service-based approach.

Exemplary real world application built with Angular

Pros of angular-realworld-example-app

  • Implements a real-world application (Medium clone) with more complex features
  • Follows RealWorld spec, making it easier to compare with other framework implementations
  • Includes authentication and API integration

Cons of angular-realworld-example-app

  • Less focus on Angular-specific best practices and optimizations
  • Fewer examples of advanced Angular features like custom directives or pipes
  • Less comprehensive documentation and comments in the codebase

Code Comparison

angular-realworld-example-app:

export class ArticleListComponent implements OnInit {
  constructor(
    private articlesService: ArticlesService,
    private route: ActivatedRoute
  ) {}

  ngOnInit() {
    this.route.data.subscribe(
      (data: { articles: Article[] }) => {
        this.articles = data.articles;
      }
    );
  }
}

angular-example-app:

export class HeroesComponent implements OnInit {
  constructor(
    private heroService: HeroService,
    private translateService: TranslateService
  ) {}

  ngOnInit() {
    this.getHeroes();
    this.translateService.onLangChange.subscribe(() => {
      this.getHeroes();
    });
  }
}

The angular-realworld-example-app focuses on implementing a real-world application with API integration, while angular-example-app emphasizes Angular-specific features like internationalization. Both examples demonstrate proper use of dependency injection and component lifecycle hooks.

25,308

Customizable admin dashboard template based on Angular 10+

Pros of ngx-admin

  • More comprehensive UI components and layouts
  • Better suited for large-scale enterprise applications
  • Includes advanced features like authentication and role-based access control

Cons of ngx-admin

  • Steeper learning curve due to its complexity
  • May be overkill for smaller projects or learning purposes
  • Less focus on best practices and clean code structure

Code Comparison

ngx-admin:

@Component({
  selector: 'ngx-dashboard',
  styleUrls: ['./dashboard.component.scss'],
  templateUrl: './dashboard.component.html',
})
export class DashboardComponent implements OnDestroy {
  private alive = true;

angular-example-app:

@Component({
  selector: 'app-heroes',
  templateUrl: './heroes.component.html',
  styleUrls: ['./heroes.component.scss']
})
export class HeroesComponent implements OnInit {
  heroes: Hero[];

ngx-admin uses a more complex component structure with lifecycle hooks and private properties, while angular-example-app focuses on simplicity and readability. The ngx-admin example shows a dashboard component, indicating its focus on admin interfaces, whereas angular-example-app demonstrates a basic heroes component, highlighting its educational nature.

Both repositories serve different purposes: ngx-admin is a feature-rich admin template for building large-scale applications, while angular-example-app is a simpler, more educational project focused on Angular fundamentals and best practices. Choose based on your project requirements and learning goals.

Angular and TypeScript JumpStart example application

Pros of Angular-JumpStart

  • More comprehensive documentation and setup instructions
  • Includes a basic backend server for API simulation
  • Focuses on core Angular concepts without additional libraries

Cons of Angular-JumpStart

  • Less extensive feature set compared to angular-example-app
  • Fewer examples of advanced Angular techniques
  • Simpler UI design, which may be less visually appealing

Code Comparison

Angular-JumpStart:

@Component({
  selector: 'app-customers',
  templateUrl: './customers.component.html'
})
export class CustomersComponent implements OnInit {
  title: string;
  people: any[] = [];

angular-example-app:

@Component({
  selector: 'app-heroes',
  templateUrl: './heroes.component.html',
  styleUrls: ['./heroes.component.scss'],
  changeDetection: ChangeDetectionStrategy.OnPush,
})
export class HeroesComponent implements OnInit {
  heroes$: Observable<Hero[]>;

The Angular-JumpStart example shows a simpler component structure, while the angular-example-app demonstrates more advanced techniques like change detection strategy and observables.

Angular-JumpStart is ideal for beginners looking to grasp fundamental Angular concepts, offering a straightforward approach with basic examples. On the other hand, angular-example-app provides a more feature-rich environment, showcasing advanced Angular practices and a polished UI, making it suitable for developers seeking to explore more complex Angular applications.

Convert Figma logo designs to code with AI

Visual Copilot

Introducing Visual Copilot: A new AI model to turn Figma designs to high quality code using your components.

Try Visual Copilot

README

Angular Example App

Example app with Angular 17 + i18n + Standalone Components and Es-Build Enabled

:clap::clap::tada::tada::tada::tada::clap::clap:

Real World App made with much :heart:. Contains CRUD, advanced patterns and much more!

Demo example

DEMO HERE

Setup

npm i
npm start

Status

Quality Gate StatusGitHub stars GitHub forks

Server

This project is using a real app deployed in fly.io, which you can see here. The server is using NestJS, Prisma, Postgres and GraphQL. Please check it out and also feel free to contribute or give me your thoughts.

What's included

  • Standalone components
  • Functional Guards
  • CRUD: create, update and remove heroes with this project!
  • Authentication with JWT tokens (Interceptor and Guard)
  • Internationalization with the official i18n. English and Spanish available.
  • Lazy loading modules
  • Amazing reactive functionalities with elf
  • More logical directory structure
  • Following the best practices!
  • Responsive layout with Bootstrap 5
  • Use of NgOptimizedImage
  • SASS with BEM styles
  • Example tests for: Component, Service, Interceptor, Directive and Guard
  • End-to-end tests configuration with Playwright
  • Very strict ESLint rules

Bugs and feature requests

Have a bug or a feature request? Please first read the issue guidelines and search for existing and closed issues. If your problem or idea is not addressed yet, please open a new issue.

If you have an idea or you want to do something, tell me or just do it! I'm always happy to hear your feedback!

Creators

Ismael Ramos

Thanks

I´m developing this project in my free time, but also thanks to all contributors!

Buy me a coffe

Copyright and license

Code and documentation copyright 2023 the authors. Code released under the MIT License.

Enjoy :metal: