coh-content-db 2.0.0-rc.8 → 2.0.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (74) hide show
  1. package/.github/workflows/build.yml +3 -1
  2. package/CHANGELOG.md +47 -0
  3. package/README.md +48 -17
  4. package/dist/coh-content-db.d.ts +257 -200
  5. package/dist/coh-content-db.js +509 -339
  6. package/dist/coh-content-db.js.map +1 -1
  7. package/dist/coh-content-db.mjs +501 -335
  8. package/dist/coh-content-db.mjs.map +1 -1
  9. package/jest.config.mjs +1 -0
  10. package/package.json +14 -14
  11. package/src/main/api/badge-data.ts +13 -7
  12. package/src/main/api/{content-bundle.ts → bundle-data.ts} +5 -27
  13. package/src/main/api/bundle-header-data.ts +44 -0
  14. package/src/main/api/contact-data.ts +2 -1
  15. package/src/main/api/level-range-data.ts +4 -0
  16. package/src/main/api/mission-data.ts +3 -29
  17. package/src/main/api/mission-flashback-data.ts +31 -0
  18. package/src/main/api/morality.ts +27 -9
  19. package/src/main/api/set-title-data.ts +4 -0
  20. package/src/main/api/variant-context.ts +11 -0
  21. package/src/main/api/{alternate-data.ts → variant-data.ts} +4 -4
  22. package/src/main/api/zone-data.ts +24 -0
  23. package/src/main/api/zone-type.ts +59 -0
  24. package/src/main/db/abstract-index.ts +12 -16
  25. package/src/main/db/badge-index.ts +53 -27
  26. package/src/main/db/badge-requirement.ts +1 -1
  27. package/src/main/db/badge-search-options.ts +15 -14
  28. package/src/main/db/badge.ts +46 -29
  29. package/src/main/db/bundle-header.ts +52 -0
  30. package/src/main/db/coh-content-database.ts +22 -22
  31. package/src/main/db/contact.ts +5 -4
  32. package/src/main/db/level-range.ts +15 -0
  33. package/src/main/db/mission.ts +11 -10
  34. package/src/main/db/paged.ts +7 -3
  35. package/src/main/db/set-title-ids.ts +10 -0
  36. package/src/main/db/variants.ts +84 -0
  37. package/src/main/db/zone.ts +29 -0
  38. package/src/main/index.ts +14 -8
  39. package/src/main/util/coalesce-to-array.ts +13 -0
  40. package/src/main/{util.ts → util/links.ts} +8 -22
  41. package/src/main/util/to-date.ts +9 -0
  42. package/src/test/api/alignment.test.ts +2 -2
  43. package/src/test/api/badge-data.fixture.ts +1 -0
  44. package/src/test/api/badge-data.test.ts +1 -0
  45. package/src/test/api/bundle-data.fixture.ts +7 -0
  46. package/src/test/api/bundle-header-data.fixture.ts +8 -0
  47. package/src/test/api/morality.test.ts +31 -0
  48. package/src/test/api/sex.test.ts +2 -2
  49. package/src/test/api/zone-data.fixture.ts +1 -0
  50. package/src/test/db/abstract-index.test.ts +12 -43
  51. package/src/test/db/badge-index.test.ts +197 -101
  52. package/src/test/db/badge.test.ts +122 -16
  53. package/src/test/db/bundle-header.test.ts +89 -0
  54. package/src/test/db/coh-content-database.test.ts +137 -178
  55. package/src/test/db/contact.test.ts +2 -1
  56. package/src/test/db/level-range.test.ts +47 -0
  57. package/src/test/db/mission.test.ts +8 -6
  58. package/src/test/db/morality-list.test.ts +1 -1
  59. package/src/test/db/set-title-ids.test.ts +19 -0
  60. package/src/test/db/{alternates.test.ts → variants.test.ts} +24 -24
  61. package/src/test/db/zone.test.ts +45 -0
  62. package/src/test/integration.test.ts +16 -0
  63. package/src/test/util/coalese-to-array.test.ts +17 -0
  64. package/src/test/{util.test.ts → util/links.test.ts} +5 -21
  65. package/src/test/util/to-date.test.ts +15 -0
  66. package/src/main/api/change.ts +0 -17
  67. package/src/main/changelog.ts +0 -29
  68. package/src/main/db/alternates.ts +0 -67
  69. package/src/main/db/bundle-metadata.ts +0 -45
  70. package/src/test/api/content-bundle.fixture.ts +0 -6
  71. package/src/test/api/content-bundle.test.ts +0 -14
  72. package/src/test/changelog.test.ts +0 -36
  73. package/src/test/db/bundle-metadata.test.ts +0 -84
  74. package/src/test/index.test.ts +0 -14
@@ -1 +1 @@
1
- {"version":3,"file":"coh-content-db.mjs","sources":["../src/main/api/alignment.ts","../src/main/api/badge-requirement-type.ts","../src/main/api/badge-type.ts","../src/main/api/enhancement-category.ts","../src/main/api/mission-type.ts","../src/main/api/morality.ts","../src/main/api/sex.ts","../src/main/db/alignment-list.ts","../src/main/db/alternates.ts","../src/main/db/key.ts","../src/main/db/archetype.ts","../src/main/util.ts","../src/main/db/badge-requirement.ts","../src/main/db/morality-list.ts","../src/main/db/badge.ts","../src/main/db/abstract-index.ts","../src/main/db/badge-index.ts","../src/main/db/bundle-metadata.ts","../src/main/db/zone.ts","../src/main/db/contact.ts","../src/main/db/mission.ts","../src/main/db/coh-content-database.ts","../src/main/db/location.ts","../src/main/changelog.ts"],"sourcesContent":["export const ALIGNMENT = ['hero', 'villain', 'praetorian'] as const\nexport type Alignment = typeof ALIGNMENT[number]\nexport type AlignmentExtended = Alignment\n /**\n * The alignments available for Primal Earth characters - Hero and Villain.\n */\n | 'primal'\n /**\n * All the alignments.\n */\n | 'all'\n\nconst ALIGNMENT_ORDER = Object.fromEntries(ALIGNMENT.map((x, index) => [x, index]))\n\nexport function compareAlignment(a?: Alignment, b?: Alignment): number {\n const orderA = a ? ALIGNMENT_ORDER[a] : -1\n const orderB = b ? ALIGNMENT_ORDER[b] : -1\n return orderA - orderB\n}\n","export const BADGE_REQUIREMENT_TYPE = [\n /**\n * Collect a badge.\n */\n 'badge',\n /**\n * Craft an invention.\n */\n 'invention',\n /**\n * Some invention badges require you to build x of two different invention levels, 'plus one of either level'.\n */\n 'invention-plus-one',\n /**\n * Visit a location.\n */\n 'location',\n /**\n * Click on a monument.\n */\n 'monument',\n /**\n * Complete a mission.\n */\n 'mission',\n /**\n * Complete an arbitrary task.\n */\n 'task',\n] as const\n\nexport type BadgeRequirementType = typeof BADGE_REQUIREMENT_TYPE[number]\n","export const BADGE_TYPE = [\n 'exploration',\n 'history',\n 'accomplishment',\n 'achievement',\n 'accolade',\n 'gladiator',\n 'veteran',\n 'pvp',\n 'invention',\n 'defeat',\n 'event',\n 'ouroboros',\n 'consignment',\n 'day-job',\n 'architect-entertainment',\n] as const\n\nexport type BadgeType = typeof BADGE_TYPE[number]\n","export const ENHANCEMENT_CATEGORY = [\n 'defense-debuff',\n 'to-hit-debuff',\n 'taunt',\n 'confuse',\n 'healing',\n 'defense-buff',\n 'resist-damage',\n 'intangibility',\n 'sleep',\n 'slow',\n 'hold',\n 'stun',\n 'immobilize',\n 'fear',\n 'endurance-modification',\n 'endurance-reduction',\n 'recharge-reduction',\n 'interrupt-duration',\n 'accuracy',\n 'to-hit-buff',\n 'damage',\n 'knockback',\n 'run-speed',\n 'jump',\n 'fly-speed',\n 'range',\n] as const\n\nexport type EnhancementCategory = typeof ENHANCEMENT_CATEGORY[number]\n","export const MISSION_TYPE = ['story-arc', 'mission', 'task-force', 'strike-force', 'trial', 'personal-story'] as const\nexport type MissionType = typeof MISSION_TYPE[number]\n","export const MORALITY = ['hero', 'vigilante', 'villain', 'rogue', 'resistance', 'loyalist'] as const\nexport type Morality = typeof MORALITY[number]\nexport type MoralityExtended = Morality\n /**\n * Any of the Primal Earth moralities - Hero, Vigilante, Villain, Rogue.\n */\n | 'primal'\n /**\n * Either of the Praetorian Earth moralities - Resistance or Loyalist.\n */\n | 'praetorian'\n /**\n * The moralities that roll up to the Hero {@link Alignment} - Hero and Vigilante.\n */\n | 'heroic'\n /**\n * The moralities that roll up to the Villain {@link Alignment} - Villain and Rogue.\n */\n | 'villainous'\n /**\n * Moralities with access to Paragon City - Hero, Vigilante and Rogue.\n */\n | 'paragon-city-access'\n /**\n * Moralities with access to the Rogue Isles - Villain, Rogue and Vigilante.\n */\n | 'rogue-isles-access'\n /**\n * All the moralities.\n */\n | 'all'\n","export const SEX = ['M', 'F'] as const\nexport type Sex = typeof SEX[number]\n\nconst SEX_ORDER = Object.fromEntries(SEX.map((x, index) => [x, index]))\n\nexport function compareSex(a?: Sex, b?: Sex): number {\n const orderA = a ? SEX_ORDER[a] : -1\n const orderB = b ? SEX_ORDER[b] : -1\n return orderA - orderB\n}\n","import { ALIGNMENT, Alignment, AlignmentExtended } from '../api/alignment'\n\nexport class AlignmentList {\n readonly #items: Set<Alignment>\n\n readonly hero: boolean\n readonly villain: boolean\n readonly praetorian: boolean\n\n readonly primal: boolean\n readonly all: boolean\n\n constructor(items?: AlignmentExtended[]) {\n const set = new Set(items ?? [...ALIGNMENT])\n this.hero = set.has('hero') || set.has('primal') || set.has('all')\n this.villain = set.has('villain') || set.has('primal') || set.has('all')\n this.praetorian = set.has('praetorian') || set.has('all')\n\n this.primal = this.hero && this.villain\n this.all = this.hero && this.villain && this.praetorian\n\n this.#items = new Set()\n if (this.hero) this.#items.add('hero')\n if (this.villain) this.#items.add('villain')\n if (this.praetorian) this.#items.add('praetorian')\n }\n\n get items(): Alignment[] {\n return [...this.#items]\n }\n\n has(alignment?: AlignmentExtended): boolean {\n switch (alignment) {\n case 'hero': {\n return this.hero\n }\n case 'villain': {\n return this.villain\n }\n case 'praetorian': {\n return this.praetorian\n }\n case 'primal' : {\n return this.primal\n }\n case 'all': {\n return this.all\n }\n default: {\n return false\n }\n }\n }\n}\n","import { AlternateData } from '../api/alternate-data'\nimport { compareSex, Sex } from '../api/sex'\nimport { Alignment, compareAlignment } from '../api/alignment'\n\nexport class Alternates<T> {\n readonly #sortedValues: AlternateData<T>[] = []\n\n /**\n * Create an alternate set from either a list of categorized values, or a single value when there are no alternates.\n * @param value List of alternates, or a single value.\n */\n constructor(value: AlternateData<T>[] | T) {\n if (Array.isArray(value)) {\n this.#sortedValues = value.sort()\n this.#sortedValues.sort((a, b) => this.#compareAlternates(a, b))\n } else {\n this.#sortedValues = [{ value }]\n }\n }\n\n getValue(alignment?: Alignment, sex?: Sex): T | undefined {\n for (let index = this.#sortedValues.length; index--;) {\n const entry = this.#sortedValues[index]\n if ((entry.alignment === undefined || entry.alignment === alignment)\n && (entry.sex === undefined || entry.sex === sex)\n ) return entry.value\n }\n\n return this.default?.value\n }\n\n /**\n * Get the default value for this list of alternates, the value with the highest priority and lowest specificity.\n */\n get default(): AlternateData<T> | undefined {\n return this.#sortedValues[0]\n }\n\n /**\n * Get the list of alternates sorted in canonical order (alignment then sex, low to high specificity).\n */\n get canonical(): AlternateData<T>[] {\n return this.#sortedValues\n }\n\n /**\n * Create a joined string from the alternate values in canonical order.\n * @param separator Separator to use. Default is ' / '\n */\n toString(separator: string): string {\n return this.canonical.map(x => x.value).join(separator)\n }\n\n #compareAlternates(a: AlternateData<T>, b: AlternateData<T>): number {\n const aSpecificity = (a.alignment ? 2 : 0) + (a.sex ? 1 : 0)\n const bSpecificity = (b.alignment ? 2 : 0) + (b.sex ? 1 : 0)\n if (aSpecificity !== bSpecificity) return aSpecificity - bSpecificity // Order first by least-specific\n\n const alignmentComparison = compareAlignment(a.alignment, b.alignment) // Next by alignment\n if (alignmentComparison !== 0) return alignmentComparison\n\n const sexComparison = compareSex(a.sex, b.sex) // Last by sex\n if (sexComparison !== 0) return sexComparison\n\n return String(a.value).localeCompare(String(b.value))\n }\n}\n","const INVALID_KEY_PATTERN = /[^a-z0-9-]/\n\nexport class Key {\n readonly #value: string\n\n constructor(value: string) {\n this.#validateKey(value)\n this.#value = value\n }\n\n get value(): string {\n return this.#value\n }\n\n #validateKey(key: string): void {\n if (INVALID_KEY_PATTERN.test(key)) throw new Error(`Invalid key: [${key}]; Keys can only contain lowercase characters, numbers and dashes.`)\n }\n}\n","import { Key } from './key'\nimport { ArchetypeData } from '../api/archetype-data'\n\nexport class Archetype {\n readonly key: string\n readonly name: string\n readonly description?: string\n\n constructor(data: ArchetypeData) {\n this.key = new Key(data.key).value\n this.name = data.name\n this.description = data.description\n }\n}\n","import { BadgeData } from './api/badge-data'\nimport { Badge } from './db/badge'\nimport { ZoneData } from './api/zone-data'\nimport { Zone } from './db/zone'\nimport { Contact } from './db/contact'\nimport { ContactData } from './api/contact-data'\nimport { Mission } from './db/mission'\nimport { MissionData } from './api/mission-data'\n\n/**\n * Returns the URI of the given badge that can be used in {@link MarkdownString} fields.\n *\n * URI format: `badge://<key>`\n *\n * @param target The badge or badge key to target.\n */\nexport function badgeUri(target: string | Badge | BadgeData): string {\n const key = typeof target === 'string' ? target : target.key\n return `badge://${key}`\n}\n\n/**\n * Returns a {@link MarkdownString} link to the given badge.\n *\n * Link format: `[<key>](badge://<key>)`\n *\n * @param target The {@link Badge} or badge key to target.\n */\nexport function badgeLink(target: string | Badge | BadgeData): string {\n const key = typeof target === 'string' ? target : target.key\n return `[${key}](${badgeUri(target)})`\n}\n\n/**\n * Returns the URI of the given contact that can be used in {@link MarkdownString} fields.\n *\n * URI format: `contact://<key>`\n *\n * @param target The {@link Contact} or contact key to target.\n */\nexport function contactUri(target: string | Contact | ContactData): string {\n const key = typeof target === 'string' ? target : target.key\n return `contact://${key}`\n}\n\n/**\n * Returns a {@link MarkdownString} link to the given contact.\n *\n * Link format: `[<key>](contact://<key>)`\n *\n * @param target The {@link Contact} or contact key to target.\n */\nexport function contactLink(target: string | Contact | ContactData): string {\n const key = typeof target === 'string' ? target : target.key\n return `[${key}](${contactUri(target)})`\n}\n\n/**\n * Returns the URI of the given mission that can be used in {@link MarkdownString} fields.\n *\n * URI format: `mission://<key>`\n *\n * @param target The {@link Mission} or mission key to target.\n */\nexport function missionUri(target: string | Mission | MissionData): string {\n const key = typeof target === 'string' ? target : target.key\n return `mission://${key}`\n}\n\n/**\n * Returns a {@link MarkdownString} link to the given mission.\n *\n * Link format: `[<key>](mission://<key>)`\n *\n * @param target The {@link Mission} or mission key to target.\n */\nexport function missionLink(target: string | Mission | MissionData): string {\n const key = typeof target === 'string' ? target : target.key\n return `[${key}](${missionUri(target)})`\n}\n\n/**\n * Returns the URI of the given zone that can be used in {@link MarkdownString} fields.\n *\n * URI format: `zone://<key>`\n *\n * @param target The {@link Zone} or zone key to target.\n */\nexport function zoneUri(target: string | Zone | ZoneData): string {\n const key = typeof target === 'string' ? target : target.key\n return `zone://${key}`\n}\n\n/**\n * Returns a {@link MarkdownString} link to the given zone.\n *\n * Link format: `[<key>](zone://<key>)`\n *\n * @param target The {@link Zone} or zone key to target.\n */\nexport function zoneLink(target: string | Zone | ZoneData): string {\n const key = typeof target === 'string' ? target : target.key\n return `[${key}](${zoneUri(target)})`\n}\n\n/**\n * For fields that accept either an array of values or a single value, coalesces the value to an array.\n *\n * Arrays are returned as-is.\n * Single values are returned as a single-value array.\n * Undefined values are returned as undefined.\n *\n * @param value The value to coalesce.\n */\nexport function coalesceToArray<T>(value?: T | T[]): T[] | undefined {\n if (!value) return undefined\n return Array.isArray(value) ? value as T[] : [value]\n}\n","import { BadgeRequirementData } from '../api/badge-requirement-data'\nimport { BadgeRequirementType } from '../api/badge-requirement-type'\nimport { EnhancementCategory } from '../api/enhancement-category'\nimport { Key } from './key'\nimport { MarkdownString } from '../api/markdown-string'\nimport { Link } from '../api/link'\nimport { Location } from './location'\nimport { coalesceToArray } from '../util'\n\nexport class BadgeRequirement {\n /**\n * Unique key used to reference this badge requirement.\n *\n * Keys must be unique and can only contain lowercase letters, numbers and hyphens (`-`).\n */\n readonly key: string\n\n /**\n * The requirement type.\n */\n readonly type: BadgeRequirementType\n\n /**\n * If the requirement involves a location, where it is.\n */\n readonly location?: Location[]\n\n /**\n * If the requirement involves a badge, the badge key.\n */\n readonly badgeKey?: string\n\n /**\n * If the requirement involves a mission, the mission key.\n */\n readonly missionKey?: string\n\n /**\n * If the requirement involves a monument, the text that is displayed thereon.\n */\n readonly monumentText?: string\n\n /**\n * If the requirement involves crafting an invention, the Level of the invention required.\n */\n readonly inventionLevel?: number\n\n /**\n * If the requirement involves crafting an invention, the types of enhancements that will qualify.\n */\n readonly inventionTypes?: EnhancementCategory[]\n\n /**\n * Number of times the task needs to be repeated.\n */\n readonly count?: number\n\n /**\n * Additional information about the requirement.\n */\n readonly notes?: MarkdownString\n\n /**\n * List of external links. Wiki, forums, etc.\n */\n readonly links: Link[]\n\n constructor(data: BadgeRequirementData) {\n this.key = new Key(data.key).value\n this.type = data.type\n this.location = coalesceToArray(data.location)\n this.badgeKey = data.badgeKey\n this.missionKey = data.missionKey\n this.monumentText = data.monumentText\n this.inventionLevel = data.inventionLevel\n this.inventionTypes = data.inventionTypes\n this.count = data.count\n this.notes = data.notes\n this.links = data.links ?? []\n }\n}\n","import { MORALITY, Morality, MoralityExtended } from '../api/morality'\n\nexport class MoralityList {\n readonly #items: Set<Morality>\n\n readonly hero: boolean\n readonly vigilante: boolean\n readonly villain: boolean\n readonly rogue: boolean\n readonly resistance: boolean\n readonly loyalist: boolean\n\n readonly primal: boolean\n readonly praetorian: boolean\n readonly heroic: boolean\n readonly villainous: boolean\n readonly paragonCityAccess: boolean\n readonly rogueIslesAccess: boolean\n\n readonly all: boolean\n\n constructor(items?: MoralityExtended[]) {\n const set = new Set(items ?? [...MORALITY])\n this.hero = set.has('hero') || set.has('primal') || set.has('heroic') || set.has('paragon-city-access') || set.has('all')\n this.vigilante = set.has('vigilante') || set.has('primal') || set.has('heroic') || set.has('paragon-city-access') || set.has('rogue-isles-access') || set.has('all')\n this.villain = set.has('villain') || set.has('primal') || set.has('villainous') || set.has('rogue-isles-access') || set.has('all')\n this.rogue = set.has('rogue') || set.has('primal') || set.has('villainous') || set.has('paragon-city-access') || set.has('rogue-isles-access') || set.has('all')\n this.resistance = set.has('resistance') || set.has('praetorian') || set.has('all')\n this.loyalist = set.has('loyalist') || set.has('praetorian') || set.has('all')\n\n this.primal = this.hero && this.vigilante && this.villain && this.rogue\n this.praetorian = this.loyalist && this.resistance\n this.heroic = this.hero && this.vigilante\n this.villainous = this.villain && this.rogue\n this.paragonCityAccess = this.heroic && this.rogue\n this.rogueIslesAccess = this.villainous && this.vigilante\n\n this.all = this.primal && this.praetorian\n\n this.#items = new Set()\n if (this.hero) this.#items.add('hero')\n if (this.vigilante) this.#items.add('vigilante')\n if (this.villain) this.#items.add('villain')\n if (this.rogue) this.#items.add('rogue')\n if (this.resistance) this.#items.add('resistance')\n if (this.loyalist) this.#items.add('loyalist')\n }\n\n get items(): Morality[] {\n return [...this.#items]\n }\n\n has(morality?: MoralityExtended): boolean {\n switch (morality) {\n case 'hero': {\n return this.hero\n }\n case 'vigilante': {\n return this.vigilante\n }\n case 'villain': {\n return this.villain\n }\n case 'rogue': {\n return this.rogue\n }\n case 'resistance': {\n return this.resistance\n }\n case 'loyalist': {\n return this.loyalist\n }\n case 'primal' : {\n return this.primal\n }\n case 'praetorian': {\n return this.praetorian\n }\n case 'heroic': {\n return this.hero\n }\n case 'paragon-city-access': {\n return this.paragonCityAccess\n }\n case 'rogue-isles-access': {\n return this.rogueIslesAccess\n }\n case 'villainous': {\n return this.villainous\n }\n case 'all': {\n return this.all\n }\n default: {\n return false\n }\n }\n }\n}\n","import { BadgeType } from '../api/badge-type'\nimport { Link } from '../api/link'\nimport { BadgeData } from '../api/badge-data'\nimport { BadgeRequirement } from './badge-requirement'\nimport { Key } from './key'\nimport { Alternates } from './alternates'\nimport { MarkdownString } from '../api/markdown-string'\nimport { coalesceToArray } from '../util'\nimport { MoralityList } from './morality-list'\n\nexport class Badge {\n readonly #requirementsIndex: Record<string, BadgeRequirement> = {}\n readonly #zoneKeys = new Set<string>()\n\n /**\n * The database key for this badge.\n */\n readonly key: string\n\n /**\n * The type of badge.\n */\n readonly type: BadgeType\n\n /**\n * The name of this badge.\n *\n * May vary by character sex or alignment.\n */\n readonly name: Alternates<string>\n\n /**\n * The character moralities that this badge is available to.\n */\n readonly morality: MoralityList\n\n /**\n * The badge text as it appears in-game. May vary by character sex or alignment.\n */\n readonly badgeText: Alternates<MarkdownString>\n\n /**\n * Short description of how to acquire the badge. Detailed instructions will be in the notes field.\n */\n readonly acquisition?: MarkdownString\n\n /**\n * Absolute URL to this badge's icon.\n *\n * May vary by character sex or alignment.\n */\n readonly icon: Alternates<string>\n\n /**\n * Freeform notes or tips about the badge.\n */\n readonly notes?: MarkdownString\n\n /**\n * List of external links. Wiki, forums, etc.\n */\n readonly links: Link[]\n\n /**\n * The id used with the in-game `/settitle` command to apply the badge.\n * The first value is the id for primal characters and the (optional) second number is the id for praetorian characters.\n */\n readonly setTitleId?: [number, number?]\n\n /**\n * A description of the effect the badge will have, such as a buff or granting a temporary power.\n */\n readonly effect?: MarkdownString\n\n /**\n * Represents the requirements for badges with multiple fulfillment steps, such as visiting monuments for history badges, completing missions, or collecting other badges.\n */\n readonly requirements?: BadgeRequirement[]\n\n /**\n * Some badges are not included in the badge total count... such as Flames of Prometheus, which can be removed by redeeming it for a Notice of the Well.\n */\n readonly ignoreInTotals: boolean\n\n constructor(badgeData: BadgeData) {\n this.key = new Key(badgeData.key).value\n this.type = badgeData.type\n this.name = new Alternates(badgeData.name)\n this.morality = new MoralityList(coalesceToArray(badgeData.morality))\n this.badgeText = new Alternates(badgeData.badgeText ?? [])\n this.acquisition = badgeData.acquisition\n this.icon = new Alternates(badgeData.icon ?? [])\n this.notes = badgeData.notes\n this.links = badgeData.links ?? []\n this.effect = badgeData.effect\n this.setTitleId = badgeData.setTitleId\n this.ignoreInTotals = badgeData.ignoreInTotals ?? false\n\n this.requirements = badgeData.requirements?.map((requirementData) => {\n if (this.#requirementsIndex[requirementData.key]) throw new Error(`Duplicate badge requirement key [${badgeData.key}:${requirementData.key}]`)\n const requirement = new BadgeRequirement(requirementData)\n this.#requirementsIndex[requirement.key] = requirement\n if (requirement.location) for (const location of requirement.location) {\n if (location.zoneKey) this.#zoneKeys.add(location.zoneKey)\n }\n return requirement\n })\n }\n\n getRequirement(key: string): BadgeRequirement {\n const result = this.#requirementsIndex[key]\n if (result === undefined) throw new Error(`Unknown badge requirement key [${key}]`)\n return result\n }\n\n /**\n * Return a list of all the zone keys referenced by this badge.\n */\n get zoneKeys(): string[] {\n return [...this.#zoneKeys]\n }\n\n /**\n * The zone key if this badge relates to a single zone.\n */\n get zoneKey(): string | undefined {\n return this.#zoneKeys.size === 1 ? this.#zoneKeys.values().next().value : undefined\n }\n}\n\nexport function compareByDefaultName(a?: Badge, b?: Badge): number {\n const aName = a?.name.default?.value\n const bName = b?.name.default?.value\n if (!aName && !bName) return 0\n if (!aName) return 1\n if (!bName) return -1\n return aName.localeCompare(bName)\n}\n\nexport function compareByZoneKey(a?: Badge, b?: Badge): number {\n const aZone = a?.zoneKey\n const bZone = b?.zoneKey\n if (!aZone && !bZone) return 0\n if (!aZone) return 1\n if (!bZone) return -1\n return aZone.localeCompare(bZone)\n}\n","type KeysOfType<T, V> = { [P in keyof T]: T[P] extends V ? P : never }[keyof T]\n\nexport class AbstractIndex<T> {\n readonly #keyField: KeysOfType<T, string>\n protected _values: T[] = []\n protected _hashTable: Record<string, T> = {}\n\n constructor(keyField: KeysOfType<T, string>) {\n this.#keyField = keyField\n }\n\n /**\n * Return all indexed values\n */\n get values(): T[] {\n return this._values\n }\n\n /**\n * Load the given list of values into the index, replacing any existing data.\n * @param values List of values.\n */\n load(values: T[] | undefined): void {\n this._values = values ?? []\n this._hashTable = {}\n for (const value of this.values) {\n const key = value[this.#keyField] as string\n if (this._hashTable[key] !== undefined) throw new Error(`Duplicate key [${key}]`)\n this._hashTable[key] = value\n }\n }\n\n /**\n * Get a value from the index\n * @param key Key string\n */\n get(key: string | undefined): T | undefined {\n if (!key) return undefined\n return this._hashTable[key]\n }\n}\n","import { Badge, compareByDefaultName, compareByZoneKey } from './badge'\nimport { BadgeSearchOptions } from './badge-search-options'\nimport { Paged } from './paged'\nimport { AbstractIndex } from './abstract-index'\n\nexport class BadgeIndex extends AbstractIndex<Badge> {\n constructor() {\n super('key')\n }\n\n search(options?: BadgeSearchOptions): Paged<Badge> {\n const filtered = (options?.query || options?.filter)\n ? this._values.filter(badge => this.#satisfiesQueryPredicate(badge, options?.query) && this.#satisfiesFilterPredicate(badge, options?.filter))\n : this._values\n\n const totalPages = options?.pageSize ? Math.ceil(filtered.length / (options?.pageSize)) : 1\n const page = Math.max(1, Math.min(totalPages, options?.page ?? 1))\n const paged = options?.pageSize ? filtered.slice((page - 1) * options.pageSize, page * options?.pageSize) : filtered\n\n const sorted = this.#sort(paged, options?.sort)\n\n return {\n items: sorted,\n page: page,\n pageSize: options?.pageSize,\n totalItems: filtered.length,\n totalPages: totalPages,\n }\n }\n\n #satisfiesQueryPredicate(badge: Badge, query?: BadgeSearchOptions['query']): boolean {\n const queryString = query?.str?.toLowerCase() ?? ''\n return !!(((query?.on?.name ?? true) && badge.name.canonical.some(x => x.value.toLowerCase().includes(queryString)))\n || (query?.on?.badgeText && badge.badgeText.canonical.some(x => x.value.toLowerCase().includes(queryString)))\n || (query?.on?.acquisition && badge.acquisition?.toLowerCase().includes(queryString))\n || (query?.on?.effect && badge.effect?.toLowerCase().includes(queryString))\n || (query?.on?.notes && badge.notes?.toLowerCase().includes(queryString))\n || (query?.on?.setTitle && (badge.setTitleId?.some(x => x?.toString().includes(queryString)))))\n }\n\n #satisfiesFilterPredicate(badge: Badge, filter?: BadgeSearchOptions['filter']): boolean {\n return (!filter?.type || badge.type === filter.type)\n && (!filter?.zoneKey || badge.zoneKey === filter.zoneKey)\n && (!filter?.morality || badge.morality.has(filter.morality))\n }\n\n #sort(badges: Badge[], sort?: BadgeSearchOptions['sort']): Badge[] {\n if (!sort) return badges\n const ascending = sort.dir !== 'desc'\n\n if (sort.by === 'badge-name') return badges.sort((a, b) => ascending ? compareByDefaultName(a, b) : compareByDefaultName(b, a))\n\n if (sort.by === 'zone-key') return badges.sort((a, b) => ascending ? compareByZoneKey(a, b) : compareByZoneKey(b, a))\n\n return sort.dir === 'desc' ? badges.reverse() : badges\n }\n}\n","import { ContentBundle } from '../api/content-bundle'\nimport { Change } from '../api/change'\nimport { Link } from '../api/link'\nimport { MarkdownString } from '../api/markdown-string'\n\nexport class BundleMetadata {\n /**\n * Name of the content bundle.\n */\n readonly name: string\n\n /**\n * Description of the fork.\n */\n readonly description?: MarkdownString\n\n /**\n * Repository where the db content package is maintained.\n */\n readonly repository?: string\n\n /**\n * List of external links. Wiki, forums, etc.\n */\n readonly links?: Link[]\n\n /**\n * Change log for this data package.\n */\n readonly changelog?: Change[]\n\n /**\n * The current version of the data package.\n */\n readonly version?: string\n\n constructor(bundle: ContentBundle) {\n this.name = bundle.name\n this.description = bundle.description\n this.repository = bundle.repository\n this.links = bundle.links ?? []\n this.changelog = bundle.changelog ?? []\n this.version = this.changelog?.at(-1)?.version\n }\n}\n","import { Link } from '../api/link'\nimport { ZoneData } from '../api/zone-data'\nimport { Key } from './key'\n\nexport class Zone {\n /**\n * Unique key used to reference this zone.\n *\n * Keys must be unique and can only contain lowercase letters, numbers and hyphens (`-`).\n */\n readonly key: string\n\n /**\n * The name of the zone as it appears in-game.\n */\n readonly name: string\n\n /**\n * List of external links. Wiki, forums, etc.\n */\n readonly links: Link[]\n\n constructor(data: ZoneData) {\n this.key = new Key(data.key).value\n this.name = data.name\n this.links = data.links ?? []\n }\n}\n","import { Link } from '../api/link'\nimport { Key } from './key'\nimport { MarkdownString } from '../api/markdown-string'\nimport { ContactData } from '../api/contact-data'\nimport { Location } from './location'\nimport { MoralityList } from './morality-list'\nimport { coalesceToArray } from '../util'\n\nexport class Contact {\n /**\n * Unique key used to reference this contact.\n *\n * Keys must be unique and can only contain lowercase letters, numbers and hyphens (`-`).\n */\n readonly key: string\n\n /**\n * The name of this contact.\n */\n readonly name: string\n\n /**\n * The contact's title.\n */\n readonly title?: string\n\n /**\n * The character moralities that this contact will interact with.\n */\n readonly morality?: MoralityList\n\n /**\n * The location of this contact.\n */\n readonly location?: Location\n\n /**\n * The level range this contact will offer missions for.\n */\n readonly levelRange?: [number, number?]\n\n /**\n * Freeform notes or tips about the contact.\n */\n readonly notes?: MarkdownString\n\n /**\n * List of external links. Wiki, forums, etc.\n */\n readonly links: Link[]\n\n constructor(data: ContactData) {\n this.key = new Key(data.key).value\n this.name = data.name\n this.title = data.title\n this.morality = new MoralityList(coalesceToArray(data.morality))\n this.location = data.location\n this.levelRange = data.levelRange\n this.notes = data.notes\n this.links = data.links ?? []\n }\n}\n","import { MissionType } from '../api/mission-type'\nimport { MarkdownString } from '../api/markdown-string'\nimport { Link } from '../api/link'\nimport { MissionData } from '../api/mission-data'\nimport { Key } from './key'\nimport { coalesceToArray } from '../util'\nimport { MoralityList } from './morality-list'\n\nexport class Mission {\n /**\n * Unique key used to reference this mission.\n *\n * Keys must be unique and can only contain lowercase letters, numbers and hyphens (`-`).\n */\n readonly key: string\n\n /**\n * The name of the mission as it appears from the contact.\n *\n * The name may be different when viewed in Ouroboros as a Flashback.\n */\n readonly name: string\n\n /**\n * The type of mission... Story arc, task force, trial, etc.\n */\n readonly type: MissionType\n\n /**\n * The character moralities that may accept the mission.\n */\n readonly morality: MoralityList\n\n /**\n * The keys of any contacts that provide this mission.\n */\n readonly contactKeys?: string[]\n\n /**\n * The level range this mission is available for.\n */\n readonly levelRange?: [number, number?]\n\n /**\n * Freeform notes or tips about the mission.\n */\n readonly notes?: MarkdownString\n\n /**\n * List of external links. Wiki, forums, etc.\n */\n readonly links: Link[]\n\n /**\n * If the mission is available in Ouroboros as a Flashback.\n */\n readonly flashback?: {\n\n /**\n * The id of the mission as seen in the Flashback menu, i.e. '14.01'.\n */\n readonly id: string\n\n /**\n * The level range this mission appears under as a Flashback. Leave undefined if the same as the base mission.\n */\n readonly levelRange?: [number, number?]\n\n /**\n * The name as it appears in the Flashback list. Leave undefined if the same as the base mission.\n */\n readonly name?: string\n\n /**\n * The character moralities that the mission will appear for in the Flashback list. Leave undefined if the same as the base mission.\n */\n readonly morality?: MoralityList\n\n /**\n * Freeform notes or tips about the Flashback version of the mission.\n */\n readonly notes?: MarkdownString\n }\n\n constructor(data: MissionData) {\n this.key = new Key(data.key).value\n this.name = data.name\n this.type = data.type\n this.morality = new MoralityList(coalesceToArray(data.morality))\n this.contactKeys = coalesceToArray(data.contactKeys)\n this.levelRange = data.levelRange\n this.notes = data.notes\n this.links = data.links ?? []\n this.flashback = createFlashback(data)\n }\n}\n\nfunction createFlashback(data: MissionData): Mission['flashback'] {\n if (!data.flashback) return undefined\n return {\n id: data.flashback.id,\n levelRange: data.flashback.levelRange ?? data.levelRange,\n name: data.flashback.name ?? data.name,\n morality: new MoralityList(coalesceToArray(data.flashback.morality ?? data.morality)),\n notes: data.flashback.notes,\n }\n}\n","import { ContentBundle } from '../api/content-bundle'\nimport { Archetype } from './archetype'\nimport { Zone } from './zone'\nimport { Badge } from './badge'\nimport { BundleMetadata } from './bundle-metadata'\nimport { BadgeIndex } from './badge-index'\nimport { BadgeSearchOptions } from './badge-search-options'\nimport { Paged } from './paged'\nimport { Contact } from './contact'\nimport { Mission } from './mission'\nimport { AbstractIndex } from './abstract-index'\n\nexport class CohContentDatabase {\n #archetypeIndex = new AbstractIndex<Archetype>('key')\n #zoneIndex = new AbstractIndex<Zone>('key')\n #contactIndex = new AbstractIndex<Contact>('key')\n #missionIndex = new AbstractIndex<Mission>('key')\n #badgeIndex = new BadgeIndex()\n\n #metadata?: BundleMetadata\n #servers?: string[]\n\n /**\n * Load the given content bundle, resetting the db if a bundle is already loaded.\n * @param bundle The bundle to load.\n */\n load(bundle: ContentBundle): void {\n this.#metadata = new BundleMetadata(bundle)\n this.#servers = bundle.servers ?? []\n\n this.#archetypeIndex.load(bundle.archetypes?.map(x => new Archetype(x)))\n this.#zoneIndex.load(bundle.zones?.map(x => new Zone(x)))\n this.#contactIndex.load(bundle.contacts?.map(x => new Contact(x)))\n this.#missionIndex.load(bundle.missions?.map(x => new Mission(x)))\n this.#badgeIndex.load(bundle.badges?.map(x => new Badge(x)))\n }\n\n /**\n * Metadata about the content bundle.\n */\n get metadata(): BundleMetadata | undefined {\n return this.#metadata\n }\n\n /**\n * List of the game server names.\n *\n * Torchbearer, Excelsior, etc.\n */\n get servers(): string[] {\n return this.#servers ?? []\n }\n\n /**\n * List of archetypes.\n */\n get archetypes(): Archetype[] {\n return this.#archetypeIndex.values\n }\n\n /**\n * Get archetype by key.\n * @param key The key.\n */\n getArchetype(key: string | undefined): Archetype | undefined {\n return this.#archetypeIndex.get(key)\n }\n\n /**\n * List of game zones.\n */\n get zones(): Zone[] {\n return this.#zoneIndex.values\n }\n\n /**\n * Get zone by key.\n * @param key The key.\n */\n getZone(key: string | undefined): Zone | undefined {\n return this.#zoneIndex.get(key)\n }\n\n /**\n * List of contacts.\n */\n get contacts(): Contact[] {\n return this.#contactIndex.values\n }\n\n /**\n * Get contact by key.\n * @param key The key.\n */\n getContact(key: string | undefined): Contact | undefined {\n return this.#contactIndex.get(key)\n }\n\n /**\n * List of missions.\n */\n get missions(): Mission[] {\n return this.#missionIndex.values\n }\n\n /**\n * Get mission by key.\n * @param key The key.\n */\n getMission(key: string | undefined): Mission | undefined {\n return this.#missionIndex.get(key)\n }\n\n /**\n * List of badges.\n */\n get badges(): Badge[] {\n return this.#badgeIndex.values\n }\n\n /**\n * Get badge by key.\n * @param key The key.\n */\n getBadge(key: string | undefined): Badge | undefined {\n return this.#badgeIndex.get(key)\n }\n\n /**\n * Search, sort and filter the badge list.\n * This is a fairly brute-forced approach and will not be as performant as loading the badge data into a traditional\n * database engine, but is sufficient for most operations.\n * @param options {@link BadgeSearchOptions}\n */\n searchBadges(options?: BadgeSearchOptions): Paged<Badge> {\n return this.#badgeIndex.search(options)\n }\n}\n","import { Coords, LocationData, LocationIcon } from '../api/location-data'\n\nexport class Location {\n /**\n * Key of the {@link Zone} that the location references.\n */\n readonly zoneKey?: string\n\n /**\n * In-game `/loc` coordinates of the location.\n */\n readonly coords?: Coords\n\n /**\n * The type of icon to use if the location appears on a map. (Typically the Vidiot map icon).\n */\n readonly icon?: LocationIcon\n\n /**\n * The text that should appear in the location icon. (Typically a number or symbol from the Vidiot map).\n */\n readonly iconText?: string\n\n constructor(data: LocationData) {\n this.zoneKey = data.zoneKey\n this.coords = data.coords\n this.icon = data.icon\n this.iconText = data.iconText\n }\n}\n","import { Change } from './api/change'\n\nexport const CHANGELOG: Change[] = [\n {\n version: '2.0.0',\n date: new Date('2025-03-12'),\n description: ''\n + '* Replaced redundant interfaces with their concrete equivalents.\\n'\n + `* Server groups are now referred to as 'forks'.\\n`\n + '* Replaced enums with union types and changed values to `kebab-case`.\\n'\n + '* `IServerGroupData` is now `ContentBundle` and each database instance is now designed to accept only a single bundle.\\n'\n + '* `GameMap` is now `Zone`.\\n'\n + '* Removed the `serverGroup` property from entities to simplify the object tree given that only a single context can exist per db now.\\n'\n + '* Added a simple indexing and search function for badge names, text and acquisition info.\\n'\n + '* Zone and badge references now follow a standard Markdown link format with a `badge://` or `map://` protocol.\\n'\n + '* Badge partials are now known as badge requirements.\\n'\n + '* Removed the `VidiotMap` API as it was never used or fleshed out properly.\\n'\n + '* Added formal support for Missions and Contacts in badge requirements.\\n'\n + '* Move exploration badge locations into badge requirement list.\\n'\n + '* Standardized pluralization of some field names (name, icon).\\n'\n + '* Combined `settitle` ids into a single tuple field.\\n'\n + '* Change from GNU to The Unlicense.\\n'\n + '* Removed all third-party dependencies.\\n'\n + '* Moved from webpack to rollup for packaging.\\n'\n + '* Add eslint for linting.\\n'\n + '* Add jest for unit tests.\\n'\n + '* Added GitHub Actions for CI.\\n',\n },\n]\n"],"names":["_items","__privateAdd","__publicField","__privateSet","__privateGet","__privateMethod"],"mappings":"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"}
1
+ {"version":3,"file":"coh-content-db.mjs","sources":["../src/main/api/alignment.ts","../src/main/api/badge-requirement-type.ts","../src/main/api/badge-type.ts","../src/main/api/enhancement-category.ts","../src/main/api/mission-type.ts","../src/main/api/morality.ts","../src/main/api/sex.ts","../src/main/api/zone-type.ts","../src/main/db/alignment-list.ts","../src/main/db/key.ts","../src/main/db/archetype.ts","../src/main/util/coalesce-to-array.ts","../src/main/db/badge-requirement.ts","../src/main/db/variants.ts","../src/main/db/morality-list.ts","../src/main/db/abstract-index.ts","../src/main/util/to-date.ts","../src/main/db/set-title-ids.ts","../src/main/db/badge.ts","../src/main/db/badge-index.ts","../src/main/db/bundle-header.ts","../src/main/db/level-range.ts","../src/main/db/zone.ts","../src/main/db/contact.ts","../src/main/db/mission.ts","../src/main/db/coh-content-database.ts","../src/main/db/location.ts","../src/main/util/links.ts"],"sourcesContent":["export const ALIGNMENT = ['hero', 'villain', 'praetorian'] as const\nexport type Alignment = typeof ALIGNMENT[number]\nexport type AlignmentExtended = Alignment\n /**\n * The alignments available for Primal Earth characters - Hero and Villain.\n */\n | 'primal'\n /**\n * All the alignments.\n */\n | 'all'\n\nconst ALIGNMENT_ORDER = Object.fromEntries(ALIGNMENT.map((x, index) => [x, index]))\n\nexport function compareAlignment(a?: Alignment, b?: Alignment): number {\n const orderA = a ? ALIGNMENT_ORDER[a] : -1\n const orderB = b ? ALIGNMENT_ORDER[b] : -1\n return orderA - orderB\n}\n","export const BADGE_REQUIREMENT_TYPE = [\n /**\n * Collect a badge.\n */\n 'badge',\n /**\n * Craft an invention.\n */\n 'invention',\n /**\n * Some invention badges require you to build x of two different invention levels, 'plus one of either level'.\n */\n 'invention-plus-one',\n /**\n * Visit a location.\n */\n 'location',\n /**\n * Click on a monument.\n */\n 'monument',\n /**\n * Complete a mission.\n */\n 'mission',\n /**\n * Complete an arbitrary task.\n */\n 'task',\n] as const\n\nexport type BadgeRequirementType = typeof BADGE_REQUIREMENT_TYPE[number]\n","export const BADGE_TYPE = [\n 'exploration',\n 'history',\n 'accomplishment',\n 'achievement',\n 'accolade',\n 'gladiator',\n 'veteran',\n 'pvp',\n 'invention',\n 'defeat',\n 'event',\n 'ouroboros',\n 'consignment',\n 'day-job',\n 'architect-entertainment',\n] as const\n\nexport type BadgeType = typeof BADGE_TYPE[number]\n","export const ENHANCEMENT_CATEGORY = [\n 'defense-debuff',\n 'to-hit-debuff',\n 'taunt',\n 'confuse',\n 'healing',\n 'defense-buff',\n 'resist-damage',\n 'intangibility',\n 'sleep',\n 'slow',\n 'hold',\n 'stun',\n 'immobilize',\n 'fear',\n 'endurance-modification',\n 'endurance-reduction',\n 'recharge-reduction',\n 'interrupt-duration',\n 'accuracy',\n 'to-hit-buff',\n 'damage',\n 'knockback',\n 'run-speed',\n 'jump',\n 'fly-speed',\n 'range',\n] as const\n\nexport type EnhancementCategory = typeof ENHANCEMENT_CATEGORY[number]\n","export const MISSION_TYPE = ['story-arc', 'mission', 'task-force', 'strike-force', 'trial', 'personal-story'] as const\nexport type MissionType = typeof MISSION_TYPE[number]\n","import { Alignment } from './alignment'\n\nexport const MORALITY = ['hero', 'vigilante', 'villain', 'rogue', 'resistance', 'loyalist'] as const\nexport const MORALITY_EXTENDED = [\n ...MORALITY,\n /**\n * Any of the Primal Earth moralities - Hero, Vigilante, Villain, Rogue.\n */\n 'primal',\n /**\n * Either of the Praetorian Earth moralities - Resistance or Loyalist.\n */\n 'praetorian',\n /**\n * The moralities that roll up to the Hero {@link Alignment} - Hero and Vigilante.\n */\n 'heroic',\n /**\n * The moralities that roll up to the Villain {@link Alignment} - Villain and Rogue.\n */\n 'villainous',\n /**\n * Moralities with access to Paragon City - Hero, Vigilante and Rogue.\n */\n 'paragon-city-access',\n /**\n * Moralities with access to the Rogue Isles - Villain, Rogue and Vigilante.\n */\n 'rogue-isles-access',\n /**\n * All the moralities.\n */\n 'all',\n] as const\nexport type Morality = typeof MORALITY[number]\nexport type MoralityExtended = typeof MORALITY_EXTENDED[number]\n\n/**\n * Maps a morality to the underlying alignment\n */\nexport const MoralityMap: Record<Morality | Alignment, Alignment> = {\n hero: 'hero',\n vigilante: 'hero',\n villain: 'villain',\n rogue: 'villain',\n loyalist: 'praetorian',\n resistance: 'praetorian',\n praetorian: 'praetorian',\n}\n","export const SEX = ['M', 'F'] as const\nexport type Sex = typeof SEX[number]\n\nconst SEX_ORDER = Object.fromEntries(SEX.map((x, index) => [x, index]))\n\nexport function compareSex(a?: Sex, b?: Sex): number {\n const orderA = a ? SEX_ORDER[a] : -1\n const orderB = b ? SEX_ORDER[b] : -1\n return orderA - orderB\n}\n","export const ZONE_TYPE = [\n /**\n * The standard zone type, even if not technically occurring in the 'City' proper.\n */\n 'city',\n /**\n * An Ouroboros flashback to a zone as it was in a previous era.\n */\n 'echo',\n /**\n * Tutorial zon, usually inaccessible after leaving.\n */\n 'tutorial',\n /**\n * Trial zones, like the Abandoned Sewers trial.\n */\n 'trial',\n /**\n * Hazard zones like the Hollows.\n */\n 'hazard',\n /**\n * Mayhem mission zones.\n */\n 'mayhem',\n /**\n * Safeguard mission zones.\n */\n 'safeguard',\n /**\n * Exists inside a mission not covered by the other types.\n */\n 'mission',\n /**\n * Incarnate trial zones.\n */\n 'incarnate',\n /**\n * Cooprative zones where Heroes and Villains can team up for PvE content.\n */\n 'co-op',\n /**\n * PvP zones like Bloody Bay.\n */\n 'pvp',\n /**\n * Located in an arena PvP map.\n */\n 'arena',\n /**\n * A building, usually contained within another zone, like the AE buildings.\n */\n 'building',\n /**\n * Stuff like the (Phone only) zone.\n */\n 'other',\n] as const\nexport type ZoneType = typeof ZONE_TYPE[number]\n","import { ALIGNMENT, Alignment, AlignmentExtended } from '../api/alignment'\n\nexport class AlignmentList {\n readonly #items: Set<Alignment>\n\n readonly hero: boolean\n readonly villain: boolean\n readonly praetorian: boolean\n\n readonly primal: boolean\n readonly all: boolean\n\n constructor(items?: AlignmentExtended[]) {\n const set = new Set(items ?? [...ALIGNMENT])\n this.hero = set.has('hero') || set.has('primal') || set.has('all')\n this.villain = set.has('villain') || set.has('primal') || set.has('all')\n this.praetorian = set.has('praetorian') || set.has('all')\n\n this.primal = this.hero && this.villain\n this.all = this.hero && this.villain && this.praetorian\n\n this.#items = new Set()\n if (this.hero) this.#items.add('hero')\n if (this.villain) this.#items.add('villain')\n if (this.praetorian) this.#items.add('praetorian')\n }\n\n get items(): Alignment[] {\n return [...this.#items]\n }\n\n has(alignment?: AlignmentExtended): boolean {\n switch (alignment) {\n case 'hero': {\n return this.hero\n }\n case 'villain': {\n return this.villain\n }\n case 'praetorian': {\n return this.praetorian\n }\n case 'primal' : {\n return this.primal\n }\n case 'all': {\n return this.all\n }\n default: {\n return false\n }\n }\n }\n}\n","const INVALID_KEY_PATTERN = /[^a-z0-9-]/\n\nexport class Key {\n readonly #value: string\n\n constructor(value: string) {\n this.#validateKey(value)\n this.#value = value\n }\n\n get value(): string {\n return this.#value\n }\n\n #validateKey(key: string): void {\n if (INVALID_KEY_PATTERN.test(key)) throw new Error(`Invalid key: [${key}]; Keys can only contain lowercase characters, numbers and dashes.`)\n }\n}\n","import { Key } from './key'\nimport { ArchetypeData } from '../api/archetype-data'\n\nexport class Archetype {\n readonly key: string\n readonly name: string\n readonly description?: string\n\n constructor(data: ArchetypeData) {\n this.key = new Key(data.key).value\n this.name = data.name\n this.description = data.description\n }\n}\n","/**\n * For fields that accept either an array of values or a single value, coalesces the value to an array.\n *\n * Arrays are returned as-is.\n * Single values are returned as a single-value array.\n * Undefined values are returned as undefined.\n *\n * @param value The value to coalesce.\n */\nexport function coalesceToArray<T>(value?: T | T[]): T[] | undefined {\n if (!value) return undefined\n return Array.isArray(value) ? value as T[] : [value]\n}\n","import { BadgeRequirementData } from '../api/badge-requirement-data'\nimport { BadgeRequirementType } from '../api/badge-requirement-type'\nimport { EnhancementCategory } from '../api/enhancement-category'\nimport { Key } from './key'\nimport { MarkdownString } from '../api/markdown-string'\nimport { Link } from '../api/link'\nimport { Location } from './location'\nimport { coalesceToArray } from '../util/coalesce-to-array'\n\nexport class BadgeRequirement {\n /**\n * Unique key used to reference this badge requirement.\n *\n * Keys must be unique and can only contain lowercase letters, numbers and hyphens (`-`).\n */\n readonly key: string\n\n /**\n * The requirement type.\n */\n readonly type: BadgeRequirementType\n\n /**\n * If the requirement involves a location, where it is.\n */\n readonly location?: Location[]\n\n /**\n * If the requirement involves a badge, the badge key.\n */\n readonly badgeKey?: string\n\n /**\n * If the requirement involves a mission, the mission key.\n */\n readonly missionKey?: string\n\n /**\n * If the requirement involves a monument, the text that is displayed thereon.\n */\n readonly monumentText?: string\n\n /**\n * If the requirement involves crafting an invention, the Level of the invention required.\n */\n readonly inventionLevel?: number\n\n /**\n * If the requirement involves crafting an invention, the types of enhancements that will qualify.\n */\n readonly inventionTypes?: EnhancementCategory[]\n\n /**\n * Number of times the task needs to be repeated.\n */\n readonly count?: number\n\n /**\n * Additional information about the requirement.\n */\n readonly notes?: MarkdownString\n\n /**\n * List of external links. Wiki, forums, etc.\n */\n readonly links: Link[]\n\n constructor(data: BadgeRequirementData) {\n this.key = new Key(data.key).value\n this.type = data.type\n this.location = coalesceToArray(data.location)\n this.badgeKey = data.badgeKey\n this.missionKey = data.missionKey\n this.monumentText = data.monumentText\n this.inventionLevel = data.inventionLevel\n this.inventionTypes = data.inventionTypes\n this.count = data.count\n this.notes = data.notes\n this.links = data.links ?? []\n }\n}\n","import { VariantData } from '../api/variant-data'\nimport { compareSex } from '../api/sex'\nimport { compareAlignment } from '../api/alignment'\nimport { VariantContext } from '../api/variant-context'\nimport { MoralityMap } from '../api/morality'\n\nexport class Variants<T> {\n readonly #sortedValues: VariantData<T>[] = []\n\n /**\n * Create a variant set from either a list of categorized values, or a single value when there are no variants.\n * @param value List of variants, or a single value.\n */\n constructor(value: VariantData<T>[] | T) {\n if (Array.isArray(value)) {\n this.#sortedValues = value.toSorted()\n this.#sortedValues.sort((a, b) => this.#compareVariants(a, b))\n } else {\n this.#sortedValues = [{ value }]\n }\n }\n\n /**\n * Get a variant by context\n * @param context The context\n */\n getVariant(context?: VariantContext): VariantData<T> | undefined {\n const alignment = context?.morality ? MoralityMap[context.morality] : undefined\n const sex = context?.sex\n\n for (let index = this.#sortedValues.length; index--;) {\n const entry = this.#sortedValues[index]\n if ((entry.alignment === undefined || entry.alignment === alignment)\n && (entry.sex === undefined || entry.sex === sex)\n ) return entry\n }\n\n return this.default\n }\n\n /**\n * Get a value by variant context\n * @param context The context\n */\n getValue(context?: VariantContext): T | undefined {\n return this.getVariant(context)?.value\n }\n\n /**\n * Get the default value for this list of variants, the value with the highest priority and lowest specificity.\n */\n get default(): VariantData<T> | undefined {\n return this.#sortedValues[0]\n }\n\n /**\n * Get the list of variants sorted in canonical order (alignment then sex, low to high specificity).\n */\n get canonical(): VariantData<T>[] {\n return this.#sortedValues\n }\n\n /**\n * Create a joined string from the variant values in canonical order.\n * @param separator Separator to use. Default is ' / '\n */\n toString(separator: string): string {\n return this.canonical.map(x => x.value).join(separator)\n }\n\n #compareVariants(a: VariantData<T>, b: VariantData<T>): number {\n const aSpecificity = (a.alignment ? 2 : 0) + (a.sex ? 1 : 0)\n const bSpecificity = (b.alignment ? 2 : 0) + (b.sex ? 1 : 0)\n if (aSpecificity !== bSpecificity) return aSpecificity - bSpecificity // Order first by least-specific\n\n const alignmentComparison = compareAlignment(a.alignment, b.alignment) // Next by alignment\n if (alignmentComparison !== 0) return alignmentComparison\n\n const sexComparison = compareSex(a.sex, b.sex) // Last by sex\n if (sexComparison !== 0) return sexComparison\n\n return String(a.value).localeCompare(String(b.value))\n }\n}\n","import { MORALITY, Morality, MoralityExtended } from '../api/morality'\n\nexport class MoralityList {\n readonly #items: Set<Morality>\n\n readonly hero: boolean\n readonly vigilante: boolean\n readonly villain: boolean\n readonly rogue: boolean\n readonly resistance: boolean\n readonly loyalist: boolean\n\n readonly primal: boolean\n readonly praetorian: boolean\n readonly heroic: boolean\n readonly villainous: boolean\n readonly paragonCityAccess: boolean\n readonly rogueIslesAccess: boolean\n\n readonly all: boolean\n\n constructor(items?: MoralityExtended[]) {\n const set = new Set(items ?? [...MORALITY])\n this.hero = set.has('hero') || set.has('primal') || set.has('heroic') || set.has('paragon-city-access') || set.has('all')\n this.vigilante = set.has('vigilante') || set.has('primal') || set.has('heroic') || set.has('paragon-city-access') || set.has('rogue-isles-access') || set.has('all')\n this.villain = set.has('villain') || set.has('primal') || set.has('villainous') || set.has('rogue-isles-access') || set.has('all')\n this.rogue = set.has('rogue') || set.has('primal') || set.has('villainous') || set.has('paragon-city-access') || set.has('rogue-isles-access') || set.has('all')\n this.resistance = set.has('resistance') || set.has('praetorian') || set.has('all')\n this.loyalist = set.has('loyalist') || set.has('praetorian') || set.has('all')\n\n this.primal = this.hero && this.vigilante && this.villain && this.rogue\n this.praetorian = this.loyalist && this.resistance\n this.heroic = this.hero && this.vigilante\n this.villainous = this.villain && this.rogue\n this.paragonCityAccess = this.heroic && this.rogue\n this.rogueIslesAccess = this.villainous && this.vigilante\n\n this.all = this.primal && this.praetorian\n\n this.#items = new Set()\n if (this.hero) this.#items.add('hero')\n if (this.vigilante) this.#items.add('vigilante')\n if (this.villain) this.#items.add('villain')\n if (this.rogue) this.#items.add('rogue')\n if (this.resistance) this.#items.add('resistance')\n if (this.loyalist) this.#items.add('loyalist')\n }\n\n get items(): Morality[] {\n return [...this.#items]\n }\n\n has(morality?: MoralityExtended): boolean {\n switch (morality) {\n case 'hero': {\n return this.hero\n }\n case 'vigilante': {\n return this.vigilante\n }\n case 'villain': {\n return this.villain\n }\n case 'rogue': {\n return this.rogue\n }\n case 'resistance': {\n return this.resistance\n }\n case 'loyalist': {\n return this.loyalist\n }\n case 'primal' : {\n return this.primal\n }\n case 'praetorian': {\n return this.praetorian\n }\n case 'heroic': {\n return this.hero\n }\n case 'paragon-city-access': {\n return this.paragonCityAccess\n }\n case 'rogue-isles-access': {\n return this.rogueIslesAccess\n }\n case 'villainous': {\n return this.villainous\n }\n case 'all': {\n return this.all\n }\n default: {\n return false\n }\n }\n }\n}\n","type KeysOfType<T, V> = { [P in keyof T]: T[P] extends V ? P : never }[keyof T]\n\nexport class AbstractIndex<T> {\n protected _values: T[] = []\n protected _hashTable: Record<string, T> = {}\n\n /**\n * Create a new index.\n * @param keyField The field of the values that will act as the key.\n * @param values Values to index.\n */\n constructor(keyField: KeysOfType<T, string>, values: T[] | undefined) {\n this._values = values ?? []\n this._hashTable = {}\n for (const value of this.values) {\n const key = value[keyField] as string\n if (this._hashTable[key] !== undefined) throw new Error(`Duplicate key [${key}]`)\n this._hashTable[key] = value\n }\n }\n\n /**\n * Return all indexed values\n */\n get values(): T[] {\n return this._values\n }\n\n /**\n * Get a value from the index\n * @param key Key string\n */\n get(key: string | undefined): T | undefined {\n if (!key) return undefined\n return this._hashTable[key]\n }\n}\n","/**\n * Converts an iso string to a Date object, throwing an error if the iso string is invalid.\n * @param iso ISO-8601 Date string\n */\nexport function toDate(iso: string): Date {\n const date = new Date(iso)\n if (!date || Number.isNaN(date.getTime())) throw new Error(`Invalid date format: [${iso}]`)\n return date\n}\n","import { SetTitleData } from '../api/set-title-data'\n\nexport class SetTitleIds {\n readonly primal: number\n readonly praetorian?: number\n\n constructor(value: SetTitleData) {\n [this.primal, this.praetorian] = value\n }\n}\n","import { BadgeType } from '../api/badge-type'\nimport { Link } from '../api/link'\nimport { BadgeData } from '../api/badge-data'\nimport { BadgeRequirement } from './badge-requirement'\nimport { Key } from './key'\nimport { Variants } from './variants'\nimport { MarkdownString } from '../api/markdown-string'\nimport { MoralityList } from './morality-list'\nimport { AbstractIndex } from './abstract-index'\nimport { toDate } from '../util/to-date'\nimport { coalesceToArray } from '../util/coalesce-to-array'\nimport { SetTitleIds } from './set-title-ids'\nimport { VariantContext } from '../api/variant-context'\n\nexport class Badge {\n readonly #requirementsIndex: AbstractIndex<BadgeRequirement>\n readonly #zoneKeys = new Set<string>()\n\n /**\n * The database key for this badge.\n */\n readonly key: string\n\n /**\n * The type of badge.\n */\n readonly type: BadgeType\n\n /**\n * The name of this badge.\n *\n * May vary by character sex or alignment.\n */\n readonly name: Variants<string>\n\n /**\n * The date that the badge was added to the game.\n */\n readonly releaseDate: Date\n\n /**\n * The character moralities that this badge is available to.\n */\n readonly morality: MoralityList\n\n /**\n * The badge text as it appears in-game. May vary by character sex or alignment.\n */\n readonly badgeText: Variants<MarkdownString>\n\n /**\n * Short description of how to acquire the badge. Detailed instructions will be in the notes field.\n */\n readonly acquisition?: MarkdownString\n\n /**\n * Absolute URL to this badge's icon.\n *\n * May vary by character sex or alignment.\n */\n readonly icon: Variants<string>\n\n /**\n * Freeform notes or tips about the badge.\n */\n readonly notes?: MarkdownString\n\n /**\n * List of external links. Wiki, forums, etc.\n */\n readonly links: Link[]\n\n /**\n * The id used with the in-game `/settitle` command to apply the badge.\n * The first value is the id for primal characters and the (optional) second number is the id for praetorian characters.\n */\n readonly setTitleId?: SetTitleIds\n\n /**\n * A description of the effect the badge will have, such as a buff or granting a temporary power.\n */\n readonly effect?: MarkdownString\n\n /**\n * Some badges are not included in the badge total count... such as Flames of Prometheus, which can be removed by redeeming it for a Notice of the Well.\n */\n readonly ignoreInTotals: boolean\n\n constructor(badgeData: BadgeData) {\n this.key = new Key(badgeData.key).value\n this.type = badgeData.type\n this.name = new Variants(badgeData.name)\n this.releaseDate = toDate(badgeData.releaseDate)\n this.morality = new MoralityList(coalesceToArray(badgeData.morality))\n this.badgeText = new Variants(badgeData.badgeText ?? [])\n this.acquisition = badgeData.acquisition\n this.icon = new Variants(badgeData.icon ?? [])\n this.notes = badgeData.notes\n this.links = badgeData.links ?? []\n this.effect = badgeData.effect\n this.setTitleId = badgeData.setTitleId ? new SetTitleIds(badgeData.setTitleId) : undefined\n this.ignoreInTotals = badgeData.ignoreInTotals ?? false\n\n this.#requirementsIndex = new AbstractIndex<BadgeRequirement>('key', badgeData.requirements?.map(x => new BadgeRequirement(x)))\n\n for (const requirement of this.#requirementsIndex.values) {\n if (requirement.location) for (const location of requirement.location) {\n if (location.zoneKey) this.#zoneKeys.add(location.zoneKey)\n }\n }\n }\n\n /**\n * Represents the requirements for badges with multiple fulfillment steps, such as visiting monuments for history badges, completing missions, or collecting other badges.\n */\n get requirements(): BadgeRequirement[] {\n return this.#requirementsIndex.values\n }\n\n getRequirement(key: string): BadgeRequirement | undefined {\n return this.#requirementsIndex.get(key)\n }\n\n /**\n * Return a list of all the zone keys referenced by this badge.\n */\n get zoneKeys(): string[] {\n return [...this.#zoneKeys]\n }\n\n /**\n * The zone key if this badge relates to a single zone.\n */\n get zoneKey(): string | undefined {\n return this.#zoneKeys.size === 1 ? this.#zoneKeys.values().next().value : undefined\n }\n}\n\nexport function compareByName(a?: Badge, b?: Badge, context?: VariantContext): number {\n const aName = a?.name?.getValue(context)\n const bName = b?.name?.getValue(context)\n if (!aName && !bName) return 0\n if (!aName) return 1\n if (!bName) return -1\n return aName.localeCompare(bName)\n}\n\nexport function compareByZoneKey(a?: Badge, b?: Badge): number {\n const aZone = a?.zoneKey\n const bZone = b?.zoneKey\n if (!aZone && !bZone) return 0\n if (!aZone) return 1\n if (!bZone) return -1\n return aZone.localeCompare(bZone)\n}\n\nexport function compareByReleaseDate(a?: Badge, b?: Badge): number {\n const aReleaseDate = a?.releaseDate?.getTime()\n const bReleaseDate = b?.releaseDate?.getTime()\n if (aReleaseDate === bReleaseDate) return 0\n if (!aReleaseDate) return 1\n if (!bReleaseDate) return -1\n return aReleaseDate < bReleaseDate ? -1 : 1\n}\n","import { Badge, compareByName, compareByReleaseDate, compareByZoneKey } from './badge'\nimport { BadgeSearchOptions } from './badge-search-options'\nimport { Paged } from './paged'\nimport { AbstractIndex } from './abstract-index'\n\nexport class BadgeIndex extends AbstractIndex<Badge> {\n constructor(values: Badge[] | undefined) {\n super('key', values)\n }\n\n search(options?: BadgeSearchOptions): Paged<Badge> {\n const matched = (options?.query || options?.filter)\n ? this._values.filter(badge => this.#satisfiesQueryPredicate(badge, options?.query) && this.#satisfiesFilterPredicate(badge, options?.filter))\n : this._values\n\n const sorted = this.#sort(matched, options)\n\n const totalPages = options?.pageSize ? Math.ceil(matched.length / (options?.pageSize)) : 1\n const pageNumber = Math.max(1, Math.min(totalPages, options?.page ?? 1))\n const items = options?.pageSize ? sorted.slice((pageNumber - 1) * options.pageSize, pageNumber * options?.pageSize) : sorted\n\n return {\n items: items,\n pageIndex: pageNumber - 1,\n pageNumber: pageNumber,\n pageSize: options?.pageSize,\n matchedItemCount: matched.length,\n totalItemCount: this._values.length,\n totalPageCount: totalPages,\n }\n }\n\n #satisfiesQueryPredicate(badge: Badge, query?: BadgeSearchOptions['query']): boolean {\n const queryString = query?.str?.toLowerCase() ?? ''\n const fields = query?.fields ? new Set(query?.fields) : new Set(['name']) // Default to name if not provided\n if (fields.size === 0) return true\n\n return !!((fields.has('name') && badge.name.canonical.some(x => x.value.toLowerCase().includes(queryString)))\n || (fields.has('badge-text') && badge.badgeText.canonical.some(x => x.value.toLowerCase().includes(queryString)))\n || (fields.has('acquisition') && badge.acquisition?.toLowerCase().includes(queryString))\n || (fields.has('effect') && badge.effect?.toLowerCase().includes(queryString))\n || (fields.has('notes') && badge.notes?.toLowerCase().includes(queryString))\n || (fields.has('set-title-id') && (badge.setTitleId?.primal.toString() === queryString))\n || (fields.has('set-title-id') && (badge.setTitleId?.praetorian?.toString() === queryString))\n )\n }\n\n #satisfiesFilterPredicate(badge: Badge, filter?: BadgeSearchOptions['filter']): boolean {\n return (!filter?.type || badge.type === filter.type)\n && (!filter?.zoneKey || badge.zoneKey === filter.zoneKey)\n && (!filter?.morality || badge.morality.has(filter.morality))\n && (!filter?.predicate || filter.predicate(badge))\n }\n\n #sort(badges: Badge[], options?: BadgeSearchOptions): Badge[] {\n switch (options?.sort) {\n case 'name.asc': {\n return badges.toSorted((a, b) => compareByName(a, b, options.context))\n }\n case 'name.desc': {\n return badges.toSorted((a, b) => compareByName(b, a, options.context))\n }\n case 'zone-key.asc': {\n return badges.toSorted(compareByZoneKey)\n }\n case 'zone-key.desc': {\n return badges.toSorted((a, b) => compareByZoneKey(b, a))\n }\n case 'release-date.asc': {\n return badges.toSorted(compareByReleaseDate)\n }\n case 'release-date.desc': {\n return badges.toSorted((a, b) => compareByReleaseDate(b, a))\n }\n case 'canonical.desc': {\n return badges.toReversed()\n }\n default: {\n return [...badges]\n }\n }\n }\n}\n","import { Link } from '../api/link'\nimport { MarkdownString } from '../api/markdown-string'\nimport { BundleHeaderData } from '../api/bundle-header-data'\nimport { toDate } from '../util/to-date'\n\nexport class BundleHeader {\n /**\n * Name of the fork this bundle contains data for.\n */\n readonly name: string\n\n /**\n * Version number for this data package.\n */\n readonly version: string\n\n /**\n * The time this bundle was last updated.\n */\n readonly lastUpdateTime: Date\n\n /**\n * Description of the fork.\n */\n readonly description?: MarkdownString\n\n /**\n * Url for the repository where the bundle is maintained.\n */\n readonly repositoryUrl?: string\n\n /**\n * Url for the location of the changelog.\n */\n readonly changelogUrl?: string\n\n /**\n * List of external links. Wiki, forums, etc.\n */\n readonly links?: Link[]\n\n constructor(data: BundleHeaderData) {\n if (!data) throw new Error('Missing header data')\n this.name = data.name\n this.version = data.version\n this.lastUpdateTime = toDate(data.lastUpdateTime)\n this.description = data?.description\n this.repositoryUrl = data?.repositoryUrl\n this.changelogUrl = data?.changelogUrl\n this.links = data?.links ?? []\n }\n}\n","import { LevelRangeData } from '../api/level-range-data'\n\nexport class LevelRange {\n readonly min: number\n readonly max?: number\n\n constructor(value: LevelRangeData) {\n if (Array.isArray(value)) {\n this.min = value[0]\n this.max = value[1] === undefined ? undefined : value[1]\n } else {\n this.min = value\n }\n }\n}\n","import { Link } from '../api/link'\nimport { ZoneData } from '../api/zone-data'\nimport { Key } from './key'\nimport { MoralityList } from './morality-list'\nimport { coalesceToArray } from '../util/coalesce-to-array'\nimport { ZoneType } from '../api/zone-type'\nimport { MarkdownString } from '../api/markdown-string'\nimport { LevelRange } from './level-range'\n\nexport class Zone {\n /**\n * Unique key used to reference this zone.\n *\n * Keys must be unique and can only contain lowercase letters, numbers and hyphens (`-`).\n */\n readonly key: string\n\n /**\n * The name of the zone as it appears in-game.\n */\n readonly name: string\n\n /**\n * The type of zone.\n */\n readonly type: ZoneType\n\n /**\n * The character moralities that this zone is accessible by.\n */\n readonly morality: MoralityList\n\n /**\n * The level range this zone is recommended for.\n */\n readonly levelRange?: LevelRange\n\n /**\n * Freeform notes or tips about the zone.\n */\n readonly notes?: MarkdownString\n\n /**\n * List of external links. Wiki, forums, etc.\n */\n readonly links: Link[]\n\n constructor(data: ZoneData) {\n this.key = new Key(data.key).value\n this.name = data.name\n this.type = data.type\n this.morality = new MoralityList(coalesceToArray(data.morality))\n this.levelRange = data.levelRange ? new LevelRange(data.levelRange) : undefined\n this.notes = data.notes\n this.links = data.links ?? []\n }\n}\n","import { Link } from '../api/link'\nimport { Key } from './key'\nimport { MarkdownString } from '../api/markdown-string'\nimport { ContactData } from '../api/contact-data'\nimport { Location } from './location'\nimport { MoralityList } from './morality-list'\nimport { coalesceToArray } from '../util/coalesce-to-array'\nimport { LevelRange } from './level-range'\n\nexport class Contact {\n /**\n * Unique key used to reference this contact.\n *\n * Keys must be unique and can only contain lowercase letters, numbers and hyphens (`-`).\n */\n readonly key: string\n\n /**\n * The name of this contact.\n */\n readonly name: string\n\n /**\n * The contact's title.\n */\n readonly title?: string\n\n /**\n * The character moralities that this contact will interact with.\n */\n readonly morality: MoralityList\n\n /**\n * The location of this contact.\n */\n readonly location?: Location\n\n /**\n * The level range this contact will offer missions for.\n */\n readonly levelRange?: LevelRange\n\n /**\n * Freeform notes or tips about the contact.\n */\n readonly notes?: MarkdownString\n\n /**\n * List of external links. Wiki, forums, etc.\n */\n readonly links: Link[]\n\n constructor(data: ContactData) {\n this.key = new Key(data.key).value\n this.name = data.name\n this.title = data.title\n this.morality = new MoralityList(coalesceToArray(data.morality))\n this.location = data.location\n this.levelRange = data.levelRange ? new LevelRange(data.levelRange) : undefined\n this.notes = data.notes\n this.links = data.links ?? []\n }\n}\n","import { MissionType } from '../api/mission-type'\nimport { MarkdownString } from '../api/markdown-string'\nimport { Link } from '../api/link'\nimport { MissionData } from '../api/mission-data'\nimport { Key } from './key'\nimport { MoralityList } from './morality-list'\nimport { coalesceToArray } from '../util/coalesce-to-array'\nimport { LevelRange } from './level-range'\n\nexport class Mission {\n /**\n * Unique key used to reference this mission.\n *\n * Keys must be unique and can only contain lowercase letters, numbers and hyphens (`-`).\n */\n readonly key: string\n\n /**\n * The name of the mission as it appears from the contact.\n *\n * The name may be different when viewed in Ouroboros as a Flashback.\n */\n readonly name: string\n\n /**\n * The type of mission... Story arc, task force, trial, etc.\n */\n readonly type: MissionType\n\n /**\n * The character moralities that may accept the mission.\n */\n readonly morality: MoralityList\n\n /**\n * The keys of any contacts that provide this mission.\n */\n readonly contactKeys?: string[]\n\n /**\n * The level range this mission is available for.\n */\n readonly levelRange?: LevelRange\n\n /**\n * Freeform notes or tips about the mission.\n */\n readonly notes?: MarkdownString\n\n /**\n * List of external links. Wiki, forums, etc.\n */\n readonly links: Link[]\n\n /**\n * If the mission is available in Ouroboros as a Flashback.\n */\n readonly flashback?: {\n\n /**\n * The id of the mission as seen in the Flashback menu, i.e. '14.01'.\n */\n readonly id: string\n\n /**\n * The level range this mission appears under as a Flashback.\n */\n readonly levelRange?: LevelRange\n\n /**\n * The name as it appears in the Flashback list.\n */\n readonly name: string\n\n /**\n * The character moralities that the mission will appear for in the Flashback list.\n */\n readonly morality: MoralityList\n\n /**\n * Freeform notes or tips about the Flashback version of the mission.\n */\n readonly notes?: MarkdownString\n }\n\n constructor(data: MissionData) {\n this.key = new Key(data.key).value\n this.name = data.name\n this.type = data.type\n this.morality = new MoralityList(coalesceToArray(data.morality))\n this.contactKeys = coalesceToArray(data.contactKeys)\n this.levelRange = data.levelRange ? new LevelRange(data.levelRange) : undefined\n this.notes = data.notes\n this.links = data.links ?? []\n this.flashback = createFlashback(data)\n }\n}\n\nfunction createFlashback(data: MissionData): Mission['flashback'] {\n if (!data.flashback) return undefined\n return {\n id: data.flashback.id,\n levelRange: data.flashback.levelRange ? new LevelRange(data.flashback.levelRange) : undefined,\n name: data.flashback.name ?? data.name,\n morality: new MoralityList(coalesceToArray(data.flashback.morality ?? data.morality)),\n notes: data.flashback.notes,\n }\n}\n","import { BundleData } from '../api/bundle-data'\nimport { Archetype } from './archetype'\nimport { Zone } from './zone'\nimport { Badge } from './badge'\nimport { BundleHeader } from './bundle-header'\nimport { BadgeSearchOptions } from './badge-search-options'\nimport { Paged } from './paged'\nimport { Contact } from './contact'\nimport { Mission } from './mission'\nimport { AbstractIndex } from './abstract-index'\nimport { BadgeIndex } from './badge-index'\n\nexport class CohContentDatabase {\n readonly #archetypeIndex\n readonly #zoneIndex\n readonly #contactIndex\n readonly #missionIndex\n readonly #badgeIndex\n\n readonly #header: BundleHeader\n readonly #servers: string[]\n\n /**\n * Create a db instance from the given content bundle.\n * @param bundle The bundle to load.\n */\n constructor(bundle: BundleData) {\n this.#header = new BundleHeader(bundle.header)\n this.#servers = bundle.servers ?? []\n\n this.#archetypeIndex = new AbstractIndex<Archetype>('key', bundle.archetypes?.map(x => new Archetype(x)))\n this.#zoneIndex = new AbstractIndex<Zone>('key', bundle.zones?.map(x => new Zone(x)))\n this.#contactIndex = new AbstractIndex<Contact>('key', bundle.contacts?.map(x => new Contact(x)))\n this.#missionIndex = new AbstractIndex<Mission>('key', bundle.missions?.map(x => new Mission(x)))\n this.#badgeIndex = new BadgeIndex(bundle.badges?.map(x => new Badge(x)))\n }\n\n /**\n * Header information about the content bundle.\n */\n get header(): BundleHeader {\n return this.#header\n }\n\n /**\n * List of the game server names.\n *\n * Torchbearer, Excelsior, etc.\n */\n get servers(): string[] {\n return this.#servers\n }\n\n /**\n * List of archetypes.\n */\n get archetypes(): Archetype[] {\n return this.#archetypeIndex.values\n }\n\n /**\n * Get archetype by key.\n * @param key The key.\n */\n getArchetype(key: string | undefined): Archetype | undefined {\n return this.#archetypeIndex.get(key)\n }\n\n /**\n * List of game zones.\n */\n get zones(): Zone[] {\n return this.#zoneIndex.values\n }\n\n /**\n * Get zone by key.\n * @param key The key.\n */\n getZone(key: string | undefined): Zone | undefined {\n return this.#zoneIndex.get(key)\n }\n\n /**\n * List of contacts.\n */\n get contacts(): Contact[] {\n return this.#contactIndex.values\n }\n\n /**\n * Get contact by key.\n * @param key The key.\n */\n getContact(key: string | undefined): Contact | undefined {\n return this.#contactIndex.get(key)\n }\n\n /**\n * List of missions.\n */\n get missions(): Mission[] {\n return this.#missionIndex.values\n }\n\n /**\n * Get mission by key.\n * @param key The key.\n */\n getMission(key: string | undefined): Mission | undefined {\n return this.#missionIndex.get(key)\n }\n\n /**\n * List of badges.\n */\n get badges(): Badge[] {\n return this.#badgeIndex.values\n }\n\n /**\n * Get badge by key.\n * @param key The key.\n */\n getBadge(key: string | undefined): Badge | undefined {\n return this.#badgeIndex.get(key)\n }\n\n /**\n * Search, sort and filter the badge list.\n * This is a fairly brute-forced approach and will not be as performant as loading the badge data into a traditional\n * database engine, but is sufficient for most operations.\n * @param options {@link BadgeSearchOptions}\n */\n searchBadges(options?: BadgeSearchOptions): Paged<Badge> {\n return this.#badgeIndex.search(options)\n }\n}\n","import { Coords, LocationData, LocationIcon } from '../api/location-data'\n\nexport class Location {\n /**\n * Key of the {@link Zone} that the location references.\n */\n readonly zoneKey?: string\n\n /**\n * In-game `/loc` coordinates of the location.\n */\n readonly coords?: Coords\n\n /**\n * The type of icon to use if the location appears on a map. (Typically the Vidiot map icon).\n */\n readonly icon?: LocationIcon\n\n /**\n * The text that should appear in the location icon. (Typically a number or symbol from the Vidiot map).\n */\n readonly iconText?: string\n\n constructor(data: LocationData) {\n this.zoneKey = data.zoneKey\n this.coords = data.coords\n this.icon = data.icon\n this.iconText = data.iconText\n }\n}\n","import { BadgeData } from '../api/badge-data'\nimport { Badge } from '../db/badge'\nimport { ZoneData } from '../api/zone-data'\nimport { Zone } from '../db/zone'\nimport { Contact } from '../db/contact'\nimport { ContactData } from '../api/contact-data'\nimport { Mission } from '../db/mission'\nimport { MissionData } from '../api/mission-data'\n\n/**\n * Returns the URI of the given badge that can be used in {@link MarkdownString} fields.\n *\n * URI format: `badge://<key>`\n *\n * @param target The badge or badge key to target.\n */\nexport function badgeUri(target: string | Badge | BadgeData): string {\n const key = typeof target === 'string' ? target : target.key\n return `badge://${key}`\n}\n\n/**\n * Returns a {@link MarkdownString} link to the given badge.\n *\n * Link format: `[<key>](badge://<key>)`\n *\n * @param target The {@link Badge} or badge key to target.\n */\nexport function badgeLink(target: string | Badge | BadgeData): string {\n const key = typeof target === 'string' ? target : target.key\n return `[${key}](${badgeUri(target)})`\n}\n\n/**\n * Returns the URI of the given contact that can be used in {@link MarkdownString} fields.\n *\n * URI format: `contact://<key>`\n *\n * @param target The {@link Contact} or contact key to target.\n */\nexport function contactUri(target: string | Contact | ContactData): string {\n const key = typeof target === 'string' ? target : target.key\n return `contact://${key}`\n}\n\n/**\n * Returns a {@link MarkdownString} link to the given contact.\n *\n * Link format: `[<key>](contact://<key>)`\n *\n * @param target The {@link Contact} or contact key to target.\n */\nexport function contactLink(target: string | Contact | ContactData): string {\n const key = typeof target === 'string' ? target : target.key\n return `[${key}](${contactUri(target)})`\n}\n\n/**\n * Returns the URI of the given mission that can be used in {@link MarkdownString} fields.\n *\n * URI format: `mission://<key>`\n *\n * @param target The {@link Mission} or mission key to target.\n */\nexport function missionUri(target: string | Mission | MissionData): string {\n const key = typeof target === 'string' ? target : target.key\n return `mission://${key}`\n}\n\n/**\n * Returns a {@link MarkdownString} link to the given mission.\n *\n * Link format: `[<key>](mission://<key>)`\n *\n * @param target The {@link Mission} or mission key to target.\n */\nexport function missionLink(target: string | Mission | MissionData): string {\n const key = typeof target === 'string' ? target : target.key\n return `[${key}](${missionUri(target)})`\n}\n\n/**\n * Returns the URI of the given zone that can be used in {@link MarkdownString} fields.\n *\n * URI format: `zone://<key>`\n *\n * @param target The {@link Zone} or zone key to target.\n */\nexport function zoneUri(target: string | Zone | ZoneData): string {\n const key = typeof target === 'string' ? target : target.key\n return `zone://${key}`\n}\n\n/**\n * Returns a {@link MarkdownString} link to the given zone.\n *\n * Link format: `[<key>](zone://<key>)`\n *\n * @param target The {@link Zone} or zone key to target.\n */\nexport function zoneLink(target: string | Zone | ZoneData): string {\n const key = typeof target === 'string' ? target : target.key\n return `[${key}](${zoneUri(target)})`\n}\n"],"names":["_items","__privateAdd","__publicField","__privateSet","__privateGet","__privateMethod"],"mappings":"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"}
package/jest.config.mjs CHANGED
@@ -4,4 +4,5 @@ export default {
4
4
  transform: {
5
5
  '^.+.tsx?$': ['ts-jest', {}],
6
6
  },
7
+ coverageReporters: ['clover', 'json', 'lcov', 'text', 'text-summary'],
7
8
  }
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "coh-content-db",
3
- "version": "2.0.0-rc.8",
3
+ "version": "2.0.0",
4
4
  "description": "City of Heroes Content Database",
5
5
  "homepage": "https://github.com/n15g/coh-content-db#readme",
6
6
  "bugs": {
@@ -23,20 +23,20 @@
23
23
  "watch": "rollup --config --watch"
24
24
  },
25
25
  "devDependencies": {
26
- "@stylistic/eslint-plugin": "^3.1.0",
27
- "@stylistic/eslint-plugin-ts": "^3.1.0",
28
- "@types/jest": "^29.5.14",
26
+ "@stylistic/eslint-plugin": "^5.6.1",
27
+ "@stylistic/eslint-plugin-ts": "^4.4.1",
28
+ "@types/jest": "^30.0.0",
29
29
  "efate": "^1.5.1",
30
- "eslint": "^9.20.0",
31
- "eslint-plugin-unicorn": "^56.0.1",
32
- "globals": "^15.14.0",
33
- "jest": "^29.7.0",
34
- "rollup": "^4.34.6",
35
- "rollup-plugin-dts": "^6.1.1",
36
- "rollup-plugin-esbuild": "^6.2.0",
37
- "ts-jest": "^29.2.5",
38
- "typescript": "^5.7.3",
39
- "typescript-eslint": "^8.24.0"
30
+ "eslint": "^9.39.1",
31
+ "eslint-plugin-unicorn": "^62.0.0",
32
+ "globals": "^16.5.0",
33
+ "jest": "^30.2.0",
34
+ "rollup": "^4.53.3",
35
+ "rollup-plugin-dts": "^6.2.3",
36
+ "rollup-plugin-esbuild": "^6.2.1",
37
+ "ts-jest": "^29.4.5",
38
+ "typescript": "^5.9.3",
39
+ "typescript-eslint": "^8.48.0"
40
40
  },
41
41
  "engines": {
42
42
  "node": ">=22"
@@ -1,9 +1,10 @@
1
1
  import { BadgeRequirementData } from './badge-requirement-data'
2
2
  import { Link } from './link'
3
3
  import { BadgeType } from './badge-type'
4
- import { AlternateData } from './alternate-data'
4
+ import { VariantData } from './variant-data'
5
5
  import { MarkdownString } from './markdown-string'
6
6
  import { MoralityExtended } from './morality'
7
+ import { SetTitleData } from './set-title-data'
7
8
 
8
9
  export interface BadgeData {
9
10
 
@@ -22,9 +23,14 @@ export interface BadgeData {
22
23
  /**
23
24
  * The name of this badge.
24
25
  *
25
- * If the value differs by sex or alignment, include an {@link AlternateData} for each variant.
26
+ * If the value differs by sex or alignment, include an {@link VariantData} for each variant.
26
27
  */
27
- readonly name: string | AlternateData<string>[]
28
+ readonly name: string | VariantData<string>[]
29
+
30
+ /**
31
+ * The date that the badge was added to the game.
32
+ */
33
+ readonly releaseDate: string
28
34
 
29
35
  /**
30
36
  * The {@link MoralityExtended|moralities} that this badge is available to. If undefined then all moralities will be assumed.
@@ -34,7 +40,7 @@ export interface BadgeData {
34
40
  /**
35
41
  * The badge text as it appears in-game. May vary by character sex or alignment.
36
42
  */
37
- readonly badgeText?: AlternateData<MarkdownString>[] | MarkdownString
43
+ readonly badgeText?: VariantData<MarkdownString>[] | MarkdownString
38
44
 
39
45
  /**
40
46
  * Short description of how to acquire the badge. Detailed instructions should go in the notes field.
@@ -44,9 +50,9 @@ export interface BadgeData {
44
50
  /**
45
51
  * List of absolute URLs for this badge's icons.
46
52
  *
47
- * If the value differs by sex or alignment, include an {@link AlternateData} for each variant.
53
+ * If the value differs by sex or alignment, include an {@link VariantData} for each variant.
48
54
  */
49
- readonly icon?: string | AlternateData<string>[]
55
+ readonly icon?: string | VariantData<string>[]
50
56
 
51
57
  /**
52
58
  * Freeform notes or tips about the badge.
@@ -62,7 +68,7 @@ export interface BadgeData {
62
68
  * The id used with the in-game `/settitle` command to apply the badge.
63
69
  * The first value is the id for primal characters and the (optional) second number is the id for praetorian characters.
64
70
  */
65
- readonly setTitleId?: [number, number?]
71
+ readonly setTitleId?: SetTitleData
66
72
 
67
73
  /**
68
74
  * A description of the effect the badge will have, such as a buff or granting a temporary power.
@@ -1,35 +1,18 @@
1
1
  import { ArchetypeData } from './archetype-data'
2
2
  import { ZoneData } from './zone-data'
3
3
  import { BadgeData } from './badge-data'
4
- import { Change } from './change'
5
- import { Link } from './link'
6
- import { MarkdownString } from './markdown-string'
7
4
  import { ContactData } from './contact-data'
8
5
  import { MissionData } from './mission-data'
6
+ import { BundleHeaderData } from './bundle-header-data'
9
7
 
10
8
  /**
11
- * A content bundle holds the data that makes up one forked instance of the game since the original sunset, such as Homecoming (https://forums.homecomingservers.com/).
9
+ * A bundle of game data from a forked instance of the game, such as Homecoming (https://forums.homecomingservers.com/).
12
10
  */
13
- export interface ContentBundle {
11
+ export interface BundleData {
14
12
  /**
15
- * Name of the fork this bundle contains data for.
13
+ * Bundle header.
16
14
  */
17
- readonly name: string
18
-
19
- /**
20
- * Description of the fork.
21
- */
22
- readonly description?: MarkdownString
23
-
24
- /**
25
- * Repository where the db content package is maintained.
26
- */
27
- readonly repository?: string
28
-
29
- /**
30
- * List of external links. Wiki, forums, etc.
31
- */
32
- readonly links?: Link[]
15
+ readonly header: BundleHeaderData
33
16
 
34
17
  /**
35
18
  * List of the game server names in this fork.
@@ -61,9 +44,4 @@ export interface ContentBundle {
61
44
  * List of badges available on this fork.
62
45
  */
63
46
  readonly badges?: BadgeData[]
64
-
65
- /**
66
- * Change log for this data package.
67
- */
68
- readonly changelog?: Change[]
69
47
  }
@@ -0,0 +1,44 @@
1
+ import { Link } from './link'
2
+ import { MarkdownString } from './markdown-string'
3
+
4
+ /**
5
+ * Metadata about a content bundle.
6
+ */
7
+ export interface BundleHeaderData {
8
+ /**
9
+ * Name of the fork this bundle contains data for.
10
+ */
11
+ readonly name: string
12
+
13
+ /**
14
+ * Version number for this data package.
15
+ */
16
+ readonly version: string
17
+
18
+ /**
19
+ * The time this bundle was last updated.
20
+ *
21
+ * Must be an ISO-8601 string in UTC.
22
+ */
23
+ readonly lastUpdateTime: string
24
+
25
+ /**
26
+ * Description of the fork.
27
+ */
28
+ readonly description?: MarkdownString
29
+
30
+ /**
31
+ * Url for the repository where the bundle is maintained.
32
+ */
33
+ readonly repositoryUrl?: string
34
+
35
+ /**
36
+ * Url for the location of the changelog.
37
+ */
38
+ readonly changelogUrl?: string
39
+
40
+ /**
41
+ * List of external links. Wiki, forums, etc.
42
+ */
43
+ readonly links?: Link[]
44
+ }
@@ -2,6 +2,7 @@ import { Link } from './link'
2
2
  import { MarkdownString } from './markdown-string'
3
3
  import { LocationData } from './location-data'
4
4
  import { MoralityExtended } from './morality'
5
+ import { LevelRangeData } from './level-range-data'
5
6
 
6
7
  export interface ContactData {
7
8
  /**
@@ -34,7 +35,7 @@ export interface ContactData {
34
35
  /**
35
36
  * The level range this contact will offer missions for.
36
37
  */
37
- readonly levelRange?: [number, number?]
38
+ readonly levelRange?: LevelRangeData
38
39
 
39
40
  /**
40
41
  * Freeform notes or tips about the contact.
@@ -0,0 +1,4 @@
1
+ /**
2
+ * Can be an array of [min, max], just the [min], or a number representing the minimum value
3
+ */
4
+ export type LevelRangeData = [number, number?] | number