Skip to content

Commit

Permalink
Approximate dates patch (#394)
Browse files Browse the repository at this point in the history
* Patch approximate dates conversion
  • Loading branch information
khoidt authored Sep 23, 2023
1 parent 4b8347f commit 06aed0c
Show file tree
Hide file tree
Showing 2 changed files with 177 additions and 12 deletions.
99 changes: 99 additions & 0 deletions src/fragmentarium/domain/Date.test.ts
Original file line number Diff line number Diff line change
Expand Up @@ -31,6 +31,17 @@ const eponym = {
phase: 'NA',
} as Eponym

const nabonassarEraKing = {
orderGlobal: 172,
dynastyNumber: '14',
dynastyName: 'Persian Rulers',
orderInDynasty: '3',
name: 'Darius I',
date: '521–486',
totalOfYears: '36',
notes: '',
}

describe('MesopotamianDate', () => {
describe('converts from json', () => {
it('initializes from JSON', () => {
Expand Down Expand Up @@ -99,6 +110,94 @@ describe('MesopotamianDate', () => {
expect(date.toString()).toBe('12.V.10 SE (30 August 302 BCE)')
})

it('returns the correct string representation (Seleucid, no day)', () => {
const date = new MesopotamianDate(
{ value: '10' },
{ value: '5' },
{ value: '' },
undefined,
undefined,
true
)
expect(date.toString()).toBe('∅.V.10 SE (ca. 19 August 302 BCE)')
})

it('returns the correct string representation (Seleucid, no month)', () => {
const date = new MesopotamianDate(
{ value: '10' },
{ value: '' },
{ value: '12' },
undefined,
undefined,
true
)
expect(date.toString()).toBe('12.∅.10 SE (ca. 4 May 302 BCE)')
})

it('returns the correct string representation (Seleucid, no year)', () => {
const date = new MesopotamianDate(
{ value: '' },
{ value: '5' },
{ value: '12' },
undefined,
undefined,
true
)
expect(date.toString()).toBe('12.V.∅ SE')
})

it('returns the correct string representation (Nabonassar era)', () => {
const date = new MesopotamianDate(
{ value: '10' },
{ value: '5' },
{ value: '12' },
nabonassarEraKing,
undefined,
undefined,
false
)
expect(date.toString()).toBe('12.V.10 Darius I (11 August 512 BCE)')
})

it('returns the correct string representation (Nabonassar era, no year)', () => {
const date = new MesopotamianDate(
{ value: '10' },
{ value: '5' },
{ value: '' },
nabonassarEraKing,
undefined,
undefined,
false
)
expect(date.toString()).toBe('∅.V.10 Darius I (ca. 31 July 512 BCE)')
})

it('returns the correct string representation (Nabonassar era, no month)', () => {
const date = new MesopotamianDate(
{ value: '10' },
{ value: '' },
{ value: '12' },
nabonassarEraKing,
undefined,
undefined,
false
)
expect(date.toString()).toBe('12.∅.10 Darius I (ca. 16 April 512 BCE)')
})

it('returns the correct string representation (Nabonassar era, no day)', () => {
const date = new MesopotamianDate(
{ value: '10' },
{ value: '5' },
{ value: '' },
nabonassarEraKing,
undefined,
undefined,
false
)
expect(date.toString()).toBe('∅.V.10 Darius I (ca. 31 July 512 BCE)')
})

it('returns the correct string representation (Ur III)', () => {
const date = new MesopotamianDate(
{ value: '10' },
Expand Down
90 changes: 78 additions & 12 deletions src/fragmentarium/domain/Date.ts
Original file line number Diff line number Diff line change
Expand Up @@ -151,17 +151,20 @@ export class MesopotamianDate {
}

toModernDate(): string {
const year = parseInt(this.year.value)
const month = parseInt(this.month.value)
const day = parseInt(this.day.value)
const { year, month, day, isApproximate } = this.getDateApproximation()
let result = ''
if (this.isSeleucidEra) {
result = this.seleucidToModernDate(year, month, day)
if (this.isSeleucidEra && year > 0) {
result = this.seleucidToModernDate(year, month, day, isApproximate)
} else if (
this.king?.orderGlobal &&
Object.values(data.rulerToBrinkmanKings).includes(this.king?.orderGlobal)
) {
result = this.nabonassarEraToModernDate(year, month, day)
result = this.nabonassarEraToModernDate(
year > 0 ? year : 1,
month,
day,
isApproximate
)
} else if (this.isAssyrianDate && this.eponym?.date) {
result = `ca. ${this.eponym?.date} BCE`
} else if (this.king?.date) {
Expand All @@ -170,34 +173,97 @@ export class MesopotamianDate {
return result
}

private insertDateApproximation(
dateString: string,
isApproximate: boolean
): string {
return `${isApproximate ? 'ca. ' : ''}${dateString}`
}

private getDateApproximation(): {
year: number
month: number
day: number
isApproximate: boolean
} {
let year = parseInt(this.year.value)
let month = parseInt(this.month.value)
let day = parseInt(this.day.value)
const isApproximate = this.isApproximate()
if (isNaN(month) || this.month.isBroken) {
month = 1
}
if (isNaN(day) || this.day.isBroken) {
day = 1
}
if (isNaN(year) || this.year.isBroken) {
year = -1
}
return {
year,
month,
day,
isApproximate: isApproximate,
}
}

private isApproximate(): boolean {
return [
_.some(
[
parseInt(this.year.value),
parseInt(this.month.value),
parseInt(this.day.value),
],
_.isNaN
),
[
this.year.isBroken,
this.month.isBroken,
this.day.isBroken,
this.year.isUncertain,
this.month.isUncertain,
this.day.isUncertain,
].includes(true),
].includes(true)
}

private seleucidToModernDate(
year: number,
month: number,
day: number
day: number,
isApproximate: boolean
): string {
const converter = new DateConverter()
converter.setSeBabylonianDate(year, month, day)
return converter.toModernDateString()
return this.insertDateApproximation(
converter.toModernDateString(),
isApproximate
)
}

private nabonassarEraToModernDate(
year: number,
month: number,
day: number
day: number,
isApproximate: boolean
): string {
const kingName = Object.keys(data.rulerToBrinkmanKings).find(
(key) => data.rulerToBrinkmanKings[key] === this.king?.orderGlobal
)
if (kingName) {
const converter = new DateConverter()
converter.setMesopotamianDate(kingName, year, month, day)
return converter.toModernDateString()
return this.insertDateApproximation(
converter.toModernDateString(),
isApproximate
)
}
return ''
}
private kingToModernDate(year?: number): string {
private kingToModernDate(year: number): string {
const firstReignYear = this.king?.date?.split('-')[0]
return firstReignYear !== undefined && year && !this.year.isBroken
return firstReignYear !== undefined && year > 0
? `ca. ${parseInt(firstReignYear) - year + 1} BCE`
: this.king?.date && !['', '?'].includes(this.king?.date)
? `ca. ${this.king?.date} BCE`
Expand Down

0 comments on commit 06aed0c

Please sign in to comment.