mirror of
https://github.com/plan-player-analytics/Plan.git
synced 2025-01-24 09:01:41 +01:00
Added new constructor to ActivityIndex
This commit is contained in:
parent
a8296b3d54
commit
ecb7eeb62b
@ -67,14 +67,18 @@ public class ActivityIndex {
|
|||||||
|
|
||||||
private long playtimeMsThreshold;
|
private long playtimeMsThreshold;
|
||||||
|
|
||||||
public ActivityIndex(
|
public ActivityIndex(DataContainer container, long date, long playtimeMsThreshold) {
|
||||||
DataContainer container, long date,
|
|
||||||
long playtimeMsThreshold
|
|
||||||
) {
|
|
||||||
this.playtimeMsThreshold = playtimeMsThreshold;
|
this.playtimeMsThreshold = playtimeMsThreshold;
|
||||||
|
|
||||||
value = calculate(container, date);
|
|
||||||
this.date = date;
|
this.date = date;
|
||||||
|
value = calculate(container);
|
||||||
|
}
|
||||||
|
|
||||||
|
public ActivityIndex(List<Session> sessions, long date, long playtimeMsThreshold) {
|
||||||
|
this.playtimeMsThreshold = playtimeMsThreshold;
|
||||||
|
|
||||||
|
this.date = date;
|
||||||
|
value = calculate(new SessionsMutator(sessions));
|
||||||
}
|
}
|
||||||
|
|
||||||
public ActivityIndex(double value, long date) {
|
public ActivityIndex(double value, long date) {
|
||||||
@ -86,21 +90,23 @@ public class ActivityIndex {
|
|||||||
return new String[]{"Very Active", "Active", "Regular", "Irregular", "Inactive"};
|
return new String[]{"Very Active", "Active", "Regular", "Irregular", "Inactive"};
|
||||||
}
|
}
|
||||||
|
|
||||||
private double calculate(DataContainer container, long date) {
|
private double calculate(DataContainer container) {
|
||||||
|
Optional<List<Session>> sessionsValue = container.getValue(PlayerKeys.SESSIONS);
|
||||||
|
return sessionsValue
|
||||||
|
.map(sessions -> calculate(new SessionsMutator(sessions)))
|
||||||
|
.orElse(0.0);
|
||||||
|
}
|
||||||
|
|
||||||
|
private double calculate(SessionsMutator sessionsMutator) {
|
||||||
|
if (sessionsMutator.all().isEmpty()) {
|
||||||
|
return 0.0;
|
||||||
|
}
|
||||||
|
|
||||||
long week = TimeAmount.WEEK.toMillis(1L);
|
long week = TimeAmount.WEEK.toMillis(1L);
|
||||||
long weekAgo = date - week;
|
long weekAgo = date - week;
|
||||||
long twoWeeksAgo = date - 2L * week;
|
long twoWeeksAgo = date - 2L * week;
|
||||||
long threeWeeksAgo = date - 3L * week;
|
long threeWeeksAgo = date - 3L * week;
|
||||||
|
|
||||||
Optional<List<Session>> sessionsValue = container.getValue(PlayerKeys.SESSIONS);
|
|
||||||
if (!sessionsValue.isPresent()) {
|
|
||||||
return 0.0;
|
|
||||||
}
|
|
||||||
SessionsMutator sessionsMutator = new SessionsMutator(sessionsValue.get());
|
|
||||||
if (sessionsMutator.all().isEmpty()) {
|
|
||||||
return 0.0;
|
|
||||||
}
|
|
||||||
|
|
||||||
SessionsMutator weekOne = sessionsMutator.filterSessionsBetween(weekAgo, date);
|
SessionsMutator weekOne = sessionsMutator.filterSessionsBetween(weekAgo, date);
|
||||||
SessionsMutator weekTwo = sessionsMutator.filterSessionsBetween(twoWeeksAgo, weekAgo);
|
SessionsMutator weekTwo = sessionsMutator.filterSessionsBetween(twoWeeksAgo, weekAgo);
|
||||||
SessionsMutator weekThree = sessionsMutator.filterSessionsBetween(threeWeeksAgo, twoWeeksAgo);
|
SessionsMutator weekThree = sessionsMutator.filterSessionsBetween(threeWeeksAgo, twoWeeksAgo);
|
||||||
|
Loading…
Reference in New Issue
Block a user