UNPKG

@apollo/client

Version:

A fully-featured caching GraphQL client.

125 lines 5.35 kB
import { __assign } from "tslib"; import { Observable } from "../../utilities/index.js"; var OperationBatcher = (function () { function OperationBatcher(_a) { var batchDebounce = _a.batchDebounce, batchInterval = _a.batchInterval, batchMax = _a.batchMax, batchHandler = _a.batchHandler, batchKey = _a.batchKey; this.batchesByKey = new Map(); this.scheduledBatchTimerByKey = new Map(); this.batchDebounce = batchDebounce; this.batchInterval = batchInterval; this.batchMax = batchMax || 0; this.batchHandler = batchHandler; this.batchKey = batchKey || (function () { return ''; }); } OperationBatcher.prototype.enqueueRequest = function (request) { var _this = this; var requestCopy = __assign(__assign({}, request), { next: [], error: [], complete: [], subscribers: new Set() }); var key = this.batchKey(request.operation); if (!requestCopy.observable) { requestCopy.observable = new Observable(function (observer) { var batch = _this.batchesByKey.get(key); if (!batch) _this.batchesByKey.set(key, batch = new Set()); var isFirstEnqueuedRequest = batch.size === 0; var isFirstSubscriber = requestCopy.subscribers.size === 0; requestCopy.subscribers.add(observer); if (isFirstSubscriber) { batch.add(requestCopy); } if (observer.next) { requestCopy.next.push(observer.next.bind(observer)); } if (observer.error) { requestCopy.error.push(observer.error.bind(observer)); } if (observer.complete) { requestCopy.complete.push(observer.complete.bind(observer)); } if (isFirstEnqueuedRequest || _this.batchDebounce) { _this.scheduleQueueConsumption(key); } if (batch.size === _this.batchMax) { _this.consumeQueue(key); } return function () { var _a; if (requestCopy.subscribers.delete(observer) && requestCopy.subscribers.size < 1) { if (batch.delete(requestCopy) && batch.size < 1) { _this.consumeQueue(key); (_a = batch.subscription) === null || _a === void 0 ? void 0 : _a.unsubscribe(); } } }; }); } return requestCopy.observable; }; OperationBatcher.prototype.consumeQueue = function (key) { if (key === void 0) { key = ''; } var batch = this.batchesByKey.get(key); this.batchesByKey.delete(key); if (!batch || !batch.size) { return; } var operations = []; var forwards = []; var observables = []; var nexts = []; var errors = []; var completes = []; batch.forEach(function (request) { operations.push(request.operation); forwards.push(request.forward); observables.push(request.observable); nexts.push(request.next); errors.push(request.error); completes.push(request.complete); }); var batchedObservable = this.batchHandler(operations, forwards) || Observable.of(); var onError = function (error) { errors.forEach(function (rejecters) { if (rejecters) { rejecters.forEach(function (e) { return e(error); }); } }); }; batch.subscription = batchedObservable.subscribe({ next: function (results) { if (!Array.isArray(results)) { results = [results]; } if (nexts.length !== results.length) { var error = new Error("server returned results with length ".concat(results.length, ", expected length of ").concat(nexts.length)); error.result = results; return onError(error); } results.forEach(function (result, index) { if (nexts[index]) { nexts[index].forEach(function (next) { return next(result); }); } }); }, error: onError, complete: function () { completes.forEach(function (complete) { if (complete) { complete.forEach(function (c) { return c(); }); } }); }, }); return observables; }; OperationBatcher.prototype.scheduleQueueConsumption = function (key) { var _this = this; clearTimeout(this.scheduledBatchTimerByKey.get(key)); this.scheduledBatchTimerByKey.set(key, setTimeout(function () { _this.consumeQueue(key); _this.scheduledBatchTimerByKey.delete(key); }, this.batchInterval)); }; return OperationBatcher; }()); export { OperationBatcher }; //# sourceMappingURL=batching.js.map