From e7f5516b4d04c16ed2c12dcc9c9c5f34d9f1f73b Mon Sep 17 00:00:00 2001 From: "John Molakvoæ (skjnldsv)" Date: Sun, 4 Oct 2020 15:33:17 +0200 Subject: Init vue comments tab MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit Signed-off-by: John Molakvoæ (skjnldsv) --- apps/comments/src/utils/cancelableRequest.js | 62 ++++++++++++++++++++++++++++ 1 file changed, 62 insertions(+) create mode 100644 apps/comments/src/utils/cancelableRequest.js (limited to 'apps/comments/src/utils/cancelableRequest.js') diff --git a/apps/comments/src/utils/cancelableRequest.js b/apps/comments/src/utils/cancelableRequest.js new file mode 100644 index 00000000000..425e94a787a --- /dev/null +++ b/apps/comments/src/utils/cancelableRequest.js @@ -0,0 +1,62 @@ +/** + * @copyright Copyright (c) 2020 John Molakvoæ + * + * @author John Molakvoæ + * + * @license GNU AGPL version 3 or any later version + * + * This program is free software: you can redistribute it and/or modify + * it under the terms of the GNU Affero General Public License as + * published by the Free Software Foundation, either version 3 of the + * License, or (at your option) any later version. + * + * This program is distributed in the hope that it will be useful, + * but WITHOUT ANY WARRANTY; without even the implied warranty of + * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the + * GNU Affero General Public License for more details. + * + * You should have received a copy of the GNU Affero General Public License + * along with this program. If not, see . + * + */ + +import axios from '@nextcloud/axios' + +/** + * Create a cancel token + * @returns {CancelTokenSource} + */ +const createCancelToken = () => axios.CancelToken.source() + +/** + * Creates a cancelable axios 'request object'. + * + * @param {function} request the axios promise request + * @returns {Object} + */ +const cancelableRequest = function(request) { + /** + * Generate an axios cancel token + */ + const cancelToken = createCancelToken() + + /** + * Execute the request + * + * @param {string} url the url to send the request to + * @param {Object} [options] optional config for the request + */ + const fetch = async function(url, options) { + return request( + url, + Object.assign({ cancelToken: cancelToken.token }, options) + ) + } + + return { + request: fetch, + cancel: cancelToken.cancel, + } +} + +export default cancelableRequest -- cgit v1.2.3