Skip to content

Commit

Permalink
fix: practical work 1 updates
Browse files Browse the repository at this point in the history
  • Loading branch information
ErwannLeRoux committed May 3, 2023
1 parent 9ba31f3 commit 61d8c13
Show file tree
Hide file tree
Showing 5 changed files with 64 additions and 56 deletions.
1 change: 0 additions & 1 deletion .env.dist
Original file line number Diff line number Diff line change
Expand Up @@ -14,4 +14,3 @@ MERCURE_PUBLIC_URL=http://localhost:81/.well-known/mercure
MERCURE_PUBLISHER_JWT_KEY=!ChangeThisMercureHubJWTSecretKey!
MERCURE_SUBSCRIBER_JWT_KEY=!ChangeThisMercureHubJWTSecretKey!
MERCURE_CORS_ALLOW_ORIGIN="cors_origin http://localhost:80"

70 changes: 50 additions & 20 deletions public/js/dinosaurs.js
Original file line number Diff line number Diff line change
Expand Up @@ -2,34 +2,64 @@ const alertContainer = document.querySelector('#alert-container')
const template = document.querySelector('#dinosaur-item-template')
const dinosaurList = document.querySelector('#dinosaur-list')

fetch(window.location)
.then(async response => {
const topic = response.headers.get('x-mercure-topic')
const hubUrl = response.headers.get('Link').match(/<([^>]+)>;\s+rel=(?:mercure|"[^"]*mercure[^"]*")/)[1]
const displayToast = (message) => {
alertContainer.innerHTML = `<div class='alert alert-success'>${message}</div>`
window.setTimeout(() => {
const alert = document.querySelector('.alert')
alert.parentNode.removeChild(alert)
}, 5000)
}

const createDinosaur = (name, link) => {
const clone = template.content.cloneNode(true)
const dinosaurTemplateNameContainer = clone.querySelector('#dinosaur-item-template-name')
const dinosaurTemplateLinkContainer = clone.querySelector('#dinosaur-item-template-link')

dinosaurTemplateNameContainer.innerHTML = name
dinosaurTemplateLinkContainer.href = link

const hub = new URL(hubUrl);
dinosaurList.append(clone)

hub.searchParams.append('topic', topic)
displayToast(`Welcome to ${name}!`)
}

const es = new EventSource(hub)
const removeDinosaur = (id) => {
const item = document.querySelector(`a[data-id="${id}"]`)
item.remove()

es.onmessage = e => {
const dinosaur = JSON.parse(e.data)
displayToast(`A dinosaur has been removed !`)
}

const editDinosaur = (data) => {
const item = document.querySelector(`a[data-id="${data.id}"]`)
const name = item.querySelector('div')
name.innerHTML = data.name
}

fetch(window.location)
.then(async response => {
const topic = response.headers.get('x-mercure-topic')
const hubUrl = response.headers.get('Link').match(/<([^>]+)>;\s+rel=(?:mercure|"[^"]*mercure[^"]*")/)[1]

const clone = template.content.cloneNode(true)
const dinosaurTemplateNameContainer = clone.querySelector('#dinosaur-item-template-name')
const dinosaurTemplateLinkContainer = clone.querySelector('#dinosaur-item-template-link')
const hub = new URL(hubUrl);

dinosaurTemplateNameContainer.innerHTML = dinosaur.name
dinosaurTemplateLinkContainer.href = dinosaur.link
hub.searchParams.append('topic', topic)

dinosaurList.append(clone)
const es = new EventSource(hub)

alertContainer.innerHTML =`<div class='alert alert-success'>Welcome to ${dinosaur.name}!</div>`
es.onmessage = e => {
const message = JSON.parse(e.data)

window.setTimeout(() => {
const alert = document.querySelector('.alert')
alert.parentNode.removeChild(alert)
}, 5000);
switch (message.type) {
case 'create':
createDinosaur(message.name, message.link)
break
case 'remove':
removeDinosaur(message.id)
break
case 'edit':
editDinosaur(message.data)
break
}
}
})
46 changes: 12 additions & 34 deletions src/Controller/DinosaursController.php
Original file line number Diff line number Diff line change
Expand Up @@ -73,38 +73,6 @@ public function single(
]);
}

#[Route(
'/api/dinosaurs/{id}',
name: 'api_single_dinosaur',
requirements: ['id' => '\d+']
)]
public function apiSingle(
string $id,
ManagerRegistry $doctrine,
Request $request
): Response
{
$dinosaur = $doctrine
->getRepository(Dinosaur::class)
->find($id)
;

if ($dinosaur === false) {
throw $this->createNotFoundException(
'The dinosaur you are looking for does not exists.'
);
}

return new JsonResponse([
'id' => $dinosaur->getId(),
'name' => $dinosaur->getName(),
'gender' => $dinosaur->getGender(),
'age' => $dinosaur->getAge(),
'eyeColor' => $dinosaur->getEyesColor(),
'topic' => "https://dinosaur-app/api/dinosaurs/{$dinosaur->getId()}"
]);
}

#[Route('/dinosaurs/create', name: 'app_create_dinosaur')]
public function create(
Request $request,
Expand All @@ -130,6 +98,7 @@ public function create(
json_encode([
'link' => $this->router->generate('app_single_dinosaur', ['id' => $dinosaur->getId()]),
'name' => $dinosaur->getName(),
'type' => 'create',
'message' => "{$dinosaur->getName()} has been created!"
])
);
Expand Down Expand Up @@ -177,11 +146,17 @@ public function edit(Request $request, int $id, ManagerRegistry $doctrine): Resp
$update = new Update(
[
sprintf('https://dinosaur-app/dinosaurs/edit/%d', $id),
'https://dinosaur-app/dinosaurs',
'https://dinosaur-app/activity'
],
json_encode([
'link' => $this->router->generate('app_single_dinosaur', ['id' => $dinosaur->getId()]),
'message' => "{$dinosaur->getName()} has been edited!"
'message' => "{$dinosaur->getName()} has been edited!",
'type' => 'edit',
'data' => [
'id' => $dinosaur->getId(),
'name' => $dinosaur->getName()
]
])
);

Expand Down Expand Up @@ -222,11 +197,14 @@ public function remove(int $id, ManagerRegistry $doctrine): Response
$update = new Update(
[
sprintf('https://dinosaur-app/dinosaurs/remove/%d', $id),
'https://dinosaur-app/dinosaurs',
'https://dinosaur-app/activity'
],
json_encode([
'link' => $this->router->generate('app_single_dinosaur', ['id' => $id]),
'message' => "{$dinosaur->getName()} has been removed!"
'message' => "{$dinosaur->getName()} has been removed!",
'type' => 'remove',
'id' => $id
])
);

Expand Down
2 changes: 1 addition & 1 deletion templates/activity.html.twig
Original file line number Diff line number Diff line change
Expand Up @@ -20,4 +20,4 @@
{{ mercure('https://example.com/books/1')|json_encode(constant('JSON_UNESCAPED_SLASHES') b-or constant('JSON_HEX_TAG'))|raw }}
</script>
</main>
{% endblock %}
{% endblock %}
1 change: 1 addition & 0 deletions templates/dinosaurs-list.html.twig
Original file line number Diff line number Diff line change
Expand Up @@ -20,6 +20,7 @@
{% for dinosaur in dinosaurs %}
<a class="list-group-item list-group-item-action d-flex gap-3 py-3"
href="{{ path('app_single_dinosaur', {id: dinosaur.id}) }}"
data-id="{{ dinosaur.id }}"
>
<img
src="{{ asset('img/dino.png') }}"
Expand Down

0 comments on commit 61d8c13

Please sign in to comment.