Skip to content

Commit

Permalink
fix(imgur): resolves issues with retrieving the foundLocation now tha…
Browse files Browse the repository at this point in the history
…t date is in the description
  • Loading branch information
KenEucker committed Jan 4, 2024
1 parent 5aa0142 commit 9eebe68
Show file tree
Hide file tree
Showing 4 changed files with 27 additions and 15 deletions.
9 changes: 5 additions & 4 deletions examples/node/index.js
Original file line number Diff line number Diff line change
Expand Up @@ -189,8 +189,8 @@ const runTests = async (out = false) => {
await get10PlayersAsync("BikeTag", biketagDefaultInstance, out)
}

if (false) {
// if (bikeTagImgurInstance) {
// if (false) {
if (bikeTagImgurInstance) {
console.log(pretty("Imgur BikeTag Client Instantiated"), imgurInstanceOpts)
await getGameAsync("Imgur", bikeTagImgurInstance, out)
// await getTag1Async("Imgur", bikeTagImgurInstance, out)
Expand All @@ -202,14 +202,15 @@ const runTests = async (out = false) => {
// await get10PlayersAsync("Imgur", bikeTagImgurInstance, out)
}

if (bikeTagSanityInstance) {
if (false) {
// if (bikeTagSanityInstance) {
console.log(pretty("Sanity BikeTag Client Instantiated"), sanityInstanceOpts)
// await getTag1Async("Sanity", bikeTagSanityInstance, out)
// await get10TagsAsync("Sanity", bikeTagSanityInstance, out)
await getGameAsync("Sanity", bikeTagSanityInstance, out)
// await getAllGamesAsync("Sanity", bikeTagSanityInstance, out)
await get10PlayersAsync("Sanity", bikeTagSanityInstance, out)
// await get1PlayerAsync("Sanity", bikeTagSanityInstance, out)
await get1PlayerAsync("Sanity", bikeTagSanityInstance, out)
// await get10AchievementsAsync("Sanity", bikeTagSanityInstance, out)
// await get10AmbassadorsAsync("Sanity", bikeTagSanityInstance, out)
// await get10SettingsAsync("Sanity", bikeTagSanityInstance, out)
Expand Down
3 changes: 2 additions & 1 deletion src/common/expressions.ts
Original file line number Diff line number Diff line change
Expand Up @@ -7,8 +7,9 @@ export const getPlayerFromTextRegex = new RegExp(
/((?:proof\s*(?:found\s*at\s*)?(?:\(.*\))?\s*by\s*)(.*?(?= on \[|$)))|((?:tag\s*(?:(?:\(\s*hint:\s*)?.*\))?\s*by\s*)(.+?(?= on \[|\r|\n|$))?)|((?:tag\s*(?:(?:\(\s*hint:\s*)?.*\))?\s*by\s*)(.+?(?= on \[|\r|\n))?)|((?:credit goes to:\s*)(.*)(?:\sfor finding))|(?:tag\s*)(?:number\s*)?(\d*)?(?:\s*by\s*)(.+?(?= on \[|$|\n))/i
)

/// Removed an OR from here, TEST: #64 proof found at (Earth) by Tim on [1/4/24@11:16:05)
export const getFoundLocationFromTextRegex = new RegExp(
/(?:is\s*(at|the)?\s*\(?)(.*)(?:\)|]|$)|(?:found\s*(at)?\s*\(?)(.*)(?:\)|])|(?:found\s*at\s*\()(.*)(?:\))|(?:\[(?:\s*bike\s*)(?:\s*tag\s*))#?(\d+)(?:(?:\])|(?:\s*.\s*(.*)\]))/im
/(?:is\s*(?:at|the)?\s*?)(.*?)(?=\s*by\s+|\]|$)|(?:found)\s*(?:at)?\s*\(([^()]+(\([^()]+\)[^()]*)*)\)(.*(?:\)|]|$))|(?:found\s*at\s*\()(.*(?:\)))/im
)

export const getConfirmedBoundaryFromTextRegex = new RegExp(
Expand Down
24 changes: 15 additions & 9 deletions src/common/getters.ts
Original file line number Diff line number Diff line change
Expand Up @@ -142,7 +142,11 @@ export const getFoundLocationFromText = (
return fallback
}

const foundLocation = (foundLocationText[1] || '').trim()
const foundLocation = (
foundLocationText[1] ??
foundLocationText[2] ??
''
).trim()
putCacheIfExists(cacheKey, foundLocation, cache)

return foundLocation
Expand Down Expand Up @@ -472,13 +476,14 @@ export const getDateStringForImgurDescription = (isodate: number): string => {

export const getImgurFoundDescriptionFromBikeTagData = (
tag: Tag,
includeCredit = true
includeCredit = true,
includeDate = true
): string =>
`#${tag.tagnumber} proof${
tag.foundLocation ? ` found at (${tag.foundLocation})` : ''
}${
includeCredit ? ` by ${tag.foundPlayer}` : ''
}${getDateStringForImgurDescription(tag.foundTime)}`
}${includeCredit ? ` by ${tag.foundPlayer}` : ''}${
includeDate ? getDateStringForImgurDescription(tag.foundTime) : ''
}`

export const getImgurFoundTitleFromBikeTagData = (tag: Tag): string =>
`${
Expand Down Expand Up @@ -507,13 +512,14 @@ export const getImgurMysteryTitleFromBikeTagData = (tag: Tag): string =>
export const getImgurMysteryDescriptionFromBikeTagData = (
tag: Tag,
includeCredit = true,
includeHint = true
includeHint = true,
includeDate = true
): string =>
`#${tag.tagnumber} tag ${
includeHint && tag.hint ? `(hint: ${tag.hint})` : ''
}${
includeCredit ? ` by ${tag.mysteryPlayer}` : ''
}${getDateStringForImgurDescription(tag.mysteryTime)}`
}${includeCredit ? ` by ${tag.mysteryPlayer}` : ''}${
includeDate ? getDateStringForImgurDescription(tag.mysteryTime) : ''
}`

export const getOnlyMysteryTagFromTagData = (tagData: Tag): Tag => {
const onlyMysteryTagFields = {
Expand Down
6 changes: 5 additions & 1 deletion src/imgur/helpers.ts
Original file line number Diff line number Diff line change
Expand Up @@ -288,7 +288,11 @@ export function getFoundLocationFromText(
return fallback as string
}

const foundLocation = (foundLocationText[4] || '').trim()
const foundLocation = (
foundLocationText[1] ??
foundLocationText[2] ??
''
).trim()
putCacheIfExists(cacheKey, foundLocation, cache)

return foundLocation
Expand Down

0 comments on commit 9eebe68

Please sign in to comment.