X-Git-Url: https://git.pterodactylus.net/?a=blobdiff_plain;f=src%2Fmain%2Fjava%2Fnet%2Fpterodactylus%2Fdemoscenemusic%2Fpage%2Fadmin%2FEditArtistPage.java;h=e737e607a4270563ddf015acbac0664aba056320;hb=8a7577702632b72078156b2003808f65a1f60f5b;hp=c51e584044793d990771e27ed145aa9e776d0d2f;hpb=f65f457310948c77765f26e1e91fc7a3d903220a;p=demoscenemusic.git diff --git a/src/main/java/net/pterodactylus/demoscenemusic/page/admin/EditArtistPage.java b/src/main/java/net/pterodactylus/demoscenemusic/page/admin/EditArtistPage.java index c51e584..e737e60 100644 --- a/src/main/java/net/pterodactylus/demoscenemusic/page/admin/EditArtistPage.java +++ b/src/main/java/net/pterodactylus/demoscenemusic/page/admin/EditArtistPage.java @@ -17,8 +17,11 @@ package net.pterodactylus.demoscenemusic.page.admin; +import java.util.Collection; + import net.pterodactylus.demoscenemusic.core.Core; import net.pterodactylus.demoscenemusic.data.Artist; +import net.pterodactylus.demoscenemusic.data.Group; import net.pterodactylus.demoscenemusic.page.ServletRequest; import net.pterodactylus.util.database.DatabaseException; import net.pterodactylus.util.template.Template; @@ -59,17 +62,39 @@ public class EditArtistPage extends AdminBasePage { protected void processTemplate(TemplateContext templateContext, ServletRequest request) throws RedirectException { super.processTemplate(templateContext, request); String id = request.getServletRequest().getParameter("id"); - /* TODO - check for null. */ - Artist artist; try { - artist = getCore().getDataManager().getArtistById(id); + Artist artist = getCore().getDataManager().getArtistById(id); /* TODO - check for null. */ templateContext.set("artist", artist); if (request.getMethod() == Method.POST) { String name = request.getServletRequest().getParameter("name"); - artist.setName(name); + if ((name != null) && (name.trim().length() > 0)) { + artist.setName(name); + } + + /* process property changes. */ + processProperties(request, artist); + + /* check for new group. */ + if ("true".equals(request.getServletRequest().getParameter("add-group"))) { + String groupId = request.getServletRequest().getParameter("group"); + Group group = getCore().getDataManager().getGroupById(groupId); + Collection groups = artist.getGroups(); + groups.add(group); + artist.setGroups(groups); + } + + /* check for deleted groups. */ + if ("true".equals(request.getServletRequest().getParameter("delete-group"))) { + String groupId = request.getServletRequest().getParameter("group"); + Group group = getCore().getDataManager().getGroupById(groupId); + Collection groups = artist.getGroups(); + groups.remove(group); + artist.setGroups(groups); + } + getCore().getDataManager().saveArtist(artist); - throw new RedirectException("admin.artists"); + throw new RedirectException("admin.edit-artist?id=" + artist.getId()); } } catch (DatabaseException de1) { throw new RuntimeException("Could not load artist.", de1);