date.d.ts 2.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051
  1. import type { ColumnBuilderBaseConfig } from "../../column-builder.js";
  2. import type { ColumnBaseConfig } from "../../column.js";
  3. import { entityKind } from "../../entity.js";
  4. import type { AnyMySqlTable } from "../table.js";
  5. import { type Equal } from "../../utils.js";
  6. import { MySqlColumn, MySqlColumnBuilder } from "./common.js";
  7. export type MySqlDateBuilderInitial<TName extends string> = MySqlDateBuilder<{
  8. name: TName;
  9. dataType: 'date';
  10. columnType: 'MySqlDate';
  11. data: Date;
  12. driverParam: string | number;
  13. enumValues: undefined;
  14. }>;
  15. export declare class MySqlDateBuilder<T extends ColumnBuilderBaseConfig<'date', 'MySqlDate'>> extends MySqlColumnBuilder<T> {
  16. static readonly [entityKind]: string;
  17. constructor(name: T['name']);
  18. }
  19. export declare class MySqlDate<T extends ColumnBaseConfig<'date', 'MySqlDate'>> extends MySqlColumn<T> {
  20. static readonly [entityKind]: string;
  21. constructor(table: AnyMySqlTable<{
  22. name: T['tableName'];
  23. }>, config: MySqlDateBuilder<T>['config']);
  24. getSQLType(): string;
  25. mapFromDriverValue(value: string): Date;
  26. }
  27. export type MySqlDateStringBuilderInitial<TName extends string> = MySqlDateStringBuilder<{
  28. name: TName;
  29. dataType: 'string';
  30. columnType: 'MySqlDateString';
  31. data: string;
  32. driverParam: string | number;
  33. enumValues: undefined;
  34. }>;
  35. export declare class MySqlDateStringBuilder<T extends ColumnBuilderBaseConfig<'string', 'MySqlDateString'>> extends MySqlColumnBuilder<T> {
  36. static readonly [entityKind]: string;
  37. constructor(name: T['name']);
  38. }
  39. export declare class MySqlDateString<T extends ColumnBaseConfig<'string', 'MySqlDateString'>> extends MySqlColumn<T> {
  40. static readonly [entityKind]: string;
  41. constructor(table: AnyMySqlTable<{
  42. name: T['tableName'];
  43. }>, config: MySqlDateStringBuilder<T>['config']);
  44. getSQLType(): string;
  45. }
  46. export interface MySqlDateConfig<TMode extends 'date' | 'string' = 'date' | 'string'> {
  47. mode?: TMode;
  48. }
  49. export declare function date(): MySqlDateBuilderInitial<''>;
  50. export declare function date<TMode extends MySqlDateConfig['mode'] & {}>(config?: MySqlDateConfig<TMode>): Equal<TMode, 'string'> extends true ? MySqlDateStringBuilderInitial<''> : MySqlDateBuilderInitial<''>;
  51. export declare function date<TName extends string, TMode extends MySqlDateConfig['mode'] & {}>(name: TName, config?: MySqlDateConfig<TMode>): Equal<TMode, 'string'> extends true ? MySqlDateStringBuilderInitial<TName> : MySqlDateBuilderInitial<TName>;