mirror of https://github.com/abpframework/abp.git
81 changed files with 562 additions and 644 deletions
@ -1,5 +0,0 @@ |
|||
{ |
|||
"printWidth": 100, |
|||
"singleQuote": true, |
|||
"trailingComma": "all" |
|||
} |
|||
@ -1 +1,27 @@ |
|||
# MyProjectName |
|||
# MyProjectName |
|||
|
|||
This project was generated with [Angular CLI](https://github.com/angular/angular-cli) version 9.1.9. |
|||
|
|||
## Development server |
|||
|
|||
Run `ng serve` for a dev server. Navigate to `http://localhost:4200/`. The app will automatically reload if you change any of the source files. |
|||
|
|||
## Code scaffolding |
|||
|
|||
Run `ng generate component component-name` to generate a new component. You can also use `ng generate directive|pipe|service|class|guard|interface|enum|module`. |
|||
|
|||
## Build |
|||
|
|||
Run `ng build` to build the project. The build artifacts will be stored in the `dist/` directory. Use the `--prod` flag for a production build. |
|||
|
|||
## Running unit tests |
|||
|
|||
Run `ng test` to execute the unit tests via [Karma](https://karma-runner.github.io). |
|||
|
|||
## Running end-to-end tests |
|||
|
|||
Run `ng e2e` to execute the end-to-end tests via [Protractor](http://www.protractortest.org/). |
|||
|
|||
## Further help |
|||
|
|||
To get more help on the Angular CLI use `ng help` or go check out the [Angular CLI README](https://github.com/angular/angular-cli/blob/master/README.md). |
|||
|
|||
@ -1,11 +0,0 @@ |
|||
import { browser, by, element } from 'protractor'; |
|||
|
|||
export class AppPage { |
|||
navigateTo() { |
|||
return browser.get(browser.baseUrl) as Promise<any>; |
|||
} |
|||
|
|||
getTitleText() { |
|||
return element(by.css('app-root h1')).getText() as Promise<string>; |
|||
} |
|||
} |
|||
@ -1,57 +1,51 @@ |
|||
{ |
|||
"name": "MyProjectName", |
|||
"name": "my-project-name", |
|||
"version": "0.0.0", |
|||
"scripts": { |
|||
"ng": "ng", |
|||
"start": "ng serve", |
|||
"start:hmr": "ng serve --open", |
|||
"build": "ng build", |
|||
"start": "ng serve dev-app --open", |
|||
"build": "ng build my-project-name --prod", |
|||
"build:app": "ng build dev-app --prod", |
|||
"test": "ng test", |
|||
"lint": "ng lint", |
|||
"e2e": "ng e2e" |
|||
}, |
|||
"private": true, |
|||
"dependencies": { |
|||
"@abp/ng.account": "~2.9.0", |
|||
"@abp/ng.identity": "~2.9.0", |
|||
"@abp/ng.setting-management": "~2.9.0", |
|||
"@abp/ng.tenant-management": "~2.9.0", |
|||
"@abp/ng.theme.basic": "~2.9.0", |
|||
"@angular/animations": "~9.1.2", |
|||
"@angular/common": "~9.1.2", |
|||
"@angular/compiler": "~9.1.2", |
|||
"@angular/core": "~9.1.2", |
|||
"@angular/forms": "~9.1.2", |
|||
"@angular/platform-browser": "~9.1.2", |
|||
"@angular/platform-browser-dynamic": "~9.1.2", |
|||
"@angular/router": "~9.1.2", |
|||
"rxjs": "~6.5.5", |
|||
"@angular/animations": "~9.1.11", |
|||
"@angular/common": "~9.1.11", |
|||
"@angular/compiler": "~9.1.11", |
|||
"@angular/core": "~9.1.11", |
|||
"@angular/forms": "~9.1.11", |
|||
"@angular/platform-browser": "~9.1.11", |
|||
"@angular/platform-browser-dynamic": "~9.1.11", |
|||
"@angular/router": "~9.1.11", |
|||
"@abp/ng.theme.shared": "~2.9.1", |
|||
"@swimlane/ngx-datatable": "^17.0.0", |
|||
"rxjs": "~6.5.4", |
|||
"tslib": "^1.10.0", |
|||
"zone.js": "~0.10.2" |
|||
}, |
|||
"devDependencies": { |
|||
"@angular-devkit/build-angular": "~0.901.1", |
|||
"@angular-devkit/build-ng-packagr": "~0.901.1", |
|||
"@angular/cli": "~9.1.1", |
|||
"@angular/compiler-cli": "~9.1.2", |
|||
"@angular/language-service": "~9.1.2", |
|||
"@ngxs/logger-plugin": "^3.5.1", |
|||
"@types/jasmine": "~3.3.8", |
|||
"@types/jasminewd2": "~2.0.3", |
|||
"@angular-devkit/build-angular": "~0.901.9", |
|||
"@angular-devkit/build-ng-packagr": "~0.901.9", |
|||
"@angular/cli": "~9.1.9", |
|||
"@angular/compiler-cli": "~9.1.11", |
|||
"@types/node": "^12.11.1", |
|||
"@types/jasmine": "~3.5.0", |
|||
"@types/jasminewd2": "~2.0.3", |
|||
"codelyzer": "^5.1.2", |
|||
"jasmine-core": "~3.4.0", |
|||
"jasmine-core": "~3.5.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", |
|||
"karma": "~5.0.0", |
|||
"karma-chrome-launcher": "~3.1.0", |
|||
"karma-coverage-istanbul-reporter": "~2.1.0", |
|||
"karma-jasmine": "~3.0.1", |
|||
"karma-jasmine-html-reporter": "^1.4.2", |
|||
"ng-packagr": "^9.0.0", |
|||
"ngxs-schematic": "^1.1.9", |
|||
"protractor": "~5.4.0", |
|||
"ts-node": "~7.0.0", |
|||
"tslint": "~5.15.0", |
|||
"protractor": "~7.0.0", |
|||
"ts-node": "~8.3.0", |
|||
"tslint": "~6.1.0", |
|||
"typescript": "~3.8.3" |
|||
} |
|||
} |
|||
|
|||
@ -0,0 +1,11 @@ |
|||
import { browser, by, element } from 'protractor'; |
|||
|
|||
export class AppPage { |
|||
navigateTo(): Promise<unknown> { |
|||
return browser.get(browser.baseUrl) as Promise<unknown>; |
|||
} |
|||
|
|||
getTitleText(): Promise<string> { |
|||
return element(by.css('app-root .content span')).getText() as Promise<string>; |
|||
} |
|||
} |
|||
@ -1,7 +1,7 @@ |
|||
{ |
|||
"extends": "../tsconfig.json", |
|||
"extends": "../../../tsconfig.json", |
|||
"compilerOptions": { |
|||
"outDir": "../out-tsc/e2e", |
|||
"outDir": "../../../out-tsc/e2e", |
|||
"module": "commonjs", |
|||
"target": "es5", |
|||
"types": [ |
|||
|
Before Width: | Height: | Size: 101 KiB After Width: | Height: | Size: 101 KiB |
@ -0,0 +1,57 @@ |
|||
import { ABP, DynamicLayoutComponent } from '@abp/ng.core'; |
|||
import { NgModule } from '@angular/core'; |
|||
import { RouterModule, Routes } from '@angular/router'; |
|||
|
|||
const routes: Routes = [ |
|||
{ |
|||
path: '', |
|||
component: DynamicLayoutComponent, |
|||
children: [ |
|||
{ |
|||
path: '', |
|||
pathMatch: 'full', |
|||
loadChildren: () => |
|||
import('./home/home.module').then((m) => m.HomeModule), |
|||
}, |
|||
{ |
|||
path: 'account', |
|||
loadChildren: () => |
|||
import('@abp/ng.account').then((m) => |
|||
m.AccountModule.forLazy({ redirectUrl: '/' }) |
|||
), |
|||
}, |
|||
{ |
|||
path: 'identity', |
|||
loadChildren: () => |
|||
import('@abp/ng.identity').then((m) => m.IdentityModule.forLazy()), |
|||
}, |
|||
{ |
|||
path: 'tenant-management', |
|||
loadChildren: () => |
|||
import('@abp/ng.tenant-management').then((m) => |
|||
m.TenantManagementModule.forLazy() |
|||
), |
|||
}, |
|||
{ |
|||
path: 'setting-management', |
|||
loadChildren: () => |
|||
import('@abp/ng.setting-management').then((m) => |
|||
m.SettingManagementModule.forLazy() |
|||
), |
|||
}, |
|||
{ |
|||
path: 'my-project-name', |
|||
loadChildren: () => |
|||
import('@my-company-name/my-project-name').then((m) => |
|||
m.MyProjectNameModule.forLazy() |
|||
), |
|||
}, |
|||
], |
|||
}, |
|||
]; |
|||
|
|||
@NgModule({ |
|||
imports: [RouterModule.forRoot(routes)], |
|||
exports: [RouterModule], |
|||
}) |
|||
export class AppRoutingModule {} |
|||
@ -1,44 +1,41 @@ |
|||
import { AccountConfigModule } from '@abp/ng.account.config'; |
|||
import { AccountConfigModule } from '@abp/ng.account/config'; |
|||
import { CoreModule } from '@abp/ng.core'; |
|||
import { IdentityConfigModule } from '@abp/ng.identity.config'; |
|||
import { SettingManagementConfigModule } from '@abp/ng.setting-management.config'; |
|||
import { TenantManagementConfigModule } from '@abp/ng.tenant-management.config'; |
|||
import { IdentityConfigModule } from '@abp/ng.identity/config'; |
|||
import { SettingManagementConfigModule } from '@abp/ng.setting-management/config'; |
|||
import { TenantManagementConfigModule } from '@abp/ng.tenant-management/config'; |
|||
import { ThemeSharedModule } from '@abp/ng.theme.shared'; |
|||
import { NgModule } from '@angular/core'; |
|||
import { BrowserModule } from '@angular/platform-browser'; |
|||
import { BrowserAnimationsModule } from '@angular/platform-browser/animations'; |
|||
import { NgxsLoggerPluginModule } from '@ngxs/logger-plugin'; |
|||
import { MyProjectNameConfigModule } from '@my-company-name/my-project-name/config'; |
|||
import { NgxsModule } from '@ngxs/store'; |
|||
import { OAuthModule } from 'angular-oauth2-oidc'; |
|||
import { MyProjectNameConfigModule } from '../../projects/my-project-name-config/src/public-api'; |
|||
import { environment } from '../environments/environment'; |
|||
import { AppRoutingModule } from './app-routing.module'; |
|||
import { AppComponent } from './app.component'; |
|||
import { APP_ROUTE_PROVIDER } from './route.provider'; |
|||
import { SharedModule } from './shared/shared.module'; |
|||
|
|||
const LOGGERS = [NgxsLoggerPluginModule.forRoot({ disabled: false })]; |
|||
|
|||
@NgModule({ |
|||
declarations: [AppComponent], |
|||
imports: [ |
|||
BrowserModule, |
|||
BrowserAnimationsModule, |
|||
AppRoutingModule, |
|||
ThemeSharedModule.forRoot(), |
|||
CoreModule.forRoot({ |
|||
environment, |
|||
sendNullsAsQueryParam: false, |
|||
skipGetAppConfiguration: false, |
|||
}), |
|||
OAuthModule.forRoot(), |
|||
NgxsModule.forRoot([]), |
|||
AccountConfigModule.forRoot({ redirectUrl: '/' }), |
|||
IdentityConfigModule, |
|||
TenantManagementConfigModule, |
|||
SettingManagementConfigModule, |
|||
MyProjectNameConfigModule, |
|||
ThemeSharedModule.forRoot(), |
|||
AccountConfigModule.forRoot(), |
|||
IdentityConfigModule.forRoot(), |
|||
MyProjectNameConfigModule.forRoot(), |
|||
TenantManagementConfigModule.forRoot(), |
|||
SettingManagementConfigModule.forRoot(), |
|||
NgxsModule.forRoot(), |
|||
SharedModule, |
|||
|
|||
...(environment.production ? [] : LOGGERS), |
|||
], |
|||
providers: [APP_ROUTE_PROVIDER], |
|||
declarations: [AppComponent], |
|||
bootstrap: [AppComponent], |
|||
}) |
|||
export class AppModule {} |
|||
@ -1,12 +1,10 @@ |
|||
import { NgModule } from '@angular/core'; |
|||
import { Routes, RouterModule } from '@angular/router'; |
|||
import { HomeComponent } from './home.component'; |
|||
import { ApplicationLayoutComponent } from '@abp/ng.theme.basic'; |
|||
|
|||
const routes: Routes = [ |
|||
{ |
|||
path: '', |
|||
component: ApplicationLayoutComponent, |
|||
children: [{ path: '', component: HomeComponent }], |
|||
}, |
|||
]; |
|||
@ -0,0 +1,7 @@ |
|||
import { Component } from '@angular/core'; |
|||
|
|||
@Component({ |
|||
selector: 'app-home', |
|||
templateUrl: './home.component.html', |
|||
}) |
|||
export class HomeComponent {} |
|||
@ -0,0 +1,25 @@ |
|||
import { RoutesService, eLayoutType } from '@abp/ng.core'; |
|||
import { APP_INITIALIZER } from '@angular/core'; |
|||
|
|||
export const APP_ROUTE_PROVIDER = [ |
|||
{ |
|||
provide: APP_INITIALIZER, |
|||
useFactory: configureRoutes, |
|||
deps: [RoutesService], |
|||
multi: true, |
|||
}, |
|||
]; |
|||
|
|||
function configureRoutes(routes: RoutesService) { |
|||
return () => { |
|||
routes.add([ |
|||
{ |
|||
path: '/', |
|||
name: 'Home', |
|||
iconClass: 'fas fa-home', |
|||
order: 1, |
|||
layout: eLayoutType.application, |
|||
}, |
|||
]); |
|||
}; |
|||
} |
|||
@ -0,0 +1,13 @@ |
|||
<!doctype html> |
|||
<html lang="en"> |
|||
<head> |
|||
<meta charset="utf-8"> |
|||
<title>DevApp</title> |
|||
<base href="/"> |
|||
<meta name="viewport" content="width=device-width, initial-scale=1"> |
|||
<link rel="icon" type="image/x-icon" href="favicon.ico"> |
|||
</head> |
|||
<body> |
|||
<app-root></app-root> |
|||
</body> |
|||
</html> |
|||
@ -0,0 +1 @@ |
|||
/* You can add global styles to this file, and also import other style files */ |
|||
@ -0,0 +1,14 @@ |
|||
{ |
|||
"extends": "../../tsconfig.json", |
|||
"compilerOptions": { |
|||
"outDir": "../../out-tsc/app", |
|||
"types": [] |
|||
}, |
|||
"files": [ |
|||
"src/main.ts", |
|||
"src/polyfills.ts" |
|||
], |
|||
"include": [ |
|||
"src/**/*.d.ts" |
|||
] |
|||
} |
|||
@ -0,0 +1,9 @@ |
|||
{ |
|||
"extends": "../../tsconfig.prod.json", |
|||
"compilerOptions": { |
|||
"outDir": "../../out-tsc/app", |
|||
"types": [] |
|||
}, |
|||
"files": ["src/main.ts", "src/polyfills.ts"], |
|||
"include": ["src/**/*.d.ts"] |
|||
} |
|||
@ -1,7 +1,7 @@ |
|||
{ |
|||
"extends": "./tsconfig.json", |
|||
"extends": "../../tsconfig.json", |
|||
"compilerOptions": { |
|||
"outDir": "./out-tsc/spec", |
|||
"outDir": "../../out-tsc/spec", |
|||
"types": [ |
|||
"jasmine", |
|||
"node" |
|||
@ -1 +0,0 @@ |
|||
# MyProjectNameConfig |
|||
@ -1,32 +0,0 @@ |
|||
// Karma configuration file, see link for more information
|
|||
// https://karma-runner.github.io/1.0/config/configuration-file.html
|
|||
|
|||
module.exports = function (config) { |
|||
config.set({ |
|||
basePath: '', |
|||
frameworks: ['jasmine', '@angular-devkit/build-angular'], |
|||
plugins: [ |
|||
require('karma-jasmine'), |
|||
require('karma-chrome-launcher'), |
|||
require('karma-jasmine-html-reporter'), |
|||
require('karma-coverage-istanbul-reporter'), |
|||
require('@angular-devkit/build-angular/plugins/karma') |
|||
], |
|||
client: { |
|||
clearContext: false // leave Jasmine Spec Runner output visible in browser
|
|||
}, |
|||
coverageIstanbulReporter: { |
|||
dir: require('path').join(__dirname, '../../coverage/my-project-name-config'), |
|||
reports: ['html', 'lcovonly', 'text-summary'], |
|||
fixWebpackSourcePaths: true |
|||
}, |
|||
reporters: ['progress', 'kjhtml'], |
|||
port: 9876, |
|||
colors: true, |
|||
logLevel: config.LOG_INFO, |
|||
autoWatch: true, |
|||
browsers: ['Chrome'], |
|||
singleRun: false, |
|||
restartOnFileChange: true |
|||
}); |
|||
}; |
|||
@ -1,7 +0,0 @@ |
|||
{ |
|||
"$schema": "../../node_modules/ng-packagr/ng-package.schema.json", |
|||
"dest": "../../dist/my-project-name-config", |
|||
"lib": { |
|||
"entryFile": "src/public-api.ts" |
|||
} |
|||
} |
|||
@ -1,7 +0,0 @@ |
|||
{ |
|||
"name": "my-project-name.config", |
|||
"version": "0.0.1", |
|||
"peerDependencies": { |
|||
"@abp/ng.core": "~2.9.0" |
|||
} |
|||
} |
|||
@ -1,9 +0,0 @@ |
|||
import { Component } from '@angular/core'; |
|||
|
|||
@Component({ |
|||
selector: 'my-project-name-settings', |
|||
template: ` |
|||
<h3>MyProjectName Settings</h3> |
|||
`,
|
|||
}) |
|||
export class MyProjectNameSettingsComponent {} |
|||
@ -1,12 +0,0 @@ |
|||
import { NgModule, APP_INITIALIZER } from '@angular/core'; |
|||
import { MyProjectNameConfigService } from './services/my-project-name-config.service'; |
|||
import { noop } from '@abp/ng.core'; |
|||
import { MyProjectNameSettingsComponent } from './components/my-project-name-settings.component'; |
|||
|
|||
@NgModule({ |
|||
declarations: [MyProjectNameSettingsComponent], |
|||
providers: [{ provide: APP_INITIALIZER, deps: [MyProjectNameConfigService], multi: true, useFactory: noop }], |
|||
exports: [MyProjectNameSettingsComponent], |
|||
entryComponents: [MyProjectNameSettingsComponent], |
|||
}) |
|||
export class MyProjectNameConfigModule {} |
|||
@ -1,25 +0,0 @@ |
|||
import { Injectable } from '@angular/core'; |
|||
import { eLayoutType, addAbpRoutes, ABP } from '@abp/ng.core'; |
|||
import { addSettingTab } from '@abp/ng.theme.shared'; |
|||
import { MyProjectNameSettingsComponent } from '../components/my-project-name-settings.component'; |
|||
|
|||
@Injectable({ |
|||
providedIn: 'root', |
|||
}) |
|||
export class MyProjectNameConfigService { |
|||
constructor() { |
|||
addAbpRoutes({ |
|||
name: 'MyProjectName', |
|||
path: 'my-project-name', |
|||
layout: eLayoutType.application, |
|||
order: 2, |
|||
} as ABP.FullRoute); |
|||
|
|||
const route = addSettingTab({ |
|||
component: MyProjectNameSettingsComponent, |
|||
name: 'MyProjectName Settings', |
|||
order: 1, |
|||
requiredPolicy: '', |
|||
}); |
|||
} |
|||
} |
|||
@ -1,3 +0,0 @@ |
|||
export * from './lib/components/my-project-name-settings.component'; |
|||
export * from './lib/services/my-project-name-config.service'; |
|||
export * from './lib/my-project-name-config.module'; |
|||
@ -1,21 +0,0 @@ |
|||
// This file is required by karma.conf.js and loads recursively all the .spec and framework files
|
|||
|
|||
import 'zone.js/dist/zone'; |
|||
import 'zone.js/dist/zone-testing'; |
|||
import { getTestBed } from '@angular/core/testing'; |
|||
import { |
|||
BrowserDynamicTestingModule, |
|||
platformBrowserDynamicTesting |
|||
} from '@angular/platform-browser-dynamic/testing'; |
|||
|
|||
declare const require: any; |
|||
|
|||
// First, initialize the Angular testing environment.
|
|||
getTestBed().initTestEnvironment( |
|||
BrowserDynamicTestingModule, |
|||
platformBrowserDynamicTesting() |
|||
); |
|||
// Then we find all the tests.
|
|||
const context = require.context('./', true, /\.spec\.ts$/); |
|||
// And load the modules.
|
|||
context.keys().map(context); |
|||
@ -1,25 +0,0 @@ |
|||
{ |
|||
"extends": "../../tsconfig.json", |
|||
"compilerOptions": { |
|||
"outDir": "../../out-tsc/lib", |
|||
"target": "es2015", |
|||
"declaration": true, |
|||
"inlineSources": true, |
|||
"types": [], |
|||
"lib": [ |
|||
"dom", |
|||
"es2018" |
|||
] |
|||
}, |
|||
"angularCompilerOptions": { |
|||
"skipTemplateCodegen": true, |
|||
"strictMetadataEmit": true, |
|||
"fullTemplateTypeCheck": true, |
|||
"strictInjectionParameters": true, |
|||
"enableResourceInlining": true |
|||
}, |
|||
"exclude": [ |
|||
"src/test.ts", |
|||
"**/*.spec.ts" |
|||
] |
|||
} |
|||
@ -1,6 +0,0 @@ |
|||
{ |
|||
"extends": "./tsconfig.lib.json", |
|||
"angularCompilerOptions": { |
|||
"enableIvy": false |
|||
} |
|||
} |
|||
@ -1,17 +0,0 @@ |
|||
{ |
|||
"extends": "../../tsconfig.json", |
|||
"compilerOptions": { |
|||
"outDir": "../../out-tsc/spec", |
|||
"types": [ |
|||
"jasmine", |
|||
"node" |
|||
] |
|||
}, |
|||
"files": [ |
|||
"src/test.ts" |
|||
], |
|||
"include": [ |
|||
"**/*.spec.ts", |
|||
"**/*.d.ts" |
|||
] |
|||
} |
|||
@ -1 +1,24 @@ |
|||
# MyProjectName |
|||
# MyProjectName |
|||
|
|||
This library was generated with [Angular CLI](https://github.com/angular/angular-cli) version 9.1.11. |
|||
|
|||
## Code scaffolding |
|||
|
|||
Run `ng generate component component-name --project my-project-name` to generate a new component. You can also use `ng generate directive|pipe|service|class|guard|interface|enum|module --project my-project-name`. |
|||
> Note: Don't forget to add `--project my-project-name` or else it will be added to the default project in your `angular.json` file. |
|||
|
|||
## Build |
|||
|
|||
Run `ng build my-project-name` to build the project. The build artifacts will be stored in the `dist/` directory. |
|||
|
|||
## Publishing |
|||
|
|||
After building your library with `ng build my-project-name`, go to the dist folder `cd dist/my-project-name` and run `npm publish`. |
|||
|
|||
## Running unit tests |
|||
|
|||
Run `ng test my-project-name` to execute the unit tests via [Karma](https://karma-runner.github.io). |
|||
|
|||
## Further help |
|||
|
|||
To get more help on the Angular CLI use `ng help` or go check out the [Angular CLI README](https://github.com/angular/angular-cli/blob/master/README.md). |
|||
|
|||
@ -0,0 +1,7 @@ |
|||
{ |
|||
"$schema": "../../../node_modules/ng-packagr/ng-package.schema.json", |
|||
"dest": "../../dist/my-project-name/config", |
|||
"lib": { |
|||
"entryFile": "src/public-api.ts" |
|||
} |
|||
} |
|||
@ -0,0 +1 @@ |
|||
export * from './route-names'; |
|||
@ -0,0 +1,3 @@ |
|||
export const enum eMyProjectNameRouteNames { |
|||
MyProjectName = 'MyProjectName', |
|||
} |
|||
@ -0,0 +1,12 @@ |
|||
import { ModuleWithProviders, NgModule } from '@angular/core'; |
|||
import { MY_PROJECT_NAME_ROUTE_PROVIDERS } from './providers/route.provider'; |
|||
|
|||
@NgModule() |
|||
export class MyProjectNameConfigModule { |
|||
static forRoot(): ModuleWithProviders<MyProjectNameConfigModule> { |
|||
return { |
|||
ngModule: MyProjectNameConfigModule, |
|||
providers: [MY_PROJECT_NAME_ROUTE_PROVIDERS], |
|||
}; |
|||
} |
|||
} |
|||
@ -0,0 +1 @@ |
|||
export * from './route.provider'; |
|||
@ -0,0 +1,28 @@ |
|||
import { eLayoutType, RoutesService } from '@abp/ng.core'; |
|||
import { eThemeSharedRouteNames } from '@abp/ng.theme.shared'; |
|||
import { APP_INITIALIZER } from '@angular/core'; |
|||
import { eMyProjectNameRouteNames } from '../enums/route-names'; |
|||
|
|||
export const MY_PROJECT_NAME_ROUTE_PROVIDERS = [ |
|||
{ |
|||
provide: APP_INITIALIZER, |
|||
useFactory: configureRoutes, |
|||
deps: [RoutesService], |
|||
multi: true, |
|||
}, |
|||
]; |
|||
|
|||
export function configureRoutes(routes: RoutesService) { |
|||
return () => { |
|||
routes.add([ |
|||
{ |
|||
path: '/my-project-name', |
|||
name: eMyProjectNameRouteNames.MyProjectName, |
|||
parentName: eThemeSharedRouteNames.Administration, |
|||
iconClass: 'fas fa-book', |
|||
layout: eLayoutType.application, |
|||
order: 3, |
|||
}, |
|||
]); |
|||
}; |
|||
} |
|||
@ -0,0 +1,3 @@ |
|||
export * from './enums'; |
|||
export * from './my-project-name-config.module'; |
|||
export * from './providers'; |
|||
@ -1,8 +1,13 @@ |
|||
{ |
|||
"name": "my-project-name", |
|||
"version": "0.0.1", |
|||
"peerDependencies": { |
|||
"@angular/common": "^9.1.11", |
|||
"@angular/core": "^9.1.11", |
|||
"@abp/ng.core": ">=3.0.0", |
|||
"@abp/ng.theme.shared": ">=3.0.0" |
|||
}, |
|||
"dependencies": { |
|||
"@abp/ng.theme.shared": "~2.9.0", |
|||
"my-project-name.config": "^0.0.1" |
|||
"tslib": "^1.10.0" |
|||
} |
|||
} |
|||
|
|||
@ -1,12 +1,23 @@ |
|||
import { NgModule } from '@angular/core'; |
|||
import { NgModule, NgModuleFactory, ModuleWithProviders } from '@angular/core'; |
|||
import { CoreModule, LazyModuleFactory } from '@abp/ng.core'; |
|||
import { ThemeSharedModule } from '@abp/ng.theme.shared'; |
|||
import { MyProjectNameComponent } from './components/my-project-name.component'; |
|||
import { MyProjectNameRoutingModule } from './my-project-name-routing.module'; |
|||
import { ThemeSharedModule } from '@abp/ng.theme.shared'; |
|||
import { CoreModule } from '@abp/ng.core'; |
|||
|
|||
@NgModule({ |
|||
declarations: [MyProjectNameComponent], |
|||
imports: [CoreModule, ThemeSharedModule, MyProjectNameRoutingModule], |
|||
exports: [MyProjectNameComponent], |
|||
}) |
|||
export class MyProjectNameModule {} |
|||
export class MyProjectNameModule { |
|||
static forChild(): ModuleWithProviders<MyProjectNameModule> { |
|||
return { |
|||
ngModule: MyProjectNameModule, |
|||
providers: [], |
|||
}; |
|||
} |
|||
|
|||
static forLazy(): NgModuleFactory<MyProjectNameModule> { |
|||
return new LazyModuleFactory(MyProjectNameModule.forChild()); |
|||
} |
|||
} |
|||
|
|||
@ -0,0 +1,16 @@ |
|||
import { TestBed } from '@angular/core/testing'; |
|||
|
|||
import { MyProjectNameService } from './my-project-name.service'; |
|||
|
|||
describe('MyProjectNameService', () => { |
|||
let service: MyProjectNameService; |
|||
|
|||
beforeEach(() => { |
|||
TestBed.configureTestingModule({}); |
|||
service = TestBed.inject(MyProjectNameService); |
|||
}); |
|||
|
|||
it('should be created', () => { |
|||
expect(service).toBeTruthy(); |
|||
}); |
|||
}); |
|||
@ -0,0 +1,9 @@ |
|||
import { Injectable } from '@angular/core'; |
|||
|
|||
@Injectable({ |
|||
providedIn: 'root' |
|||
}) |
|||
export class MyProjectNameService { |
|||
|
|||
constructor() { } |
|||
} |
|||
@ -1,2 +1,7 @@ |
|||
/* |
|||
* Public API Surface of my-project-name |
|||
*/ |
|||
|
|||
export * from './lib/components/my-project-name.component'; |
|||
export * from './lib/services/my-project-name.service'; |
|||
export * from './lib/my-project-name.module'; |
|||
|
|||
@ -1,25 +1,17 @@ |
|||
{ |
|||
"extends": "../../tsconfig.json", |
|||
"extends": "../../tsconfig.prod.json", |
|||
"compilerOptions": { |
|||
"outDir": "../../out-tsc/lib", |
|||
"target": "es2015", |
|||
"declaration": true, |
|||
"inlineSources": true, |
|||
"types": [], |
|||
"lib": [ |
|||
"dom", |
|||
"es2018" |
|||
] |
|||
"lib": ["dom", "es2018"] |
|||
}, |
|||
"angularCompilerOptions": { |
|||
"skipTemplateCodegen": true, |
|||
"strictMetadataEmit": true, |
|||
"fullTemplateTypeCheck": true, |
|||
"strictInjectionParameters": true, |
|||
"enableResourceInlining": true |
|||
}, |
|||
"exclude": [ |
|||
"src/test.ts", |
|||
"**/*.spec.ts" |
|||
] |
|||
"exclude": ["src/test.ts", "**/*.spec.ts"] |
|||
} |
|||
|
|||
@ -1,51 +0,0 @@ |
|||
import { ABP } from '@abp/ng.core'; |
|||
import { NgModule } from '@angular/core'; |
|||
import { RouterModule, Routes } from '@angular/router'; |
|||
|
|||
const routes: Routes = [ |
|||
{ |
|||
path: '', |
|||
loadChildren: () => import('./home/home.module').then(m => m.HomeModule), |
|||
data: { |
|||
routes: { |
|||
name: 'Home', |
|||
order: 1, |
|||
} as ABP.Route, |
|||
}, |
|||
}, |
|||
{ |
|||
path: 'account', |
|||
loadChildren: () => |
|||
import('./lazy-libs/account-wrapper.module').then(m => m.AccountWrapperModule), |
|||
}, |
|||
{ |
|||
path: 'identity', |
|||
loadChildren: () => |
|||
import('./lazy-libs/identity-wrapper.module').then(m => m.IdentityWrapperModule), |
|||
}, |
|||
{ |
|||
path: 'tenant-management', |
|||
loadChildren: () => |
|||
import('./lazy-libs/tenant-management-wrapper.module').then( |
|||
m => m.TenantManagementWrapperModule, |
|||
), |
|||
}, |
|||
{ |
|||
path: 'setting-management', |
|||
loadChildren: () => |
|||
import('./lazy-libs/setting-management-wrapper.module').then( |
|||
m => m.SettingManagementWrapperModule, |
|||
), |
|||
}, |
|||
{ |
|||
path: 'my-project-name', |
|||
loadChildren: () => |
|||
import('./lazy-libs/my-project-name-wrapper.module').then(m => m.MyProjectNameWrapperModule), |
|||
}, |
|||
]; |
|||
|
|||
@NgModule({ |
|||
imports: [RouterModule.forRoot(routes)], |
|||
exports: [RouterModule], |
|||
}) |
|||
export class AppRoutingModule {} |
|||
@ -1,6 +0,0 @@ |
|||
<div id="AbpContentToolbar"></div> |
|||
<div class="row"> |
|||
<a routerLink="/account/login" [state]="{ redirectUrl: '/' }" role="button"> |
|||
{{ '::Login' | abpLocalization }}</a |
|||
> |
|||
</div> |
|||
@ -1,14 +0,0 @@ |
|||
import { Component } from '@angular/core'; |
|||
import { OAuthService } from 'angular-oauth2-oidc'; |
|||
|
|||
@Component({ |
|||
selector: 'app-home', |
|||
templateUrl: './home.component.html', |
|||
}) |
|||
export class HomeComponent { |
|||
get hasLoggedIn(): boolean { |
|||
return this.oAuthService.hasValidAccessToken(); |
|||
} |
|||
|
|||
constructor(private oAuthService: OAuthService) {} |
|||
} |
|||
@ -1,7 +0,0 @@ |
|||
import { NgModule } from '@angular/core'; |
|||
import { AccountModule } from '@abp/ng.account'; |
|||
|
|||
@NgModule({ |
|||
imports: [AccountModule], |
|||
}) |
|||
export class AccountWrapperModule {} |
|||
@ -1,7 +0,0 @@ |
|||
import { NgModule } from '@angular/core'; |
|||
import { IdentityModule } from '@abp/ng.identity'; |
|||
|
|||
@NgModule({ |
|||
imports: [IdentityModule], |
|||
}) |
|||
export class IdentityWrapperModule {} |
|||
@ -1,7 +0,0 @@ |
|||
import { NgModule } from '@angular/core'; |
|||
import { MyProjectNameModule } from '../../../projects/my-project-name/src/public-api'; |
|||
|
|||
@NgModule({ |
|||
imports: [MyProjectNameModule], |
|||
}) |
|||
export class MyProjectNameWrapperModule {} |
|||
@ -1,7 +0,0 @@ |
|||
import { NgModule } from '@angular/core'; |
|||
import { SettingManagementModule } from '@abp/ng.setting-management'; |
|||
|
|||
@NgModule({ |
|||
imports: [SettingManagementModule], |
|||
}) |
|||
export class SettingManagementWrapperModule {} |
|||
@ -1,7 +0,0 @@ |
|||
import { NgModule } from '@angular/core'; |
|||
import { TenantManagementModule } from '@abp/ng.tenant-management'; |
|||
|
|||
@NgModule({ |
|||
imports: [TenantManagementModule], |
|||
}) |
|||
export class TenantManagementWrapperModule {} |
|||
@ -1,16 +0,0 @@ |
|||
<!DOCTYPE html> |
|||
<html lang="en"> |
|||
<head> |
|||
<meta charset="utf-8" /> |
|||
<title>MyProjectName</title> |
|||
<base href="/" /> |
|||
|
|||
<meta name="viewport" content="width=device-width, initial-scale=1" /> |
|||
<link rel="icon" type="image/x-icon" href="favicon.ico" /> |
|||
</head> |
|||
<body class="bg-light"> |
|||
<app-root> |
|||
<div class="donut centered"></div> |
|||
</app-root> |
|||
</body> |
|||
</html> |
|||
@ -1,27 +0,0 @@ |
|||
/* You can add global styles to this file, and also import other style files */ |
|||
|
|||
@keyframes donut-spin { |
|||
0% { |
|||
transform: rotate(0deg); |
|||
} |
|||
100% { |
|||
transform: rotate(360deg); |
|||
} |
|||
} |
|||
.donut { |
|||
display: inline-block; |
|||
border: 4px solid rgba(0, 0, 0, 0.1); |
|||
border-left-color: #7983ff; |
|||
border-radius: 50%; |
|||
width: 30px; |
|||
height: 30px; |
|||
animation: donut-spin 1.2s linear infinite; |
|||
|
|||
&.centered { |
|||
position: fixed; |
|||
top: 50%; |
|||
left: 50%; |
|||
/* bring your own prefixes */ |
|||
transform: translate(-50%, -50%); |
|||
} |
|||
} |
|||
@ -1,12 +0,0 @@ |
|||
{ |
|||
"extends": "./tsconfig.json", |
|||
"compilerOptions": { |
|||
"outDir": "./out-tsc/app", |
|||
"types": ["node"] |
|||
}, |
|||
"files": [ |
|||
"src/main.ts", |
|||
"src/polyfills.ts" |
|||
], |
|||
"include": ["src/**/*.d.ts"] |
|||
} |
|||
@ -1,37 +1,13 @@ |
|||
{ |
|||
"compileOnSave": false, |
|||
"extends": "./tsconfig.prod.json", |
|||
"compilerOptions": { |
|||
"baseUrl": "./", |
|||
"outDir": "./dist/out-tsc", |
|||
"sourceMap": true, |
|||
"declaration": false, |
|||
"downlevelIteration": true, |
|||
"emitDecoratorMetadata": true, |
|||
"experimentalDecorators": true, |
|||
"module": "esnext", |
|||
"moduleResolution": "node", |
|||
"importHelpers": true, |
|||
"target": "es2015", |
|||
"typeRoots": [ |
|||
"node_modules/@types" |
|||
], |
|||
"lib": [ |
|||
"es2018", |
|||
"dom" |
|||
], |
|||
"paths": { |
|||
"my-project-name": [ |
|||
"dist/my-project-name" |
|||
"@my-company-name/my-project-name": [ |
|||
"projects/my-project-name/src/public-api.ts" |
|||
], |
|||
"my-project-name/*": [ |
|||
"dist/my-project-name/*" |
|||
], |
|||
"my-project-name-config": [ |
|||
"dist/my-project-name-config" |
|||
], |
|||
"my-project-name-config/*": [ |
|||
"dist/my-project-name-config/*" |
|||
"@my-company-name/my-project-name/config": [ |
|||
"projects/my-project-name/config/src/public-api.ts" |
|||
] |
|||
} |
|||
} |
|||
} |
|||
} |
|||
|
|||
@ -0,0 +1,20 @@ |
|||
{ |
|||
"compileOnSave": false, |
|||
"compilerOptions": { |
|||
"baseUrl": "./", |
|||
"outDir": "./dist/out-tsc", |
|||
"sourceMap": true, |
|||
"declaration": false, |
|||
"downlevelIteration": true, |
|||
"experimentalDecorators": true, |
|||
"module": "esnext", |
|||
"moduleResolution": "node", |
|||
"importHelpers": true, |
|||
"target": "es2015", |
|||
"lib": ["es2018", "dom"] |
|||
}, |
|||
"angularCompilerOptions": { |
|||
"fullTemplateTypeCheck": true, |
|||
"strictInjectionParameters": true |
|||
} |
|||
} |
|||
Loading…
Reference in new issue