/*
* 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;
}
}