datasquirel/package-shared/functions/backend/grabSchemaFieldsFromData.ts

88 lines
2.5 KiB
TypeScript
Raw Normal View History

2025-01-10 19:10:28 +00:00
import { DSQL_FieldSchemaType } from "../../types";
import serverError from "./serverError";
2024-12-08 08:58:57 +00:00
2025-01-10 19:10:28 +00:00
type Param = {
data?: { [s: string]: any };
fields?: string[];
excludeData?: { [s: string]: any };
excludeFields?: DSQL_FieldSchemaType[];
};
2024-12-08 08:58:57 +00:00
/**
* # Add User Table to Database
*/
2025-01-10 19:10:28 +00:00
export default function grabSchemaFieldsFromData({
2024-12-08 08:58:57 +00:00
data,
fields,
excludeData,
excludeFields,
2025-01-10 19:10:28 +00:00
}: Param): DSQL_FieldSchemaType[] {
2024-12-08 08:58:57 +00:00
try {
const possibleFields = require("../../data/possibleFields.json");
const dataTypes = require("../../data/dataTypes.json");
2025-01-10 19:10:28 +00:00
/** @type {DSQL_FieldSchemaType[]} */
const finalFields: DSQL_FieldSchemaType[] = [];
2024-12-08 08:58:57 +00:00
/** @type {string[]} */
2025-01-10 19:10:28 +00:00
let filteredFields: string[] = [];
2024-12-08 08:58:57 +00:00
if (data && Object.keys(data)?.[0]) {
filteredFields = Object.keys(data);
}
if (fields) {
filteredFields = [...filteredFields, ...fields];
filteredFields = [...new Set(filteredFields)];
}
filteredFields = filteredFields
.filter(
(fld) => !excludeData || !Object.keys(excludeData).includes(fld)
)
.filter(
(fld) =>
!excludeFields ||
!excludeFields.find((exlFld) => exlFld.fieldName == fld)
);
filteredFields.forEach((fld) => {
const value = data ? data[fld] : null;
if (typeof value == "string") {
2025-01-10 19:10:28 +00:00
const newField: DSQL_FieldSchemaType = {
fieldName: fld,
dataType: value.length > 255 ? "TEXT" : "VARCHAR(255)",
};
2024-12-08 08:58:57 +00:00
if (Boolean(value.match(/<[^>]+>/g))) {
newField.richText = true;
}
finalFields.push(newField);
} else if (typeof value == "number") {
2025-01-10 19:10:28 +00:00
finalFields.push({
fieldName: fld,
dataType: "INT",
});
2024-12-08 08:58:57 +00:00
} else {
2025-01-10 19:10:28 +00:00
finalFields.push({
fieldName: fld,
dataType: "VARCHAR(255)",
});
2024-12-08 08:58:57 +00:00
}
});
return finalFields;
2025-01-10 19:10:28 +00:00
} catch (/** @type {any} */ error: any) {
2024-12-08 08:58:57 +00:00
console.log(`grabSchemaFieldsFromData.js ERROR: ${error.message}`);
serverError({
component: "grabSchemaFieldsFromData.js",
message: error.message,
});
return [];
}
2025-01-10 19:10:28 +00:00
}