From 431014efacf8bf24b58a21180e71e0db865f30fe Mon Sep 17 00:00:00 2001 From: "(quasar) nebula" Date: Sun, 8 Oct 2023 12:42:15 -0300 Subject: content: listTagsBy{Name,Uses} -> listArtTagsBy{Name,Uses} --- src/content/dependencies/listArtTagsByName.js | 57 +++++++++++++++++++++++++++ src/content/dependencies/listArtTagsByUses.js | 54 +++++++++++++++++++++++++ src/content/dependencies/listTagsByName.js | 57 --------------------------- src/content/dependencies/listTagsByUses.js | 54 ------------------------- 4 files changed, 111 insertions(+), 111 deletions(-) create mode 100644 src/content/dependencies/listArtTagsByName.js create mode 100644 src/content/dependencies/listArtTagsByUses.js delete mode 100644 src/content/dependencies/listTagsByName.js delete mode 100644 src/content/dependencies/listTagsByUses.js (limited to 'src/content/dependencies') diff --git a/src/content/dependencies/listArtTagsByName.js b/src/content/dependencies/listArtTagsByName.js new file mode 100644 index 00000000..9bec9eaa --- /dev/null +++ b/src/content/dependencies/listArtTagsByName.js @@ -0,0 +1,57 @@ +import {stitchArrays, unique} from '#sugar'; +import {sortAlphabetically} from '#wiki-data'; + +export default { + contentDependencies: ['generateListingPage', 'linkArtTagGallery'], + extraDependencies: ['language', 'wikiData'], + + sprawl({artTagData}) { + return {artTagData}; + }, + + query({artTagData}, spec) { + return { + spec, + + artTags: + sortAlphabetically( + artTagData + .filter(artTag => !artTag.isContentWarning)), + }; + }, + + relations(relation, query) { + return { + page: relation('generateListingPage', query.spec), + + artTagLinks: + query.artTags + .map(artTag => relation('linkArtTagGallery', artTag)), + }; + }, + + data(query) { + return { + counts: + query.artTags.map(artTag => + unique([ + ...artTag.indirectlyTaggedInThings, + ...artTag.directlyTaggedInThings, + ]).length), + }; + }, + + generate(data, relations, {language}) { + return relations.page.slots({ + type: 'rows', + rows: + stitchArrays({ + link: relations.artTagLinks, + count: data.counts, + }).map(({link, count}) => ({ + tag: link, + timesUsed: language.countTimesUsed(count, {unit: true}), + })), + }); + }, +}; diff --git a/src/content/dependencies/listArtTagsByUses.js b/src/content/dependencies/listArtTagsByUses.js new file mode 100644 index 00000000..9eb6f185 --- /dev/null +++ b/src/content/dependencies/listArtTagsByUses.js @@ -0,0 +1,54 @@ +import {stitchArrays, unique} from '#sugar'; +import {filterByCount, sortAlphabetically, sortByCount} from '#wiki-data'; + +export default { + contentDependencies: ['generateListingPage', 'linkArtTagGallery'], + extraDependencies: ['language', 'wikiData'], + + sprawl: ({artTagData}) => + ({artTagData}), + + query({artTagData}, spec) { + const artTags = + sortAlphabetically( + artTagData + .filter(artTag => !artTag.isContentWarning)); + + const counts = + artTags.map(artTag => + unique([ + ...artTag.directlyTaggedInThings, + ...artTag.indirectlyTaggedInThings, + ]).length); + + filterByCount(artTags, counts); + sortByCount(artTags, counts, {greatestFirst: true}); + + return {spec, artTags, counts}; + }, + + relations: (relation, query) => ({ + page: + relation('generateListingPage', query.spec), + + artTagLinks: + query.artTags + .map(artTag => relation('linkArtTagGallery', artTag)), + }), + + data: (query) => + ({counts: query.counts}), + + generate: (data, relations, {language}) => + relations.page.slots({ + type: 'rows', + rows: + stitchArrays({ + link: relations.artTagLinks, + count: data.counts, + }).map(({link, count}) => ({ + tag: link, + timesUsed: language.countTimesUsed(count, {unit: true}), + })), + }), +}; diff --git a/src/content/dependencies/listTagsByName.js b/src/content/dependencies/listTagsByName.js deleted file mode 100644 index 9bec9eaa..00000000 --- a/src/content/dependencies/listTagsByName.js +++ /dev/null @@ -1,57 +0,0 @@ -import {stitchArrays, unique} from '#sugar'; -import {sortAlphabetically} from '#wiki-data'; - -export default { - contentDependencies: ['generateListingPage', 'linkArtTagGallery'], - extraDependencies: ['language', 'wikiData'], - - sprawl({artTagData}) { - return {artTagData}; - }, - - query({artTagData}, spec) { - return { - spec, - - artTags: - sortAlphabetically( - artTagData - .filter(artTag => !artTag.isContentWarning)), - }; - }, - - relations(relation, query) { - return { - page: relation('generateListingPage', query.spec), - - artTagLinks: - query.artTags - .map(artTag => relation('linkArtTagGallery', artTag)), - }; - }, - - data(query) { - return { - counts: - query.artTags.map(artTag => - unique([ - ...artTag.indirectlyTaggedInThings, - ...artTag.directlyTaggedInThings, - ]).length), - }; - }, - - generate(data, relations, {language}) { - return relations.page.slots({ - type: 'rows', - rows: - stitchArrays({ - link: relations.artTagLinks, - count: data.counts, - }).map(({link, count}) => ({ - tag: link, - timesUsed: language.countTimesUsed(count, {unit: true}), - })), - }); - }, -}; diff --git a/src/content/dependencies/listTagsByUses.js b/src/content/dependencies/listTagsByUses.js deleted file mode 100644 index 9eb6f185..00000000 --- a/src/content/dependencies/listTagsByUses.js +++ /dev/null @@ -1,54 +0,0 @@ -import {stitchArrays, unique} from '#sugar'; -import {filterByCount, sortAlphabetically, sortByCount} from '#wiki-data'; - -export default { - contentDependencies: ['generateListingPage', 'linkArtTagGallery'], - extraDependencies: ['language', 'wikiData'], - - sprawl: ({artTagData}) => - ({artTagData}), - - query({artTagData}, spec) { - const artTags = - sortAlphabetically( - artTagData - .filter(artTag => !artTag.isContentWarning)); - - const counts = - artTags.map(artTag => - unique([ - ...artTag.directlyTaggedInThings, - ...artTag.indirectlyTaggedInThings, - ]).length); - - filterByCount(artTags, counts); - sortByCount(artTags, counts, {greatestFirst: true}); - - return {spec, artTags, counts}; - }, - - relations: (relation, query) => ({ - page: - relation('generateListingPage', query.spec), - - artTagLinks: - query.artTags - .map(artTag => relation('linkArtTagGallery', artTag)), - }), - - data: (query) => - ({counts: query.counts}), - - generate: (data, relations, {language}) => - relations.page.slots({ - type: 'rows', - rows: - stitchArrays({ - link: relations.artTagLinks, - count: data.counts, - }).map(({link, count}) => ({ - tag: link, - timesUsed: language.countTimesUsed(count, {unit: true}), - })), - }), -}; -- cgit 1.3.0-6-gf8a5