Podcast management (WIP)

This commit is contained in:
dece 2023-10-14 18:26:09 +02:00
parent 4566f8b85b
commit c39e7039ac
12 changed files with 73 additions and 57 deletions

View file

@ -15,14 +15,14 @@ use Symfony\Component\HttpFoundation\Response;
use Symfony\Component\Routing\Annotation\Route;
use Symfony\Component\String\Slugger\SluggerInterface;
#[Route('/manage/podcast')]
#[Route('/manage/podcasts')]
class PodcastController extends AbstractController
{
#[Route('/', name: 'app_podcast_index', methods: ['GET'])]
public function index(PodcastRepository $podcastRepository): Response
{
return $this->render('podcast/index.html.twig', [
'podcasts' => $podcastRepository->findAllOrderedById(),
'podcasts' => $podcastRepository->findOwnedBy($this->getUser())
]);
}

View file

@ -47,7 +47,7 @@ class PodcastType extends AbstractType
]),
])
->add('owner', EntityType::class, [
'help' => 'The podcast owner is the only user of this instance able to see and modify it.',
'help' => 'The podcast owner is the only user of this instance able to modify it.',
'class' => User::class,
'disabled' => true,
])

View file

@ -3,6 +3,7 @@
namespace App\Repository;
use App\Entity\Podcast;
use App\Entity\User;
use Doctrine\Bundle\DoctrineBundle\Repository\ServiceEntityRepository;
use Doctrine\Persistence\ManagerRegistry;
@ -39,8 +40,8 @@ class PodcastRepository extends ServiceEntityRepository
}
}
public function findAllOrderedById(): array
public function findOwnedBy(User $user): array
{
return $this->findBy([], ['id' => 'ASC']);
return $this->findBy(['owner' => $user], ['id' => 'ASC']);
}
}

View file

@ -4,11 +4,13 @@
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<title>{% block title %}LSBC{% endblock %}</title>
{% block stylesheets %}
<style>
img { max-width: 100%; }
.help-text { font-size: 0.8em; }
</style>
<link rel="stylesheet" href="/simple-v1.min.css">
{% endblock %}
</head>
<body>
{% block body %}{% endblock %}

View file

@ -8,4 +8,5 @@
{% endfor %}
</ul>
<p>The <a href="https://git.dece.space/dece/lsbc">LSBC</a> project is licensed as GPLv3.</p>
<a href="/login"><button>Login</button></a>
{% endblock %}

View file

@ -22,8 +22,7 @@ form { display: flex; flex-direction: column; gap: 0.5em; }
<label for="password">Password:</label>
<input type="password" id="password" name="_password">
{# If you want to control the URL the user is redirected to on success
<input type="hidden" name="_target_path" value="/account"> #}
<input type="hidden" name="_target_path" value="/manage/podcasts">
<input type="hidden" name="_csrf_token" value="{{ csrf_token('authenticate') }}">

View file

@ -1,4 +1,8 @@
<form method="post" action="{{ path('app_podcast_delete', {'id': podcast.id}) }}" onsubmit="return confirm('Are you sure you want to delete this item?');">
<form
method="post"
action="{{ path('app_podcast_delete', {'id': podcast.id}) }}"
onsubmit="return confirm('Are you sure you want to delete this podcast?');"
>
<input type="hidden" name="_token" value="{{ csrf_token('delete' ~ podcast.id) }}">
<button class="btn">Delete</button>
</form>

View file

@ -5,12 +5,12 @@
{% block stylesheets %}
{{ parent() }}
<style>
td img { width: 5em; }
td img { width: 5em; }
</style>
{% endblock %}
{% block body %}
<h1>Podcast index</h1>
<h1>Your podcasts</h1>
<table class="table">
<thead>
@ -30,17 +30,19 @@ td img { width: 5em; }
<td>{{ podcast.author }}</td>
<td><img src="{{ podcast.logoPath }}" alt="{{ podcast.name }} logo"></td>
<td>
<a href="{{ path('app_podcast_show', {'id': podcast.id}) }}">show</a>
<a href="{{ path('app_podcast_edit', {'id': podcast.id}) }}">edit</a>
<a href="{{ path('app_podcast_show', {'id': podcast.id}) }}"
><button>Show</button></a>
<a href="{{ path('app_podcast_edit', {'id': podcast.id}) }}"
><button>Edit</button></a>
</td>
</tr>
{% else %}
<tr>
<td colspan="5">no records found</td>
<td colspan="5">No podcasts found.</td>
</tr>
{% endfor %}
</tbody>
</table>
<a href="{{ path('app_podcast_new') }}">Create new</a>
<a href="{{ path('app_podcast_new') }}"><button>Create new</button></a>
{% endblock %}

View file

@ -2,8 +2,15 @@
{% block title %}Podcast{% endblock %}
{% block stylesheets %}
{{ parent() }}
<style>
th { min-width: 8em; }
</style>
{% endblock %}
{% block body %}
<h1>Podcast</h1>
<h1>Podcast {{ podcast.name }}</h1>
<table class="table">
<tbody>