neoorm 0.1.0 → 0.1.2
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/bin/neoorm.js +0 -0
- package/dist/codegen/emit-includes.d.ts.map +1 -1
- package/dist/codegen/emit-includes.js +1 -62
- package/dist/codegen/emit-includes.js.map +1 -1
- package/dist/codegen/emit-models.d.ts +3 -0
- package/dist/codegen/emit-models.d.ts.map +1 -0
- package/dist/codegen/emit-models.js +142 -0
- package/dist/codegen/emit-models.js.map +1 -0
- package/dist/codegen/generate.d.ts +4 -2
- package/dist/codegen/generate.d.ts.map +1 -1
- package/dist/codegen/generate.js +49 -15
- package/dist/codegen/generate.js.map +1 -1
- package/dist/codegen/manifest-relations.d.ts +6 -0
- package/dist/codegen/manifest-relations.d.ts.map +1 -0
- package/dist/codegen/manifest-relations.js +70 -0
- package/dist/codegen/manifest-relations.js.map +1 -0
- package/dist/codegen/schema-to-manifest.d.ts +2 -1
- package/dist/codegen/schema-to-manifest.d.ts.map +1 -1
- package/dist/codegen/schema-to-manifest.js +12 -2
- package/dist/codegen/schema-to-manifest.js.map +1 -1
- package/dist/dialect/postgres.d.ts.map +1 -1
- package/dist/dialect/postgres.js +22 -23
- package/dist/dialect/postgres.js.map +1 -1
- package/dist/dialect/types.d.ts +4 -1
- package/dist/dialect/types.d.ts.map +1 -1
- package/dist/index.d.ts +1 -1
- package/dist/index.d.ts.map +1 -1
- package/dist/introspect/pull.d.ts.map +1 -1
- package/dist/introspect/pull.js +59 -30
- package/dist/introspect/pull.js.map +1 -1
- package/dist/plugins/builtin.d.ts +11 -0
- package/dist/plugins/builtin.d.ts.map +1 -0
- package/dist/plugins/builtin.js +130 -0
- package/dist/plugins/builtin.js.map +1 -0
- package/dist/plugins/ensure-plugins.d.ts +3 -0
- package/dist/plugins/ensure-plugins.d.ts.map +1 -0
- package/dist/plugins/ensure-plugins.js +19 -0
- package/dist/plugins/ensure-plugins.js.map +1 -0
- package/dist/plugins/index.d.ts +4 -0
- package/dist/plugins/index.d.ts.map +1 -0
- package/dist/plugins/index.js +3 -0
- package/dist/plugins/index.js.map +1 -0
- package/dist/plugins/postgis/columns.d.ts +25 -0
- package/dist/plugins/postgis/columns.d.ts.map +1 -0
- package/dist/plugins/postgis/columns.js +82 -0
- package/dist/plugins/postgis/columns.js.map +1 -0
- package/dist/plugins/postgis/geojson.d.ts +4 -0
- package/dist/plugins/postgis/geojson.d.ts.map +1 -0
- package/dist/plugins/postgis/geojson.js +22 -0
- package/dist/plugins/postgis/geojson.js.map +1 -0
- package/dist/plugins/postgis/index.d.ts +4 -0
- package/dist/plugins/postgis/index.d.ts.map +1 -0
- package/dist/plugins/postgis/index.js +6 -0
- package/dist/plugins/postgis/index.js.map +1 -0
- package/dist/plugins/postgis/operators.d.ts +5 -0
- package/dist/plugins/postgis/operators.d.ts.map +1 -0
- package/dist/plugins/postgis/operators.js +35 -0
- package/dist/plugins/postgis/operators.js.map +1 -0
- package/dist/plugins/postgis/plugin.d.ts +3 -0
- package/dist/plugins/postgis/plugin.d.ts.map +1 -0
- package/dist/plugins/postgis/plugin.js +7 -0
- package/dist/plugins/postgis/plugin.js.map +1 -0
- package/dist/plugins/registry.d.ts +10 -0
- package/dist/plugins/registry.d.ts.map +1 -0
- package/dist/plugins/registry.js +89 -0
- package/dist/plugins/registry.js.map +1 -0
- package/dist/plugins/types.d.ts +32 -0
- package/dist/plugins/types.d.ts.map +1 -0
- package/dist/plugins/types.js +2 -0
- package/dist/plugins/types.js.map +1 -0
- package/dist/runtime/client.d.ts +17 -4
- package/dist/runtime/client.d.ts.map +1 -1
- package/dist/runtime/client.js +8 -0
- package/dist/runtime/client.js.map +1 -1
- package/dist/runtime/query/compile.d.ts +2 -0
- package/dist/runtime/query/compile.d.ts.map +1 -1
- package/dist/runtime/query/compile.js +99 -8
- package/dist/runtime/query/compile.js.map +1 -1
- package/dist/runtime/query/count.d.ts +10 -0
- package/dist/runtime/query/count.d.ts.map +1 -0
- package/dist/runtime/query/count.js +24 -0
- package/dist/runtime/query/count.js.map +1 -0
- package/dist/runtime/query/unique.d.ts +8 -0
- package/dist/runtime/query/unique.d.ts.map +1 -0
- package/dist/runtime/query/unique.js +47 -0
- package/dist/runtime/query/unique.js.map +1 -0
- package/dist/runtime/query/upsert.d.ts +10 -0
- package/dist/runtime/query/upsert.d.ts.map +1 -0
- package/dist/runtime/query/upsert.js +38 -0
- package/dist/runtime/query/upsert.js.map +1 -0
- package/dist/runtime/types.d.ts +27 -14
- package/dist/runtime/types.d.ts.map +1 -1
- package/dist/schema/column.d.ts +5 -11
- package/dist/schema/column.d.ts.map +1 -1
- package/dist/schema/column.js +7 -53
- package/dist/schema/column.js.map +1 -1
- package/dist/schema/index.d.ts +1 -1
- package/dist/schema/index.d.ts.map +1 -1
- package/dist/schema/types.d.ts +13 -0
- package/dist/schema/types.d.ts.map +1 -1
- package/dist/sql/template.d.ts.map +1 -1
- package/dist/sql/template.js.map +1 -1
- package/package.json +30 -12
|
@@ -0,0 +1,82 @@
|
|
|
1
|
+
import { createColumnBuilder } from "../../schema/column.js";
|
|
2
|
+
import { geoJsonFromValue, geoJsonToParam } from "./geojson.js";
|
|
3
|
+
import { postgisWhereOperators } from "./operators.js";
|
|
4
|
+
function spatialSqlType(base, options) {
|
|
5
|
+
const subtype = options?.subtype;
|
|
6
|
+
const srid = options?.srid;
|
|
7
|
+
if (subtype && srid !== undefined) {
|
|
8
|
+
return `${base}(${subtype},${srid})`;
|
|
9
|
+
}
|
|
10
|
+
if (subtype) {
|
|
11
|
+
return `${base}(${subtype})`;
|
|
12
|
+
}
|
|
13
|
+
if (srid !== undefined) {
|
|
14
|
+
return `${base}(${srid})`;
|
|
15
|
+
}
|
|
16
|
+
return base;
|
|
17
|
+
}
|
|
18
|
+
function spatialSelectExpression(col) {
|
|
19
|
+
const sqlName = `"${col.sqlName.replace(/"/g, '""')}"`;
|
|
20
|
+
return `ST_AsGeoJSON(${sqlName})::json AS ${sqlName}`;
|
|
21
|
+
}
|
|
22
|
+
function spatialWriteExpression(col, paramIndex) {
|
|
23
|
+
const srid = col.typeOptions?.["srid"] ?? 4326;
|
|
24
|
+
return `ST_SetSRID(ST_GeomFromGeoJSON($${paramIndex}::json), ${srid})`;
|
|
25
|
+
}
|
|
26
|
+
function createSpatialTypePlugin(kind, base, defaultOptions) {
|
|
27
|
+
return {
|
|
28
|
+
kind,
|
|
29
|
+
createBuilder(options) {
|
|
30
|
+
const merged = { ...defaultOptions, ...options };
|
|
31
|
+
return createColumnBuilder({
|
|
32
|
+
kind,
|
|
33
|
+
nullable: true,
|
|
34
|
+
unique: false,
|
|
35
|
+
primary: false,
|
|
36
|
+
defaultNow: false,
|
|
37
|
+
typeOptions: merged,
|
|
38
|
+
});
|
|
39
|
+
},
|
|
40
|
+
columnType(col) {
|
|
41
|
+
return spatialSqlType(base, col.typeOptions);
|
|
42
|
+
},
|
|
43
|
+
columnTsType(col) {
|
|
44
|
+
const tsType = kind === "point" ? "GeoJsonPoint" : "GeoJsonGeometry";
|
|
45
|
+
return col.nullable ? `${tsType} | null` : tsType;
|
|
46
|
+
},
|
|
47
|
+
selectExpression: spatialSelectExpression,
|
|
48
|
+
writeExpression: spatialWriteExpression,
|
|
49
|
+
serializeValue(_col, value) {
|
|
50
|
+
return geoJsonToParam(value);
|
|
51
|
+
},
|
|
52
|
+
deserializeValue(_col, dbValue) {
|
|
53
|
+
return geoJsonFromValue(dbValue);
|
|
54
|
+
},
|
|
55
|
+
whereOperators: postgisWhereOperators,
|
|
56
|
+
introspect(_pgDataType, udtName) {
|
|
57
|
+
if (kind === "geography") {
|
|
58
|
+
return udtName === "geography";
|
|
59
|
+
}
|
|
60
|
+
if (kind === "point") {
|
|
61
|
+
return udtName === "geometry";
|
|
62
|
+
}
|
|
63
|
+
return udtName === "geometry";
|
|
64
|
+
},
|
|
65
|
+
};
|
|
66
|
+
}
|
|
67
|
+
export const geometryType = createSpatialTypePlugin("geometry", "geometry");
|
|
68
|
+
export const geographyType = createSpatialTypePlugin("geography", "geography");
|
|
69
|
+
export const pointType = createSpatialTypePlugin("point", "geometry", {
|
|
70
|
+
subtype: "Point",
|
|
71
|
+
srid: 4326,
|
|
72
|
+
});
|
|
73
|
+
export function geometry(options) {
|
|
74
|
+
return geometryType.createBuilder(options);
|
|
75
|
+
}
|
|
76
|
+
export function geography(options) {
|
|
77
|
+
return geographyType.createBuilder(options);
|
|
78
|
+
}
|
|
79
|
+
export function point(options) {
|
|
80
|
+
return pointType.createBuilder(options);
|
|
81
|
+
}
|
|
82
|
+
//# sourceMappingURL=columns.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"columns.js","sourceRoot":"","sources":["../../../src/plugins/postgis/columns.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"geojson.d.ts","sourceRoot":"","sources":["../../../src/plugins/postgis/geojson.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,eAAe,EAAE,MAAM,cAAc,CAAC;AAEpD,wBAAgB,cAAc,CAAC,KAAK,EAAE,OAAO,GAAG,OAAO,CAQtD;AAED,wBAAgB,gBAAgB,CAAC,OAAO,EAAE,OAAO,GAAG,eAAe,GAAG,IAAI,CAWzE"}
|
|
@@ -0,0 +1,22 @@
|
|
|
1
|
+
export function geoJsonToParam(value) {
|
|
2
|
+
if (value === null || value === undefined) {
|
|
3
|
+
return null;
|
|
4
|
+
}
|
|
5
|
+
if (typeof value === "string") {
|
|
6
|
+
return value;
|
|
7
|
+
}
|
|
8
|
+
return JSON.stringify(value);
|
|
9
|
+
}
|
|
10
|
+
export function geoJsonFromValue(dbValue) {
|
|
11
|
+
if (dbValue === null || dbValue === undefined) {
|
|
12
|
+
return null;
|
|
13
|
+
}
|
|
14
|
+
if (typeof dbValue === "string") {
|
|
15
|
+
return JSON.parse(dbValue);
|
|
16
|
+
}
|
|
17
|
+
if (typeof dbValue === "object") {
|
|
18
|
+
return dbValue;
|
|
19
|
+
}
|
|
20
|
+
return null;
|
|
21
|
+
}
|
|
22
|
+
//# sourceMappingURL=geojson.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"geojson.js","sourceRoot":"","sources":["../../../src/plugins/postgis/geojson.ts"],"names":[],"mappings":"AAEA,MAAM,UAAU,cAAc,CAAC,KAAc;IAC3C,IAAI,KAAK,KAAK,IAAI,IAAI,KAAK,KAAK,SAAS,EAAE,CAAC;QAC1C,OAAO,IAAI,CAAC;IACd,CAAC;IACD,IAAI,OAAO,KAAK,KAAK,QAAQ,EAAE,CAAC;QAC9B,OAAO,KAAK,CAAC;IACf,CAAC;IACD,OAAO,IAAI,CAAC,SAAS,CAAC,KAAK,CAAC,CAAC;AAC/B,CAAC;AAED,MAAM,UAAU,gBAAgB,CAAC,OAAgB;IAC/C,IAAI,OAAO,KAAK,IAAI,IAAI,OAAO,KAAK,SAAS,EAAE,CAAC;QAC9C,OAAO,IAAI,CAAC;IACd,CAAC;IACD,IAAI,OAAO,OAAO,KAAK,QAAQ,EAAE,CAAC;QAChC,OAAO,IAAI,CAAC,KAAK,CAAC,OAAO,CAAoB,CAAC;IAChD,CAAC;IACD,IAAI,OAAO,OAAO,KAAK,QAAQ,EAAE,CAAC;QAChC,OAAO,OAA0B,CAAC;IACpC,CAAC;IACD,OAAO,IAAI,CAAC;AACd,CAAC"}
|
|
@@ -0,0 +1,4 @@
|
|
|
1
|
+
export type { GeoJsonPoint, GeoJsonPolygon, GeoJsonGeometry, GeometryOptions, GeographyOptions, PointOptions, } from "./columns.js";
|
|
2
|
+
export { geometry, geography, point } from "./columns.js";
|
|
3
|
+
export { postgisPlugin } from "./plugin.js";
|
|
4
|
+
//# sourceMappingURL=index.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/plugins/postgis/index.ts"],"names":[],"mappings":"AAGA,YAAY,EACV,YAAY,EACZ,cAAc,EACd,eAAe,EACf,eAAe,EACf,gBAAgB,EAChB,YAAY,GACb,MAAM,cAAc,CAAC;AAEtB,OAAO,EAAE,QAAQ,EAAE,SAAS,EAAE,KAAK,EAAE,MAAM,cAAc,CAAC;AAC1D,OAAO,EAAE,aAAa,EAAE,MAAM,aAAa,CAAC"}
|
|
@@ -0,0 +1,6 @@
|
|
|
1
|
+
import { registerPlugin } from "../registry.js";
|
|
2
|
+
import { postgisPlugin } from "./plugin.js";
|
|
3
|
+
export { geometry, geography, point } from "./columns.js";
|
|
4
|
+
export { postgisPlugin } from "./plugin.js";
|
|
5
|
+
registerPlugin(postgisPlugin);
|
|
6
|
+
//# sourceMappingURL=index.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/plugins/postgis/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,cAAc,EAAE,MAAM,gBAAgB,CAAC;AAChD,OAAO,EAAE,aAAa,EAAE,MAAM,aAAa,CAAC;AAW5C,OAAO,EAAE,QAAQ,EAAE,SAAS,EAAE,KAAK,EAAE,MAAM,cAAc,CAAC;AAC1D,OAAO,EAAE,aAAa,EAAE,MAAM,aAAa,CAAC;AAE5C,cAAc,CAAC,aAAa,CAAC,CAAC"}
|
|
@@ -0,0 +1,5 @@
|
|
|
1
|
+
import type { ManifestColumn } from "../../dialect/types.js";
|
|
2
|
+
import type { PluginWhereOperator } from "../types.js";
|
|
3
|
+
export declare const postgisWhereOperators: Record<string, PluginWhereOperator>;
|
|
4
|
+
export declare function isPostgisColumn(col: ManifestColumn): boolean;
|
|
5
|
+
//# sourceMappingURL=operators.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"operators.d.ts","sourceRoot":"","sources":["../../../src/plugins/postgis/operators.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,cAAc,EAAE,MAAM,wBAAwB,CAAC;AAC7D,OAAO,KAAK,EAAE,mBAAmB,EAAE,MAAM,aAAa,CAAC;AAOvD,eAAO,MAAM,qBAAqB,EAAE,MAAM,CAAC,MAAM,EAAE,mBAAmB,CA0BrE,CAAC;AAEF,wBAAgB,eAAe,CAAC,GAAG,EAAE,cAAc,GAAG,OAAO,CAE5D"}
|
|
@@ -0,0 +1,35 @@
|
|
|
1
|
+
import { geoJsonToParam } from "./geojson.js";
|
|
2
|
+
function geomFromGeoJson(paramIndex) {
|
|
3
|
+
return `ST_GeomFromGeoJSON($${paramIndex}::json)`;
|
|
4
|
+
}
|
|
5
|
+
export const postgisWhereOperators = {
|
|
6
|
+
intersects: {
|
|
7
|
+
compile(sqlCol, value, _col, startParamIndex) {
|
|
8
|
+
return {
|
|
9
|
+
sql: `ST_Intersects(${sqlCol}, ${geomFromGeoJson(startParamIndex)})`,
|
|
10
|
+
params: [geoJsonToParam(value)],
|
|
11
|
+
};
|
|
12
|
+
},
|
|
13
|
+
},
|
|
14
|
+
within: {
|
|
15
|
+
compile(sqlCol, value, _col, startParamIndex) {
|
|
16
|
+
return {
|
|
17
|
+
sql: `ST_Within(${sqlCol}, ${geomFromGeoJson(startParamIndex)})`,
|
|
18
|
+
params: [geoJsonToParam(value)],
|
|
19
|
+
};
|
|
20
|
+
},
|
|
21
|
+
},
|
|
22
|
+
dWithin: {
|
|
23
|
+
compile(sqlCol, value, _col, startParamIndex) {
|
|
24
|
+
const payload = value;
|
|
25
|
+
return {
|
|
26
|
+
sql: `ST_DWithin(${sqlCol}, ${geomFromGeoJson(startParamIndex)}, $${startParamIndex + 1})`,
|
|
27
|
+
params: [geoJsonToParam(payload.geometry), payload.distance],
|
|
28
|
+
};
|
|
29
|
+
},
|
|
30
|
+
},
|
|
31
|
+
};
|
|
32
|
+
export function isPostgisColumn(col) {
|
|
33
|
+
return col.kind === "geometry" || col.kind === "geography" || col.kind === "point";
|
|
34
|
+
}
|
|
35
|
+
//# sourceMappingURL=operators.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"operators.js","sourceRoot":"","sources":["../../../src/plugins/postgis/operators.ts"],"names":[],"mappings":"AAEA,OAAO,EAAE,cAAc,EAAE,MAAM,cAAc,CAAC;AAE9C,SAAS,eAAe,CAAC,UAAkB;IACzC,OAAO,uBAAuB,UAAU,SAAS,CAAC;AACpD,CAAC;AAED,MAAM,CAAC,MAAM,qBAAqB,GAAwC;IACxE,UAAU,EAAE;QACV,OAAO,CAAC,MAAM,EAAE,KAAK,EAAE,IAAI,EAAE,eAAe;YAC1C,OAAO;gBACL,GAAG,EAAE,iBAAiB,MAAM,KAAK,eAAe,CAAC,eAAe,CAAC,GAAG;gBACpE,MAAM,EAAE,CAAC,cAAc,CAAC,KAAK,CAAC,CAAC;aAChC,CAAC;QACJ,CAAC;KACF;IACD,MAAM,EAAE;QACN,OAAO,CAAC,MAAM,EAAE,KAAK,EAAE,IAAI,EAAE,eAAe;YAC1C,OAAO;gBACL,GAAG,EAAE,aAAa,MAAM,KAAK,eAAe,CAAC,eAAe,CAAC,GAAG;gBAChE,MAAM,EAAE,CAAC,cAAc,CAAC,KAAK,CAAC,CAAC;aAChC,CAAC;QACJ,CAAC;KACF;IACD,OAAO,EAAE;QACP,OAAO,CAAC,MAAM,EAAE,KAAK,EAAE,IAAI,EAAE,eAAe;YAC1C,MAAM,OAAO,GAAG,KAAgD,CAAC;YACjE,OAAO;gBACL,GAAG,EAAE,cAAc,MAAM,KAAK,eAAe,CAAC,eAAe,CAAC,MAAM,eAAe,GAAG,CAAC,GAAG;gBAC1F,MAAM,EAAE,CAAC,cAAc,CAAC,OAAO,CAAC,QAAQ,CAAC,EAAE,OAAO,CAAC,QAAQ,CAAC;aAC7D,CAAC;QACJ,CAAC;KACF;CACF,CAAC;AAEF,MAAM,UAAU,eAAe,CAAC,GAAmB;IACjD,OAAO,GAAG,CAAC,IAAI,KAAK,UAAU,IAAI,GAAG,CAAC,IAAI,KAAK,WAAW,IAAI,GAAG,CAAC,IAAI,KAAK,OAAO,CAAC;AACrF,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"plugin.d.ts","sourceRoot":"","sources":["../../../src/plugins/postgis/plugin.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,YAAY,EAAE,MAAM,aAAa,CAAC;AAGhD,eAAO,MAAM,aAAa,EAAE,YAI3B,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"plugin.js","sourceRoot":"","sources":["../../../src/plugins/postgis/plugin.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,YAAY,EAAE,aAAa,EAAE,SAAS,EAAE,MAAM,cAAc,CAAC;AAEtE,MAAM,CAAC,MAAM,aAAa,GAAiB;IACzC,IAAI,EAAE,SAAS;IACf,UAAU,EAAE,CAAC,SAAS,CAAC;IACvB,WAAW,EAAE,CAAC,YAAY,EAAE,aAAa,EAAE,SAAS,CAAC;CACtD,CAAC"}
|
|
@@ -0,0 +1,10 @@
|
|
|
1
|
+
import type { ColumnTypePlugin, NeoOrmPlugin } from "./types.js";
|
|
2
|
+
export declare function registerPlugin(plugin: NeoOrmPlugin): void;
|
|
3
|
+
export declare function getPluginRegistry(): readonly NeoOrmPlugin[];
|
|
4
|
+
export declare function getColumnType(kind: string): ColumnTypePlugin | undefined;
|
|
5
|
+
export declare function getColumnTypeOrThrow(kind: string): ColumnTypePlugin;
|
|
6
|
+
export declare function clearPluginRegistry(): void;
|
|
7
|
+
export declare function collectExtensions(plugins: readonly NeoOrmPlugin[]): string[];
|
|
8
|
+
export declare function collectExtensionsForKinds(kinds: readonly string[]): string[];
|
|
9
|
+
export declare function findIntrospectColumnType(pgDataType: string, udtName: string): ColumnTypePlugin | undefined;
|
|
10
|
+
//# sourceMappingURL=registry.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"registry.d.ts","sourceRoot":"","sources":["../../src/plugins/registry.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,gBAAgB,EAAE,YAAY,EAAE,MAAM,YAAY,CAAC;AA4BjE,wBAAgB,cAAc,CAAC,MAAM,EAAE,YAAY,GAAG,IAAI,CAMzD;AAED,wBAAgB,iBAAiB,IAAI,SAAS,YAAY,EAAE,CAG3D;AAED,wBAAgB,aAAa,CAAC,IAAI,EAAE,MAAM,GAAG,gBAAgB,GAAG,SAAS,CAMxE;AAED,wBAAgB,oBAAoB,CAAC,IAAI,EAAE,MAAM,GAAG,gBAAgB,CAQnE;AAED,wBAAgB,mBAAmB,IAAI,IAAI,CAI1C;AAED,wBAAgB,iBAAiB,CAAC,OAAO,EAAE,SAAS,YAAY,EAAE,GAAG,MAAM,EAAE,CAQ5E;AAED,wBAAgB,yBAAyB,CAAC,KAAK,EAAE,SAAS,MAAM,EAAE,GAAG,MAAM,EAAE,CAiB5E;AAED,wBAAgB,wBAAwB,CACtC,UAAU,EAAE,MAAM,EAClB,OAAO,EAAE,MAAM,GACd,gBAAgB,GAAG,SAAS,CAQ9B"}
|
|
@@ -0,0 +1,89 @@
|
|
|
1
|
+
import { builtinPlugin } from "./builtin.js";
|
|
2
|
+
const pluginRegistry = [];
|
|
3
|
+
const columnTypeMap = new Map();
|
|
4
|
+
let builtinsRegistered = false;
|
|
5
|
+
function indexColumnTypes(plugin, allowOverwrite = false) {
|
|
6
|
+
for (const columnType of plugin.columnTypes) {
|
|
7
|
+
if (columnTypeMap.has(columnType.kind) && !allowOverwrite) {
|
|
8
|
+
const existing = columnTypeMap.get(columnType.kind);
|
|
9
|
+
if (existing !== columnType) {
|
|
10
|
+
throw new Error(`Duplicate column type kind registered: ${columnType.kind}`);
|
|
11
|
+
}
|
|
12
|
+
continue;
|
|
13
|
+
}
|
|
14
|
+
columnTypeMap.set(columnType.kind, columnType);
|
|
15
|
+
}
|
|
16
|
+
}
|
|
17
|
+
function ensureBuiltins() {
|
|
18
|
+
if (builtinsRegistered)
|
|
19
|
+
return;
|
|
20
|
+
builtinsRegistered = true;
|
|
21
|
+
pluginRegistry.push(builtinPlugin);
|
|
22
|
+
indexColumnTypes(builtinPlugin, true);
|
|
23
|
+
}
|
|
24
|
+
export function registerPlugin(plugin) {
|
|
25
|
+
ensureBuiltins();
|
|
26
|
+
if (!pluginRegistry.some((p) => p.name === plugin.name)) {
|
|
27
|
+
pluginRegistry.push(plugin);
|
|
28
|
+
}
|
|
29
|
+
indexColumnTypes(plugin, true);
|
|
30
|
+
}
|
|
31
|
+
export function getPluginRegistry() {
|
|
32
|
+
ensureBuiltins();
|
|
33
|
+
return pluginRegistry;
|
|
34
|
+
}
|
|
35
|
+
export function getColumnType(kind) {
|
|
36
|
+
ensureBuiltins();
|
|
37
|
+
if (kind === "fk") {
|
|
38
|
+
return columnTypeMap.get("text");
|
|
39
|
+
}
|
|
40
|
+
return columnTypeMap.get(kind);
|
|
41
|
+
}
|
|
42
|
+
export function getColumnTypeOrThrow(kind) {
|
|
43
|
+
const columnType = getColumnType(kind);
|
|
44
|
+
if (!columnType) {
|
|
45
|
+
throw new Error(`Unknown column kind "${kind}". Import the plugin that provides this type (e.g. import "neoorm/plugins/postgis").`);
|
|
46
|
+
}
|
|
47
|
+
return columnType;
|
|
48
|
+
}
|
|
49
|
+
export function clearPluginRegistry() {
|
|
50
|
+
pluginRegistry.length = 0;
|
|
51
|
+
columnTypeMap.clear();
|
|
52
|
+
builtinsRegistered = false;
|
|
53
|
+
}
|
|
54
|
+
export function collectExtensions(plugins) {
|
|
55
|
+
const extensions = new Set();
|
|
56
|
+
for (const plugin of plugins) {
|
|
57
|
+
for (const ext of plugin.extensions ?? []) {
|
|
58
|
+
extensions.add(ext);
|
|
59
|
+
}
|
|
60
|
+
}
|
|
61
|
+
return [...extensions];
|
|
62
|
+
}
|
|
63
|
+
export function collectExtensionsForKinds(kinds) {
|
|
64
|
+
const extensions = new Set();
|
|
65
|
+
ensureBuiltins();
|
|
66
|
+
for (const kind of kinds) {
|
|
67
|
+
if (kind === "fk")
|
|
68
|
+
continue;
|
|
69
|
+
for (const plugin of pluginRegistry) {
|
|
70
|
+
if (!plugin.columnTypes.some((columnType) => columnType.kind === kind)) {
|
|
71
|
+
continue;
|
|
72
|
+
}
|
|
73
|
+
for (const ext of plugin.extensions ?? []) {
|
|
74
|
+
extensions.add(ext);
|
|
75
|
+
}
|
|
76
|
+
}
|
|
77
|
+
}
|
|
78
|
+
return [...extensions];
|
|
79
|
+
}
|
|
80
|
+
export function findIntrospectColumnType(pgDataType, udtName) {
|
|
81
|
+
ensureBuiltins();
|
|
82
|
+
for (const columnType of columnTypeMap.values()) {
|
|
83
|
+
if (columnType.introspect?.(pgDataType, udtName)) {
|
|
84
|
+
return columnType;
|
|
85
|
+
}
|
|
86
|
+
}
|
|
87
|
+
return undefined;
|
|
88
|
+
}
|
|
89
|
+
//# sourceMappingURL=registry.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"registry.js","sourceRoot":"","sources":["../../src/plugins/registry.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,32 @@
|
|
|
1
|
+
import type { ColumnBuilder, ColumnMeta } from "../schema/column.js";
|
|
2
|
+
import type { ManifestColumn } from "../dialect/types.js";
|
|
3
|
+
export type PluginWhereCompileResult = {
|
|
4
|
+
sql: string;
|
|
5
|
+
params: unknown[];
|
|
6
|
+
};
|
|
7
|
+
export type PluginWhereOperator = {
|
|
8
|
+
compile: (sqlCol: string, value: unknown, col: ManifestColumn, startParamIndex: number) => PluginWhereCompileResult;
|
|
9
|
+
};
|
|
10
|
+
export type ColumnTypePlugin = {
|
|
11
|
+
readonly kind: string;
|
|
12
|
+
createBuilder(options?: Record<string, unknown>): ColumnBuilder<unknown>;
|
|
13
|
+
columnType(col: ManifestColumn): string;
|
|
14
|
+
columnTsType(col: ManifestColumn): string;
|
|
15
|
+
formatDefault?(col: ManifestColumn, value: unknown): string;
|
|
16
|
+
selectExpression?(col: ManifestColumn): string;
|
|
17
|
+
writeExpression?(col: ManifestColumn, paramIndex: number): string;
|
|
18
|
+
serializeValue?(col: ManifestColumn, value: unknown): unknown;
|
|
19
|
+
deserializeValue?(col: ManifestColumn, dbValue: unknown): unknown;
|
|
20
|
+
whereOperators?: Record<string, PluginWhereOperator>;
|
|
21
|
+
introspect?(pgDataType: string, udtName: string): boolean;
|
|
22
|
+
};
|
|
23
|
+
export type NeoOrmPlugin = {
|
|
24
|
+
readonly name: string;
|
|
25
|
+
readonly extensions?: readonly string[];
|
|
26
|
+
readonly columnTypes: readonly ColumnTypePlugin[];
|
|
27
|
+
};
|
|
28
|
+
export type ExtendedColumnMeta = ColumnMeta & {
|
|
29
|
+
kind: string;
|
|
30
|
+
typeOptions?: Record<string, unknown>;
|
|
31
|
+
};
|
|
32
|
+
//# sourceMappingURL=types.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"types.d.ts","sourceRoot":"","sources":["../../src/plugins/types.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,aAAa,EAAE,UAAU,EAAE,MAAM,qBAAqB,CAAC;AACrE,OAAO,KAAK,EAAE,cAAc,EAAE,MAAM,qBAAqB,CAAC;AAE1D,MAAM,MAAM,wBAAwB,GAAG;IACrC,GAAG,EAAE,MAAM,CAAC;IACZ,MAAM,EAAE,OAAO,EAAE,CAAC;CACnB,CAAC;AAEF,MAAM,MAAM,mBAAmB,GAAG;IAChC,OAAO,EAAE,CACP,MAAM,EAAE,MAAM,EACd,KAAK,EAAE,OAAO,EACd,GAAG,EAAE,cAAc,EACnB,eAAe,EAAE,MAAM,KACpB,wBAAwB,CAAC;CAC/B,CAAC;AAEF,MAAM,MAAM,gBAAgB,GAAG;IAC7B,QAAQ,CAAC,IAAI,EAAE,MAAM,CAAC;IACtB,aAAa,CAAC,OAAO,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,GAAG,aAAa,CAAC,OAAO,CAAC,CAAC;IACzE,UAAU,CAAC,GAAG,EAAE,cAAc,GAAG,MAAM,CAAC;IACxC,YAAY,CAAC,GAAG,EAAE,cAAc,GAAG,MAAM,CAAC;IAC1C,aAAa,CAAC,CAAC,GAAG,EAAE,cAAc,EAAE,KAAK,EAAE,OAAO,GAAG,MAAM,CAAC;IAC5D,gBAAgB,CAAC,CAAC,GAAG,EAAE,cAAc,GAAG,MAAM,CAAC;IAC/C,eAAe,CAAC,CAAC,GAAG,EAAE,cAAc,EAAE,UAAU,EAAE,MAAM,GAAG,MAAM,CAAC;IAClE,cAAc,CAAC,CAAC,GAAG,EAAE,cAAc,EAAE,KAAK,EAAE,OAAO,GAAG,OAAO,CAAC;IAC9D,gBAAgB,CAAC,CAAC,GAAG,EAAE,cAAc,EAAE,OAAO,EAAE,OAAO,GAAG,OAAO,CAAC;IAClE,cAAc,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,mBAAmB,CAAC,CAAC;IACrD,UAAU,CAAC,CAAC,UAAU,EAAE,MAAM,EAAE,OAAO,EAAE,MAAM,GAAG,OAAO,CAAC;CAC3D,CAAC;AAEF,MAAM,MAAM,YAAY,GAAG;IACzB,QAAQ,CAAC,IAAI,EAAE,MAAM,CAAC;IACtB,QAAQ,CAAC,UAAU,CAAC,EAAE,SAAS,MAAM,EAAE,CAAC;IACxC,QAAQ,CAAC,WAAW,EAAE,SAAS,gBAAgB,EAAE,CAAC;CACnD,CAAC;AAEF,MAAM,MAAM,kBAAkB,GAAG,UAAU,GAAG;IAC5C,IAAI,EAAE,MAAM,CAAC;IACb,WAAW,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,CAAC;CACvC,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"types.js","sourceRoot":"","sources":["../../src/plugins/types.ts"],"names":[],"mappings":""}
|
package/dist/runtime/client.d.ts
CHANGED
|
@@ -2,7 +2,7 @@ import { Pool } from "pg";
|
|
|
2
2
|
import type { Manifest } from "../dialect/types.js";
|
|
3
3
|
import type { TableDef } from "../schema/table.js";
|
|
4
4
|
import type { WithInput } from "./query/find.js";
|
|
5
|
-
import type { TypedNeoOrmClient, DefaultWithMap } from "./types.js";
|
|
5
|
+
import type { TypedNeoOrmClient, DefaultWithMap, DefaultRowPayloadMap } from "./types.js";
|
|
6
6
|
export type TableRepository = {
|
|
7
7
|
findMany(args?: {
|
|
8
8
|
where?: Record<string, unknown>;
|
|
@@ -16,6 +16,10 @@ export type TableRepository = {
|
|
|
16
16
|
orderBy?: Record<string, string>;
|
|
17
17
|
with?: Record<string, WithInput>;
|
|
18
18
|
}): Promise<Record<string, unknown> | null>;
|
|
19
|
+
findUnique(args: {
|
|
20
|
+
where: Record<string, unknown>;
|
|
21
|
+
with?: Record<string, WithInput>;
|
|
22
|
+
}): Promise<Record<string, unknown> | null>;
|
|
19
23
|
findById(id: string, args?: {
|
|
20
24
|
with?: Record<string, WithInput>;
|
|
21
25
|
}): Promise<Record<string, unknown> | null>;
|
|
@@ -23,6 +27,12 @@ export type TableRepository = {
|
|
|
23
27
|
data: Record<string, unknown>;
|
|
24
28
|
with?: Record<string, WithInput>;
|
|
25
29
|
}): Promise<Record<string, unknown>>;
|
|
30
|
+
upsert(args: {
|
|
31
|
+
where: Record<string, unknown>;
|
|
32
|
+
create: Record<string, unknown>;
|
|
33
|
+
update: Record<string, unknown>;
|
|
34
|
+
with?: Record<string, WithInput>;
|
|
35
|
+
}): Promise<Record<string, unknown>>;
|
|
26
36
|
update(args: {
|
|
27
37
|
where: Record<string, unknown>;
|
|
28
38
|
data: Record<string, unknown>;
|
|
@@ -43,6 +53,9 @@ export type TableRepository = {
|
|
|
43
53
|
deleteMany(args?: {
|
|
44
54
|
where?: Record<string, unknown>;
|
|
45
55
|
}): Promise<number>;
|
|
56
|
+
count(args?: {
|
|
57
|
+
where?: Record<string, unknown>;
|
|
58
|
+
}): Promise<number>;
|
|
46
59
|
deleteById(id: string): Promise<Record<string, unknown> | null>;
|
|
47
60
|
};
|
|
48
61
|
/** @deprecated Use TypedNeoOrmClient with createNeoOrmClient generic instead */
|
|
@@ -55,7 +68,7 @@ export interface NeoOrmClient {
|
|
|
55
68
|
$disconnect(): Promise<void>;
|
|
56
69
|
[tableAccessor: string]: TableRepository | NeoOrmClient["sql"] | NeoOrmClient["execute"] | NeoOrmClient["$disconnect"];
|
|
57
70
|
}
|
|
58
|
-
export declare function createNeoOrmClient<TTables extends Record<string, TableDef>, TIncludes extends Record<keyof TTables & string, unknown> = DefaultWithMap<TTables>>(manifest: Manifest, connectionString?: string): TypedNeoOrmClient<TTables, TIncludes>;
|
|
59
|
-
export declare function createNeoOrmClientFromPool<TTables extends Record<string, TableDef>, TIncludes extends Record<keyof TTables & string, unknown> = DefaultWithMap<TTables>>(manifest: Manifest, pool: Pool): TypedNeoOrmClient<TTables, TIncludes>;
|
|
60
|
-
export type { TypedNeoOrmClient, TypedTableRepository, DefaultWithMap } from "./types.js";
|
|
71
|
+
export declare function createNeoOrmClient<TTables extends Record<string, TableDef>, TIncludes extends Record<keyof TTables & string, unknown> = DefaultWithMap<TTables>, TRowPayloads extends Record<keyof TTables & string, Record<string, unknown>> = DefaultRowPayloadMap<TTables>>(manifest: Manifest, connectionString?: string): TypedNeoOrmClient<TTables, TIncludes, TRowPayloads>;
|
|
72
|
+
export declare function createNeoOrmClientFromPool<TTables extends Record<string, TableDef>, TIncludes extends Record<keyof TTables & string, unknown> = DefaultWithMap<TTables>, TRowPayloads extends Record<keyof TTables & string, Record<string, unknown>> = DefaultRowPayloadMap<TTables>>(manifest: Manifest, pool: Pool): TypedNeoOrmClient<TTables, TIncludes, TRowPayloads>;
|
|
73
|
+
export type { TypedNeoOrmClient, TypedTableRepository, DefaultWithMap, DefaultRowPayloadMap } from "./types.js";
|
|
61
74
|
//# sourceMappingURL=client.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"client.d.ts","sourceRoot":"","sources":["../../src/runtime/client.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,IAAI,EAAE,MAAM,IAAI,CAAC;AAC1B,OAAO,KAAK,EAAE,QAAQ,EAAE,MAAM,qBAAqB,CAAC;AACpD,OAAO,KAAK,EAAE,QAAQ,EAAE,MAAM,oBAAoB,CAAC;
|
|
1
|
+
{"version":3,"file":"client.d.ts","sourceRoot":"","sources":["../../src/runtime/client.ts"],"names":[],"mappings":"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"}
|
package/dist/runtime/client.js
CHANGED
|
@@ -1,20 +1,26 @@
|
|
|
1
1
|
import { Pool } from "pg";
|
|
2
|
+
import { ensurePlugins } from "../plugins/ensure-plugins.js";
|
|
2
3
|
import { createExecutor, compileQuery } from "./executor.js";
|
|
3
4
|
import { findMany, findFirst, findById } from "./query/find.js";
|
|
5
|
+
import { countRecords, findUnique } from "./query/count.js";
|
|
4
6
|
import { createRecord } from "./query/create.js";
|
|
7
|
+
import { upsertRecord } from "./query/upsert.js";
|
|
5
8
|
import { updateRecord, updateManyRecords, updateById } from "./query/update.js";
|
|
6
9
|
import { deleteRecord, deleteManyRecords, deleteById } from "./query/delete.js";
|
|
7
10
|
function createTableRepository(executor, manifest, accessor) {
|
|
8
11
|
return {
|
|
9
12
|
findMany: (args) => findMany(executor, manifest, accessor, args),
|
|
10
13
|
findFirst: (args) => findFirst(executor, manifest, accessor, args),
|
|
14
|
+
findUnique: (args) => findUnique(executor, manifest, accessor, args),
|
|
11
15
|
findById: (id, args) => findById(executor, manifest, accessor, id, args),
|
|
12
16
|
create: (args) => createRecord(executor, manifest, accessor, args),
|
|
17
|
+
upsert: (args) => upsertRecord(executor, manifest, accessor, args),
|
|
13
18
|
update: (args) => updateRecord(executor, manifest, accessor, args),
|
|
14
19
|
updateMany: (args) => updateManyRecords(executor, manifest, accessor, args),
|
|
15
20
|
updateById: (id, args) => updateById(executor, manifest, accessor, id, args),
|
|
16
21
|
delete: (args) => deleteRecord(executor, manifest, accessor, args),
|
|
17
22
|
deleteMany: (args) => deleteManyRecords(executor, manifest, accessor, args),
|
|
23
|
+
count: (args) => countRecords(executor, manifest, accessor, args),
|
|
18
24
|
deleteById: (id) => deleteById(executor, manifest, accessor, id),
|
|
19
25
|
};
|
|
20
26
|
}
|
|
@@ -35,6 +41,7 @@ function buildClient(executor, manifest, disconnect) {
|
|
|
35
41
|
return client;
|
|
36
42
|
}
|
|
37
43
|
export function createNeoOrmClient(manifest, connectionString) {
|
|
44
|
+
ensurePlugins(manifest);
|
|
38
45
|
const url = connectionString ?? process.env["DATABASE_URL"];
|
|
39
46
|
if (!url) {
|
|
40
47
|
throw new Error("DATABASE_URL is required");
|
|
@@ -46,6 +53,7 @@ export function createNeoOrmClient(manifest, connectionString) {
|
|
|
46
53
|
});
|
|
47
54
|
}
|
|
48
55
|
export function createNeoOrmClientFromPool(manifest, pool) {
|
|
56
|
+
ensurePlugins(manifest);
|
|
49
57
|
const executor = createExecutor(pool);
|
|
50
58
|
return buildClient(executor, manifest, async () => {
|
|
51
59
|
await pool.end();
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"client.js","sourceRoot":"","sources":["../../src/runtime/client.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,IAAI,EAAE,MAAM,IAAI,CAAC;AAG1B,OAAO,EAAE,cAAc,EAAE,YAAY,EAAiB,MAAM,eAAe,CAAC;AAC5E,OAAO,EAAE,QAAQ,EAAE,SAAS,EAAE,QAAQ,EAAE,MAAM,iBAAiB,CAAC;AAChE,OAAO,EAAE,YAAY,EAAE,MAAM,mBAAmB,CAAC;AACjD,OAAO,EAAE,YAAY,EAAE,iBAAiB,EAAE,UAAU,EAAE,MAAM,mBAAmB,CAAC;AAChF,OAAO,EAAE,YAAY,EAAE,iBAAiB,EAAE,UAAU,EAAE,MAAM,mBAAmB,CAAC;
|
|
1
|
+
{"version":3,"file":"client.js","sourceRoot":"","sources":["../../src/runtime/client.ts"],"names":[],"mappings":"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"}
|
|
@@ -9,6 +9,8 @@ export declare function normalizeSelectColumns(select?: readonly string[] | Reco
|
|
|
9
9
|
export declare function buildSelectColumns(table: ManifestTable, select?: readonly string[]): string;
|
|
10
10
|
export declare function buildFindByIdQuery(table: ManifestTable, idColumn?: string): string;
|
|
11
11
|
export declare function buildFindManyQuery(table: ManifestTable, whereSql: string, orderSql: string, limit?: number, offset?: number): string;
|
|
12
|
+
export declare function buildCountQuery(table: ManifestTable, whereSql: string): string;
|
|
13
|
+
export declare function buildUpsertQuery(table: ManifestTable, insertKeys: string[], updateKeys: string[], conflictSqlColumns: readonly string[]): string;
|
|
12
14
|
export declare function buildInsertQuery(table: ManifestTable, dataKeys: string[]): string;
|
|
13
15
|
export declare function buildUpdateQuery(table: ManifestTable, dataKeys: string[], whereSql: string): string;
|
|
14
16
|
export declare function buildDeleteQuery(table: ManifestTable, whereSql: string): string;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"compile.d.ts","sourceRoot":"","sources":["../../../src/runtime/query/compile.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,OAAO,EAAkB,aAAa,EAAiB,MAAM,wBAAwB,CAAC;
|
|
1
|
+
{"version":3,"file":"compile.d.ts","sourceRoot":"","sources":["../../../src/runtime/query/compile.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,OAAO,EAAkB,aAAa,EAAiB,MAAM,wBAAwB,CAAC;AAKpG,MAAM,MAAM,WAAW,GAAG;IACxB,GAAG,EAAE,MAAM,CAAC;IACZ,MAAM,EAAE,OAAO,EAAE,CAAC;CACnB,CAAC;AA+CF,wBAAgB,YAAY,CAC1B,KAAK,EAAE,aAAa,EACpB,KAAK,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,GAAG,SAAS,EAC1C,OAAO,EAAE,OAAO,EAChB,eAAe,SAAI,GAClB,WAAW,CA0Db;AAED,wBAAgB,cAAc,CAC5B,KAAK,EAAE,aAAa,EACpB,OAAO,EAAE,MAAM,CAAC,MAAM,EAAE,MAAM,CAAC,GAAG,SAAS,GAC1C,MAAM,CAYR;AAED,wBAAgB,sBAAsB,CACpC,MAAM,CAAC,EAAE,SAAS,MAAM,EAAE,GAAG,MAAM,CAAC,MAAM,EAAE,OAAO,GAAG,SAAS,CAAC,GAC/D,SAAS,MAAM,EAAE,GAAG,SAAS,CAM/B;AAaD,wBAAgB,kBAAkB,CAAC,KAAK,EAAE,aAAa,EAAE,MAAM,CAAC,EAAE,SAAS,MAAM,EAAE,GAAG,MAAM,CAO3F;AAED,wBAAgB,kBAAkB,CAChC,KAAK,EAAE,aAAa,EACpB,QAAQ,SAAO,GACd,MAAM,CAKR;AAED,wBAAgB,kBAAkB,CAChC,KAAK,EAAE,aAAa,EACpB,QAAQ,EAAE,MAAM,EAChB,QAAQ,EAAE,MAAM,EAChB,KAAK,CAAC,EAAE,MAAM,EACd,MAAM,CAAC,EAAE,MAAM,GACd,MAAM,CAUR;AAED,wBAAgB,eAAe,CAAC,KAAK,EAAE,aAAa,EAAE,QAAQ,EAAE,MAAM,GAAG,MAAM,CAI9E;AAED,wBAAgB,gBAAgB,CAC9B,KAAK,EAAE,aAAa,EACpB,UAAU,EAAE,MAAM,EAAE,EACpB,UAAU,EAAE,MAAM,EAAE,EACpB,kBAAkB,EAAE,SAAS,MAAM,EAAE,GACpC,MAAM,CA4BR;AAED,wBAAgB,gBAAgB,CAC9B,KAAK,EAAE,aAAa,EACpB,QAAQ,EAAE,MAAM,EAAE,GACjB,MAAM,CAcR;AAED,wBAAgB,gBAAgB,CAC9B,KAAK,EAAE,aAAa,EACpB,QAAQ,EAAE,MAAM,EAAE,EAClB,QAAQ,EAAE,MAAM,GACf,MAAM,CAiBR;AAED,wBAAgB,gBAAgB,CAC9B,KAAK,EAAE,aAAa,EACpB,QAAQ,EAAE,MAAM,GACf,MAAM,CAMR;AAED,wBAAgB,oBAAoB,CAClC,KAAK,EAAE,aAAa,EACpB,QAAQ,EAAE,MAAM,GACf,MAAM,CAIR;AAED,wBAAgB,oBAAoB,CAClC,KAAK,EAAE,aAAa,EACpB,QAAQ,EAAE,MAAM,EAAE,EAClB,QAAQ,EAAE,MAAM,GACf,MAAM,CAeR;AAED,wBAAgB,eAAe,CAC7B,KAAK,EAAE,aAAa,EACpB,IAAI,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,GAC5B;IAAE,IAAI,EAAE,MAAM,EAAE,CAAC;IAAC,MAAM,EAAE,OAAO,EAAE,CAAA;CAAE,CAavC;AAED,wBAAgB,OAAO,CAAC,KAAK,EAAE,aAAa,EAAE,GAAG,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,GAAG,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,CAgBnG;AAED,wBAAgB,QAAQ,CACtB,KAAK,EAAE,aAAa,EACpB,IAAI,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,EAAE,GAC9B,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,EAAE,CAE3B"}
|