exceladdincbms-v2 20.0.3 → 20.0.5
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/esm2022/bulk-tool-20.mjs +5 -0
- package/esm2022/lib/auth.service.mjs +50 -0
- package/esm2022/lib/bulk-tool.component.mjs +22 -0
- package/esm2022/lib/bulk-tool.module.mjs +50 -0
- package/esm2022/lib/bulk-tool.service.mjs +14 -0
- package/esm2022/lib/constant.enum.mjs +6 -0
- package/esm2022/lib/environmentsModel.info.mjs +2 -0
- package/esm2022/lib/http-interceptor.mjs +25 -0
- package/esm2022/lib/login/login.component.mjs +84 -0
- package/esm2022/lib/materils/materils.module.mjs +172 -0
- package/esm2022/lib/menu/menu.component.mjs +47 -0
- package/esm2022/public_api.mjs +10 -0
- package/fesm2022/bulk-tool-20.mjs +448 -0
- package/fesm2022/bulk-tool-20.mjs.map +1 -0
- package/index.d.ts +31 -83
- package/lib/auth.service.d.ts +16 -0
- package/lib/bulk-tool.component.d.ts +8 -0
- package/lib/bulk-tool.module.d.ts +17 -0
- package/lib/bulk-tool.service.d.ts +6 -0
- package/lib/constant.enum.d.ts +5 -0
- package/lib/environmentsModel.info.d.ts +3 -0
- package/lib/http-interceptor.d.ts +8 -0
- package/lib/login/login.component.d.ts +27 -0
- package/lib/materils/materils.module.d.ts +45 -0
- package/lib/menu/menu.component.d.ts +28 -0
- package/package.json +5 -5
- package/public_api.d.ts +6 -2
- package/fesm2022/exceladdincbms-20.mjs +0 -638
- package/fesm2022/exceladdincbms-20.mjs.map +0 -1
- package/src/lib/auth.service.ts +0 -46
- package/src/lib/base-app.service.ts +0 -36
- package/src/lib/bulk-tool.component.ts +0 -20
- package/src/lib/bulk-tool.module.ts +0 -32
- package/src/lib/constant.enum.ts +0 -6
- package/src/lib/environmentsModel.info.ts +0 -14
- package/src/lib/http-interceptor.ts +0 -22
- package/src/lib/login/login.component.css +0 -103
- package/src/lib/login/login.component.html +0 -59
- package/src/lib/login/login.component.ts +0 -105
- package/src/lib/materils/materils.module.ts +0 -96
- package/src/lib/menu/menu.component.css +0 -388
- package/src/lib/menu/menu.component.html +0 -46
- package/src/lib/menu/menu.component.ts +0 -191
- package/src/public_api.ts +0 -14
- package/src/styles.css +0 -44
|
@@ -0,0 +1,5 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Generated bundle index. Do not edit.
|
|
3
|
+
*/
|
|
4
|
+
export * from './public_api';
|
|
5
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYnVsay10b29sLTIwLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vcHJvamVjdHMvYnVsay10b29sL3NyYy9idWxrLXRvb2wtMjAudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUE7O0dBRUc7QUFFSCxjQUFjLGNBQWMsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogR2VuZXJhdGVkIGJ1bmRsZSBpbmRleC4gRG8gbm90IGVkaXQuXG4gKi9cblxuZXhwb3J0ICogZnJvbSAnLi9wdWJsaWNfYXBpJztcbiJdfQ==
|
|
@@ -0,0 +1,50 @@
|
|
|
1
|
+
import { Injectable, Injector } from '@angular/core';
|
|
2
|
+
import { HttpClient } from '@angular/common/http';
|
|
3
|
+
import { map } from 'rxjs/operators';
|
|
4
|
+
import * as i0 from "@angular/core";
|
|
5
|
+
import * as i1 from "@angular/common/http";
|
|
6
|
+
export class AuthService {
|
|
7
|
+
http;
|
|
8
|
+
injector;
|
|
9
|
+
API_ENDPOINT; //= this.injector.get("config").Url;
|
|
10
|
+
//private RM_ENDPOINT = this.injector.get("config").apiBaseUrl;
|
|
11
|
+
_username;
|
|
12
|
+
//private headers = new Headers({ 'Content-Type': 'application/x-www-form-urlencoded' });
|
|
13
|
+
constructor(http, injector) {
|
|
14
|
+
this.http = http;
|
|
15
|
+
this.injector = injector;
|
|
16
|
+
this.API_ENDPOINT = this.injector.get("config").Url;
|
|
17
|
+
}
|
|
18
|
+
//private postheaders = new Headers({'Content-Type': 'application/json'});
|
|
19
|
+
login(username, password) {
|
|
20
|
+
this._username = username;
|
|
21
|
+
return this.http.post(this.API_ENDPOINT + "/login", { username, password })
|
|
22
|
+
.pipe(map(user => {
|
|
23
|
+
// login successful if there's a jwt token in the response
|
|
24
|
+
if (user && user.token) {
|
|
25
|
+
console.log(user);
|
|
26
|
+
// store user details and jwt token in local storage to keep user logged in between page refreshes
|
|
27
|
+
localStorage.setItem('TokenInfo', JSON.stringify(user));
|
|
28
|
+
}
|
|
29
|
+
return user;
|
|
30
|
+
}));
|
|
31
|
+
}
|
|
32
|
+
logout() {
|
|
33
|
+
localStorage.removeItem('TokenInfo');
|
|
34
|
+
}
|
|
35
|
+
GetMenu() {
|
|
36
|
+
return this.http.get(this.API_ENDPOINT + '/Menus/userMenus?username=' + this._username)
|
|
37
|
+
.pipe(map(res => {
|
|
38
|
+
return res;
|
|
39
|
+
}));
|
|
40
|
+
}
|
|
41
|
+
/** @nocollapse */ static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "20.3.15", ngImport: i0, type: AuthService, deps: [{ token: i1.HttpClient }, { token: i0.Injector }], target: i0.ɵɵFactoryTarget.Injectable });
|
|
42
|
+
/** @nocollapse */ static ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "20.3.15", ngImport: i0, type: AuthService, providedIn: 'root' });
|
|
43
|
+
}
|
|
44
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "20.3.15", ngImport: i0, type: AuthService, decorators: [{
|
|
45
|
+
type: Injectable,
|
|
46
|
+
args: [{
|
|
47
|
+
providedIn: 'root'
|
|
48
|
+
}]
|
|
49
|
+
}], ctorParameters: () => [{ type: i1.HttpClient }, { type: i0.Injector }] });
|
|
50
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYXV0aC5zZXJ2aWNlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vcHJvamVjdHMvYnVsay10b29sL3NyYy9saWIvYXV0aC5zZXJ2aWNlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxVQUFVLEVBQUUsUUFBUSxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBQ3JELE9BQU8sRUFBRSxVQUFVLEVBQUUsTUFBTSxzQkFBc0IsQ0FBQztBQUNsRCxPQUFPLEVBQUUsR0FBRyxFQUFFLE1BQU0sZ0JBQWdCLENBQUM7OztBQVFyQyxNQUFNLE9BQU8sV0FBVztJQUtBO0lBQXdCO0lBSnhDLFlBQVksQ0FBQyxDQUFDLG9DQUFvQztJQUMxRCwrREFBK0Q7SUFDdEQsU0FBUyxDQUFDO0lBQ2YseUZBQXlGO0lBQ3pGLFlBQW9CLElBQWdCLEVBQVEsUUFBa0I7UUFBMUMsU0FBSSxHQUFKLElBQUksQ0FBWTtRQUFRLGFBQVEsR0FBUixRQUFRLENBQVU7UUFDMUQsSUFBSSxDQUFDLFlBQVksR0FBRyxJQUFJLENBQUMsUUFBUSxDQUFDLEdBQUcsQ0FBQyxRQUFRLENBQUMsQ0FBQyxHQUFHLENBQUM7SUFDeEQsQ0FBQztJQUVELDBFQUEwRTtJQUMxRSxLQUFLLENBQUMsUUFBZ0IsRUFBRSxRQUFnQjtRQUVwQyxJQUFJLENBQUMsU0FBUyxHQUFHLFFBQVEsQ0FBQztRQUMxQixPQUFPLElBQUksQ0FBQyxJQUFJLENBQUMsSUFBSSxDQUFNLElBQUksQ0FBQyxZQUFZLEdBQUcsUUFBUSxFQUFFLEVBQUUsUUFBUSxFQUFFLFFBQVEsRUFBRSxDQUFDO2FBQzNFLElBQUksQ0FBQyxHQUFHLENBQUMsSUFBSSxDQUFDLEVBQUU7WUFDYiwwREFBMEQ7WUFDMUQsSUFBSSxJQUFJLElBQUksSUFBSSxDQUFDLEtBQUssRUFBRyxDQUFDO2dCQUN0QixPQUFPLENBQUMsR0FBRyxDQUFDLElBQUksQ0FBQyxDQUFDO2dCQUNsQixrR0FBa0c7Z0JBQ2xHLFlBQVksQ0FBQyxPQUFPLENBQUMsV0FBVyxFQUFFLElBQUksQ0FBQyxTQUFTLENBQUMsSUFBSSxDQUFDLENBQUMsQ0FBQztZQUM1RCxDQUFDO1lBQ0QsT0FBTyxJQUFJLENBQUM7UUFDaEIsQ0FBQyxDQUFDLENBQUMsQ0FBQztJQUNaLENBQUM7SUFFRCxNQUFNO1FBQ0YsWUFBWSxDQUFDLFVBQVUsQ0FBQyxXQUFXLENBQUMsQ0FBQztJQUN6QyxDQUFDO0lBRU0sT0FBTztRQUNWLE9BQU8sSUFBSSxDQUFDLElBQUksQ0FBQyxHQUFHLENBQUMsSUFBSSxDQUFDLFlBQVksR0FBRSw0QkFBNEIsR0FBRyxJQUFJLENBQUMsU0FBUyxDQUFDO2FBQ3JGLElBQUksQ0FBQyxHQUFHLENBQUMsR0FBRyxDQUFDLEVBQUU7WUFFWixPQUFPLEdBQUcsQ0FBQztRQUNmLENBQUMsQ0FBQyxDQUFDLENBQUM7SUFDUixDQUFDOzJIQW5DUSxXQUFXOytIQUFYLFdBQVcsY0FGVixNQUFNOzs0RkFFUCxXQUFXO2tCQUh2QixVQUFVO21CQUFDO29CQUNWLFVBQVUsRUFBRSxNQUFNO2lCQUNuQiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IEluamVjdGFibGUsIEluamVjdG9yIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XHJcbmltcG9ydCB7IEh0dHBDbGllbnQgfSBmcm9tICdAYW5ndWxhci9jb21tb24vaHR0cCc7XHJcbmltcG9ydCB7IG1hcCB9IGZyb20gJ3J4anMvb3BlcmF0b3JzJztcclxuaW1wb3J0IHsgQ29uc3RhbnQgfSBmcm9tICcuL2NvbnN0YW50LmVudW0nO1xyXG5pbXBvcnQgeyBPYnNlcnZhYmxlIH0gZnJvbSBcInJ4anNcIjtcclxuXHJcblxyXG5ASW5qZWN0YWJsZSh7XHJcbiAgcHJvdmlkZWRJbjogJ3Jvb3QnXHJcbn0pXHJcbmV4cG9ydCBjbGFzcyBBdXRoU2VydmljZSB7XHJcbnByaXZhdGUgQVBJX0VORFBPSU5UOyAvLz0gdGhpcy5pbmplY3Rvci5nZXQoXCJjb25maWdcIikuVXJsO1xyXG4vL3ByaXZhdGUgUk1fRU5EUE9JTlQgPSB0aGlzLmluamVjdG9yLmdldChcImNvbmZpZ1wiKS5hcGlCYXNlVXJsO1xyXG4gIHB1YmxpYyBfdXNlcm5hbWU7XHJcbiAgICAvL3ByaXZhdGUgaGVhZGVycyA9IG5ldyBIZWFkZXJzKHsgJ0NvbnRlbnQtVHlwZSc6ICdhcHBsaWNhdGlvbi94LXd3dy1mb3JtLXVybGVuY29kZWQnIH0pO1xyXG4gICAgY29uc3RydWN0b3IocHJpdmF0ZSBodHRwOiBIdHRwQ2xpZW50LHB1YmxpYyBpbmplY3RvcjogSW5qZWN0b3IpIHtcclxuICAgICAgICB0aGlzLkFQSV9FTkRQT0lOVCA9IHRoaXMuaW5qZWN0b3IuZ2V0KFwiY29uZmlnXCIpLlVybDtcclxuICAgIH1cclxuICAgXHJcbiAgICAvL3ByaXZhdGUgcG9zdGhlYWRlcnMgPSBuZXcgSGVhZGVycyh7J0NvbnRlbnQtVHlwZSc6ICdhcHBsaWNhdGlvbi9qc29uJ30pO1xyXG4gICAgbG9naW4odXNlcm5hbWU6IHN0cmluZywgcGFzc3dvcmQ6IHN0cmluZykgOiBPYnNlcnZhYmxlPGFueT5cclxuICAgIHtcclxuICAgICAgICB0aGlzLl91c2VybmFtZSA9IHVzZXJuYW1lO1xyXG4gICAgICAgIHJldHVybiB0aGlzLmh0dHAucG9zdDxhbnk+KHRoaXMuQVBJX0VORFBPSU5UICsgXCIvbG9naW5cIiwgeyB1c2VybmFtZSwgcGFzc3dvcmQgfSlcclxuICAgICAgICAgICAgLnBpcGUobWFwKHVzZXIgPT4ge1xyXG4gICAgICAgICAgICAgICAgLy8gbG9naW4gc3VjY2Vzc2Z1bCBpZiB0aGVyZSdzIGEgand0IHRva2VuIGluIHRoZSByZXNwb25zZVxyXG4gICAgICAgICAgICAgICAgaWYgKHVzZXIgJiYgdXNlci50b2tlbiApIHtcclxuICAgICAgICAgICAgICAgICAgICBjb25zb2xlLmxvZyh1c2VyKTtcclxuICAgICAgICAgICAgICAgICAgICAvLyBzdG9yZSB1c2VyIGRldGFpbHMgYW5kIGp3dCB0b2tlbiBpbiBsb2NhbCBzdG9yYWdlIHRvIGtlZXAgdXNlciBsb2dnZWQgaW4gYmV0d2VlbiBwYWdlIHJlZnJlc2hlc1xyXG4gICAgICAgICAgICAgICAgICAgIGxvY2FsU3RvcmFnZS5zZXRJdGVtKCdUb2tlbkluZm8nLCBKU09OLnN0cmluZ2lmeSh1c2VyKSk7XHJcbiAgICAgICAgICAgICAgICB9XHJcbiAgICAgICAgICAgICAgICByZXR1cm4gdXNlcjtcclxuICAgICAgICAgICAgfSkpO1xyXG4gICAgfVxyXG5cclxuICAgIGxvZ291dCgpIHtcclxuICAgICAgICBsb2NhbFN0b3JhZ2UucmVtb3ZlSXRlbSgnVG9rZW5JbmZvJyk7XHJcbiAgICB9XHJcbiAgICAgXHJcbiAgICBwdWJsaWMgR2V0TWVudSgpOiBPYnNlcnZhYmxlPGFueT4ge1xyXG4gICAgICAgIHJldHVybiB0aGlzLmh0dHAuZ2V0KHRoaXMuQVBJX0VORFBPSU5UICsnL01lbnVzL3VzZXJNZW51cz91c2VybmFtZT0nKyAgdGhpcy5fdXNlcm5hbWUpXHJcbiAgICAgICAgLnBpcGUobWFwKHJlcyA9PiB7XHJcbiAgICAgICAgICBcclxuICAgICAgICAgICAgcmV0dXJuIHJlcztcclxuICAgICAgICB9KSk7XHJcbiAgICB9XHJcbn1cclxuIl19
|
|
@@ -0,0 +1,22 @@
|
|
|
1
|
+
import { Component } from '@angular/core';
|
|
2
|
+
import * as i0 from "@angular/core";
|
|
3
|
+
export class BulkToolComponent {
|
|
4
|
+
constructor() { }
|
|
5
|
+
ngOnInit() {
|
|
6
|
+
}
|
|
7
|
+
/** @nocollapse */ static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "20.3.15", ngImport: i0, type: BulkToolComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
|
|
8
|
+
/** @nocollapse */ static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "20.3.15", type: BulkToolComponent, isStandalone: false, selector: "lib-BulkTool", ngImport: i0, template: `
|
|
9
|
+
<p>
|
|
10
|
+
bulk-tool works!
|
|
11
|
+
</p>
|
|
12
|
+
`, isInline: true });
|
|
13
|
+
}
|
|
14
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "20.3.15", ngImport: i0, type: BulkToolComponent, decorators: [{
|
|
15
|
+
type: Component,
|
|
16
|
+
args: [{ selector: 'lib-BulkTool', standalone: false, template: `
|
|
17
|
+
<p>
|
|
18
|
+
bulk-tool works!
|
|
19
|
+
</p>
|
|
20
|
+
` }]
|
|
21
|
+
}], ctorParameters: () => [] });
|
|
22
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYnVsay10b29sLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3Byb2plY3RzL2J1bGstdG9vbC9zcmMvbGliL2J1bGstdG9vbC5jb21wb25lbnQudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFNBQVMsRUFBVSxNQUFNLGVBQWUsQ0FBQzs7QUFZbEQsTUFBTSxPQUFPLGlCQUFpQjtJQUU1QixnQkFBZ0IsQ0FBQztJQUVqQixRQUFRO0lBQ1IsQ0FBQzsySEFMVSxpQkFBaUI7K0dBQWpCLGlCQUFpQix5RUFQbEI7Ozs7R0FJVDs7NEZBR1UsaUJBQWlCO2tCQVY3QixTQUFTOytCQUNFLGNBQWMsY0FDWCxLQUFLLFlBQ1I7Ozs7R0FJVCIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENvbXBvbmVudCwgT25Jbml0IH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XHJcblxyXG5AQ29tcG9uZW50KHtcclxuICBzZWxlY3RvcjogJ2xpYi1CdWxrVG9vbCcsXHJcbiAgc3RhbmRhbG9uZSA6IGZhbHNlLFxyXG4gIHRlbXBsYXRlOiBgXHJcbiAgICA8cD5cclxuICAgICAgYnVsay10b29sIHdvcmtzIVxyXG4gICAgPC9wPlxyXG4gIGAsXHJcbiAgc3R5bGVzOiBbXVxyXG59KVxyXG5leHBvcnQgY2xhc3MgQnVsa1Rvb2xDb21wb25lbnQgaW1wbGVtZW50cyBPbkluaXQge1xyXG5cclxuICBjb25zdHJ1Y3RvcigpIHsgfVxyXG5cclxuICBuZ09uSW5pdCgpIHtcclxuICB9XHJcblxyXG59XHJcbiJdfQ==
|
|
@@ -0,0 +1,50 @@
|
|
|
1
|
+
import { NgModule } from '@angular/core';
|
|
2
|
+
import { BulkToolComponent } from './bulk-tool.component';
|
|
3
|
+
import { LoginComponent } from './login/login.component';
|
|
4
|
+
import { MaterilsModule } from './materils/materils.module';
|
|
5
|
+
import { MenuComponent } from './menu/menu.component';
|
|
6
|
+
import { FormsModule, ReactiveFormsModule } from '@angular/forms';
|
|
7
|
+
import { CommonModule } from '@angular/common';
|
|
8
|
+
import { RouterModule } from '@angular/router';
|
|
9
|
+
import { HttpClientModule, HTTP_INTERCEPTORS } from '@angular/common/http';
|
|
10
|
+
import { HttpLibInterceptor } from './http-interceptor';
|
|
11
|
+
import { AuthService } from './auth.service';
|
|
12
|
+
import * as i0 from "@angular/core";
|
|
13
|
+
export class BulkToolModule {
|
|
14
|
+
static forRoot(config) {
|
|
15
|
+
return {
|
|
16
|
+
ngModule: BulkToolModule,
|
|
17
|
+
providers: [{ provide: 'config', useValue: config }]
|
|
18
|
+
};
|
|
19
|
+
}
|
|
20
|
+
/** @nocollapse */ static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "20.3.15", ngImport: i0, type: BulkToolModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule });
|
|
21
|
+
/** @nocollapse */ static ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "20.3.15", ngImport: i0, type: BulkToolModule, declarations: [BulkToolComponent, LoginComponent, MenuComponent], imports: [MaterilsModule,
|
|
22
|
+
FormsModule,
|
|
23
|
+
CommonModule,
|
|
24
|
+
RouterModule,
|
|
25
|
+
ReactiveFormsModule,
|
|
26
|
+
HttpClientModule], exports: [BulkToolComponent, LoginComponent, MenuComponent] });
|
|
27
|
+
/** @nocollapse */ static ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "20.3.15", ngImport: i0, type: BulkToolModule, providers: [{ provide: HTTP_INTERCEPTORS, useClass: HttpLibInterceptor, multi: true }, AuthService], imports: [MaterilsModule,
|
|
28
|
+
FormsModule,
|
|
29
|
+
CommonModule,
|
|
30
|
+
RouterModule,
|
|
31
|
+
ReactiveFormsModule,
|
|
32
|
+
HttpClientModule] });
|
|
33
|
+
}
|
|
34
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "20.3.15", ngImport: i0, type: BulkToolModule, decorators: [{
|
|
35
|
+
type: NgModule,
|
|
36
|
+
args: [{
|
|
37
|
+
imports: [
|
|
38
|
+
MaterilsModule,
|
|
39
|
+
FormsModule,
|
|
40
|
+
CommonModule,
|
|
41
|
+
RouterModule,
|
|
42
|
+
ReactiveFormsModule,
|
|
43
|
+
HttpClientModule,
|
|
44
|
+
],
|
|
45
|
+
declarations: [BulkToolComponent, LoginComponent, MenuComponent],
|
|
46
|
+
exports: [BulkToolComponent, LoginComponent, MenuComponent],
|
|
47
|
+
providers: [{ provide: HTTP_INTERCEPTORS, useClass: HttpLibInterceptor, multi: true }, AuthService]
|
|
48
|
+
}]
|
|
49
|
+
}] });
|
|
50
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYnVsay10b29sLm1vZHVsZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3Byb2plY3RzL2J1bGstdG9vbC9zcmMvbGliL2J1bGstdG9vbC5tb2R1bGUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFFBQVEsRUFBc0IsTUFBTSxlQUFlLENBQUM7QUFDN0QsT0FBTyxFQUFFLGlCQUFpQixFQUFFLE1BQU0sdUJBQXVCLENBQUM7QUFDMUQsT0FBTyxFQUFFLGNBQWMsRUFBRSxNQUFNLHlCQUF5QixDQUFDO0FBQ3pELE9BQU8sRUFBRSxjQUFjLEVBQUUsTUFBTSw0QkFBNEIsQ0FBQztBQUM1RCxPQUFPLEVBQUUsYUFBYSxFQUFFLE1BQU0sdUJBQXVCLENBQUM7QUFFdEQsT0FBTyxFQUFFLFdBQVcsRUFBRSxtQkFBbUIsRUFBRSxNQUFNLGdCQUFnQixDQUFDO0FBQ2xFLE9BQU8sRUFBRSxZQUFZLEVBQUUsTUFBTSxpQkFBaUIsQ0FBQztBQUMvQyxPQUFPLEVBQUUsWUFBWSxFQUFFLE1BQU0saUJBQWlCLENBQUM7QUFDL0MsT0FBTyxFQUFFLGdCQUFnQixFQUFFLGlCQUFpQixFQUFFLE1BQU0sc0JBQXNCLENBQUM7QUFDM0UsT0FBTyxFQUFFLGtCQUFrQixFQUFFLE1BQU0sb0JBQW9CLENBQUM7QUFDeEQsT0FBTyxFQUFFLFdBQVcsRUFBRSxNQUFNLGdCQUFnQixDQUFDOztBQW9CN0MsTUFBTSxPQUFPLGNBQWM7SUFDekIsTUFBTSxDQUFDLE9BQU8sQ0FBRSxNQUF5QjtRQUN2QyxPQUFPO1lBQ0wsUUFBUSxFQUFFLGNBQWM7WUFDeEIsU0FBUyxFQUFFLENBQUMsRUFBRSxPQUFPLEVBQUUsUUFBUSxFQUFFLFFBQVEsRUFBRSxNQUFNLEVBQUUsQ0FBQztTQUNyRCxDQUFDO0lBQ0osQ0FBQzsySEFOVSxjQUFjOzRIQUFkLGNBQWMsaUJBSlYsaUJBQWlCLEVBQUUsY0FBYyxFQUFFLGFBQWEsYUFUN0QsY0FBYztZQUNkLFdBQVc7WUFDWCxZQUFZO1lBQ1osWUFBWTtZQUNaLG1CQUFtQjtZQUNuQixnQkFBZ0IsYUFLUixpQkFBaUIsRUFBRSxjQUFjLEVBQUUsYUFBYTs0SEFHL0MsY0FBYyxhQUZmLENBQUUsRUFBRSxPQUFPLEVBQUUsaUJBQWlCLEVBQUUsUUFBUSxFQUFFLGtCQUFrQixFQUFFLEtBQUssRUFBRSxJQUFJLEVBQUUsRUFBQyxXQUFXLENBQUMsWUFYaEcsY0FBYztZQUNkLFdBQVc7WUFDWCxZQUFZO1lBQ1osWUFBWTtZQUNaLG1CQUFtQjtZQUNuQixnQkFBZ0I7OzRGQVFQLGNBQWM7a0JBZjFCLFFBQVE7bUJBQUM7b0JBQ1IsT0FBTyxFQUFFO3dCQUNQLGNBQWM7d0JBQ2QsV0FBVzt3QkFDWCxZQUFZO3dCQUNaLFlBQVk7d0JBQ1osbUJBQW1CO3dCQUNuQixnQkFBZ0I7cUJBR2pCO29CQUNELFlBQVksRUFBRSxDQUFDLGlCQUFpQixFQUFFLGNBQWMsRUFBRSxhQUFhLENBQUM7b0JBQ2hFLE9BQU8sRUFBRSxDQUFDLGlCQUFpQixFQUFFLGNBQWMsRUFBRSxhQUFhLENBQUM7b0JBQzNELFNBQVMsRUFBQyxDQUFFLEVBQUUsT0FBTyxFQUFFLGlCQUFpQixFQUFFLFFBQVEsRUFBRSxrQkFBa0IsRUFBRSxLQUFLLEVBQUUsSUFBSSxFQUFFLEVBQUMsV0FBVyxDQUFDO2lCQUNuRyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IE5nTW9kdWxlLE1vZHVsZVdpdGhQcm92aWRlcnMgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcclxuaW1wb3J0IHsgQnVsa1Rvb2xDb21wb25lbnQgfSBmcm9tICcuL2J1bGstdG9vbC5jb21wb25lbnQnO1xyXG5pbXBvcnQgeyBMb2dpbkNvbXBvbmVudCB9IGZyb20gJy4vbG9naW4vbG9naW4uY29tcG9uZW50JztcclxuaW1wb3J0IHsgTWF0ZXJpbHNNb2R1bGUgfSBmcm9tICcuL21hdGVyaWxzL21hdGVyaWxzLm1vZHVsZSc7XHJcbmltcG9ydCB7IE1lbnVDb21wb25lbnQgfSBmcm9tICcuL21lbnUvbWVudS5jb21wb25lbnQnO1xyXG5cclxuaW1wb3J0IHsgRm9ybXNNb2R1bGUsIFJlYWN0aXZlRm9ybXNNb2R1bGUgfSBmcm9tICdAYW5ndWxhci9mb3Jtcyc7XHJcbmltcG9ydCB7IENvbW1vbk1vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL2NvbW1vbic7XHJcbmltcG9ydCB7IFJvdXRlck1vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL3JvdXRlcic7XHJcbmltcG9ydCB7IEh0dHBDbGllbnRNb2R1bGUsIEhUVFBfSU5URVJDRVBUT1JTIH0gZnJvbSAnQGFuZ3VsYXIvY29tbW9uL2h0dHAnO1xyXG5pbXBvcnQgeyBIdHRwTGliSW50ZXJjZXB0b3IgfSBmcm9tICcuL2h0dHAtaW50ZXJjZXB0b3InO1xyXG5pbXBvcnQgeyBBdXRoU2VydmljZSB9IGZyb20gJy4vYXV0aC5zZXJ2aWNlJztcclxuaW1wb3J0IHtJRW52aXJvbm1lbnRzSW5mb30gZnJvbSAnLi4vbGliL2Vudmlyb25tZW50c01vZGVsLmluZm8nO1xyXG5cclxuXHJcblxyXG5ATmdNb2R1bGUoe1xyXG4gIGltcG9ydHM6IFtcclxuICAgIE1hdGVyaWxzTW9kdWxlLFxyXG4gICAgRm9ybXNNb2R1bGUsXHJcbiAgICBDb21tb25Nb2R1bGUsXHJcbiAgICBSb3V0ZXJNb2R1bGUsXHJcbiAgICBSZWFjdGl2ZUZvcm1zTW9kdWxlLFxyXG4gICAgSHR0cENsaWVudE1vZHVsZSxcclxuXHJcbiAgIFxyXG4gIF0sXHJcbiAgZGVjbGFyYXRpb25zOiBbQnVsa1Rvb2xDb21wb25lbnQsIExvZ2luQ29tcG9uZW50LCBNZW51Q29tcG9uZW50XSxcclxuICBleHBvcnRzOiBbQnVsa1Rvb2xDb21wb25lbnQsIExvZ2luQ29tcG9uZW50LCBNZW51Q29tcG9uZW50XSxcclxuICBwcm92aWRlcnM6WyB7IHByb3ZpZGU6IEhUVFBfSU5URVJDRVBUT1JTLCB1c2VDbGFzczogSHR0cExpYkludGVyY2VwdG9yLCBtdWx0aTogdHJ1ZSB9LEF1dGhTZXJ2aWNlXVxyXG59KVxyXG5leHBvcnQgY2xhc3MgQnVsa1Rvb2xNb2R1bGUge1xyXG4gIHN0YXRpYyBmb3JSb290KMKgY29uZmlnwqA6SUVudmlyb25tZW50c0luZm8pOiBNb2R1bGVXaXRoUHJvdmlkZXJzPEJ1bGtUb29sTW9kdWxlPiB7XHJcbiAgICByZXR1cm4ge1xyXG4gICAgICBuZ01vZHVsZTogQnVsa1Rvb2xNb2R1bGUsXHJcbiAgICAgIHByb3ZpZGVyczogW3vCoHByb3ZpZGU6wqAnY29uZmlnJyzCoHVzZVZhbHVlOsKgY29uZmlnwqB9XVxyXG4gICAgfTtcclxuICB9XHJcblxyXG4gfVxyXG4iXX0=
|
|
@@ -0,0 +1,14 @@
|
|
|
1
|
+
import { Injectable } from '@angular/core';
|
|
2
|
+
import * as i0 from "@angular/core";
|
|
3
|
+
export class BulkToolService {
|
|
4
|
+
constructor() { }
|
|
5
|
+
/** @nocollapse */ static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "20.3.15", ngImport: i0, type: BulkToolService, deps: [], target: i0.ɵɵFactoryTarget.Injectable });
|
|
6
|
+
/** @nocollapse */ static ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "20.3.15", ngImport: i0, type: BulkToolService, providedIn: 'root' });
|
|
7
|
+
}
|
|
8
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "20.3.15", ngImport: i0, type: BulkToolService, decorators: [{
|
|
9
|
+
type: Injectable,
|
|
10
|
+
args: [{
|
|
11
|
+
providedIn: 'root'
|
|
12
|
+
}]
|
|
13
|
+
}], ctorParameters: () => [] });
|
|
14
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYnVsay10b29sLnNlcnZpY2UuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9wcm9qZWN0cy9idWxrLXRvb2wvc3JjL2xpYi9idWxrLXRvb2wuc2VydmljZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsVUFBVSxFQUFFLE1BQU0sZUFBZSxDQUFDOztBQUszQyxNQUFNLE9BQU8sZUFBZTtJQUUxQixnQkFBZ0IsQ0FBQzsySEFGTixlQUFlOytIQUFmLGVBQWUsY0FGZCxNQUFNOzs0RkFFUCxlQUFlO2tCQUgzQixVQUFVO21CQUFDO29CQUNWLFVBQVUsRUFBRSxNQUFNO2lCQUNuQiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IEluamVjdGFibGUgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcclxuXHJcbkBJbmplY3RhYmxlKHtcclxuICBwcm92aWRlZEluOiAncm9vdCdcclxufSlcclxuZXhwb3J0IGNsYXNzIEJ1bGtUb29sU2VydmljZSB7XHJcblxyXG4gIGNvbnN0cnVjdG9yKCkgeyB9XHJcbn1cclxuIl19
|
|
@@ -0,0 +1,6 @@
|
|
|
1
|
+
export const Constant = {
|
|
2
|
+
APPSERVICEURL: 'https://localhost:44348/api',
|
|
3
|
+
APPSERVICEPRODURL: 'https://tk4addin.dev.summitenergy.com/appservices/api',
|
|
4
|
+
INVALID: "Invalid Username or Password"
|
|
5
|
+
};
|
|
6
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY29uc3RhbnQuZW51bS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3Byb2plY3RzL2J1bGstdG9vbC9zcmMvbGliL2NvbnN0YW50LmVudW0udHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsTUFBTSxDQUFDLE1BQU0sUUFBUSxHQUFFO0lBQ25CLGFBQWEsRUFBQyw2QkFBNkI7SUFDM0MsaUJBQWlCLEVBQUMsdURBQXVEO0lBRXpFLE9BQU8sRUFBQyw4QkFBOEI7Q0FDekMsQ0FBQSIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCBjb25zdCBDb25zdGFudD0ge1xyXG4gICAgQVBQU0VSVklDRVVSTDonaHR0cHM6Ly9sb2NhbGhvc3Q6NDQzNDgvYXBpJyxcclxuICAgIEFQUFNFUlZJQ0VQUk9EVVJMOidodHRwczovL3RrNGFkZGluLmRldi5zdW1taXRlbmVyZ3kuY29tL2FwcHNlcnZpY2VzL2FwaScsXHJcblxyXG4gICAgSU5WQUxJRDpcIkludmFsaWQgVXNlcm5hbWUgb3IgUGFzc3dvcmRcIlxyXG59XHJcbiJdfQ==
|
|
@@ -0,0 +1,2 @@
|
|
|
1
|
+
export {};
|
|
2
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZW52aXJvbm1lbnRzTW9kZWwuaW5mby5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3Byb2plY3RzL2J1bGstdG9vbC9zcmMvbGliL2Vudmlyb25tZW50c01vZGVsLmluZm8udHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IiIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCBpbnRlcmZhY2UgSUVudmlyb25tZW50c0luZm8ge1xyXG4gICAgVXJsOnN0cmluZ1xyXG59Il19
|
|
@@ -0,0 +1,25 @@
|
|
|
1
|
+
import { Injectable } from '@angular/core';
|
|
2
|
+
import * as i0 from "@angular/core";
|
|
3
|
+
export class HttpLibInterceptor {
|
|
4
|
+
intercept(request, newRequest) {
|
|
5
|
+
// add authorization header to request
|
|
6
|
+
//Get Token data from local storage
|
|
7
|
+
let tokenInfo = JSON.parse(localStorage.getItem('TokenInfo'));
|
|
8
|
+
if (tokenInfo && tokenInfo.token) {
|
|
9
|
+
request = request.clone({
|
|
10
|
+
setHeaders: {
|
|
11
|
+
Authorization: `Bearer ${tokenInfo.token}`,
|
|
12
|
+
"Content-Type": 'application/json'
|
|
13
|
+
}
|
|
14
|
+
});
|
|
15
|
+
}
|
|
16
|
+
console.log(request);
|
|
17
|
+
return newRequest.handle(request);
|
|
18
|
+
}
|
|
19
|
+
/** @nocollapse */ static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "20.3.15", ngImport: i0, type: HttpLibInterceptor, deps: [], target: i0.ɵɵFactoryTarget.Injectable });
|
|
20
|
+
/** @nocollapse */ static ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "20.3.15", ngImport: i0, type: HttpLibInterceptor });
|
|
21
|
+
}
|
|
22
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "20.3.15", ngImport: i0, type: HttpLibInterceptor, decorators: [{
|
|
23
|
+
type: Injectable
|
|
24
|
+
}] });
|
|
25
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaHR0cC1pbnRlcmNlcHRvci5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3Byb2plY3RzL2J1bGstdG9vbC9zcmMvbGliL2h0dHAtaW50ZXJjZXB0b3IudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFVBQVUsRUFBRSxNQUFNLGVBQWUsQ0FBQzs7QUFJM0MsTUFBTSxPQUFPLGtCQUFrQjtJQUMzQixTQUFTLENBQUMsT0FBeUIsRUFBRSxVQUF1QjtRQUN4RCxzQ0FBc0M7UUFDdEMsbUNBQW1DO1FBQ25DLElBQUksU0FBUyxHQUFHLElBQUksQ0FBQyxLQUFLLENBQUMsWUFBWSxDQUFDLE9BQU8sQ0FBQyxXQUFXLENBQUMsQ0FBQyxDQUFDO1FBRTlELElBQUksU0FBUyxJQUFJLFNBQVMsQ0FBQyxLQUFLLEVBQUUsQ0FBQztZQUNqQyxPQUFPLEdBQUcsT0FBTyxDQUFDLEtBQUssQ0FBQztnQkFDdEIsVUFBVSxFQUFFO29CQUNWLGFBQWEsRUFBRSxVQUFVLFNBQVMsQ0FBQyxLQUFLLEVBQUU7b0JBQzFDLGNBQWMsRUFBRSxrQkFBa0I7aUJBQ25DO2FBQ0YsQ0FBQyxDQUFDO1FBQ0wsQ0FBQztRQUNMLE9BQU8sQ0FBQyxHQUFHLENBQUMsT0FBTyxDQUFDLENBQUM7UUFDakIsT0FBTyxVQUFVLENBQUMsTUFBTSxDQUFDLE9BQU8sQ0FBQyxDQUFDO0lBQ3BDLENBQUM7MkhBaEJNLGtCQUFrQjsrSEFBbEIsa0JBQWtCOzs0RkFBbEIsa0JBQWtCO2tCQUQ5QixVQUFVIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgSW5qZWN0YWJsZSB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xyXG5pbXBvcnQgeyBIdHRwUmVxdWVzdCwgSHR0cEhhbmRsZXIsIEh0dHBFdmVudCwgSHR0cEludGVyY2VwdG9yIH0gZnJvbSAnQGFuZ3VsYXIvY29tbW9uL2h0dHAnO1xyXG5pbXBvcnQgeyBPYnNlcnZhYmxlIH0gZnJvbSAncnhqcyc7XHJcbkBJbmplY3RhYmxlKClcclxuZXhwb3J0IGNsYXNzIEh0dHBMaWJJbnRlcmNlcHRvciBpbXBsZW1lbnRzIEh0dHBJbnRlcmNlcHRvciB7XHJcbiAgICBpbnRlcmNlcHQocmVxdWVzdDogSHR0cFJlcXVlc3Q8YW55PiwgbmV3UmVxdWVzdDogSHR0cEhhbmRsZXIpOiBPYnNlcnZhYmxlPEh0dHBFdmVudDxhbnk+PiB7XHJcbiAgICAgICAgLy8gYWRkIGF1dGhvcml6YXRpb24gaGVhZGVyIHRvIHJlcXVlc3RcclxuICAgICAgICAvL0dldCBUb2tlbiBkYXRhIGZyb20gbG9jYWwgc3RvcmFnZVxyXG4gICAgICAgIGxldCB0b2tlbkluZm8gPSBKU09OLnBhcnNlKGxvY2FsU3RvcmFnZS5nZXRJdGVtKCdUb2tlbkluZm8nKSk7XHJcbiAgICAgICBcclxuICAgICAgICBpZiAodG9rZW5JbmZvICYmIHRva2VuSW5mby50b2tlbikge1xyXG4gICAgICAgICAgcmVxdWVzdCA9IHJlcXVlc3QuY2xvbmUoe1xyXG4gICAgICAgICAgICBzZXRIZWFkZXJzOiB7XHJcbiAgICAgICAgICAgICAgQXV0aG9yaXphdGlvbjogYEJlYXJlciAke3Rva2VuSW5mby50b2tlbn1gLFxyXG4gICAgICAgICAgICAgIFwiQ29udGVudC1UeXBlXCI6ICdhcHBsaWNhdGlvbi9qc29uJ1xyXG4gICAgICAgICAgICB9XHJcbiAgICAgICAgICB9KTtcclxuICAgICAgICB9XHJcbiAgICBjb25zb2xlLmxvZyhyZXF1ZXN0KTtcclxuICAgICAgICByZXR1cm4gbmV3UmVxdWVzdC5oYW5kbGUocmVxdWVzdCk7XHJcbiAgICAgIH1cclxufVxyXG4iXX0=
|
|
@@ -0,0 +1,84 @@
|
|
|
1
|
+
import { Component, Input } from '@angular/core';
|
|
2
|
+
import { Router, ActivatedRoute } from '@angular/router';
|
|
3
|
+
import { FormBuilder, Validators } from '@angular/forms';
|
|
4
|
+
import { first } from 'rxjs/operators';
|
|
5
|
+
import { Constant } from '../constant.enum';
|
|
6
|
+
import { AuthService } from '../auth.service';
|
|
7
|
+
import * as i0 from "@angular/core";
|
|
8
|
+
import * as i1 from "@angular/forms";
|
|
9
|
+
import * as i2 from "@angular/router";
|
|
10
|
+
import * as i3 from "../auth.service";
|
|
11
|
+
import * as i4 from "@angular/material/button";
|
|
12
|
+
import * as i5 from "@angular/material/icon";
|
|
13
|
+
import * as i6 from "@angular/material/input";
|
|
14
|
+
import * as i7 from "@angular/material/progress-spinner";
|
|
15
|
+
import * as i8 from "@angular/common";
|
|
16
|
+
export class LoginComponent {
|
|
17
|
+
formBuilder;
|
|
18
|
+
route;
|
|
19
|
+
router;
|
|
20
|
+
authenticationService;
|
|
21
|
+
isLoading = false;
|
|
22
|
+
routeUrl;
|
|
23
|
+
loginForm;
|
|
24
|
+
// submitClick = false;
|
|
25
|
+
submitted = false;
|
|
26
|
+
returnUrl;
|
|
27
|
+
error = '';
|
|
28
|
+
constructor(formBuilder, route, router, authenticationService) {
|
|
29
|
+
this.formBuilder = formBuilder;
|
|
30
|
+
this.route = route;
|
|
31
|
+
this.router = router;
|
|
32
|
+
this.authenticationService = authenticationService;
|
|
33
|
+
}
|
|
34
|
+
isvalidUser = true;
|
|
35
|
+
ngOnInit() {
|
|
36
|
+
this.loginForm = this.formBuilder.group({
|
|
37
|
+
username: ['', Validators.required],
|
|
38
|
+
password: ['', Validators.required]
|
|
39
|
+
});
|
|
40
|
+
// reset login status
|
|
41
|
+
this.authenticationService.logout();
|
|
42
|
+
this.returnUrl = this.route.snapshot.queryParams['returnUrl'] || this.routeUrl;
|
|
43
|
+
}
|
|
44
|
+
get formsData() { return this.loginForm.controls; }
|
|
45
|
+
onLogin() {
|
|
46
|
+
this.submitted = true;
|
|
47
|
+
this.isLoading = true;
|
|
48
|
+
// stop here if form is invalid
|
|
49
|
+
if (this.loginForm.invalid) {
|
|
50
|
+
this.isLoading = false;
|
|
51
|
+
return;
|
|
52
|
+
}
|
|
53
|
+
//this.submitClick = true;
|
|
54
|
+
this.authenticationService.login(this.formsData.username.value, this.formsData.password.value)
|
|
55
|
+
.pipe(first())
|
|
56
|
+
.subscribe(data => {
|
|
57
|
+
console.log(data.status);
|
|
58
|
+
if (data.status == "InValid") {
|
|
59
|
+
this.isLoading = false;
|
|
60
|
+
this.isvalidUser = false;
|
|
61
|
+
this.error = Constant.INVALID;
|
|
62
|
+
this.router.navigate(["/login"]);
|
|
63
|
+
}
|
|
64
|
+
else {
|
|
65
|
+
this.isLoading = false;
|
|
66
|
+
this.router.navigate([this.returnUrl]);
|
|
67
|
+
}
|
|
68
|
+
}, error => {
|
|
69
|
+
this.isLoading = false;
|
|
70
|
+
this.error = Constant.INVALID;
|
|
71
|
+
this.router.navigate(["/login"]);
|
|
72
|
+
//this.submitClick = true;
|
|
73
|
+
});
|
|
74
|
+
}
|
|
75
|
+
/** @nocollapse */ static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "20.3.15", ngImport: i0, type: LoginComponent, deps: [{ token: i1.FormBuilder }, { token: i2.ActivatedRoute }, { token: i2.Router }, { token: i3.AuthService }], target: i0.ɵɵFactoryTarget.Component });
|
|
76
|
+
/** @nocollapse */ static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "20.3.15", type: LoginComponent, isStandalone: false, selector: "lib-login", inputs: { routeUrl: "routeUrl" }, ngImport: i0, template: "\r\n<div class=\"container\">\r\n <div class=\"loginForm\">\r\n <div class=\"example-sidenav-content\">\r\n <div class=\"loginWidget\">\r\n <form [formGroup]=\"loginForm\" >\r\n <h2>Login</h2>\r\n <div> </div>\r\n <div class=\"form-group\">\r\n <!-- <label for=\"username\">Username</label> -->\r\n <!-- <input type=\"text\" formControlName=\"username\" class=\"form-control\"\r\n [ngClass]=\"{ 'is-invalid': submitted && formsData.username.errors }\" /> -->\r\n <mat-form-field class=\"example-full-width\"\r\n color=\"primary\">\r\n <mat-label>Enter Username</mat-label>\r\n <input class=\"toolbar-search\" formControlName=\"username\" type=\"text\" matInput>\r\n <mat-icon matSuffix style=\"font-size: 1.2em\"></mat-icon>\r\n </mat-form-field>\r\n <!-- <div *ngIf=\"submitted && formsData.username.errors\" class=\"invalid-feedback\">\r\n <div *ngIf=\"formsData.username.errors.required\">Username is required</div>\r\n </div> -->\r\n </div>\r\n <div class=\"form-group\">\r\n <!-- <label for=\"password\">Password</label> -->\r\n <!-- <input type=\"password\" formControlName=\"password\" class=\"form-control\"\r\n [ngClass]=\"{ 'is-invalid': submitted && formsData.password.errors }\" /> -->\r\n <mat-form-field class=\"example-full-width\"\r\n color=\"primary\">\r\n <mat-label>Enter Password</mat-label>\r\n <input class=\"toolbar-search\" formControlName=\"password\" type=\"password\" matInput>\r\n <mat-icon matSuffix style=\"font-size: 1.2em\"></mat-icon>\r\n </mat-form-field>\r\n <!-- <div *ngIf=\"submitted && formsData.password.errors\" class=\"invalid-feedback\">\r\n <div *ngIf=\"formsData.password.errors.required\">Password is required</div>\r\n </div> -->\r\n </div>\r\n <div class=\"form-group\">\r\n <!-- <button [disabled]=\"submitClick\" class=\"btn btn-primary\">Login</button> -->\r\n <button style=\"background-color: #0888CA;color: #fff;\" mat-button class=\"!loginForm.valid btn btn-primary\" (click)=\"onLogin()\">Login</button>\r\n </div>\r\n <div *ngIf =\"!isvalidUser\" class=\"alert alert-danger\">{{error}}</div>\r\n </form>\r\n </div>\r\n\r\n <section class=\"loade\" *ngIf=\"isLoading\">\r\n <mat-spinner color=\"black\" [diameter]=60 ></mat-spinner>\r\n <span>\r\n Logging...\r\n </span>\r\n </section>\r\n\r\n \r\n <!-- <button type=\"button\" mat-button (click)=\"drawer.toggle()\">\r\n Toggle sidenav\r\n</button> -->\r\n </div>\r\n </div>\r\n </div>\r\n\r\n\r\n\r\n", styles: ["::ng-deep .mat-mdc-form-field .mdc-line-ripple{width:70%!important;left:0!important}::ng-deep .mdc-text-field__input{margin-bottom:.7em!important}::ng-deep .mat-mdc-form-field-label{left:0!important;text-align:left!important;width:100%!important}::ng-deep .mat-mdc-form-field-infix{margin-bottom:-15px!important;margin-left:-18px!important;padding-left:17px!important;min-width:0!important;width:180px!important}button[mat-button]{height:26px!important;min-height:26px!important;padding:0 12px!important;font-size:14px!important}button[mat-button]{height:30px!important;min-height:30px!important;padding:0 14px!important;font-size:13 px!important}body{background:#f4fafd}.loginForm{border-radius:0;background:#fff;width:90%;max-width:450px;padding:15px;text-align:left;margin:60px auto;border:#f4f4f4 solid 1px;box-shadow:4px 2px 5px -2px #c2b3c2}::ng-deep .mat-button,.mat-flat-button,.mat-icon-button,.mat-stroked-button{box-sizing:border-box;position:relative;-webkit-user-select:none;user-select:none;cursor:pointer;outline:0;border:none;-webkit-tap-highlight-color:transparent;display:inline-block;white-space:nowrap;text-decoration:none;vertical-align:baseline;text-align:center;margin:0;min-width:64px;line-height:28px!important;padding:0 16px;border-radius:4px;overflow:visible}.nb-spinner{width:75pxx;height:75px;margin:0;background:transparent;border-top:4px solid #03A9F4;border-right:4px solid transparent;border-radius:50%;animation:1s spin linear infinite}.loade{background:#ffffff80;width:100%;height:100%;overflow:hidden;padding-left:67px;position:absolute;z-index:1;opacity:50;top:0;padding-top:135px}.square-spinner{width:55px;display:block;background-color:#03a9f4;height:55px;animation:3s flip ease-in-out infinite}::ng-deep .mat-spinner circle{stroke:green;stroke-width:10%}::ng-deep .mdc-text-field--filled:not(.mdc-text-field--disabled){background-color:unset!important}::ng-deep .mat-mdc-form-field-focus-overlay{background-color:unset!important}::ng-deep .mat-mdc-form-field-required-marker{display:none!important}::ng-deep .mdc-floating-label--required:after{content:none!important;font-weight:500!important}::ng-deep .mat-mdc-form-field .mat-mdc-form-field-required-marker,::ng-deep .mat-mdc-form-field .mdc-floating-label--required:after{display:none!important;content:none!important}::ng-deep .mdc-text-field--filled .mdc-floating-label{font-size:16px!important;color:#6b6b6b!important}\n"], dependencies: [{ kind: "component", type: i4.MatButton, selector: " button[matButton], a[matButton], button[mat-button], button[mat-raised-button], button[mat-flat-button], button[mat-stroked-button], a[mat-button], a[mat-raised-button], a[mat-flat-button], a[mat-stroked-button] ", inputs: ["matButton"], exportAs: ["matButton", "matAnchor"] }, { kind: "component", type: i5.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }, { kind: "directive", type: i6.MatInput, selector: "input[matInput], textarea[matInput], select[matNativeControl], input[matNativeControl], textarea[matNativeControl]", inputs: ["disabled", "id", "placeholder", "name", "required", "type", "errorStateMatcher", "aria-describedby", "value", "readonly", "disabledInteractive"], exportAs: ["matInput"] }, { kind: "component", type: i6.MatFormField, selector: "mat-form-field", inputs: ["hideRequiredMarker", "color", "floatLabel", "appearance", "subscriptSizing", "hintLabel"], exportAs: ["matFormField"] }, { kind: "directive", type: i6.MatLabel, selector: "mat-label" }, { kind: "directive", type: i6.MatSuffix, selector: "[matSuffix], [matIconSuffix], [matTextSuffix]", inputs: ["matTextSuffix"] }, { kind: "component", type: i7.MatProgressSpinner, selector: "mat-progress-spinner, mat-spinner", inputs: ["color", "mode", "value", "diameter", "strokeWidth"], exportAs: ["matProgressSpinner"] }, { kind: "directive", type: i1.ɵNgNoValidate, selector: "form:not([ngNoForm]):not([ngNativeValidate])" }, { kind: "directive", type: i1.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { kind: "directive", type: i1.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i1.NgControlStatusGroup, selector: "[formGroupName],[formArrayName],[ngModelGroup],[formGroup],form:not([ngNoForm]),[ngForm]" }, { kind: "directive", type: i8.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i1.FormGroupDirective, selector: "[formGroup]", inputs: ["formGroup"], outputs: ["ngSubmit"], exportAs: ["ngForm"] }, { kind: "directive", type: i1.FormControlName, selector: "[formControlName]", inputs: ["formControlName", "disabled", "ngModel"], outputs: ["ngModelChange"] }] });
|
|
77
|
+
}
|
|
78
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "20.3.15", ngImport: i0, type: LoginComponent, decorators: [{
|
|
79
|
+
type: Component,
|
|
80
|
+
args: [{ standalone: false, selector: 'lib-login', template: "\r\n<div class=\"container\">\r\n <div class=\"loginForm\">\r\n <div class=\"example-sidenav-content\">\r\n <div class=\"loginWidget\">\r\n <form [formGroup]=\"loginForm\" >\r\n <h2>Login</h2>\r\n <div> </div>\r\n <div class=\"form-group\">\r\n <!-- <label for=\"username\">Username</label> -->\r\n <!-- <input type=\"text\" formControlName=\"username\" class=\"form-control\"\r\n [ngClass]=\"{ 'is-invalid': submitted && formsData.username.errors }\" /> -->\r\n <mat-form-field class=\"example-full-width\"\r\n color=\"primary\">\r\n <mat-label>Enter Username</mat-label>\r\n <input class=\"toolbar-search\" formControlName=\"username\" type=\"text\" matInput>\r\n <mat-icon matSuffix style=\"font-size: 1.2em\"></mat-icon>\r\n </mat-form-field>\r\n <!-- <div *ngIf=\"submitted && formsData.username.errors\" class=\"invalid-feedback\">\r\n <div *ngIf=\"formsData.username.errors.required\">Username is required</div>\r\n </div> -->\r\n </div>\r\n <div class=\"form-group\">\r\n <!-- <label for=\"password\">Password</label> -->\r\n <!-- <input type=\"password\" formControlName=\"password\" class=\"form-control\"\r\n [ngClass]=\"{ 'is-invalid': submitted && formsData.password.errors }\" /> -->\r\n <mat-form-field class=\"example-full-width\"\r\n color=\"primary\">\r\n <mat-label>Enter Password</mat-label>\r\n <input class=\"toolbar-search\" formControlName=\"password\" type=\"password\" matInput>\r\n <mat-icon matSuffix style=\"font-size: 1.2em\"></mat-icon>\r\n </mat-form-field>\r\n <!-- <div *ngIf=\"submitted && formsData.password.errors\" class=\"invalid-feedback\">\r\n <div *ngIf=\"formsData.password.errors.required\">Password is required</div>\r\n </div> -->\r\n </div>\r\n <div class=\"form-group\">\r\n <!-- <button [disabled]=\"submitClick\" class=\"btn btn-primary\">Login</button> -->\r\n <button style=\"background-color: #0888CA;color: #fff;\" mat-button class=\"!loginForm.valid btn btn-primary\" (click)=\"onLogin()\">Login</button>\r\n </div>\r\n <div *ngIf =\"!isvalidUser\" class=\"alert alert-danger\">{{error}}</div>\r\n </form>\r\n </div>\r\n\r\n <section class=\"loade\" *ngIf=\"isLoading\">\r\n <mat-spinner color=\"black\" [diameter]=60 ></mat-spinner>\r\n <span>\r\n Logging...\r\n </span>\r\n </section>\r\n\r\n \r\n <!-- <button type=\"button\" mat-button (click)=\"drawer.toggle()\">\r\n Toggle sidenav\r\n</button> -->\r\n </div>\r\n </div>\r\n </div>\r\n\r\n\r\n\r\n", styles: ["::ng-deep .mat-mdc-form-field .mdc-line-ripple{width:70%!important;left:0!important}::ng-deep .mdc-text-field__input{margin-bottom:.7em!important}::ng-deep .mat-mdc-form-field-label{left:0!important;text-align:left!important;width:100%!important}::ng-deep .mat-mdc-form-field-infix{margin-bottom:-15px!important;margin-left:-18px!important;padding-left:17px!important;min-width:0!important;width:180px!important}button[mat-button]{height:26px!important;min-height:26px!important;padding:0 12px!important;font-size:14px!important}button[mat-button]{height:30px!important;min-height:30px!important;padding:0 14px!important;font-size:13 px!important}body{background:#f4fafd}.loginForm{border-radius:0;background:#fff;width:90%;max-width:450px;padding:15px;text-align:left;margin:60px auto;border:#f4f4f4 solid 1px;box-shadow:4px 2px 5px -2px #c2b3c2}::ng-deep .mat-button,.mat-flat-button,.mat-icon-button,.mat-stroked-button{box-sizing:border-box;position:relative;-webkit-user-select:none;user-select:none;cursor:pointer;outline:0;border:none;-webkit-tap-highlight-color:transparent;display:inline-block;white-space:nowrap;text-decoration:none;vertical-align:baseline;text-align:center;margin:0;min-width:64px;line-height:28px!important;padding:0 16px;border-radius:4px;overflow:visible}.nb-spinner{width:75pxx;height:75px;margin:0;background:transparent;border-top:4px solid #03A9F4;border-right:4px solid transparent;border-radius:50%;animation:1s spin linear infinite}.loade{background:#ffffff80;width:100%;height:100%;overflow:hidden;padding-left:67px;position:absolute;z-index:1;opacity:50;top:0;padding-top:135px}.square-spinner{width:55px;display:block;background-color:#03a9f4;height:55px;animation:3s flip ease-in-out infinite}::ng-deep .mat-spinner circle{stroke:green;stroke-width:10%}::ng-deep .mdc-text-field--filled:not(.mdc-text-field--disabled){background-color:unset!important}::ng-deep .mat-mdc-form-field-focus-overlay{background-color:unset!important}::ng-deep .mat-mdc-form-field-required-marker{display:none!important}::ng-deep .mdc-floating-label--required:after{content:none!important;font-weight:500!important}::ng-deep .mat-mdc-form-field .mat-mdc-form-field-required-marker,::ng-deep .mat-mdc-form-field .mdc-floating-label--required:after{display:none!important;content:none!important}::ng-deep .mdc-text-field--filled .mdc-floating-label{font-size:16px!important;color:#6b6b6b!important}\n"] }]
|
|
81
|
+
}], ctorParameters: () => [{ type: i1.FormBuilder }, { type: i2.ActivatedRoute }, { type: i2.Router }, { type: i3.AuthService }], propDecorators: { routeUrl: [{
|
|
82
|
+
type: Input
|
|
83
|
+
}] } });
|
|
84
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"login.component.js","sourceRoot":"","sources":["../../../../../projects/bulk-tool/src/lib/login/login.component.ts","../../../../../projects/bulk-tool/src/lib/login/login.component.html"],"names":[],"mappings":"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","sourcesContent":["\r\nimport { Component, OnInit, Input } from '@angular/core';\r\nimport { Router, ActivatedRoute, RouterModule } from '@angular/router';\r\nimport { FormBuilder, FormGroup, Validators, AbstractControl } from '@angular/forms';\r\nimport { first } from 'rxjs/operators';\r\nimport { Constant } from '../constant.enum';\r\nimport { AuthService } from '../auth.service';\r\n//import { url } from 'inspector';\r\nexport interface Login\r\n{\r\n  [key: string]: AbstractControl\r\n}\r\n\r\n@Component({\r\n  standalone : false,\r\n  selector: 'lib-login',\r\n  templateUrl: 'login.component.html',\r\n  styleUrls: ['./login.component.css']\r\n})\r\n\r\nexport class LoginComponent implements OnInit {\r\n  public isLoading: boolean = false;\r\n  @Input() routeUrl: string;\r\n  loginForm: FormGroup;\r\n // submitClick = false;\r\n  submitted = false;\r\n  returnUrl: string;\r\n  error = '';\r\n\r\n  constructor(\r\n    private formBuilder: FormBuilder,\r\n    private route: ActivatedRoute,\r\n    private router: Router,\r\n    private authenticationService: AuthService) { }\r\n    public isvalidUser:boolean = true;\r\n  ngOnInit() {\r\n    this.loginForm = this.formBuilder.group({\r\n      username: ['', Validators.required],\r\n      password: ['', Validators.required]\r\n    });\r\n\r\n    // reset login status\r\n    this.authenticationService.logout();\r\n\r\n    this.returnUrl = this.route.snapshot.queryParams['returnUrl'] || this.routeUrl;\r\n  }\r\n\r\n  get formsData():Login { return this.loginForm.controls; }\r\n\r\n  onLogin() {\r\n    this.submitted = true;\r\n    this.isLoading = true;\r\n    // stop here if form is invalid\r\n    if (this.loginForm.invalid) {\r\n      this.isLoading = false;\r\n      return;\r\n    }\r\n\r\n    //this.submitClick = true;\r\n    this.authenticationService.login(this.formsData.username.value, this.formsData.password.value)\r\n      .pipe(first())\r\n      .subscribe(\r\n        data => {\r\n          console.log(data.status);\r\n          if(data.status==\"InValid\")\r\n          {\r\n             this.isLoading = false;\r\n             this.isvalidUser=false;\r\n             this.error = Constant.INVALID;\r\n             this.router.navigate([\"/login\"]);\r\n          }\r\n          else\r\n          {\r\n            this.isLoading = false;\r\n            this.router.navigate([this.returnUrl]);\r\n          }\r\n        },\r\n        error => {\r\n          this.isLoading = false;\r\n          this.error = Constant.INVALID;\r\n          this.router.navigate([\"/login\"]);\r\n          //this.submitClick = true;\r\n        });\r\n  }\r\n}\r\n","\r\n<div class=\"container\">\r\n  <div class=\"loginForm\">\r\n  <div class=\"example-sidenav-content\">\r\n    <div class=\"loginWidget\">\r\n      <form [formGroup]=\"loginForm\" >\r\n        <h2>Login</h2>\r\n        <div>&nbsp;</div>\r\n        <div class=\"form-group\">\r\n          <!-- <label for=\"username\">Username</label> -->\r\n          <!-- <input type=\"text\" formControlName=\"username\" class=\"form-control\"\r\n            [ngClass]=\"{ 'is-invalid': submitted && formsData.username.errors }\" /> -->\r\n    <mat-form-field class=\"example-full-width\"\r\n    color=\"primary\">\r\n      <mat-label>Enter Username</mat-label>\r\n      <input class=\"toolbar-search\" formControlName=\"username\" type=\"text\" matInput>\r\n       <mat-icon matSuffix style=\"font-size: 1.2em\"></mat-icon>\r\n          </mat-form-field>\r\n          <!-- <div *ngIf=\"submitted && formsData.username.errors\" class=\"invalid-feedback\">\r\n            <div *ngIf=\"formsData.username.errors.required\">Username is required</div>\r\n          </div> -->\r\n        </div>\r\n        <div class=\"form-group\">\r\n          <!-- <label for=\"password\">Password</label> -->\r\n          <!-- <input type=\"password\" formControlName=\"password\" class=\"form-control\"\r\n            [ngClass]=\"{ 'is-invalid': submitted && formsData.password.errors }\" /> -->\r\n       <mat-form-field class=\"example-full-width\"\r\n      color=\"primary\">\r\n        <mat-label>Enter Password</mat-label>\r\n        <input class=\"toolbar-search\" formControlName=\"password\" type=\"password\" matInput>\r\n         <mat-icon matSuffix style=\"font-size: 1.2em\"></mat-icon>\r\n          </mat-form-field>\r\n          <!-- <div *ngIf=\"submitted && formsData.password.errors\" class=\"invalid-feedback\">\r\n            <div *ngIf=\"formsData.password.errors.required\">Password is required</div>\r\n          </div> -->\r\n        </div>\r\n        <div class=\"form-group\">\r\n          <!-- <button [disabled]=\"submitClick\" class=\"btn btn-primary\">Login</button> -->\r\n          <button  style=\"background-color: #0888CA;color: #fff;\" mat-button  class=\"!loginForm.valid btn btn-primary\" (click)=\"onLogin()\">Login</button>\r\n        </div>\r\n        <div *ngIf =\"!isvalidUser\" class=\"alert alert-danger\">{{error}}</div>\r\n      </form>\r\n    </div>\r\n\r\n    <section class=\"loade\" *ngIf=\"isLoading\">\r\n      <mat-spinner color=\"black\" [diameter]=60 ></mat-spinner>\r\n      <span>\r\n    Logging...\r\n    </span>\r\n    </section>\r\n\r\n    \r\n    <!-- <button type=\"button\" mat-button (click)=\"drawer.toggle()\">\r\n  Toggle sidenav\r\n</button> -->\r\n  </div>\r\n  </div>\r\n  </div>\r\n\r\n\r\n\r\n"]}
|
|
@@ -0,0 +1,172 @@
|
|
|
1
|
+
import { NgModule } from '@angular/core';
|
|
2
|
+
import { DragDropModule } from '@angular/cdk/drag-drop';
|
|
3
|
+
import { ScrollingModule } from '@angular/cdk/scrolling';
|
|
4
|
+
import { CdkTableModule } from '@angular/cdk/table';
|
|
5
|
+
import { CdkTreeModule } from '@angular/cdk/tree';
|
|
6
|
+
import { A11yModule } from '@angular/cdk/a11y';
|
|
7
|
+
import { MatAutocompleteModule } from '@angular/material/autocomplete';
|
|
8
|
+
import { MatBadgeModule } from '@angular/material/badge';
|
|
9
|
+
import { MatBottomSheetModule } from '@angular/material/bottom-sheet';
|
|
10
|
+
import { MatButtonModule } from '@angular/material/button';
|
|
11
|
+
import { MatButtonToggleModule } from '@angular/material/button-toggle';
|
|
12
|
+
import { MatCardModule } from '@angular/material/card';
|
|
13
|
+
import { MatCheckboxModule } from '@angular/material/checkbox';
|
|
14
|
+
import { MatChipsModule } from '@angular/material/chips';
|
|
15
|
+
import { MatNativeDateModule, MatRippleModule } from '@angular/material/core';
|
|
16
|
+
import { MatDatepickerModule } from '@angular/material/datepicker';
|
|
17
|
+
import { MatDialogModule } from '@angular/material/dialog';
|
|
18
|
+
import { MatDividerModule } from '@angular/material/divider';
|
|
19
|
+
import { MatExpansionModule } from '@angular/material/expansion';
|
|
20
|
+
import { MatGridListModule } from '@angular/material/grid-list';
|
|
21
|
+
import { MatIconModule } from '@angular/material/icon';
|
|
22
|
+
import { MatInputModule } from '@angular/material/input';
|
|
23
|
+
import { MatListModule } from '@angular/material/list';
|
|
24
|
+
import { MatMenuModule } from '@angular/material/menu';
|
|
25
|
+
import { MatPaginatorModule } from '@angular/material/paginator';
|
|
26
|
+
import { MatProgressBarModule } from '@angular/material/progress-bar';
|
|
27
|
+
import { MatProgressSpinnerModule } from '@angular/material/progress-spinner';
|
|
28
|
+
import { MatRadioModule } from '@angular/material/radio';
|
|
29
|
+
import { MatSelectModule } from '@angular/material/select';
|
|
30
|
+
import { MatSidenavModule } from '@angular/material/sidenav';
|
|
31
|
+
import { MatSlideToggleModule } from '@angular/material/slide-toggle';
|
|
32
|
+
import { MatSliderModule } from '@angular/material/slider';
|
|
33
|
+
import { MatSnackBarModule } from '@angular/material/snack-bar';
|
|
34
|
+
import { MatSortModule } from '@angular/material/sort';
|
|
35
|
+
import { MatStepperModule } from '@angular/material/stepper';
|
|
36
|
+
import { MatTableModule } from '@angular/material/table';
|
|
37
|
+
import { MatTabsModule } from '@angular/material/tabs';
|
|
38
|
+
import { MatToolbarModule } from '@angular/material/toolbar';
|
|
39
|
+
import { MatTooltipModule } from '@angular/material/tooltip';
|
|
40
|
+
import { MatTreeModule } from '@angular/material/tree';
|
|
41
|
+
import * as i0 from "@angular/core";
|
|
42
|
+
export class MaterilsModule {
|
|
43
|
+
/** @nocollapse */ static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "20.3.15", ngImport: i0, type: MaterilsModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule });
|
|
44
|
+
/** @nocollapse */ static ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "20.3.15", ngImport: i0, type: MaterilsModule, exports: [A11yModule,
|
|
45
|
+
CdkTableModule,
|
|
46
|
+
CdkTreeModule,
|
|
47
|
+
DragDropModule,
|
|
48
|
+
MatAutocompleteModule,
|
|
49
|
+
MatBadgeModule,
|
|
50
|
+
MatBottomSheetModule,
|
|
51
|
+
MatButtonModule,
|
|
52
|
+
MatButtonToggleModule,
|
|
53
|
+
MatCardModule,
|
|
54
|
+
MatCheckboxModule,
|
|
55
|
+
MatChipsModule,
|
|
56
|
+
MatStepperModule,
|
|
57
|
+
MatDatepickerModule,
|
|
58
|
+
MatDialogModule,
|
|
59
|
+
MatDividerModule,
|
|
60
|
+
MatExpansionModule,
|
|
61
|
+
MatGridListModule,
|
|
62
|
+
MatIconModule,
|
|
63
|
+
MatInputModule,
|
|
64
|
+
MatListModule,
|
|
65
|
+
MatMenuModule,
|
|
66
|
+
MatNativeDateModule,
|
|
67
|
+
MatPaginatorModule,
|
|
68
|
+
MatProgressBarModule,
|
|
69
|
+
MatProgressSpinnerModule,
|
|
70
|
+
MatRadioModule,
|
|
71
|
+
MatRippleModule,
|
|
72
|
+
MatSelectModule,
|
|
73
|
+
MatSidenavModule,
|
|
74
|
+
MatSliderModule,
|
|
75
|
+
MatSlideToggleModule,
|
|
76
|
+
MatSnackBarModule,
|
|
77
|
+
MatSortModule,
|
|
78
|
+
MatTableModule,
|
|
79
|
+
MatTabsModule,
|
|
80
|
+
MatToolbarModule,
|
|
81
|
+
MatTooltipModule,
|
|
82
|
+
MatTreeModule,
|
|
83
|
+
ScrollingModule] });
|
|
84
|
+
/** @nocollapse */ static ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "20.3.15", ngImport: i0, type: MaterilsModule, imports: [A11yModule,
|
|
85
|
+
CdkTableModule,
|
|
86
|
+
CdkTreeModule,
|
|
87
|
+
DragDropModule,
|
|
88
|
+
MatAutocompleteModule,
|
|
89
|
+
MatBadgeModule,
|
|
90
|
+
MatBottomSheetModule,
|
|
91
|
+
MatButtonModule,
|
|
92
|
+
MatButtonToggleModule,
|
|
93
|
+
MatCardModule,
|
|
94
|
+
MatCheckboxModule,
|
|
95
|
+
MatChipsModule,
|
|
96
|
+
MatStepperModule,
|
|
97
|
+
MatDatepickerModule,
|
|
98
|
+
MatDialogModule,
|
|
99
|
+
MatDividerModule,
|
|
100
|
+
MatExpansionModule,
|
|
101
|
+
MatGridListModule,
|
|
102
|
+
MatIconModule,
|
|
103
|
+
MatInputModule,
|
|
104
|
+
MatListModule,
|
|
105
|
+
MatMenuModule,
|
|
106
|
+
MatNativeDateModule,
|
|
107
|
+
MatPaginatorModule,
|
|
108
|
+
MatProgressBarModule,
|
|
109
|
+
MatProgressSpinnerModule,
|
|
110
|
+
MatRadioModule,
|
|
111
|
+
MatRippleModule,
|
|
112
|
+
MatSelectModule,
|
|
113
|
+
MatSidenavModule,
|
|
114
|
+
MatSliderModule,
|
|
115
|
+
MatSlideToggleModule,
|
|
116
|
+
MatSnackBarModule,
|
|
117
|
+
MatSortModule,
|
|
118
|
+
MatTableModule,
|
|
119
|
+
MatTabsModule,
|
|
120
|
+
MatToolbarModule,
|
|
121
|
+
MatTooltipModule,
|
|
122
|
+
MatTreeModule,
|
|
123
|
+
ScrollingModule] });
|
|
124
|
+
}
|
|
125
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "20.3.15", ngImport: i0, type: MaterilsModule, decorators: [{
|
|
126
|
+
type: NgModule,
|
|
127
|
+
args: [{
|
|
128
|
+
exports: [
|
|
129
|
+
A11yModule,
|
|
130
|
+
CdkTableModule,
|
|
131
|
+
CdkTreeModule,
|
|
132
|
+
DragDropModule,
|
|
133
|
+
MatAutocompleteModule,
|
|
134
|
+
MatBadgeModule,
|
|
135
|
+
MatBottomSheetModule,
|
|
136
|
+
MatButtonModule,
|
|
137
|
+
MatButtonToggleModule,
|
|
138
|
+
MatCardModule,
|
|
139
|
+
MatCheckboxModule,
|
|
140
|
+
MatChipsModule,
|
|
141
|
+
MatStepperModule,
|
|
142
|
+
MatDatepickerModule,
|
|
143
|
+
MatDialogModule,
|
|
144
|
+
MatDividerModule,
|
|
145
|
+
MatExpansionModule,
|
|
146
|
+
MatGridListModule,
|
|
147
|
+
MatIconModule,
|
|
148
|
+
MatInputModule,
|
|
149
|
+
MatListModule,
|
|
150
|
+
MatMenuModule,
|
|
151
|
+
MatNativeDateModule,
|
|
152
|
+
MatPaginatorModule,
|
|
153
|
+
MatProgressBarModule,
|
|
154
|
+
MatProgressSpinnerModule,
|
|
155
|
+
MatRadioModule,
|
|
156
|
+
MatRippleModule,
|
|
157
|
+
MatSelectModule,
|
|
158
|
+
MatSidenavModule,
|
|
159
|
+
MatSliderModule,
|
|
160
|
+
MatSlideToggleModule,
|
|
161
|
+
MatSnackBarModule,
|
|
162
|
+
MatSortModule,
|
|
163
|
+
MatTableModule,
|
|
164
|
+
MatTabsModule,
|
|
165
|
+
MatToolbarModule,
|
|
166
|
+
MatTooltipModule,
|
|
167
|
+
MatTreeModule,
|
|
168
|
+
ScrollingModule,
|
|
169
|
+
]
|
|
170
|
+
}]
|
|
171
|
+
}] });
|
|
172
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"materils.module.js","sourceRoot":"","sources":["../../../../../projects/bulk-tool/src/lib/materils/materils.module.ts"],"names":[],"mappings":"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","sourcesContent":["\r\nimport { NgModule } from '@angular/core';\r\nimport { CommonModule } from '@angular/common';\r\nimport {DragDropModule} from '@angular/cdk/drag-drop';\r\nimport {ScrollingModule} from '@angular/cdk/scrolling';\r\nimport {CdkTableModule} from '@angular/cdk/table';\r\nimport {CdkTreeModule} from '@angular/cdk/tree';\r\nimport {A11yModule} from '@angular/cdk/a11y';\r\nimport { MatAutocompleteModule } from '@angular/material/autocomplete';\r\nimport { MatBadgeModule } from '@angular/material/badge';\r\nimport { MatBottomSheetModule } from '@angular/material/bottom-sheet';\r\nimport { MatButtonModule } from '@angular/material/button';\r\nimport { MatButtonToggleModule } from '@angular/material/button-toggle';\r\nimport { MatCardModule } from '@angular/material/card';\r\nimport { MatCheckboxModule } from '@angular/material/checkbox';\r\nimport { MatChipsModule } from '@angular/material/chips';\r\nimport { MatNativeDateModule, MatRippleModule } from '@angular/material/core';\r\nimport { MatDatepickerModule } from '@angular/material/datepicker';\r\nimport { MatDialogModule } from '@angular/material/dialog';\r\nimport { MatDividerModule } from '@angular/material/divider';\r\nimport { MatExpansionModule } from '@angular/material/expansion';\r\nimport { MatGridListModule } from '@angular/material/grid-list';\r\nimport { MatIconModule } from '@angular/material/icon';\r\nimport { MatInputModule } from '@angular/material/input';\r\nimport { MatListModule } from '@angular/material/list';\r\nimport { MatMenuModule } from '@angular/material/menu';\r\nimport { MatPaginatorModule } from '@angular/material/paginator';\r\nimport { MatProgressBarModule } from '@angular/material/progress-bar';\r\nimport { MatProgressSpinnerModule } from '@angular/material/progress-spinner';\r\nimport { MatRadioModule } from '@angular/material/radio';\r\nimport { MatSelectModule } from '@angular/material/select';\r\nimport { MatSidenavModule } from '@angular/material/sidenav';\r\nimport { MatSlideToggleModule } from '@angular/material/slide-toggle';\r\nimport { MatSliderModule } from '@angular/material/slider';\r\nimport { MatSnackBarModule } from '@angular/material/snack-bar';\r\nimport { MatSortModule } from '@angular/material/sort';\r\nimport { MatStepperModule } from '@angular/material/stepper';\r\nimport { MatTableModule } from '@angular/material/table';\r\nimport { MatTabsModule } from '@angular/material/tabs';\r\nimport { MatToolbarModule } from '@angular/material/toolbar';\r\nimport { MatTooltipModule } from '@angular/material/tooltip';\r\nimport { MatTreeModule } from '@angular/material/tree';\r\n\r\n@NgModule({\r\n  exports: [\r\n    A11yModule,\r\n    CdkTableModule,\r\n    CdkTreeModule,\r\n    DragDropModule,\r\n    MatAutocompleteModule,\r\n    MatBadgeModule,\r\n    MatBottomSheetModule,\r\n    MatButtonModule,\r\n    MatButtonToggleModule,\r\n    MatCardModule,\r\n    MatCheckboxModule,\r\n    MatChipsModule,\r\n    MatStepperModule,\r\n    MatDatepickerModule,\r\n    MatDialogModule,\r\n    MatDividerModule,\r\n    MatExpansionModule,\r\n    MatGridListModule,\r\n    MatIconModule,\r\n    MatInputModule,\r\n    MatListModule,\r\n    MatMenuModule,\r\n    MatNativeDateModule,\r\n    MatPaginatorModule,\r\n    MatProgressBarModule,\r\n    MatProgressSpinnerModule,\r\n    MatRadioModule,\r\n    MatRippleModule,\r\n    MatSelectModule,\r\n    MatSidenavModule,\r\n    MatSliderModule,\r\n    MatSlideToggleModule,\r\n    MatSnackBarModule,\r\n    MatSortModule,\r\n    MatTableModule,\r\n    MatTabsModule,\r\n    MatToolbarModule,\r\n    MatTooltipModule,\r\n    MatTreeModule,\r\n    ScrollingModule,\r\n  ]\r\n})\r\n\r\n\r\nexport class MaterilsModule { }\r\n"]}
|
|
@@ -0,0 +1,47 @@
|
|
|
1
|
+
import { Component, ViewChild } from '@angular/core';
|
|
2
|
+
import { AuthService } from '../auth.service';
|
|
3
|
+
import * as i0 from "@angular/core";
|
|
4
|
+
import * as i1 from "../auth.service";
|
|
5
|
+
import * as i2 from "@angular/material/button";
|
|
6
|
+
import * as i3 from "@angular/material/icon";
|
|
7
|
+
import * as i4 from "@angular/material/list";
|
|
8
|
+
import * as i5 from "@angular/material/sidenav";
|
|
9
|
+
import * as i6 from "@angular/material/toolbar";
|
|
10
|
+
import * as i7 from "@angular/common";
|
|
11
|
+
import * as i8 from "@angular/router";
|
|
12
|
+
export class MenuComponent {
|
|
13
|
+
authenticationService;
|
|
14
|
+
async;
|
|
15
|
+
MenuMode = "over";
|
|
16
|
+
message = '';
|
|
17
|
+
tooltext;
|
|
18
|
+
sidenav;
|
|
19
|
+
messages = [];
|
|
20
|
+
MenuData = [];
|
|
21
|
+
constructor(authenticationService) {
|
|
22
|
+
this.authenticationService = authenticationService;
|
|
23
|
+
}
|
|
24
|
+
ngOnInit() {
|
|
25
|
+
this.tooltext = 'CBMS';
|
|
26
|
+
this.GetCBMenu();
|
|
27
|
+
}
|
|
28
|
+
GetCBMenu() {
|
|
29
|
+
this.authenticationService.GetMenu().subscribe(data => {
|
|
30
|
+
this.MenuData = data;
|
|
31
|
+
});
|
|
32
|
+
}
|
|
33
|
+
listItemClick(link) {
|
|
34
|
+
this.tooltext = link.displaytext;
|
|
35
|
+
this.sidenav.toggle();
|
|
36
|
+
}
|
|
37
|
+
/** @nocollapse */ static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "20.3.15", ngImport: i0, type: MenuComponent, deps: [{ token: i1.AuthService }], target: i0.ɵɵFactoryTarget.Component });
|
|
38
|
+
/** @nocollapse */ static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "20.3.15", type: MenuComponent, isStandalone: false, selector: "lib-menu", viewQueries: [{ propertyName: "sidenav", first: true, predicate: ["sidenav"], descendants: true }], ngImport: i0, template: "\r\n<!-- <div class=\"container\" style=\"padding-top:200px\"> -->\r\n <mat-sidenav-container class=\"example-container\" > \r\n <mat-sidenav-content>\r\n <mat-toolbar color=\"primary\">\r\n <button mat-icon-button (click)=\"sidenav.toggle()\"><mat-icon>menu</mat-icon></button>\r\n <div id=\"toolbarTitle\" style=\"margin-left:8px\"><h1 >{{tooltext}}</h1></div>\r\n </mat-toolbar> \r\n <div>\r\n <router-outlet></router-outlet>\r\n </div>\r\n\r\n </mat-sidenav-content>\r\n\r\n <mat-sidenav #sidenav [mode]=\"MenuMode\">\r\n <p>\r\n <mat-nav-list *ngFor=\"let link of MenuData\">\r\n <ul class=\"list-group\">\r\n <li><a mat-list-item (click)=\"tooltext=link.displaytext\" [routerLink]='link.targetAction'>{{ link.displaytext}}</a>\r\n <ul class=\"subMenu\">\r\n <li>\r\n <mat-list>\r\n <div *ngFor=\"let sublink of link.children\">\r\n <a mat-list-item (click)=\"listItemClick(link)\" [routerLink]='sublink.targetAction'>{{ sublink.displaytext}}</a>\r\n </div>\r\n </mat-list >\r\n </li>\r\n </ul>\r\n </li>\r\n </ul>\r\n </mat-nav-list>\r\n <!-- <mat-nav-list><a mat-list-item routerLink=\"/MyNav/fetch-data\">Fetch data</a></mat-nav-list> -->\r\n <mat-nav-list><a mat-list-item [routerLink]=\"['/login']\">Logout</a></mat-nav-list> \r\n </p>\r\n \r\n </mat-sidenav> \r\n </mat-sidenav-container>\r\n<!-- </div> -->\r\n \r\n", styles: ["body{font: 12px Arial,sans-serif!important}.sidenav-container{height:100%}.sidenav{width:200px}.sidenav .mat-toolbar{background:inherit;font: 12px Arial,sans-serif!important}.mat-toolbar.mat-primary{position:sticky;height:40px;font-size:17px;top:10px;z-index:1;font-weight:5px}.example-container{display:flex;flex-direction:column;position:absolute;inset:0;height:auto;min-height:350px;border:#999 solid 1px}.example-is-mobile .example-toolbar{position:fixed;z-index:2}.mat-list-base{padding-top:0!important}.mat-drawer{z-index:4;display:block;position:absolute;top:40px;bottom:0;z-index:3;outline:0;box-sizing:border-box;transform:translate3d(-100%,0,0);height:50%;background-color:#ebebff}.mat-drawer-backdrop.mat-drawer-shown{background-color:#fff!important}a.mat-list-item{padding:0 10px;background:#ebebff!important;width:100%;display:block;color:#000000de!important}.mat-drawer-inner-container{width:100%;height:100%;overflow:inherit;-webkit-overflow-scrolling:touch}.subMenu{margin:0;width:100%;padding:0 15px;background:#ebebff!important;list-style:none}.mat-list-base .mat-list-item .mat-list-option .mat-list-item-content{margin:0;height:30px!important}.mat-list-base .mat-list-item .mat-list-item-content,.mat-list-base .mat-list-option .mat-list-item-content{padding:0px,0px,0px,0px!important;font: 15px Arial,sans-serif!important}.example-container{display:flex;flex-direction:column;position:fixed;inset:0;height:auto;min-height:auto}@media only screen and (min-device-width: 320px) and (max-device-width: 720px) and (-webkit-min-device-pixel-ratio: 2){div#toolbarTitle h1{font-size:19px;font-weight:700;color:#fff;text-transform:uppercase}app-adddealticket.ng-star-inserted{position:absolute;top:59px;display:block;padding:0;margin:0}app-adddealticket.ng-star-inserted h1{font-size:19px;font-weight:700;color:#fff;text-transform:uppercase}.example-container{display:flex;flex-direction:column;position:fixed;inset:0;height:auto;min-height:auto}.mat-toolbar.mat-primary{position:sticky;height:56px;font-size:18px;top:0;z-index:1;font-weight:700;background:#054182}.mat-drawer{z-index:4;display:block;position:absolute;top:40px;bottom:0;z-index:3;outline:0;box-sizing:border-box;-webkit-transform:translate3d(-100%,0,0);background-color:#ebebff;transform:translate3d(-100%,0,0);height:50%}.mat-drawer-inner-container{width:100%;overflow:auto;-webkit-overflow-scrolling:touch;background:#2f4050}.mat-list-option:not(.mat-list-item-disabled):hover,.mat-nav-list .mat-list-item:not(.mat-list-item-disabled):hover{background:#0c79df}.mat-list-base .mat-list-item,.mat-list-base .mat-list-option{display:block;width:100%;padding:0;background-color:#c9d1cc!important}}\n"], dependencies: [{ kind: "component", type: i2.MatIconButton, selector: "button[mat-icon-button], a[mat-icon-button], button[matIconButton], a[matIconButton]", exportAs: ["matButton", "matAnchor"] }, { kind: "component", type: i3.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }, { kind: "component", type: i4.MatList, selector: "mat-list", exportAs: ["matList"] }, { kind: "component", type: i4.MatNavList, selector: "mat-nav-list", exportAs: ["matNavList"] }, { kind: "component", type: i4.MatListItem, selector: "mat-list-item, a[mat-list-item], button[mat-list-item]", inputs: ["activated"], exportAs: ["matListItem"] }, { kind: "component", type: i5.MatSidenav, selector: "mat-sidenav", inputs: ["fixedInViewport", "fixedTopGap", "fixedBottomGap"], exportAs: ["matSidenav"] }, { kind: "component", type: i5.MatSidenavContainer, selector: "mat-sidenav-container", exportAs: ["matSidenavContainer"] }, { kind: "component", type: i5.MatSidenavContent, selector: "mat-sidenav-content" }, { kind: "component", type: i6.MatToolbar, selector: "mat-toolbar", inputs: ["color"], exportAs: ["matToolbar"] }, { kind: "directive", type: i7.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i8.RouterOutlet, selector: "router-outlet", inputs: ["name", "routerOutletData"], outputs: ["activate", "deactivate", "attach", "detach"], exportAs: ["outlet"] }, { kind: "directive", type: i8.RouterLink, selector: "[routerLink]", inputs: ["target", "queryParams", "fragment", "queryParamsHandling", "state", "info", "relativeTo", "preserveFragment", "skipLocationChange", "replaceUrl", "routerLink"] }] });
|
|
39
|
+
}
|
|
40
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "20.3.15", ngImport: i0, type: MenuComponent, decorators: [{
|
|
41
|
+
type: Component,
|
|
42
|
+
args: [{ standalone: false, selector: 'lib-menu', template: "\r\n<!-- <div class=\"container\" style=\"padding-top:200px\"> -->\r\n <mat-sidenav-container class=\"example-container\" > \r\n <mat-sidenav-content>\r\n <mat-toolbar color=\"primary\">\r\n <button mat-icon-button (click)=\"sidenav.toggle()\"><mat-icon>menu</mat-icon></button>\r\n <div id=\"toolbarTitle\" style=\"margin-left:8px\"><h1 >{{tooltext}}</h1></div>\r\n </mat-toolbar> \r\n <div>\r\n <router-outlet></router-outlet>\r\n </div>\r\n\r\n </mat-sidenav-content>\r\n\r\n <mat-sidenav #sidenav [mode]=\"MenuMode\">\r\n <p>\r\n <mat-nav-list *ngFor=\"let link of MenuData\">\r\n <ul class=\"list-group\">\r\n <li><a mat-list-item (click)=\"tooltext=link.displaytext\" [routerLink]='link.targetAction'>{{ link.displaytext}}</a>\r\n <ul class=\"subMenu\">\r\n <li>\r\n <mat-list>\r\n <div *ngFor=\"let sublink of link.children\">\r\n <a mat-list-item (click)=\"listItemClick(link)\" [routerLink]='sublink.targetAction'>{{ sublink.displaytext}}</a>\r\n </div>\r\n </mat-list >\r\n </li>\r\n </ul>\r\n </li>\r\n </ul>\r\n </mat-nav-list>\r\n <!-- <mat-nav-list><a mat-list-item routerLink=\"/MyNav/fetch-data\">Fetch data</a></mat-nav-list> -->\r\n <mat-nav-list><a mat-list-item [routerLink]=\"['/login']\">Logout</a></mat-nav-list> \r\n </p>\r\n \r\n </mat-sidenav> \r\n </mat-sidenav-container>\r\n<!-- </div> -->\r\n \r\n", styles: ["body{font: 12px Arial,sans-serif!important}.sidenav-container{height:100%}.sidenav{width:200px}.sidenav .mat-toolbar{background:inherit;font: 12px Arial,sans-serif!important}.mat-toolbar.mat-primary{position:sticky;height:40px;font-size:17px;top:10px;z-index:1;font-weight:5px}.example-container{display:flex;flex-direction:column;position:absolute;inset:0;height:auto;min-height:350px;border:#999 solid 1px}.example-is-mobile .example-toolbar{position:fixed;z-index:2}.mat-list-base{padding-top:0!important}.mat-drawer{z-index:4;display:block;position:absolute;top:40px;bottom:0;z-index:3;outline:0;box-sizing:border-box;transform:translate3d(-100%,0,0);height:50%;background-color:#ebebff}.mat-drawer-backdrop.mat-drawer-shown{background-color:#fff!important}a.mat-list-item{padding:0 10px;background:#ebebff!important;width:100%;display:block;color:#000000de!important}.mat-drawer-inner-container{width:100%;height:100%;overflow:inherit;-webkit-overflow-scrolling:touch}.subMenu{margin:0;width:100%;padding:0 15px;background:#ebebff!important;list-style:none}.mat-list-base .mat-list-item .mat-list-option .mat-list-item-content{margin:0;height:30px!important}.mat-list-base .mat-list-item .mat-list-item-content,.mat-list-base .mat-list-option .mat-list-item-content{padding:0px,0px,0px,0px!important;font: 15px Arial,sans-serif!important}.example-container{display:flex;flex-direction:column;position:fixed;inset:0;height:auto;min-height:auto}@media only screen and (min-device-width: 320px) and (max-device-width: 720px) and (-webkit-min-device-pixel-ratio: 2){div#toolbarTitle h1{font-size:19px;font-weight:700;color:#fff;text-transform:uppercase}app-adddealticket.ng-star-inserted{position:absolute;top:59px;display:block;padding:0;margin:0}app-adddealticket.ng-star-inserted h1{font-size:19px;font-weight:700;color:#fff;text-transform:uppercase}.example-container{display:flex;flex-direction:column;position:fixed;inset:0;height:auto;min-height:auto}.mat-toolbar.mat-primary{position:sticky;height:56px;font-size:18px;top:0;z-index:1;font-weight:700;background:#054182}.mat-drawer{z-index:4;display:block;position:absolute;top:40px;bottom:0;z-index:3;outline:0;box-sizing:border-box;-webkit-transform:translate3d(-100%,0,0);background-color:#ebebff;transform:translate3d(-100%,0,0);height:50%}.mat-drawer-inner-container{width:100%;overflow:auto;-webkit-overflow-scrolling:touch;background:#2f4050}.mat-list-option:not(.mat-list-item-disabled):hover,.mat-nav-list .mat-list-item:not(.mat-list-item-disabled):hover{background:#0c79df}.mat-list-base .mat-list-item,.mat-list-base .mat-list-option{display:block;width:100%;padding:0;background-color:#c9d1cc!important}}\n"] }]
|
|
43
|
+
}], ctorParameters: () => [{ type: i1.AuthService }], propDecorators: { sidenav: [{
|
|
44
|
+
type: ViewChild,
|
|
45
|
+
args: ['sidenav']
|
|
46
|
+
}] } });
|
|
47
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibWVudS5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9idWxrLXRvb2wvc3JjL2xpYi9tZW51L21lbnUuY29tcG9uZW50LnRzIiwiLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvYnVsay10b29sL3NyYy9saWIvbWVudS9tZW51LmNvbXBvbmVudC5odG1sIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxTQUFTLEVBQVUsU0FBUyxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBQzdELE9BQU8sRUFBRSxXQUFXLEVBQUUsTUFBTSxpQkFBaUIsQ0FBQzs7Ozs7Ozs7OztBQW1COUMsTUFBTSxPQUFPLGFBQWE7SUFTSjtJQVBiLEtBQUssQ0FBTTtJQUNYLFFBQVEsR0FBUSxNQUFNLENBQUM7SUFDOUIsT0FBTyxHQUFHLEVBQUUsQ0FBQztJQUNiLFFBQVEsQ0FBTTtJQUNRLE9BQU8sQ0FBQztJQUM5QixRQUFRLEdBQWEsRUFBRSxDQUFDO0lBQ2pCLFFBQVEsR0FBVyxFQUFFLENBQUM7SUFDN0IsWUFBb0IscUJBQWtDO1FBQWxDLDBCQUFxQixHQUFyQixxQkFBcUIsQ0FBYTtJQUN0RCxDQUFDO0lBRUQsUUFBUTtRQUNOLElBQUksQ0FBQyxRQUFRLEdBQUcsTUFBTSxDQUFDO1FBQ3ZCLElBQUksQ0FBQyxTQUFTLEVBQUUsQ0FBQztJQUNuQixDQUFDO0lBRU0sU0FBUztRQUNkLElBQUksQ0FBQyxxQkFBcUIsQ0FBQyxPQUFPLEVBQUUsQ0FBQyxTQUFTLENBQUMsSUFBSSxDQUFDLEVBQUU7WUFDcEQsSUFBSSxDQUFDLFFBQVEsR0FBRyxJQUFJLENBQUM7UUFDdkIsQ0FBQyxDQUFDLENBQUM7SUFDTCxDQUFDO0lBRUQsYUFBYSxDQUFDLElBQUk7UUFFaEIsSUFBSSxDQUFDLFFBQVEsR0FBQyxJQUFJLENBQUMsV0FBVyxDQUFDO1FBQy9CLElBQUksQ0FBQyxPQUFPLENBQUMsTUFBTSxFQUFFLENBQUM7SUFDeEIsQ0FBQzsySEEzQlUsYUFBYTsrR0FBYixhQUFhLHlLQ3BCMUIsdWlEQXVDQTs7NEZEbkJhLGFBQWE7a0JBTnpCLFNBQVM7aUNBQ0ssS0FBSyxZQUNSLFVBQVU7O3NCQVVuQixTQUFTO3VCQUFDLFNBQVMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDb21wb25lbnQsIE9uSW5pdCwgVmlld0NoaWxkIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XHJcbmltcG9ydCB7IEF1dGhTZXJ2aWNlIH0gZnJvbSAnLi4vYXV0aC5zZXJ2aWNlJztcclxuXHJcblxyXG5leHBvcnQgaW50ZXJmYWNlIE1lbnUge1xyXG4gIGRpc3BsYXl0ZXh0OiBzdHJpbmc7XHJcbiAgZGlzcGxheW9yZGVyOiBudW1iZXI7XHJcbiAgbWVudUlkOiBudW1iZXI7XHJcbiAgbWVudWxldmVsOiBudW1iZXI7XHJcbiAgcGFyZW50TWVudUlkOiBudW1iZXI7XHJcbiAgdGFyZ2V0QWN0aW9uOiBzdHJpbmc7XHJcbiAgdGFyZ2V0U2VydmVyOiBzdHJpbmc7XHJcbn1cclxuXHJcbkBDb21wb25lbnQoe1xyXG4gIHN0YW5kYWxvbmUgOiBmYWxzZSxcclxuICBzZWxlY3RvcjogJ2xpYi1tZW51JyxcclxuICB0ZW1wbGF0ZVVybDogJy4vbWVudS5jb21wb25lbnQuaHRtbCcsXHJcbiAgc3R5bGVVcmxzOiBbJy4vbWVudS5jb21wb25lbnQuY3NzJ11cclxufSlcclxuZXhwb3J0IGNsYXNzIE1lbnVDb21wb25lbnQgaW1wbGVtZW50cyBPbkluaXQge1xyXG5cclxuICBwdWJsaWMgYXN5bmM6IGFueTtcclxuICBwdWJsaWMgTWVudU1vZGU6c3RyaW5nPVwib3ZlclwiO1xyXG4gIG1lc3NhZ2UgPSAnJztcclxuICB0b29sdGV4dDogYW55O1xyXG4gIEBWaWV3Q2hpbGQoJ3NpZGVuYXYnKSBzaWRlbmF2O1xyXG4gIG1lc3NhZ2VzOiBzdHJpbmdbXSA9IFtdO1xyXG4gIHB1YmxpYyBNZW51RGF0YTogTWVudVtdID0gW107XHJcbiAgY29uc3RydWN0b3IocHJpdmF0ZSBhdXRoZW50aWNhdGlvblNlcnZpY2U6IEF1dGhTZXJ2aWNlKSB7XHJcbiAgfVxyXG5cclxuICBuZ09uSW5pdCgpIHtcclxuICAgIHRoaXMudG9vbHRleHQgPSAnQ0JNUyc7XHJcbiAgICB0aGlzLkdldENCTWVudSgpO1xyXG4gIH1cclxuXHJcbiAgcHVibGljIEdldENCTWVudSgpIHtcclxuICAgIHRoaXMuYXV0aGVudGljYXRpb25TZXJ2aWNlLkdldE1lbnUoKS5zdWJzY3JpYmUoZGF0YSA9PiB7XHJcbiAgICAgIHRoaXMuTWVudURhdGEgPSBkYXRhO1xyXG4gICAgfSk7XHJcbiAgfVxyXG5cclxuICBsaXN0SXRlbUNsaWNrKGxpbmspXHJcbiAge1xyXG4gICAgdGhpcy50b29sdGV4dD1saW5rLmRpc3BsYXl0ZXh0O1xyXG4gICAgdGhpcy5zaWRlbmF2LnRvZ2dsZSgpO1xyXG4gIH1cclxufVxyXG4iLCJcclxuPCEtLSA8ZGl2IGNsYXNzPVwiY29udGFpbmVyXCIgc3R5bGU9XCJwYWRkaW5nLXRvcDoyMDBweFwiPiAtLT5cclxuICA8bWF0LXNpZGVuYXYtY29udGFpbmVyIGNsYXNzPVwiZXhhbXBsZS1jb250YWluZXJcIiA+ICBcclxuICAgIDxtYXQtc2lkZW5hdi1jb250ZW50PlxyXG4gICAgICA8bWF0LXRvb2xiYXIgY29sb3I9XCJwcmltYXJ5XCI+XHJcbiAgICAgICAgPGJ1dHRvbiBtYXQtaWNvbi1idXR0b24gKGNsaWNrKT1cInNpZGVuYXYudG9nZ2xlKClcIj48bWF0LWljb24+bWVudTwvbWF0LWljb24+PC9idXR0b24+XHJcbiAgICAgICAgPGRpdiBpZD1cInRvb2xiYXJUaXRsZVwiIHN0eWxlPVwibWFyZ2luLWxlZnQ6OHB4XCI+PGgxID57e3Rvb2x0ZXh0fX08L2gxPjwvZGl2PlxyXG4gICAgICA8L21hdC10b29sYmFyPiAgXHJcbiAgICAgIDxkaXY+XHJcbiAgICAgICAgPHJvdXRlci1vdXRsZXQ+PC9yb3V0ZXItb3V0bGV0PlxyXG4gICAgICA8L2Rpdj5cclxuXHJcbiAgIDwvbWF0LXNpZGVuYXYtY29udGVudD5cclxuXHJcbiAgIDxtYXQtc2lkZW5hdiAjc2lkZW5hdiBbbW9kZV09XCJNZW51TW9kZVwiPlxyXG4gICAgPHA+XHJcbiAgICAgIDxtYXQtbmF2LWxpc3QgKm5nRm9yPVwibGV0IGxpbmsgb2YgTWVudURhdGFcIj5cclxuICAgICAgICA8dWwgY2xhc3M9XCJsaXN0LWdyb3VwXCI+XHJcbiAgICAgICAgICA8bGk+PGEgbWF0LWxpc3QtaXRlbSAoY2xpY2spPVwidG9vbHRleHQ9bGluay5kaXNwbGF5dGV4dFwiIFtyb3V0ZXJMaW5rXT0nbGluay50YXJnZXRBY3Rpb24nPnt7IGxpbmsuZGlzcGxheXRleHR9fTwvYT5cclxuICAgICAgICAgICA8dWwgY2xhc3M9XCJzdWJNZW51XCI+XHJcbiAgICAgICAgICAgICA8bGk+XHJcbiAgICAgICAgICAgICAgICAgPG1hdC1saXN0PlxyXG4gICAgICAgICAgICAgICAgICAgICA8ZGl2ICpuZ0Zvcj1cImxldCBzdWJsaW5rIG9mIGxpbmsuY2hpbGRyZW5cIj5cclxuICAgICAgICAgICAgICAgICAgICAgPGEgbWF0LWxpc3QtaXRlbSAoY2xpY2spPVwibGlzdEl0ZW1DbGljayhsaW5rKVwiIFtyb3V0ZXJMaW5rXT0nc3VibGluay50YXJnZXRBY3Rpb24nPnt7IHN1YmxpbmsuZGlzcGxheXRleHR9fTwvYT5cclxuICAgICAgICAgICAgICAgICAgIDwvZGl2PlxyXG4gICAgICAgICAgICAgICAgICA8L21hdC1saXN0ID5cclxuICAgICAgICAgICAgIDwvbGk+XHJcbiAgICAgICAgICAgPC91bD5cclxuICAgICAgICAgPC9saT5cclxuICAgICAgICA8L3VsPlxyXG4gICAgIDwvbWF0LW5hdi1saXN0PlxyXG4gICAgIDwhLS0gPG1hdC1uYXYtbGlzdD48YSBtYXQtbGlzdC1pdGVtIHJvdXRlckxpbms9XCIvTXlOYXYvZmV0Y2gtZGF0YVwiPkZldGNoIGRhdGE8L2E+PC9tYXQtbmF2LWxpc3Q+IC0tPlxyXG4gICAgIDxtYXQtbmF2LWxpc3Q+PGEgbWF0LWxpc3QtaXRlbSBbcm91dGVyTGlua109XCJbJy9sb2dpbiddXCI+TG9nb3V0PC9hPjwvbWF0LW5hdi1saXN0PiBcclxuICAgPC9wPlxyXG4gICAgXHJcbiAgIDwvbWF0LXNpZGVuYXY+ICAgXHJcbiA8L21hdC1zaWRlbmF2LWNvbnRhaW5lcj5cclxuPCEtLSA8L2Rpdj4gLS0+XHJcbiBcclxuIl19
|