diff options
author | (quasar) nebula <qznebula@protonmail.com> | 2024-01-30 10:50:47 -0400 |
---|---|---|
committer | (quasar) nebula <qznebula@protonmail.com> | 2024-01-30 14:30:05 -0400 |
commit | f12bbec38694c30a79655a0be54768cd83f1efb5 (patch) | |
tree | e002a7784069f9bded34f81006fde798c1224979 | |
parent | fbf452ff1283b79ab5c4428ca6ccb13713ae9107 (diff) |
data: artist: combine artistData with artistAliasData
-rw-r--r-- | src/data/things/artist.js | 44 |
1 files changed, 26 insertions, 18 deletions
diff --git a/src/data/things/artist.js b/src/data/things/artist.js index 5e12f389..a12dc963 100644 --- a/src/data/things/artist.js +++ b/src/data/things/artist.js @@ -6,7 +6,7 @@ import CacheableObject from '#cacheable-object'; import {colors} from '#cli'; import {input} from '#composite'; import find from '#find'; -import {unique} from '#sugar'; +import {stitchArrays, unique} from '#sugar'; import Thing from '#thing'; import {isName, validateArrayItems} from '#validators'; import {sortAlphabetically} from '#wiki-data'; @@ -276,26 +276,34 @@ export class Artist extends Thing { documentThing: Artist, save(results) { - const artistData = results; - - const artistAliasData = results.flatMap((artist) => { - const origRef = Thing.getReference(artist); - return artist.aliasNames?.map((name) => { - const alias = new Artist(); - alias.name = name; - alias.isAlias = true; - alias.aliasedArtist = origRef; - alias.artistData = artistData; - return alias; - }) ?? []; - }); - - return {artistData, artistAliasData}; + const artists = results; + + const artistRefs = + artists.map(artist => Thing.getReference(artist)); + + const artistAliasNames = + artists.map(artist => artist.aliasNames); + + const artistAliases = + stitchArrays({ + originalArtistRef: artistRefs, + aliasNames: artistAliasNames, + }).flatMap(({originalArtistRef, aliasNames}) => + aliasNames.map(name => { + const alias = new Artist(); + alias.name = name; + alias.isAlias = true; + alias.aliasedArtist = originalArtistRef; + return alias; + })); + + const artistData = [...artists, ...artistAliases]; + + return {artistData}; }, - sort({artistData, artistAliasData}) { + sort({artistData}) { sortAlphabetically(artistData); - sortAlphabetically(artistAliasData); }, }); |