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,10 @@
|
|
|
1
|
+
/*
|
|
2
|
+
* Public API Surface of bulk-tool
|
|
3
|
+
*/
|
|
4
|
+
export * from './lib/bulk-tool.service';
|
|
5
|
+
export * from './lib/bulk-tool.component';
|
|
6
|
+
export * from './lib/bulk-tool.module';
|
|
7
|
+
export * from './lib/login/login.component';
|
|
8
|
+
export * from './lib/menu/menu.component';
|
|
9
|
+
export * from './lib/materils/materils.module';
|
|
10
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHVibGljX2FwaS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3Byb2plY3RzL2J1bGstdG9vbC9zcmMvcHVibGljX2FwaS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQTs7R0FFRztBQUVILGNBQWMseUJBQXlCLENBQUM7QUFDeEMsY0FBYywyQkFBMkIsQ0FBQztBQUMxQyxjQUFjLHdCQUF3QixDQUFDO0FBQ3ZDLGNBQWMsNkJBQTZCLENBQUM7QUFDNUMsY0FBYywyQkFBMkIsQ0FBQztBQUMxQyxjQUFjLGdDQUFnQyxDQUFBIiwic291cmNlc0NvbnRlbnQiOlsiLypcclxuICogUHVibGljIEFQSSBTdXJmYWNlIG9mIGJ1bGstdG9vbFxyXG4gKi9cclxuXHJcbmV4cG9ydCAqIGZyb20gJy4vbGliL2J1bGstdG9vbC5zZXJ2aWNlJztcclxuZXhwb3J0ICogZnJvbSAnLi9saWIvYnVsay10b29sLmNvbXBvbmVudCc7XHJcbmV4cG9ydCAqIGZyb20gJy4vbGliL2J1bGstdG9vbC5tb2R1bGUnO1xyXG5leHBvcnQgKiBmcm9tICcuL2xpYi9sb2dpbi9sb2dpbi5jb21wb25lbnQnO1xyXG5leHBvcnQgKiBmcm9tICcuL2xpYi9tZW51L21lbnUuY29tcG9uZW50JztcclxuZXhwb3J0ICogZnJvbSAnLi9saWIvbWF0ZXJpbHMvbWF0ZXJpbHMubW9kdWxlJ1xyXG4iXX0=
|
|
@@ -0,0 +1,448 @@
|
|
|
1
|
+
import * as i0 from '@angular/core';
|
|
2
|
+
import { Injectable, Component, Input, NgModule, ViewChild } from '@angular/core';
|
|
3
|
+
import * as i2 from '@angular/router';
|
|
4
|
+
import { RouterModule } from '@angular/router';
|
|
5
|
+
import * as i1$1 from '@angular/forms';
|
|
6
|
+
import { Validators, FormsModule, ReactiveFormsModule } from '@angular/forms';
|
|
7
|
+
import { map, first } from 'rxjs/operators';
|
|
8
|
+
import * as i1 from '@angular/common/http';
|
|
9
|
+
import { HttpClientModule, HTTP_INTERCEPTORS } from '@angular/common/http';
|
|
10
|
+
import * as i4 from '@angular/material/button';
|
|
11
|
+
import { MatButtonModule } from '@angular/material/button';
|
|
12
|
+
import * as i5 from '@angular/material/icon';
|
|
13
|
+
import { MatIconModule } from '@angular/material/icon';
|
|
14
|
+
import * as i6 from '@angular/material/input';
|
|
15
|
+
import { MatInputModule } from '@angular/material/input';
|
|
16
|
+
import * as i7 from '@angular/material/progress-spinner';
|
|
17
|
+
import { MatProgressSpinnerModule } from '@angular/material/progress-spinner';
|
|
18
|
+
import * as i8 from '@angular/common';
|
|
19
|
+
import { CommonModule } from '@angular/common';
|
|
20
|
+
import { DragDropModule } from '@angular/cdk/drag-drop';
|
|
21
|
+
import { ScrollingModule } from '@angular/cdk/scrolling';
|
|
22
|
+
import { CdkTableModule } from '@angular/cdk/table';
|
|
23
|
+
import { CdkTreeModule } from '@angular/cdk/tree';
|
|
24
|
+
import { A11yModule } from '@angular/cdk/a11y';
|
|
25
|
+
import { MatAutocompleteModule } from '@angular/material/autocomplete';
|
|
26
|
+
import { MatBadgeModule } from '@angular/material/badge';
|
|
27
|
+
import { MatBottomSheetModule } from '@angular/material/bottom-sheet';
|
|
28
|
+
import { MatButtonToggleModule } from '@angular/material/button-toggle';
|
|
29
|
+
import { MatCardModule } from '@angular/material/card';
|
|
30
|
+
import { MatCheckboxModule } from '@angular/material/checkbox';
|
|
31
|
+
import { MatChipsModule } from '@angular/material/chips';
|
|
32
|
+
import { MatNativeDateModule, MatRippleModule } from '@angular/material/core';
|
|
33
|
+
import { MatDatepickerModule } from '@angular/material/datepicker';
|
|
34
|
+
import { MatDialogModule } from '@angular/material/dialog';
|
|
35
|
+
import { MatDividerModule } from '@angular/material/divider';
|
|
36
|
+
import { MatExpansionModule } from '@angular/material/expansion';
|
|
37
|
+
import { MatGridListModule } from '@angular/material/grid-list';
|
|
38
|
+
import * as i4$1 from '@angular/material/list';
|
|
39
|
+
import { MatListModule } from '@angular/material/list';
|
|
40
|
+
import { MatMenuModule } from '@angular/material/menu';
|
|
41
|
+
import { MatPaginatorModule } from '@angular/material/paginator';
|
|
42
|
+
import { MatProgressBarModule } from '@angular/material/progress-bar';
|
|
43
|
+
import { MatRadioModule } from '@angular/material/radio';
|
|
44
|
+
import { MatSelectModule } from '@angular/material/select';
|
|
45
|
+
import * as i5$1 from '@angular/material/sidenav';
|
|
46
|
+
import { MatSidenavModule } from '@angular/material/sidenav';
|
|
47
|
+
import { MatSlideToggleModule } from '@angular/material/slide-toggle';
|
|
48
|
+
import { MatSliderModule } from '@angular/material/slider';
|
|
49
|
+
import { MatSnackBarModule } from '@angular/material/snack-bar';
|
|
50
|
+
import { MatSortModule } from '@angular/material/sort';
|
|
51
|
+
import { MatStepperModule } from '@angular/material/stepper';
|
|
52
|
+
import { MatTableModule } from '@angular/material/table';
|
|
53
|
+
import { MatTabsModule } from '@angular/material/tabs';
|
|
54
|
+
import * as i6$1 from '@angular/material/toolbar';
|
|
55
|
+
import { MatToolbarModule } from '@angular/material/toolbar';
|
|
56
|
+
import { MatTooltipModule } from '@angular/material/tooltip';
|
|
57
|
+
import { MatTreeModule } from '@angular/material/tree';
|
|
58
|
+
|
|
59
|
+
class BulkToolService {
|
|
60
|
+
constructor() { }
|
|
61
|
+
/** @nocollapse */ static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "20.3.15", ngImport: i0, type: BulkToolService, deps: [], target: i0.ɵɵFactoryTarget.Injectable });
|
|
62
|
+
/** @nocollapse */ static ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "20.3.15", ngImport: i0, type: BulkToolService, providedIn: 'root' });
|
|
63
|
+
}
|
|
64
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "20.3.15", ngImport: i0, type: BulkToolService, decorators: [{
|
|
65
|
+
type: Injectable,
|
|
66
|
+
args: [{
|
|
67
|
+
providedIn: 'root'
|
|
68
|
+
}]
|
|
69
|
+
}], ctorParameters: () => [] });
|
|
70
|
+
|
|
71
|
+
class BulkToolComponent {
|
|
72
|
+
constructor() { }
|
|
73
|
+
ngOnInit() {
|
|
74
|
+
}
|
|
75
|
+
/** @nocollapse */ static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "20.3.15", ngImport: i0, type: BulkToolComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
|
|
76
|
+
/** @nocollapse */ static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "20.3.15", type: BulkToolComponent, isStandalone: false, selector: "lib-BulkTool", ngImport: i0, template: `
|
|
77
|
+
<p>
|
|
78
|
+
bulk-tool works!
|
|
79
|
+
</p>
|
|
80
|
+
`, isInline: true });
|
|
81
|
+
}
|
|
82
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "20.3.15", ngImport: i0, type: BulkToolComponent, decorators: [{
|
|
83
|
+
type: Component,
|
|
84
|
+
args: [{ selector: 'lib-BulkTool', standalone: false, template: `
|
|
85
|
+
<p>
|
|
86
|
+
bulk-tool works!
|
|
87
|
+
</p>
|
|
88
|
+
` }]
|
|
89
|
+
}], ctorParameters: () => [] });
|
|
90
|
+
|
|
91
|
+
const Constant = {
|
|
92
|
+
APPSERVICEURL: 'https://localhost:44348/api',
|
|
93
|
+
APPSERVICEPRODURL: 'https://tk4addin.dev.summitenergy.com/appservices/api',
|
|
94
|
+
INVALID: "Invalid Username or Password"
|
|
95
|
+
};
|
|
96
|
+
|
|
97
|
+
class AuthService {
|
|
98
|
+
http;
|
|
99
|
+
injector;
|
|
100
|
+
API_ENDPOINT; //= this.injector.get("config").Url;
|
|
101
|
+
//private RM_ENDPOINT = this.injector.get("config").apiBaseUrl;
|
|
102
|
+
_username;
|
|
103
|
+
//private headers = new Headers({ 'Content-Type': 'application/x-www-form-urlencoded' });
|
|
104
|
+
constructor(http, injector) {
|
|
105
|
+
this.http = http;
|
|
106
|
+
this.injector = injector;
|
|
107
|
+
this.API_ENDPOINT = this.injector.get("config").Url;
|
|
108
|
+
}
|
|
109
|
+
//private postheaders = new Headers({'Content-Type': 'application/json'});
|
|
110
|
+
login(username, password) {
|
|
111
|
+
this._username = username;
|
|
112
|
+
return this.http.post(this.API_ENDPOINT + "/login", { username, password })
|
|
113
|
+
.pipe(map(user => {
|
|
114
|
+
// login successful if there's a jwt token in the response
|
|
115
|
+
if (user && user.token) {
|
|
116
|
+
console.log(user);
|
|
117
|
+
// store user details and jwt token in local storage to keep user logged in between page refreshes
|
|
118
|
+
localStorage.setItem('TokenInfo', JSON.stringify(user));
|
|
119
|
+
}
|
|
120
|
+
return user;
|
|
121
|
+
}));
|
|
122
|
+
}
|
|
123
|
+
logout() {
|
|
124
|
+
localStorage.removeItem('TokenInfo');
|
|
125
|
+
}
|
|
126
|
+
GetMenu() {
|
|
127
|
+
return this.http.get(this.API_ENDPOINT + '/Menus/userMenus?username=' + this._username)
|
|
128
|
+
.pipe(map(res => {
|
|
129
|
+
return res;
|
|
130
|
+
}));
|
|
131
|
+
}
|
|
132
|
+
/** @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 });
|
|
133
|
+
/** @nocollapse */ static ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "20.3.15", ngImport: i0, type: AuthService, providedIn: 'root' });
|
|
134
|
+
}
|
|
135
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "20.3.15", ngImport: i0, type: AuthService, decorators: [{
|
|
136
|
+
type: Injectable,
|
|
137
|
+
args: [{
|
|
138
|
+
providedIn: 'root'
|
|
139
|
+
}]
|
|
140
|
+
}], ctorParameters: () => [{ type: i1.HttpClient }, { type: i0.Injector }] });
|
|
141
|
+
|
|
142
|
+
class LoginComponent {
|
|
143
|
+
formBuilder;
|
|
144
|
+
route;
|
|
145
|
+
router;
|
|
146
|
+
authenticationService;
|
|
147
|
+
isLoading = false;
|
|
148
|
+
routeUrl;
|
|
149
|
+
loginForm;
|
|
150
|
+
// submitClick = false;
|
|
151
|
+
submitted = false;
|
|
152
|
+
returnUrl;
|
|
153
|
+
error = '';
|
|
154
|
+
constructor(formBuilder, route, router, authenticationService) {
|
|
155
|
+
this.formBuilder = formBuilder;
|
|
156
|
+
this.route = route;
|
|
157
|
+
this.router = router;
|
|
158
|
+
this.authenticationService = authenticationService;
|
|
159
|
+
}
|
|
160
|
+
isvalidUser = true;
|
|
161
|
+
ngOnInit() {
|
|
162
|
+
this.loginForm = this.formBuilder.group({
|
|
163
|
+
username: ['', Validators.required],
|
|
164
|
+
password: ['', Validators.required]
|
|
165
|
+
});
|
|
166
|
+
// reset login status
|
|
167
|
+
this.authenticationService.logout();
|
|
168
|
+
this.returnUrl = this.route.snapshot.queryParams['returnUrl'] || this.routeUrl;
|
|
169
|
+
}
|
|
170
|
+
get formsData() { return this.loginForm.controls; }
|
|
171
|
+
onLogin() {
|
|
172
|
+
this.submitted = true;
|
|
173
|
+
this.isLoading = true;
|
|
174
|
+
// stop here if form is invalid
|
|
175
|
+
if (this.loginForm.invalid) {
|
|
176
|
+
this.isLoading = false;
|
|
177
|
+
return;
|
|
178
|
+
}
|
|
179
|
+
//this.submitClick = true;
|
|
180
|
+
this.authenticationService.login(this.formsData.username.value, this.formsData.password.value)
|
|
181
|
+
.pipe(first())
|
|
182
|
+
.subscribe(data => {
|
|
183
|
+
console.log(data.status);
|
|
184
|
+
if (data.status == "InValid") {
|
|
185
|
+
this.isLoading = false;
|
|
186
|
+
this.isvalidUser = false;
|
|
187
|
+
this.error = Constant.INVALID;
|
|
188
|
+
this.router.navigate(["/login"]);
|
|
189
|
+
}
|
|
190
|
+
else {
|
|
191
|
+
this.isLoading = false;
|
|
192
|
+
this.router.navigate([this.returnUrl]);
|
|
193
|
+
}
|
|
194
|
+
}, error => {
|
|
195
|
+
this.isLoading = false;
|
|
196
|
+
this.error = Constant.INVALID;
|
|
197
|
+
this.router.navigate(["/login"]);
|
|
198
|
+
//this.submitClick = true;
|
|
199
|
+
});
|
|
200
|
+
}
|
|
201
|
+
/** @nocollapse */ static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "20.3.15", ngImport: i0, type: LoginComponent, deps: [{ token: i1$1.FormBuilder }, { token: i2.ActivatedRoute }, { token: i2.Router }, { token: AuthService }], target: i0.ɵɵFactoryTarget.Component });
|
|
202
|
+
/** @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;-webkit-box-shadow:4px 2px 5px -2px rgba(194,179,194,1);-moz-box-shadow:4px 2px 5px -2px rgba(194,179,194,1);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;-moz-user-select:none;-ms-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%;-webkit-animation:1s spin linear infinite;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;-webkit-animation:3s rotate2 ease-in-out infinite;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$1.ɵNgNoValidate, selector: "form:not([ngNoForm]):not([ngNativeValidate])" }, { kind: "directive", type: i1$1.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$1.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i1$1.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$1.FormGroupDirective, selector: "[formGroup]", inputs: ["formGroup"], outputs: ["ngSubmit"], exportAs: ["ngForm"] }, { kind: "directive", type: i1$1.FormControlName, selector: "[formControlName]", inputs: ["formControlName", "disabled", "ngModel"], outputs: ["ngModelChange"] }] });
|
|
203
|
+
}
|
|
204
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "20.3.15", ngImport: i0, type: LoginComponent, decorators: [{
|
|
205
|
+
type: Component,
|
|
206
|
+
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;-webkit-box-shadow:4px 2px 5px -2px rgba(194,179,194,1);-moz-box-shadow:4px 2px 5px -2px rgba(194,179,194,1);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;-moz-user-select:none;-ms-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%;-webkit-animation:1s spin linear infinite;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;-webkit-animation:3s rotate2 ease-in-out infinite;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"] }]
|
|
207
|
+
}], ctorParameters: () => [{ type: i1$1.FormBuilder }, { type: i2.ActivatedRoute }, { type: i2.Router }, { type: AuthService }], propDecorators: { routeUrl: [{
|
|
208
|
+
type: Input
|
|
209
|
+
}] } });
|
|
210
|
+
|
|
211
|
+
class MaterilsModule {
|
|
212
|
+
/** @nocollapse */ static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "20.3.15", ngImport: i0, type: MaterilsModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule });
|
|
213
|
+
/** @nocollapse */ static ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "20.3.15", ngImport: i0, type: MaterilsModule, exports: [A11yModule,
|
|
214
|
+
CdkTableModule,
|
|
215
|
+
CdkTreeModule,
|
|
216
|
+
DragDropModule,
|
|
217
|
+
MatAutocompleteModule,
|
|
218
|
+
MatBadgeModule,
|
|
219
|
+
MatBottomSheetModule,
|
|
220
|
+
MatButtonModule,
|
|
221
|
+
MatButtonToggleModule,
|
|
222
|
+
MatCardModule,
|
|
223
|
+
MatCheckboxModule,
|
|
224
|
+
MatChipsModule,
|
|
225
|
+
MatStepperModule,
|
|
226
|
+
MatDatepickerModule,
|
|
227
|
+
MatDialogModule,
|
|
228
|
+
MatDividerModule,
|
|
229
|
+
MatExpansionModule,
|
|
230
|
+
MatGridListModule,
|
|
231
|
+
MatIconModule,
|
|
232
|
+
MatInputModule,
|
|
233
|
+
MatListModule,
|
|
234
|
+
MatMenuModule,
|
|
235
|
+
MatNativeDateModule,
|
|
236
|
+
MatPaginatorModule,
|
|
237
|
+
MatProgressBarModule,
|
|
238
|
+
MatProgressSpinnerModule,
|
|
239
|
+
MatRadioModule,
|
|
240
|
+
MatRippleModule,
|
|
241
|
+
MatSelectModule,
|
|
242
|
+
MatSidenavModule,
|
|
243
|
+
MatSliderModule,
|
|
244
|
+
MatSlideToggleModule,
|
|
245
|
+
MatSnackBarModule,
|
|
246
|
+
MatSortModule,
|
|
247
|
+
MatTableModule,
|
|
248
|
+
MatTabsModule,
|
|
249
|
+
MatToolbarModule,
|
|
250
|
+
MatTooltipModule,
|
|
251
|
+
MatTreeModule,
|
|
252
|
+
ScrollingModule] });
|
|
253
|
+
/** @nocollapse */ static ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "20.3.15", ngImport: i0, type: MaterilsModule, imports: [A11yModule,
|
|
254
|
+
CdkTableModule,
|
|
255
|
+
CdkTreeModule,
|
|
256
|
+
DragDropModule,
|
|
257
|
+
MatAutocompleteModule,
|
|
258
|
+
MatBadgeModule,
|
|
259
|
+
MatBottomSheetModule,
|
|
260
|
+
MatButtonModule,
|
|
261
|
+
MatButtonToggleModule,
|
|
262
|
+
MatCardModule,
|
|
263
|
+
MatCheckboxModule,
|
|
264
|
+
MatChipsModule,
|
|
265
|
+
MatStepperModule,
|
|
266
|
+
MatDatepickerModule,
|
|
267
|
+
MatDialogModule,
|
|
268
|
+
MatDividerModule,
|
|
269
|
+
MatExpansionModule,
|
|
270
|
+
MatGridListModule,
|
|
271
|
+
MatIconModule,
|
|
272
|
+
MatInputModule,
|
|
273
|
+
MatListModule,
|
|
274
|
+
MatMenuModule,
|
|
275
|
+
MatNativeDateModule,
|
|
276
|
+
MatPaginatorModule,
|
|
277
|
+
MatProgressBarModule,
|
|
278
|
+
MatProgressSpinnerModule,
|
|
279
|
+
MatRadioModule,
|
|
280
|
+
MatRippleModule,
|
|
281
|
+
MatSelectModule,
|
|
282
|
+
MatSidenavModule,
|
|
283
|
+
MatSliderModule,
|
|
284
|
+
MatSlideToggleModule,
|
|
285
|
+
MatSnackBarModule,
|
|
286
|
+
MatSortModule,
|
|
287
|
+
MatTableModule,
|
|
288
|
+
MatTabsModule,
|
|
289
|
+
MatToolbarModule,
|
|
290
|
+
MatTooltipModule,
|
|
291
|
+
MatTreeModule,
|
|
292
|
+
ScrollingModule] });
|
|
293
|
+
}
|
|
294
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "20.3.15", ngImport: i0, type: MaterilsModule, decorators: [{
|
|
295
|
+
type: NgModule,
|
|
296
|
+
args: [{
|
|
297
|
+
exports: [
|
|
298
|
+
A11yModule,
|
|
299
|
+
CdkTableModule,
|
|
300
|
+
CdkTreeModule,
|
|
301
|
+
DragDropModule,
|
|
302
|
+
MatAutocompleteModule,
|
|
303
|
+
MatBadgeModule,
|
|
304
|
+
MatBottomSheetModule,
|
|
305
|
+
MatButtonModule,
|
|
306
|
+
MatButtonToggleModule,
|
|
307
|
+
MatCardModule,
|
|
308
|
+
MatCheckboxModule,
|
|
309
|
+
MatChipsModule,
|
|
310
|
+
MatStepperModule,
|
|
311
|
+
MatDatepickerModule,
|
|
312
|
+
MatDialogModule,
|
|
313
|
+
MatDividerModule,
|
|
314
|
+
MatExpansionModule,
|
|
315
|
+
MatGridListModule,
|
|
316
|
+
MatIconModule,
|
|
317
|
+
MatInputModule,
|
|
318
|
+
MatListModule,
|
|
319
|
+
MatMenuModule,
|
|
320
|
+
MatNativeDateModule,
|
|
321
|
+
MatPaginatorModule,
|
|
322
|
+
MatProgressBarModule,
|
|
323
|
+
MatProgressSpinnerModule,
|
|
324
|
+
MatRadioModule,
|
|
325
|
+
MatRippleModule,
|
|
326
|
+
MatSelectModule,
|
|
327
|
+
MatSidenavModule,
|
|
328
|
+
MatSliderModule,
|
|
329
|
+
MatSlideToggleModule,
|
|
330
|
+
MatSnackBarModule,
|
|
331
|
+
MatSortModule,
|
|
332
|
+
MatTableModule,
|
|
333
|
+
MatTabsModule,
|
|
334
|
+
MatToolbarModule,
|
|
335
|
+
MatTooltipModule,
|
|
336
|
+
MatTreeModule,
|
|
337
|
+
ScrollingModule,
|
|
338
|
+
]
|
|
339
|
+
}]
|
|
340
|
+
}] });
|
|
341
|
+
|
|
342
|
+
class MenuComponent {
|
|
343
|
+
authenticationService;
|
|
344
|
+
async;
|
|
345
|
+
MenuMode = "over";
|
|
346
|
+
message = '';
|
|
347
|
+
tooltext;
|
|
348
|
+
sidenav;
|
|
349
|
+
messages = [];
|
|
350
|
+
MenuData = [];
|
|
351
|
+
constructor(authenticationService) {
|
|
352
|
+
this.authenticationService = authenticationService;
|
|
353
|
+
}
|
|
354
|
+
ngOnInit() {
|
|
355
|
+
this.tooltext = 'CBMS';
|
|
356
|
+
this.GetCBMenu();
|
|
357
|
+
}
|
|
358
|
+
GetCBMenu() {
|
|
359
|
+
this.authenticationService.GetMenu().subscribe(data => {
|
|
360
|
+
this.MenuData = data;
|
|
361
|
+
});
|
|
362
|
+
}
|
|
363
|
+
listItemClick(link) {
|
|
364
|
+
this.tooltext = link.displaytext;
|
|
365
|
+
this.sidenav.toggle();
|
|
366
|
+
}
|
|
367
|
+
/** @nocollapse */ static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "20.3.15", ngImport: i0, type: MenuComponent, deps: [{ token: AuthService }], target: i0.ɵɵFactoryTarget.Component });
|
|
368
|
+
/** @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:-webkit-sticky;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:-webkit-sticky;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: i4.MatIconButton, selector: "button[mat-icon-button], a[mat-icon-button], button[matIconButton], a[matIconButton]", exportAs: ["matButton", "matAnchor"] }, { kind: "component", type: i5.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }, { kind: "component", type: i4$1.MatList, selector: "mat-list", exportAs: ["matList"] }, { kind: "component", type: i4$1.MatNavList, selector: "mat-nav-list", exportAs: ["matNavList"] }, { kind: "component", type: i4$1.MatListItem, selector: "mat-list-item, a[mat-list-item], button[mat-list-item]", inputs: ["activated"], exportAs: ["matListItem"] }, { kind: "component", type: i5$1.MatSidenav, selector: "mat-sidenav", inputs: ["fixedInViewport", "fixedTopGap", "fixedBottomGap"], exportAs: ["matSidenav"] }, { kind: "component", type: i5$1.MatSidenavContainer, selector: "mat-sidenav-container", exportAs: ["matSidenavContainer"] }, { kind: "component", type: i5$1.MatSidenavContent, selector: "mat-sidenav-content" }, { kind: "component", type: i6$1.MatToolbar, selector: "mat-toolbar", inputs: ["color"], exportAs: ["matToolbar"] }, { kind: "directive", type: i8.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i2.RouterOutlet, selector: "router-outlet", inputs: ["name", "routerOutletData"], outputs: ["activate", "deactivate", "attach", "detach"], exportAs: ["outlet"] }, { kind: "directive", type: i2.RouterLink, selector: "[routerLink]", inputs: ["target", "queryParams", "fragment", "queryParamsHandling", "state", "info", "relativeTo", "preserveFragment", "skipLocationChange", "replaceUrl", "routerLink"] }] });
|
|
369
|
+
}
|
|
370
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "20.3.15", ngImport: i0, type: MenuComponent, decorators: [{
|
|
371
|
+
type: Component,
|
|
372
|
+
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:-webkit-sticky;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:-webkit-sticky;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"] }]
|
|
373
|
+
}], ctorParameters: () => [{ type: AuthService }], propDecorators: { sidenav: [{
|
|
374
|
+
type: ViewChild,
|
|
375
|
+
args: ['sidenav']
|
|
376
|
+
}] } });
|
|
377
|
+
|
|
378
|
+
class HttpLibInterceptor {
|
|
379
|
+
intercept(request, newRequest) {
|
|
380
|
+
// add authorization header to request
|
|
381
|
+
//Get Token data from local storage
|
|
382
|
+
let tokenInfo = JSON.parse(localStorage.getItem('TokenInfo'));
|
|
383
|
+
if (tokenInfo && tokenInfo.token) {
|
|
384
|
+
request = request.clone({
|
|
385
|
+
setHeaders: {
|
|
386
|
+
Authorization: `Bearer ${tokenInfo.token}`,
|
|
387
|
+
"Content-Type": 'application/json'
|
|
388
|
+
}
|
|
389
|
+
});
|
|
390
|
+
}
|
|
391
|
+
console.log(request);
|
|
392
|
+
return newRequest.handle(request);
|
|
393
|
+
}
|
|
394
|
+
/** @nocollapse */ static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "20.3.15", ngImport: i0, type: HttpLibInterceptor, deps: [], target: i0.ɵɵFactoryTarget.Injectable });
|
|
395
|
+
/** @nocollapse */ static ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "20.3.15", ngImport: i0, type: HttpLibInterceptor });
|
|
396
|
+
}
|
|
397
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "20.3.15", ngImport: i0, type: HttpLibInterceptor, decorators: [{
|
|
398
|
+
type: Injectable
|
|
399
|
+
}] });
|
|
400
|
+
|
|
401
|
+
class BulkToolModule {
|
|
402
|
+
static forRoot(config) {
|
|
403
|
+
return {
|
|
404
|
+
ngModule: BulkToolModule,
|
|
405
|
+
providers: [{ provide: 'config', useValue: config }]
|
|
406
|
+
};
|
|
407
|
+
}
|
|
408
|
+
/** @nocollapse */ static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "20.3.15", ngImport: i0, type: BulkToolModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule });
|
|
409
|
+
/** @nocollapse */ static ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "20.3.15", ngImport: i0, type: BulkToolModule, declarations: [BulkToolComponent, LoginComponent, MenuComponent], imports: [MaterilsModule,
|
|
410
|
+
FormsModule,
|
|
411
|
+
CommonModule,
|
|
412
|
+
RouterModule,
|
|
413
|
+
ReactiveFormsModule,
|
|
414
|
+
HttpClientModule], exports: [BulkToolComponent, LoginComponent, MenuComponent] });
|
|
415
|
+
/** @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,
|
|
416
|
+
FormsModule,
|
|
417
|
+
CommonModule,
|
|
418
|
+
RouterModule,
|
|
419
|
+
ReactiveFormsModule,
|
|
420
|
+
HttpClientModule] });
|
|
421
|
+
}
|
|
422
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "20.3.15", ngImport: i0, type: BulkToolModule, decorators: [{
|
|
423
|
+
type: NgModule,
|
|
424
|
+
args: [{
|
|
425
|
+
imports: [
|
|
426
|
+
MaterilsModule,
|
|
427
|
+
FormsModule,
|
|
428
|
+
CommonModule,
|
|
429
|
+
RouterModule,
|
|
430
|
+
ReactiveFormsModule,
|
|
431
|
+
HttpClientModule,
|
|
432
|
+
],
|
|
433
|
+
declarations: [BulkToolComponent, LoginComponent, MenuComponent],
|
|
434
|
+
exports: [BulkToolComponent, LoginComponent, MenuComponent],
|
|
435
|
+
providers: [{ provide: HTTP_INTERCEPTORS, useClass: HttpLibInterceptor, multi: true }, AuthService]
|
|
436
|
+
}]
|
|
437
|
+
}] });
|
|
438
|
+
|
|
439
|
+
/*
|
|
440
|
+
* Public API Surface of bulk-tool
|
|
441
|
+
*/
|
|
442
|
+
|
|
443
|
+
/**
|
|
444
|
+
* Generated bundle index. Do not edit.
|
|
445
|
+
*/
|
|
446
|
+
|
|
447
|
+
export { BulkToolComponent, BulkToolModule, BulkToolService, LoginComponent, MaterilsModule, MenuComponent };
|
|
448
|
+
//# sourceMappingURL=bulk-tool-20.mjs.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"bulk-tool-20.mjs","sources":["../../../projects/bulk-tool/src/lib/bulk-tool.service.ts","../../../projects/bulk-tool/src/lib/bulk-tool.component.ts","../../../projects/bulk-tool/src/lib/constant.enum.ts","../../../projects/bulk-tool/src/lib/auth.service.ts","../../../projects/bulk-tool/src/lib/login/login.component.ts","../../../projects/bulk-tool/src/lib/login/login.component.html","../../../projects/bulk-tool/src/lib/materils/materils.module.ts","../../../projects/bulk-tool/src/lib/menu/menu.component.ts","../../../projects/bulk-tool/src/lib/menu/menu.component.html","../../../projects/bulk-tool/src/lib/http-interceptor.ts","../../../projects/bulk-tool/src/lib/bulk-tool.module.ts","../../../projects/bulk-tool/src/public_api.ts","../../../projects/bulk-tool/src/bulk-tool-20.ts"],"sourcesContent":["import { Injectable } from '@angular/core';\r\n\r\n@Injectable({\r\n providedIn: 'root'\r\n})\r\nexport class BulkToolService {\r\n\r\n constructor() { }\r\n}\r\n","import { Component, OnInit } from '@angular/core';\r\n\r\n@Component({\r\n selector: 'lib-BulkTool',\r\n standalone : false,\r\n template: `\r\n <p>\r\n bulk-tool works!\r\n </p>\r\n `,\r\n styles: []\r\n})\r\nexport class BulkToolComponent implements OnInit {\r\n\r\n constructor() { }\r\n\r\n ngOnInit() {\r\n }\r\n\r\n}\r\n","export const Constant= {\r\n APPSERVICEURL:'https://localhost:44348/api',\r\n APPSERVICEPRODURL:'https://tk4addin.dev.summitenergy.com/appservices/api',\r\n\r\n INVALID:\"Invalid Username or Password\"\r\n}\r\n","import { Injectable, Injector } from '@angular/core';\r\nimport { HttpClient } from '@angular/common/http';\r\nimport { map } from 'rxjs/operators';\r\nimport { Constant } from './constant.enum';\r\nimport { Observable } from \"rxjs\";\r\n\r\n\r\n@Injectable({\r\n providedIn: 'root'\r\n})\r\nexport class AuthService {\r\nprivate API_ENDPOINT; //= this.injector.get(\"config\").Url;\r\n//private RM_ENDPOINT = this.injector.get(\"config\").apiBaseUrl;\r\n public _username;\r\n //private headers = new Headers({ 'Content-Type': 'application/x-www-form-urlencoded' });\r\n constructor(private http: HttpClient,public injector: Injector) {\r\n this.API_ENDPOINT = this.injector.get(\"config\").Url;\r\n }\r\n \r\n //private postheaders = new Headers({'Content-Type': 'application/json'});\r\n login(username: string, password: string) : Observable<any>\r\n {\r\n this._username = username;\r\n return this.http.post<any>(this.API_ENDPOINT + \"/login\", { username, password })\r\n .pipe(map(user => {\r\n // login successful if there's a jwt token in the response\r\n if (user && user.token ) {\r\n console.log(user);\r\n // store user details and jwt token in local storage to keep user logged in between page refreshes\r\n localStorage.setItem('TokenInfo', JSON.stringify(user));\r\n }\r\n return user;\r\n }));\r\n }\r\n\r\n logout() {\r\n localStorage.removeItem('TokenInfo');\r\n }\r\n \r\n public GetMenu(): Observable<any> {\r\n return this.http.get(this.API_ENDPOINT +'/Menus/userMenus?username='+ this._username)\r\n .pipe(map(res => {\r\n \r\n return res;\r\n }));\r\n }\r\n}\r\n","\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> </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","\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","import { Component, OnInit, ViewChild } from '@angular/core';\r\nimport { AuthService } from '../auth.service';\r\n\r\n\r\nexport interface Menu {\r\n displaytext: string;\r\n displayorder: number;\r\n menuId: number;\r\n menulevel: number;\r\n parentMenuId: number;\r\n targetAction: string;\r\n targetServer: string;\r\n}\r\n\r\n@Component({\r\n standalone : false,\r\n selector: 'lib-menu',\r\n templateUrl: './menu.component.html',\r\n styleUrls: ['./menu.component.css']\r\n})\r\nexport class MenuComponent implements OnInit {\r\n\r\n public async: any;\r\n public MenuMode:string=\"over\";\r\n message = '';\r\n tooltext: any;\r\n @ViewChild('sidenav') sidenav;\r\n messages: string[] = [];\r\n public MenuData: Menu[] = [];\r\n constructor(private authenticationService: AuthService) {\r\n }\r\n\r\n ngOnInit() {\r\n this.tooltext = 'CBMS';\r\n this.GetCBMenu();\r\n }\r\n\r\n public GetCBMenu() {\r\n this.authenticationService.GetMenu().subscribe(data => {\r\n this.MenuData = data;\r\n });\r\n }\r\n\r\n listItemClick(link)\r\n {\r\n this.tooltext=link.displaytext;\r\n this.sidenav.toggle();\r\n }\r\n}\r\n","\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","import { Injectable } from '@angular/core';\r\nimport { HttpRequest, HttpHandler, HttpEvent, HttpInterceptor } from '@angular/common/http';\r\nimport { Observable } from 'rxjs';\r\n@Injectable()\r\nexport class HttpLibInterceptor implements HttpInterceptor {\r\n intercept(request: HttpRequest<any>, newRequest: HttpHandler): Observable<HttpEvent<any>> {\r\n // add authorization header to request\r\n //Get Token data from local storage\r\n let tokenInfo = JSON.parse(localStorage.getItem('TokenInfo'));\r\n \r\n if (tokenInfo && tokenInfo.token) {\r\n request = request.clone({\r\n setHeaders: {\r\n Authorization: `Bearer ${tokenInfo.token}`,\r\n \"Content-Type\": 'application/json'\r\n }\r\n });\r\n }\r\n console.log(request);\r\n return newRequest.handle(request);\r\n }\r\n}\r\n","import { NgModule,ModuleWithProviders } from '@angular/core';\r\nimport { BulkToolComponent } from './bulk-tool.component';\r\nimport { LoginComponent } from './login/login.component';\r\nimport { MaterilsModule } from './materils/materils.module';\r\nimport { MenuComponent } from './menu/menu.component';\r\n\r\nimport { FormsModule, ReactiveFormsModule } from '@angular/forms';\r\nimport { CommonModule } from '@angular/common';\r\nimport { RouterModule } from '@angular/router';\r\nimport { HttpClientModule, HTTP_INTERCEPTORS } from '@angular/common/http';\r\nimport { HttpLibInterceptor } from './http-interceptor';\r\nimport { AuthService } from './auth.service';\r\nimport {IEnvironmentsInfo} from '../lib/environmentsModel.info';\r\n\r\n\r\n\r\n@NgModule({\r\n imports: [\r\n MaterilsModule,\r\n FormsModule,\r\n CommonModule,\r\n RouterModule,\r\n ReactiveFormsModule,\r\n HttpClientModule,\r\n\r\n \r\n ],\r\n declarations: [BulkToolComponent, LoginComponent, MenuComponent],\r\n exports: [BulkToolComponent, LoginComponent, MenuComponent],\r\n providers:[ { provide: HTTP_INTERCEPTORS, useClass: HttpLibInterceptor, multi: true },AuthService]\r\n})\r\nexport class BulkToolModule {\r\n static forRoot( config :IEnvironmentsInfo): ModuleWithProviders<BulkToolModule> {\r\n return {\r\n ngModule: BulkToolModule,\r\n providers: [{ provide: 'config', useValue: config }]\r\n };\r\n }\r\n\r\n }\r\n","/*\r\n * Public API Surface of bulk-tool\r\n */\r\n\r\nexport * from './lib/bulk-tool.service';\r\nexport * from './lib/bulk-tool.component';\r\nexport * from './lib/bulk-tool.module';\r\nexport * from './lib/login/login.component';\r\nexport * from './lib/menu/menu.component';\r\nexport * from './lib/materils/materils.module'\r\n","/**\n * Generated bundle index. Do not edit.\n */\n\nexport * from './public_api';\n"],"names":["i1","i3.AuthService","i1.AuthService","i2","i3","i4","i5","i6","i7","i8"],"mappings":"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"}
|