Skip to content

Commit

Permalink
Fix types
Browse files Browse the repository at this point in the history
  • Loading branch information
adrinr committed Dec 20, 2024
1 parent acc9da3 commit fc76f57
Show file tree
Hide file tree
Showing 2 changed files with 28 additions and 18 deletions.
12 changes: 6 additions & 6 deletions packages/frontend-core/src/components/grid/stores/columns.ts
Original file line number Diff line number Diff line change
Expand Up @@ -9,7 +9,7 @@ interface ColumnStore {

interface DerivedColumnStore {
tableColumns: Readable<Column[]>
displayColumn: Readable<Column>
displayColumn: Readable<Column | undefined>
columnLookupMap: Readable<Record<string, Column>>
visibleColumns: Readable<Column[]>
scrollableColumns: Readable<Column[]>
Expand Down Expand Up @@ -37,7 +37,7 @@ type Column = FieldSchema & {
}

export const createStores = (): ColumnStore => {
const columns = writable([])
const columns = writable<Column[]>([])

// Enrich columns with metadata about their display position
const enrichedColumns = derived(columns, $columns => {
Expand All @@ -51,7 +51,7 @@ export const createStores = (): ColumnStore => {
}
if (col.visible) {
idx++
offset += col.width
offset += col.width ?? 0
}
return enriched
})
Expand All @@ -70,7 +70,7 @@ export const deriveStores = (context: StoreContext): DerivedColumnStore => {

// Derive a lookup map for all columns by name
const columnLookupMap = derived(columns, $columns => {
let map = {}
let map: Record<string, Column> = {}
$columns.forEach(column => {
map[column.name] = column
})
Expand Down Expand Up @@ -164,7 +164,7 @@ export const initialise = (context: StoreContext) => {
const { definition, columns, displayColumn, enrichedSchema } = context

// Merge new schema fields with existing schema in order to preserve widths
const processColumns = $enrichedSchema => {
const processColumns = ($enrichedSchema: any) => {
if (!$enrichedSchema) {
columns.set([])
return
Expand All @@ -174,7 +174,7 @@ export const initialise = (context: StoreContext) => {
const $displayColumn = get(displayColumn)

// Find primary display
let primaryDisplay
let primaryDisplay: string
const candidatePD = $definition.primaryDisplay || $displayColumn?.name
if (candidatePD && $enrichedSchema[candidatePD]) {
primaryDisplay = candidatePD
Expand Down
34 changes: 22 additions & 12 deletions packages/frontend-core/src/components/grid/stores/index.ts
Original file line number Diff line number Diff line change
Expand Up @@ -50,33 +50,43 @@ const DependencyOrderedStores = [
Cache,
]

export type Store = Columns.Store & {
// TODO while typing the rest of stores
datasource: any
definition: Writable<any>
displayColumn: Writable<any>
enrichedSchema: any
}
export interface BaseStore {}

export type Store = BaseStore &
Columns.Store & {
// TODO while typing the rest of stores
datasource: any
definition: Writable<any>
enrichedSchema: any
}

export const attachStores = (context): Store => {
export const attachStores = (context: Store): Store => {
// Atomic store creation
for (let store of DependencyOrderedStores) {
context = { ...context, ...store.createStores?.(context) }
if ("createStores" in store) {
context = { ...context, ...store.createStores?.(context) }
}
}

// Derived store creation
for (let store of DependencyOrderedStores) {
context = { ...context, ...store.deriveStores?.(context) }
if ("deriveStores" in store) {
context = { ...context, ...store.deriveStores?.(context) }
}
}

// Action creation
for (let store of DependencyOrderedStores) {
context = { ...context, ...store.createActions?.(context) }
if ("createActions" in store) {
context = { ...context, ...store.createActions?.(context) }
}
}

// Initialise any store logic
for (let store of DependencyOrderedStores) {
store.initialise?.(context)
if ("initialise" in store) {
store.initialise?.(context)
}
}

return context
Expand Down

0 comments on commit fc76f57

Please sign in to comment.