I have an application developed using Angular. It using lazy loading. It working fine on the web. Recently I updated Angular Project to Angular 8 and make a production build and using that dist as the www build the Cordova application. It gives a white page when we launch the app.
It has two levels of routing
Bothe levels have <router-outlet ></router-outlet>
I try with exactly billow Angular 8 example to Run in Cordova 9 https://stackblitz.com/edit/angular-nested-routing-with-modules-with-bootstrap?embed=1&file=src/index.html
app-routing.module.ts
//app-routing.module.ts
import { NgModule } from '@angular/core';
import { Routes, RouterModule } from '@angular/router';
import { DashboardComponent } from './dashboard/dashboard.component';
import { ProfileComponent } from './profile/profile.component';
import { AttendanceComponent } from './attendance/attendance.component';
import { Page404Component } from './page404/page404.component';
const routes: Routes = [
{ path: 'leaves', loadChildren: () => import(`./leaves/leaves.module`).then(m => m.LeavesModule) , },
{ path: 'leaves', redirectTo: 'dashboard', pathMatch: 'full' },
{ path: '**', component: Page404Component },
];
@NgModule({
imports: [
RouterModule.forRoot(routes,{ enableTracing: false })
],
exports: [RouterModule]
})
export class AppRoutingModule { }
leaves-routing.module.ts
//leaves-routing.module.ts
import { NgModule } from '@angular/core';
import { Routes, RouterModule } from '@angular/router';
import { ApplyComponent } from './apply/apply.component';
import { LeavesComponent } from './leaves.component';
import { Page404leavesComponent } from './page404leaves/page404leaves.component';
const routes: Routes = [
{
path: '', component: LeavesComponent, children: [
{
path: 'apply', component: ApplyComponent
},
{
path: '', redirectTo: 'apply', pathMatch: 'full'
},
{ path: '**', component: Page404leavesComponent }
]
}
];
@NgModule({
imports: [RouterModule.forChild(routes)],
exports: [RouterModule]
})
export class LeavesRoutingModule { }
package.json
{
"name": "web",
"version": "0.0.0",
"scripts": {
"ng": "ng",
"start": "ng serve",
"build": "ng build",
"test": "ng test",
"lint": "ng lint",
"e2e": "ng e2e"
},
"private": true,
"dependencies": {
"@angular/animations": "~8.2.14",
"@angular/cdk": "^10.0.2",
"@angular/common": "~8.2.14",
"@angular/compiler": "~8.2.14",
"@angular/core": "~8.2.14",
"@angular/forms": "~8.2.14",
"@angular/platform-browser": "~8.2.14",
"@angular/platform-browser-dynamic": "~8.2.14",
"@angular/router": "~8.2.14",
"rxjs": "~6.4.0",
"tslib": "^1.10.0",
"zone.js": "~0.9.1"
},
"devDependencies": {
"@angular-devkit/build-angular": "~0.803.28",
"@angular/cli": "~8.3.28",
"@angular/compiler-cli": "~8.2.14",
"@angular/language-service": "~8.2.14",
"@types/node": "~8.9.4",
"@types/jasmine": "~3.3.8",
"@types/jasminewd2": "~2.0.3",
"codelyzer": "^5.0.0",
"jasmine-core": "~3.4.0",
"jasmine-spec-reporter": "~4.2.1",
"karma": "~4.1.0",
"karma-chrome-launcher": "~2.2.0",
"karma-coverage-istanbul-reporter": "~2.0.1",
"karma-jasmine": "~2.0.1",
"karma-jasmine-html-reporter": "^1.4.0",
"protractor": "~7.0.0",
"ts-node": "~7.0.0",
"tslint": "~5.15.0",
"typescript": "~3.5.3"
}
}
When we debug the Cordova app by console getting billow type of errors.
Failed to load resource: The requested URL was not found on this server.file:///private/var/containers/Bundle/Application/18A12E91-7FEE-437A-8218-C72D98382451/UPay%20Dev.app/www/polyfills-es2015.ffa9bb4e015925544f91.js
After a few workarounds, I have identified the issue of dynamic routing
What I have used for loading modules dynamically previously is
It should be changed like shown below
Use single-quote insted of backticks
I think this will help someone