2022-01-14 18:42:14 +01:00
|
|
|
import { tables } from "../stores/backend"
|
|
|
|
import { BannedSearchTypes } from "../constants/backend"
|
|
|
|
import { get } from "svelte/store"
|
|
|
|
|
|
|
|
export function getTableFields(linkField) {
|
|
|
|
const table = get(tables).list.find(table => table._id === linkField.tableId)
|
|
|
|
if (!table || !table.sql) {
|
|
|
|
return []
|
|
|
|
}
|
|
|
|
const linkFields = getFields(Object.values(table.schema), {
|
|
|
|
allowLinks: false,
|
|
|
|
})
|
|
|
|
return linkFields.map(field => ({
|
|
|
|
...field,
|
|
|
|
name: `${table.name}.${field.name}`,
|
|
|
|
}))
|
|
|
|
}
|
|
|
|
|
2022-11-29 12:00:54 +01:00
|
|
|
export function getFields(
|
|
|
|
fields,
|
|
|
|
{ allowLinks } = { allowLinks: true },
|
|
|
|
tableId
|
|
|
|
) {
|
2022-01-17 17:48:49 +01:00
|
|
|
let filteredFields = fields.filter(
|
2022-01-14 18:42:14 +01:00
|
|
|
field => !BannedSearchTypes.includes(field.type)
|
|
|
|
)
|
|
|
|
if (allowLinks) {
|
|
|
|
const linkFields = fields.filter(field => field.type === "link")
|
|
|
|
for (let linkField of linkFields) {
|
|
|
|
// only allow one depth of SQL relationship filtering
|
2022-01-17 17:48:49 +01:00
|
|
|
filteredFields = filteredFields.concat(getTableFields(linkField))
|
2022-01-14 18:42:14 +01:00
|
|
|
}
|
|
|
|
}
|
2022-01-21 17:24:24 +01:00
|
|
|
const staticFormulaFields = fields.filter(
|
|
|
|
field => field.type === "formula" && field.formulaType === "static"
|
|
|
|
)
|
2022-11-29 12:00:54 +01:00
|
|
|
const table = get(tables).list.find(table => table._id === tableId)
|
|
|
|
if (table?.type === "external") {
|
|
|
|
filteredFields = filteredFields.filter(field => field.name !== "_id")
|
|
|
|
}
|
2022-01-21 17:24:24 +01:00
|
|
|
return filteredFields.concat(staticFormulaFields)
|
2022-01-14 18:42:14 +01:00
|
|
|
}
|