Skip to content

Navigation Menu

Sign in
Appearance settings

Search code, repositories, users, issues, pull requests...

Provide feedback

We read every piece of feedback, and take your input very seriously.

Saved searches

Use saved searches to filter your results more quickly

Appearance settings

dmmishchenko/angular-clean-code

Open more actions menu

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

63 Commits
63 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

angular-clean-code

Clean code architecture example: https://github.com/dmmishchenko/angular-clean-code/tree/clean-code-architecture

Project structure

Short overview:

  • Grouped by scope: review (feature-specific) and shared (reused across the app).
  • Grouped by role inside each scope:
    • feature: components/widgets and any feature-only services
    • data-access: use cases and adapters/services/repositories
    • ui: dumb/reusable UI with no business logic
    • util: pure interfaces and models (framework-free)
  • Pages compose feature components.
  • DI tokens live next to the implementations (e.g., review/data-access/tokens.ts, shared/tokens.ts).

Dependency direction:

  • feature → data-access → util
  • ui depends only on util (and Angular), never on feature internals
  • shared can be used by any scope
src/
  pages/
    review-page/                 # page composed from feature widgets

  libs/
    review/
      feature/                   # widgets (header, right-panel, versions-list, video-menu, workspace)
        header/
        right-panel/
        versions-list/
        video-menu/
        workspace/
          services/
            media-assets.service.ts
      data-access/               # usecases + adapters/services/repositories
        review-page-state/
        route-query-state.service.ts
        review-query-state.decorator.ts
        sync/
        versions-mock.repository.ts
        tokens.ts
        usecases/
      ui/                        # reusable UI (no business logic)
        media-asset/
      util/                      # pure interfaces and models
        interfaces/
        models/

    shared/
      data-access/
        message-bus.service.ts
      util/
        errors/
        interfaces/
        models/
      tokens.ts

TypeScript path aliases:

"paths": {
  "@review/*": ["src/libs/review/*"],
  "@shared/*": ["src/libs/shared/*"]
}

About

Repository with different approaches to architecture

Topics

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published
Morty Proxy This is a proxified and sanitized view of the page, visit original site.