2024-06-26 13:40:16 +02:00
|
|
|
import { FieldType, Table } from "@budibase/types"
|
2024-07-26 14:35:36 +02:00
|
|
|
import { PROTECTED_INTERNAL_COLUMNS } from "./constants"
|
2023-10-10 15:50:12 +02:00
|
|
|
|
|
|
|
const allowDisplayColumnByType: Record<FieldType, boolean> = {
|
|
|
|
[FieldType.STRING]: true,
|
|
|
|
[FieldType.LONGFORM]: true,
|
|
|
|
[FieldType.OPTIONS]: true,
|
|
|
|
[FieldType.NUMBER]: true,
|
|
|
|
[FieldType.DATETIME]: true,
|
|
|
|
[FieldType.FORMULA]: true,
|
|
|
|
[FieldType.AUTO]: true,
|
|
|
|
[FieldType.INTERNAL]: true,
|
|
|
|
[FieldType.BARCODEQR]: true,
|
|
|
|
[FieldType.BIGINT]: true,
|
|
|
|
[FieldType.BOOLEAN]: false,
|
|
|
|
[FieldType.ARRAY]: false,
|
2024-04-03 17:05:18 +02:00
|
|
|
[FieldType.ATTACHMENTS]: false,
|
|
|
|
[FieldType.ATTACHMENT_SINGLE]: false,
|
2024-05-17 18:04:15 +02:00
|
|
|
[FieldType.SIGNATURE_SINGLE]: false,
|
2023-10-10 15:50:12 +02:00
|
|
|
[FieldType.LINK]: false,
|
|
|
|
[FieldType.JSON]: false,
|
|
|
|
[FieldType.BB_REFERENCE]: false,
|
2024-04-22 11:14:23 +02:00
|
|
|
[FieldType.BB_REFERENCE_SINGLE]: false,
|
2023-10-10 15:50:12 +02:00
|
|
|
}
|
|
|
|
|
2023-10-18 16:38:37 +02:00
|
|
|
const allowSortColumnByType: Record<FieldType, boolean> = {
|
|
|
|
[FieldType.STRING]: true,
|
|
|
|
[FieldType.LONGFORM]: true,
|
|
|
|
[FieldType.OPTIONS]: true,
|
|
|
|
[FieldType.NUMBER]: true,
|
|
|
|
[FieldType.DATETIME]: true,
|
|
|
|
[FieldType.AUTO]: true,
|
|
|
|
[FieldType.INTERNAL]: true,
|
|
|
|
[FieldType.BARCODEQR]: true,
|
|
|
|
[FieldType.BIGINT]: true,
|
|
|
|
[FieldType.BOOLEAN]: true,
|
|
|
|
[FieldType.JSON]: true,
|
|
|
|
[FieldType.FORMULA]: false,
|
2024-04-03 17:05:18 +02:00
|
|
|
[FieldType.ATTACHMENTS]: false,
|
|
|
|
[FieldType.ATTACHMENT_SINGLE]: false,
|
2024-05-17 18:04:15 +02:00
|
|
|
[FieldType.SIGNATURE_SINGLE]: false,
|
2023-10-18 16:38:37 +02:00
|
|
|
[FieldType.ARRAY]: false,
|
|
|
|
[FieldType.LINK]: false,
|
|
|
|
[FieldType.BB_REFERENCE]: false,
|
2024-04-22 11:14:23 +02:00
|
|
|
[FieldType.BB_REFERENCE_SINGLE]: false,
|
2023-10-18 16:38:37 +02:00
|
|
|
}
|
|
|
|
|
2023-10-10 15:50:12 +02:00
|
|
|
export function canBeDisplayColumn(type: FieldType): boolean {
|
|
|
|
return !!allowDisplayColumnByType[type]
|
|
|
|
}
|
2023-10-18 16:38:37 +02:00
|
|
|
|
|
|
|
export function canBeSortColumn(type: FieldType): boolean {
|
|
|
|
return !!allowSortColumnByType[type]
|
|
|
|
}
|
2024-06-26 13:40:16 +02:00
|
|
|
|
|
|
|
export function findDuplicateInternalColumns(table: Table): string[] {
|
2024-06-26 14:36:20 +02:00
|
|
|
// maintains the case of keys
|
|
|
|
const casedKeys = Object.keys(table.schema)
|
2024-06-26 13:40:16 +02:00
|
|
|
// get the column names
|
2024-06-26 14:36:20 +02:00
|
|
|
const uncasedKeys = casedKeys.map(colName => colName.toLowerCase())
|
2024-06-26 13:40:16 +02:00
|
|
|
// there are duplicates
|
2024-06-26 14:36:20 +02:00
|
|
|
const set = new Set(uncasedKeys)
|
2024-06-26 13:40:16 +02:00
|
|
|
let duplicates: string[] = []
|
2024-06-26 14:36:20 +02:00
|
|
|
if (set.size !== uncasedKeys.length) {
|
2024-06-26 13:40:16 +02:00
|
|
|
for (let key of set.keys()) {
|
2024-06-26 14:36:20 +02:00
|
|
|
const count = uncasedKeys.filter(name => name === key).length
|
2024-06-26 13:40:16 +02:00
|
|
|
if (count > 1) {
|
|
|
|
duplicates.push(key)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
2024-07-26 14:35:36 +02:00
|
|
|
for (let internalColumn of PROTECTED_INTERNAL_COLUMNS) {
|
2024-06-26 14:36:20 +02:00
|
|
|
if (casedKeys.find(key => key === internalColumn)) {
|
|
|
|
duplicates.push(internalColumn)
|
|
|
|
}
|
|
|
|
}
|
2024-06-26 13:40:16 +02:00
|
|
|
return duplicates
|
|
|
|
}
|