Skip to content

Commit

Permalink
feat: rework how often available is updated
Browse files Browse the repository at this point in the history
  • Loading branch information
TurtIeSocks committed Jan 17, 2024
1 parent 1362796 commit ed35dcd
Show file tree
Hide file tree
Showing 9 changed files with 137 additions and 34 deletions.
53 changes: 42 additions & 11 deletions server/src/graphql/resolvers.js
Original file line number Diff line number Diff line change
Expand Up @@ -21,17 +21,6 @@ const resolvers = {
Query: {
available: (_, _args, { Event, Db, perms }) => {
const data = {
pokemon: perms.pokemon ? Event.available.pokemon : [],
gyms: perms.gyms || perms.raids ? Event.available.gyms : [],
nests: perms.nests ? Event.available.nests : [],
pokestops:
perms.pokestops ||
perms.invasions ||
perms.eventStops ||
perms.quests ||
perms.lures
? Event.available.pokestops
: [],
questConditions: perms.quests ? Db.questConditions : {},
masterfile: { ...Event.masterfile, invasions: Event.invasions },
filters: buildDefaultFilters(perms, Db),
Expand All @@ -46,6 +35,48 @@ const resolvers = {
}
return data
},
availablePokemon: (_, _args, { Event, perms }) =>
perms?.pokemon ? Event.available.pokemon : [],
availableGyms: (_, _args, { Event, perms }) =>
Event.available.gyms.filter((x) => {
if (x.startsWith('g') || x.startsWith('t')) {
return perms?.gyms
}
if (
x.startsWith('r') ||
x.startsWith('e') ||
Number.isInteger(Number(x.charAt(0)))
) {
return perms?.raids
}
return false
}),
availableNests: (_, _args, { Event, perms }) =>
perms?.nests ? Event.available.nests : [],
availablePokestops: (_, _args, { Event, perms }) =>
Event.available.pokestops.filter((x) => {
if (x.startsWith('i') || x.startsWith('a')) {
return perms?.invasions
}
if (x.startsWith('d') || x.startsWith('f') || x.startsWith('h')) {
return perms?.lures
}
if (
x.startsWith('q') ||
x.startsWith('m') ||
x.startsWith('x') ||
x.startsWith('c') ||
x.startsWith('d') ||
x.startsWith('p') ||
Number.isInteger(Number(x.charAt(0)))
) {
return perms?.quests
}
if (x.startsWith('l')) {
return perms?.lures
}
return perms?.pokestops
}),
backup: (_, args, { req, perms, Db }) => {
if (perms?.backups && req?.user?.id) {
return Db.models.Backup.getOne(args.id, req?.user?.id)
Expand Down
6 changes: 5 additions & 1 deletion server/src/graphql/typeDefs/index.graphql
Original file line number Diff line number Diff line change
@@ -1,7 +1,11 @@
scalar JSON

type Query {
available: Available
available: MapData
availablePokemon: [String]
availablePokestops: [String]
availableGyms: [String]
availableNests: [String]
badges: [Badge]
backup(id: ID): Backup
backups: [Backup]
Expand Down
6 changes: 1 addition & 5 deletions server/src/graphql/typeDefs/map.graphql
Original file line number Diff line number Diff line change
@@ -1,9 +1,5 @@
type Available {
type MapData {
masterfile: JSON
pokestops: [String]
gyms: [String]
pokemon: [String]
nests: [String]
filters: JSON
questConditions: JSON
icons: JSON
Expand Down
9 changes: 8 additions & 1 deletion server/src/services/EventManager.js
Original file line number Diff line number Diff line change
Expand Up @@ -17,7 +17,14 @@ class EventManager {
/** @type {import("@rm/types").Masterfile['invasions'] | {}} */
this.invasions =
'invasions' in this.masterfile ? this.masterfile.invasions : {}
this.available = { gyms: [], pokestops: [], pokemon: [], nests: [] }

/** @type {{[key in keyof import('@rm/types').Available]: string[] }} */
this.available = {
gyms: [],
pokestops: [],
pokemon: [],
nests: [],
}
this.uicons = []
this.uaudio = []
this.uiconsBackup = {}
Expand Down
4 changes: 3 additions & 1 deletion src/components/layout/dialogs/UserOptions.jsx
Original file line number Diff line number Diff line change
Expand Up @@ -67,7 +67,7 @@ const MemoInputType = React.memo(
next.localState?.[next.subOption || next.option],
)

export default function UserOptions() {
function UserOptions() {
const { t } = useTranslation()
const { open, category, type } = useLayoutStore((s) => s.dialog)

Expand Down Expand Up @@ -201,3 +201,5 @@ export default function UserOptions() {
</DialogWrapper>
)
}

export default React.memo(UserOptions)
8 changes: 4 additions & 4 deletions src/components/layout/drawer/SelectorList.jsx
Original file line number Diff line number Diff line change
Expand Up @@ -21,6 +21,7 @@ import { useTranslateById } from '@hooks/useTranslateById'
import { useMemory } from '@hooks/useMemory'
import { useLayoutStore } from '@hooks/useLayoutStore'
import { useDeepStore, useStorage } from '@hooks/useStorage'
import useGetAvailable from '@hooks/useGetAvailable'

import { BoolToggle } from './BoolToggle'
import { GenericSearchMemo } from './ItemSearch'
Expand All @@ -45,10 +46,9 @@ function SelectorList({ category, subCategory, label, height = 400 }) {
const searchKey = `${category}${
subCategory ? capitalize(subCategory) : ''
}QuickSelect`

const { available } = useGetAvailable(category)
const { t: tId } = useTranslateById()
const { t } = useTranslation()
const available = useMemory((s) => s.available[category])
const allFilters = useMemory((s) => s.filters[category]?.filter)

const onlyShowAvailable = useStorage((s) =>
Expand Down Expand Up @@ -83,13 +83,13 @@ function SelectorList({ category, subCategory, label, height = 400 }) {
case 'rocketPokemon':
return key.startsWith('a')
case 'pokemon':
return !Number.isNaN(Number(key.charAt(0)))
return Number.isInteger(Number(key.charAt(0)))
default:
switch (category) {
case 'gyms':
return key.startsWith('t')
default:
return !Number.isNaN(Number(key.charAt(0)))
return Number.isInteger(Number(key.charAt(0)))
}
}
})
Expand Down
46 changes: 46 additions & 0 deletions src/hooks/useGetAvailable.js
Original file line number Diff line number Diff line change
@@ -0,0 +1,46 @@
// @ts-check
import { useEffect, useMemo } from 'react'
import { useQuery } from '@apollo/client'
import * as queries from '@services/queries/available'
import { capitalize } from '@mui/material'

import { useMemory } from './useMemory'

/**
* @param {keyof import('packages/types/lib').Available} category
* @returns {{available: string[], loading: boolean, error: import('@apollo/client').ApolloError}}
*/
export default function useGetAvailable(category) {
const capitalized = capitalize(category)
const active = useMemory((s) => s.active)
const online = useMemory((s) => s.online)

/** @type {import('@apollo/client').QueryResult<{ [key: string]: string[] }>} */
const { data, previousData, loading, error } = useQuery(
queries[`getAvailable${capitalized}`],
{
fetchPolicy: active && online ? 'network-only' : 'cache-and-network',
},
)

useEffect(() => {
if (data?.[`available${capitalized}`]) {
useMemory.setState((prev) => ({
available: {
...prev.available,
[category]: data[`available${capitalized}`].some(
(key, i) => key !== prev.available[category][i],
)
? data[`available${capitalized}`]
: prev.available[category],
// if it's the same, don't cause re-renders
},
}))
}
}, [data])

return useMemo(() => {
const available = (data || previousData)?.[`available${capitalized}`] || []
return { available, loading, error }
}, [data, previousData, loading, error])
}
7 changes: 3 additions & 4 deletions src/hooks/useRefresh.js
Original file line number Diff line number Diff line change
@@ -1,7 +1,7 @@
// @ts-check
import { useEffect } from 'react'
import { useQuery } from '@apollo/client'
import getAvailable from '@services/queries/available'
import { getMapData } from '@services/queries/available'

import { deepMerge } from '@services/functions/deepMerge'
import UAssets from '@services/Icons'
Expand All @@ -15,7 +15,7 @@ export default function useRefresh() {

const hasIcons = useMemory((s) => !!s.Icons)

const { data, stopPolling, startPolling, refetch } = useQuery(getAvailable, {
const { data, stopPolling, startPolling, refetch } = useQuery(getMapData, {
fetchPolicy: active && online ? 'network-only' : 'cache-only',
})

Expand All @@ -34,7 +34,7 @@ export default function useRefresh() {

useEffect(() => {
if (data?.available) {
const { masterfile, filters, icons, audio, ...rest } = data.available
const { masterfile, filters, icons, audio } = data.available
const { icons: userIcons, audio: userAudio } = useStorage.getState()
const existing = useMemory.getState()

Expand Down Expand Up @@ -74,7 +74,6 @@ export default function useRefresh() {
)
}
useMemory.setState({
available: rest,
masterfile,
filters,
Icons,
Expand Down
32 changes: 25 additions & 7 deletions src/services/queries/available.js
Original file line number Diff line number Diff line change
@@ -1,13 +1,9 @@
import { gql } from '@apollo/client'

const getAvailable = gql`
query Available {
export const getMapData = gql`
query MapData {
available {
masterfile
pokestops
gyms
pokemon
nests
filters
questConditions
icons
Expand All @@ -16,4 +12,26 @@ const getAvailable = gql`
}
`

export default getAvailable
export const getAvailablePokemon = gql`
query AvailablePokemon {
availablePokemon
}
`

export const getAvailablePokestops = gql`
query AvailablePokestops {
availablePokestops
}
`

export const getAvailableGyms = gql`
query AvailableGyms {
availableGyms
}
`

export const getAvailableNests = gql`
query AvailableNests {
availableNests
}
`

0 comments on commit ed35dcd

Please sign in to comment.