added top album tab, moved error catching from invocation to implicit
This commit is contained in:
parent
59bb4fdb6f
commit
6904663e59
@ -111,6 +111,16 @@ public class FmNetwork {
|
|||||||
log.logInfo(new InfoEntry("getAlbum").addArg("no user play count for").addArg(nameIn)
|
log.logInfo(new InfoEntry("getAlbum").addArg("no user play count for").addArg(nameIn)
|
||||||
.addArg(e.getMessage()));
|
.addArg(e.getMessage()));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
try {
|
||||||
|
JSONArray imageArray = albumJson.getJSONArray("image");
|
||||||
|
JSONObject imageObj = (JSONObject) imageArray.get(imageArray.length() - 1);
|
||||||
|
|
||||||
|
builder.setImageUrl(imageObj.getString("#text"));
|
||||||
|
} catch (JSONException e) {
|
||||||
|
log.logInfo(new InfoEntry("getAlbum").addArg("no image for").addArg(nameIn)
|
||||||
|
.addArg(e.getMessage()));
|
||||||
|
}
|
||||||
|
|
||||||
try {
|
try {
|
||||||
JSONObject wikiJson = albumJson.getJSONObject("wiki");
|
JSONObject wikiJson = albumJson.getJSONObject("wiki");
|
||||||
|
@ -279,10 +279,29 @@ public class FmUserNetwork extends FmNetwork {
|
|||||||
|
|
||||||
return LocalDateTime.ofInstant(Instant.ofEpochSecond(uts), ZoneId.systemDefault());
|
return LocalDateTime.ofInstant(Instant.ofEpochSecond(uts), ZoneId.systemDefault());
|
||||||
}
|
}
|
||||||
|
|
||||||
|
private String getPeriod(TimePeriod period) {
|
||||||
|
switch(period){
|
||||||
|
case OVERALL:
|
||||||
|
return "overall";
|
||||||
|
case SEVENDAY:
|
||||||
|
return "7day";
|
||||||
|
case ONEMONTH:
|
||||||
|
return "1month";
|
||||||
|
case THREEMONTH:
|
||||||
|
return "3month";
|
||||||
|
case SIXMONTH:
|
||||||
|
return "6month";
|
||||||
|
case TWELVEMONTH:
|
||||||
|
return "12month";
|
||||||
|
default:
|
||||||
|
throw new IllegalArgumentException("invalid period provided");
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
public FMObjList getTopTracks(String period, int number) throws ApiCallException {
|
public FMObjList getTopTracks(TimePeriod period, int number) throws ApiCallException {
|
||||||
|
|
||||||
Logger.getLog().log(new LogEntry("getTopTracks").addArg(period).addArg(Integer.toString(number)));
|
Logger.getLog().log(new LogEntry("getTopTracks").addArg(getPeriod(period)).addArg(Integer.toString(number)));
|
||||||
|
|
||||||
int limit = 50;
|
int limit = 50;
|
||||||
|
|
||||||
@ -302,7 +321,7 @@ public class FmUserNetwork extends FmNetwork {
|
|||||||
HashMap<String, String> parameters = new HashMap<String, String>();
|
HashMap<String, String> parameters = new HashMap<String, String>();
|
||||||
|
|
||||||
parameters.put("user", userName);
|
parameters.put("user", userName);
|
||||||
parameters.put("period", period);
|
parameters.put("period", getPeriod(period));
|
||||||
parameters.put("limit", Integer.toString(limit));
|
parameters.put("limit", Integer.toString(limit));
|
||||||
parameters.put("page", Integer.toString(counter + 1));
|
parameters.put("page", Integer.toString(counter + 1));
|
||||||
|
|
||||||
@ -326,9 +345,9 @@ public class FmUserNetwork extends FmNetwork {
|
|||||||
return tracks;
|
return tracks;
|
||||||
}
|
}
|
||||||
|
|
||||||
public FMObjList getTopAlbums(String period, int number) throws ApiCallException {
|
public FMObjList getTopAlbums(TimePeriod period, int number) throws ApiCallException {
|
||||||
|
|
||||||
Logger.getLog().log(new LogEntry("getTopAlbums").addArg(period).addArg(Integer.toString(number)));
|
Logger.getLog().log(new LogEntry("getTopAlbums").addArg(getPeriod(period)).addArg(Integer.toString(number)));
|
||||||
|
|
||||||
int limit = 50;
|
int limit = 50;
|
||||||
|
|
||||||
@ -348,7 +367,7 @@ public class FmUserNetwork extends FmNetwork {
|
|||||||
HashMap<String, String> parameters = new HashMap<String, String>();
|
HashMap<String, String> parameters = new HashMap<String, String>();
|
||||||
|
|
||||||
parameters.put("user", userName);
|
parameters.put("user", userName);
|
||||||
parameters.put("period", period);
|
parameters.put("period", getPeriod(period));
|
||||||
parameters.put("limit", Integer.toString(limit));
|
parameters.put("limit", Integer.toString(limit));
|
||||||
parameters.put("page", Integer.toString(counter + 1));
|
parameters.put("page", Integer.toString(counter + 1));
|
||||||
|
|
||||||
@ -361,9 +380,15 @@ public class FmUserNetwork extends FmNetwork {
|
|||||||
|
|
||||||
if (albums.size() < number) {
|
if (albums.size() < number) {
|
||||||
Artist artist = new ArtistBuilder(json.getJSONObject("artist").getString("name")).build();
|
Artist artist = new ArtistBuilder(json.getJSONObject("artist").getString("name")).build();
|
||||||
Album album = new AlbumBuilder(json.getString("name"), artist)
|
AlbumBuilder albumBuilder = new AlbumBuilder(json.getString("name"), artist)
|
||||||
.setUserPlayCount(json.getInt("playcount")).build();
|
.setUserPlayCount(json.getInt("playcount"));
|
||||||
|
|
||||||
|
JSONArray imageArray = json.getJSONArray("image");
|
||||||
|
JSONObject imageObj = (JSONObject) imageArray.get(imageArray.length() - 1);
|
||||||
|
|
||||||
|
albumBuilder.setImageUrl(imageObj.getString("#text"));
|
||||||
|
|
||||||
|
Album album = albumBuilder.build();
|
||||||
albums.add(album);
|
albums.add(album);
|
||||||
|
|
||||||
}
|
}
|
||||||
@ -373,9 +398,9 @@ public class FmUserNetwork extends FmNetwork {
|
|||||||
return albums;
|
return albums;
|
||||||
}
|
}
|
||||||
|
|
||||||
public FMObjList getTopArtists(String period, int number) throws ApiCallException {
|
public FMObjList getTopArtists(TimePeriod period, int number) throws ApiCallException {
|
||||||
|
|
||||||
Logger.getLog().log(new LogEntry("getTopArtists").addArg(period).addArg(Integer.toString(number)));
|
Logger.getLog().log(new LogEntry("getTopArtists").addArg(getPeriod(period)).addArg(Integer.toString(number)));
|
||||||
|
|
||||||
int limit = 50;
|
int limit = 50;
|
||||||
|
|
||||||
@ -395,7 +420,7 @@ public class FmUserNetwork extends FmNetwork {
|
|||||||
HashMap<String, String> parameters = new HashMap<String, String>();
|
HashMap<String, String> parameters = new HashMap<String, String>();
|
||||||
|
|
||||||
parameters.put("user", userName);
|
parameters.put("user", userName);
|
||||||
parameters.put("period", period);
|
parameters.put("period", getPeriod(period));
|
||||||
parameters.put("limit", Integer.toString(limit));
|
parameters.put("limit", Integer.toString(limit));
|
||||||
parameters.put("page", Integer.toString(counter + 1));
|
parameters.put("page", Integer.toString(counter + 1));
|
||||||
|
|
||||||
|
12
src/main/java/sarsoo/fmframework/fm/TimePeriod.java
Normal file
12
src/main/java/sarsoo/fmframework/fm/TimePeriod.java
Normal file
@ -0,0 +1,12 @@
|
|||||||
|
package sarsoo.fmframework.fm;
|
||||||
|
|
||||||
|
public enum TimePeriod {
|
||||||
|
|
||||||
|
OVERALL,
|
||||||
|
SEVENDAY,
|
||||||
|
ONEMONTH,
|
||||||
|
THREEMONTH,
|
||||||
|
SIXMONTH,
|
||||||
|
TWELVEMONTH
|
||||||
|
|
||||||
|
}
|
18
src/main/java/sarsoo/fmframework/fx/TiledImage.java
Normal file
18
src/main/java/sarsoo/fmframework/fx/TiledImage.java
Normal file
@ -0,0 +1,18 @@
|
|||||||
|
package sarsoo.fmframework.fx;
|
||||||
|
|
||||||
|
import javafx.scene.image.Image;
|
||||||
|
|
||||||
|
public class TiledImage extends Image {
|
||||||
|
|
||||||
|
private int index;
|
||||||
|
|
||||||
|
public TiledImage(String url, int index) {
|
||||||
|
super(url);
|
||||||
|
this.index = index;
|
||||||
|
}
|
||||||
|
|
||||||
|
public int getIndex() {
|
||||||
|
return index;
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
@ -74,12 +74,7 @@ public class FMObjListPaneController {
|
|||||||
@Override
|
@Override
|
||||||
public void handle(Event event) {
|
public void handle(Event event) {
|
||||||
|
|
||||||
try {
|
FmFramework.getController().addTab(new ArtistTab((Artist) obj));
|
||||||
FmFramework.getController().addTab(new ArtistTab((Artist) obj));
|
|
||||||
} catch (IOException e) {
|
|
||||||
|
|
||||||
e.printStackTrace();
|
|
||||||
}
|
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -165,12 +160,7 @@ public class FMObjListPaneController {
|
|||||||
@Override
|
@Override
|
||||||
public void handle(Event event) {
|
public void handle(Event event) {
|
||||||
|
|
||||||
try {
|
FmFramework.getController().addTab(new ArtistTab((Artist) obj));
|
||||||
FmFramework.getController().addTab(new ArtistTab((Artist) obj));
|
|
||||||
} catch (IOException e) {
|
|
||||||
|
|
||||||
e.printStackTrace();
|
|
||||||
}
|
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -106,18 +106,12 @@ public class FMObjListPaneEditController {
|
|||||||
@Override
|
@Override
|
||||||
public void handle(Event event) {
|
public void handle(Event event) {
|
||||||
|
|
||||||
try {
|
if (obj.getClass() == Artist.class) {
|
||||||
|
FmFramework.getController().addTab(new ArtistTab((Artist) obj));
|
||||||
if (obj.getClass() == Artist.class) {
|
} else if (obj.getClass() == Album.class) {
|
||||||
FmFramework.getController().addTab(new ArtistTab((Artist) obj));
|
FmFramework.getController().addTab(new AlbumTab((Album) obj));
|
||||||
} else if (obj.getClass() == Album.class) {
|
} else if (obj.getClass() == Track.class) {
|
||||||
FmFramework.getController().addTab(new AlbumTab((Album) obj));
|
FmFramework.getController().addTab(new TrackTab((Track) obj));
|
||||||
} else if (obj.getClass() == Track.class) {
|
|
||||||
FmFramework.getController().addTab(new TrackTab((Track) obj));
|
|
||||||
}
|
|
||||||
} catch (IOException e) {
|
|
||||||
|
|
||||||
e.printStackTrace();
|
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
@ -35,6 +35,7 @@ import sarsoo.fmframework.fx.tab.FMObjListEditTab;
|
|||||||
import sarsoo.fmframework.fx.tab.GenrePieChartTab;
|
import sarsoo.fmframework.fx.tab.GenrePieChartTab;
|
||||||
import sarsoo.fmframework.fx.tab.ScrobbleChartTab;
|
import sarsoo.fmframework.fx.tab.ScrobbleChartTab;
|
||||||
import sarsoo.fmframework.fx.tab.ScrobbleTab;
|
import sarsoo.fmframework.fx.tab.ScrobbleTab;
|
||||||
|
import sarsoo.fmframework.fx.tab.TopAlbumTab;
|
||||||
import sarsoo.fmframework.fx.tab.TrackTab;
|
import sarsoo.fmframework.fx.tab.TrackTab;
|
||||||
import sarsoo.fmframework.fx.tab.WebViewTab;
|
import sarsoo.fmframework.fx.tab.WebViewTab;
|
||||||
import sarsoo.fmframework.log.Log;
|
import sarsoo.fmframework.log.Log;
|
||||||
@ -123,19 +124,15 @@ public class RootController {
|
|||||||
getLastTrack.setOnSucceeded(new EventHandler<WorkerStateEvent>() {
|
getLastTrack.setOnSucceeded(new EventHandler<WorkerStateEvent>() {
|
||||||
@Override
|
@Override
|
||||||
public void handle(WorkerStateEvent t) {
|
public void handle(WorkerStateEvent t) {
|
||||||
try {
|
TrackTab tab = new TrackTab(((Track) t.getSource().getValue()));
|
||||||
TrackTab tab = new TrackTab(((Track) t.getSource().getValue()));
|
|
||||||
|
|
||||||
Platform.runLater(new Runnable() {
|
Platform.runLater(new Runnable() {
|
||||||
@Override
|
@Override
|
||||||
public void run() {
|
public void run() {
|
||||||
addTab(tab);
|
addTab(tab, false);
|
||||||
}
|
}
|
||||||
|
|
||||||
});
|
});
|
||||||
} catch (IOException e) {
|
|
||||||
e.printStackTrace();
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
getLastTrack.start();
|
getLastTrack.start();
|
||||||
@ -179,12 +176,17 @@ public class RootController {
|
|||||||
getTags.start();
|
getTags.start();
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
public void addTab(Tab tab) {
|
public void addTab(Tab tab) {
|
||||||
|
addTab(tab, true);
|
||||||
|
}
|
||||||
|
|
||||||
|
public void addTab(Tab tab, Boolean select) {
|
||||||
tabPane.getTabs().add(tab);
|
tabPane.getTabs().add(tab);
|
||||||
SingleSelectionModel<Tab> selectionModel = tabPane.getSelectionModel();
|
SingleSelectionModel<Tab> selectionModel = tabPane.getSelectionModel();
|
||||||
|
|
||||||
selectionModel.select(tab);
|
if(select)
|
||||||
|
selectionModel.select(tab);
|
||||||
}
|
}
|
||||||
|
|
||||||
@FXML
|
@FXML
|
||||||
@ -243,13 +245,14 @@ public class RootController {
|
|||||||
}
|
}
|
||||||
});
|
});
|
||||||
|
|
||||||
addTab(tab);
|
addTab(tab, true);
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
} catch (IOException e) {
|
} catch (IOException e) {
|
||||||
e.printStackTrace();
|
e.printStackTrace();
|
||||||
} catch (ApiCallException e) {}
|
} catch (ApiCallException e) {
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
protected void completeAuth(FmAuthNetwork net, String token) {
|
protected void completeAuth(FmAuthNetwork net, String token) {
|
||||||
@ -257,12 +260,13 @@ public class RootController {
|
|||||||
String sk;
|
String sk;
|
||||||
try {
|
try {
|
||||||
sk = net.getSession(token);
|
sk = net.getSession(token);
|
||||||
|
|
||||||
if (sk != null) {
|
if (sk != null) {
|
||||||
FmFramework.getSessionConfig().addVariable(new ConfigVariable("session_key", sk));
|
FmFramework.getSessionConfig().addVariable(new ConfigVariable("session_key", sk));
|
||||||
}
|
}
|
||||||
|
|
||||||
} catch (ApiCallException e) {}
|
} catch (ApiCallException e) {
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
public void changeUsername() {
|
public void changeUsername() {
|
||||||
@ -395,12 +399,8 @@ public class RootController {
|
|||||||
@FXML
|
@FXML
|
||||||
protected void handleCreateList(ActionEvent event) {
|
protected void handleCreateList(ActionEvent event) {
|
||||||
|
|
||||||
try {
|
Tab tab = new FMObjListEditTab();
|
||||||
Tab tab = new FMObjListEditTab();
|
addTab(tab, true);
|
||||||
addTab(tab);
|
|
||||||
} catch (IOException e) {
|
|
||||||
e.printStackTrace();
|
|
||||||
}
|
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -421,21 +421,22 @@ public class RootController {
|
|||||||
|
|
||||||
@FXML
|
@FXML
|
||||||
protected void handleScrobble(ActionEvent event) throws IOException {
|
protected void handleScrobble(ActionEvent event) throws IOException {
|
||||||
addTab(new ScrobbleTab());
|
addTab(new ScrobbleTab(), true);
|
||||||
}
|
}
|
||||||
|
|
||||||
@FXML
|
@FXML
|
||||||
protected void handleOpenConsole(ActionEvent event) {
|
protected void handleOpenConsole(ActionEvent event) {
|
||||||
addTab(new ConsoleTab());
|
addTab(new ConsoleTab(), true);
|
||||||
|
}
|
||||||
|
|
||||||
|
@FXML
|
||||||
|
protected void handleTopAlbum(ActionEvent event) {
|
||||||
|
addTab(new TopAlbumTab(), true);
|
||||||
}
|
}
|
||||||
|
|
||||||
@FXML
|
@FXML
|
||||||
protected void handleScrobbleChart(ActionEvent event) {
|
protected void handleScrobbleChart(ActionEvent event) {
|
||||||
try {
|
addTab(new ScrobbleChartTab(), true);
|
||||||
addTab(new ScrobbleChartTab());
|
|
||||||
} catch (IOException e) {
|
|
||||||
e.printStackTrace();
|
|
||||||
}
|
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -453,17 +454,13 @@ public class RootController {
|
|||||||
FMObjList list = persist.readListFromFile(file);
|
FMObjList list = persist.readListFromFile(file);
|
||||||
list.setGroupName(file.getName());
|
list.setGroupName(file.getName());
|
||||||
list.refresh();
|
list.refresh();
|
||||||
try {
|
addTab(new FMObjListEditTab(list), true);
|
||||||
addTab(new FMObjListEditTab(list));
|
|
||||||
} catch (IOException e) {
|
|
||||||
e.printStackTrace();
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@FXML
|
@FXML
|
||||||
protected void handleOpenEdit(ActionEvent event) {
|
protected void handleOpenEdit(ActionEvent event) {
|
||||||
addTab(new ConsoleTab());
|
addTab(new ConsoleTab(), true);
|
||||||
}
|
}
|
||||||
|
|
||||||
public void closeCurrentTab() {
|
public void closeCurrentTab() {
|
||||||
@ -484,7 +481,7 @@ public class RootController {
|
|||||||
|
|
||||||
@FXML
|
@FXML
|
||||||
protected void handleGenrePieTab(ActionEvent event) {
|
protected void handleGenrePieTab(ActionEvent event) {
|
||||||
addTab(new GenrePieChartTab());
|
addTab(new GenrePieChartTab(), true);
|
||||||
}
|
}
|
||||||
|
|
||||||
private ArrayList<Tag> tags;
|
private ArrayList<Tag> tags;
|
||||||
|
@ -39,6 +39,8 @@ public class ScrobbleChartPaneController {
|
|||||||
// dropDownTimeRange.setItems(FXCollections.observableArrayList("week", "month",
|
// dropDownTimeRange.setItems(FXCollections.observableArrayList("week", "month",
|
||||||
// "3 month", "6 month", "year"));
|
// "3 month", "6 month", "year"));
|
||||||
dropDownTimeRange.getItems().addAll("week", "30 day", "90 day", "180 day", "year");
|
dropDownTimeRange.getItems().addAll("week", "30 day", "90 day", "180 day", "year");
|
||||||
|
|
||||||
|
dropDownTimeRange.getSelectionModel().select(0);
|
||||||
}
|
}
|
||||||
|
|
||||||
@FXML
|
@FXML
|
||||||
|
@ -0,0 +1,213 @@
|
|||||||
|
package sarsoo.fmframework.fx.controller;
|
||||||
|
|
||||||
|
import java.util.ArrayList;
|
||||||
|
import java.util.Collections;
|
||||||
|
import java.util.Comparator;
|
||||||
|
|
||||||
|
import javafx.application.Platform;
|
||||||
|
import javafx.collections.ObservableList;
|
||||||
|
import javafx.concurrent.WorkerStateEvent;
|
||||||
|
import javafx.event.ActionEvent;
|
||||||
|
import javafx.event.EventHandler;
|
||||||
|
import javafx.fxml.FXML;
|
||||||
|
import javafx.scene.Node;
|
||||||
|
import javafx.scene.control.Button;
|
||||||
|
import javafx.scene.control.ChoiceBox;
|
||||||
|
import javafx.scene.control.Label;
|
||||||
|
import javafx.scene.control.ToolBar;
|
||||||
|
import javafx.scene.image.Image;
|
||||||
|
import javafx.scene.image.ImageView;
|
||||||
|
import javafx.scene.layout.BorderPane;
|
||||||
|
import javafx.scene.layout.GridPane;
|
||||||
|
import javafx.scene.layout.TilePane;
|
||||||
|
import sarsoo.fmframework.config.Config;
|
||||||
|
import sarsoo.fmframework.fm.FmUserNetwork;
|
||||||
|
import sarsoo.fmframework.fm.TimePeriod;
|
||||||
|
import sarsoo.fmframework.fx.FmFramework;
|
||||||
|
import sarsoo.fmframework.fx.TiledImage;
|
||||||
|
import sarsoo.fmframework.fx.service.GetFXImageService;
|
||||||
|
import sarsoo.fmframework.fx.service.GetTopAlbumsService;
|
||||||
|
import sarsoo.fmframework.music.Album;
|
||||||
|
import sarsoo.fmframework.music.FMObj;
|
||||||
|
import sarsoo.fmframework.util.FMObjList;
|
||||||
|
|
||||||
|
public class TopAlbumController {
|
||||||
|
|
||||||
|
@FXML
|
||||||
|
protected BorderPane borderPane;
|
||||||
|
|
||||||
|
@FXML
|
||||||
|
protected ToolBar toolBar;
|
||||||
|
|
||||||
|
@FXML
|
||||||
|
protected ChoiceBox<String> dropDownTimeRange;
|
||||||
|
|
||||||
|
@FXML
|
||||||
|
protected ChoiceBox<Integer> dropDownLimit;
|
||||||
|
|
||||||
|
@FXML
|
||||||
|
protected Button buttonLoad;
|
||||||
|
|
||||||
|
@FXML
|
||||||
|
protected Button buttonGenerate;
|
||||||
|
|
||||||
|
@FXML
|
||||||
|
protected GridPane gridPane;
|
||||||
|
|
||||||
|
@FXML
|
||||||
|
protected TilePane tilePane;
|
||||||
|
|
||||||
|
FMObjList albums;
|
||||||
|
ArrayList<TiledImage> images = new ArrayList<>();
|
||||||
|
|
||||||
|
@FXML
|
||||||
|
public void initialize() {
|
||||||
|
dropDownTimeRange.getItems().addAll("week", "30 day", "90 day", "180 day", "year", "overall");
|
||||||
|
|
||||||
|
for (int i = 1; i < 16; i++) {
|
||||||
|
dropDownLimit.getItems().add(i);
|
||||||
|
}
|
||||||
|
|
||||||
|
for (int i = 20; i < 110; i+=10) {
|
||||||
|
dropDownLimit.getItems().add(i);
|
||||||
|
}
|
||||||
|
|
||||||
|
dropDownTimeRange.getSelectionModel().select(0);
|
||||||
|
dropDownLimit.getSelectionModel().select(0);
|
||||||
|
}
|
||||||
|
|
||||||
|
@FXML
|
||||||
|
private void handleLoad(ActionEvent event) {
|
||||||
|
Config config = FmFramework.getSessionConfig();
|
||||||
|
FmUserNetwork net = new FmUserNetwork(config.getValue("api_key"), config.getValue("username"));
|
||||||
|
|
||||||
|
String value = (String) dropDownTimeRange.getValue();
|
||||||
|
|
||||||
|
TimePeriod timePeriod = null;
|
||||||
|
|
||||||
|
switch (value) {
|
||||||
|
case "week":
|
||||||
|
timePeriod = TimePeriod.SEVENDAY;
|
||||||
|
break;
|
||||||
|
case "30 day":
|
||||||
|
timePeriod = TimePeriod.ONEMONTH;
|
||||||
|
break;
|
||||||
|
case "90 day":
|
||||||
|
timePeriod = TimePeriod.THREEMONTH;
|
||||||
|
break;
|
||||||
|
case "180 day":
|
||||||
|
timePeriod = TimePeriod.SIXMONTH;
|
||||||
|
break;
|
||||||
|
case "year":
|
||||||
|
timePeriod = TimePeriod.TWELVEMONTH;
|
||||||
|
break;
|
||||||
|
case "overall":
|
||||||
|
timePeriod = TimePeriod.OVERALL;
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
|
||||||
|
GetTopAlbumsService service = new GetTopAlbumsService(timePeriod, dropDownLimit.getValue(), net);
|
||||||
|
|
||||||
|
service.setOnSucceeded(new EventHandler<WorkerStateEvent>() {
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void handle(WorkerStateEvent t) {
|
||||||
|
Platform.runLater(new Runnable() {
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void run() {
|
||||||
|
|
||||||
|
gridPane.getChildren().clear();
|
||||||
|
|
||||||
|
if (albums != null)
|
||||||
|
albums.clear();
|
||||||
|
|
||||||
|
albums = (FMObjList) t.getSource().getValue();
|
||||||
|
|
||||||
|
if (albums.size() > 0) {
|
||||||
|
buttonGenerate.setDisable(false);
|
||||||
|
} else {
|
||||||
|
buttonGenerate.setDisable(true);
|
||||||
|
}
|
||||||
|
|
||||||
|
int counter = 0;
|
||||||
|
for (FMObj fmObj : albums) {
|
||||||
|
Album album = (Album) fmObj;
|
||||||
|
|
||||||
|
Label albumName = new Label(album.getName().toLowerCase());
|
||||||
|
Label artistName = new Label(album.getArtist().getName().toLowerCase());
|
||||||
|
Label userPlays = new Label(Integer.toString(album.getUserPlayCount()));
|
||||||
|
|
||||||
|
gridPane.add(new Label(Integer.toString(counter + 1)), 0, counter);
|
||||||
|
gridPane.add(albumName, 1, counter);
|
||||||
|
gridPane.add(artistName, 2, counter);
|
||||||
|
gridPane.add(userPlays, 3, counter);
|
||||||
|
|
||||||
|
counter++;
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
});
|
||||||
|
}
|
||||||
|
});
|
||||||
|
|
||||||
|
service.start();
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
@FXML
|
||||||
|
private void handleGenerate(ActionEvent event) {
|
||||||
|
|
||||||
|
if (albums != null) {
|
||||||
|
if (albums.size() > 0) {
|
||||||
|
tilePane.getChildren().clear();
|
||||||
|
images.clear();
|
||||||
|
|
||||||
|
int counter = 0;
|
||||||
|
for (FMObj obj : albums) {
|
||||||
|
|
||||||
|
Album album = (Album) obj;
|
||||||
|
|
||||||
|
GetFXImageService service = new GetFXImageService(album.getImageURL().toString(), counter);
|
||||||
|
|
||||||
|
service.setOnSucceeded(new EventHandler<WorkerStateEvent>() {
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void handle(WorkerStateEvent t) {
|
||||||
|
|
||||||
|
TiledImage image = (TiledImage) t.getSource().getValue();
|
||||||
|
|
||||||
|
images.add(image);
|
||||||
|
|
||||||
|
refreshImages();
|
||||||
|
}
|
||||||
|
});
|
||||||
|
|
||||||
|
service.start();
|
||||||
|
counter++;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
private void refreshImages() {
|
||||||
|
ObservableList<Node> list = tilePane.getChildren();
|
||||||
|
|
||||||
|
list.clear();
|
||||||
|
|
||||||
|
Collections.sort(images, new Comparator<TiledImage>() {
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public int compare(TiledImage arg0, TiledImage arg1) {
|
||||||
|
return arg0.getIndex() - arg1.getIndex();
|
||||||
|
}
|
||||||
|
|
||||||
|
});
|
||||||
|
|
||||||
|
for(TiledImage image: images) {
|
||||||
|
list.add(new ImageView(image));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
@ -62,11 +62,7 @@ public class AlbumBorderPaneController extends FMObjBorderPaneController {
|
|||||||
viewArtist.setOnAction(new EventHandler<ActionEvent>() {
|
viewArtist.setOnAction(new EventHandler<ActionEvent>() {
|
||||||
@Override
|
@Override
|
||||||
public void handle(ActionEvent e) {
|
public void handle(ActionEvent e) {
|
||||||
try {
|
FmFramework.getController().addTab(new ArtistTab(album.getArtist()));
|
||||||
FmFramework.getController().addTab(new ArtistTab(album.getArtist()));
|
|
||||||
} catch (IOException e1) {
|
|
||||||
e1.printStackTrace();
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
} else {
|
} else {
|
||||||
|
@ -53,11 +53,7 @@ public class TrackBorderPaneController extends FMObjBorderPaneController {
|
|||||||
viewAlbum.setOnAction(new EventHandler<ActionEvent>() {
|
viewAlbum.setOnAction(new EventHandler<ActionEvent>() {
|
||||||
@Override
|
@Override
|
||||||
public void handle(ActionEvent e) {
|
public void handle(ActionEvent e) {
|
||||||
try {
|
FmFramework.getController().addTab(new AlbumTab(track.getAlbum()));
|
||||||
FmFramework.getController().addTab(new AlbumTab(track.getAlbum()));
|
|
||||||
} catch (IOException e1) {
|
|
||||||
e1.printStackTrace();
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
}else {
|
}else {
|
||||||
@ -68,11 +64,7 @@ public class TrackBorderPaneController extends FMObjBorderPaneController {
|
|||||||
viewArtist.setOnAction(new EventHandler<ActionEvent>() {
|
viewArtist.setOnAction(new EventHandler<ActionEvent>() {
|
||||||
@Override
|
@Override
|
||||||
public void handle(ActionEvent e) {
|
public void handle(ActionEvent e) {
|
||||||
try {
|
FmFramework.getController().addTab(new ArtistTab(track.getArtist()));
|
||||||
FmFramework.getController().addTab(new ArtistTab(track.getArtist()));
|
|
||||||
} catch (IOException e1) {
|
|
||||||
e1.printStackTrace();
|
|
||||||
}//
|
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
}else {
|
}else {
|
||||||
|
@ -0,0 +1,42 @@
|
|||||||
|
package sarsoo.fmframework.fx.service;
|
||||||
|
|
||||||
|
import javafx.concurrent.Service;
|
||||||
|
import javafx.concurrent.Task;
|
||||||
|
import javafx.scene.image.Image;
|
||||||
|
import sarsoo.fmframework.fx.TiledImage;
|
||||||
|
import sarsoo.fmframework.log.Logger;
|
||||||
|
import sarsoo.fmframework.log.entry.ErrorEntry;
|
||||||
|
|
||||||
|
public class GetFXImageService extends Service<TiledImage> {
|
||||||
|
|
||||||
|
private String url;
|
||||||
|
private int index;
|
||||||
|
|
||||||
|
public GetFXImageService(String url, int index) {
|
||||||
|
super();
|
||||||
|
this.url = url;
|
||||||
|
this.index = index;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
protected Task<TiledImage> createTask() {
|
||||||
|
return new Task<TiledImage>() {
|
||||||
|
|
||||||
|
@Override
|
||||||
|
protected TiledImage call() throws Exception {
|
||||||
|
|
||||||
|
return new TiledImage(url, index);
|
||||||
|
}
|
||||||
|
|
||||||
|
};
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
protected void failed() {
|
||||||
|
super.failed();
|
||||||
|
|
||||||
|
Logger.getLog().logError(new ErrorEntry("failed to get image " + url));
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
@ -0,0 +1,45 @@
|
|||||||
|
package sarsoo.fmframework.fx.service;
|
||||||
|
|
||||||
|
import javafx.concurrent.Service;
|
||||||
|
import javafx.concurrent.Task;
|
||||||
|
import sarsoo.fmframework.fm.FmUserNetwork;
|
||||||
|
import sarsoo.fmframework.fm.TimePeriod;
|
||||||
|
import sarsoo.fmframework.log.Logger;
|
||||||
|
import sarsoo.fmframework.log.entry.ErrorEntry;
|
||||||
|
import sarsoo.fmframework.util.FMObjList;
|
||||||
|
|
||||||
|
public class GetTopAlbumsService extends Service<FMObjList> {
|
||||||
|
|
||||||
|
private int limit;
|
||||||
|
private TimePeriod period;
|
||||||
|
private FmUserNetwork net;
|
||||||
|
|
||||||
|
public GetTopAlbumsService(TimePeriod period, int limit, FmUserNetwork net) {
|
||||||
|
super();
|
||||||
|
this.limit = limit;
|
||||||
|
this.period = period;
|
||||||
|
this.net = net;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
protected Task<FMObjList> createTask() {
|
||||||
|
return new Task<FMObjList>() {
|
||||||
|
|
||||||
|
@Override
|
||||||
|
protected FMObjList call() throws Exception {
|
||||||
|
|
||||||
|
return net.getTopAlbums(period, limit);
|
||||||
|
}
|
||||||
|
|
||||||
|
};
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
protected void failed() {
|
||||||
|
super.failed();
|
||||||
|
|
||||||
|
Logger.getLog().logError(new ErrorEntry("failed to get top albums"));
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
@ -14,7 +14,7 @@ import javafx.fxml.FXMLLoader;
|
|||||||
|
|
||||||
public class AlbumTab extends Tab {
|
public class AlbumTab extends Tab {
|
||||||
|
|
||||||
public AlbumTab(Album album) throws IOException {
|
public AlbumTab(Album album) {
|
||||||
|
|
||||||
setText(album.getName().toLowerCase());
|
setText(album.getName().toLowerCase());
|
||||||
|
|
||||||
@ -24,17 +24,23 @@ public class AlbumTab extends Tab {
|
|||||||
|
|
||||||
loader.setController(controller);
|
loader.setController(controller);
|
||||||
|
|
||||||
AnchorPane pane = (AnchorPane) loader.load();
|
AnchorPane pane;
|
||||||
|
|
||||||
|
try {
|
||||||
|
pane = (AnchorPane) loader.load();
|
||||||
|
|
||||||
|
AnchorPane.setTopAnchor(pane, 0.0);
|
||||||
|
AnchorPane.setLeftAnchor(pane, 0.0);
|
||||||
|
AnchorPane.setRightAnchor(pane, 0.0);
|
||||||
|
AnchorPane.setBottomAnchor(pane, 0.0);
|
||||||
|
|
||||||
AnchorPane.setTopAnchor(pane, 0.0);
|
setContent(pane);
|
||||||
AnchorPane.setLeftAnchor(pane, 0.0);
|
|
||||||
AnchorPane.setRightAnchor(pane, 0.0);
|
|
||||||
AnchorPane.setBottomAnchor(pane, 0.0);
|
|
||||||
|
|
||||||
setContent(pane);
|
|
||||||
|
|
||||||
controller.populate(album);
|
|
||||||
|
|
||||||
|
controller.populate(album);
|
||||||
|
|
||||||
|
} catch (IOException e) {
|
||||||
|
e.printStackTrace();
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
@ -10,7 +10,7 @@ import javafx.fxml.FXMLLoader;
|
|||||||
|
|
||||||
public class ArtistTab extends Tab{
|
public class ArtistTab extends Tab{
|
||||||
|
|
||||||
public ArtistTab(Artist artist) throws IOException {
|
public ArtistTab(Artist artist) {
|
||||||
|
|
||||||
setText(artist.getName().toLowerCase());
|
setText(artist.getName().toLowerCase());
|
||||||
|
|
||||||
@ -20,16 +20,22 @@ public class ArtistTab extends Tab{
|
|||||||
|
|
||||||
loader.setController(controller);
|
loader.setController(controller);
|
||||||
|
|
||||||
AnchorPane pane = (AnchorPane) loader.load();
|
AnchorPane pane;
|
||||||
|
|
||||||
AnchorPane.setTopAnchor(pane, 0.0);
|
|
||||||
AnchorPane.setLeftAnchor(pane, 0.0);
|
|
||||||
AnchorPane.setRightAnchor(pane, 0.0);
|
|
||||||
AnchorPane.setBottomAnchor(pane, 0.0);
|
|
||||||
|
|
||||||
setContent(pane);
|
try {
|
||||||
|
pane = (AnchorPane) loader.load();
|
||||||
controller.populate(artist);
|
|
||||||
|
AnchorPane.setTopAnchor(pane, 0.0);
|
||||||
|
AnchorPane.setLeftAnchor(pane, 0.0);
|
||||||
|
AnchorPane.setRightAnchor(pane, 0.0);
|
||||||
|
AnchorPane.setBottomAnchor(pane, 0.0);
|
||||||
|
|
||||||
|
setContent(pane);
|
||||||
|
|
||||||
|
controller.populate(artist);
|
||||||
|
} catch (IOException e) {
|
||||||
|
e.printStackTrace();
|
||||||
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -9,30 +9,37 @@ import javafx.fxml.FXMLLoader;
|
|||||||
|
|
||||||
public class FMObjListEditTab extends Tab {
|
public class FMObjListEditTab extends Tab {
|
||||||
|
|
||||||
public FMObjListEditTab() throws IOException {
|
public FMObjListEditTab() {
|
||||||
|
|
||||||
setText("List");
|
setText("List");
|
||||||
|
|
||||||
FXMLLoader loader = new FXMLLoader(getClass().getResource("../ui/FMObjListEditPane.fxml"));
|
FXMLLoader loader = new FXMLLoader(getClass().getResource("../ui/FMObjListEditPane.fxml"));
|
||||||
|
|
||||||
AnchorPane pane = (AnchorPane) loader.load();
|
AnchorPane pane;
|
||||||
|
|
||||||
|
try {
|
||||||
|
pane = (AnchorPane) loader.load();
|
||||||
|
|
||||||
|
AnchorPane.setTopAnchor(pane, 0.0);
|
||||||
|
AnchorPane.setLeftAnchor(pane, 0.0);
|
||||||
|
AnchorPane.setRightAnchor(pane, 0.0);
|
||||||
|
AnchorPane.setBottomAnchor(pane, 0.0);
|
||||||
|
|
||||||
AnchorPane.setTopAnchor(pane, 0.0);
|
// BorderPane
|
||||||
AnchorPane.setLeftAnchor(pane, 0.0);
|
|
||||||
AnchorPane.setRightAnchor(pane, 0.0);
|
|
||||||
AnchorPane.setBottomAnchor(pane, 0.0);
|
|
||||||
|
|
||||||
// BorderPane
|
setText("list");
|
||||||
|
|
||||||
setText("list");
|
setContent(pane);
|
||||||
|
|
||||||
setContent(pane);
|
|
||||||
|
|
||||||
FMObjListPaneEditController control = (FMObjListPaneEditController) loader.getController();
|
|
||||||
|
|
||||||
|
FMObjListPaneEditController control = (FMObjListPaneEditController) loader.getController();
|
||||||
|
|
||||||
|
} catch (IOException e) {
|
||||||
|
// TODO Auto-generated catch block
|
||||||
|
e.printStackTrace();
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
public FMObjListEditTab(FMObjList list) throws IOException {
|
public FMObjListEditTab(FMObjList list) {
|
||||||
|
|
||||||
if (list.getGroupName() != null) {
|
if (list.getGroupName() != null) {
|
||||||
setText(list.getGroupName());
|
setText(list.getGroupName());
|
||||||
@ -42,20 +49,27 @@ public class FMObjListEditTab extends Tab {
|
|||||||
|
|
||||||
FXMLLoader loader = new FXMLLoader(getClass().getResource("../ui/FMObjListEditPane.fxml"));
|
FXMLLoader loader = new FXMLLoader(getClass().getResource("../ui/FMObjListEditPane.fxml"));
|
||||||
|
|
||||||
AnchorPane pane = (AnchorPane) loader.load();
|
AnchorPane pane;
|
||||||
|
|
||||||
AnchorPane.setTopAnchor(pane, 0.0);
|
try {
|
||||||
AnchorPane.setLeftAnchor(pane, 0.0);
|
pane = (AnchorPane) loader.load();
|
||||||
AnchorPane.setRightAnchor(pane, 0.0);
|
|
||||||
AnchorPane.setBottomAnchor(pane, 0.0);
|
AnchorPane.setTopAnchor(pane, 0.0);
|
||||||
|
AnchorPane.setLeftAnchor(pane, 0.0);
|
||||||
|
AnchorPane.setRightAnchor(pane, 0.0);
|
||||||
|
AnchorPane.setBottomAnchor(pane, 0.0);
|
||||||
|
|
||||||
// BorderPane
|
// BorderPane
|
||||||
|
|
||||||
setContent(pane);
|
setContent(pane);
|
||||||
|
|
||||||
FMObjListPaneEditController control = (FMObjListPaneEditController) loader.getController();
|
FMObjListPaneEditController control = (FMObjListPaneEditController) loader.getController();
|
||||||
control.setList(list);
|
control.setList(list);
|
||||||
control.refresh();
|
control.refresh();
|
||||||
|
|
||||||
|
} catch (IOException e) {
|
||||||
|
e.printStackTrace();
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
@ -9,51 +9,31 @@ import javafx.fxml.FXMLLoader;
|
|||||||
|
|
||||||
public class FMObjListTab extends Tab {
|
public class FMObjListTab extends Tab {
|
||||||
|
|
||||||
public FMObjListTab(FMObjList list) throws IOException {
|
public FMObjListTab(FMObjList list) {
|
||||||
|
|
||||||
setText(list.getGroupName());
|
setText(list.getGroupName());
|
||||||
|
|
||||||
FXMLLoader loader = new FXMLLoader(getClass().getResource("../ui/FMObjListPane.fxml"));
|
FXMLLoader loader = new FXMLLoader(getClass().getResource("../ui/FMObjListPane.fxml"));
|
||||||
|
|
||||||
AnchorPane pane = (AnchorPane) loader.load();
|
AnchorPane pane;
|
||||||
|
try {
|
||||||
|
pane = (AnchorPane) loader.load();
|
||||||
|
|
||||||
|
AnchorPane.setTopAnchor(pane, 0.0);
|
||||||
|
AnchorPane.setLeftAnchor(pane, 0.0);
|
||||||
|
AnchorPane.setRightAnchor(pane, 0.0);
|
||||||
|
AnchorPane.setBottomAnchor(pane, 0.0);
|
||||||
|
|
||||||
AnchorPane.setTopAnchor(pane, 0.0);
|
setContent(pane);
|
||||||
AnchorPane.setLeftAnchor(pane, 0.0);
|
|
||||||
AnchorPane.setRightAnchor(pane, 0.0);
|
setText(list.getGroupName());
|
||||||
AnchorPane.setBottomAnchor(pane, 0.0);
|
|
||||||
|
|
||||||
setContent(pane);
|
FMObjListPaneController control = (FMObjListPaneController) loader.getController();
|
||||||
|
|
||||||
setText(list.getGroupName());
|
|
||||||
|
|
||||||
FMObjListPaneController control = (FMObjListPaneController) loader.getController();
|
|
||||||
|
|
||||||
control.populate(list);
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
control.populate(list);
|
||||||
|
|
||||||
|
} catch (IOException e) {
|
||||||
|
e.printStackTrace();
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
// public FMObjListTab() throws IOException {
|
|
||||||
//
|
|
||||||
// setText("List");
|
|
||||||
//
|
|
||||||
// FXMLLoader loader = new FXMLLoader(getClass().getResource("ui/FMObjListPaneEdit.fxml"));
|
|
||||||
//
|
|
||||||
// AnchorPane pane = (AnchorPane) loader.load();
|
|
||||||
//
|
|
||||||
// AnchorPane.setTopAnchor(pane, 0.0);
|
|
||||||
// AnchorPane.setLeftAnchor(pane, 0.0);
|
|
||||||
// AnchorPane.setRightAnchor(pane, 0.0);
|
|
||||||
// AnchorPane.setBottomAnchor(pane, 0.0);
|
|
||||||
//
|
|
||||||
//// BorderPane
|
|
||||||
//
|
|
||||||
// setContent(pane);
|
|
||||||
//
|
|
||||||
// FMObjListPaneEditController control = (FMObjListPaneEditController) loader.getController();
|
|
||||||
//
|
|
||||||
//
|
|
||||||
// }
|
|
||||||
|
|
||||||
}
|
}
|
||||||
|
@ -15,21 +15,26 @@ public abstract class FMObjTab extends Tab {
|
|||||||
protected AnchorPane infoAnchorPane;
|
protected AnchorPane infoAnchorPane;
|
||||||
protected FMObjBorderPaneController controller;
|
protected FMObjBorderPaneController controller;
|
||||||
|
|
||||||
protected FMObjTab() throws IOException {
|
protected FMObjTab() {
|
||||||
|
|
||||||
FXMLLoader loader = new FXMLLoader(getClass().getResource("../ui/FMObjBorderPane.fxml"));
|
FXMLLoader loader = new FXMLLoader(getClass().getResource("../ui/FMObjBorderPane.fxml"));
|
||||||
|
|
||||||
AnchorPane anchor = (AnchorPane) loader.load();
|
AnchorPane anchor;
|
||||||
|
try {
|
||||||
|
anchor = (AnchorPane) loader.load();
|
||||||
|
|
||||||
AnchorPane.setTopAnchor(anchor, 0.0);
|
AnchorPane.setTopAnchor(anchor, 0.0);
|
||||||
AnchorPane.setLeftAnchor(anchor, 0.0);
|
AnchorPane.setLeftAnchor(anchor, 0.0);
|
||||||
AnchorPane.setRightAnchor(anchor, 0.0);
|
AnchorPane.setRightAnchor(anchor, 0.0);
|
||||||
AnchorPane.setBottomAnchor(anchor, 0.0);
|
AnchorPane.setBottomAnchor(anchor, 0.0);
|
||||||
|
|
||||||
this.controller = (FMObjBorderPaneController) loader.getController();
|
this.controller = (FMObjBorderPaneController) loader.getController();
|
||||||
|
|
||||||
setContent(anchor);
|
|
||||||
|
|
||||||
|
setContent(anchor);
|
||||||
|
|
||||||
|
} catch (IOException e) {
|
||||||
|
e.printStackTrace();
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
public AnchorPane getInfoAnchorPane() {
|
public AnchorPane getInfoAnchorPane() {
|
||||||
|
@ -9,26 +9,30 @@ import javafx.fxml.FXMLLoader;
|
|||||||
|
|
||||||
public class ScrobbleChartTab extends Tab {
|
public class ScrobbleChartTab extends Tab {
|
||||||
|
|
||||||
public ScrobbleChartTab() throws IOException {
|
public ScrobbleChartTab() {
|
||||||
|
|
||||||
setText("scrobbles");
|
setText("scrobbles");
|
||||||
|
|
||||||
FXMLLoader loader = new FXMLLoader(getClass().getResource("../ui/ScrobbleChartPane.fxml"));
|
FXMLLoader loader = new FXMLLoader(getClass().getResource("../ui/ScrobbleChartPane.fxml"));
|
||||||
|
|
||||||
AnchorPane pane = (AnchorPane) loader.load();
|
AnchorPane pane;
|
||||||
|
|
||||||
AnchorPane.setTopAnchor(pane, 0.0);
|
|
||||||
AnchorPane.setLeftAnchor(pane, 0.0);
|
|
||||||
AnchorPane.setRightAnchor(pane, 0.0);
|
|
||||||
AnchorPane.setBottomAnchor(pane, 0.0);
|
|
||||||
|
|
||||||
setContent(pane);
|
|
||||||
|
|
||||||
ScrobbleChartPaneController control = (ScrobbleChartPaneController) loader.getController();
|
|
||||||
|
|
||||||
//control.populate();
|
|
||||||
|
|
||||||
|
|
||||||
|
try {
|
||||||
|
pane = (AnchorPane) loader.load();
|
||||||
|
|
||||||
|
AnchorPane.setTopAnchor(pane, 0.0);
|
||||||
|
AnchorPane.setLeftAnchor(pane, 0.0);
|
||||||
|
AnchorPane.setRightAnchor(pane, 0.0);
|
||||||
|
AnchorPane.setBottomAnchor(pane, 0.0);
|
||||||
|
|
||||||
|
setContent(pane);
|
||||||
|
|
||||||
|
ScrobbleChartPaneController control = (ScrobbleChartPaneController) loader.getController();
|
||||||
|
|
||||||
|
//control.populate();
|
||||||
|
} catch (IOException e) {
|
||||||
|
e.printStackTrace();
|
||||||
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -9,25 +9,29 @@ import javafx.fxml.FXMLLoader;
|
|||||||
|
|
||||||
public class ScrobbleTab extends Tab {
|
public class ScrobbleTab extends Tab {
|
||||||
|
|
||||||
public ScrobbleTab() throws IOException {
|
public ScrobbleTab() {
|
||||||
|
|
||||||
setText("scrobble");
|
setText("scrobble");
|
||||||
|
|
||||||
FXMLLoader loader = new FXMLLoader(getClass().getResource("../ui/ScrobblePane.fxml"));
|
FXMLLoader loader = new FXMLLoader(getClass().getResource("../ui/ScrobblePane.fxml"));
|
||||||
|
|
||||||
AnchorPane pane = (AnchorPane) loader.load();
|
AnchorPane pane;
|
||||||
|
try {
|
||||||
|
pane = (AnchorPane) loader.load();
|
||||||
|
|
||||||
|
AnchorPane.setTopAnchor(pane, 0.0);
|
||||||
|
AnchorPane.setLeftAnchor(pane, 0.0);
|
||||||
|
AnchorPane.setRightAnchor(pane, 0.0);
|
||||||
|
AnchorPane.setBottomAnchor(pane, 0.0);
|
||||||
|
|
||||||
AnchorPane.setTopAnchor(pane, 0.0);
|
setContent(pane);
|
||||||
AnchorPane.setLeftAnchor(pane, 0.0);
|
|
||||||
AnchorPane.setRightAnchor(pane, 0.0);
|
|
||||||
AnchorPane.setBottomAnchor(pane, 0.0);
|
|
||||||
|
|
||||||
setContent(pane);
|
ScrobblePaneController control = (ScrobblePaneController) loader.getController();
|
||||||
|
|
||||||
ScrobblePaneController control = (ScrobblePaneController) loader.getController();
|
//control.populate();
|
||||||
|
} catch (IOException e) {
|
||||||
//control.populate();
|
e.printStackTrace();
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
37
src/main/java/sarsoo/fmframework/fx/tab/TopAlbumTab.java
Normal file
37
src/main/java/sarsoo/fmframework/fx/tab/TopAlbumTab.java
Normal file
@ -0,0 +1,37 @@
|
|||||||
|
package sarsoo.fmframework.fx.tab;
|
||||||
|
|
||||||
|
import java.io.IOException;
|
||||||
|
|
||||||
|
import javafx.scene.control.*;
|
||||||
|
import javafx.scene.layout.*;
|
||||||
|
import sarsoo.fmframework.fx.controller.TopAlbumController;
|
||||||
|
import javafx.fxml.FXMLLoader;
|
||||||
|
|
||||||
|
public class TopAlbumTab extends Tab {
|
||||||
|
|
||||||
|
public TopAlbumTab() {
|
||||||
|
|
||||||
|
setText("top albums");
|
||||||
|
|
||||||
|
FXMLLoader loader = new FXMLLoader(getClass().getResource("../ui/TopAlbumPane.fxml"));
|
||||||
|
|
||||||
|
AnchorPane pane;
|
||||||
|
try {
|
||||||
|
pane = (AnchorPane) loader.load();
|
||||||
|
AnchorPane.setTopAnchor(pane, 0.0);
|
||||||
|
AnchorPane.setLeftAnchor(pane, 0.0);
|
||||||
|
AnchorPane.setRightAnchor(pane, 0.0);
|
||||||
|
AnchorPane.setBottomAnchor(pane, 0.0);
|
||||||
|
|
||||||
|
setContent(pane);
|
||||||
|
|
||||||
|
TopAlbumController control = (TopAlbumController) loader.getController();
|
||||||
|
|
||||||
|
//control.populate();
|
||||||
|
|
||||||
|
} catch (IOException e) {
|
||||||
|
e.printStackTrace();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
@ -12,7 +12,7 @@ import javafx.fxml.FXMLLoader;
|
|||||||
|
|
||||||
public class TrackTab extends Tab {
|
public class TrackTab extends Tab {
|
||||||
|
|
||||||
public TrackTab(Track track) throws IOException {
|
public TrackTab(Track track) {
|
||||||
|
|
||||||
setText(track.getName().toLowerCase());
|
setText(track.getName().toLowerCase());
|
||||||
|
|
||||||
@ -22,16 +22,22 @@ public class TrackTab extends Tab {
|
|||||||
|
|
||||||
loader.setController(controller);
|
loader.setController(controller);
|
||||||
|
|
||||||
AnchorPane pane = (AnchorPane) loader.load();
|
AnchorPane pane;
|
||||||
|
try {
|
||||||
|
pane = (AnchorPane) loader.load();
|
||||||
|
|
||||||
|
AnchorPane.setTopAnchor(pane, 0.0);
|
||||||
|
AnchorPane.setLeftAnchor(pane, 0.0);
|
||||||
|
AnchorPane.setRightAnchor(pane, 0.0);
|
||||||
|
AnchorPane.setBottomAnchor(pane, 0.0);
|
||||||
|
|
||||||
AnchorPane.setTopAnchor(pane, 0.0);
|
setContent(pane);
|
||||||
AnchorPane.setLeftAnchor(pane, 0.0);
|
|
||||||
AnchorPane.setRightAnchor(pane, 0.0);
|
|
||||||
AnchorPane.setBottomAnchor(pane, 0.0);
|
|
||||||
|
|
||||||
setContent(pane);
|
controller.populate(track);
|
||||||
|
|
||||||
controller.populate(track);
|
} catch (IOException e) {
|
||||||
|
e.printStackTrace();
|
||||||
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1,8 +1,14 @@
|
|||||||
package sarsoo.fmframework.music;
|
package sarsoo.fmframework.music;
|
||||||
|
|
||||||
|
import java.awt.image.BufferedImage;
|
||||||
|
import java.io.IOException;
|
||||||
import java.io.Serializable;
|
import java.io.Serializable;
|
||||||
|
import java.net.MalformedURLException;
|
||||||
|
import java.net.URL;
|
||||||
import java.util.ArrayList;
|
import java.util.ArrayList;
|
||||||
|
|
||||||
|
import javax.imageio.ImageIO;
|
||||||
|
|
||||||
import sarsoo.fmframework.cache.Cacheable;
|
import sarsoo.fmframework.cache.Cacheable;
|
||||||
|
|
||||||
public class Album extends FMObj implements Serializable, Cacheable{
|
public class Album extends FMObj implements Serializable, Cacheable{
|
||||||
@ -11,7 +17,10 @@ public class Album extends FMObj implements Serializable, Cacheable{
|
|||||||
protected Artist artist;
|
protected Artist artist;
|
||||||
protected ArrayList<Tag> tagList;
|
protected ArrayList<Tag> tagList;
|
||||||
protected ArrayList<Track> trackList;
|
protected ArrayList<Track> trackList;
|
||||||
|
|
||||||
|
protected URL imageUrl;
|
||||||
|
protected BufferedImage image;
|
||||||
|
|
||||||
private Album(AlbumBuilder builder) {
|
private Album(AlbumBuilder builder) {
|
||||||
this.name = builder.name;
|
this.name = builder.name;
|
||||||
this.artist = builder.artist;
|
this.artist = builder.artist;
|
||||||
@ -29,9 +38,26 @@ public class Album extends FMObj implements Serializable, Cacheable{
|
|||||||
this.tagList = builder.tagList;
|
this.tagList = builder.tagList;
|
||||||
this.trackList = builder.trackList;
|
this.trackList = builder.trackList;
|
||||||
|
|
||||||
|
this.imageUrl = builder.imageUrl;
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public URL getImageURL() {
|
||||||
|
return imageUrl;
|
||||||
|
}
|
||||||
|
|
||||||
|
public void loadImage() {
|
||||||
|
try {
|
||||||
|
image = ImageIO.read(imageUrl);
|
||||||
|
} catch (IOException e) {
|
||||||
|
e.printStackTrace();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
public BufferedImage getImage() {
|
||||||
|
return image;
|
||||||
|
}
|
||||||
|
|
||||||
public Artist getArtist() {
|
public Artist getArtist() {
|
||||||
return artist;
|
return artist;
|
||||||
}
|
}
|
||||||
@ -87,6 +113,8 @@ public class Album extends FMObj implements Serializable, Cacheable{
|
|||||||
protected ArrayList<Tag> tagList;
|
protected ArrayList<Tag> tagList;
|
||||||
protected ArrayList<Track> trackList;
|
protected ArrayList<Track> trackList;
|
||||||
|
|
||||||
|
protected URL imageUrl;
|
||||||
|
|
||||||
|
|
||||||
public AlbumBuilder(String name, Artist artist) {
|
public AlbumBuilder(String name, Artist artist) {
|
||||||
|
|
||||||
@ -134,6 +162,15 @@ public class Album extends FMObj implements Serializable, Cacheable{
|
|||||||
return this;
|
return this;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public AlbumBuilder setImageUrl(String url) {
|
||||||
|
try {
|
||||||
|
this.imageUrl = new URL(url);
|
||||||
|
} catch (MalformedURLException e) {
|
||||||
|
e.printStackTrace();
|
||||||
|
}
|
||||||
|
return this;
|
||||||
|
}
|
||||||
|
|
||||||
public Album build() {
|
public Album build() {
|
||||||
return new Album(this);
|
return new Album(this);
|
||||||
}
|
}
|
||||||
|
@ -89,6 +89,27 @@
|
|||||||
-fx-background-color: #4D4D4D;
|
-fx-background-color: #4D4D4D;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
.text-area {
|
||||||
|
-fx-background-color: #202124;
|
||||||
|
-fx-text-fill: white;
|
||||||
|
}
|
||||||
|
|
||||||
|
.text-area .content {
|
||||||
|
-fx-background-color: transparent ;
|
||||||
|
}
|
||||||
|
|
||||||
|
.text-area > .viewport {
|
||||||
|
-fx-background-color: transparent;
|
||||||
|
}
|
||||||
|
|
||||||
|
.scroll-pane {
|
||||||
|
-fx-background-color: transparent;
|
||||||
|
}
|
||||||
|
|
||||||
|
.scroll-pane > .viewport {
|
||||||
|
-fx-background-color: transparent;
|
||||||
|
}
|
||||||
|
|
||||||
.text-area {
|
.text-area {
|
||||||
-fx-background-color: #202124;
|
-fx-background-color: #202124;
|
||||||
}
|
}
|
||||||
@ -137,6 +158,7 @@
|
|||||||
.tab{
|
.tab{
|
||||||
-fx-background-insets: 0 1 0 1,0,0;
|
-fx-background-insets: 0 1 0 1,0,0;
|
||||||
}
|
}
|
||||||
|
|
||||||
.tab-pane .tab
|
.tab-pane .tab
|
||||||
{
|
{
|
||||||
-fx-background-color: #202124;
|
-fx-background-color: #202124;
|
||||||
|
@ -71,6 +71,11 @@
|
|||||||
</accelerator></MenuItem>
|
</accelerator></MenuItem>
|
||||||
</items>
|
</items>
|
||||||
</Menu>
|
</Menu>
|
||||||
|
<Menu fx:id="menuTop" mnemonicParsing="false" text="top">
|
||||||
|
<items>
|
||||||
|
<MenuItem fx:id="menuItemAlbumCollage" mnemonicParsing="false" onAction="#handleTopAlbum" text="album" />
|
||||||
|
</items>
|
||||||
|
</Menu>
|
||||||
<Menu fx:id="menuChart" mnemonicParsing="false" text="chart">
|
<Menu fx:id="menuChart" mnemonicParsing="false" text="chart">
|
||||||
<items>
|
<items>
|
||||||
<MenuItem fx:id="menuItemScrobbleChart" mnemonicParsing="false" onAction="#handleScrobbleChart" text="daily scrobbles" />
|
<MenuItem fx:id="menuItemScrobbleChart" mnemonicParsing="false" onAction="#handleScrobbleChart" text="daily scrobbles" />
|
||||||
|
@ -0,0 +1,52 @@
|
|||||||
|
<?xml version="1.0" encoding="UTF-8"?>
|
||||||
|
|
||||||
|
<?import javafx.scene.control.Button?>
|
||||||
|
<?import javafx.scene.control.ChoiceBox?>
|
||||||
|
<?import javafx.scene.control.ScrollPane?>
|
||||||
|
<?import javafx.scene.control.SplitPane?>
|
||||||
|
<?import javafx.scene.control.ToolBar?>
|
||||||
|
<?import javafx.scene.layout.AnchorPane?>
|
||||||
|
<?import javafx.scene.layout.BorderPane?>
|
||||||
|
<?import javafx.scene.layout.ColumnConstraints?>
|
||||||
|
<?import javafx.scene.layout.GridPane?>
|
||||||
|
<?import javafx.scene.layout.TilePane?>
|
||||||
|
|
||||||
|
<AnchorPane prefHeight="484.0" prefWidth="885.0" stylesheets="@../styles/mainPane.css" xmlns="http://javafx.com/javafx/11.0.1" xmlns:fx="http://javafx.com/fxml/1" fx:controller="sarsoo.fmframework.fx.controller.TopAlbumController">
|
||||||
|
<children>
|
||||||
|
<BorderPane fx:id="borderPane" prefHeight="327.0" prefWidth="600.0" styleClass="backGround" stylesheets="@../styles/ObjPane.css" AnchorPane.bottomAnchor="0.0" AnchorPane.leftAnchor="0.0" AnchorPane.rightAnchor="0.0" AnchorPane.topAnchor="0.0">
|
||||||
|
<bottom>
|
||||||
|
<ToolBar fx:id="toolBar" prefHeight="40.0" prefWidth="200.0" BorderPane.alignment="CENTER">
|
||||||
|
<items>
|
||||||
|
<ChoiceBox fx:id="dropDownLimit" prefHeight="26.0" prefWidth="79.0" />
|
||||||
|
<ChoiceBox fx:id="dropDownTimeRange" prefHeight="25.0" prefWidth="208.0" />
|
||||||
|
<Button fx:id="buttonLoad" mnemonicParsing="false" onAction="#handleLoad" text="load" />
|
||||||
|
<Button fx:id="buttonGenerate" disable="true" mnemonicParsing="false" onAction="#handleGenerate" text="generate" />
|
||||||
|
</items>
|
||||||
|
</ToolBar>
|
||||||
|
</bottom>
|
||||||
|
<center>
|
||||||
|
<SplitPane dividerPositions="0.5" prefHeight="160.0" prefWidth="200.0" BorderPane.alignment="CENTER">
|
||||||
|
<items>
|
||||||
|
<ScrollPane fitToHeight="true" fitToWidth="true">
|
||||||
|
<content>
|
||||||
|
<GridPane fx:id="gridPane" alignment="CENTER" styleClass="backGround">
|
||||||
|
<columnConstraints>
|
||||||
|
<ColumnConstraints halignment="CENTER" hgrow="NEVER" maxWidth="30.0" minWidth="30.0" />
|
||||||
|
<ColumnConstraints halignment="CENTER" hgrow="SOMETIMES" minWidth="10.0" prefWidth="300.0" />
|
||||||
|
<ColumnConstraints halignment="CENTER" hgrow="SOMETIMES" minWidth="10.0" prefWidth="128.0" />
|
||||||
|
<ColumnConstraints halignment="CENTER" hgrow="NEVER" maxWidth="40.0" minWidth="50.0" />
|
||||||
|
</columnConstraints>
|
||||||
|
</GridPane>
|
||||||
|
</content>
|
||||||
|
</ScrollPane>
|
||||||
|
<ScrollPane fitToWidth="true" hbarPolicy="NEVER">
|
||||||
|
<content>
|
||||||
|
<TilePane fx:id="tilePane" alignment="CENTER" prefColumns="3" prefHeight="0.0" prefWidth="0.0" />
|
||||||
|
</content>
|
||||||
|
</ScrollPane>
|
||||||
|
</items>
|
||||||
|
</SplitPane>
|
||||||
|
</center>
|
||||||
|
</BorderPane>
|
||||||
|
</children>
|
||||||
|
</AnchorPane>
|
@ -55,7 +55,7 @@ public class FmUserNetworkTest {
|
|||||||
|
|
||||||
FMObjList list;
|
FMObjList list;
|
||||||
try {
|
try {
|
||||||
list = net.getTopAlbums("7day", limit);
|
list = net.getTopAlbums(TimePeriod.SEVENDAY, limit);
|
||||||
|
|
||||||
assertEquals(limit, list.size());
|
assertEquals(limit, list.size());
|
||||||
|
|
||||||
@ -73,7 +73,7 @@ public class FmUserNetworkTest {
|
|||||||
|
|
||||||
FMObjList list;
|
FMObjList list;
|
||||||
try {
|
try {
|
||||||
list = net.getTopArtists("7day", limit);
|
list = net.getTopArtists(TimePeriod.SEVENDAY, limit);
|
||||||
|
|
||||||
// list.stream().forEach(System.out::println);
|
// list.stream().forEach(System.out::println);
|
||||||
assertEquals(limit, list.size());
|
assertEquals(limit, list.size());
|
||||||
@ -92,7 +92,7 @@ public class FmUserNetworkTest {
|
|||||||
|
|
||||||
FMObjList list;
|
FMObjList list;
|
||||||
try {
|
try {
|
||||||
list = net.getTopTracks("7day", limit);
|
list = net.getTopTracks(TimePeriod.SEVENDAY, limit);
|
||||||
|
|
||||||
// list.stream().forEach(System.out::println);
|
// list.stream().forEach(System.out::println);
|
||||||
assertEquals(limit, list.size());
|
assertEquals(limit, list.size());
|
||||||
|
Loading…
Reference in New Issue
Block a user