From 26d1243e689b5c2a3c194efd83dd33d2af12a9a4 Mon Sep 17 00:00:00 2001 From: Adria Navarro Date: Mon, 23 Dec 2024 19:44:40 +0100 Subject: [PATCH] More typings --- .../src/components/grid/stores/datasource.ts | 25 ++++++++++++------- .../frontend-core/src/utils/relatedColumns.ts | 9 ++++++- .../types/src/ui/stores/grid/datasource.ts | 5 ++++ 3 files changed, 29 insertions(+), 10 deletions(-) diff --git a/packages/frontend-core/src/components/grid/stores/datasource.ts b/packages/frontend-core/src/components/grid/stores/datasource.ts index 0bda8b0d64..c969e05694 100644 --- a/packages/frontend-core/src/components/grid/stores/datasource.ts +++ b/packages/frontend-core/src/components/grid/stores/datasource.ts @@ -4,8 +4,11 @@ import { enrichSchemaWithRelColumns, memo } from "../../../utils" import { cloneDeep } from "lodash" import { FieldSchema, + Row, + SaveRowRequest, SaveTableRequest, UIDatasource, + UIFieldMutation, UIFieldSchema, UpdateViewRequest, ViewV2Type, @@ -211,7 +214,7 @@ export const createActions = (context: StoreContext): ActionDatasourceStore => { } // Updates the datasources primary display column - const changePrimaryDisplay = async column => { + const changePrimaryDisplay = async (column: string) => { let newDefinition = cloneDeep(get(definition)) // Update primary display @@ -227,7 +230,7 @@ export const createActions = (context: StoreContext): ActionDatasourceStore => { } // Adds a schema mutation for a single field - const addSchemaMutation = (field, mutation) => { + const addSchemaMutation = (field: string, mutation: UIFieldMutation) => { if (!field || !mutation) { return } @@ -243,7 +246,11 @@ export const createActions = (context: StoreContext): ActionDatasourceStore => { } // Adds a nested schema mutation for a single field - const addSubSchemaMutation = (field, fromField, mutation) => { + const addSubSchemaMutation = ( + field: string, + fromField: string, + mutation: UIFieldMutation + ) => { if (!field || !fromField || !mutation) { return } @@ -305,32 +312,32 @@ export const createActions = (context: StoreContext): ActionDatasourceStore => { } // Adds a row to the datasource - const addRow = async row => { + const addRow = async (row: SaveRowRequest) => { return await getAPI()?.actions.addRow(row) } // Updates an existing row in the datasource - const updateRow = async row => { + const updateRow = async (row: SaveRowRequest) => { return await getAPI()?.actions.updateRow(row) } // Deletes rows from the datasource - const deleteRows = async rows => { + const deleteRows = async (rows: Row[]) => { return await getAPI()?.actions.deleteRows(rows) } // Gets a single row from a datasource - const getRow = async id => { + const getRow = async (id: string) => { return await getAPI()?.actions.getRow(id) } // Checks if a certain datasource config is valid - const isDatasourceValid = datasource => { + const isDatasourceValid = (datasource: UIDatasource) => { return getAPI()?.actions.isDatasourceValid(datasource) } // Checks if this datasource can use a specific column by name - const canUseColumn = name => { + const canUseColumn = (name: string) => { return getAPI()?.actions.canUseColumn(name) } diff --git a/packages/frontend-core/src/utils/relatedColumns.ts b/packages/frontend-core/src/utils/relatedColumns.ts index 6d29ef9ce4..5b63e25625 100644 --- a/packages/frontend-core/src/utils/relatedColumns.ts +++ b/packages/frontend-core/src/utils/relatedColumns.ts @@ -14,7 +14,14 @@ const columnTypeManyTypeOverrides = { } const columnTypeManyParser = { - [FieldType.DATETIME]: (value: any[], field: any) => { + [FieldType.DATETIME]: ( + value: any[], + field: { + timeOnly?: boolean + dateOnly?: boolean + ignoreTimezones?: boolean + } + ) => { function parseDate(value: any) { const { timeOnly, dateOnly, ignoreTimezones } = field || {} const enableTime = !dateOnly diff --git a/packages/types/src/ui/stores/grid/datasource.ts b/packages/types/src/ui/stores/grid/datasource.ts index b1ed806b35..ea6e8d1368 100644 --- a/packages/types/src/ui/stores/grid/datasource.ts +++ b/packages/types/src/ui/stores/grid/datasource.ts @@ -10,3 +10,8 @@ export interface UIDatasource { } queryUI: any // TODO } + +export interface UIFieldMutation { + visible: boolean + readonly?: boolean +}