sunrise-cms/helpers/lotOccupancyDB/updateOccupancyTypeField.ts

61 lines
1.9 KiB
TypeScript

import sqlite from "better-sqlite3";
import { lotOccupancyDB as databasePath } from "../../data/databasePaths.js";
import { clearCacheByTableName } from "../functions.cache.js";
import type * as recordTypes from "../../types/recordTypes";
interface UpdateOccupancyTypeFieldForm {
occupancyTypeFieldId: number | string;
occupancyTypeField: string;
isRequired: "0" | "1";
minimumLength?: string;
maximumLength?: string;
pattern?: string;
occupancyTypeFieldValues: string;
}
export function updateOccupancyTypeField(
occupancyTypeFieldForm: UpdateOccupancyTypeFieldForm,
requestSession: recordTypes.PartialSession
): boolean {
const database = sqlite(databasePath);
const rightNowMillis = Date.now();
const result = database
.prepare(
`update OccupancyTypeFields
set occupancyTypeField = ?,
isRequired = ?,
minimumLength = ?,
maximumLength = ?,
pattern = ?,
occupancyTypeFieldValues = ?,
recordUpdate_userName = ?,
recordUpdate_timeMillis = ?
where occupancyTypeFieldId = ?
and recordDelete_timeMillis is null`
)
.run(
occupancyTypeFieldForm.occupancyTypeField,
Number.parseInt(occupancyTypeFieldForm.isRequired, 10),
occupancyTypeFieldForm.minimumLength || 0,
occupancyTypeFieldForm.maximumLength || 100,
occupancyTypeFieldForm.pattern || "",
occupancyTypeFieldForm.occupancyTypeFieldValues,
requestSession.user.userName,
rightNowMillis,
occupancyTypeFieldForm.occupancyTypeFieldId
);
database.close();
clearCacheByTableName("OccupancyTypeFields");
return result.changes > 0;
}
export default updateOccupancyTypeField;