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/esm2022/lib/checksheet/checksheet-question-list/checksheet-question-list.component.mjs
ADDED
|
@@ -0,0 +1,161 @@
|
|
|
1
|
+
import { Component, EventEmitter, Input, Output } from '@angular/core';
|
|
2
|
+
import { ActionPopupComponent } from 'ngx-techlify-core';
|
|
3
|
+
import { ChecksheetQuestionFormComponent } from '../checksheet-question-form/checksheet-question-form.component';
|
|
4
|
+
import * as i0 from "@angular/core";
|
|
5
|
+
import * as i1 from "ngx-spinner";
|
|
6
|
+
import * as i2 from "ngx-techlify-core";
|
|
7
|
+
import * as i3 from "@angular/material/dialog";
|
|
8
|
+
import * as i4 from "@angular/common";
|
|
9
|
+
import * as i5 from "@angular/flex-layout/flex";
|
|
10
|
+
import * as i6 from "@angular/material/button";
|
|
11
|
+
import * as i7 from "@angular/material/card";
|
|
12
|
+
import * as i8 from "@angular/material/icon";
|
|
13
|
+
import * as i9 from "ngx-infinite-scroll";
|
|
14
|
+
import * as i10 from "../checksheet-question/checksheet-question.component";
|
|
15
|
+
export class ChecksheetQuestionListComponent {
|
|
16
|
+
spinnerService;
|
|
17
|
+
alertService;
|
|
18
|
+
dialog;
|
|
19
|
+
dataManager;
|
|
20
|
+
checksheet = {};
|
|
21
|
+
checksheetChange = new EventEmitter();
|
|
22
|
+
submission;
|
|
23
|
+
disableInput;
|
|
24
|
+
questions = [];
|
|
25
|
+
constructor(spinnerService, alertService, dialog, dataManager) {
|
|
26
|
+
this.spinnerService = spinnerService;
|
|
27
|
+
this.alertService = alertService;
|
|
28
|
+
this.dialog = dialog;
|
|
29
|
+
this.dataManager = dataManager;
|
|
30
|
+
}
|
|
31
|
+
ngOnInit() {
|
|
32
|
+
this.questions = this.checksheet?.questions || [];
|
|
33
|
+
}
|
|
34
|
+
onScroll() { }
|
|
35
|
+
editQuestion(question, index) {
|
|
36
|
+
const dialogRef = this.dialog.open(ChecksheetQuestionFormComponent, {
|
|
37
|
+
width: '800px',
|
|
38
|
+
data: {
|
|
39
|
+
update: true,
|
|
40
|
+
question: question
|
|
41
|
+
},
|
|
42
|
+
autoFocus: false
|
|
43
|
+
});
|
|
44
|
+
dialogRef.afterClosed().subscribe((result) => {
|
|
45
|
+
if (result) {
|
|
46
|
+
question = result;
|
|
47
|
+
this.questions[index] = question;
|
|
48
|
+
}
|
|
49
|
+
});
|
|
50
|
+
}
|
|
51
|
+
addQuestion() {
|
|
52
|
+
const dialogRef = this.dialog.open(ChecksheetQuestionFormComponent, {
|
|
53
|
+
width: '800px',
|
|
54
|
+
data: {
|
|
55
|
+
question: {
|
|
56
|
+
format_id: this.checksheet.id
|
|
57
|
+
}
|
|
58
|
+
},
|
|
59
|
+
autoFocus: false
|
|
60
|
+
});
|
|
61
|
+
dialogRef.afterClosed().subscribe((result) => {
|
|
62
|
+
if (result) {
|
|
63
|
+
this.questions.push(result);
|
|
64
|
+
}
|
|
65
|
+
});
|
|
66
|
+
}
|
|
67
|
+
async moveQuestionUp(index) {
|
|
68
|
+
if (index < this.questions.length) {
|
|
69
|
+
this.spinnerService.show();
|
|
70
|
+
try {
|
|
71
|
+
if (index <= 0) {
|
|
72
|
+
return;
|
|
73
|
+
}
|
|
74
|
+
const q1 = this.questions[index];
|
|
75
|
+
const q2 = this.questions[index - 1];
|
|
76
|
+
await this.dataManager.PUT(`api/checksheet-format-questions/${q1.id}`, {
|
|
77
|
+
...q1,
|
|
78
|
+
rank: index - 1
|
|
79
|
+
});
|
|
80
|
+
await this.dataManager.PUT(`api/checksheet-format-questions/${q2.id}`, {
|
|
81
|
+
...q2,
|
|
82
|
+
rank: index
|
|
83
|
+
});
|
|
84
|
+
this.questions[index] = q2;
|
|
85
|
+
this.questions[index - 1] = q1;
|
|
86
|
+
}
|
|
87
|
+
catch (error) {
|
|
88
|
+
this.alertService.addAlert('Unable to move question, try later', 'warn');
|
|
89
|
+
}
|
|
90
|
+
finally {
|
|
91
|
+
this.spinnerService.hide();
|
|
92
|
+
}
|
|
93
|
+
}
|
|
94
|
+
}
|
|
95
|
+
async moveQuestionDown(index) {
|
|
96
|
+
if (index < this.questions.length) {
|
|
97
|
+
this.spinnerService.show();
|
|
98
|
+
try {
|
|
99
|
+
const q1 = this.questions[index];
|
|
100
|
+
const q2 = this.questions[index + 1];
|
|
101
|
+
await this.dataManager.PUT(`api/checksheet-format-questions/${q1.id}`, {
|
|
102
|
+
...q1,
|
|
103
|
+
rank: index + 1
|
|
104
|
+
});
|
|
105
|
+
await this.dataManager.PUT(`api/checksheet-format-questions/${q2.id}`, {
|
|
106
|
+
...q2,
|
|
107
|
+
rank: index
|
|
108
|
+
});
|
|
109
|
+
this.questions[index] = q2;
|
|
110
|
+
this.questions[index + 1] = q1;
|
|
111
|
+
}
|
|
112
|
+
catch (error) {
|
|
113
|
+
this.alertService.addAlert('Unable to move question, try later', 'warn');
|
|
114
|
+
}
|
|
115
|
+
finally {
|
|
116
|
+
this.spinnerService.hide();
|
|
117
|
+
}
|
|
118
|
+
}
|
|
119
|
+
}
|
|
120
|
+
deleteQuestion(question) {
|
|
121
|
+
const dialogRef = this.dialog.open(ActionPopupComponent, {
|
|
122
|
+
width: '400px',
|
|
123
|
+
data: {
|
|
124
|
+
title: 'Delete Question',
|
|
125
|
+
message: `Are you sure to delete the question?`
|
|
126
|
+
},
|
|
127
|
+
autoFocus: false
|
|
128
|
+
});
|
|
129
|
+
dialogRef.afterClosed().subscribe(async (result) => {
|
|
130
|
+
if (result) {
|
|
131
|
+
//Action confirmed
|
|
132
|
+
try {
|
|
133
|
+
this.spinnerService.show();
|
|
134
|
+
await this.dataManager.DELETE(`api/checksheet-format-questions/${question.id}`);
|
|
135
|
+
this.questions = this.questions.filter((x) => x.id !== question.id);
|
|
136
|
+
}
|
|
137
|
+
catch (error) {
|
|
138
|
+
this.alertService.addAlert('Unable to delete question, try later', 'warn');
|
|
139
|
+
}
|
|
140
|
+
finally {
|
|
141
|
+
this.spinnerService.hide();
|
|
142
|
+
}
|
|
143
|
+
}
|
|
144
|
+
});
|
|
145
|
+
}
|
|
146
|
+
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: ChecksheetQuestionListComponent, deps: [{ token: i1.NgxSpinnerService }, { token: i2.AlertService }, { token: i3.MatDialog }, { token: i2.DataManager }], target: i0.ɵɵFactoryTarget.Component });
|
|
147
|
+
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.13", type: ChecksheetQuestionListComponent, selector: "app-checksheet-question-list", inputs: { checksheet: "checksheet", submission: "submission", disableInput: "disableInput" }, outputs: { checksheetChange: "checksheetChange" }, ngImport: i0, template: "<ng-container *ngIf=\"checksheet?.id\">\n <button\n *ngIf=\"!disableInput\"\n type=\"button\"\n mat-raised-button\n color=\"primary\"\n (click)=\"addQuestion()\"\n class=\"mb-2\"\n >\n Add Question\n </button>\n\n <div\n class=\"d-flex flex-column gap-3 mat-typography scroll-container\"\n infiniteScroll\n [infiniteScrollDistance]=\"1\"\n [infiniteScrollThrottle]=\"50\"\n (scrolled)=\"onScroll()\"\n [scrollWindow]=\"false\"\n >\n <mat-card\n class=\"d-flex flex-column gap-3\"\n *ngFor=\"let question of questions; let i = index\"\n >\n <div\n class=\"d-flex flex-row gap-3 justify-content-end\"\n *ngIf=\"!disableInput\"\n >\n <mat-icon class=\"cursor-pointer\" (click)=\"deleteQuestion(question)\">\n delete\n </mat-icon>\n <mat-icon class=\"cursor-pointer\" (click)=\"editQuestion(question, i)\">\n edit\n </mat-icon>\n <mat-icon\n class=\"cursor-pointer\"\n *ngIf=\"i > 0\"\n (click)=\"moveQuestionUp(i)\"\n >\n arrow_upward\n </mat-icon>\n <mat-icon\n class=\"cursor-pointer\"\n *ngIf=\"i < questions.length - 1\"\n (click)=\"moveQuestionDown(i)\"\n >\n arrow_downward\n </mat-icon>\n </div>\n\n <div>\n <app-checksheet-question\n [questionInfo]=\"question\"\n [index]=\"i\"\n ></app-checksheet-question>\n </div>\n </mat-card>\n </div>\n</ng-container>\n\n<ng-container *ngIf=\"submission?.id\">\n <div fxLayout=\"column\" fxLayoutGap=\"1rem\" class=\"mat-typography\">\n <mat-card\n fxLayout=\"column\"\n fxLayoutGap=\"0.5rem\"\n class=\"w-100\"\n *ngFor=\"let question of submission.format.questions; let i = index\"\n >\n <app-checksheet-question\n [questionInfo]=\"question\"\n [index]=\"i\"\n [submissionView]=\"true\"\n [submissionId]=\"submission.id\"\n [disableInput]=\"disableInput\"\n >\n </app-checksheet-question>\n </mat-card>\n </div>\n</ng-container>\n", styles: [""], dependencies: [{ kind: "directive", type: i4.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i4.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i5.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: i5.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: "component", type: i6.MatButton, selector: " button[mat-button], button[mat-raised-button], button[mat-flat-button], button[mat-stroked-button] ", exportAs: ["matButton"] }, { kind: "component", type: i7.MatCard, selector: "mat-card", inputs: ["appearance"], exportAs: ["matCard"] }, { kind: "component", type: i8.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }, { kind: "directive", type: i9.InfiniteScrollDirective, selector: "[infiniteScroll], [infinite-scroll], [data-infinite-scroll]", inputs: ["infiniteScrollDistance", "infiniteScrollUpDistance", "infiniteScrollThrottle", "infiniteScrollDisabled", "infiniteScrollContainer", "scrollWindow", "immediateCheck", "horizontal", "alwaysCallback", "fromRoot"], outputs: ["scrolled", "scrolledUp"] }, { kind: "component", type: i10.ChecksheetQuestionComponent, selector: "app-checksheet-question", inputs: ["questionInfo", "index", "submissionView", "submissionId", "disableInput", "isWorking"], outputs: ["isWorkingChange"] }] });
|
|
148
|
+
}
|
|
149
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: ChecksheetQuestionListComponent, decorators: [{
|
|
150
|
+
type: Component,
|
|
151
|
+
args: [{ selector: 'app-checksheet-question-list', template: "<ng-container *ngIf=\"checksheet?.id\">\n <button\n *ngIf=\"!disableInput\"\n type=\"button\"\n mat-raised-button\n color=\"primary\"\n (click)=\"addQuestion()\"\n class=\"mb-2\"\n >\n Add Question\n </button>\n\n <div\n class=\"d-flex flex-column gap-3 mat-typography scroll-container\"\n infiniteScroll\n [infiniteScrollDistance]=\"1\"\n [infiniteScrollThrottle]=\"50\"\n (scrolled)=\"onScroll()\"\n [scrollWindow]=\"false\"\n >\n <mat-card\n class=\"d-flex flex-column gap-3\"\n *ngFor=\"let question of questions; let i = index\"\n >\n <div\n class=\"d-flex flex-row gap-3 justify-content-end\"\n *ngIf=\"!disableInput\"\n >\n <mat-icon class=\"cursor-pointer\" (click)=\"deleteQuestion(question)\">\n delete\n </mat-icon>\n <mat-icon class=\"cursor-pointer\" (click)=\"editQuestion(question, i)\">\n edit\n </mat-icon>\n <mat-icon\n class=\"cursor-pointer\"\n *ngIf=\"i > 0\"\n (click)=\"moveQuestionUp(i)\"\n >\n arrow_upward\n </mat-icon>\n <mat-icon\n class=\"cursor-pointer\"\n *ngIf=\"i < questions.length - 1\"\n (click)=\"moveQuestionDown(i)\"\n >\n arrow_downward\n </mat-icon>\n </div>\n\n <div>\n <app-checksheet-question\n [questionInfo]=\"question\"\n [index]=\"i\"\n ></app-checksheet-question>\n </div>\n </mat-card>\n </div>\n</ng-container>\n\n<ng-container *ngIf=\"submission?.id\">\n <div fxLayout=\"column\" fxLayoutGap=\"1rem\" class=\"mat-typography\">\n <mat-card\n fxLayout=\"column\"\n fxLayoutGap=\"0.5rem\"\n class=\"w-100\"\n *ngFor=\"let question of submission.format.questions; let i = index\"\n >\n <app-checksheet-question\n [questionInfo]=\"question\"\n [index]=\"i\"\n [submissionView]=\"true\"\n [submissionId]=\"submission.id\"\n [disableInput]=\"disableInput\"\n >\n </app-checksheet-question>\n </mat-card>\n </div>\n</ng-container>\n" }]
|
|
152
|
+
}], ctorParameters: () => [{ type: i1.NgxSpinnerService }, { type: i2.AlertService }, { type: i3.MatDialog }, { type: i2.DataManager }], propDecorators: { checksheet: [{
|
|
153
|
+
type: Input
|
|
154
|
+
}], checksheetChange: [{
|
|
155
|
+
type: Output
|
|
156
|
+
}], submission: [{
|
|
157
|
+
type: Input
|
|
158
|
+
}], disableInput: [{
|
|
159
|
+
type: Input
|
|
160
|
+
}] } });
|
|
161
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"checksheet-question-list.component.js","sourceRoot":"","sources":["../../../../../../projects/ngx-techlify-checksheet/src/lib/checksheet/checksheet-question-list/checksheet-question-list.component.ts","../../../../../../projects/ngx-techlify-checksheet/src/lib/checksheet/checksheet-question-list/checksheet-question-list.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, EventEmitter, Input, OnInit, Output } from '@angular/core';\nimport { MatDialog } from '@angular/material/dialog';\nimport { NgxSpinnerService } from 'ngx-spinner';\nimport {\n  ActionPopup,\n  ActionPopupComponent,\n  AlertService,\n  DataManager\n} from 'ngx-techlify-core';\nimport { ChecksheetQuestionFormComponent } from '../checksheet-question-form/checksheet-question-form.component';\n\n@Component({\n  selector: 'app-checksheet-question-list',\n  templateUrl: './checksheet-question-list.component.html',\n  styleUrls: ['./checksheet-question-list.component.scss']\n})\nexport class ChecksheetQuestionListComponent implements OnInit {\n  @Input() checksheet: any = {};\n  @Output() checksheetChange = new EventEmitter();\n\n  @Input() submission!: any;\n  @Input() disableInput!: boolean;\n  questions: any[] = [];\n\n  constructor(\n    private spinnerService: NgxSpinnerService,\n    private alertService: AlertService,\n    private dialog: MatDialog,\n    private dataManager: DataManager\n  ) {}\n\n  ngOnInit(): void {\n    this.questions = this.checksheet?.questions || [];\n  }\n\n  onScroll() {}\n\n  editQuestion(question: any, index: any) {\n    const dialogRef = this.dialog.open(ChecksheetQuestionFormComponent, {\n      width: '800px',\n      data: {\n        update: true,\n        question: question\n      },\n      autoFocus: false\n    });\n\n    dialogRef.afterClosed().subscribe((result) => {\n      if (result) {\n        question = result;\n        this.questions[index] = question;\n      }\n    });\n  }\n\n  addQuestion() {\n    const dialogRef = this.dialog.open(ChecksheetQuestionFormComponent, {\n      width: '800px',\n      data: {\n        question: {\n          format_id: this.checksheet.id\n        }\n      },\n      autoFocus: false\n    });\n\n    dialogRef.afterClosed().subscribe((result) => {\n      if (result) {\n        this.questions.push(result);\n      }\n    });\n  }\n\n  async moveQuestionUp(index: any) {\n    if (index < this.questions.length) {\n      this.spinnerService.show();\n      try {\n        if (index <= 0) {\n          return;\n        }\n        const q1 = this.questions[index];\n        const q2 = this.questions[index - 1];\n        await this.dataManager.PUT(`api/checksheet-format-questions/${q1.id}`, {\n          ...q1,\n          rank: index - 1\n        });\n        await this.dataManager.PUT(`api/checksheet-format-questions/${q2.id}`, {\n          ...q2,\n          rank: index\n        });\n\n        this.questions[index] = q2;\n        this.questions[index - 1] = q1;\n      } catch (error) {\n        this.alertService.addAlert(\n          'Unable to move question, try later',\n          'warn'\n        );\n      } finally {\n        this.spinnerService.hide();\n      }\n    }\n  }\n\n  async moveQuestionDown(index: any) {\n    if (index < this.questions.length) {\n      this.spinnerService.show();\n      try {\n        const q1 = this.questions[index];\n        const q2 = this.questions[index + 1];\n        await this.dataManager.PUT(`api/checksheet-format-questions/${q1.id}`, {\n          ...q1,\n          rank: index + 1\n        });\n        await this.dataManager.PUT(`api/checksheet-format-questions/${q2.id}`, {\n          ...q2,\n          rank: index\n        });\n\n        this.questions[index] = q2;\n        this.questions[index + 1] = q1;\n      } catch (error) {\n        this.alertService.addAlert(\n          'Unable to move question, try later',\n          'warn'\n        );\n      } finally {\n        this.spinnerService.hide();\n      }\n    }\n  }\n\n  deleteQuestion(question: any) {\n    const dialogRef = this.dialog.open(ActionPopupComponent, {\n      width: '400px',\n      data: <ActionPopup>{\n        title: 'Delete Question',\n        message: `Are you sure to delete the question?`\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          await this.dataManager.DELETE(\n            `api/checksheet-format-questions/${question.id}`\n          );\n          this.questions = this.questions.filter(\n            (x: any) => x.id !== question.id\n          );\n        } catch (error) {\n          this.alertService.addAlert(\n            'Unable to delete question, try later',\n            'warn'\n          );\n        } finally {\n          this.spinnerService.hide();\n        }\n      }\n    });\n  }\n}\n","<ng-container *ngIf=\"checksheet?.id\">\n  <button\n    *ngIf=\"!disableInput\"\n    type=\"button\"\n    mat-raised-button\n    color=\"primary\"\n    (click)=\"addQuestion()\"\n    class=\"mb-2\"\n  >\n    Add Question\n  </button>\n\n  <div\n    class=\"d-flex flex-column gap-3 mat-typography scroll-container\"\n    infiniteScroll\n    [infiniteScrollDistance]=\"1\"\n    [infiniteScrollThrottle]=\"50\"\n    (scrolled)=\"onScroll()\"\n    [scrollWindow]=\"false\"\n  >\n    <mat-card\n      class=\"d-flex flex-column gap-3\"\n      *ngFor=\"let question of questions; let i = index\"\n    >\n      <div\n        class=\"d-flex flex-row gap-3 justify-content-end\"\n        *ngIf=\"!disableInput\"\n      >\n        <mat-icon class=\"cursor-pointer\" (click)=\"deleteQuestion(question)\">\n          delete\n        </mat-icon>\n        <mat-icon class=\"cursor-pointer\" (click)=\"editQuestion(question, i)\">\n          edit\n        </mat-icon>\n        <mat-icon\n          class=\"cursor-pointer\"\n          *ngIf=\"i > 0\"\n          (click)=\"moveQuestionUp(i)\"\n        >\n          arrow_upward\n        </mat-icon>\n        <mat-icon\n          class=\"cursor-pointer\"\n          *ngIf=\"i < questions.length - 1\"\n          (click)=\"moveQuestionDown(i)\"\n        >\n          arrow_downward\n        </mat-icon>\n      </div>\n\n      <div>\n        <app-checksheet-question\n          [questionInfo]=\"question\"\n          [index]=\"i\"\n        ></app-checksheet-question>\n      </div>\n    </mat-card>\n  </div>\n</ng-container>\n\n<ng-container *ngIf=\"submission?.id\">\n  <div fxLayout=\"column\" fxLayoutGap=\"1rem\" class=\"mat-typography\">\n    <mat-card\n      fxLayout=\"column\"\n      fxLayoutGap=\"0.5rem\"\n      class=\"w-100\"\n      *ngFor=\"let question of submission.format.questions; let i = index\"\n    >\n      <app-checksheet-question\n        [questionInfo]=\"question\"\n        [index]=\"i\"\n        [submissionView]=\"true\"\n        [submissionId]=\"submission.id\"\n        [disableInput]=\"disableInput\"\n      >\n      </app-checksheet-question>\n    </mat-card>\n  </div>\n</ng-container>\n"]}
|
|
@@ -0,0 +1,242 @@
|
|
|
1
|
+
import { __decorate } from "tslib";
|
|
2
|
+
import { Component, Input } from '@angular/core';
|
|
3
|
+
import { Validators } from '@angular/forms';
|
|
4
|
+
import { DateValidator } from 'ngx-techlify-core';
|
|
5
|
+
import { UntilDestroy, untilDestroyed } from '@ngneat/until-destroy';
|
|
6
|
+
import { ActionPopupComponent } from 'ngx-techlify-core';
|
|
7
|
+
import { debounceTime } from 'rxjs/operators';
|
|
8
|
+
import { ChecksheetSubmissionFormComponent } from '../checksheet-submission-form/checksheet-submission-form.component';
|
|
9
|
+
import * as i0 from "@angular/core";
|
|
10
|
+
import * as i1 from "ngx-spinner";
|
|
11
|
+
import * as i2 from "ngx-techlify-core";
|
|
12
|
+
import * as i3 from "@angular/router";
|
|
13
|
+
import * as i4 from "@angular/material/dialog";
|
|
14
|
+
import * as i5 from "@angular/forms";
|
|
15
|
+
import * as i6 from "@angular/common";
|
|
16
|
+
import * as i7 from "@angular/flex-layout/flex";
|
|
17
|
+
import * as i8 from "@angular/material/button";
|
|
18
|
+
import * as i9 from "@angular/material/datepicker";
|
|
19
|
+
import * as i10 from "@angular/material/form-field";
|
|
20
|
+
import * as i11 from "@angular/material/icon";
|
|
21
|
+
import * as i12 from "@angular/material/input";
|
|
22
|
+
import * as i13 from "@angular/material/table";
|
|
23
|
+
import * as i14 from "ngx-infinite-scroll";
|
|
24
|
+
const errorMessages = {
|
|
25
|
+
date_from: {
|
|
26
|
+
required: 'Start date is required',
|
|
27
|
+
invalidDate: 'Invalid date'
|
|
28
|
+
},
|
|
29
|
+
date_to: {
|
|
30
|
+
required: 'End date is required',
|
|
31
|
+
invalidDate: 'Invalid date'
|
|
32
|
+
}
|
|
33
|
+
};
|
|
34
|
+
let ChecksheetReportComponent = class ChecksheetReportComponent {
|
|
35
|
+
spinnerService;
|
|
36
|
+
alertService;
|
|
37
|
+
router;
|
|
38
|
+
dataManager;
|
|
39
|
+
currentUserService;
|
|
40
|
+
dialog;
|
|
41
|
+
formValidator;
|
|
42
|
+
fb;
|
|
43
|
+
datePipe;
|
|
44
|
+
checksheetSubmissionList = [];
|
|
45
|
+
pageEvent = { page: 1, perPage: 25, lastPage: 1 };
|
|
46
|
+
filters;
|
|
47
|
+
vehicle;
|
|
48
|
+
displayedColumns = [
|
|
49
|
+
'index',
|
|
50
|
+
'date',
|
|
51
|
+
'vehicle',
|
|
52
|
+
'created_at',
|
|
53
|
+
'reviewer.name',
|
|
54
|
+
'mechanical_issues',
|
|
55
|
+
'notes'
|
|
56
|
+
];
|
|
57
|
+
filterFormGroup;
|
|
58
|
+
constructor(spinnerService, alertService, router, dataManager, currentUserService, dialog, formValidator, fb, datePipe) {
|
|
59
|
+
this.spinnerService = spinnerService;
|
|
60
|
+
this.alertService = alertService;
|
|
61
|
+
this.router = router;
|
|
62
|
+
this.dataManager = dataManager;
|
|
63
|
+
this.currentUserService = currentUserService;
|
|
64
|
+
this.dialog = dialog;
|
|
65
|
+
this.formValidator = formValidator;
|
|
66
|
+
this.fb = fb;
|
|
67
|
+
this.datePipe = datePipe;
|
|
68
|
+
this.filters = {};
|
|
69
|
+
this.filters.sort_by = 'created_at|DESC';
|
|
70
|
+
this.createForm();
|
|
71
|
+
}
|
|
72
|
+
get excelData() {
|
|
73
|
+
if (this.checksheetSubmissionList.length <= 0) {
|
|
74
|
+
return [];
|
|
75
|
+
}
|
|
76
|
+
return this.checksheetSubmissionList.map((item) => {
|
|
77
|
+
return {
|
|
78
|
+
Date: item?.date ? new Date(item?.date).toDateString() : '',
|
|
79
|
+
Vehicle: item?.vehicle?.title_field,
|
|
80
|
+
Driver: item?.creator?.name,
|
|
81
|
+
'Time Submitted': item?.created_at
|
|
82
|
+
? this.datePipe.transform(new Date(item?.created_at), 'yyyy-MM-dd HH:mm')
|
|
83
|
+
: '',
|
|
84
|
+
'Verified By ': item?.reviewer?.name,
|
|
85
|
+
'Mechanical Issues': (item?.mechanical_issues || []).reduce((a, v) => `${a}${v?.details_without_html}, `, ''),
|
|
86
|
+
Notes: item?.comments
|
|
87
|
+
};
|
|
88
|
+
});
|
|
89
|
+
}
|
|
90
|
+
ngOnInit() {
|
|
91
|
+
this.filterFormGroup.valueChanges
|
|
92
|
+
.pipe(debounceTime(500), untilDestroyed(this))
|
|
93
|
+
.subscribe((x) => {
|
|
94
|
+
let model = this.filterFormGroup.value;
|
|
95
|
+
model.date_from = model.date_from
|
|
96
|
+
? this.datePipe.transform(model.date_from, 'yyyy-MM-dd')
|
|
97
|
+
: '';
|
|
98
|
+
model.date_to = model.date_to
|
|
99
|
+
? this.datePipe.transform(model.date_to, 'yyyy-MM-dd')
|
|
100
|
+
: '';
|
|
101
|
+
this.filters = { ...this.filters, ...model };
|
|
102
|
+
this.reload();
|
|
103
|
+
});
|
|
104
|
+
this.fetchChecksheetSubmissionsDetails();
|
|
105
|
+
}
|
|
106
|
+
createForm() {
|
|
107
|
+
this.filterFormGroup = this.fb.group({
|
|
108
|
+
date_from: ['', Validators.compose([DateValidator()])],
|
|
109
|
+
date_to: ['', Validators.compose([DateValidator()])],
|
|
110
|
+
status_id: [''],
|
|
111
|
+
model_id: [''],
|
|
112
|
+
creator_id: [''],
|
|
113
|
+
reviewer_id: [''],
|
|
114
|
+
checksheet_format_id: [''],
|
|
115
|
+
driver_assigned_customer_id: [''],
|
|
116
|
+
vehicle_assigned_customer_id: ['']
|
|
117
|
+
});
|
|
118
|
+
}
|
|
119
|
+
get currentUserId() {
|
|
120
|
+
return this.currentUserService.getUser().id;
|
|
121
|
+
}
|
|
122
|
+
createChecksheetSubmission() {
|
|
123
|
+
const dialogRef = this.dialog.open(ChecksheetSubmissionFormComponent, {
|
|
124
|
+
width: '400px',
|
|
125
|
+
data: {
|
|
126
|
+
submission: {},
|
|
127
|
+
vehicle: this.vehicle
|
|
128
|
+
},
|
|
129
|
+
autoFocus: false
|
|
130
|
+
});
|
|
131
|
+
dialogRef.afterClosed().subscribe((result) => {
|
|
132
|
+
if (result) {
|
|
133
|
+
//Action confirmed
|
|
134
|
+
this.editChecksheetSubmission(result);
|
|
135
|
+
}
|
|
136
|
+
});
|
|
137
|
+
}
|
|
138
|
+
deactivateChecksheetSubmission(checksheetSubmission) {
|
|
139
|
+
const dialogRef = this.dialog.open(ActionPopupComponent, {
|
|
140
|
+
width: '400px',
|
|
141
|
+
data: {
|
|
142
|
+
title: 'Deactivate Submissions',
|
|
143
|
+
message: `Are you sure to proceed deactivate?`
|
|
144
|
+
},
|
|
145
|
+
autoFocus: false
|
|
146
|
+
});
|
|
147
|
+
dialogRef.afterClosed().subscribe(async (result) => {
|
|
148
|
+
if (result) {
|
|
149
|
+
//Action confirmed
|
|
150
|
+
try {
|
|
151
|
+
this.spinnerService.show();
|
|
152
|
+
await this.dataManager.DELETE(`api/checksheets/${checksheetSubmission.id}`);
|
|
153
|
+
this.checksheetSubmissionList = this.checksheetSubmissionList.filter((x) => x.id !== checksheetSubmission.id);
|
|
154
|
+
}
|
|
155
|
+
catch (error) {
|
|
156
|
+
this.alertService.addAlert('Unable to deactivate Checksheet, try later', 'warn');
|
|
157
|
+
}
|
|
158
|
+
finally {
|
|
159
|
+
this.spinnerService.hide();
|
|
160
|
+
}
|
|
161
|
+
}
|
|
162
|
+
});
|
|
163
|
+
}
|
|
164
|
+
editChecksheetSubmission(checksheetSubmission) {
|
|
165
|
+
this.router.navigate([
|
|
166
|
+
'vehicles/checksheets/checksheets/view',
|
|
167
|
+
checksheetSubmission.id
|
|
168
|
+
], { queryParams: { is_vehicle_view: true } });
|
|
169
|
+
}
|
|
170
|
+
viewChecksheetSubmission(checksheetSubmission) {
|
|
171
|
+
this.router.navigate([
|
|
172
|
+
'vehicles/checksheets/checksheets-view',
|
|
173
|
+
checksheetSubmission.id
|
|
174
|
+
]);
|
|
175
|
+
}
|
|
176
|
+
reviewChecksheetSubmission(checksheetSubmission) {
|
|
177
|
+
this.router.navigate([
|
|
178
|
+
'vehicles/checksheets/checksheets/review',
|
|
179
|
+
checksheetSubmission.id
|
|
180
|
+
]);
|
|
181
|
+
}
|
|
182
|
+
onScroll() {
|
|
183
|
+
if (this.pageEvent.page < this.pageEvent.lastPage) {
|
|
184
|
+
this.pageEvent.page += 1;
|
|
185
|
+
}
|
|
186
|
+
this.fetchChecksheetSubmissionsDetails();
|
|
187
|
+
}
|
|
188
|
+
async fetchChecksheetSubmissionsDetails() {
|
|
189
|
+
this.spinnerService.show();
|
|
190
|
+
if (this.vehicle) {
|
|
191
|
+
this.filters.model_id = this.vehicle.id;
|
|
192
|
+
}
|
|
193
|
+
try {
|
|
194
|
+
const result = await this.dataManager.GET(`api/checksheets`, {
|
|
195
|
+
...this.pageEvent,
|
|
196
|
+
...this.filters
|
|
197
|
+
});
|
|
198
|
+
this.checksheetSubmissionList = this.checksheetSubmissionList.concat(result.data);
|
|
199
|
+
this.pageEvent.page = result.current_page;
|
|
200
|
+
this.pageEvent.lastPage = result.last_page;
|
|
201
|
+
}
|
|
202
|
+
catch (error) {
|
|
203
|
+
this.alertService.addAlert('Unable to get Checksheets, try later', 'warn');
|
|
204
|
+
}
|
|
205
|
+
finally {
|
|
206
|
+
this.spinnerService.hide();
|
|
207
|
+
}
|
|
208
|
+
}
|
|
209
|
+
reload() {
|
|
210
|
+
this.pageEvent = { page: 1, perPage: 25, lastPage: 1 };
|
|
211
|
+
this.checksheetSubmissionList = [];
|
|
212
|
+
this.fetchChecksheetSubmissionsDetails();
|
|
213
|
+
}
|
|
214
|
+
getFieldValue(field) {
|
|
215
|
+
return this.filterFormGroup.get(field)?.value;
|
|
216
|
+
}
|
|
217
|
+
resetFieldValue(field, event) {
|
|
218
|
+
event.stopPropagation();
|
|
219
|
+
this.filterFormGroup.get(field)?.setValue('');
|
|
220
|
+
}
|
|
221
|
+
/** Method to evaluate form fields*/
|
|
222
|
+
isFieldValid(field) {
|
|
223
|
+
return this.formValidator.isFieldValid(field, this.filterFormGroup, true);
|
|
224
|
+
}
|
|
225
|
+
/** Method to find error in form fields*/
|
|
226
|
+
getErrorMessage(field) {
|
|
227
|
+
return this.formValidator.getErrorMessage(field, this.filterFormGroup, errorMessages);
|
|
228
|
+
}
|
|
229
|
+
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: ChecksheetReportComponent, deps: [{ token: i1.NgxSpinnerService }, { token: i2.AlertService }, { token: i3.Router }, { token: i2.DataManager }, { token: i2.CurrentUserService }, { token: i4.MatDialog }, { token: i2.FormValidatorService }, { token: i5.UntypedFormBuilder }, { token: i6.DatePipe }], target: i0.ɵɵFactoryTarget.Component });
|
|
230
|
+
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.13", type: ChecksheetReportComponent, selector: "app-checksheet-report", inputs: { vehicle: "vehicle" }, ngImport: i0, template: "<div\n fxLayout=\"column\"\n fxLayoutAlign=\"start\"\n fxLayoutGap=\"1.5rem\"\n class=\"mat-typography m-4\"\n>\n <div fxLayout fxLayoutAlign=\"center center\">\n <h3 class=\"m-0 font-weight-bold mr-3\">\n Checksheet Report\n\n <app-export-excel-button\n class=\"ml-2\"\n elementId=\"pdfable-section\"\n name=\"checksheet-report-download\"\n [data]=\"excelData\"\n >\n </app-export-excel-button>\n </h3>\n </div>\n\n <form\n fxLayout=\"row wrap d-print-none\"\n fxLayoutGap=\"1rem\"\n [formGroup]=\"filterFormGroup\"\n >\n <mat-form-field>\n <input\n matInput\n [matDatepicker]=\"picker\"\n placeholder=\"Start Date (MM/DD/YYYY)\"\n formControlName=\"date_from\"\n autocomplete=\"off\"\n />\n <mat-datepicker-toggle matSuffix [for]=\"picker\"></mat-datepicker-toggle>\n <mat-datepicker #picker></mat-datepicker>\n <mat-error *ngIf=\"isFieldValid('date_from')\"\n >{{ getErrorMessage('date_from') }}\n </mat-error>\n <button\n mat-button\n *ngIf=\"getFieldValue('date_from')\"\n matSuffix\n mat-icon-button\n (click)=\"resetFieldValue('date_from', $event)\"\n >\n <mat-icon>close</mat-icon>\n </button>\n </mat-form-field>\n\n <mat-form-field>\n <input\n matInput\n [matDatepicker]=\"p2\"\n placeholder=\"End Date (MM/DD/YYYY)\"\n formControlName=\"date_to\"\n autocomplete=\"off\"\n />\n <mat-datepicker-toggle matSuffix [for]=\"p2\"></mat-datepicker-toggle>\n <mat-datepicker #p2></mat-datepicker>\n <mat-error *ngIf=\"isFieldValid('date_to')\"\n >{{ getErrorMessage('date_to') }}\n </mat-error>\n <button\n mat-button\n *ngIf=\"getFieldValue('date_to')\"\n matSuffix\n mat-icon-button\n (click)=\"resetFieldValue('date_to', $event)\"\n >\n <mat-icon>close</mat-icon>\n </button>\n </mat-form-field>\n\n <mat-form-field>\n <mat-label>Status</mat-label>\n <app-searchable-selector\n formControlName=\"status_id\"\n apiUrl=\"api/checksheet-submission-statuses\"\n [enableSearch]=\"false\"\n >\n </app-searchable-selector>\n <mat-icon\n matSuffix\n *ngIf=\"getFieldValue('status_id')\"\n (click)=\"resetFieldValue('status_id', $event)\"\n >\n close</mat-icon\n >\n </mat-form-field>\n\n <mat-form-field *ngIf=\"!vehicle\">\n <mat-label>Vehicle</mat-label>\n <app-searchable-selector\n formControlName=\"model_id\"\n apiUrl=\"api/vehicles\"\n [enableSearch]=\"true\"\n titleField=\"title_field\"\n [sort]=\"false\"\n >\n </app-searchable-selector>\n <mat-icon\n matSuffix\n *ngIf=\"getFieldValue('model_id')\"\n (click)=\"resetFieldValue('model_id', $event)\"\n >\n close</mat-icon\n >\n </mat-form-field>\n\n <mat-form-field>\n <mat-label>Creator</mat-label>\n <app-searchable-selector\n formControlName=\"creator_id\"\n apiUrl=\"api/users\"\n [enableSearch]=\"true\"\n titleField=\"name\"\n >\n </app-searchable-selector>\n <mat-icon\n matSuffix\n *ngIf=\"getFieldValue('creator_id')\"\n (click)=\"resetFieldValue('creator_id', $event)\"\n >\n close</mat-icon\n >\n </mat-form-field>\n\n <mat-form-field>\n <mat-label>Reviewer</mat-label>\n <app-searchable-selector\n formControlName=\"reviewer_id\"\n apiUrl=\"api/users\"\n [enableSearch]=\"true\"\n titleField=\"name\"\n >\n </app-searchable-selector>\n <mat-icon\n matSuffix\n *ngIf=\"getFieldValue('reviewer_id')\"\n (click)=\"resetFieldValue('reviewer_id', $event)\"\n >\n close</mat-icon\n >\n </mat-form-field>\n\n <mat-form-field>\n <mat-label>Checksheet Format</mat-label>\n <app-searchable-selector\n formControlName=\"checksheet_format_id\"\n apiUrl=\"api/checksheet-formats?is_published=true\"\n [enableSearch]=\"true\"\n >\n </app-searchable-selector>\n <mat-icon\n matSuffix\n *ngIf=\"getFieldValue('checksheet_format_id')\"\n (click)=\"resetFieldValue('checksheet_format_id', $event)\"\n >\n close</mat-icon\n >\n </mat-form-field>\n\n <mat-form-field>\n <mat-label>Vehicle Assigned Customer</mat-label>\n <app-searchable-selector\n formControlName=\"vehicle_assigned_customer_id\"\n apiUrl=\"api/customers\"\n [enableSearch]=\"true\"\n titleField=\"name\"\n >\n </app-searchable-selector>\n <mat-icon\n matSuffix\n *ngIf=\"getFieldValue('vehicle_assigned_customer_id')\"\n (click)=\"resetFieldValue('vehicle_assigned_customer_id', $event)\"\n >\n close</mat-icon\n >\n </mat-form-field>\n\n <!-- <mat-form-field>\n <mat-label>Driver Assigned Customer</mat-label>\n <app-searchable-selector formControlName=\"driver_assigned_customer_id\" apiUrl=\"api/customers\"\n [enableSearch]=\"true\" titleField=\"name\">\n </app-searchable-selector>\n <mat-icon matSuffix *ngIf=\"getFieldValue('driver_assigned_customer_id')\"\n (click)=\"resetFieldValue('driver_assigned_customer_id', $event)\">\n close</mat-icon>\n </mat-form-field> -->\n </form>\n\n <div\n id=\"pdfable-section\"\n class=\"scroll-container\"\n infiniteScroll\n [infiniteScrollDistance]=\"2\"\n [infiniteScrollThrottle]=\"50\"\n (scrolled)=\"onScroll()\"\n [scrollWindow]=\"false\"\n >\n <table\n mat-table\n [dataSource]=\"checksheetSubmissionList\"\n class=\"w-100\"\n multiTemplateDataRows\n >\n <!-- Index Column -->\n <ng-container matColumnDef=\"index\">\n <th mat-header-cell *matHeaderCellDef>#</th>\n <td mat-cell *matCellDef=\"let element; let i = dataIndex\">\n {{ i + 1 }}\n </td>\n </ng-container>\n\n <!-- Date Column -->\n <ng-container matColumnDef=\"date\">\n <th mat-header-cell *matHeaderCellDef>Date</th>\n <td mat-cell *matCellDef=\"let element\">\n {{ element.date | date : 'mediumDate' }}\n </td>\n </ng-container>\n\n <!-- Vehicle Column -->\n <ng-container matColumnDef=\"vehicle\">\n <th mat-header-cell *matHeaderCellDef>Vehicle</th>\n <td mat-cell *matCellDef=\"let element\">\n {{ element.vehicle?.title_field }}\n </td>\n </ng-container>\n\n <!-- Category Column -->\n <ng-container matColumnDef=\"created_at\">\n <th mat-header-cell *matHeaderCellDef>Submitted On</th>\n <td mat-cell *matCellDef=\"let element\">\n {{ element.created_at | date : 'mediumDate' }}\n {{ element.created_at | date : 'shortTime' }} <br />\n <small>by {{ element.creator?.name }}</small>\n </td>\n </ng-container>\n\n <!-- Category Column -->\n <ng-container matColumnDef=\"reviewer.name\">\n <th mat-header-cell *matHeaderCellDef>Verified By</th>\n <td mat-cell *matCellDef=\"let element\">\n {{ element.reviewer?.name }} <br />\n <small *ngIf=\"element.reviewed_at\">\n on {{ element.reviewed_at | date : 'mediumDate' }}\n {{ element.reviewed_at | date : 'shortTime' }}\n </small>\n </td>\n </ng-container>\n\n <!-- Category Column -->\n <ng-container matColumnDef=\"mechanical_issues\">\n <th mat-header-cell *matHeaderCellDef>Mechanical Issues</th>\n <td mat-cell *matCellDef=\"let element\" class=\"w-50\">\n <ul>\n <li\n *ngFor=\"let issue of element?.mechanical_issues\"\n [innerHTML]=\"issue.details_without_html\"\n ></li>\n </ul>\n </td>\n </ng-container>\n\n <!-- Category Column -->\n <ng-container matColumnDef=\"notes\">\n <th mat-header-cell *matHeaderCellDef>Notes</th>\n <td mat-cell *matCellDef=\"let element\">\n {{ element.comments }}\n </td>\n </ng-container>\n\n <tr mat-header-row *matHeaderRowDef=\"displayedColumns\"></tr>\n <tr mat-row *matRowDef=\"let row; columns: displayedColumns\"></tr>\n </table>\n </div>\n</div>\n", styles: [""], dependencies: [{ kind: "directive", type: i6.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i6.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i7.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: i7.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: i7.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: i8.MatButton, selector: " button[mat-button], button[mat-raised-button], button[mat-flat-button], button[mat-stroked-button] ", exportAs: ["matButton"] }, { kind: "component", type: i8.MatIconButton, selector: "button[mat-icon-button]", exportAs: ["matButton"] }, { kind: "component", type: i9.MatDatepicker, selector: "mat-datepicker", exportAs: ["matDatepicker"] }, { kind: "directive", type: i9.MatDatepickerInput, selector: "input[matDatepicker]", inputs: ["matDatepicker", "min", "max", "matDatepickerFilter"], exportAs: ["matDatepickerInput"] }, { kind: "component", type: i9.MatDatepickerToggle, selector: "mat-datepicker-toggle", inputs: ["for", "tabIndex", "aria-label", "disabled", "disableRipple"], exportAs: ["matDatepickerToggle"] }, { kind: "component", type: i10.MatFormField, selector: "mat-form-field", inputs: ["hideRequiredMarker", "color", "floatLabel", "appearance", "subscriptSizing", "hintLabel"], exportAs: ["matFormField"] }, { kind: "directive", type: i10.MatLabel, selector: "mat-label" }, { kind: "directive", type: i10.MatError, selector: "mat-error, [matError]", inputs: ["id"] }, { kind: "directive", type: i10.MatSuffix, selector: "[matSuffix], [matIconSuffix], [matTextSuffix]", inputs: ["matTextSuffix"] }, { kind: "component", type: i11.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }, { 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.MatTable, selector: "mat-table, table[mat-table]", exportAs: ["matTable"] }, { kind: "directive", type: i13.MatHeaderCellDef, selector: "[matHeaderCellDef]" }, { kind: "directive", type: i13.MatHeaderRowDef, selector: "[matHeaderRowDef]", inputs: ["matHeaderRowDef", "matHeaderRowDefSticky"] }, { kind: "directive", type: i13.MatColumnDef, selector: "[matColumnDef]", inputs: ["matColumnDef"] }, { kind: "directive", type: i13.MatCellDef, selector: "[matCellDef]" }, { kind: "directive", type: i13.MatRowDef, selector: "[matRowDef]", inputs: ["matRowDefColumns", "matRowDefWhen"] }, { kind: "directive", type: i13.MatHeaderCell, selector: "mat-header-cell, th[mat-header-cell]" }, { kind: "directive", type: i13.MatCell, selector: "mat-cell, td[mat-cell]" }, { kind: "component", type: i13.MatHeaderRow, selector: "mat-header-row, tr[mat-header-row]", exportAs: ["matHeaderRow"] }, { kind: "component", type: i13.MatRow, selector: "mat-row, tr[mat-row]", exportAs: ["matRow"] }, { kind: "directive", type: i5.ɵNgNoValidate, selector: "form:not([ngNoForm]):not([ngNativeValidate])" }, { kind: "directive", type: i5.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: i5.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i5.NgControlStatusGroup, selector: "[formGroupName],[formArrayName],[ngModelGroup],[formGroup],form:not([ngNoForm]),[ngForm]" }, { kind: "directive", type: i5.FormGroupDirective, selector: "[formGroup]", inputs: ["formGroup"], outputs: ["ngSubmit"], exportAs: ["ngForm"] }, { kind: "directive", type: i5.FormControlName, selector: "[formControlName]", inputs: ["formControlName", "disabled", "ngModel"], outputs: ["ngModelChange"] }, { kind: "directive", type: i14.InfiniteScrollDirective, selector: "[infiniteScroll], [infinite-scroll], [data-infinite-scroll]", inputs: ["infiniteScrollDistance", "infiniteScrollUpDistance", "infiniteScrollThrottle", "infiniteScrollDisabled", "infiniteScrollContainer", "scrollWindow", "immediateCheck", "horizontal", "alwaysCallback", "fromRoot"], outputs: ["scrolled", "scrolledUp"] }, { kind: "component", type: i2.SearchableSelectorComponent, selector: "app-searchable-selector", inputs: ["valueField", "titleField", "subtitleField", "apiUrl", "multiple", "selectedValue", "enableSearch", "add", "addConfig", "edit", "editConfig", "sort", "sortBy", "searchField", "itemComponent", "items", "apiDataProperty", "cache", "perPage", "inDataSearch", "panelWidth", "focusSearchOnOpen", "required", "disabled", "value"], outputs: ["selectedValueChange", "selectionChange", "itemsChange"] }, { kind: "component", type: i2.ExportExcelButtonComponent, selector: "app-export-excel-button", inputs: ["name", "data"] }, { kind: "pipe", type: i6.DatePipe, name: "date" }] });
|
|
231
|
+
};
|
|
232
|
+
ChecksheetReportComponent = __decorate([
|
|
233
|
+
UntilDestroy()
|
|
234
|
+
], ChecksheetReportComponent);
|
|
235
|
+
export { ChecksheetReportComponent };
|
|
236
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: ChecksheetReportComponent, decorators: [{
|
|
237
|
+
type: Component,
|
|
238
|
+
args: [{ selector: 'app-checksheet-report', template: "<div\n fxLayout=\"column\"\n fxLayoutAlign=\"start\"\n fxLayoutGap=\"1.5rem\"\n class=\"mat-typography m-4\"\n>\n <div fxLayout fxLayoutAlign=\"center center\">\n <h3 class=\"m-0 font-weight-bold mr-3\">\n Checksheet Report\n\n <app-export-excel-button\n class=\"ml-2\"\n elementId=\"pdfable-section\"\n name=\"checksheet-report-download\"\n [data]=\"excelData\"\n >\n </app-export-excel-button>\n </h3>\n </div>\n\n <form\n fxLayout=\"row wrap d-print-none\"\n fxLayoutGap=\"1rem\"\n [formGroup]=\"filterFormGroup\"\n >\n <mat-form-field>\n <input\n matInput\n [matDatepicker]=\"picker\"\n placeholder=\"Start Date (MM/DD/YYYY)\"\n formControlName=\"date_from\"\n autocomplete=\"off\"\n />\n <mat-datepicker-toggle matSuffix [for]=\"picker\"></mat-datepicker-toggle>\n <mat-datepicker #picker></mat-datepicker>\n <mat-error *ngIf=\"isFieldValid('date_from')\"\n >{{ getErrorMessage('date_from') }}\n </mat-error>\n <button\n mat-button\n *ngIf=\"getFieldValue('date_from')\"\n matSuffix\n mat-icon-button\n (click)=\"resetFieldValue('date_from', $event)\"\n >\n <mat-icon>close</mat-icon>\n </button>\n </mat-form-field>\n\n <mat-form-field>\n <input\n matInput\n [matDatepicker]=\"p2\"\n placeholder=\"End Date (MM/DD/YYYY)\"\n formControlName=\"date_to\"\n autocomplete=\"off\"\n />\n <mat-datepicker-toggle matSuffix [for]=\"p2\"></mat-datepicker-toggle>\n <mat-datepicker #p2></mat-datepicker>\n <mat-error *ngIf=\"isFieldValid('date_to')\"\n >{{ getErrorMessage('date_to') }}\n </mat-error>\n <button\n mat-button\n *ngIf=\"getFieldValue('date_to')\"\n matSuffix\n mat-icon-button\n (click)=\"resetFieldValue('date_to', $event)\"\n >\n <mat-icon>close</mat-icon>\n </button>\n </mat-form-field>\n\n <mat-form-field>\n <mat-label>Status</mat-label>\n <app-searchable-selector\n formControlName=\"status_id\"\n apiUrl=\"api/checksheet-submission-statuses\"\n [enableSearch]=\"false\"\n >\n </app-searchable-selector>\n <mat-icon\n matSuffix\n *ngIf=\"getFieldValue('status_id')\"\n (click)=\"resetFieldValue('status_id', $event)\"\n >\n close</mat-icon\n >\n </mat-form-field>\n\n <mat-form-field *ngIf=\"!vehicle\">\n <mat-label>Vehicle</mat-label>\n <app-searchable-selector\n formControlName=\"model_id\"\n apiUrl=\"api/vehicles\"\n [enableSearch]=\"true\"\n titleField=\"title_field\"\n [sort]=\"false\"\n >\n </app-searchable-selector>\n <mat-icon\n matSuffix\n *ngIf=\"getFieldValue('model_id')\"\n (click)=\"resetFieldValue('model_id', $event)\"\n >\n close</mat-icon\n >\n </mat-form-field>\n\n <mat-form-field>\n <mat-label>Creator</mat-label>\n <app-searchable-selector\n formControlName=\"creator_id\"\n apiUrl=\"api/users\"\n [enableSearch]=\"true\"\n titleField=\"name\"\n >\n </app-searchable-selector>\n <mat-icon\n matSuffix\n *ngIf=\"getFieldValue('creator_id')\"\n (click)=\"resetFieldValue('creator_id', $event)\"\n >\n close</mat-icon\n >\n </mat-form-field>\n\n <mat-form-field>\n <mat-label>Reviewer</mat-label>\n <app-searchable-selector\n formControlName=\"reviewer_id\"\n apiUrl=\"api/users\"\n [enableSearch]=\"true\"\n titleField=\"name\"\n >\n </app-searchable-selector>\n <mat-icon\n matSuffix\n *ngIf=\"getFieldValue('reviewer_id')\"\n (click)=\"resetFieldValue('reviewer_id', $event)\"\n >\n close</mat-icon\n >\n </mat-form-field>\n\n <mat-form-field>\n <mat-label>Checksheet Format</mat-label>\n <app-searchable-selector\n formControlName=\"checksheet_format_id\"\n apiUrl=\"api/checksheet-formats?is_published=true\"\n [enableSearch]=\"true\"\n >\n </app-searchable-selector>\n <mat-icon\n matSuffix\n *ngIf=\"getFieldValue('checksheet_format_id')\"\n (click)=\"resetFieldValue('checksheet_format_id', $event)\"\n >\n close</mat-icon\n >\n </mat-form-field>\n\n <mat-form-field>\n <mat-label>Vehicle Assigned Customer</mat-label>\n <app-searchable-selector\n formControlName=\"vehicle_assigned_customer_id\"\n apiUrl=\"api/customers\"\n [enableSearch]=\"true\"\n titleField=\"name\"\n >\n </app-searchable-selector>\n <mat-icon\n matSuffix\n *ngIf=\"getFieldValue('vehicle_assigned_customer_id')\"\n (click)=\"resetFieldValue('vehicle_assigned_customer_id', $event)\"\n >\n close</mat-icon\n >\n </mat-form-field>\n\n <!-- <mat-form-field>\n <mat-label>Driver Assigned Customer</mat-label>\n <app-searchable-selector formControlName=\"driver_assigned_customer_id\" apiUrl=\"api/customers\"\n [enableSearch]=\"true\" titleField=\"name\">\n </app-searchable-selector>\n <mat-icon matSuffix *ngIf=\"getFieldValue('driver_assigned_customer_id')\"\n (click)=\"resetFieldValue('driver_assigned_customer_id', $event)\">\n close</mat-icon>\n </mat-form-field> -->\n </form>\n\n <div\n id=\"pdfable-section\"\n class=\"scroll-container\"\n infiniteScroll\n [infiniteScrollDistance]=\"2\"\n [infiniteScrollThrottle]=\"50\"\n (scrolled)=\"onScroll()\"\n [scrollWindow]=\"false\"\n >\n <table\n mat-table\n [dataSource]=\"checksheetSubmissionList\"\n class=\"w-100\"\n multiTemplateDataRows\n >\n <!-- Index Column -->\n <ng-container matColumnDef=\"index\">\n <th mat-header-cell *matHeaderCellDef>#</th>\n <td mat-cell *matCellDef=\"let element; let i = dataIndex\">\n {{ i + 1 }}\n </td>\n </ng-container>\n\n <!-- Date Column -->\n <ng-container matColumnDef=\"date\">\n <th mat-header-cell *matHeaderCellDef>Date</th>\n <td mat-cell *matCellDef=\"let element\">\n {{ element.date | date : 'mediumDate' }}\n </td>\n </ng-container>\n\n <!-- Vehicle Column -->\n <ng-container matColumnDef=\"vehicle\">\n <th mat-header-cell *matHeaderCellDef>Vehicle</th>\n <td mat-cell *matCellDef=\"let element\">\n {{ element.vehicle?.title_field }}\n </td>\n </ng-container>\n\n <!-- Category Column -->\n <ng-container matColumnDef=\"created_at\">\n <th mat-header-cell *matHeaderCellDef>Submitted On</th>\n <td mat-cell *matCellDef=\"let element\">\n {{ element.created_at | date : 'mediumDate' }}\n {{ element.created_at | date : 'shortTime' }} <br />\n <small>by {{ element.creator?.name }}</small>\n </td>\n </ng-container>\n\n <!-- Category Column -->\n <ng-container matColumnDef=\"reviewer.name\">\n <th mat-header-cell *matHeaderCellDef>Verified By</th>\n <td mat-cell *matCellDef=\"let element\">\n {{ element.reviewer?.name }} <br />\n <small *ngIf=\"element.reviewed_at\">\n on {{ element.reviewed_at | date : 'mediumDate' }}\n {{ element.reviewed_at | date : 'shortTime' }}\n </small>\n </td>\n </ng-container>\n\n <!-- Category Column -->\n <ng-container matColumnDef=\"mechanical_issues\">\n <th mat-header-cell *matHeaderCellDef>Mechanical Issues</th>\n <td mat-cell *matCellDef=\"let element\" class=\"w-50\">\n <ul>\n <li\n *ngFor=\"let issue of element?.mechanical_issues\"\n [innerHTML]=\"issue.details_without_html\"\n ></li>\n </ul>\n </td>\n </ng-container>\n\n <!-- Category Column -->\n <ng-container matColumnDef=\"notes\">\n <th mat-header-cell *matHeaderCellDef>Notes</th>\n <td mat-cell *matCellDef=\"let element\">\n {{ element.comments }}\n </td>\n </ng-container>\n\n <tr mat-header-row *matHeaderRowDef=\"displayedColumns\"></tr>\n <tr mat-row *matRowDef=\"let row; columns: displayedColumns\"></tr>\n </table>\n </div>\n</div>\n" }]
|
|
239
|
+
}], ctorParameters: () => [{ type: i1.NgxSpinnerService }, { type: i2.AlertService }, { type: i3.Router }, { type: i2.DataManager }, { type: i2.CurrentUserService }, { type: i4.MatDialog }, { type: i2.FormValidatorService }, { type: i5.UntypedFormBuilder }, { type: i6.DatePipe }], propDecorators: { vehicle: [{
|
|
240
|
+
type: Input
|
|
241
|
+
}] } });
|
|
242
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"checksheet-report.component.js","sourceRoot":"","sources":["../../../../../../projects/ngx-techlify-checksheet/src/lib/checksheet/checksheet-report/checksheet-report.component.ts","../../../../../../projects/ngx-techlify-checksheet/src/lib/checksheet/checksheet-report/checksheet-report.component.html"],"names":[],"mappings":"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","sourcesContent":["import { DatePipe } from '@angular/common';\nimport { Component, Input, OnInit } from '@angular/core';\nimport {\n  UntypedFormBuilder,\n  UntypedFormGroup,\n  Validators\n} from '@angular/forms';\nimport { MatDialog } from '@angular/material/dialog';\nimport { Router } from '@angular/router';\nimport { DateValidator } from 'ngx-techlify-core';\nimport { UntilDestroy, untilDestroyed } from '@ngneat/until-destroy';\nimport { NgxSpinnerService } from 'ngx-spinner';\nimport {\n  ActionPopup,\n  ActionPopupComponent,\n  AlertService,\n  DataManager,\n  FormValidatorService\n} from 'ngx-techlify-core';\nimport { CurrentUserService } from 'ngx-techlify-core';\nimport { debounceTime } from 'rxjs/operators';\nimport { ChecksheetSubmissionFormComponent } from '../checksheet-submission-form/checksheet-submission-form.component';\n\nconst errorMessages: any = {\n  date_from: {\n    required: 'Start date is required',\n    invalidDate: 'Invalid date'\n  },\n  date_to: {\n    required: 'End date is required',\n    invalidDate: 'Invalid date'\n  }\n};\n@UntilDestroy()\n@Component({\n  selector: 'app-checksheet-report',\n  templateUrl: './checksheet-report.component.html',\n  styleUrls: ['./checksheet-report.component.scss']\n})\nexport class ChecksheetReportComponent implements OnInit {\n  checksheetSubmissionList: any[] = [];\n  pageEvent: any = { page: 1, perPage: 25, lastPage: 1 };\n  filters: any;\n  @Input() vehicle: any;\n\n  displayedColumns: any[] = [\n    'index',\n    'date',\n    'vehicle',\n    'created_at',\n    'reviewer.name',\n    'mechanical_issues',\n    'notes'\n  ];\n\n  filterFormGroup!: UntypedFormGroup;\n\n  constructor(\n    private spinnerService: NgxSpinnerService,\n    private alertService: AlertService,\n    private router: Router,\n    private dataManager: DataManager,\n    private currentUserService: CurrentUserService,\n    private dialog: MatDialog,\n    private formValidator: FormValidatorService,\n    private fb: UntypedFormBuilder,\n    private datePipe: DatePipe\n  ) {\n    this.filters = {};\n    this.filters.sort_by = 'created_at|DESC';\n    this.createForm();\n  }\n\n  get excelData(): any[] {\n    if (this.checksheetSubmissionList.length <= 0) {\n      return [];\n    }\n\n    return this.checksheetSubmissionList.map((item) => {\n      return {\n        Date: item?.date ? new Date(item?.date).toDateString() : '',\n        Vehicle: item?.vehicle?.title_field,\n        Driver: item?.creator?.name,\n        'Time Submitted': item?.created_at\n          ? this.datePipe.transform(\n              new Date(item?.created_at),\n              'yyyy-MM-dd HH:mm'\n            )\n          : '',\n        'Verified By ': item?.reviewer?.name,\n        'Mechanical Issues': ((item?.mechanical_issues || []) as []).reduce(\n          (a: any, v: any) => `${a}${v?.details_without_html}, `,\n          ''\n        ),\n        Notes: item?.comments\n      };\n    });\n  }\n\n  ngOnInit(): void {\n    this.filterFormGroup.valueChanges\n      .pipe(debounceTime(500), untilDestroyed(this))\n      .subscribe((x) => {\n        let model = this.filterFormGroup.value;\n        model.date_from = model.date_from\n          ? this.datePipe.transform(model.date_from, 'yyyy-MM-dd')\n          : '';\n        model.date_to = model.date_to\n          ? this.datePipe.transform(model.date_to, 'yyyy-MM-dd')\n          : '';\n        this.filters = { ...this.filters, ...model };\n        this.reload();\n      });\n    this.fetchChecksheetSubmissionsDetails();\n  }\n\n  private createForm() {\n    this.filterFormGroup = this.fb.group({\n      date_from: ['', Validators.compose([DateValidator()])],\n      date_to: ['', Validators.compose([DateValidator()])],\n      status_id: [''],\n      model_id: [''],\n      creator_id: [''],\n      reviewer_id: [''],\n      checksheet_format_id: [''],\n      driver_assigned_customer_id: [''],\n      vehicle_assigned_customer_id: ['']\n    });\n  }\n\n  get currentUserId() {\n    return this.currentUserService.getUser().id;\n  }\n\n  createChecksheetSubmission() {\n    const dialogRef = this.dialog.open(\n      ChecksheetSubmissionFormComponent,\n      {\n        width: '400px',\n        data: {\n          submission: {},\n          vehicle: this.vehicle\n        },\n        autoFocus: false\n      }\n    );\n\n    dialogRef.afterClosed().subscribe((result) => {\n      if (result) {\n        //Action confirmed\n        this.editChecksheetSubmission(result);\n      }\n    });\n  }\n\n  deactivateChecksheetSubmission(checksheetSubmission: any) {\n    const dialogRef = this.dialog.open(ActionPopupComponent, {\n      width: '400px',\n      data: <ActionPopup>{\n        title: 'Deactivate Submissions',\n        message: `Are you sure to proceed deactivate?`\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          await this.dataManager.DELETE(\n            `api/checksheets/${checksheetSubmission.id}`\n          );\n\n          this.checksheetSubmissionList = this.checksheetSubmissionList.filter(\n            (x) => x.id !== checksheetSubmission.id\n          );\n        } catch (error) {\n          this.alertService.addAlert(\n            'Unable to deactivate Checksheet, try later',\n            'warn'\n          );\n        } finally {\n          this.spinnerService.hide();\n        }\n      }\n    });\n  }\n\n  editChecksheetSubmission(checksheetSubmission: any) {\n    this.router.navigate(\n      [\n        'vehicles/checksheets/checksheets/view',\n        checksheetSubmission.id\n      ],\n      { queryParams: { is_vehicle_view: true } }\n    );\n  }\n\n  viewChecksheetSubmission(checksheetSubmission: any) {\n    this.router.navigate([\n      'vehicles/checksheets/checksheets-view',\n      checksheetSubmission.id\n    ]);\n  }\n\n  reviewChecksheetSubmission(checksheetSubmission: any) {\n    this.router.navigate([\n      'vehicles/checksheets/checksheets/review',\n      checksheetSubmission.id\n    ]);\n  }\n\n  onScroll() {\n    if (this.pageEvent.page < this.pageEvent.lastPage) {\n      this.pageEvent.page += 1;\n    }\n    this.fetchChecksheetSubmissionsDetails();\n  }\n\n  async fetchChecksheetSubmissionsDetails() {\n    this.spinnerService.show();\n    if (this.vehicle) {\n      this.filters.model_id = this.vehicle.id;\n    }\n\n    try {\n      const result = await this.dataManager.GET(`api/checksheets`, {\n        ...this.pageEvent,\n        ...this.filters\n      });\n      this.checksheetSubmissionList = this.checksheetSubmissionList.concat(\n        result.data\n      );\n      this.pageEvent.page = result.current_page;\n      this.pageEvent.lastPage = result.last_page;\n    } catch (error) {\n      this.alertService.addAlert(\n        'Unable to get Checksheets, try later',\n        'warn'\n      );\n    } finally {\n      this.spinnerService.hide();\n    }\n  }\n\n  reload() {\n    this.pageEvent = { page: 1, perPage: 25, lastPage: 1 };\n    this.checksheetSubmissionList = [];\n    this.fetchChecksheetSubmissionsDetails();\n  }\n\n  getFieldValue(field: string) {\n    return this.filterFormGroup.get(field)?.value;\n  }\n\n  resetFieldValue(field: string, event: any) {\n    event.stopPropagation();\n    this.filterFormGroup.get(field)?.setValue('');\n  }\n\n  /** Method to evaluate form fields*/\n  isFieldValid(field: string) {\n    return this.formValidator.isFieldValid(field, this.filterFormGroup, true);\n  }\n  /** Method to find error in form fields*/\n  getErrorMessage(field: string) {\n    return this.formValidator.getErrorMessage(\n      field,\n      this.filterFormGroup,\n      errorMessages\n    );\n  }\n}\n","<div\n  fxLayout=\"column\"\n  fxLayoutAlign=\"start\"\n  fxLayoutGap=\"1.5rem\"\n  class=\"mat-typography m-4\"\n>\n  <div fxLayout fxLayoutAlign=\"center center\">\n    <h3 class=\"m-0 font-weight-bold mr-3\">\n      Checksheet Report\n\n      <app-export-excel-button\n        class=\"ml-2\"\n        elementId=\"pdfable-section\"\n        name=\"checksheet-report-download\"\n        [data]=\"excelData\"\n      >\n      </app-export-excel-button>\n    </h3>\n  </div>\n\n  <form\n    fxLayout=\"row wrap d-print-none\"\n    fxLayoutGap=\"1rem\"\n    [formGroup]=\"filterFormGroup\"\n  >\n    <mat-form-field>\n      <input\n        matInput\n        [matDatepicker]=\"picker\"\n        placeholder=\"Start Date (MM/DD/YYYY)\"\n        formControlName=\"date_from\"\n        autocomplete=\"off\"\n      />\n      <mat-datepicker-toggle matSuffix [for]=\"picker\"></mat-datepicker-toggle>\n      <mat-datepicker #picker></mat-datepicker>\n      <mat-error *ngIf=\"isFieldValid('date_from')\"\n        >{{ getErrorMessage('date_from') }}\n      </mat-error>\n      <button\n        mat-button\n        *ngIf=\"getFieldValue('date_from')\"\n        matSuffix\n        mat-icon-button\n        (click)=\"resetFieldValue('date_from', $event)\"\n      >\n        <mat-icon>close</mat-icon>\n      </button>\n    </mat-form-field>\n\n    <mat-form-field>\n      <input\n        matInput\n        [matDatepicker]=\"p2\"\n        placeholder=\"End Date (MM/DD/YYYY)\"\n        formControlName=\"date_to\"\n        autocomplete=\"off\"\n      />\n      <mat-datepicker-toggle matSuffix [for]=\"p2\"></mat-datepicker-toggle>\n      <mat-datepicker #p2></mat-datepicker>\n      <mat-error *ngIf=\"isFieldValid('date_to')\"\n        >{{ getErrorMessage('date_to') }}\n      </mat-error>\n      <button\n        mat-button\n        *ngIf=\"getFieldValue('date_to')\"\n        matSuffix\n        mat-icon-button\n        (click)=\"resetFieldValue('date_to', $event)\"\n      >\n        <mat-icon>close</mat-icon>\n      </button>\n    </mat-form-field>\n\n    <mat-form-field>\n      <mat-label>Status</mat-label>\n      <app-searchable-selector\n        formControlName=\"status_id\"\n        apiUrl=\"api/checksheet-submission-statuses\"\n        [enableSearch]=\"false\"\n      >\n      </app-searchable-selector>\n      <mat-icon\n        matSuffix\n        *ngIf=\"getFieldValue('status_id')\"\n        (click)=\"resetFieldValue('status_id', $event)\"\n      >\n        close</mat-icon\n      >\n    </mat-form-field>\n\n    <mat-form-field *ngIf=\"!vehicle\">\n      <mat-label>Vehicle</mat-label>\n      <app-searchable-selector\n        formControlName=\"model_id\"\n        apiUrl=\"api/vehicles\"\n        [enableSearch]=\"true\"\n        titleField=\"title_field\"\n        [sort]=\"false\"\n      >\n      </app-searchable-selector>\n      <mat-icon\n        matSuffix\n        *ngIf=\"getFieldValue('model_id')\"\n        (click)=\"resetFieldValue('model_id', $event)\"\n      >\n        close</mat-icon\n      >\n    </mat-form-field>\n\n    <mat-form-field>\n      <mat-label>Creator</mat-label>\n      <app-searchable-selector\n        formControlName=\"creator_id\"\n        apiUrl=\"api/users\"\n        [enableSearch]=\"true\"\n        titleField=\"name\"\n      >\n      </app-searchable-selector>\n      <mat-icon\n        matSuffix\n        *ngIf=\"getFieldValue('creator_id')\"\n        (click)=\"resetFieldValue('creator_id', $event)\"\n      >\n        close</mat-icon\n      >\n    </mat-form-field>\n\n    <mat-form-field>\n      <mat-label>Reviewer</mat-label>\n      <app-searchable-selector\n        formControlName=\"reviewer_id\"\n        apiUrl=\"api/users\"\n        [enableSearch]=\"true\"\n        titleField=\"name\"\n      >\n      </app-searchable-selector>\n      <mat-icon\n        matSuffix\n        *ngIf=\"getFieldValue('reviewer_id')\"\n        (click)=\"resetFieldValue('reviewer_id', $event)\"\n      >\n        close</mat-icon\n      >\n    </mat-form-field>\n\n    <mat-form-field>\n      <mat-label>Checksheet Format</mat-label>\n      <app-searchable-selector\n        formControlName=\"checksheet_format_id\"\n        apiUrl=\"api/checksheet-formats?is_published=true\"\n        [enableSearch]=\"true\"\n      >\n      </app-searchable-selector>\n      <mat-icon\n        matSuffix\n        *ngIf=\"getFieldValue('checksheet_format_id')\"\n        (click)=\"resetFieldValue('checksheet_format_id', $event)\"\n      >\n        close</mat-icon\n      >\n    </mat-form-field>\n\n    <mat-form-field>\n      <mat-label>Vehicle Assigned Customer</mat-label>\n      <app-searchable-selector\n        formControlName=\"vehicle_assigned_customer_id\"\n        apiUrl=\"api/customers\"\n        [enableSearch]=\"true\"\n        titleField=\"name\"\n      >\n      </app-searchable-selector>\n      <mat-icon\n        matSuffix\n        *ngIf=\"getFieldValue('vehicle_assigned_customer_id')\"\n        (click)=\"resetFieldValue('vehicle_assigned_customer_id', $event)\"\n      >\n        close</mat-icon\n      >\n    </mat-form-field>\n\n    <!-- <mat-form-field>\n            <mat-label>Driver Assigned Customer</mat-label>\n            <app-searchable-selector formControlName=\"driver_assigned_customer_id\" apiUrl=\"api/customers\"\n                [enableSearch]=\"true\" titleField=\"name\">\n            </app-searchable-selector>\n            <mat-icon matSuffix *ngIf=\"getFieldValue('driver_assigned_customer_id')\"\n                (click)=\"resetFieldValue('driver_assigned_customer_id', $event)\">\n                close</mat-icon>\n        </mat-form-field> -->\n  </form>\n\n  <div\n    id=\"pdfable-section\"\n    class=\"scroll-container\"\n    infiniteScroll\n    [infiniteScrollDistance]=\"2\"\n    [infiniteScrollThrottle]=\"50\"\n    (scrolled)=\"onScroll()\"\n    [scrollWindow]=\"false\"\n  >\n    <table\n      mat-table\n      [dataSource]=\"checksheetSubmissionList\"\n      class=\"w-100\"\n      multiTemplateDataRows\n    >\n      <!-- Index Column -->\n      <ng-container matColumnDef=\"index\">\n        <th mat-header-cell *matHeaderCellDef>#</th>\n        <td mat-cell *matCellDef=\"let element; let i = dataIndex\">\n          {{ i + 1 }}\n        </td>\n      </ng-container>\n\n      <!-- Date Column -->\n      <ng-container matColumnDef=\"date\">\n        <th mat-header-cell *matHeaderCellDef>Date</th>\n        <td mat-cell *matCellDef=\"let element\">\n          {{ element.date | date : 'mediumDate' }}\n        </td>\n      </ng-container>\n\n      <!-- Vehicle Column -->\n      <ng-container matColumnDef=\"vehicle\">\n        <th mat-header-cell *matHeaderCellDef>Vehicle</th>\n        <td mat-cell *matCellDef=\"let element\">\n          {{ element.vehicle?.title_field }}\n        </td>\n      </ng-container>\n\n      <!-- Category Column -->\n      <ng-container matColumnDef=\"created_at\">\n        <th mat-header-cell *matHeaderCellDef>Submitted On</th>\n        <td mat-cell *matCellDef=\"let element\">\n          {{ element.created_at | date : 'mediumDate' }}\n          {{ element.created_at | date : 'shortTime' }} <br />\n          <small>by {{ element.creator?.name }}</small>\n        </td>\n      </ng-container>\n\n      <!-- Category Column -->\n      <ng-container matColumnDef=\"reviewer.name\">\n        <th mat-header-cell *matHeaderCellDef>Verified By</th>\n        <td mat-cell *matCellDef=\"let element\">\n          {{ element.reviewer?.name }} <br />\n          <small *ngIf=\"element.reviewed_at\">\n            on {{ element.reviewed_at | date : 'mediumDate' }}\n            {{ element.reviewed_at | date : 'shortTime' }}\n          </small>\n        </td>\n      </ng-container>\n\n      <!-- Category Column -->\n      <ng-container matColumnDef=\"mechanical_issues\">\n        <th mat-header-cell *matHeaderCellDef>Mechanical Issues</th>\n        <td mat-cell *matCellDef=\"let element\" class=\"w-50\">\n          <ul>\n            <li\n              *ngFor=\"let issue of element?.mechanical_issues\"\n              [innerHTML]=\"issue.details_without_html\"\n            ></li>\n          </ul>\n        </td>\n      </ng-container>\n\n      <!-- Category Column -->\n      <ng-container matColumnDef=\"notes\">\n        <th mat-header-cell *matHeaderCellDef>Notes</th>\n        <td mat-cell *matCellDef=\"let element\">\n          {{ element.comments }}\n        </td>\n      </ng-container>\n\n      <tr mat-header-row *matHeaderRowDef=\"displayedColumns\"></tr>\n      <tr mat-row *matRowDef=\"let row; columns: displayedColumns\"></tr>\n    </table>\n  </div>\n</div>\n"]}
|