Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Findspot display #404

Merged
merged 43 commits into from
Nov 8, 2023
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
Show all changes
43 commits
Select commit Hold shift + click to select a range
9386b38
add DateRange interface
fsimonjetz Nov 2, 2023
7fb575a
implement Findspot interface
fsimonjetz Nov 2, 2023
8473576
use lodash capitalize
fsimonjetz Nov 2, 2023
8c89069
prepare findspot class display
fsimonjetz Nov 2, 2023
9aa9dc7
update schema with findspot id
fsimonjetz Nov 2, 2023
5f4ba5c
Merge branch 'master' into findspot-display
fsimonjetz Nov 3, 2023
02f6a82
pass findspotService through app
fsimonjetz Nov 3, 2023
541cbf9
add FindspotService
fsimonjetz Nov 3, 2023
ea65719
refactor findspot from dto
fsimonjetz Nov 3, 2023
edcca30
add findspot route
fsimonjetz Nov 3, 2023
114219b
remove debug log
fsimonjetz Nov 3, 2023
88fb0ea
wrap ArchaeologyEditor in withData
fsimonjetz Nov 3, 2023
03945a2
add updateFindspot and renderFindspot
fsimonjetz Nov 3, 2023
8c6e44d
add findspotServiceMock
fsimonjetz Nov 3, 2023
ea9c1c4
add findspotFactory
fsimonjetz Nov 3, 2023
8cfa98f
update object dto conversions
fsimonjetz Nov 6, 2023
1346f57
update tests
fsimonjetz Nov 6, 2023
3f75e18
extend dto transformation functions
fsimonjetz Nov 6, 2023
3bedff3
extend findspot factories
fsimonjetz Nov 6, 2023
9fccb15
add tests for dto functions
fsimonjetz Nov 6, 2023
3b0f68b
change date datatype
fsimonjetz Nov 6, 2023
e98d2b0
new date display logic
fsimonjetz Nov 6, 2023
23a6f61
refactoring, bug fixes
fsimonjetz Nov 7, 2023
a7516c4
add findspot display tests
fsimonjetz Nov 7, 2023
64302a4
add helper functions, refactor
fsimonjetz Nov 7, 2023
2241ac5
better levelLayer mock
fsimonjetz Nov 7, 2023
52e3874
better levelLayer mock
fsimonjetz Nov 7, 2023
5b70f2b
Merge branch 'findspot-display' of https://github.com/ElectronicBabyl…
fsimonjetz Nov 7, 2023
8084c44
add findspotService mocks
fsimonjetz Nov 7, 2023
e97aee9
refactor JsonApiClient
fsimonjetz Nov 7, 2023
5dff10a
refactor type
fsimonjetz Nov 7, 2023
7ff4780
make site optional
fsimonjetz Nov 7, 2023
ec71fef
add FindspotService test
fsimonjetz Nov 7, 2023
3f9d53e
extract FindspotRepository
fsimonjetz Nov 7, 2023
5cce710
fix typo
fsimonjetz Nov 7, 2023
e7095ca
add FindspotRepository test
fsimonjetz Nov 7, 2023
a5365bd
refactoring
fsimonjetz Nov 7, 2023
42799fa
fix findspot update
fsimonjetz Nov 7, 2023
a6e3b76
add findspots selection test
fsimonjetz Nov 7, 2023
6db3785
shorter test values
fsimonjetz Nov 7, 2023
841bb4a
fix missing key
fsimonjetz Nov 7, 2023
ea8a5f3
longer test list
fsimonjetz Nov 8, 2023
00e332f
prevent double whitespace
fsimonjetz Nov 8, 2023
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
6 changes: 1 addition & 5 deletions src/corpus/ui/ChapterViewSideBar.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -8,10 +8,6 @@ import { ChapterDisplay } from 'corpus/domain/chapter'

import './ChapterViewSideBar.sass'

function capitalize(word: string): string {
return word[0].toUpperCase() + word.substring(1)
}

function Switch({
target,
label = '',
Expand All @@ -24,7 +20,7 @@ function Switch({
return (
<Form.Switch
className="settings__switch"
label={label || capitalize(target)}
label={label || _.capitalize(target)}
id={_.uniqueId('sidebar-text-toggle-')}
onClick={() => {
dispatchRows({ target: target, type: isExpanded ? 'close' : 'expand' })
Expand Down
22 changes: 22 additions & 0 deletions src/fragmentarium/application/FindspotService.test.ts
Original file line number Diff line number Diff line change
@@ -0,0 +1,22 @@
import { findspotFactory } from 'test-support/fragment-fixtures'
import { FindspotService } from './FindspotService'
import { testDelegation, TestData } from 'test-support/utils'

const findspotRepository = {
fetchFindspots: jest.fn(),
}
const findspotService = new FindspotService(findspotRepository)
const expectedFindspots = findspotFactory.buildList(3)

const testData: TestData<FindspotService>[] = [
new TestData(
'fetchFindspots',
[],
findspotRepository.fetchFindspots,
expectedFindspots,
null,
Promise.resolve(expectedFindspots)
),
]

testDelegation(findspotService, testData)
11 changes: 11 additions & 0 deletions src/fragmentarium/application/FindspotService.ts
Original file line number Diff line number Diff line change
@@ -0,0 +1,11 @@
import Bluebird from 'bluebird'
import { Findspot } from 'fragmentarium/domain/archaeology'
import { FindspotRepository } from 'fragmentarium/infrastructure/FindspotRepository'

export class FindspotService {
constructor(private readonly findspotRepository: FindspotRepository) {}

fetchFindspots(): Bluebird<Findspot[]> {
return this.findspotRepository.fetchFindspots()
}
}
5 changes: 5 additions & 0 deletions src/fragmentarium/domain/Date.ts
Original file line number Diff line number Diff line change
Expand Up @@ -12,6 +12,11 @@ export interface DateField {
isUncertain?: boolean
}

export interface DateRange {
start: Date
end: Date
}

export interface MonthField extends DateField {
isIntercalary?: boolean
}
Expand Down
144 changes: 137 additions & 7 deletions src/fragmentarium/domain/archaeology.test.ts
Original file line number Diff line number Diff line change
@@ -1,28 +1,158 @@
import { archaeologyFactory } from 'test-support/fragment-fixtures'
import { SiteKey, createArchaeology, toArchaeologyDto } from './archaeology'
import _ from 'lodash'
import {
archaeologyFactory,
dateRangeFactory,
findspotFactory,
} from 'test-support/fragment-fixtures'
import {
BuildingType,
Findspot,
FindspotDto,
SiteKey,
createArchaeology,
excavationSites,
fromFindspotDto,
fromPlanDto,
toArchaeologyDto,
toFindspotDto,
toPlanDto,
} from './archaeology'
import MuseumNumber, { museumNumberToString } from './MuseumNumber'
import {
cslDataFactory,
referenceDtoFactory,
} from 'test-support/bibliography-fixtures'
import createReference from 'bibliography/application/createReference'

const excavationNumber: MuseumNumber = {
prefix: 'A',
number: '38',
suffix: '',
}
const archaeology = archaeologyFactory.build({
excavationNumber: museumNumberToString(excavationNumber),
const site: SiteKey = 'Assyria'

const cslData = cslDataFactory.build()
const referenceDto = referenceDtoFactory.build(
{ id: cslData.id },
{ associations: { document: cslData } }
)
const reference = createReference(referenceDto)
const planDto = {
svg: '<svg></svg>',
references: [referenceDto],
}
const plan = { svg: '<svg></svg>', references: [reference] }
const dateRange = dateRangeFactory.build()
const findspot = findspotFactory.build({
site: excavationSites[site],
dateRange: dateRange,
plans: [plan],
})
const findspotDto: FindspotDto = {
..._.pick(
findspot,
'area',
'building',
'buildingType',
'levelLayerPhase',
'room',
'context',
'primaryContext',
'notes',
'dateRange'
),
_id: findspot.id,
site: site,
plans: [planDto],
}
const displayParams: Partial<Findspot> = {
area: '',
building: 'a house',
buildingType: 'RESIDENTIAL' as BuildingType,
levelLayerPhase: 'II',
dateRange: {
start: -1200,
end: -1150,
notes: '',
},
notes: '',
}
const archaeology = archaeologyFactory.build(
{
excavationNumber: museumNumberToString(excavationNumber),
},
{
associations: {
findspot,
},
}
)

test('fromPlanDto', () => {
expect(fromPlanDto(planDto)).toEqual(plan)
})
test('toPlanDto', () => {
expect(toPlanDto(plan)).toEqual(planDto)
})
test('fromFindspotDto', () => {
expect(fromFindspotDto(findspotDto)).toEqual(findspot)
})
test('toFindspotDto', () => {
expect(toFindspotDto(findspot)).toEqual(findspotDto)
})
test('fromPlanDto', () => {
expect(fromPlanDto(planDto)).toEqual(plan)
})
test('toArchaeologyDto', () => {
expect(toArchaeologyDto(archaeology)).toEqual({
...archaeology,
site: archaeology.site?.name,
findspot: archaeology.findspot ? toFindspotDto(archaeology.findspot) : null,
})
})
test('createArchaeology', () => {
expect(
createArchaeology({
...archaeology,
excavationNumber: excavationNumber,
site: (archaeology.site?.name || '') as SiteKey,
...toArchaeologyDto(archaeology),
excavationNumber,
})
).toEqual(archaeology)
})
test.each([
[
'with area and notes',
{ ...displayParams, area: 'some area', notes: 'general notes' },
'some area > a house (Residential), II (1200 BCE - 1150 BCE), general notes.',
],
[
'no area and notes',
{ ...displayParams, area: '' },
'a house (Residential), II (1200 BCE - 1150 BCE).',
],
[
'no notes',
{ ...displayParams, notes: '' },
'a house (Residential), II (1200 BCE - 1150 BCE).',
],
[
'no buildingType',
{ ...displayParams, buildingType: null },
'a house, II (1200 BCE - 1150 BCE).',
],
[
'no levelLayerPhase and date',
{ ...displayParams, levelLayerPhase: '', dateRange: null },
'a house (Residential).',
],
[
'with date notes',
{
...displayParams,
dateRange: { ...displayParams.dateRange, notes: 'date notes' },
},
'a house (Residential), II (1200 BCE - 1150 BCE, date notes).',
],
])('Correctly builds findspot info %s', (_info, params, expected) => {
const findspot = findspotFactory.build(params)
expect(findspot.toString()).toEqual(expected)
})
Loading
Loading