From 7b5d0e928a7676c4eecc88c425376cf45296d019 Mon Sep 17 00:00:00 2001 From: Bruce MacDonald Date: Tue, 13 Aug 2024 13:21:57 -0700 Subject: [PATCH] dynamic import of whatwg-fetch to allow environments without it --- src/browser.ts | 22 ++++++++++++++++++---- 1 file changed, 18 insertions(+), 4 deletions(-) diff --git a/src/browser.ts b/src/browser.ts index 40ba369..7bdd1be 100644 --- a/src/browser.ts +++ b/src/browser.ts @@ -1,6 +1,5 @@ import * as utils from './utils.js' import { AbortableAsyncIterator, parseJSON, post } from './utils.js' -import 'whatwg-fetch' import type { ChatRequest, @@ -39,9 +38,24 @@ export class Ollama { this.config.host = utils.formatHost(config?.host ?? 'http://127.0.0.1:11434') } - this.fetch = fetch - if (config?.fetch != null) { - this.fetch = config.fetch + this.fetch = config?.fetch || this.getFetch(); + } + + private getFetch(): Fetch { + if (typeof window !== 'undefined' && window.fetch) { + return window.fetch.bind(window); + } + + if (typeof global !== 'undefined' && global.fetch) { + return global.fetch; + } + + try { + // Use dynamic import to allow for environments where whatwg-fetch is not available + return require('whatwg-fetch'); + } catch (error) { + console.error('Failed to import whatwg-fetch:', error); + throw new Error('Fetch is not available. Please provide a fetch implementation in the config.'); } }