home page affiche les posts créé :P

This commit is contained in:
Guams 2024-12-26 16:22:54 +01:00
parent 7a96d5f2e0
commit 54e69e3440
9 changed files with 87 additions and 40 deletions

View File

@ -1,20 +1,11 @@
<app-header></app-header>
<div class="main-content">
<article>
<img class="blog-img" src=" " alt="article image">
<h2 class="blog-title blog">Analyse approfondie de Goodbye Eri</h2>
<p class="blog-category blog">Mangas & Animes</p>
<em class="blog-date blog">Publié le 30 novembre 2024 à 17:16h</em>
<p class="blog-desc">Dans ce post j'analyse le one shot "Goodbye, Eri" écrit par Tatsuki Fujimoto. J'y aborde
beaucoup d'aspects du manga comme la mémoire humaine, la spontanéité des uns qui vient en opposition avec
l'hypocrisie des autres et plein d'autres thèmes ! Disclaimer : Tout comme mon post sur
"Persona 3 Reload - Episode Aigis", je spoil l'intégralité de l'oeuvre.</p>
<p-button (click)="successMessage('salut', 'grgtr')" label="Lire la suite"/>
<div>
<p-avatar label="G" shape="circle" styleClass="mr-2" size="large"/>
<em>Guams</em>
</div>
</article>
@for (post of posts; track post.id) {
<app-post-home [illustration]="post.illustration"
[date]="post.publication_date"
[category]="post.category"
[title]="post.title"
[username]="'Guams'"
[description]="post.description" />
}
</div>
{{ actualAuthor | json }}

View File

@ -11,6 +11,7 @@ import {ToastModule} from 'primeng/toast';
import {CookieService} from 'ngx-cookie-service';
import {PostService} from '../services/post.service';
import {Post} from '../models/post';
import {PostHomeComponent} from '../post-home/post-home.component';
@Component({
selector: 'app-home',
@ -20,7 +21,8 @@ import {Post} from '../models/post';
Button,
HeaderComponent,
ToastModule,
JsonPipe
JsonPipe,
PostHomeComponent
],
templateUrl: './home.component.html',
styleUrl: './home.component.css'

View File

@ -19,5 +19,3 @@
<p-editor formControlName="body" [style]="{ height: '320px' }"/>
<p-button type="submit" label="envoyer" ></p-button>
</form>

View File

@ -1,6 +1,6 @@
import {Component, OnDestroy} from '@angular/core';
import {HeaderComponent} from '../header/header.component';
import {FormControl, FormGroup, ReactiveFormsModule, Validators} from '@angular/forms';
import {FormBuilder, FormControl, FormGroup, ReactiveFormsModule, ValidationErrors, Validators} from '@angular/forms';
import {InputTextModule} from 'primeng/inputtext';
import {InputTextareaModule} from 'primeng/inputtextarea';
import {FileSelectEvent, FileUploadModule} from 'primeng/fileupload';
@ -12,6 +12,7 @@ import {MessageService} from 'primeng/api';
import {EditorModule} from 'primeng/editor';
import {AuthorService} from '../services/author.service';
import {Author} from '../models/author';
import {Router} from '@angular/router';
@Component({
selector: 'app-new-post',
@ -31,19 +32,24 @@ export class NewPostComponent implements OnDestroy {
subs: Subscription[] = []
actualAuthor: Author | undefined;
uploadedFile: File | undefined;
form: FormGroup = new FormGroup({
description: new FormControl('', [Validators.required, Validators.maxLength(512)]),
title: new FormControl('', [Validators.required, Validators.maxLength(50)]),
body: new FormControl('', [Validators.required]),
category: new FormControl('', [Validators.required, Validators.maxLength(50)]),
});
form: FormGroup;
constructor(private postService: PostService,
constructor(private formBuilder: FormBuilder,
private postService: PostService,
private cookieService: CookieService,
private authorService: AuthorService,
private messageService: MessageService,) {
private messageService: MessageService,
private router: Router) {
this.form = this.formBuilder.group({
description: ['', [Validators.required, Validators.maxLength(512)]],
title: ['', [Validators.required, Validators.maxLength(50)]],
body: ['', [Validators.required]],
category: ['', [Validators.required, Validators.maxLength(50)]],
});
if (this.cookieService.get("author")) {
this.actualAuthor = JSON.parse(this.cookieService.get("author"));
}
}
onSelected(event: FileSelectEvent) {
if (event.currentFiles && event.currentFiles.length > 0) {
@ -54,7 +60,7 @@ export class NewPostComponent implements OnDestroy {
onSubmit() {
const formData = this.form.value;
if (this.uploadedFile) {
if (this.uploadedFile && this.form.status === 'VALID') {
const postToPost: any = { // LOL
body: formData.body as string,
description: formData.description as string,
@ -73,7 +79,9 @@ export class NewPostComponent implements OnDestroy {
)
).subscribe({
next: () => {
console.log('Post créé, attribué et illustration changée avec succès.');
this.router.navigate(['/']).then(() => {
this.successMessage('Succès', 'Post créé avec succès')
});
},
error: (err) => {
this.failureMessage('Erreur', err.message);
@ -83,6 +91,16 @@ export class NewPostComponent implements OnDestroy {
}
}
successMessage(summary: string, detail: string): void {
this.messageService.add({
severity: 'success',
summary: summary,
detail: detail,
life: 3000,
closable: false
});
}
failureMessage(summary: string, detail: string): void {
this.messageService.add({
severity: 'error',

View File

@ -0,0 +1,8 @@
<p-card>
<img src="data:image/jpeg;base64,{{ illustration }}"/>
<h2>{{ title }}</h2>
<p>{{ category }}</p>
<em>{{ date }}</em>
<p>{{ description }}</p>
<p-button label="Lire la suite"/>
</p-card>

View File

@ -0,0 +1,24 @@
import {Component, Input} from '@angular/core';
import {Button} from 'primeng/button';
import {CardModule} from 'primeng/card';
@Component({
selector: 'app-post-home',
standalone: true,
imports: [
Button,
CardModule
],
templateUrl: './post-home.component.html',
styleUrl: './post-home.component.css'
})
export class PostHomeComponent {
@Input() title: string = '';
@Input() illustration: string = '';
@Input() category: string = '';
@Input() date: Date = new Date();
@Input() description: string = '';
@Input() username: string = '';
@Input() avatar: string = '';
}

View File

@ -32,7 +32,7 @@ export class AuthorService {
return this.httpClient.put<any>(`http://localhost:8080/api/authors/${authorId}/posts`, postId, httpOptions);
}
getAuthor(id: string | undefined): Observable<Author> {
getAuthor(id: string | null): Observable<Author> {
if (id) {
return this.httpClient.get<Author>("http://localhost:8080/api/authors/" + id);
} else {

View File

@ -24,12 +24,18 @@ export class PostService {
}
changeIllustration(id: bigint, image: File | undefined, token: string): Observable<Post> {
if (image) {
const formData: FormData = new FormData();
formData.append('illustration', image);
const httpOptions = {
headers: new HttpHeaders({
'Authorization': `Bearer ${token}`
})
};
return this.httpClient.put<Post>(`${this.url}/${id}`, image, httpOptions);
console.log(image);
return this.httpClient.put<Post>(`${this.url}/${id}/illustration`, formData, httpOptions);
} else {
throw new Error('Image doesn\'t exist');
}
}
}