Un début d'ajout pour uploader des images
This commit is contained in:
@@ -0,0 +1,18 @@
|
||||
<form [formGroup]="imgForm" (ngSubmit)="onSubmit(imgForm.value)" autocomplete="off" style="padding: 10px;">
|
||||
<p>
|
||||
<input type="file" #fileUpload id="fileUpload" name="fileUpload" accept="image/*" style="display: none"
|
||||
formControlName="image" (change)="onFileChanged($event)" />
|
||||
<button (click)="fileUpload.click()">Select File</button>
|
||||
</p>
|
||||
<p>
|
||||
<mat-form-field>
|
||||
<mat-label>Comment about the image</mat-label>
|
||||
<input matInput type="text" formControlName="comment" />
|
||||
</mat-form-field>
|
||||
</p>
|
||||
|
||||
<button mat-button color="warn" type="submit">
|
||||
<mat-icon>file_upload</mat-icon>
|
||||
Upload image
|
||||
</button>
|
||||
</form>
|
||||
@@ -0,0 +1,25 @@
|
||||
import { async, ComponentFixture, TestBed } from '@angular/core/testing';
|
||||
|
||||
import { ListOfImagesComponent } from './list-of-images.component';
|
||||
|
||||
describe('ListOfImagesComponent', () => {
|
||||
let component: ListOfImagesComponent;
|
||||
let fixture: ComponentFixture<ListOfImagesComponent>;
|
||||
|
||||
beforeEach(async(() => {
|
||||
TestBed.configureTestingModule({
|
||||
declarations: [ ListOfImagesComponent ]
|
||||
})
|
||||
.compileComponents();
|
||||
}));
|
||||
|
||||
beforeEach(() => {
|
||||
fixture = TestBed.createComponent(ListOfImagesComponent);
|
||||
component = fixture.componentInstance;
|
||||
fixture.detectChanges();
|
||||
});
|
||||
|
||||
it('should create', () => {
|
||||
expect(component).toBeTruthy();
|
||||
});
|
||||
});
|
||||
@@ -0,0 +1,63 @@
|
||||
import { Component, OnInit, ViewChild } from "@angular/core";
|
||||
import { FormGroup, FormControl, Validators } from "@angular/forms";
|
||||
import { MatTableDataSource } from "@angular/material/table";
|
||||
import { MatPaginator } from "@angular/material/paginator";
|
||||
|
||||
import { ImageService } from "../../services/image.service";
|
||||
import { ServiceComm } from "../../services/service-comm.service";
|
||||
import { ImageResp } from "../../models/Image";
|
||||
import { AddAction } from "../../models/add-action.enum";
|
||||
|
||||
@Component({
|
||||
selector: "app-list-of-images",
|
||||
templateUrl: "./list-of-images.component.html",
|
||||
styleUrls: ["./list-of-images.component.css"],
|
||||
})
|
||||
export class ListOfImagesComponent implements OnInit {
|
||||
public imgForm: FormGroup;
|
||||
private selectedFile: File;
|
||||
public dataSourceTable: MatTableDataSource<ImageResp>;
|
||||
public resultsLength = 0;
|
||||
@ViewChild(MatPaginator, { static: true }) paginator: MatPaginator;
|
||||
|
||||
constructor(
|
||||
private serviceApi: ImageService,
|
||||
private serviceComm: ServiceComm
|
||||
) {}
|
||||
|
||||
ngOnInit(): void {
|
||||
this.serviceComm.refreshRequest.subscribe((action) => {
|
||||
if (action === AddAction.Gear) {
|
||||
this.getListOfImages();
|
||||
}
|
||||
});
|
||||
this.getListOfImages();
|
||||
|
||||
this.imgForm = new FormGroup({
|
||||
comment: new FormControl("", Validators.required),
|
||||
image: new FormControl("", Validators.required),
|
||||
});
|
||||
}
|
||||
|
||||
getListOfImages() {
|
||||
this.serviceApi.getListOfImages().subscribe((data) => {
|
||||
setTimeout(() => {
|
||||
this.dataSourceTable = new MatTableDataSource<ImageResp>(data);
|
||||
this.dataSourceTable.paginator = this.paginator;
|
||||
this.resultsLength = data.length;
|
||||
}, 500);
|
||||
});
|
||||
}
|
||||
|
||||
onFileChanged(event) {
|
||||
this.selectedFile = event.target.files[0];
|
||||
}
|
||||
|
||||
onSubmit(formData) {
|
||||
if (this.imgForm.invalid) {
|
||||
return;
|
||||
}
|
||||
|
||||
this.serviceApi.AddImage(formData.comment, this.selectedFile);
|
||||
}
|
||||
}
|
||||
Reference in New Issue
Block a user