sendou.ink/app/utils/sql.ts
Kalle fd48bced91
Migrate Prettier/Eslint/Stylelint setup to Biome (#1772)
* Initial

* CSS lint

* Test CI

* Add 1v1, 2v2, and 3v3 Tags (#1771)

* Initial

* CSS lint

* Test CI

* Rename step

---------

Co-authored-by: xi <104683822+ximk@users.noreply.github.com>
2024-06-24 13:07:17 +03:00

33 lines
855 B
TypeScript

export function errorIsSqliteUniqueConstraintFailure(error: any) {
return error?.code === "SQLITE_CONSTRAINT_UNIQUE";
}
export function errorIsSqliteForeignKeyConstraintFailure(error: Error) {
return error?.message?.includes("FOREIGN KEY constraint failed");
}
export function parseDBJsonArray(value: any) {
const parsed = JSON.parse(value);
// If the returned array of JSON objects from DB is empty
// it will be returned as object with all values being null
// this is a (hacky) workaround for that
return parsed.filter((item: any) =>
Object.values(item).some((val) => val !== null),
);
}
export function parseDBArray(value: any) {
const parsed = JSON.parse(value);
if (!parsed || (parsed.length === 1 && parsed[0] === null)) {
return [];
}
return parsed;
}
export function booleanToInt(value: boolean) {
return value ? 1 : 0;
}