ngx-techlify-checksheet 18.0.0
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/README.md +24 -0
- package/esm2022/lib/@shared/file-upload-button/file-upload-button.component.mjs +50 -0
- package/esm2022/lib/@shared/index.mjs +2 -0
- package/esm2022/lib/@shared/material.module.mjs +171 -0
- package/esm2022/lib/@shared/shared.module.mjs +54 -0
- package/esm2022/lib/checksheet/checksheet-form/checksheet-form.component.mjs +161 -0
- package/esm2022/lib/checksheet/checksheet-form-button/checksheet-form-button.component.mjs +58 -0
- package/esm2022/lib/checksheet/checksheet-format-list/checksheet-format-list.component.mjs +123 -0
- package/esm2022/lib/checksheet/checksheet-format-question.service.mjs +18 -0
- package/esm2022/lib/checksheet/checksheet-format.service.mjs +24 -0
- package/esm2022/lib/checksheet/checksheet-list/checksheet-list.component.mjs +138 -0
- package/esm2022/lib/checksheet/checksheet-node-view/checksheet-node-view.component.mjs +59 -0
- package/esm2022/lib/checksheet/checksheet-question/checksheet-question.component.mjs +174 -0
- package/esm2022/lib/checksheet/checksheet-question-form/checksheet-question-form.component.mjs +148 -0
- package/esm2022/lib/checksheet/checksheet-question-list/checksheet-question-list.component.mjs +161 -0
- package/esm2022/lib/checksheet/checksheet-report/checksheet-report.component.mjs +242 -0
- package/esm2022/lib/checksheet/checksheet-review-button/checksheet-review-button.component.mjs +68 -0
- package/esm2022/lib/checksheet/checksheet-routing.module.mjs +44 -0
- package/esm2022/lib/checksheet/checksheet-submission-answer.service.mjs +18 -0
- package/esm2022/lib/checksheet/checksheet-submission-delete-button/checksheet-submission-delete-button.component.mjs +52 -0
- package/esm2022/lib/checksheet/checksheet-submission-file/checksheet-submission-file-delete-button/checksheet-submission-file-delete-button.component.mjs +55 -0
- package/esm2022/lib/checksheet/checksheet-submission-file/checksheet-submission-files/checksheet-submission-files.component.mjs +67 -0
- package/esm2022/lib/checksheet/checksheet-submission-file-upload/checksheet-submisison-file-upload.component.mjs +46 -0
- package/esm2022/lib/checksheet/checksheet-submission-file.service.mjs +18 -0
- package/esm2022/lib/checksheet/checksheet-submission-form/checksheet-submission-form.component.mjs +131 -0
- package/esm2022/lib/checksheet/checksheet-submission-form-button/checksheet-submission-form-button.component.mjs +58 -0
- package/esm2022/lib/checksheet/checksheet-submission-list/checksheet-submission-list.component.mjs +107 -0
- package/esm2022/lib/checksheet/checksheet-submission-review-button/checksheet-submission-review-button.component.mjs +68 -0
- package/esm2022/lib/checksheet/checksheet-submission-view/checksheet-submission-view.component.mjs +142 -0
- package/esm2022/lib/checksheet/checksheet-submission.service.mjs +36 -0
- package/esm2022/lib/checksheet/checksheet-submittable.type.mjs +2 -0
- package/esm2022/lib/checksheet/checksheet-view/checksheet-view.component.mjs +140 -0
- package/esm2022/lib/checksheet/checksheet.module.mjs +131 -0
- package/esm2022/lib/checksheet/checksheet.service.mjs +44 -0
- package/esm2022/lib/checksheet/mechanical-issue-form/mechanical-issue-form.component.mjs +73 -0
- package/esm2022/ngx-techlify-checksheet.mjs +5 -0
- package/esm2022/public-api.mjs +9 -0
- package/fesm2022/ngx-techlify-checksheet.mjs +2550 -0
- package/fesm2022/ngx-techlify-checksheet.mjs.map +1 -0
- package/index.d.ts +5 -0
- package/lib/@shared/file-upload-button/file-upload-button.component.d.ts +20 -0
- package/lib/@shared/index.d.ts +1 -0
- package/lib/@shared/material.module.d.ts +40 -0
- package/lib/@shared/shared.module.d.ts +14 -0
- package/lib/checksheet/checksheet-form/checksheet-form.component.d.ts +45 -0
- package/lib/checksheet/checksheet-form-button/checksheet-form-button.component.d.ts +29 -0
- package/lib/checksheet/checksheet-format-list/checksheet-format-list.component.d.ts +19 -0
- package/lib/checksheet/checksheet-format-question.service.d.ts +7 -0
- package/lib/checksheet/checksheet-format.service.d.ts +10 -0
- package/lib/checksheet/checksheet-list/checksheet-list.component.d.ts +31 -0
- package/lib/checksheet/checksheet-node-view/checksheet-node-view.component.d.ts +25 -0
- package/lib/checksheet/checksheet-question/checksheet-question.component.d.ts +34 -0
- package/lib/checksheet/checksheet-question-form/checksheet-question-form.component.d.ts +38 -0
- package/lib/checksheet/checksheet-question-list/checksheet-question-list.component.d.ts +26 -0
- package/lib/checksheet/checksheet-report/checksheet-report.component.d.ts +47 -0
- package/lib/checksheet/checksheet-review-button/checksheet-review-button.component.d.ts +32 -0
- package/lib/checksheet/checksheet-routing.module.d.ts +7 -0
- package/lib/checksheet/checksheet-submission-answer.service.d.ts +7 -0
- package/lib/checksheet/checksheet-submission-delete-button/checksheet-submission-delete-button.component.d.ts +24 -0
- package/lib/checksheet/checksheet-submission-file/checksheet-submission-file-delete-button/checksheet-submission-file-delete-button.component.d.ts +24 -0
- package/lib/checksheet/checksheet-submission-file/checksheet-submission-files/checksheet-submission-files.component.d.ts +17 -0
- package/lib/checksheet/checksheet-submission-file-upload/checksheet-submisison-file-upload.component.d.ts +13 -0
- package/lib/checksheet/checksheet-submission-file.service.d.ts +7 -0
- package/lib/checksheet/checksheet-submission-form/checksheet-submission-form.component.d.ts +27 -0
- package/lib/checksheet/checksheet-submission-form-button/checksheet-submission-form-button.component.d.ts +29 -0
- package/lib/checksheet/checksheet-submission-list/checksheet-submission-list.component.d.ts +24 -0
- package/lib/checksheet/checksheet-submission-review-button/checksheet-submission-review-button.component.d.ts +32 -0
- package/lib/checksheet/checksheet-submission-view/checksheet-submission-view.component.d.ts +37 -0
- package/lib/checksheet/checksheet-submission.service.d.ts +22 -0
- package/lib/checksheet/checksheet-submittable.type.d.ts +1 -0
- package/lib/checksheet/checksheet-view/checksheet-view.component.d.ts +37 -0
- package/lib/checksheet/checksheet.module.d.ts +34 -0
- package/lib/checksheet/checksheet.service.d.ts +25 -0
- package/lib/checksheet/mechanical-issue-form/mechanical-issue-form.component.d.ts +21 -0
- package/package.json +45 -0
- package/public-api.d.ts +5 -0
package/README.md
ADDED
|
@@ -0,0 +1,24 @@
|
|
|
1
|
+
# NgxTechlifyChecksheet
|
|
2
|
+
|
|
3
|
+
This library was generated with [Angular CLI](https://github.com/angular/angular-cli) version 18.2.0.
|
|
4
|
+
|
|
5
|
+
## Code scaffolding
|
|
6
|
+
|
|
7
|
+
Run `ng generate component component-name --project ngx-techlify-checksheet` to generate a new component. You can also use `ng generate directive|pipe|service|class|guard|interface|enum|module --project ngx-techlify-checksheet`.
|
|
8
|
+
> Note: Don't forget to add `--project ngx-techlify-checksheet` or else it will be added to the default project in your `angular.json` file.
|
|
9
|
+
|
|
10
|
+
## Build
|
|
11
|
+
|
|
12
|
+
Run `ng build ngx-techlify-checksheet` to build the project. The build artifacts will be stored in the `dist/` directory.
|
|
13
|
+
|
|
14
|
+
## Publishing
|
|
15
|
+
|
|
16
|
+
After building your library with `ng build ngx-techlify-checksheet`, go to the dist folder `cd dist/ngx-techlify-checksheet` and run `npm publish`.
|
|
17
|
+
|
|
18
|
+
## Running unit tests
|
|
19
|
+
|
|
20
|
+
Run `ng test ngx-techlify-checksheet` to execute the unit tests via [Karma](https://karma-runner.github.io).
|
|
21
|
+
|
|
22
|
+
## Further help
|
|
23
|
+
|
|
24
|
+
To get more help on the Angular CLI use `ng help` or go check out the [Angular CLI Overview and Command Reference](https://angular.dev/tools/cli) page.
|
|
@@ -0,0 +1,50 @@
|
|
|
1
|
+
import { Component, EventEmitter, Input, Output } from '@angular/core';
|
|
2
|
+
import { CommonModule } from '@angular/common';
|
|
3
|
+
import { MatButtonModule } from '@angular/material/button';
|
|
4
|
+
import { MatIconModule } from '@angular/material/icon';
|
|
5
|
+
import * as i0 from "@angular/core";
|
|
6
|
+
import * as i1 from "ngx-techlify-core";
|
|
7
|
+
import * as i2 from "@angular/material/button";
|
|
8
|
+
import * as i3 from "@angular/material/icon";
|
|
9
|
+
export class FileUploadButtonComponent {
|
|
10
|
+
entityFileService;
|
|
11
|
+
config;
|
|
12
|
+
uploaded = new EventEmitter();
|
|
13
|
+
DEFAULT_FILE_ID = 'file-upload-button';
|
|
14
|
+
isUploading;
|
|
15
|
+
constructor(entityFileService) {
|
|
16
|
+
this.entityFileService = entityFileService;
|
|
17
|
+
}
|
|
18
|
+
async onFileChange(event) {
|
|
19
|
+
if (event.target.files && event.target.files.length) {
|
|
20
|
+
const fileArray = Array.from(event.target.files);
|
|
21
|
+
const fileInput = document.getElementById(this.config?.fileId ?? this.DEFAULT_FILE_ID);
|
|
22
|
+
fileInput.value = '';
|
|
23
|
+
this.isUploading = true;
|
|
24
|
+
const results = await this.uploadFiles(fileArray);
|
|
25
|
+
this.uploaded.emit(results);
|
|
26
|
+
this.isUploading = false;
|
|
27
|
+
}
|
|
28
|
+
}
|
|
29
|
+
selectFiles(event) {
|
|
30
|
+
event.preventDefault();
|
|
31
|
+
document
|
|
32
|
+
.getElementById(this.config?.fileId ?? this.DEFAULT_FILE_ID)
|
|
33
|
+
?.click();
|
|
34
|
+
}
|
|
35
|
+
async uploadFiles(files) {
|
|
36
|
+
const uploadPromises = files.map((file) => this.entityFileService.uploadEntityFile(file));
|
|
37
|
+
return await Promise.all(uploadPromises);
|
|
38
|
+
}
|
|
39
|
+
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: FileUploadButtonComponent, deps: [{ token: i1.EntityFileService }], target: i0.ɵɵFactoryTarget.Component });
|
|
40
|
+
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.13", type: FileUploadButtonComponent, isStandalone: true, selector: "app-file-upload-button", inputs: { config: "config" }, outputs: { uploaded: "uploaded" }, ngImport: i0, template: "<button\n [disabled]=\"isUploading\"\n mat-stroked-button\n type=\"button\"\n (click)=\"selectFiles($event)\"\n>\n <mat-icon>attachment</mat-icon> Attach\n</button>\n\n<input\n type=\"file\"\n id=\"{{ config.fileId ?? DEFAULT_FILE_ID }}\"\n [accept]=\"config.accept ?? '*'\"\n (change)=\"onFileChange($event)\"\n [multiple]=\"config.multiple ?? false\"\n class=\"d-none\"\n/>\n", styles: [""], dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "ngmodule", type: MatButtonModule }, { kind: "component", type: i2.MatButton, selector: " button[mat-button], button[mat-raised-button], button[mat-flat-button], button[mat-stroked-button] ", exportAs: ["matButton"] }, { kind: "ngmodule", type: MatIconModule }, { kind: "component", type: i3.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }] });
|
|
41
|
+
}
|
|
42
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: FileUploadButtonComponent, decorators: [{
|
|
43
|
+
type: Component,
|
|
44
|
+
args: [{ selector: 'app-file-upload-button', standalone: true, imports: [CommonModule, MatButtonModule, MatIconModule], template: "<button\n [disabled]=\"isUploading\"\n mat-stroked-button\n type=\"button\"\n (click)=\"selectFiles($event)\"\n>\n <mat-icon>attachment</mat-icon> Attach\n</button>\n\n<input\n type=\"file\"\n id=\"{{ config.fileId ?? DEFAULT_FILE_ID }}\"\n [accept]=\"config.accept ?? '*'\"\n (change)=\"onFileChange($event)\"\n [multiple]=\"config.multiple ?? false\"\n class=\"d-none\"\n/>\n" }]
|
|
45
|
+
}], ctorParameters: () => [{ type: i1.EntityFileService }], propDecorators: { config: [{
|
|
46
|
+
type: Input
|
|
47
|
+
}], uploaded: [{
|
|
48
|
+
type: Output
|
|
49
|
+
}] } });
|
|
50
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZmlsZS11cGxvYWQtYnV0dG9uLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL25neC10ZWNobGlmeS1jaGVja3NoZWV0L3NyYy9saWIvQHNoYXJlZC9maWxlLXVwbG9hZC1idXR0b24vZmlsZS11cGxvYWQtYnV0dG9uLmNvbXBvbmVudC50cyIsIi4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL25neC10ZWNobGlmeS1jaGVja3NoZWV0L3NyYy9saWIvQHNoYXJlZC9maWxlLXVwbG9hZC1idXR0b24vZmlsZS11cGxvYWQtYnV0dG9uLmNvbXBvbmVudC5odG1sIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxTQUFTLEVBQUUsWUFBWSxFQUFFLEtBQUssRUFBRSxNQUFNLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFDdkUsT0FBTyxFQUFFLFlBQVksRUFBRSxNQUFNLGlCQUFpQixDQUFDO0FBQy9DLE9BQU8sRUFBRSxlQUFlLEVBQUUsTUFBTSwwQkFBMEIsQ0FBQztBQUMzRCxPQUFPLEVBQUUsYUFBYSxFQUFFLE1BQU0sd0JBQXdCLENBQUM7Ozs7O0FBVXZELE1BQU0sT0FBTyx5QkFBeUI7SUFXaEI7SUFWWCxNQUFNLENBSWI7SUFDUSxRQUFRLEdBQXdCLElBQUksWUFBWSxFQUFTLENBQUM7SUFFM0QsZUFBZSxHQUFHLG9CQUFvQixDQUFDO0lBQ2hELFdBQVcsQ0FBVztJQUV0QixZQUFvQixpQkFBb0M7UUFBcEMsc0JBQWlCLEdBQWpCLGlCQUFpQixDQUFtQjtJQUFHLENBQUM7SUFFNUQsS0FBSyxDQUFDLFlBQVksQ0FBQyxLQUFVO1FBQzNCLElBQUksS0FBSyxDQUFDLE1BQU0sQ0FBQyxLQUFLLElBQUksS0FBSyxDQUFDLE1BQU0sQ0FBQyxLQUFLLENBQUMsTUFBTSxFQUFFLENBQUM7WUFDcEQsTUFBTSxTQUFTLEdBQVcsS0FBSyxDQUFDLElBQUksQ0FBQyxLQUFLLENBQUMsTUFBTSxDQUFDLEtBQUssQ0FBQyxDQUFDO1lBQ3pELE1BQU0sU0FBUyxHQUFHLFFBQVEsQ0FBQyxjQUFjLENBQ3ZDLElBQUksQ0FBQyxNQUFNLEVBQUUsTUFBTSxJQUFJLElBQUksQ0FBQyxlQUFlLENBQ3hCLENBQUM7WUFDdEIsU0FBUyxDQUFDLEtBQUssR0FBRyxFQUFFLENBQUM7WUFDckIsSUFBSSxDQUFDLFdBQVcsR0FBRyxJQUFJLENBQUM7WUFDeEIsTUFBTSxPQUFPLEdBQUcsTUFBTSxJQUFJLENBQUMsV0FBVyxDQUFDLFNBQVMsQ0FBQyxDQUFDO1lBQ2xELElBQUksQ0FBQyxRQUFRLENBQUMsSUFBSSxDQUFDLE9BQU8sQ0FBQyxDQUFDO1lBQzVCLElBQUksQ0FBQyxXQUFXLEdBQUcsS0FBSyxDQUFDO1FBQzNCLENBQUM7SUFDSCxDQUFDO0lBRUQsV0FBVyxDQUFDLEtBQVU7UUFDcEIsS0FBSyxDQUFDLGNBQWMsRUFBRSxDQUFDO1FBQ3ZCLFFBQVE7YUFDTCxjQUFjLENBQUMsSUFBSSxDQUFDLE1BQU0sRUFBRSxNQUFNLElBQUksSUFBSSxDQUFDLGVBQWUsQ0FBQztZQUM1RCxFQUFFLEtBQUssRUFBRSxDQUFDO0lBQ2QsQ0FBQztJQUVPLEtBQUssQ0FBQyxXQUFXLENBQUMsS0FBYTtRQUNyQyxNQUFNLGNBQWMsR0FBRyxLQUFLLENBQUMsR0FBRyxDQUFDLENBQUMsSUFBSSxFQUFFLEVBQUUsQ0FDeEMsSUFBSSxDQUFDLGlCQUFpQixDQUFDLGdCQUFnQixDQUFDLElBQUksQ0FBQyxDQUM5QyxDQUFDO1FBQ0YsT0FBTyxNQUFNLE9BQU8sQ0FBQyxHQUFHLENBQUMsY0FBYyxDQUFDLENBQUM7SUFDM0MsQ0FBQzt3R0F2Q1UseUJBQXlCOzRGQUF6Qix5QkFBeUIsbUpDYnRDLHNZQWlCQSx5RERSWSxZQUFZLDhCQUFFLGVBQWUsMk5BQUUsYUFBYTs7NEZBSTNDLHlCQUF5QjtrQkFQckMsU0FBUzsrQkFDRSx3QkFBd0IsY0FDdEIsSUFBSSxXQUNQLENBQUMsWUFBWSxFQUFFLGVBQWUsRUFBRSxhQUFhLENBQUM7c0ZBSzlDLE1BQU07c0JBQWQsS0FBSztnQkFLSSxRQUFRO3NCQUFqQixNQUFNIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ29tcG9uZW50LCBFdmVudEVtaXR0ZXIsIElucHV0LCBPdXRwdXQgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IENvbW1vbk1vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL2NvbW1vbic7XG5pbXBvcnQgeyBNYXRCdXR0b25Nb2R1bGUgfSBmcm9tICdAYW5ndWxhci9tYXRlcmlhbC9idXR0b24nO1xuaW1wb3J0IHsgTWF0SWNvbk1vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL21hdGVyaWFsL2ljb24nO1xuaW1wb3J0IHsgRW50aXR5RmlsZVNlcnZpY2UgfSBmcm9tICduZ3gtdGVjaGxpZnktY29yZSc7XG5cbkBDb21wb25lbnQoe1xuICBzZWxlY3RvcjogJ2FwcC1maWxlLXVwbG9hZC1idXR0b24nLFxuICBzdGFuZGFsb25lOiB0cnVlLFxuICBpbXBvcnRzOiBbQ29tbW9uTW9kdWxlLCBNYXRCdXR0b25Nb2R1bGUsIE1hdEljb25Nb2R1bGVdLFxuICB0ZW1wbGF0ZVVybDogJy4vZmlsZS11cGxvYWQtYnV0dG9uLmNvbXBvbmVudC5odG1sJyxcbiAgc3R5bGVVcmxzOiBbJy4vZmlsZS11cGxvYWQtYnV0dG9uLmNvbXBvbmVudC5zY3NzJ11cbn0pXG5leHBvcnQgY2xhc3MgRmlsZVVwbG9hZEJ1dHRvbkNvbXBvbmVudCAge1xuICBASW5wdXQoKSBjb25maWchOiB7XG4gICAgZmlsZUlkPzogc3RyaW5nIHwgdW5kZWZpbmVkO1xuICAgIG11bHRpcGxlPzogYm9vbGVhbiB8IHVuZGVmaW5lZDtcbiAgICBhY2NlcHQ/OiBzdHJpbmcgfCB1bmRlZmluZWQ7XG4gIH07XG4gIEBPdXRwdXQoKSB1cGxvYWRlZDogRXZlbnRFbWl0dGVyPGFueVtdPiA9IG5ldyBFdmVudEVtaXR0ZXI8YW55W10+KCk7XG5cbiAgcmVhZG9ubHkgREVGQVVMVF9GSUxFX0lEID0gJ2ZpbGUtdXBsb2FkLWJ1dHRvbic7XG4gIGlzVXBsb2FkaW5nITogYm9vbGVhbjtcblxuICBjb25zdHJ1Y3Rvcihwcml2YXRlIGVudGl0eUZpbGVTZXJ2aWNlOiBFbnRpdHlGaWxlU2VydmljZSkge31cblxuICBhc3luYyBvbkZpbGVDaGFuZ2UoZXZlbnQ6IGFueSkge1xuICAgIGlmIChldmVudC50YXJnZXQuZmlsZXMgJiYgZXZlbnQudGFyZ2V0LmZpbGVzLmxlbmd0aCkge1xuICAgICAgY29uc3QgZmlsZUFycmF5OiBGaWxlW10gPSBBcnJheS5mcm9tKGV2ZW50LnRhcmdldC5maWxlcyk7XG4gICAgICBjb25zdCBmaWxlSW5wdXQgPSBkb2N1bWVudC5nZXRFbGVtZW50QnlJZChcbiAgICAgICAgdGhpcy5jb25maWc/LmZpbGVJZCA/PyB0aGlzLkRFRkFVTFRfRklMRV9JRFxuICAgICAgKSBhcyBIVE1MSW5wdXRFbGVtZW50O1xuICAgICAgZmlsZUlucHV0LnZhbHVlID0gJyc7XG4gICAgICB0aGlzLmlzVXBsb2FkaW5nID0gdHJ1ZTtcbiAgICAgIGNvbnN0IHJlc3VsdHMgPSBhd2FpdCB0aGlzLnVwbG9hZEZpbGVzKGZpbGVBcnJheSk7XG4gICAgICB0aGlzLnVwbG9hZGVkLmVtaXQocmVzdWx0cyk7XG4gICAgICB0aGlzLmlzVXBsb2FkaW5nID0gZmFsc2U7XG4gICAgfVxuICB9XG5cbiAgc2VsZWN0RmlsZXMoZXZlbnQ6IGFueSkge1xuICAgIGV2ZW50LnByZXZlbnREZWZhdWx0KCk7XG4gICAgZG9jdW1lbnRcbiAgICAgIC5nZXRFbGVtZW50QnlJZCh0aGlzLmNvbmZpZz8uZmlsZUlkID8/IHRoaXMuREVGQVVMVF9GSUxFX0lEKVxuICAgICAgPy5jbGljaygpO1xuICB9XG5cbiAgcHJpdmF0ZSBhc3luYyB1cGxvYWRGaWxlcyhmaWxlczogRmlsZVtdKTogUHJvbWlzZTxhbnlbXT4ge1xuICAgIGNvbnN0IHVwbG9hZFByb21pc2VzID0gZmlsZXMubWFwKChmaWxlKSA9PlxuICAgICAgdGhpcy5lbnRpdHlGaWxlU2VydmljZS51cGxvYWRFbnRpdHlGaWxlKGZpbGUpXG4gICAgKTtcbiAgICByZXR1cm4gYXdhaXQgUHJvbWlzZS5hbGwodXBsb2FkUHJvbWlzZXMpO1xuICB9XG59XG4iLCI8YnV0dG9uXG4gIFtkaXNhYmxlZF09XCJpc1VwbG9hZGluZ1wiXG4gIG1hdC1zdHJva2VkLWJ1dHRvblxuICB0eXBlPVwiYnV0dG9uXCJcbiAgKGNsaWNrKT1cInNlbGVjdEZpbGVzKCRldmVudClcIlxuPlxuICA8bWF0LWljb24+YXR0YWNobWVudDwvbWF0LWljb24+IEF0dGFjaFxuPC9idXR0b24+XG5cbjxpbnB1dFxuICB0eXBlPVwiZmlsZVwiXG4gIGlkPVwie3sgY29uZmlnLmZpbGVJZCA/PyBERUZBVUxUX0ZJTEVfSUQgfX1cIlxuICBbYWNjZXB0XT1cImNvbmZpZy5hY2NlcHQgPz8gJyonXCJcbiAgKGNoYW5nZSk9XCJvbkZpbGVDaGFuZ2UoJGV2ZW50KVwiXG4gIFttdWx0aXBsZV09XCJjb25maWcubXVsdGlwbGUgPz8gZmFsc2VcIlxuICBjbGFzcz1cImQtbm9uZVwiXG4vPlxuIl19
|
|
@@ -0,0 +1,2 @@
|
|
|
1
|
+
export * from './shared.module';
|
|
2
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9uZ3gtdGVjaGxpZnktY2hlY2tzaGVldC9zcmMvbGliL0BzaGFyZWQvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsY0FBYyxpQkFBaUIsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCAqIGZyb20gJy4vc2hhcmVkLm1vZHVsZSc7XG4iXX0=
|
|
@@ -0,0 +1,171 @@
|
|
|
1
|
+
/*
|
|
2
|
+
* This module imports and re-exports all Angular Material modules for convenience,
|
|
3
|
+
* so only 1 module import is needed in your feature modules.
|
|
4
|
+
* See https://material.angular.io/guide/getting-started#step-3-import-the-component-modules.
|
|
5
|
+
*
|
|
6
|
+
* To optimize your production builds, you should only import the components used in your app.
|
|
7
|
+
*/
|
|
8
|
+
import { NgModule } from '@angular/core';
|
|
9
|
+
import { MatCommonModule, MatLineModule, MatNativeDateModule, MatOptionModule, MatPseudoCheckboxModule, MatRippleModule } from '@angular/material/core';
|
|
10
|
+
import { MatAutocompleteModule } from '@angular/material/autocomplete';
|
|
11
|
+
import { MatBadgeModule } from '@angular/material/badge';
|
|
12
|
+
import { MatButtonModule } from '@angular/material/button';
|
|
13
|
+
import { MatButtonToggleModule } from '@angular/material/button-toggle';
|
|
14
|
+
import { MatCardModule } from '@angular/material/card';
|
|
15
|
+
import { MatCheckboxModule } from '@angular/material/checkbox';
|
|
16
|
+
import { MatChipsModule } from '@angular/material/chips';
|
|
17
|
+
import { MatDatepickerModule } from '@angular/material/datepicker';
|
|
18
|
+
import { MatDialogModule } from '@angular/material/dialog';
|
|
19
|
+
import { MatDividerModule } from '@angular/material/divider';
|
|
20
|
+
import { MatExpansionModule } from '@angular/material/expansion';
|
|
21
|
+
import { MatFormFieldModule } from '@angular/material/form-field';
|
|
22
|
+
import { MatGridListModule } from '@angular/material/grid-list';
|
|
23
|
+
import { MatIconModule } from '@angular/material/icon';
|
|
24
|
+
import { MatInputModule } from '@angular/material/input';
|
|
25
|
+
import { MatListModule } from '@angular/material/list';
|
|
26
|
+
import { MatMenuModule } from '@angular/material/menu';
|
|
27
|
+
import { MatPaginatorModule } from '@angular/material/paginator';
|
|
28
|
+
import { MatProgressBarModule } from '@angular/material/progress-bar';
|
|
29
|
+
import { MatProgressSpinnerModule } from '@angular/material/progress-spinner';
|
|
30
|
+
import { MatRadioModule } from '@angular/material/radio';
|
|
31
|
+
import { MatSelectModule } from '@angular/material/select';
|
|
32
|
+
import { MatSidenavModule } from '@angular/material/sidenav';
|
|
33
|
+
import { MatSlideToggleModule } from '@angular/material/slide-toggle';
|
|
34
|
+
import { MatSliderModule } from '@angular/material/slider';
|
|
35
|
+
import { MatSnackBarModule } from '@angular/material/snack-bar';
|
|
36
|
+
import { MatSortModule } from '@angular/material/sort';
|
|
37
|
+
import { MatStepperModule } from '@angular/material/stepper';
|
|
38
|
+
import { MatTableModule } from '@angular/material/table';
|
|
39
|
+
import { MatTabsModule } from '@angular/material/tabs';
|
|
40
|
+
import { MatToolbarModule } from '@angular/material/toolbar';
|
|
41
|
+
import { MatTooltipModule } from '@angular/material/tooltip';
|
|
42
|
+
import { MatTreeModule } from '@angular/material/tree';
|
|
43
|
+
import * as i0 from "@angular/core";
|
|
44
|
+
export class MaterialModule {
|
|
45
|
+
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: MaterialModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule });
|
|
46
|
+
static ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "18.2.13", ngImport: i0, type: MaterialModule, exports: [MatAutocompleteModule,
|
|
47
|
+
MatBadgeModule,
|
|
48
|
+
MatButtonModule,
|
|
49
|
+
MatButtonToggleModule,
|
|
50
|
+
MatCardModule,
|
|
51
|
+
MatCheckboxModule,
|
|
52
|
+
MatChipsModule,
|
|
53
|
+
MatCommonModule,
|
|
54
|
+
MatDatepickerModule,
|
|
55
|
+
MatDialogModule,
|
|
56
|
+
MatDividerModule,
|
|
57
|
+
MatExpansionModule,
|
|
58
|
+
MatFormFieldModule,
|
|
59
|
+
MatGridListModule,
|
|
60
|
+
MatIconModule,
|
|
61
|
+
MatInputModule,
|
|
62
|
+
MatLineModule,
|
|
63
|
+
MatListModule,
|
|
64
|
+
MatMenuModule,
|
|
65
|
+
MatNativeDateModule,
|
|
66
|
+
MatOptionModule,
|
|
67
|
+
MatPaginatorModule,
|
|
68
|
+
MatProgressBarModule,
|
|
69
|
+
MatProgressSpinnerModule,
|
|
70
|
+
MatPseudoCheckboxModule,
|
|
71
|
+
MatRadioModule,
|
|
72
|
+
MatRippleModule,
|
|
73
|
+
MatSelectModule,
|
|
74
|
+
MatSidenavModule,
|
|
75
|
+
MatSlideToggleModule,
|
|
76
|
+
MatSliderModule,
|
|
77
|
+
MatSnackBarModule,
|
|
78
|
+
MatSortModule,
|
|
79
|
+
MatStepperModule,
|
|
80
|
+
MatTableModule,
|
|
81
|
+
MatTabsModule,
|
|
82
|
+
MatToolbarModule,
|
|
83
|
+
MatTooltipModule,
|
|
84
|
+
MatTreeModule] });
|
|
85
|
+
static ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: MaterialModule, imports: [MatAutocompleteModule,
|
|
86
|
+
MatBadgeModule,
|
|
87
|
+
MatButtonModule,
|
|
88
|
+
MatButtonToggleModule,
|
|
89
|
+
MatCardModule,
|
|
90
|
+
MatCheckboxModule,
|
|
91
|
+
MatChipsModule,
|
|
92
|
+
MatCommonModule,
|
|
93
|
+
MatDatepickerModule,
|
|
94
|
+
MatDialogModule,
|
|
95
|
+
MatDividerModule,
|
|
96
|
+
MatExpansionModule,
|
|
97
|
+
MatFormFieldModule,
|
|
98
|
+
MatGridListModule,
|
|
99
|
+
MatIconModule,
|
|
100
|
+
MatInputModule,
|
|
101
|
+
MatLineModule,
|
|
102
|
+
MatListModule,
|
|
103
|
+
MatMenuModule,
|
|
104
|
+
MatNativeDateModule,
|
|
105
|
+
MatOptionModule,
|
|
106
|
+
MatPaginatorModule,
|
|
107
|
+
MatProgressBarModule,
|
|
108
|
+
MatProgressSpinnerModule,
|
|
109
|
+
MatPseudoCheckboxModule,
|
|
110
|
+
MatRadioModule,
|
|
111
|
+
MatRippleModule,
|
|
112
|
+
MatSelectModule,
|
|
113
|
+
MatSidenavModule,
|
|
114
|
+
MatSlideToggleModule,
|
|
115
|
+
MatSliderModule,
|
|
116
|
+
MatSnackBarModule,
|
|
117
|
+
MatSortModule,
|
|
118
|
+
MatStepperModule,
|
|
119
|
+
MatTableModule,
|
|
120
|
+
MatTabsModule,
|
|
121
|
+
MatToolbarModule,
|
|
122
|
+
MatTooltipModule,
|
|
123
|
+
MatTreeModule] });
|
|
124
|
+
}
|
|
125
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: MaterialModule, decorators: [{
|
|
126
|
+
type: NgModule,
|
|
127
|
+
args: [{
|
|
128
|
+
exports: [
|
|
129
|
+
MatAutocompleteModule,
|
|
130
|
+
MatBadgeModule,
|
|
131
|
+
MatButtonModule,
|
|
132
|
+
MatButtonToggleModule,
|
|
133
|
+
MatCardModule,
|
|
134
|
+
MatCheckboxModule,
|
|
135
|
+
MatChipsModule,
|
|
136
|
+
MatCommonModule,
|
|
137
|
+
MatDatepickerModule,
|
|
138
|
+
MatDialogModule,
|
|
139
|
+
MatDividerModule,
|
|
140
|
+
MatExpansionModule,
|
|
141
|
+
MatFormFieldModule,
|
|
142
|
+
MatGridListModule,
|
|
143
|
+
MatIconModule,
|
|
144
|
+
MatInputModule,
|
|
145
|
+
MatLineModule,
|
|
146
|
+
MatListModule,
|
|
147
|
+
MatMenuModule,
|
|
148
|
+
MatNativeDateModule,
|
|
149
|
+
MatOptionModule,
|
|
150
|
+
MatPaginatorModule,
|
|
151
|
+
MatProgressBarModule,
|
|
152
|
+
MatProgressSpinnerModule,
|
|
153
|
+
MatPseudoCheckboxModule,
|
|
154
|
+
MatRadioModule,
|
|
155
|
+
MatRippleModule,
|
|
156
|
+
MatSelectModule,
|
|
157
|
+
MatSidenavModule,
|
|
158
|
+
MatSlideToggleModule,
|
|
159
|
+
MatSliderModule,
|
|
160
|
+
MatSnackBarModule,
|
|
161
|
+
MatSortModule,
|
|
162
|
+
MatStepperModule,
|
|
163
|
+
MatTableModule,
|
|
164
|
+
MatTabsModule,
|
|
165
|
+
MatToolbarModule,
|
|
166
|
+
MatTooltipModule,
|
|
167
|
+
MatTreeModule
|
|
168
|
+
]
|
|
169
|
+
}]
|
|
170
|
+
}] });
|
|
171
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"material.module.js","sourceRoot":"","sources":["../../../../../projects/ngx-techlify-checksheet/src/lib/@shared/material.module.ts"],"names":[],"mappings":"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","sourcesContent":["/*\n * This module imports and re-exports all Angular Material modules for convenience,\n * so only 1 module import is needed in your feature modules.\n * See https://material.angular.io/guide/getting-started#step-3-import-the-component-modules.\n *\n * To optimize your production builds, you should only import the components used in your app.\n */\n\nimport { NgModule } from '@angular/core';\nimport {\n  MatCommonModule,\n  MatLineModule,\n  MatNativeDateModule,\n  MatOptionModule,\n  MatPseudoCheckboxModule,\n  MatRippleModule\n} from '@angular/material/core';\nimport { MatAutocompleteModule } from '@angular/material/autocomplete';\nimport { MatBadgeModule } from '@angular/material/badge';\nimport { MatButtonModule } from '@angular/material/button';\nimport { MatButtonToggleModule } from '@angular/material/button-toggle';\nimport { MatCardModule } from '@angular/material/card';\nimport { MatCheckboxModule } from '@angular/material/checkbox';\nimport { MatChipsModule } from '@angular/material/chips';\nimport { MatDatepickerModule } from '@angular/material/datepicker';\nimport { MatDialogModule } from '@angular/material/dialog';\nimport { MatDividerModule } from '@angular/material/divider';\nimport { MatExpansionModule } from '@angular/material/expansion';\nimport { MatFormFieldModule } from '@angular/material/form-field';\nimport { MatGridListModule } from '@angular/material/grid-list';\nimport { MatIconModule } from '@angular/material/icon';\nimport { MatInputModule } from '@angular/material/input';\nimport { MatListModule } from '@angular/material/list';\nimport { MatMenuModule } from '@angular/material/menu';\nimport { MatPaginatorModule } from '@angular/material/paginator';\nimport { MatProgressBarModule } from '@angular/material/progress-bar';\nimport { MatProgressSpinnerModule } from '@angular/material/progress-spinner';\nimport { MatRadioModule } from '@angular/material/radio';\nimport { MatSelectModule } from '@angular/material/select';\nimport { MatSidenavModule } from '@angular/material/sidenav';\nimport { MatSlideToggleModule } from '@angular/material/slide-toggle';\nimport { MatSliderModule } from '@angular/material/slider';\nimport { MatSnackBarModule } from '@angular/material/snack-bar';\nimport { MatSortModule } from '@angular/material/sort';\nimport { MatStepperModule } from '@angular/material/stepper';\nimport { MatTableModule } from '@angular/material/table';\nimport { MatTabsModule } from '@angular/material/tabs';\nimport { MatToolbarModule } from '@angular/material/toolbar';\nimport { MatTooltipModule } from '@angular/material/tooltip';\nimport { MatTreeModule } from '@angular/material/tree';\n\n@NgModule({\n  exports: [\n    MatAutocompleteModule,\n    MatBadgeModule,\n    MatButtonModule,\n    MatButtonToggleModule,\n    MatCardModule,\n    MatCheckboxModule,\n    MatChipsModule,\n    MatCommonModule,\n    MatDatepickerModule,\n    MatDialogModule,\n    MatDividerModule,\n    MatExpansionModule,\n    MatFormFieldModule,\n    MatGridListModule,\n    MatIconModule,\n    MatInputModule,\n    MatLineModule,\n    MatListModule,\n    MatMenuModule,\n    MatNativeDateModule,\n    MatOptionModule,\n    MatPaginatorModule,\n    MatProgressBarModule,\n    MatProgressSpinnerModule,\n    MatPseudoCheckboxModule,\n    MatRadioModule,\n    MatRippleModule,\n    MatSelectModule,\n    MatSidenavModule,\n    MatSlideToggleModule,\n    MatSliderModule,\n    MatSnackBarModule,\n    MatSortModule,\n    MatStepperModule,\n    MatTableModule,\n    MatTabsModule,\n    MatToolbarModule,\n    MatTooltipModule,\n    MatTreeModule\n  ]\n})\nexport class MaterialModule { }\n"]}
|
|
@@ -0,0 +1,54 @@
|
|
|
1
|
+
import { NgModule } from '@angular/core';
|
|
2
|
+
import { CommonModule } from '@angular/common';
|
|
3
|
+
import { FlexLayoutModule } from '@angular/flex-layout';
|
|
4
|
+
import { MaterialModule } from './material.module';
|
|
5
|
+
import { FormsModule, ReactiveFormsModule } from '@angular/forms';
|
|
6
|
+
import { InfiniteScrollModule } from 'ngx-infinite-scroll';
|
|
7
|
+
import { RouterModule } from '@angular/router';
|
|
8
|
+
import { LoaderModule } from 'ngx-techlify-core';
|
|
9
|
+
import { NgxPermissionsModule } from 'ngx-permissions';
|
|
10
|
+
import * as i0 from "@angular/core";
|
|
11
|
+
export class SharedModule {
|
|
12
|
+
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: SharedModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule });
|
|
13
|
+
static ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "18.2.13", ngImport: i0, type: SharedModule, imports: [FlexLayoutModule,
|
|
14
|
+
MaterialModule,
|
|
15
|
+
CommonModule], exports: [FlexLayoutModule,
|
|
16
|
+
MaterialModule,
|
|
17
|
+
NgxPermissionsModule,
|
|
18
|
+
FormsModule,
|
|
19
|
+
ReactiveFormsModule,
|
|
20
|
+
InfiniteScrollModule,
|
|
21
|
+
RouterModule,
|
|
22
|
+
LoaderModule] });
|
|
23
|
+
static ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: SharedModule, imports: [FlexLayoutModule,
|
|
24
|
+
MaterialModule,
|
|
25
|
+
CommonModule, FlexLayoutModule,
|
|
26
|
+
MaterialModule,
|
|
27
|
+
NgxPermissionsModule,
|
|
28
|
+
FormsModule,
|
|
29
|
+
ReactiveFormsModule,
|
|
30
|
+
InfiniteScrollModule,
|
|
31
|
+
RouterModule,
|
|
32
|
+
LoaderModule] });
|
|
33
|
+
}
|
|
34
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: SharedModule, decorators: [{
|
|
35
|
+
type: NgModule,
|
|
36
|
+
args: [{
|
|
37
|
+
imports: [
|
|
38
|
+
FlexLayoutModule,
|
|
39
|
+
MaterialModule,
|
|
40
|
+
CommonModule
|
|
41
|
+
],
|
|
42
|
+
exports: [
|
|
43
|
+
FlexLayoutModule,
|
|
44
|
+
MaterialModule,
|
|
45
|
+
NgxPermissionsModule,
|
|
46
|
+
FormsModule,
|
|
47
|
+
ReactiveFormsModule,
|
|
48
|
+
InfiniteScrollModule,
|
|
49
|
+
RouterModule,
|
|
50
|
+
LoaderModule
|
|
51
|
+
]
|
|
52
|
+
}]
|
|
53
|
+
}] });
|
|
54
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic2hhcmVkLm1vZHVsZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL25neC10ZWNobGlmeS1jaGVja3NoZWV0L3NyYy9saWIvQHNoYXJlZC9zaGFyZWQubW9kdWxlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBQyxRQUFRLEVBQUMsTUFBTSxlQUFlLENBQUM7QUFDdkMsT0FBTyxFQUFDLFlBQVksRUFBQyxNQUFNLGlCQUFpQixDQUFDO0FBQzdDLE9BQU8sRUFBQyxnQkFBZ0IsRUFBQyxNQUFNLHNCQUFzQixDQUFDO0FBQ3RELE9BQU8sRUFBQyxjQUFjLEVBQUMsTUFBTSxtQkFBbUIsQ0FBQztBQUNqRCxPQUFPLEVBQUMsV0FBVyxFQUFFLG1CQUFtQixFQUFDLE1BQU0sZ0JBQWdCLENBQUM7QUFDaEUsT0FBTyxFQUFDLG9CQUFvQixFQUFDLE1BQU0scUJBQXFCLENBQUM7QUFDekQsT0FBTyxFQUFDLFlBQVksRUFBQyxNQUFNLGlCQUFpQixDQUFDO0FBQzdDLE9BQU8sRUFBQyxZQUFZLEVBQUMsTUFBTSxtQkFBbUIsQ0FBQztBQUMvQyxPQUFPLEVBQUMsb0JBQW9CLEVBQUMsTUFBTSxpQkFBaUIsQ0FBQzs7QUFtQnJELE1BQU0sT0FBTyxZQUFZO3dHQUFaLFlBQVk7eUdBQVosWUFBWSxZQWZyQixnQkFBZ0I7WUFDaEIsY0FBYztZQUNkLFlBQVksYUFHWixnQkFBZ0I7WUFDaEIsY0FBYztZQUNkLG9CQUFvQjtZQUNwQixXQUFXO1lBQ1gsbUJBQW1CO1lBQ25CLG9CQUFvQjtZQUNwQixZQUFZO1lBQ1osWUFBWTt5R0FHSCxZQUFZLFlBZnJCLGdCQUFnQjtZQUNoQixjQUFjO1lBQ2QsWUFBWSxFQUdaLGdCQUFnQjtZQUNoQixjQUFjO1lBQ2Qsb0JBQW9CO1lBQ3BCLFdBQVc7WUFDWCxtQkFBbUI7WUFDbkIsb0JBQW9CO1lBQ3BCLFlBQVk7WUFDWixZQUFZOzs0RkFHSCxZQUFZO2tCQWpCeEIsUUFBUTttQkFBQztvQkFDUixPQUFPLEVBQUU7d0JBQ1AsZ0JBQWdCO3dCQUNoQixjQUFjO3dCQUNkLFlBQVk7cUJBQ2I7b0JBQ0QsT0FBTyxFQUFFO3dCQUNQLGdCQUFnQjt3QkFDaEIsY0FBYzt3QkFDZCxvQkFBb0I7d0JBQ3BCLFdBQVc7d0JBQ1gsbUJBQW1CO3dCQUNuQixvQkFBb0I7d0JBQ3BCLFlBQVk7d0JBQ1osWUFBWTtxQkFDYjtpQkFDRiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7TmdNb2R1bGV9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHtDb21tb25Nb2R1bGV9IGZyb20gJ0Bhbmd1bGFyL2NvbW1vbic7XG5pbXBvcnQge0ZsZXhMYXlvdXRNb2R1bGV9IGZyb20gJ0Bhbmd1bGFyL2ZsZXgtbGF5b3V0JztcbmltcG9ydCB7TWF0ZXJpYWxNb2R1bGV9IGZyb20gJy4vbWF0ZXJpYWwubW9kdWxlJztcbmltcG9ydCB7Rm9ybXNNb2R1bGUsIFJlYWN0aXZlRm9ybXNNb2R1bGV9IGZyb20gJ0Bhbmd1bGFyL2Zvcm1zJztcbmltcG9ydCB7SW5maW5pdGVTY3JvbGxNb2R1bGV9IGZyb20gJ25neC1pbmZpbml0ZS1zY3JvbGwnO1xuaW1wb3J0IHtSb3V0ZXJNb2R1bGV9IGZyb20gJ0Bhbmd1bGFyL3JvdXRlcic7XG5pbXBvcnQge0xvYWRlck1vZHVsZX0gZnJvbSAnbmd4LXRlY2hsaWZ5LWNvcmUnO1xuaW1wb3J0IHtOZ3hQZXJtaXNzaW9uc01vZHVsZX0gZnJvbSAnbmd4LXBlcm1pc3Npb25zJztcblxuQE5nTW9kdWxlKHtcbiAgaW1wb3J0czogW1xuICAgIEZsZXhMYXlvdXRNb2R1bGUsXG4gICAgTWF0ZXJpYWxNb2R1bGUsXG4gICAgQ29tbW9uTW9kdWxlXG4gIF0sXG4gIGV4cG9ydHM6IFtcbiAgICBGbGV4TGF5b3V0TW9kdWxlLFxuICAgIE1hdGVyaWFsTW9kdWxlLFxuICAgIE5neFBlcm1pc3Npb25zTW9kdWxlLFxuICAgIEZvcm1zTW9kdWxlLFxuICAgIFJlYWN0aXZlRm9ybXNNb2R1bGUsXG4gICAgSW5maW5pdGVTY3JvbGxNb2R1bGUsXG4gICAgUm91dGVyTW9kdWxlLFxuICAgIExvYWRlck1vZHVsZVxuICBdXG59KVxuZXhwb3J0IGNsYXNzIFNoYXJlZE1vZHVsZSB7XG59XG4iXX0=
|
|
@@ -0,0 +1,161 @@
|
|
|
1
|
+
import { Component, Input } from '@angular/core';
|
|
2
|
+
import { Validators } from '@angular/forms';
|
|
3
|
+
import { ActionPopupComponent } from 'ngx-techlify-core';
|
|
4
|
+
import * as i0 from "@angular/core";
|
|
5
|
+
import * as i1 from "ngx-techlify-core";
|
|
6
|
+
import * as i2 from "@angular/forms";
|
|
7
|
+
import * as i3 from "ngx-spinner";
|
|
8
|
+
import * as i4 from "@angular/common";
|
|
9
|
+
import * as i5 from "@angular/material/dialog";
|
|
10
|
+
import * as i6 from "@angular/router";
|
|
11
|
+
import * as i7 from "../checksheet-format.service";
|
|
12
|
+
import * as i8 from "@angular/flex-layout/flex";
|
|
13
|
+
import * as i9 from "@angular/material/button";
|
|
14
|
+
import * as i10 from "@angular/material/card";
|
|
15
|
+
import * as i11 from "@angular/material/form-field";
|
|
16
|
+
import * as i12 from "@angular/material/input";
|
|
17
|
+
import * as i13 from "@angular/material/progress-bar";
|
|
18
|
+
import * as i14 from "../checksheet-question-list/checksheet-question-list.component";
|
|
19
|
+
const errorMessages = {
|
|
20
|
+
title: {
|
|
21
|
+
required: 'The title is required.'
|
|
22
|
+
}
|
|
23
|
+
};
|
|
24
|
+
export class ChecksheetFormComponent {
|
|
25
|
+
formValidatorService;
|
|
26
|
+
fb;
|
|
27
|
+
spinnerService;
|
|
28
|
+
alertService;
|
|
29
|
+
location;
|
|
30
|
+
errorHandler;
|
|
31
|
+
dataManager;
|
|
32
|
+
dialog;
|
|
33
|
+
route;
|
|
34
|
+
checksheetFormatService;
|
|
35
|
+
checksheetForm;
|
|
36
|
+
updateMode;
|
|
37
|
+
checksheet;
|
|
38
|
+
isSaving = false;
|
|
39
|
+
id;
|
|
40
|
+
disableInput;
|
|
41
|
+
isLoading = false;
|
|
42
|
+
constructor(formValidatorService, fb, spinnerService, alertService, location, errorHandler, dataManager, dialog, route, checksheetFormatService) {
|
|
43
|
+
this.formValidatorService = formValidatorService;
|
|
44
|
+
this.fb = fb;
|
|
45
|
+
this.spinnerService = spinnerService;
|
|
46
|
+
this.alertService = alertService;
|
|
47
|
+
this.location = location;
|
|
48
|
+
this.errorHandler = errorHandler;
|
|
49
|
+
this.dataManager = dataManager;
|
|
50
|
+
this.dialog = dialog;
|
|
51
|
+
this.route = route;
|
|
52
|
+
this.checksheetFormatService = checksheetFormatService;
|
|
53
|
+
this.id = parseInt(this.route.snapshot.params?.['checksheetId']);
|
|
54
|
+
this.createForm();
|
|
55
|
+
}
|
|
56
|
+
ngOnInit() {
|
|
57
|
+
if (this.disableInput) {
|
|
58
|
+
this.checksheetForm.disable();
|
|
59
|
+
}
|
|
60
|
+
if (this.id) {
|
|
61
|
+
this.updateMode = true;
|
|
62
|
+
this.loadChecksheetFormat();
|
|
63
|
+
}
|
|
64
|
+
}
|
|
65
|
+
/**
|
|
66
|
+
* Create a check-sheet form.
|
|
67
|
+
* @private
|
|
68
|
+
*/
|
|
69
|
+
createForm() {
|
|
70
|
+
this.checksheetForm = this.fb.group({
|
|
71
|
+
id: [''],
|
|
72
|
+
title: ['', Validators.required]
|
|
73
|
+
});
|
|
74
|
+
}
|
|
75
|
+
/**Method to evaluate form fields*/
|
|
76
|
+
isFieldValid(field) {
|
|
77
|
+
return this.formValidatorService.isFieldValid(field, this.checksheetForm);
|
|
78
|
+
}
|
|
79
|
+
/**Method to find error in form fields*/
|
|
80
|
+
getErrorMessage(field) {
|
|
81
|
+
return this.formValidatorService.getErrorMessage(field, this.checksheetForm, errorMessages);
|
|
82
|
+
}
|
|
83
|
+
submit() {
|
|
84
|
+
this.checksheetForm.markAllAsTouched();
|
|
85
|
+
if (this.checksheetForm.invalid) {
|
|
86
|
+
this.alertService.addAlert('Please check the form for errors.', 'error');
|
|
87
|
+
return;
|
|
88
|
+
}
|
|
89
|
+
const model = { ...this.checksheetForm.value };
|
|
90
|
+
this.isSaving = true;
|
|
91
|
+
let request = this.updateMode
|
|
92
|
+
? this.checksheetFormatService.update(model)
|
|
93
|
+
: this.checksheetFormatService.store(model);
|
|
94
|
+
request.subscribe({
|
|
95
|
+
next: (result) => {
|
|
96
|
+
this.isSaving = false;
|
|
97
|
+
if (!this.updateMode) {
|
|
98
|
+
this.checksheet = result.item;
|
|
99
|
+
this.checksheetForm.patchValue({ ...this.checksheet });
|
|
100
|
+
}
|
|
101
|
+
this.updateMode = true;
|
|
102
|
+
this.alertService.addAlert('Checksheet saved successfully', 'success');
|
|
103
|
+
},
|
|
104
|
+
error: (error) => {
|
|
105
|
+
this.isSaving = false;
|
|
106
|
+
}
|
|
107
|
+
});
|
|
108
|
+
}
|
|
109
|
+
publishChecksheet() {
|
|
110
|
+
const dialogRef = this.dialog.open(ActionPopupComponent, {
|
|
111
|
+
width: '400px',
|
|
112
|
+
data: {
|
|
113
|
+
title: 'Publish Checksheet',
|
|
114
|
+
message: `Review the checksheet completely before publishing, you cannot alter once it is published. Are you sure to publish the Checksheet?`
|
|
115
|
+
},
|
|
116
|
+
autoFocus: false
|
|
117
|
+
});
|
|
118
|
+
dialogRef.afterClosed().subscribe(async (result) => {
|
|
119
|
+
if (result) {
|
|
120
|
+
//Action confirmed
|
|
121
|
+
try {
|
|
122
|
+
this.spinnerService.show();
|
|
123
|
+
const model = this.checksheetForm.value;
|
|
124
|
+
model.is_published = true;
|
|
125
|
+
const result = await this.dataManager.PUT(`api/checksheet-formats/${model.id}`, model);
|
|
126
|
+
this.alertService.addAlert('Checksheet successfully published', 'success');
|
|
127
|
+
this.location.back();
|
|
128
|
+
}
|
|
129
|
+
catch (error) {
|
|
130
|
+
this.errorHandler.handleError(error, 'Unable to publish checksheet, try later');
|
|
131
|
+
}
|
|
132
|
+
finally {
|
|
133
|
+
this.spinnerService.hide();
|
|
134
|
+
}
|
|
135
|
+
}
|
|
136
|
+
});
|
|
137
|
+
}
|
|
138
|
+
loadChecksheetFormat() {
|
|
139
|
+
this.isLoading = true;
|
|
140
|
+
const params = { with: 'questions.answers,questions.type' };
|
|
141
|
+
this.checksheetFormatService.show(this.id, params).subscribe({
|
|
142
|
+
next: (result) => {
|
|
143
|
+
this.isLoading = false;
|
|
144
|
+
this.checksheetForm.patchValue(result?.item);
|
|
145
|
+
this.checksheet = result?.item;
|
|
146
|
+
},
|
|
147
|
+
error: () => {
|
|
148
|
+
this.isLoading = false;
|
|
149
|
+
}
|
|
150
|
+
});
|
|
151
|
+
}
|
|
152
|
+
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: ChecksheetFormComponent, deps: [{ token: i1.FormValidatorService }, { token: i2.UntypedFormBuilder }, { token: i3.NgxSpinnerService }, { token: i1.AlertService }, { token: i4.Location }, { token: i1.ErrorHandlerService }, { token: i1.DataManager }, { token: i5.MatDialog }, { token: i6.ActivatedRoute }, { token: i7.ChecksheetFormatService }], target: i0.ɵɵFactoryTarget.Component });
|
|
153
|
+
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.13", type: ChecksheetFormComponent, selector: "app-checksheet-form", inputs: { disableInput: "disableInput" }, ngImport: i0, template: "<div fxLayout=\"column\" fxLayoutGap=\"0.5rem\">\n <h2>Checksheet Form</h2>\n\n <div\n class=\"d-flex justify-content-start align-items-start gap-3\"\n *ngIf=\"!isLoading\"\n >\n <div style=\"width: calc(70% - 1rem)\" *ngIf=\"checksheet\">\n <app-checksheet-question-list\n class=\"w-100\"\n [(checksheet)]=\"checksheet\"\n [disableInput]=\"disableInput\"\n >\n </app-checksheet-question-list>\n </div>\n <mat-card style=\"width: calc(30% - 1rem)\">\n <mat-card-content>\n <h3>Checksheet Info</h3>\n <form\n [formGroup]=\"checksheetForm\"\n (submit)=\"submit()\"\n fxLayout=\"column\"\n fxLayoutGap=\"0.25rem\"\n >\n <mat-form-field>\n <input\n matInput\n formControlName=\"title\"\n placeholder=\"Title\"\n autocomplete=\"off\"\n required\n />\n <mat-error *ngIf=\"isFieldValid('title')\">\n {{ getErrorMessage('title') }}\n </mat-error>\n </mat-form-field>\n\n <div\n class=\"my-2\"\n fxLayout=\"row\"\n fxLayoutGap=\"15px\"\n fxLayoutAlign=\"end\"\n *ngIf=\"!disableInput\"\n >\n <button\n [disabled]=\"isSaving\"\n mat-flat-button\n type=\"button\"\n (click)=\"location.back()\"\n >\n Cancel\n </button>\n <button\n [disabled]=\"isSaving\"\n mat-raised-button\n type=\"submit\"\n color=\"primary\"\n >\n Save\n </button>\n\n <button\n mat-raised-button\n [disabled]=\"isSaving\"\n color=\"accent\"\n *ngIf=\"updateMode\"\n type=\"button\"\n (click)=\"publishChecksheet()\"\n >\n Publish\n </button>\n </div>\n </form>\n </mat-card-content>\n </mat-card>\n </div>\n\n <mat-progress-bar mode=\"indeterminate\" *ngIf=\"isLoading\"></mat-progress-bar>\n</div>\n", styles: [""], dependencies: [{ kind: "directive", type: i4.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i8.DefaultLayoutDirective, selector: " [fxLayout], [fxLayout.xs], [fxLayout.sm], [fxLayout.md], [fxLayout.lg], [fxLayout.xl], [fxLayout.lt-sm], [fxLayout.lt-md], [fxLayout.lt-lg], [fxLayout.lt-xl], [fxLayout.gt-xs], [fxLayout.gt-sm], [fxLayout.gt-md], [fxLayout.gt-lg]", inputs: ["fxLayout", "fxLayout.xs", "fxLayout.sm", "fxLayout.md", "fxLayout.lg", "fxLayout.xl", "fxLayout.lt-sm", "fxLayout.lt-md", "fxLayout.lt-lg", "fxLayout.lt-xl", "fxLayout.gt-xs", "fxLayout.gt-sm", "fxLayout.gt-md", "fxLayout.gt-lg"] }, { kind: "directive", type: i8.DefaultLayoutGapDirective, selector: " [fxLayoutGap], [fxLayoutGap.xs], [fxLayoutGap.sm], [fxLayoutGap.md], [fxLayoutGap.lg], [fxLayoutGap.xl], [fxLayoutGap.lt-sm], [fxLayoutGap.lt-md], [fxLayoutGap.lt-lg], [fxLayoutGap.lt-xl], [fxLayoutGap.gt-xs], [fxLayoutGap.gt-sm], [fxLayoutGap.gt-md], [fxLayoutGap.gt-lg]", inputs: ["fxLayoutGap", "fxLayoutGap.xs", "fxLayoutGap.sm", "fxLayoutGap.md", "fxLayoutGap.lg", "fxLayoutGap.xl", "fxLayoutGap.lt-sm", "fxLayoutGap.lt-md", "fxLayoutGap.lt-lg", "fxLayoutGap.lt-xl", "fxLayoutGap.gt-xs", "fxLayoutGap.gt-sm", "fxLayoutGap.gt-md", "fxLayoutGap.gt-lg"] }, { kind: "directive", type: i8.DefaultLayoutAlignDirective, selector: " [fxLayoutAlign], [fxLayoutAlign.xs], [fxLayoutAlign.sm], [fxLayoutAlign.md], [fxLayoutAlign.lg], [fxLayoutAlign.xl], [fxLayoutAlign.lt-sm], [fxLayoutAlign.lt-md], [fxLayoutAlign.lt-lg], [fxLayoutAlign.lt-xl], [fxLayoutAlign.gt-xs], [fxLayoutAlign.gt-sm], [fxLayoutAlign.gt-md], [fxLayoutAlign.gt-lg]", inputs: ["fxLayoutAlign", "fxLayoutAlign.xs", "fxLayoutAlign.sm", "fxLayoutAlign.md", "fxLayoutAlign.lg", "fxLayoutAlign.xl", "fxLayoutAlign.lt-sm", "fxLayoutAlign.lt-md", "fxLayoutAlign.lt-lg", "fxLayoutAlign.lt-xl", "fxLayoutAlign.gt-xs", "fxLayoutAlign.gt-sm", "fxLayoutAlign.gt-md", "fxLayoutAlign.gt-lg"] }, { kind: "component", type: i9.MatButton, selector: " button[mat-button], button[mat-raised-button], button[mat-flat-button], button[mat-stroked-button] ", exportAs: ["matButton"] }, { kind: "component", type: i10.MatCard, selector: "mat-card", inputs: ["appearance"], exportAs: ["matCard"] }, { kind: "directive", type: i10.MatCardContent, selector: "mat-card-content" }, { kind: "component", type: i11.MatFormField, selector: "mat-form-field", inputs: ["hideRequiredMarker", "color", "floatLabel", "appearance", "subscriptSizing", "hintLabel"], exportAs: ["matFormField"] }, { kind: "directive", type: i11.MatError, selector: "mat-error, [matError]", inputs: ["id"] }, { kind: "directive", type: i12.MatInput, selector: "input[matInput], textarea[matInput], select[matNativeControl], input[matNativeControl], textarea[matNativeControl]", inputs: ["disabled", "id", "placeholder", "name", "required", "type", "errorStateMatcher", "aria-describedby", "value", "readonly"], exportAs: ["matInput"] }, { kind: "component", type: i13.MatProgressBar, selector: "mat-progress-bar", inputs: ["color", "value", "bufferValue", "mode"], outputs: ["animationEnd"], exportAs: ["matProgressBar"] }, { kind: "directive", type: i2.ɵNgNoValidate, selector: "form:not([ngNoForm]):not([ngNativeValidate])" }, { kind: "directive", type: i2.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: i2.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i2.NgControlStatusGroup, selector: "[formGroupName],[formArrayName],[ngModelGroup],[formGroup],form:not([ngNoForm]),[ngForm]" }, { kind: "directive", type: i2.RequiredValidator, selector: ":not([type=checkbox])[required][formControlName],:not([type=checkbox])[required][formControl],:not([type=checkbox])[required][ngModel]", inputs: ["required"] }, { kind: "directive", type: i2.FormGroupDirective, selector: "[formGroup]", inputs: ["formGroup"], outputs: ["ngSubmit"], exportAs: ["ngForm"] }, { kind: "directive", type: i2.FormControlName, selector: "[formControlName]", inputs: ["formControlName", "disabled", "ngModel"], outputs: ["ngModelChange"] }, { kind: "component", type: i14.ChecksheetQuestionListComponent, selector: "app-checksheet-question-list", inputs: ["checksheet", "submission", "disableInput"], outputs: ["checksheetChange"] }] });
|
|
154
|
+
}
|
|
155
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: ChecksheetFormComponent, decorators: [{
|
|
156
|
+
type: Component,
|
|
157
|
+
args: [{ selector: 'app-checksheet-form', template: "<div fxLayout=\"column\" fxLayoutGap=\"0.5rem\">\n <h2>Checksheet Form</h2>\n\n <div\n class=\"d-flex justify-content-start align-items-start gap-3\"\n *ngIf=\"!isLoading\"\n >\n <div style=\"width: calc(70% - 1rem)\" *ngIf=\"checksheet\">\n <app-checksheet-question-list\n class=\"w-100\"\n [(checksheet)]=\"checksheet\"\n [disableInput]=\"disableInput\"\n >\n </app-checksheet-question-list>\n </div>\n <mat-card style=\"width: calc(30% - 1rem)\">\n <mat-card-content>\n <h3>Checksheet Info</h3>\n <form\n [formGroup]=\"checksheetForm\"\n (submit)=\"submit()\"\n fxLayout=\"column\"\n fxLayoutGap=\"0.25rem\"\n >\n <mat-form-field>\n <input\n matInput\n formControlName=\"title\"\n placeholder=\"Title\"\n autocomplete=\"off\"\n required\n />\n <mat-error *ngIf=\"isFieldValid('title')\">\n {{ getErrorMessage('title') }}\n </mat-error>\n </mat-form-field>\n\n <div\n class=\"my-2\"\n fxLayout=\"row\"\n fxLayoutGap=\"15px\"\n fxLayoutAlign=\"end\"\n *ngIf=\"!disableInput\"\n >\n <button\n [disabled]=\"isSaving\"\n mat-flat-button\n type=\"button\"\n (click)=\"location.back()\"\n >\n Cancel\n </button>\n <button\n [disabled]=\"isSaving\"\n mat-raised-button\n type=\"submit\"\n color=\"primary\"\n >\n Save\n </button>\n\n <button\n mat-raised-button\n [disabled]=\"isSaving\"\n color=\"accent\"\n *ngIf=\"updateMode\"\n type=\"button\"\n (click)=\"publishChecksheet()\"\n >\n Publish\n </button>\n </div>\n </form>\n </mat-card-content>\n </mat-card>\n </div>\n\n <mat-progress-bar mode=\"indeterminate\" *ngIf=\"isLoading\"></mat-progress-bar>\n</div>\n" }]
|
|
158
|
+
}], ctorParameters: () => [{ type: i1.FormValidatorService }, { type: i2.UntypedFormBuilder }, { type: i3.NgxSpinnerService }, { type: i1.AlertService }, { type: i4.Location }, { type: i1.ErrorHandlerService }, { type: i1.DataManager }, { type: i5.MatDialog }, { type: i6.ActivatedRoute }, { type: i7.ChecksheetFormatService }], propDecorators: { disableInput: [{
|
|
159
|
+
type: Input
|
|
160
|
+
}] } });
|
|
161
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"checksheet-form.component.js","sourceRoot":"","sources":["../../../../../../projects/ngx-techlify-checksheet/src/lib/checksheet/checksheet-form/checksheet-form.component.ts","../../../../../../projects/ngx-techlify-checksheet/src/lib/checksheet/checksheet-form/checksheet-form.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, OnInit, Input } from '@angular/core';\nimport {\n  UntypedFormGroup,\n  UntypedFormBuilder,\n  Validators\n} from '@angular/forms';\nimport { FormValidatorService } from 'ngx-techlify-core';\nimport { NgxSpinnerService } from 'ngx-spinner';\nimport {\n  AlertService,\n  ActionPopupComponent,\n  ActionPopup,\n  ErrorHandlerService,\n  DataManager\n} from 'ngx-techlify-core';\nimport { ActivatedRoute } from '@angular/router';\nimport { Location } from '@angular/common';\nimport { MatDialog } from '@angular/material/dialog';\nimport { ChecksheetFormatService } from '../checksheet-format.service';\nimport { Observable } from 'rxjs';\n\nconst errorMessages: any = {\n  title: {\n    required: 'The title is required.'\n  }\n};\n\n@Component({\n  selector: 'app-checksheet-form',\n  templateUrl: './checksheet-form.component.html',\n  styleUrls: ['./checksheet-form.component.scss']\n})\nexport class ChecksheetFormComponent implements OnInit {\n  checksheetForm!: UntypedFormGroup;\n  updateMode!: boolean;\n  checksheet: any;\n  isSaving: boolean = false;\n  id!: number;\n\n  @Input() disableInput!: boolean;\n  isLoading: boolean = false;\n\n  constructor(\n    private formValidatorService: FormValidatorService,\n    private fb: UntypedFormBuilder,\n    private spinnerService: NgxSpinnerService,\n    private alertService: AlertService,\n    public location: Location,\n    private errorHandler: ErrorHandlerService,\n    private dataManager: DataManager,\n    private dialog: MatDialog,\n    private route: ActivatedRoute,\n    private checksheetFormatService: ChecksheetFormatService\n  ) {\n    this.id = parseInt(this.route.snapshot.params?.['checksheetId']);\n    this.createForm();\n  }\n\n  ngOnInit(): void {\n    if (this.disableInput) {\n      this.checksheetForm.disable();\n    }\n    if (this.id) {\n      this.updateMode = true;\n      this.loadChecksheetFormat();\n    }\n  }\n\n  /**\n   * Create a check-sheet form.\n   * @private\n   */\n  private createForm() {\n    this.checksheetForm = this.fb.group({\n      id: [''],\n      title: ['', Validators.required]\n    });\n  }\n\n  /**Method to evaluate form fields*/\n  isFieldValid(field: string) {\n    return this.formValidatorService.isFieldValid(field, this.checksheetForm);\n  }\n\n  /**Method to find error in form fields*/\n  getErrorMessage(field: string) {\n    return this.formValidatorService.getErrorMessage(\n      field,\n      this.checksheetForm,\n      errorMessages\n    );\n  }\n\n  submit() {\n    this.checksheetForm.markAllAsTouched();\n    if (this.checksheetForm.invalid) {\n      this.alertService.addAlert('Please check the form for errors.', 'error');\n      return;\n    }\n\n    const model = { ...this.checksheetForm.value };\n    this.isSaving = true;\n    let request: Observable<any> = this.updateMode\n      ? this.checksheetFormatService.update(model)\n      : this.checksheetFormatService.store(model);\n\n    request.subscribe({\n      next: (result: any) => {\n        this.isSaving = false;\n        if (!this.updateMode) {\n          this.checksheet = result.item;\n          this.checksheetForm.patchValue({ ...this.checksheet });\n        }\n        this.updateMode = true;\n        this.alertService.addAlert('Checksheet saved successfully', 'success');\n      },\n      error: (error: any) => {\n        this.isSaving = false;\n      }\n    });\n  }\n\n  publishChecksheet() {\n    const dialogRef = this.dialog.open(ActionPopupComponent, {\n      width: '400px',\n      data: <ActionPopup>{\n        title: 'Publish Checksheet',\n        message: `Review the checksheet completely before publishing, you cannot alter once it is published. Are you sure to publish the Checksheet?`\n      },\n      autoFocus: false\n    });\n\n    dialogRef.afterClosed().subscribe(async (result) => {\n      if (result) {\n        //Action confirmed\n        try {\n          this.spinnerService.show();\n          const model = this.checksheetForm.value;\n          model.is_published = true;\n          const result = await this.dataManager.PUT(\n            `api/checksheet-formats/${model.id}`,\n            model\n          );\n          this.alertService.addAlert(\n            'Checksheet successfully published',\n            'success'\n          );\n          this.location.back();\n        } catch (error) {\n          this.errorHandler.handleError(\n            error,\n            'Unable to publish checksheet, try later'\n          );\n        } finally {\n          this.spinnerService.hide();\n        }\n      }\n    });\n  }\n\n  private loadChecksheetFormat() {\n    this.isLoading = true;\n    const params: any = { with: 'questions.answers,questions.type' };\n    this.checksheetFormatService.show(this.id, params).subscribe({\n      next: (result: any) => {\n        this.isLoading = false;\n        this.checksheetForm.patchValue(result?.item);\n        this.checksheet = result?.item;\n      },\n      error: () => {\n        this.isLoading = false;\n      }\n    });\n  }\n}\n","<div fxLayout=\"column\" fxLayoutGap=\"0.5rem\">\n  <h2>Checksheet Form</h2>\n\n  <div\n    class=\"d-flex justify-content-start align-items-start gap-3\"\n    *ngIf=\"!isLoading\"\n  >\n    <div style=\"width: calc(70% - 1rem)\" *ngIf=\"checksheet\">\n      <app-checksheet-question-list\n        class=\"w-100\"\n        [(checksheet)]=\"checksheet\"\n        [disableInput]=\"disableInput\"\n      >\n      </app-checksheet-question-list>\n    </div>\n    <mat-card style=\"width: calc(30% - 1rem)\">\n      <mat-card-content>\n        <h3>Checksheet Info</h3>\n        <form\n          [formGroup]=\"checksheetForm\"\n          (submit)=\"submit()\"\n          fxLayout=\"column\"\n          fxLayoutGap=\"0.25rem\"\n        >\n          <mat-form-field>\n            <input\n              matInput\n              formControlName=\"title\"\n              placeholder=\"Title\"\n              autocomplete=\"off\"\n              required\n            />\n            <mat-error *ngIf=\"isFieldValid('title')\">\n              {{ getErrorMessage('title') }}\n            </mat-error>\n          </mat-form-field>\n\n          <div\n            class=\"my-2\"\n            fxLayout=\"row\"\n            fxLayoutGap=\"15px\"\n            fxLayoutAlign=\"end\"\n            *ngIf=\"!disableInput\"\n          >\n            <button\n              [disabled]=\"isSaving\"\n              mat-flat-button\n              type=\"button\"\n              (click)=\"location.back()\"\n            >\n              Cancel\n            </button>\n            <button\n              [disabled]=\"isSaving\"\n              mat-raised-button\n              type=\"submit\"\n              color=\"primary\"\n            >\n              Save\n            </button>\n\n            <button\n              mat-raised-button\n              [disabled]=\"isSaving\"\n              color=\"accent\"\n              *ngIf=\"updateMode\"\n              type=\"button\"\n              (click)=\"publishChecksheet()\"\n            >\n              Publish\n            </button>\n          </div>\n        </form>\n      </mat-card-content>\n    </mat-card>\n  </div>\n\n  <mat-progress-bar mode=\"indeterminate\" *ngIf=\"isLoading\"></mat-progress-bar>\n</div>\n"]}
|
|
@@ -0,0 +1,58 @@
|
|
|
1
|
+
import { Component, EventEmitter, Input, Output } from '@angular/core';
|
|
2
|
+
import * as i0 from "@angular/core";
|
|
3
|
+
import * as i1 from "@angular/material/dialog";
|
|
4
|
+
import * as i2 from "ngx-techlify-core";
|
|
5
|
+
import * as i3 from "@angular/router";
|
|
6
|
+
import * as i4 from "@angular/common";
|
|
7
|
+
import * as i5 from "@angular/material/icon";
|
|
8
|
+
import * as i6 from "@angular/material/tooltip";
|
|
9
|
+
import * as i7 from "../checksheet-submission-form/checksheet-submission-form.component";
|
|
10
|
+
export class ChecksheetFormButtonComponent {
|
|
11
|
+
matDialog;
|
|
12
|
+
alertService;
|
|
13
|
+
router;
|
|
14
|
+
submittableType = 'fixed-asset';
|
|
15
|
+
submittableId;
|
|
16
|
+
saved = new EventEmitter();
|
|
17
|
+
constructor(matDialog, alertService, router) {
|
|
18
|
+
this.matDialog = matDialog;
|
|
19
|
+
this.alertService = alertService;
|
|
20
|
+
this.router = router;
|
|
21
|
+
}
|
|
22
|
+
/**
|
|
23
|
+
* Open Checksheet form.
|
|
24
|
+
*
|
|
25
|
+
* @param templateRef
|
|
26
|
+
*/
|
|
27
|
+
openForm(templateRef) {
|
|
28
|
+
this.matDialog.open(templateRef, { width: '500px' });
|
|
29
|
+
}
|
|
30
|
+
/**
|
|
31
|
+
* Handle Checksheet save event.
|
|
32
|
+
*
|
|
33
|
+
* @param checksheetSubmission
|
|
34
|
+
*/
|
|
35
|
+
onSaved(checksheetSubmission) {
|
|
36
|
+
this.saved.emit(checksheetSubmission);
|
|
37
|
+
this.matDialog.closeAll();
|
|
38
|
+
this.alertService.addAlert('The Checksheet is saved successfully!', 'success');
|
|
39
|
+
this.router.navigate([
|
|
40
|
+
'fixed-assets/checksheets/checksheets',
|
|
41
|
+
checksheetSubmission?.id,
|
|
42
|
+
'view'
|
|
43
|
+
]);
|
|
44
|
+
}
|
|
45
|
+
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: ChecksheetFormButtonComponent, deps: [{ token: i1.MatDialog }, { token: i2.AlertService }, { token: i3.Router }], target: i0.ɵɵFactoryTarget.Component });
|
|
46
|
+
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.13", type: ChecksheetFormButtonComponent, selector: "app-checksheet-form-button", inputs: { submittableType: "submittableType", submittableId: "submittableId" }, outputs: { saved: "saved" }, ngImport: i0, template: "<span\n *ngIf=\"submittableId\"\n class=\"material-symbols-outlined text-secondary\"\n matTooltip=\"Add Checksheet\"\n (click)=\"openForm(formTemplate)\"\n>\n assignment_turned_in\n</span>\n<mat-icon\n *ngIf=\"!submittableId\"\n class=\"cursor-pointer text-secondary\"\n (click)=\"openForm(formTemplate)\"\n>\n add\n</mat-icon>\n\n<ng-template #formTemplate>\n <app-checksheet-submission-form\n mat-dialog-content\n (cancelled)=\"matDialog.closeAll()\"\n (saved)=\"onSaved($event)\"\n [submittableType]=\"submittableType\"\n [submittableId]=\"submittableId\"\n ></app-checksheet-submission-form>\n</ng-template>\n", styles: [""], dependencies: [{ kind: "directive", type: i4.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i1.MatDialogContent, selector: "[mat-dialog-content], mat-dialog-content, [matDialogContent]" }, { kind: "component", type: i5.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }, { kind: "directive", type: i6.MatTooltip, selector: "[matTooltip]", inputs: ["matTooltipPosition", "matTooltipPositionAtOrigin", "matTooltipDisabled", "matTooltipShowDelay", "matTooltipHideDelay", "matTooltipTouchGestures", "matTooltip", "matTooltipClass"], exportAs: ["matTooltip"] }, { kind: "component", type: i7.ChecksheetSubmissionFormComponent, selector: "app-checksheet-submission-form", inputs: ["submittableType", "submittableId", "checksheetSubmission"], outputs: ["cancelled", "saved"] }] });
|
|
47
|
+
}
|
|
48
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: ChecksheetFormButtonComponent, decorators: [{
|
|
49
|
+
type: Component,
|
|
50
|
+
args: [{ selector: 'app-checksheet-form-button', template: "<span\n *ngIf=\"submittableId\"\n class=\"material-symbols-outlined text-secondary\"\n matTooltip=\"Add Checksheet\"\n (click)=\"openForm(formTemplate)\"\n>\n assignment_turned_in\n</span>\n<mat-icon\n *ngIf=\"!submittableId\"\n class=\"cursor-pointer text-secondary\"\n (click)=\"openForm(formTemplate)\"\n>\n add\n</mat-icon>\n\n<ng-template #formTemplate>\n <app-checksheet-submission-form\n mat-dialog-content\n (cancelled)=\"matDialog.closeAll()\"\n (saved)=\"onSaved($event)\"\n [submittableType]=\"submittableType\"\n [submittableId]=\"submittableId\"\n ></app-checksheet-submission-form>\n</ng-template>\n" }]
|
|
51
|
+
}], ctorParameters: () => [{ type: i1.MatDialog }, { type: i2.AlertService }, { type: i3.Router }], propDecorators: { submittableType: [{
|
|
52
|
+
type: Input
|
|
53
|
+
}], submittableId: [{
|
|
54
|
+
type: Input
|
|
55
|
+
}], saved: [{
|
|
56
|
+
type: Output
|
|
57
|
+
}] } });
|
|
58
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY2hlY2tzaGVldC1mb3JtLWJ1dHRvbi5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9uZ3gtdGVjaGxpZnktY2hlY2tzaGVldC9zcmMvbGliL2NoZWNrc2hlZXQvY2hlY2tzaGVldC1mb3JtLWJ1dHRvbi9jaGVja3NoZWV0LWZvcm0tYnV0dG9uLmNvbXBvbmVudC50cyIsIi4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL25neC10ZWNobGlmeS1jaGVja3NoZWV0L3NyYy9saWIvY2hlY2tzaGVldC9jaGVja3NoZWV0LWZvcm0tYnV0dG9uL2NoZWNrc2hlZXQtZm9ybS1idXR0b24uY29tcG9uZW50Lmh0bWwiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUNMLFNBQVMsRUFDVCxZQUFZLEVBQ1osS0FBSyxFQUNMLE1BQU0sRUFFUCxNQUFNLGVBQWUsQ0FBQzs7Ozs7Ozs7O0FBV3ZCLE1BQU0sT0FBTyw2QkFBNkI7SUFNL0I7SUFDQztJQUNBO0lBUEQsZUFBZSxHQUE4QixhQUFhLENBQUM7SUFDM0QsYUFBYSxDQUFVO0lBQ3RCLEtBQUssR0FBc0IsSUFBSSxZQUFZLEVBQU8sQ0FBQztJQUU3RCxZQUNTLFNBQW9CLEVBQ25CLFlBQTBCLEVBQzFCLE1BQWM7UUFGZixjQUFTLEdBQVQsU0FBUyxDQUFXO1FBQ25CLGlCQUFZLEdBQVosWUFBWSxDQUFjO1FBQzFCLFdBQU0sR0FBTixNQUFNLENBQVE7SUFDckIsQ0FBQztJQUVKOzs7O09BSUc7SUFDSCxRQUFRLENBQUMsV0FBNkI7UUFDcEMsSUFBSSxDQUFDLFNBQVMsQ0FBQyxJQUFJLENBQUMsV0FBVyxFQUFFLEVBQUUsS0FBSyxFQUFFLE9BQU8sRUFBRSxDQUFDLENBQUM7SUFDdkQsQ0FBQztJQUVEOzs7O09BSUc7SUFDSCxPQUFPLENBQUMsb0JBQXlCO1FBQy9CLElBQUksQ0FBQyxLQUFLLENBQUMsSUFBSSxDQUFDLG9CQUFvQixDQUFDLENBQUM7UUFDdEMsSUFBSSxDQUFDLFNBQVMsQ0FBQyxRQUFRLEVBQUUsQ0FBQztRQUMxQixJQUFJLENBQUMsWUFBWSxDQUFDLFFBQVEsQ0FDeEIsdUNBQXVDLEVBQ3ZDLFNBQVMsQ0FDVixDQUFDO1FBRUYsSUFBSSxDQUFDLE1BQU0sQ0FBQyxRQUFRLENBQUM7WUFDbkIsc0NBQXNDO1lBQ3RDLG9CQUFvQixFQUFFLEVBQUU7WUFDeEIsTUFBTTtTQUNQLENBQUMsQ0FBQztJQUNMLENBQUM7d0dBdENVLDZCQUE2Qjs0RkFBN0IsNkJBQTZCLCtLQ2pCMUMsaW9CQXlCQTs7NEZEUmEsNkJBQTZCO2tCQUx6QyxTQUFTOytCQUNFLDRCQUE0Qjs4SEFLN0IsZUFBZTtzQkFBdkIsS0FBSztnQkFDRyxhQUFhO3NCQUFyQixLQUFLO2dCQUNJLEtBQUs7c0JBQWQsTUFBTSIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7XG4gIENvbXBvbmVudCxcbiAgRXZlbnRFbWl0dGVyLFxuICBJbnB1dCxcbiAgT3V0cHV0LFxuICBUZW1wbGF0ZVJlZlxufSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IE1hdERpYWxvZyB9IGZyb20gJ0Bhbmd1bGFyL21hdGVyaWFsL2RpYWxvZyc7XG5pbXBvcnQgeyBBbGVydFNlcnZpY2UgfSBmcm9tICduZ3gtdGVjaGxpZnktY29yZSc7XG5pbXBvcnQgeyBSb3V0ZXIgfSBmcm9tICdAYW5ndWxhci9yb3V0ZXInO1xuaW1wb3J0IHsgQ2hlY2tzaGVldFN1Ym1pdHRhYmxlVHlwZSB9IGZyb20gJy4uL2NoZWNrc2hlZXQtc3VibWl0dGFibGUudHlwZSc7XG5cbkBDb21wb25lbnQoe1xuICBzZWxlY3RvcjogJ2FwcC1jaGVja3NoZWV0LWZvcm0tYnV0dG9uJyxcbiAgdGVtcGxhdGVVcmw6ICcuL2NoZWNrc2hlZXQtZm9ybS1idXR0b24uY29tcG9uZW50Lmh0bWwnLFxuICBzdHlsZVVybHM6IFsnLi9jaGVja3NoZWV0LWZvcm0tYnV0dG9uLmNvbXBvbmVudC5zY3NzJ11cbn0pXG5leHBvcnQgY2xhc3MgQ2hlY2tzaGVldEZvcm1CdXR0b25Db21wb25lbnQge1xuICBASW5wdXQoKSBzdWJtaXR0YWJsZVR5cGU6IENoZWNrc2hlZXRTdWJtaXR0YWJsZVR5cGUgPSAnZml4ZWQtYXNzZXQnO1xuICBASW5wdXQoKSBzdWJtaXR0YWJsZUlkITogbnVtYmVyO1xuICBAT3V0cHV0KCkgc2F2ZWQ6IEV2ZW50RW1pdHRlcjxhbnk+ID0gbmV3IEV2ZW50RW1pdHRlcjxhbnk+KCk7XG5cbiAgY29uc3RydWN0b3IoXG4gICAgcHVibGljIG1hdERpYWxvZzogTWF0RGlhbG9nLFxuICAgIHByaXZhdGUgYWxlcnRTZXJ2aWNlOiBBbGVydFNlcnZpY2UsXG4gICAgcHJpdmF0ZSByb3V0ZXI6IFJvdXRlclxuICApIHt9XG5cbiAgLyoqXG4gICAqIE9wZW4gQ2hlY2tzaGVldCBmb3JtLlxuICAgKlxuICAgKiBAcGFyYW0gdGVtcGxhdGVSZWZcbiAgICovXG4gIG9wZW5Gb3JtKHRlbXBsYXRlUmVmOiBUZW1wbGF0ZVJlZjxhbnk+KSB7XG4gICAgdGhpcy5tYXREaWFsb2cub3Blbih0ZW1wbGF0ZVJlZiwgeyB3aWR0aDogJzUwMHB4JyB9KTtcbiAgfVxuXG4gIC8qKlxuICAgKiBIYW5kbGUgQ2hlY2tzaGVldCBzYXZlIGV2ZW50LlxuICAgKlxuICAgKiBAcGFyYW0gY2hlY2tzaGVldFN1Ym1pc3Npb25cbiAgICovXG4gIG9uU2F2ZWQoY2hlY2tzaGVldFN1Ym1pc3Npb246IGFueSkge1xuICAgIHRoaXMuc2F2ZWQuZW1pdChjaGVja3NoZWV0U3VibWlzc2lvbik7XG4gICAgdGhpcy5tYXREaWFsb2cuY2xvc2VBbGwoKTtcbiAgICB0aGlzLmFsZXJ0U2VydmljZS5hZGRBbGVydChcbiAgICAgICdUaGUgQ2hlY2tzaGVldCBpcyBzYXZlZCBzdWNjZXNzZnVsbHkhJyxcbiAgICAgICdzdWNjZXNzJ1xuICAgICk7XG5cbiAgICB0aGlzLnJvdXRlci5uYXZpZ2F0ZShbXG4gICAgICAnZml4ZWQtYXNzZXRzL2NoZWNrc2hlZXRzL2NoZWNrc2hlZXRzJyxcbiAgICAgIGNoZWNrc2hlZXRTdWJtaXNzaW9uPy5pZCxcbiAgICAgICd2aWV3J1xuICAgIF0pO1xuICB9XG59XG4iLCI8c3BhblxuICAqbmdJZj1cInN1Ym1pdHRhYmxlSWRcIlxuICBjbGFzcz1cIm1hdGVyaWFsLXN5bWJvbHMtb3V0bGluZWQgdGV4dC1zZWNvbmRhcnlcIlxuICBtYXRUb29sdGlwPVwiQWRkIENoZWNrc2hlZXRcIlxuICAoY2xpY2spPVwib3BlbkZvcm0oZm9ybVRlbXBsYXRlKVwiXG4+XG4gIGFzc2lnbm1lbnRfdHVybmVkX2luXG48L3NwYW4+XG48bWF0LWljb25cbiAgKm5nSWY9XCIhc3VibWl0dGFibGVJZFwiXG4gIGNsYXNzPVwiY3Vyc29yLXBvaW50ZXIgdGV4dC1zZWNvbmRhcnlcIlxuICAoY2xpY2spPVwib3BlbkZvcm0oZm9ybVRlbXBsYXRlKVwiXG4+XG4gIGFkZFxuPC9tYXQtaWNvbj5cblxuPG5nLXRlbXBsYXRlICNmb3JtVGVtcGxhdGU+XG4gIDxhcHAtY2hlY2tzaGVldC1zdWJtaXNzaW9uLWZvcm1cbiAgICBtYXQtZGlhbG9nLWNvbnRlbnRcbiAgICAoY2FuY2VsbGVkKT1cIm1hdERpYWxvZy5jbG9zZUFsbCgpXCJcbiAgICAoc2F2ZWQpPVwib25TYXZlZCgkZXZlbnQpXCJcbiAgICBbc3VibWl0dGFibGVUeXBlXT1cInN1Ym1pdHRhYmxlVHlwZVwiXG4gICAgW3N1Ym1pdHRhYmxlSWRdPVwic3VibWl0dGFibGVJZFwiXG4gID48L2FwcC1jaGVja3NoZWV0LXN1Ym1pc3Npb24tZm9ybT5cbjwvbmctdGVtcGxhdGU+XG4iXX0=
|