60 lines
2.5 KiB
TypeScript
60 lines
2.5 KiB
TypeScript
|
/**
|
||
|
* @license
|
||
|
* Copyright 2023 Google LLC
|
||
|
*
|
||
|
* Licensed under the Apache License, Version 2.0 (the "License");
|
||
|
* you may not use this file except in compliance with the License.
|
||
|
* You may obtain a copy of the License at
|
||
|
*
|
||
|
* http://www.apache.org/licenses/LICENSE-2.0
|
||
|
*
|
||
|
* Unless required by applicable law or agreed to in writing, software
|
||
|
* distributed under the License is distributed on an "AS IS" BASIS,
|
||
|
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||
|
* See the License for the specific language governing permissions and
|
||
|
* limitations under the License.
|
||
|
*/
|
||
|
import { Observable } from 'rxjs';
|
||
|
import { DocumentChangeType, DocumentChange, Query, QueryDocumentSnapshot, DocumentData } from '../interfaces';
|
||
|
import { SnapshotOptions } from 'firebase/firestore';
|
||
|
import { CountSnapshot } from '../lite/interfaces';
|
||
|
/**
|
||
|
* Return a stream of document changes on a query. These results are not in sort order but in
|
||
|
* order of occurence.
|
||
|
* @param query
|
||
|
*/
|
||
|
export declare function collectionChanges<T = DocumentData>(query: Query<T>, options?: {
|
||
|
events?: DocumentChangeType[];
|
||
|
}): Observable<DocumentChange<T>[]>;
|
||
|
/**
|
||
|
* Return a stream of document snapshots on a query. These results are in sort order.
|
||
|
* @param query
|
||
|
*/
|
||
|
export declare function collection<T = DocumentData>(query: Query<T>): Observable<QueryDocumentSnapshot<T>[]>;
|
||
|
/**
|
||
|
* Return a stream of document changes on a query. These results are in sort order.
|
||
|
* @param query
|
||
|
*/
|
||
|
export declare function sortedChanges<T = DocumentData>(query: Query<T>, options?: {
|
||
|
events?: DocumentChangeType[];
|
||
|
}): Observable<DocumentChange<T>[]>;
|
||
|
/**
|
||
|
* Create a stream of changes as they occur it time. This method is similar
|
||
|
* to docChanges() but it collects each event in an array over time.
|
||
|
*/
|
||
|
export declare function auditTrail<T = DocumentData>(query: Query<T>, options?: {
|
||
|
events?: DocumentChangeType[];
|
||
|
}): Observable<DocumentChange<T>[]>;
|
||
|
/**
|
||
|
* Returns a stream of documents mapped to their data payload, and optionally the document ID
|
||
|
* @param query
|
||
|
* @param options
|
||
|
*/
|
||
|
export declare function collectionData<T = DocumentData, U extends string = never>(query: Query<T>, options?: {
|
||
|
idField?: ((U | keyof T) & keyof NonNullable<T>);
|
||
|
} & SnapshotOptions): Observable<((T & {
|
||
|
[T in U]: string;
|
||
|
}) | NonNullable<T>)[]>;
|
||
|
export declare function collectionCountSnap(query: Query<unknown>): Observable<CountSnapshot>;
|
||
|
export declare function collectionCount(query: Query<unknown>): Observable<number>;
|