mirror of
https://github.com/NoCrypt/migu.git
synced 2026-03-24 03:17:46 +00:00
49 lines
2.7 KiB
Svelte
49 lines
2.7 KiB
Svelte
<script context='module'>
|
|
import SectionsManager from '@/modules/sections.js'
|
|
import Search, { search } from './Search.svelte'
|
|
import { anilistClient, currentSeason, currentYear } from '@/modules/anilist.js'
|
|
import { malDubs } from "@/modules/animedubs.js"
|
|
import Helper from "@/modules/helper.js"
|
|
|
|
const vars = { format: 'TV', season: currentSeason, year: currentYear }
|
|
|
|
async function fetchAllScheduleEntries (_variables) {
|
|
const variables = { ..._variables }
|
|
const results = { data: { Page: { media: [], pageInfo: { hasNextPage: false } } } }
|
|
const opts = { ...vars, ...SectionsManager.sanitiseObject(variables) }
|
|
const hideSubs = variables.hideSubs ? { idMal: malDubs.dubLists.value.dubbed } : {}
|
|
const hideMyAnime = (variables.hideMyAnime && Helper.isAuthorized()) ? {[Helper.isAniAuth() ? 'id_not' : 'idMal_not']:
|
|
await Helper.userLists(variables).then(res => {
|
|
return Helper.isAniAuth()
|
|
? Array.from(new Set(res.data.MediaListCollection.lists.filter(({ status }) => variables.hideStatus.includes(status)).flatMap(list => list.entries.map(({ media }) => media.id))))
|
|
: res.data.MediaList.filter(({ node }) => variables.hideStatus.includes(Helper.statusMap(node.my_list_status.status))).map(({ node }) => node.id)
|
|
})} : {}
|
|
for (let page = 1, hasNextPage = true; hasNextPage && page < 5; ++page) {
|
|
const res = await anilistClient.search({ ...opts, ...hideSubs, ...hideMyAnime, page, perPage: 50 })
|
|
hasNextPage = res.data.Page.pageInfo.hasNextPage
|
|
results.data.Page.media = results.data.Page.media.concat(res.data.Page.media)
|
|
}
|
|
const seasons = ['WINTER', 'SPRING', 'SUMMER', 'FALL']
|
|
const season = seasons.at(seasons.indexOf(vars.season) - 1)
|
|
const year = vars.season === 'WINTER' ? vars.year - 1 : vars.year
|
|
|
|
const res = await anilistClient.search({ ...hideSubs, ...hideMyAnime, format: 'TV', ...SectionsManager.sanitiseObject(variables), year, season, status: 'RELEASING', page: 1, perPage: 50 })
|
|
results.data.Page.media = results.data.Page.media.concat(res.data.Page.media)
|
|
|
|
// filter out entries without airing schedule and duplicates [only allow first occurrence]
|
|
results.data.Page.media = results.data.Page.media.filter((media, index, self) => media.airingSchedule?.nodes?.[0]?.airingAt && self.findIndex(m => m.id === media.id) === index)
|
|
|
|
results.data.Page.media.sort((a, b) => a.airingSchedule?.nodes?.[0]?.airingAt - b.airingSchedule?.nodes?.[0]?.airingAt)
|
|
|
|
return results
|
|
}
|
|
</script>
|
|
|
|
<script>
|
|
$search = {
|
|
...vars,
|
|
load: (_, __, variables) => SectionsManager.wrapResponse(fetchAllScheduleEntries(variables), 150)
|
|
}
|
|
</script>
|
|
|
|
<Search />
|