Type validation

This commit is contained in:
Adria Navarro 2024-12-24 13:41:17 +01:00
parent 68eb809d28
commit f5ebc6b249
2 changed files with 24 additions and 10 deletions

View File

@ -60,7 +60,8 @@ export type Store = BaseStore &
Table.Store & Table.Store &
ViewV2.Store & ViewV2.Store &
NonPlus.Store & NonPlus.Store &
Datasource.Store & { Datasource.Store &
Validation.Store & {
// TODO while typing the rest of stores // TODO while typing the rest of stores
fetch: Writable<any> fetch: Writable<any>
filter: Writable<any> filter: Writable<any>
@ -76,6 +77,8 @@ export type Store = BaseStore &
dispatch: (event: string, data: any) => any dispatch: (event: string, data: any) => any
notifications: Writable<any> notifications: Writable<any>
schemaOverrides: Writable<any> schemaOverrides: Writable<any>
focusedCellId: Writable<any>
previousFocusedRowId: Writable<string>
} }
export const attachStores = (context: Store): Store => { export const attachStores = (context: Store): Store => {

View File

@ -1,10 +1,21 @@
import { writable, get, derived } from "svelte/store" import { writable, get, derived, Writable, Readable } from "svelte/store"
import { Store as StoreContext } from "."
import { parseCellID } from "../lib/utils" import { parseCellID } from "../lib/utils"
interface ValidationStore {
validation: Writable<Record<string, string>>
}
interface DerivedValidationStore {
validationRowLookupMap: Readable<Record<string, string[]>>
}
export type Store = ValidationStore & DerivedValidationStore
// Normally we would break out actions into the explicit "createActions" // Normally we would break out actions into the explicit "createActions"
// function, but for validation all these actions are pure so can go into // function, but for validation all these actions are pure so can go into
// "createStores" instead to make dependency ordering simpler // "createStores" instead to make dependency ordering simpler
export const createStores = () => { export const createStores = (): ValidationStore => {
const validation = writable({}) const validation = writable({})
return { return {
@ -12,12 +23,12 @@ export const createStores = () => {
} }
} }
export const deriveStores = context => { export const deriveStores = (context: StoreContext): DerivedValidationStore => {
const { validation } = context const { validation } = context
// Derive which rows have errors so that we can use that info later // Derive which rows have errors so that we can use that info later
const validationRowLookupMap = derived(validation, $validation => { const validationRowLookupMap = derived(validation, $validation => {
let map = {} const map: Record<string, string[]> = {}
Object.entries($validation).forEach(([key, error]) => { Object.entries($validation).forEach(([key, error]) => {
// Extract row ID from all errored cell IDs // Extract row ID from all errored cell IDs
if (error) { if (error) {
@ -36,10 +47,10 @@ export const deriveStores = context => {
} }
} }
export const createActions = context => { export const createActions = (context: StoreContext) => {
const { validation, focusedCellId, validationRowLookupMap } = context const { validation, focusedCellId, validationRowLookupMap } = context
const setError = (cellId, error) => { const setError = (cellId: string | undefined, error: string) => {
if (!cellId) { if (!cellId) {
return return
} }
@ -49,11 +60,11 @@ export const createActions = context => {
})) }))
} }
const rowHasErrors = rowId => { const rowHasErrors = (rowId: string) => {
return get(validationRowLookupMap)[rowId]?.length > 0 return get(validationRowLookupMap)[rowId]?.length > 0
} }
const focusFirstRowError = rowId => { const focusFirstRowError = (rowId: string) => {
const errorCells = get(validationRowLookupMap)[rowId] const errorCells = get(validationRowLookupMap)[rowId]
const cellId = errorCells?.[0] const cellId = errorCells?.[0]
if (cellId) { if (cellId) {
@ -73,7 +84,7 @@ export const createActions = context => {
} }
} }
export const initialise = context => { export const initialise = (context: StoreContext) => {
const { validation, previousFocusedRowId, validationRowLookupMap } = context const { validation, previousFocusedRowId, validationRowLookupMap } = context
// Remove validation errors when changing rows // Remove validation errors when changing rows