quickbooks-api
Version:
A modular TypeScript SDK for seamless integration with Intuit QuickBooks APIs. Provides robust authentication handling and future-ready foundation for accounting, payments, and commerce operations.
51 lines (41 loc) • 1.59 kB
text/typescript
// Import the Query Builder
import { QuickbooksError, type Estimate, type EstimateOptions, type SearchResponse } from '../../../../types/types';
import { EstimateAPI } from '../estimate-api';
import { ApiClient } from '../../api-client';
/**
* Get Estimates for a Date Range
* @param this - The Estimate API
* @param startDate - The start date
* @param endDate - The end date
* @returns The Estimates
*/
export async function getEstimatesForDateRange(
this: EstimateAPI,
startDate: Date,
endDate: Date,
options: EstimateOptions = {},
): Promise<SearchResponse<Estimate>> {
// Ensure the Start Date is Before the End Date
if (startDate > endDate) throw new QuickbooksError('Start date must be before end date', await ApiClient.getIntuitErrorDetails(null));
// Get the Query Builder
const queryBuilder = await this.getQueryBuilder();
// Setup the Date Range Filters
queryBuilder.whereLastUpdatedAfter(startDate);
queryBuilder.whereLastUpdatedBefore(endDate);
// Setup the Search Options (if provided)
if (options.searchOptions) queryBuilder.setSearchOptions(options.searchOptions);
// Setup the URL
const url = queryBuilder.build();
// Get the Estimates
const { responseData, intuitTID } = await this.apiClient.runRequest(url, { method: 'GET' });
// Format the Response
const estimates = await this.formatResponse(responseData);
// Setup the Search Response
const searchResponse: SearchResponse<Estimate> = {
results: estimates,
hasNextPage: await this.hasNextPage(queryBuilder),
intuitTID,
};
// Return the Estimates
return searchResponse;
}