Un début d'ajout pour uploader des images
This commit is contained in:
@@ -32,6 +32,7 @@ import { StatsService } from "../services/stats.service";
|
|||||||
import { ServiceComm } from "../services/service-comm.service";
|
import { ServiceComm } from "../services/service-comm.service";
|
||||||
import { RequestCache } from "../services/request-cache.service";
|
import { RequestCache } from "../services/request-cache.service";
|
||||||
import { AuthGuardService } from "../services/auth-guard.service";
|
import { AuthGuardService } from "../services/auth-guard.service";
|
||||||
|
import { ImageService } from "../services/image.service";
|
||||||
|
|
||||||
import { BrowserAnimationsModule } from "@angular/platform-browser/animations";
|
import { BrowserAnimationsModule } from "@angular/platform-browser/animations";
|
||||||
import { FormsModule, ReactiveFormsModule } from "@angular/forms";
|
import { FormsModule, ReactiveFormsModule } from "@angular/forms";
|
||||||
@@ -57,6 +58,7 @@ import { CachingInterceptor } from "../interceptor/caching.interceptor";
|
|||||||
import { JwtAuthInterceptor } from "../interceptor/jwt-auth.interceptor";
|
import { JwtAuthInterceptor } from "../interceptor/jwt-auth.interceptor";
|
||||||
import { ErrorInterceptor } from "../interceptor/error.interceptor";
|
import { ErrorInterceptor } from "../interceptor/error.interceptor";
|
||||||
import { UserProfileComponent } from "./user-profile/user-profile.component";
|
import { UserProfileComponent } from "./user-profile/user-profile.component";
|
||||||
|
import { ListOfImagesComponent } from "./list-of-images/list-of-images.component";
|
||||||
|
|
||||||
const appRoutes: Routes = [
|
const appRoutes: Routes = [
|
||||||
{ path: "", component: DefaultComponent, canActivate: [AuthGuardService] },
|
{ path: "", component: DefaultComponent, canActivate: [AuthGuardService] },
|
||||||
@@ -126,6 +128,7 @@ const appRoutes: Routes = [
|
|||||||
CreateUserComponent,
|
CreateUserComponent,
|
||||||
LoginUserComponent,
|
LoginUserComponent,
|
||||||
UserProfileComponent,
|
UserProfileComponent,
|
||||||
|
ListOfImagesComponent,
|
||||||
],
|
],
|
||||||
imports: [
|
imports: [
|
||||||
RouterModule.forRoot(
|
RouterModule.forRoot(
|
||||||
@@ -156,6 +159,7 @@ const appRoutes: Routes = [
|
|||||||
],
|
],
|
||||||
exports: [HttpClientModule],
|
exports: [HttpClientModule],
|
||||||
providers: [
|
providers: [
|
||||||
|
ImageService,
|
||||||
AircraftService,
|
AircraftService,
|
||||||
DropzoneService,
|
DropzoneService,
|
||||||
GearService,
|
GearService,
|
||||||
|
|||||||
@@ -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);
|
||||||
|
}
|
||||||
|
}
|
||||||
@@ -40,4 +40,6 @@
|
|||||||
|
|
||||||
<button type="submit" mat-raised-button color="accent">Update my profile</button>
|
<button type="submit" mat-raised-button color="accent">Update my profile</button>
|
||||||
</form>
|
</form>
|
||||||
|
|
||||||
|
<app-list-of-images></app-list-of-images>
|
||||||
</div>
|
</div>
|
||||||
|
|||||||
19
Front/skydivelogs-app/src/models/image.ts
Normal file
19
Front/skydivelogs-app/src/models/image.ts
Normal file
@@ -0,0 +1,19 @@
|
|||||||
|
export class ImageReq {
|
||||||
|
constructor(data: any) {
|
||||||
|
Object.assign(this, data);
|
||||||
|
}
|
||||||
|
|
||||||
|
public id: number;
|
||||||
|
public comment: string;
|
||||||
|
public data: string;
|
||||||
|
}
|
||||||
|
|
||||||
|
export class ImageResp {
|
||||||
|
constructor(data: any) {
|
||||||
|
Object.assign(this, data);
|
||||||
|
}
|
||||||
|
|
||||||
|
public id: number;
|
||||||
|
public comment: string;
|
||||||
|
public data: string;
|
||||||
|
}
|
||||||
34
Front/skydivelogs-app/src/services/image.service.ts
Normal file
34
Front/skydivelogs-app/src/services/image.service.ts
Normal file
@@ -0,0 +1,34 @@
|
|||||||
|
import { Injectable } from "@angular/core";
|
||||||
|
import { HttpClient } from "@angular/common/http";
|
||||||
|
import { Observable } from "rxjs";
|
||||||
|
|
||||||
|
import { ImageResp, ImageReq } from "../models/Image";
|
||||||
|
|
||||||
|
import { BaseService } from "./base.service";
|
||||||
|
|
||||||
|
@Injectable()
|
||||||
|
export class ImageService extends BaseService {
|
||||||
|
constructor(private http: HttpClient) {
|
||||||
|
super();
|
||||||
|
}
|
||||||
|
|
||||||
|
public getListOfImages(): Observable<Array<ImageResp>> {
|
||||||
|
return this.http.get<Array<ImageResp>>(`${this.apiUrl}/Image`, {
|
||||||
|
headers: this.headers,
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
public AddImage(commentImg: string, dataImg: File) {
|
||||||
|
const bodyNewImage: ImageReq = {
|
||||||
|
id: 0,
|
||||||
|
comment: commentImg,
|
||||||
|
data: dataImg.type,
|
||||||
|
};
|
||||||
|
|
||||||
|
this.http
|
||||||
|
.post(`${this.apiUrl}/Image`, bodyNewImage, {
|
||||||
|
headers: this.headers,
|
||||||
|
})
|
||||||
|
.subscribe((data) => console.log(data));
|
||||||
|
}
|
||||||
|
}
|
||||||
Reference in New Issue
Block a user