TenantAtlas/apps/platform/.pnpm-store/v10/files/c1/f7dfd08f05306c1e0b996d80e3b6f89129343b833865f8a0a1bd51ea584039ca97e7833f26115cc4948dfe6c2b645ebe2b3085d52ad4ea327986503040a553
Ahmed Darrazi 9f74f7a658
Some checks failed
PR Fast Feedback / fast-feedback (pull_request) Failing after 51s
feat: compress governance operator outcomes
2026-04-19 14:15:11 +02:00

40 lines
1.0 KiB
Plaintext

import { entityKind } from "../../../entity.js";
import { getColumnNameAndConfig } from "../../../utils.js";
import { PgColumn, PgColumnBuilder } from "../common.js";
class PgVectorBuilder extends PgColumnBuilder {
static [entityKind] = "PgVectorBuilder";
constructor(name, config) {
super(name, "array", "PgVector");
this.config.dimensions = config.dimensions;
}
/** @internal */
build(table) {
return new PgVector(
table,
this.config
);
}
}
class PgVector extends PgColumn {
static [entityKind] = "PgVector";
dimensions = this.config.dimensions;
getSQLType() {
return `vector(${this.dimensions})`;
}
mapToDriverValue(value) {
return JSON.stringify(value);
}
mapFromDriverValue(value) {
return value.slice(1, -1).split(",").map((v) => Number.parseFloat(v));
}
}
function vector(a, b) {
const { name, config } = getColumnNameAndConfig(a, b);
return new PgVectorBuilder(name, config);
}
export {
PgVector,
PgVectorBuilder,
vector
};
//# sourceMappingURL=vector.js.map