📄Page Structure

../src/index.html

index.html
<!doctype html>
<html lang="en">
  <head>
    <title>Able Pro Angular Dashboard Template</title>
    <base href="/" />
    <!-- Meta -->
    <meta charset="utf-8" />
    <meta name="viewport" content="width=device-width, initial-scale=1, user-scalable=0, minimal-ui" />
    <meta http-equiv="X-UA-Compatible" content="IE=edge" />
    <meta
      name="description"
      content="Able pro angular 19+ admin template made using Angular Material 19+ and it has huge amount of ready made feature, UI components, pages which completely fulfills any dashboard needs."
    />
    <meta
      name="keywords"
      content="Admin templates, Angular Material Admin templates, angular 19+, Angular Material 19, Dashboard, Dashboard Templates, sass admin templates, html admin templates, Responsive, Angular19 Admin templates free download, premium Angular19 Admin templates download"
    />
    <meta name="author" content="CodedThemes" />
    <!-- theme style -->
    <link rel="icon" type="image/x-icon" href="favicon.ico" />
    <link rel="preconnect" href="https://fonts.gstatic.com" />
    <link href="https://fonts.googleapis.com/icon?family=Material+Icons" rel="stylesheet" />
    <link rel="stylesheet" href="assets/fonts/inter/inter.css" id="main-font-link" />
  </head>
  <body class="mat-typography">
    <app-root></app-root>
  </body>
</html>

../src/app/app.component.html

app.component.html
<router-outlet>
    <!-- loadChildren from app-routing.module.ts with admin.component.html or auth.component.html -->
</router-outlet>

../src/app/app-routing.module.ts

app-routing.module.ts
import { NgModule } from '@angular/core';
import { RouterModule, Routes } from '@angular/router';

import { AdminComponent } from './demo/layout/admin';
import { EmptyComponent } from './demo/layout/empty/empty.component';
import { GuestComponent } from './demo/layout/front/guest.component';
import { AuthGuardChild } from './@theme/helpers/auth.guard';
```

const routes: Routes = [
 {
    path: '',
    component: GuestComponent,
    children: [
     // load children modules with lazy load routing for without a common structure, like landing, contact-us, components, etc... 
    ]
  },
  {
    path: '',
    component: AdminComponent,
    canActivateChild: [AuthGuardChild],
    children: [
      // load children modules with lazy load routing for header, side nav common structure, like, dashboard, blank page, widget, etc...
    ]
  },
  {
    path: '',
    component: EmptyComponent,
    children: [
     // load children modules with lazy load routing without a common structure, like login, signup, reset the password, maintenance, etc...
    ]
  },
  {
    path: '**',
    loadComponent: () => import('./demo/pages/maintenance/error/error.component').then((c) => c.ErrorComponent)
  }
];

../src/app/demo/layout/admin/admin.component.html

admin.component.html
<mat-drawer-container class="example-container" [dir]="direction">
  <mat-drawer #sidebar class="pc-sidebar" [mode]="modeValue" opened>
    <nav>
      <div class="navbar-wrapper">
        <div class="m-header">
          <a>
            <img src="assets/images/logo-dark.svg" />
          </a>
        </div>
        <app-vertical-menu *ngIf="ableProConfig.layout === 'vertical'" [menus]="menus"></app-vertical-menu> <!-- for side nav - vertical.component.html -->
      </div>
    </nav>
  </mat-drawer>
  <app-nav-bar></app-nav-bar>  <!-- for header - toolbar.component.html -->
  <div class="pc-container">
    <div class="coded-wrapper">
      <div class="coded-inner-content">
        <app-breadcrumb [dashboard]="true"></app-breadcrumb> <!-- for common breadcrumb - breadcrumb.component.html -->
        <div class="main-body">
          <div class="page-wrapper">
            <router-outlet>
            <!-- page main body - loadChildren as main page body from src/app/demo/pages/... -->
            </router-outlet>
          </div>
        </div>
      </div>
    </div>
  </div>
  <app-footer></app-footer> <!-- for common footer-->
</mat-drawer-container>
<app-configuration></app-configuration> <!-- for common configuration-->

../src/app/demo/layout/empty.component.html

empty.component.html
<router-outlet>
    <!-- loadChildren component for guest.component at app-routing.module.ts for authentication blank pages without nav, header, etc. -->
</router-outlet>

Last updated