Type anys

This commit is contained in:
Adria Navarro 2024-12-30 13:05:27 +01:00
parent ed30e51733
commit d728b9f25a
3 changed files with 31 additions and 10 deletions

View File

@ -1,14 +1,19 @@
import { writable, get, Writable, Readable } from "svelte/store" import { writable, get, Writable, Readable } from "svelte/store"
import { derivedMemo, QueryUtils } from "../../../utils" import { derivedMemo, QueryUtils } from "../../../utils"
import { FieldType, EmptyFilterOption } from "@budibase/types" import {
FieldType,
EmptyFilterOption,
UIRow,
UICondition,
} from "@budibase/types"
import { Store as StoreContext } from "." import { Store as StoreContext } from "."
interface ConditionStore { interface ConditionStore {
metadata: Writable<any> metadata: Writable<Record<string, any>>
} }
interface ConditionDerivedStore { interface ConditionDerivedStore {
conditions: Readable<any> conditions: Readable<UICondition[]>
} }
export type Store = ConditionStore & ConditionDerivedStore export type Store = ConditionStore & ConditionDerivedStore
@ -49,7 +54,7 @@ export const initialise = (context: StoreContext) => {
// Recompute all metadata if conditions change // Recompute all metadata if conditions change
conditions.subscribe($conditions => { conditions.subscribe($conditions => {
let newMetadata = {} let newMetadata: Record<string, any> = {}
if ($conditions?.length) { if ($conditions?.length) {
for (let row of get(rows)) { for (let row of get(rows)) {
newMetadata[row._id] = evaluateConditions(row, $conditions) newMetadata[row._id] = evaluateConditions(row, $conditions)
@ -65,7 +70,7 @@ export const initialise = (context: StoreContext) => {
return return
} }
const $metadata = get(metadata) const $metadata = get(metadata)
let metadataUpdates = {} let metadataUpdates: Record<string, any> = {}
for (let row of $rows) { for (let row of $rows) {
if (!row._rev || $metadata[row._id]?.version !== row._rev) { if (!row._rev || $metadata[row._id]?.version !== row._rev) {
metadataUpdates[row._id] = evaluateConditions(row, $conditions) metadataUpdates[row._id] = evaluateConditions(row, $conditions)
@ -80,15 +85,15 @@ export const initialise = (context: StoreContext) => {
}) })
} }
const TypeCoercionMap = { const TypeCoercionMap: Partial<Record<FieldType, (val: string) => any>> = {
[FieldType.NUMBER]: parseFloat, [FieldType.NUMBER]: parseFloat,
[FieldType.DATETIME]: val => { [FieldType.DATETIME]: (val: string) => {
if (val) { if (val) {
return new Date(val).toISOString() return new Date(val).toISOString()
} }
return null return null
}, },
[FieldType.BOOLEAN]: val => { [FieldType.BOOLEAN]: (val: string) => {
if (`${val}`.toLowerCase().trim() === "true") { if (`${val}`.toLowerCase().trim() === "true") {
return true return true
} }
@ -101,8 +106,12 @@ const TypeCoercionMap = {
// Evaluates an array of cell conditions against a certain row and returns the // Evaluates an array of cell conditions against a certain row and returns the
// resultant metadata // resultant metadata
const evaluateConditions = (row, conditions) => { const evaluateConditions = (row: UIRow, conditions: UICondition[]) => {
let metadata = { const metadata: {
version?: string
row: Record<string, string>
cell: Record<string, any>
} = {
version: row._rev, version: row._rev,
row: {}, row: {},
cell: {}, cell: {},

View File

@ -0,0 +1,11 @@
import { FieldType, SearchFilter } from "@budibase/types"
export interface UICondition {
column: string
type: FieldType
referenceValue: string
operator: SearchFilter["operator"]
metadataKey: string
metadataValue: string
target: string
}

View File

@ -1,4 +1,5 @@
export * from "./columns" export * from "./columns"
export * from "./condition"
export * from "./datasource" export * from "./datasource"
export * from "./table" export * from "./table"
export * from "./view" export * from "./view"