From 2fbadbab35c9fde548269680ee51818c0c77033c Mon Sep 17 00:00:00 2001 From: Marshall Polaris Date: Tue, 17 Jan 2023 09:36:52 -0800 Subject: [PATCH] Extend typing to make JSON expressions work with `order` --- src/PostgrestTransformBuilder.ts | 16 +++++++++------- 1 file changed, 9 insertions(+), 7 deletions(-) diff --git a/src/PostgrestTransformBuilder.ts b/src/PostgrestTransformBuilder.ts index 624a47f8..8926f112 100644 --- a/src/PostgrestTransformBuilder.ts +++ b/src/PostgrestTransformBuilder.ts @@ -7,6 +7,10 @@ import { PostgrestSingleResponse, } from './types' +/* Extract the column name from a potential JSON accessor expression. */ +type ColumnName = + T extends `${infer TName}->${infer _TRest}` ? TName : T + export default class PostgrestTransformBuilder< Schema extends GenericSchema, Row extends Record, @@ -46,13 +50,11 @@ export default class PostgrestTransformBuilder< return this as unknown as PostgrestTransformBuilder } - order( - column: ColumnName, - options?: { ascending?: boolean; nullsFirst?: boolean; foreignTable?: undefined } - ): this - order( - column: string, - options?: { ascending?: boolean; nullsFirst?: boolean; foreignTable: string } + order>( + column: ColExpr, + options?: ColName extends keyof Row ? + { ascending?: boolean; nullsFirst?: boolean; foreignTable?: string } : + { ascending?: boolean; nullsFirst?: boolean; foreignTable: string } ): this /** * Order the query result by `column`.