1
import type { Field, RawField } from '@directus/types';
2
import type { Knex } from 'knex';
3
import type { GeoJSONGeometry } from 'wellknown';
4
import { GeometryHelper } from '../types.js';
6
export class GeometryHelperMSSQL extends GeometryHelper {
7
override isTrue(expression: Knex.Raw) {
8
return expression.wrap(``, ` = 1`);
11
override isFalse(expression: Knex.Raw) {
12
return expression.wrap(``, ` = 0`);
15
override createColumn(table: Knex.CreateTableBuilder, field: RawField | Field) {
16
if (field.type.split('.')[1]) {
17
field.meta!.special = [field.type];
20
return table.specificType(field.field, 'geometry');
23
override asText(table: string, column: string): Knex.Raw {
24
return this.knex.raw('??.??.STAsText() as ??', [table, column, column]);
27
override fromText(text: string): Knex.Raw {
28
return this.knex.raw('geometry::STGeomFromText(?, 4326)', text);
31
override _intersects(key: string, geojson: GeoJSONGeometry): Knex.Raw {
32
const geometry = this.fromGeoJSON(geojson);
33
return this.knex.raw('??.STIntersects(?)', [key, geometry]);
36
override _intersects_bbox(key: string, geojson: GeoJSONGeometry): Knex.Raw {
37
const geometry = this.fromGeoJSON(geojson);
38
return this.knex.raw('??.STEnvelope().STIntersects(?.STEnvelope())', [key, geometry]);
41
override collect(table: string, column: string): Knex.Raw {
42
return this.knex.raw('geometry::CollectionAggregate(??.??).STAsText()', [table, column]);