/* * Copyright 2008-2013, ETH Zürich, Samuel Welten, Michael Kuhn, Tobias Langner, * Sandro Affentranger, Lukas Bossard, Michael Grob, Rahul Jain, * Dominic Langenegger, Sonia Mayor Alonso, Roger Odermatt, Tobias Schlueter, * Yannick Stucki, Sebastian Wendland, Samuel Zehnder, Samuel Zihlmann, * Samuel Zweifel * * This file is part of Jukefox. * * Jukefox is free software: you can redistribute it and/or modify it under the * terms of the GNU General Public License as published by the Free Software * Foundation, either version 3 of the License, or any later version. Jukefox is * distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; * without even the implied warranty of MERCHANTABILITY or FITNESS FOR A * PARTICULAR PURPOSE. See the GNU General Public License for more details. * * You should have received a copy of the GNU General Public License along with * Jukefox. If not, see <http://www.gnu.org/licenses/>. */ package ch.ethz.dcg.jukefox.model.collection; import java.util.Arrays; import java.util.List; public class ListAlbum extends BaseAlbum implements IBaseListItem { private List<BaseArtist> artists; public ListAlbum(int id, String name, List<BaseArtist> artists) { super(id, name); this.artists = artists; } public ListAlbum(BaseSong<BaseArtist, BaseAlbum> song) { super(song.getAlbum().getId(), song.getAlbum().getName()); this.artists = Arrays.asList(song.getArtist()); } public List<BaseArtist> getArtists() { return artists; } public BaseArtist getFirstArtist() { return artists.get(0); } @Override /** * always returns album title */ public String getSortString(boolean ignorePrefix) { return name; } @Override public String getSubTitle() { return getFirstArtist().getName(); } @Override public String getTitle() { return name; } }