Remove magic string for settings

This commit is contained in:
Adria Navarro 2025-01-22 17:32:34 +01:00
parent 51614d61d5
commit 5c9cc915ff
2 changed files with 27 additions and 10 deletions

View File

@ -2,7 +2,13 @@ import { Component, Screen, ScreenProps } from "@budibase/types"
import clientManifest from "@budibase/client/manifest.json" import clientManifest from "@budibase/client/manifest.json"
export function findComponentsBySettingsType(screen: Screen, type: string) { export function findComponentsBySettingsType(screen: Screen, type: string) {
const result: Component[] = [] const result: {
component: Component
setting: {
type: string
key: string
}
}[] = []
function recurseFieldComponentsInChildren( function recurseFieldComponentsInChildren(
component: ScreenProps, component: ScreenProps,
type: string type: string
@ -11,14 +17,15 @@ export function findComponentsBySettingsType(screen: Screen, type: string) {
return return
} }
const componentType = component._component.split("/").slice(-1)[0] const definition = getManifestDefinition(component)
const definition = const setting =
clientManifest[componentType as keyof typeof clientManifest]
if (
"settings" in definition && "settings" in definition &&
definition.settings.some((s: any) => s.type === type) definition.settings.find((s: any) => s.type === type)
) { if (setting && "type" in setting) {
result.push(component) result.push({
component,
setting: { type: setting.type!, key: setting.key! },
})
} }
component._children?.forEach(child => { component._children?.forEach(child => {
recurseFieldComponentsInChildren(child, type) recurseFieldComponentsInChildren(child, type)
@ -28,3 +35,10 @@ export function findComponentsBySettingsType(screen: Screen, type: string) {
recurseFieldComponentsInChildren(screen?.props, type) recurseFieldComponentsInChildren(screen?.props, type)
return result return result
} }
function getManifestDefinition(component: Component) {
const componentType = component._component.split("/").slice(-1)[0]
const definition =
clientManifest[componentType as keyof typeof clientManifest]
return definition
}

View File

@ -38,8 +38,11 @@ export const screenComponentErrors = derived(
} }
const result: Record<string, string[]> = {} const result: Record<string, string[]> = {}
for (const component of findComponentsBySettingsType(screen, "table")) { for (const { component, setting } of findComponentsBySettingsType(
const { resourceId, type, label } = component.dataSource screen,
"table"
)) {
const { resourceId, type, label } = component[setting.key]
if (!datasources[resourceId]) { if (!datasources[resourceId]) {
const friendlyTypeName = const friendlyTypeName =
friendlyNameByType[type as keyof typeof friendlyNameByType] friendlyNameByType[type as keyof typeof friendlyNameByType]