import type { BuildColumns } from "../column-builder.js"; import { entityKind } from "../entity.js"; import type { TypedQueryBuilder } from "../query-builders/query-builder.js"; import type { AddAliasToSelection } from "../query-builders/select.types.js"; import type { ColumnsSelection, SQL } from "../sql/sql.js"; import type { SQLiteColumnBuilderBase } from "./columns/common.js"; import { QueryBuilder } from "./query-builders/query-builder.js"; import { SQLiteViewBase } from "./view-base.js"; export interface ViewBuilderConfig { algorithm?: 'undefined' | 'merge' | 'temptable'; definer?: string; sqlSecurity?: 'definer' | 'invoker'; withCheckOption?: 'cascaded' | 'local'; } export declare class ViewBuilderCore { protected name: TConfig['name']; static readonly [entityKind]: string; readonly _: { readonly name: TConfig['name']; readonly columns: TConfig['columns']; }; constructor(name: TConfig['name']); protected config: ViewBuilderConfig; } export declare class ViewBuilder extends ViewBuilderCore<{ name: TName; }> { static readonly [entityKind]: string; as(qb: TypedQueryBuilder | ((qb: QueryBuilder) => TypedQueryBuilder)): SQLiteViewWithSelection>; } export declare class ManualViewBuilder = Record> extends ViewBuilderCore<{ name: TName; columns: TColumns; }> { static readonly [entityKind]: string; private columns; constructor(name: TName, columns: TColumns); existing(): SQLiteViewWithSelection>; as(query: SQL): SQLiteViewWithSelection>; } export declare class SQLiteView extends SQLiteViewBase { static readonly [entityKind]: string; constructor({ config }: { config: { name: TName; schema: string | undefined; selectedFields: ColumnsSelection; query: SQL | undefined; }; }); } export type SQLiteViewWithSelection = SQLiteView & TSelection; export declare function sqliteView(name: TName): ViewBuilder; export declare function sqliteView>(name: TName, columns: TColumns): ManualViewBuilder; export declare const view: typeof sqliteView;