cat-documents-ng 0.0.5 → 0.0.7

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.
Files changed (75) hide show
  1. package/.github/PULL_REQUEST_TEMPLATE.md +32 -0
  2. package/.github/workflows/pr-validation.yml +87 -0
  3. package/.husky/pre-commit +4 -0
  4. package/README.md +59 -63
  5. package/angular.json +119 -0
  6. package/eslint.config.cjs +148 -0
  7. package/package.json +66 -19
  8. package/projects/cat-document-lib/README.md +63 -0
  9. package/{jest.config.mjs → projects/cat-document-lib/jest.config.mjs} +18 -18
  10. package/{ng-package.json → projects/cat-document-lib/ng-package.json} +10 -10
  11. package/projects/cat-document-lib/package-lock.json +599 -0
  12. package/projects/cat-document-lib/package.json +19 -0
  13. package/{setup-jest.ts → projects/cat-document-lib/setup-jest.ts} +9 -9
  14. package/{src/shared → projects/cat-document-lib/src/Shared}/constant/SHARED.ts +231 -231
  15. package/{src/shared → projects/cat-document-lib/src/Shared}/constant/URLS.ts +31 -31
  16. package/{src/shared → projects/cat-document-lib/src/Shared}/services/app-config.service.spec.ts +16 -16
  17. package/{src/shared → projects/cat-document-lib/src/Shared}/services/app-config.service.ts +73 -73
  18. package/{src/shared → projects/cat-document-lib/src/Shared}/services/global-error.handler.ts +29 -29
  19. package/{src → projects/cat-document-lib/src}/lib/document/components/document-container/document-container.component.html +5 -5
  20. package/{src → projects/cat-document-lib/src}/lib/document/components/document-container/document-container.component.ts +82 -82
  21. package/{src → projects/cat-document-lib/src}/lib/document/components/document-list/document-list.component.html +34 -34
  22. package/{src → projects/cat-document-lib/src}/lib/document/components/document-list/document-list.component.scss +11 -11
  23. package/{src → projects/cat-document-lib/src}/lib/document/components/document-list/document-list.component.ts +73 -73
  24. package/{src → projects/cat-document-lib/src}/lib/document/components/document-list-item/document-list-item.component.html +32 -32
  25. package/{src → projects/cat-document-lib/src}/lib/document/components/document-list-item/document-list-item.component.scss +21 -21
  26. package/{src → projects/cat-document-lib/src}/lib/document/components/document-list-item/document-list-item.component.spec.ts +23 -23
  27. package/{src → projects/cat-document-lib/src}/lib/document/components/document-list-item/document-list-item.component.ts +40 -40
  28. package/{src → projects/cat-document-lib/src}/lib/document/components/document-upload/document-upload.component.html +55 -55
  29. package/{src → projects/cat-document-lib/src}/lib/document/components/document-upload/document-upload.component.scss +26 -26
  30. package/{src → projects/cat-document-lib/src}/lib/document/components/document-upload/document-upload.component.spec.ts +24 -24
  31. package/{src → projects/cat-document-lib/src}/lib/document/components/document-upload/document-upload.component.ts +184 -184
  32. package/{src → projects/cat-document-lib/src}/lib/document/components/document-viewer/document-viewer.component.html +244 -244
  33. package/{src → projects/cat-document-lib/src}/lib/document/components/document-viewer/document-viewer.component.scss +35 -35
  34. package/{src → projects/cat-document-lib/src}/lib/document/components/document-viewer/document-viewer.component.spec.ts +21 -21
  35. package/{src → projects/cat-document-lib/src}/lib/document/components/document-viewer/document-viewer.component.ts +125 -125
  36. package/{src → projects/cat-document-lib/src}/lib/document/components/folder-block/folder-block.component.html +46 -46
  37. package/{src → projects/cat-document-lib/src}/lib/document/components/folder-block/folder-block.component.ts +51 -51
  38. package/{src → projects/cat-document-lib/src}/lib/document/components/folder-container/folder-container.component.html +1 -1
  39. package/{src → projects/cat-document-lib/src}/lib/document/components/folder-container/folder-container.component.ts +29 -29
  40. package/{src → projects/cat-document-lib/src}/lib/document/document.module.ts +191 -191
  41. package/{src → projects/cat-document-lib/src}/lib/document/models/document.model.ts +39 -39
  42. package/{src → projects/cat-document-lib/src}/lib/document/models/folder.model.ts +35 -35
  43. package/{src → projects/cat-document-lib/src}/lib/document/services/file-format.service.spec.ts +16 -16
  44. package/{src → projects/cat-document-lib/src}/lib/document/services/file-format.service.ts +41 -41
  45. package/{src → projects/cat-document-lib/src}/lib/document/state/document.query.ts +23 -23
  46. package/{src → projects/cat-document-lib/src}/lib/document/state/document.service.ts +95 -95
  47. package/{src → projects/cat-document-lib/src}/lib/document/state/document.state.ts +39 -39
  48. package/{src → projects/cat-document-lib/src}/lib/document/state/document.store.ts +23 -23
  49. package/{src → projects/cat-document-lib/src}/public-api.ts +8 -8
  50. package/{tsconfig.lib.json → projects/cat-document-lib/tsconfig.lib.json} +15 -15
  51. package/{tsconfig.lib.prod.json → projects/cat-document-lib/tsconfig.lib.prod.json} +11 -11
  52. package/{tsconfig.spec.json → projects/cat-document-lib/tsconfig.spec.json} +15 -15
  53. package/public/favicon.ico +0 -0
  54. package/src/app/app.component.html +1 -0
  55. package/src/app/app.component.scss +0 -0
  56. package/src/app/app.component.spec.ts +29 -0
  57. package/src/app/app.component.ts +15 -0
  58. package/src/app/app.module.ts +60 -0
  59. package/src/app/app.routing.module.ts +19 -0
  60. package/src/index.html +13 -0
  61. package/src/main.ts +5 -0
  62. package/src/styles.scss +39 -0
  63. package/tsconfig.app.json +15 -0
  64. package/tsconfig.json +32 -0
  65. package/src/assets/config/app.config.json +0 -4
  66. /package/{src → projects/cat-document-lib/src}/assets/images/FolderImg.png +0 -0
  67. /package/{src → projects/cat-document-lib/src}/assets/images/Frame.png +0 -0
  68. /package/{src → projects/cat-document-lib/src}/assets/images/document.png +0 -0
  69. /package/{src → projects/cat-document-lib/src}/lib/document/components/document-container/document-container.component.scss +0 -0
  70. /package/{src → projects/cat-document-lib/src}/lib/document/components/document-container/document-container.component.spec.ts +0 -0
  71. /package/{src → projects/cat-document-lib/src}/lib/document/components/document-list/document-list.component.spec.ts +0 -0
  72. /package/{src → projects/cat-document-lib/src}/lib/document/components/folder-block/folder-block.component.scss +0 -0
  73. /package/{src → projects/cat-document-lib/src}/lib/document/components/folder-block/folder-block.component.spec.ts +0 -0
  74. /package/{src → projects/cat-document-lib/src}/lib/document/components/folder-container/folder-container.component.scss +0 -0
  75. /package/{src → projects/cat-document-lib/src}/lib/document/components/folder-container/folder-container.component.spec.ts +0 -0
@@ -1,33 +1,33 @@
1
- <div class="grid">
2
- <div
3
- class="col-12 flex align-items-center justify-content-between md:col-6 xl:col-12"
4
- >
5
- <div
6
- class="col-5 flex cursor-pointer align-items-center pl-0"
7
- (click)="handleOpenDocument(document)"
8
- >
9
- <img src="../../../../assets/images/Frame.png" alt="" />
10
- <span class="ml-4">{{ document.fileName }}</span>
11
- </div>
12
- <div class="col-4 flex align-items-center justify-content-center">
13
- <span
14
- [class]="'product-badge status-' + document.status?.toLowerCase()"
15
- class="flex align-items-center justify-content-center pl-2 pr-2 pt-1 pb-1 "
16
- >
17
- <ng-container *ngIf="document.status?.toLowerCase() === 'pending'">
18
- <i class="pi pi-clock pr-1" style="font-size: 12px;"></i>
19
- Pending
20
- </ng-container>
21
- <ng-container *ngIf="document.status?.toLowerCase() === 'verified'">
22
- <i class="pi pi-check-circle pr-1" style="font-size: 12px;"></i>
23
- Verified
24
- </ng-container>
25
- <ng-container *ngIf="document.status?.toLowerCase() === 'sentreminder'">
26
- <i class="pi pi-bell pr-1" style="font-size: 12px;"></i>
27
- Sent Reminder
28
- </ng-container>
29
- </span>
30
- </div>
31
- </div>
32
- </div>
1
+ <div class="grid">
2
+ <div
3
+ class="col-12 flex align-items-center justify-content-between md:col-6 xl:col-12"
4
+ >
5
+ <div
6
+ class="col-5 flex cursor-pointer align-items-center pl-0"
7
+ (click)="handleOpenDocument(document)"
8
+ >
9
+ <img src="../../../../assets/images/Frame.png" alt="" />
10
+ <span class="ml-4">{{ document.fileName }}</span>
11
+ </div>
12
+ <div class="col-4 flex align-items-center justify-content-center">
13
+ <span
14
+ [class]="'product-badge status-' + document.status?.toLowerCase()"
15
+ class="flex align-items-center justify-content-center pl-2 pr-2 pt-1 pb-1 "
16
+ >
17
+ <ng-container *ngIf="document.status?.toLowerCase() === 'pending'">
18
+ <i class="pi pi-clock pr-1" style="font-size: 12px;"></i>
19
+ Pending
20
+ </ng-container>
21
+ <ng-container *ngIf="document.status?.toLowerCase() === 'verified'">
22
+ <i class="pi pi-check-circle pr-1" style="font-size: 12px;"></i>
23
+ Verified
24
+ </ng-container>
25
+ <ng-container *ngIf="document.status?.toLowerCase() === 'sentreminder'">
26
+ <i class="pi pi-bell pr-1" style="font-size: 12px;"></i>
27
+ Sent Reminder
28
+ </ng-container>
29
+ </span>
30
+ </div>
31
+ </div>
32
+ </div>
33
33
 
@@ -1,22 +1,22 @@
1
- .product-badge.status-pending {
2
- background: #e9b127;
3
- color: #ffffff;
4
- border-radius: 4px;
5
- }
6
- .product-badge.status-verified {
7
- background: #4caf50;
8
- color: #ffffff;
9
- border-radius: 4px;
10
- }
11
- .product-badge.status-sentreminder {
12
- background: #f57c00;
13
- color: #ffffff;
14
- border-radius: 4px;
15
- }
16
- .product-badge {
17
- text-transform: none;
18
- font-weight: 500;
19
- font-size: 12px;
20
-
21
- }
1
+ .product-badge.status-pending {
2
+ background: #e9b127;
3
+ color: #ffffff;
4
+ border-radius: 4px;
5
+ }
6
+ .product-badge.status-verified {
7
+ background: #4caf50;
8
+ color: #ffffff;
9
+ border-radius: 4px;
10
+ }
11
+ .product-badge.status-sentreminder {
12
+ background: #f57c00;
13
+ color: #ffffff;
14
+ border-radius: 4px;
15
+ }
16
+ .product-badge {
17
+ text-transform: none;
18
+ font-weight: 500;
19
+ font-size: 12px;
20
+
21
+ }
22
22
 
@@ -1,23 +1,23 @@
1
- import { ComponentFixture, TestBed } from '@angular/core/testing';
2
- import { DocumentListItemComponent } from './document-list-item.component';
3
- import { CommonModule } from '@angular/common';
4
-
5
- describe('DocumentListItemComponent', () => {
6
- let component: DocumentListItemComponent;
7
- let fixture: ComponentFixture<DocumentListItemComponent>;
8
-
9
- beforeEach(async () => {
10
- await TestBed.configureTestingModule({
11
- declarations: [DocumentListItemComponent],
12
- imports: [CommonModule], // Use CommonModule instead of BrowserModule
13
- }).compileComponents();
14
-
15
- fixture = TestBed.createComponent(DocumentListItemComponent);
16
- component = fixture.componentInstance;
17
- fixture.detectChanges();
18
- });
19
-
20
- it('should create', () => {
21
- expect(component).toBeTruthy();
22
- });
23
- });
1
+ import { ComponentFixture, TestBed } from '@angular/core/testing';
2
+ import { DocumentListItemComponent } from './document-list-item.component';
3
+ import { CommonModule } from '@angular/common';
4
+
5
+ describe('DocumentListItemComponent', () => {
6
+ let component: DocumentListItemComponent;
7
+ let fixture: ComponentFixture<DocumentListItemComponent>;
8
+
9
+ beforeEach(async () => {
10
+ await TestBed.configureTestingModule({
11
+ declarations: [DocumentListItemComponent],
12
+ imports: [CommonModule], // Use CommonModule instead of BrowserModule
13
+ }).compileComponents();
14
+
15
+ fixture = TestBed.createComponent(DocumentListItemComponent);
16
+ component = fixture.componentInstance;
17
+ fixture.detectChanges();
18
+ });
19
+
20
+ it('should create', () => {
21
+ expect(component).toBeTruthy();
22
+ });
23
+ });
@@ -1,40 +1,40 @@
1
- import { Component, EventEmitter, Input, Output } from '@angular/core';
2
- import { DocumentModel } from '../../models/document.model';
3
-
4
- /**
5
- * DocumentListItemComponent
6
- *
7
- * This component displays individual document items within a list.
8
- * It accepts a list of documents as input and handles interactions with documents.
9
- */
10
- @Component({
11
- selector: 'lib-document-list-item',
12
- standalone: false,
13
- templateUrl: './document-list-item.component.html',
14
- styleUrls: ['./document-list-item.component.scss']
15
- })
16
- export class DocumentListItemComponent {
17
- /**
18
- * Emit the selected document.
19
- * @type {EventEmitter<DocumentModel>}
20
- */
21
- @Output() documentClick = new EventEmitter<DocumentModel>();
22
-
23
- /**
24
- * The document to display.
25
- * @type {DocumentModel[]}
26
- */
27
- @Input() document!: DocumentModel;
28
-
29
- /**
30
- * Handles interactions with a document.
31
- * @param {DocumentModel} document - The document to be opened or interacted with.
32
- */
33
- handleOpenDocument(document: DocumentModel): void {
34
- if (!document) {
35
- console.error('Error: Document is null or undefined:', document);
36
- return;
37
- }
38
- this.documentClick.emit(document);
39
- }
40
- }
1
+ import { Component, EventEmitter, Input, Output } from '@angular/core';
2
+ import { DocumentModel } from '../../models/document.model';
3
+
4
+ /**
5
+ * DocumentListItemComponent
6
+ *
7
+ * This component displays individual document items within a list.
8
+ * It accepts a list of documents as input and handles interactions with documents.
9
+ */
10
+ @Component({
11
+ selector: 'lib-document-list-item',
12
+ standalone: false,
13
+ templateUrl: './document-list-item.component.html',
14
+ styleUrls: ['./document-list-item.component.scss']
15
+ })
16
+ export class DocumentListItemComponent {
17
+ /**
18
+ * Emit the selected document.
19
+ * @type {EventEmitter<DocumentModel>}
20
+ */
21
+ @Output() documentClick = new EventEmitter<DocumentModel>();
22
+
23
+ /**
24
+ * The document to display.
25
+ * @type {DocumentModel[]}
26
+ */
27
+ @Input() document!: DocumentModel;
28
+
29
+ /**
30
+ * Handles interactions with a document.
31
+ * @param {DocumentModel} document - The document to be opened or interacted with.
32
+ */
33
+ handleOpenDocument(document: DocumentModel): void {
34
+ if (!document) {
35
+ console.error('Error: Document is null or undefined:', document);
36
+ return;
37
+ }
38
+ this.documentClick.emit(document);
39
+ }
40
+ }
@@ -1,56 +1,56 @@
1
- <div class="grid">
2
- <div class="col-12 md:col-12">
3
- <p-fileUpload #fileUploader [multiple]="true" auto="true" accept="image/png,application/pdf" maxFileSize="1000000"
4
- (onSelect)="onSelectedFiles($event)">
5
- <ng-template pTemplate="header" let-chooseCallback="chooseCallback" let-clearCallback="clearCallback">
6
- <div class="p-2 flex flex-wrap justify-content-between align-items-center flex-1 gap-2">
7
- <div class="flex gap-2">
8
- <p-button (onClick)="choose($event, chooseCallback)" icon="pi pi-images" [rounded]="true"
9
- [outlined]="true" />
10
- </div>
11
- </div>
12
- </ng-template>
13
- <ng-template pTemplate="content" let-removeFileCallback="removeFileCallback"
14
- let-removeUploadedFileCallback="removeUploadedFileCallback">
15
- <div class="col-12 md:col-12 p-0">
16
- <div class="col-12 md:col-12 p-0" *ngIf="uploadedFiles.length > 0">
17
- <div *ngFor="let file of uploadedFiles; let i = index"
18
- class="m-0 flex flex-column align-items-center gap-1 mt-3">
19
- <div class="col-12 md:col-12 p-0 flex documentInfo">
20
- <div class="documentImage">
21
- <img src="../../../../assets/images/document.png" [alt]="file.name" width="45"
22
- height="50" class="object-contain" />
23
- </div>
24
- <div class="flex w-full flex-column mt-2 ml-2">
25
- <div class="flex justify-content-between">
26
- <div style=" font-weight: bold;font-size: 14px">
27
- {{ file.fileName }}
28
- </div>
29
- <i class="pi pi-times cursor-pointer" (click)="handleDocumentRemove(file,i)"></i>
30
- </div>
31
- <div class="flex justify-content-between mt-1">
32
- <div style="color: #676B89; font-size: 12px;"></div>
33
- <div class="white-space-nowrap" style="color: #0F8BFD; font-family: 14px;">{{ getProgress(file) }} %
34
- </div>
35
- </div>
36
- </div>
37
- </div>
38
- <div class="col-12 md:col-12 p-0">
39
- <p-progressBar [value]="totalSizePercent" [showValue]="false" styleClass="h-1/2rem md:ml-auto relative"
40
- [ngClass]="{ 'exceeded-progress-bar': totalSizePercent > 100 }">
41
- </p-progressBar>
42
- </div>
43
- </div>
44
- </div>
45
- </div>
46
- </ng-template>
47
- <ng-template pTemplate="empty" let-chooseCallback="chooseCallback" >
48
- <div *ngIf="!uploadedFiles.length" class="flex align-items-center justify-content-center flex-column" (click)="triggerFileUpload()">
49
- <i class="pi pi-cloud-upload border-2 border-circle p-5 text-8xl text-400 border-400"></i>
50
- <p class="mt-4 mb-0">Drag and drop files here to upload.</p>
51
- </div>
52
- </ng-template>
53
- <ng-template pTemplate="file"> </ng-template>
54
- </p-fileUpload>
55
- </div>
1
+ <div class="grid">
2
+ <div class="col-12 md:col-12">
3
+ <p-fileUpload #fileUploader [multiple]="true" auto="true" accept="image/png,application/pdf" maxFileSize="1000000"
4
+ (onSelect)="onSelectedFiles($event)">
5
+ <ng-template pTemplate="header" let-chooseCallback="chooseCallback" let-clearCallback="clearCallback">
6
+ <div class="p-2 flex flex-wrap justify-content-between align-items-center flex-1 gap-2">
7
+ <div class="flex gap-2">
8
+ <p-button (onClick)="choose($event, chooseCallback)" icon="pi pi-images" [rounded]="true"
9
+ [outlined]="true" />
10
+ </div>
11
+ </div>
12
+ </ng-template>
13
+ <ng-template pTemplate="content" let-removeFileCallback="removeFileCallback"
14
+ let-removeUploadedFileCallback="removeUploadedFileCallback">
15
+ <div class="col-12 md:col-12 p-0">
16
+ <div class="col-12 md:col-12 p-0" *ngIf="uploadedFiles.length > 0">
17
+ <div *ngFor="let file of uploadedFiles; let i = index"
18
+ class="m-0 flex flex-column align-items-center gap-1 mt-3">
19
+ <div class="col-12 md:col-12 p-0 flex documentInfo">
20
+ <div class="documentImage">
21
+ <img src="../../../../assets/images/document.png" [alt]="file.name" width="45"
22
+ height="50" class="object-contain" />
23
+ </div>
24
+ <div class="flex w-full flex-column mt-2 ml-2">
25
+ <div class="flex justify-content-between">
26
+ <div style=" font-weight: bold;font-size: 14px">
27
+ {{ file.fileName }}
28
+ </div>
29
+ <i class="pi pi-times cursor-pointer" (click)="handleDocumentRemove(file,i)"></i>
30
+ </div>
31
+ <div class="flex justify-content-between mt-1">
32
+ <div style="color: #676B89; font-size: 12px;"></div>
33
+ <div class="white-space-nowrap" style="color: #0F8BFD; font-family: 14px;">{{ getProgress(file) }} %
34
+ </div>
35
+ </div>
36
+ </div>
37
+ </div>
38
+ <div class="col-12 md:col-12 p-0">
39
+ <p-progressBar [value]="totalSizePercent" [showValue]="false" styleClass="h-1/2rem md:ml-auto relative"
40
+ [ngClass]="{ 'exceeded-progress-bar': totalSizePercent > 100 }">
41
+ </p-progressBar>
42
+ </div>
43
+ </div>
44
+ </div>
45
+ </div>
46
+ </ng-template>
47
+ <ng-template pTemplate="empty" let-chooseCallback="chooseCallback" >
48
+ <div *ngIf="!uploadedFiles.length" class="flex align-items-center justify-content-center flex-column" (click)="triggerFileUpload()">
49
+ <i class="pi pi-cloud-upload border-2 border-circle p-5 text-8xl text-400 border-400"></i>
50
+ <p class="mt-4 mb-0">Drag and drop files here to upload.</p>
51
+ </div>
52
+ </ng-template>
53
+ <ng-template pTemplate="file"> </ng-template>
54
+ </p-fileUpload>
55
+ </div>
56
56
  </div>
@@ -1,26 +1,26 @@
1
- .flex {
2
- display: flex;
3
- }
4
- .items-center {
5
- align-items: center;
6
- }
7
- .justify-center {
8
- justify-content: center;
9
- }
10
- .flex-col {
11
- flex-direction: column;
12
- }
13
- .text-muted-color {
14
- color: #6c757d; // Adjust to match your theme
15
- }
16
- .p-fileupload-buttonbar {
17
- padding: 0px;
18
- }
19
- .p-fileupload-content {
20
- background-color: #0f8bfd1a;
21
- }
22
- .p-fileupload {
23
- .p-fileupload-content {
24
- padding: 1rem 1rem;
25
- }
26
- }
1
+ .flex {
2
+ display: flex;
3
+ }
4
+ .items-center {
5
+ align-items: center;
6
+ }
7
+ .justify-center {
8
+ justify-content: center;
9
+ }
10
+ .flex-col {
11
+ flex-direction: column;
12
+ }
13
+ .text-muted-color {
14
+ color: #6c757d; // Adjust to match your theme
15
+ }
16
+ .p-fileupload-buttonbar {
17
+ padding: 0px;
18
+ }
19
+ .p-fileupload-content {
20
+ background-color: #0f8bfd1a;
21
+ }
22
+ .p-fileupload {
23
+ .p-fileupload-content {
24
+ padding: 1rem 1rem;
25
+ }
26
+ }
@@ -1,24 +1,24 @@
1
- import { ComponentFixture, TestBed } from '@angular/core/testing';
2
-
3
- import { DocumentUploadComponent } from './document-upload.component';
4
-
5
- describe('DocumentUploadComponent', () => {
6
- let component: DocumentUploadComponent;
7
- let fixture: ComponentFixture<DocumentUploadComponent>;
8
-
9
- beforeEach(async () => {
10
- await TestBed.configureTestingModule({
11
- imports: [DocumentUploadComponent]
12
- })
13
- .compileComponents();
14
-
15
- fixture = TestBed.createComponent(DocumentUploadComponent);
16
- component = fixture.componentInstance;
17
- fixture.detectChanges();
18
- });
19
-
20
- it('should create', () => {
21
- expect(component).toBeTruthy();
22
- });
23
-
24
- });
1
+ import { ComponentFixture, TestBed } from '@angular/core/testing';
2
+
3
+ import { DocumentUploadComponent } from './document-upload.component';
4
+
5
+ describe('DocumentUploadComponent', () => {
6
+ let component: DocumentUploadComponent;
7
+ let fixture: ComponentFixture<DocumentUploadComponent>;
8
+
9
+ beforeEach(async () => {
10
+ await TestBed.configureTestingModule({
11
+ imports: [DocumentUploadComponent]
12
+ })
13
+ .compileComponents();
14
+
15
+ fixture = TestBed.createComponent(DocumentUploadComponent);
16
+ component = fixture.componentInstance;
17
+ fixture.detectChanges();
18
+ });
19
+
20
+ it('should create', () => {
21
+ expect(component).toBeTruthy();
22
+ });
23
+
24
+ });