Skip to content

Commit

Permalink
fix: normalize timestamp and only return intersection of snapshots wh…
Browse files Browse the repository at this point in the history
…ere each artist is represented
  • Loading branch information
brandongregoryscott committed Aug 23, 2024
1 parent 5076670 commit a187e91
Showing 1 changed file with 48 additions and 23 deletions.
71 changes: 48 additions & 23 deletions apps/api/src/services/artist-service.ts
Original file line number Diff line number Diff line change
Expand Up @@ -12,8 +12,21 @@ import {
getQuarter,
getWeek,
getYear,
startOfWeek,
startOfDay,
startOfMonth,
startOfQuarter,
startOfYear,
} from "date-fns";
import { uniqBy } from "lodash";
import {
countBy,
groupBy,
intersectionBy,
intersectionWith,
keyBy,
noop,
uniqBy,
} from "lodash";

interface ListArtistSnapshotsOptions {
ids: string[];
Expand Down Expand Up @@ -82,43 +95,37 @@ const ArtistService = {

switch (resolution) {
case "yearly":
snapshots = uniqBy(
return intersectionByNormalizedTimestamp(
ids.length,
snapshots,
(snapshot) =>
`${snapshot.id}_${getYear(snapshot.timestamp)}`
getYear
);
break;
case "quarterly":
snapshots = uniqBy(
return intersectionByNormalizedTimestamp(
ids.length,
snapshots,
(snapshot) =>
`${snapshot.id}_${getQuarter(snapshot.timestamp)}`
getQuarter
);
break;
case "monthly":
snapshots = uniqBy(
return intersectionByNormalizedTimestamp(
ids.length,
snapshots,
(snapshot) =>
`${snapshot.id}_${getMonth(snapshot.timestamp)}`
getMonth
);
break;
case "daily":
snapshots = uniqBy(
return intersectionByNormalizedTimestamp(
ids.length,
snapshots,
(snapshot) =>
`${snapshot.id}_${getDayOfYear(snapshot.timestamp)}`
getDayOfYear
);
break;
case "weekly":
default:
snapshots = uniqBy(
return intersectionByNormalizedTimestamp(
ids.length,
snapshots,
(snapshot) =>
`${snapshot.id}_${getWeek(snapshot.timestamp)}`
getWeek
);
}

return snapshots;
},
};

Expand All @@ -127,8 +134,26 @@ const queryPlaceholder = (count: number): string =>

const normalizeArtistSnapshot = (row: ArtistSnapshotRow): ArtistSnapshot => ({
...row,
timestamp: fromUnixTime(row.timestamp).toISOString(),
timestamp: startOfDay(fromUnixTime(row.timestamp)).toISOString(),
});

const intersectionByNormalizedTimestamp = (
count: number,
snapshots: ArtistSnapshot[],
getInterval: (timestamp: string) => number
): ArtistSnapshot[] => {
const countByTimestamp = countBy(
snapshots,
(snapshot) => snapshot.timestamp
);

return uniqBy(
snapshots.filter(
(snapshot) => countByTimestamp[snapshot.timestamp] === count
),
(snapshot) => `${snapshot.id}_${getInterval(snapshot.timestamp)}`
);
};

export type { Resolution };
export { ArtistService };

0 comments on commit a187e91

Please sign in to comment.