@genome-spy/core 0.75.0 → 0.77.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/bundle/browser-KWU9rWZT.js +123 -0
- package/dist/bundle/{esm-CgfVIRJ-.js → esm-0dYHNV_D.js} +2 -2
- package/dist/bundle/{esm-sIoQYZ21.js → esm-CRMf_I9V.js} +18 -18
- package/dist/bundle/esm-CT3ygiMq.js +1084 -0
- package/dist/bundle/{esm-DQiq2Zhd.js → esm-CscjKVDc.js} +44 -44
- package/dist/bundle/index.es.js +3408 -3185
- package/dist/bundle/index.js +106 -97
- package/dist/schema.json +352 -0
- package/dist/src/config/defaults/markDefaults.d.ts.map +1 -1
- package/dist/src/config/defaults/markDefaults.js +1 -12
- package/dist/src/config/defaults/scaleDefaults.d.ts.map +1 -1
- package/dist/src/config/defaults/scaleDefaults.js +1 -0
- package/dist/src/config/markConfig.d.ts.map +1 -1
- package/dist/src/config/markConfig.js +16 -8
- package/dist/src/config/themes.d.ts.map +1 -1
- package/dist/src/config/themes.js +15 -2
- package/dist/src/data/sources/lazy/bigWigSource.d.ts.map +1 -1
- package/dist/src/data/sources/lazy/bigWigSource.js +31 -11
- package/dist/src/data/sources/lazy/registerBuiltInLazySources.js +2 -2
- package/dist/src/data/sources/lazy/registerCoreLazySources.d.ts +2 -0
- package/dist/src/data/sources/lazy/registerCoreLazySources.d.ts.map +1 -0
- package/dist/src/data/sources/lazy/registerCoreLazySources.js +2 -0
- package/dist/src/data/sources/lazy/singleAxisWindowedSource.d.ts +19 -3
- package/dist/src/data/sources/lazy/singleAxisWindowedSource.d.ts.map +1 -1
- package/dist/src/data/sources/lazy/singleAxisWindowedSource.js +34 -13
- package/dist/src/data/sources/lazy/tabixSource.d.ts +7 -0
- package/dist/src/data/sources/lazy/tabixSource.d.ts.map +1 -1
- package/dist/src/data/sources/lazy/tabixSource.js +18 -0
- package/dist/src/data/sources/lazy/tabixTsvSource.d.ts +37 -0
- package/dist/src/data/sources/lazy/tabixTsvSource.d.ts.map +1 -0
- package/dist/src/data/sources/lazy/tabixTsvSource.js +163 -0
- package/dist/src/data/transforms/filterScoredLabels.d.ts.map +1 -1
- package/dist/src/data/transforms/filterScoredLabels.js +3 -2
- package/dist/src/embedFactory.d.ts.map +1 -1
- package/dist/src/embedFactory.js +2 -0
- package/dist/src/genomeSpy/viewContextFactory.d.ts.map +1 -1
- package/dist/src/genomeSpy/viewContextFactory.js +1 -0
- package/dist/src/genomeSpyBase.d.ts +6 -0
- package/dist/src/genomeSpyBase.d.ts.map +1 -1
- package/dist/src/genomeSpyBase.js +15 -1
- package/dist/src/gl/webGLHelper.d.ts +5 -2
- package/dist/src/gl/webGLHelper.d.ts.map +1 -1
- package/dist/src/gl/webGLHelper.js +20 -3
- package/dist/src/index.d.ts +1 -0
- package/dist/src/index.d.ts.map +1 -1
- package/dist/src/index.js +1 -0
- package/dist/src/marks/__snapshots__/shaderSnapshot.test.js.snap +1084 -2
- package/dist/src/marks/link.vertex.glsl.js +1 -1
- package/dist/src/marks/mark.d.ts.map +1 -1
- package/dist/src/marks/mark.js +0 -6
- package/dist/src/marks/rect.vertex.glsl.js +1 -1
- package/dist/src/minimal.d.ts +1 -0
- package/dist/src/minimal.d.ts.map +1 -1
- package/dist/src/minimal.js +6 -4
- package/dist/src/paramRuntime/embedParamApi.d.ts +26 -0
- package/dist/src/paramRuntime/embedParamApi.d.ts.map +1 -0
- package/dist/src/paramRuntime/embedParamApi.js +133 -0
- package/dist/src/scale/scale.js +10 -2
- package/dist/src/scales/domainPlanner.js +1 -1
- package/dist/src/scales/scaleInteractionController.d.ts +8 -4
- package/dist/src/scales/scaleInteractionController.d.ts.map +1 -1
- package/dist/src/scales/scaleInteractionController.js +55 -7
- package/dist/src/scales/scaleResolution.d.ts +3 -3
- package/dist/src/scales/scaleResolution.d.ts.map +1 -1
- package/dist/src/scales/scaleResolution.js +14 -7
- package/dist/src/scales/selectionDomainUtils.d.ts +10 -0
- package/dist/src/scales/selectionDomainUtils.d.ts.map +1 -1
- package/dist/src/scales/selectionDomainUtils.js +32 -3
- package/dist/src/selection/index.d.ts +8 -0
- package/dist/src/selection/index.d.ts.map +1 -0
- package/dist/src/selection/index.js +12 -0
- package/dist/src/spec/channel.d.ts +30 -0
- package/dist/src/spec/data.d.ts +40 -0
- package/dist/src/spec/parameter.d.ts +6 -0
- package/dist/src/spec/transform.d.ts +6 -0
- package/dist/src/styles/genome-spy.css +8 -0
- package/dist/src/styles/genome-spy.css.d.ts +1 -1
- package/dist/src/styles/genome-spy.css.d.ts.map +1 -1
- package/dist/src/styles/genome-spy.css.js +8 -0
- package/dist/src/types/embedApi.d.ts +54 -0
- package/dist/src/types/scaleResolutionApi.d.ts +28 -1
- package/dist/src/types/viewContext.d.ts +11 -0
- package/dist/src/utils/ui/tooltip.d.ts.map +1 -1
- package/dist/src/utils/ui/tooltip.js +22 -0
- package/dist/src/view/axisGridView.d.ts.map +1 -1
- package/dist/src/view/axisGridView.js +2 -1
- package/dist/src/view/axisView.d.ts.map +1 -1
- package/dist/src/view/axisView.js +2 -1
- package/dist/src/view/facetView.d.ts.map +1 -1
- package/dist/src/view/facetView.js +2 -1
- package/dist/src/view/gridView/gridChild.d.ts.map +1 -1
- package/dist/src/view/gridView/gridChild.js +9 -1
- package/dist/src/view/gridView/gridView.d.ts.map +1 -1
- package/dist/src/view/gridView/gridView.js +198 -32
- package/dist/src/view/gridView/scrollbar.d.ts.map +1 -1
- package/dist/src/view/gridView/scrollbar.js +5 -1
- package/dist/src/view/gridView/selectionRect.d.ts.map +1 -1
- package/dist/src/view/gridView/selectionRect.js +5 -1
- package/dist/src/view/gridView/separatorView.d.ts.map +1 -1
- package/dist/src/view/gridView/separatorView.js +5 -1
- package/dist/src/view/testUtils.d.ts +30 -3
- package/dist/src/view/testUtils.d.ts.map +1 -1
- package/dist/src/view/testUtils.js +51 -2
- package/dist/src/view/viewSelectors.d.ts +38 -10
- package/dist/src/view/viewSelectors.d.ts.map +1 -1
- package/dist/src/view/viewSelectors.js +67 -2
- package/dist/src/view/viewUtilTypes.d.ts +15 -0
- package/dist/src/view/viewUtils.d.ts.map +1 -1
- package/dist/src/view/viewUtils.js +10 -0
- package/package.json +3 -3
- package/dist/bundle/browser-BTgw5ieH.js +0 -126
- package/dist/bundle/esm-DtE8VqAv.js +0 -1015
- /package/dist/bundle/{esm-BDFRLEuD.js → esm-C49STiCR.js} +0 -0
- /package/dist/bundle/{esm-CGX-qz1d.js → esm-CuVa5T98.js} +0 -0
|
@@ -13,13 +13,15 @@ import {
|
|
|
13
13
|
*/
|
|
14
14
|
|
|
15
15
|
/**
|
|
16
|
-
* @typedef {
|
|
17
|
-
* @typedef {
|
|
16
|
+
* @typedef {import("./viewUtilTypes.d.ts").ViewSelector} ViewSelector
|
|
17
|
+
* @typedef {import("./viewUtilTypes.d.ts").ParamSelector} ParamSelector
|
|
18
18
|
* @typedef {{ view: import("./view.js").default, param: import("../spec/parameter.js").Parameter, selector: ParamSelector }} BookmarkableParamEntry
|
|
19
19
|
* @typedef {{ message: string, scope: string[] }} SelectorValidationIssue
|
|
20
20
|
* @typedef {{ name: string | null }} ImportScopeInfo
|
|
21
21
|
* @typedef {"exclude" | "excludeSubtree"} AddressableOverride
|
|
22
|
+
* @typedef {"exclude" | "excludeSubtree"} ChromeOverride
|
|
22
23
|
* @typedef {{ skipSubtree?: boolean }} AddressableOptions
|
|
24
|
+
* @typedef {{ skipSubtree?: boolean }} ChromeOptions
|
|
23
25
|
* @typedef {{ view: import("./view.js").default, param: import("../spec/parameter.js").Parameter }} ResolvedParam
|
|
24
26
|
*/
|
|
25
27
|
|
|
@@ -31,6 +33,9 @@ const importScopes = new WeakMap();
|
|
|
31
33
|
/** @type {WeakMap<import("./view.js").default, AddressableOverride>} */
|
|
32
34
|
const addressableOverrides = new WeakMap();
|
|
33
35
|
|
|
36
|
+
/** @type {WeakMap<import("./view.js").default, ChromeOverride>} */
|
|
37
|
+
const chromeOverrides = new WeakMap();
|
|
38
|
+
|
|
34
39
|
/**
|
|
35
40
|
* Marks a view as the root of an import scope.
|
|
36
41
|
*
|
|
@@ -67,6 +72,28 @@ export function markViewAsNonAddressable(view, options = {}) {
|
|
|
67
72
|
addressableOverrides.set(view, behavior);
|
|
68
73
|
}
|
|
69
74
|
|
|
75
|
+
/**
|
|
76
|
+
* Marks a view as decorative chrome.
|
|
77
|
+
*
|
|
78
|
+
* @param {import("./view.js").default} view
|
|
79
|
+
* @param {ChromeOptions} [options]
|
|
80
|
+
*/
|
|
81
|
+
export function markViewAsChrome(view, options = {}) {
|
|
82
|
+
const skipSubtree = options.skipSubtree ?? false;
|
|
83
|
+
const behavior = skipSubtree ? "excludeSubtree" : "exclude";
|
|
84
|
+
chromeOverrides.set(view, behavior);
|
|
85
|
+
}
|
|
86
|
+
|
|
87
|
+
/**
|
|
88
|
+
* Returns whether a view has been marked as decorative chrome.
|
|
89
|
+
*
|
|
90
|
+
* @param {import("./view.js").default} view
|
|
91
|
+
* @returns {boolean}
|
|
92
|
+
*/
|
|
93
|
+
export function isChromeView(view) {
|
|
94
|
+
return chromeOverrides.has(view);
|
|
95
|
+
}
|
|
96
|
+
|
|
70
97
|
/**
|
|
71
98
|
* Returns the import scope chain for a view, using named import instances.
|
|
72
99
|
*
|
|
@@ -158,6 +185,44 @@ export function getAddressableViews(root) {
|
|
|
158
185
|
return views;
|
|
159
186
|
}
|
|
160
187
|
|
|
188
|
+
/**
|
|
189
|
+
* Visits all non-chrome views in the hierarchy.
|
|
190
|
+
*
|
|
191
|
+
* @param {import("./view.js").default} root
|
|
192
|
+
* @param {import("./view.js").Visitor} visitor
|
|
193
|
+
*/
|
|
194
|
+
export function visitNonChromeViews(root, visitor) {
|
|
195
|
+
root.visit((view) => {
|
|
196
|
+
const behavior = chromeOverrides.get(view);
|
|
197
|
+
if (behavior === "excludeSubtree") {
|
|
198
|
+
return VISIT_SKIP;
|
|
199
|
+
}
|
|
200
|
+
|
|
201
|
+
if (behavior === "exclude") {
|
|
202
|
+
return;
|
|
203
|
+
}
|
|
204
|
+
|
|
205
|
+
return visitor(view);
|
|
206
|
+
});
|
|
207
|
+
}
|
|
208
|
+
|
|
209
|
+
/**
|
|
210
|
+
* Returns non-chrome views in the hierarchy.
|
|
211
|
+
*
|
|
212
|
+
* @param {import("./view.js").default} root
|
|
213
|
+
* @returns {import("./view.js").default[]}
|
|
214
|
+
*/
|
|
215
|
+
export function getNonChromeViews(root) {
|
|
216
|
+
/** @type {import("./view.js").default[]} */
|
|
217
|
+
const views = [];
|
|
218
|
+
|
|
219
|
+
visitNonChromeViews(root, (view) => {
|
|
220
|
+
views.push(view);
|
|
221
|
+
});
|
|
222
|
+
|
|
223
|
+
return views;
|
|
224
|
+
}
|
|
225
|
+
|
|
161
226
|
/**
|
|
162
227
|
* Visits all addressable views in the hierarchy.
|
|
163
228
|
*
|
|
@@ -0,0 +1,15 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Structured view address used by selectors.
|
|
3
|
+
*/
|
|
4
|
+
export interface ViewSelector {
|
|
5
|
+
scope: string[];
|
|
6
|
+
view: string;
|
|
7
|
+
}
|
|
8
|
+
|
|
9
|
+
/**
|
|
10
|
+
* Structured parameter address used by selectors.
|
|
11
|
+
*/
|
|
12
|
+
export interface ParamSelector {
|
|
13
|
+
scope: string[];
|
|
14
|
+
param: string;
|
|
15
|
+
}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"viewUtils.d.ts","sourceRoot":"","sources":["../../../src/view/viewUtils.js"],"names":[],"mappings":"AAUA;;;;GAIG;AACH,qCAHW,OAAO,oBAAoB,EAAE,UAAU,GAAG,OAAO,iBAAiB,EAAE,YAAY,GAC9E,IAAI,IAAI,aAAa,CAIjC;AAED;;;;GAIG;AACH,oCAHW,OAAO,oBAAoB,EAAE,aAAa,GAAG,OAAO,iBAAiB,EAAE,YAAY,GACjF,IAAI,IAAI,YAAY,CAOhC;AAED;;;GAGG;AACH,+BAFW,IAAI,6EAMd;AAED;;;;GAIG;AACH,wCAFW,IAAI,8CASd;AAED;;GAEG;AACH,kDAFW,IAAI,QAiBd;AAED;;;;;;;GAOG;AACH,4CAFW,IAAI,QAUd;AAED;;;;GAIG;AACH,0DAJW,OAAO,CAAC,OAAO,kBAAkB,EAAE,OAAO,CAAC,EAAE,mBAC7C,MAAM,OAAO,GACX,OAAO,CAAC,IAAI,CAAC,CAmBzB;AAED;;;GAGG;AACH,wCAFW,IAAI;UAGO,QAAQ;aAAW,OAAO,oBAAoB,EAAE,OAAO;WAAS,OAAO,oBAAoB,EAAE,KAAK;UAAQ,OAAO,oBAAoB,EAAE,IAAI;
|
|
1
|
+
{"version":3,"file":"viewUtils.d.ts","sourceRoot":"","sources":["../../../src/view/viewUtils.js"],"names":[],"mappings":"AAUA;;;;GAIG;AACH,qCAHW,OAAO,oBAAoB,EAAE,UAAU,GAAG,OAAO,iBAAiB,EAAE,YAAY,GAC9E,IAAI,IAAI,aAAa,CAIjC;AAED;;;;GAIG;AACH,oCAHW,OAAO,oBAAoB,EAAE,aAAa,GAAG,OAAO,iBAAiB,EAAE,YAAY,GACjF,IAAI,IAAI,YAAY,CAOhC;AAED;;;GAGG;AACH,+BAFW,IAAI,6EAMd;AAED;;;;GAIG;AACH,wCAFW,IAAI,8CASd;AAED;;GAEG;AACH,kDAFW,IAAI,QAiBd;AAED;;;;;;;GAOG;AACH,4CAFW,IAAI,QAUd;AAED;;;;GAIG;AACH,0DAJW,OAAO,CAAC,OAAO,kBAAkB,EAAE,OAAO,CAAC,EAAE,mBAC7C,MAAM,OAAO,GACX,OAAO,CAAC,IAAI,CAAC,CAmBzB;AAED;;;GAGG;AACH,wCAFW,IAAI;UAGO,QAAQ;aAAW,OAAO,oBAAoB,EAAE,OAAO;WAAS,OAAO,oBAAoB,EAAE,KAAK;UAAQ,OAAO,oBAAoB,EAAE,IAAI;IAkEhK;AAED;;;;;GAKG;AACH,2CALW,OAAO,iBAAiB,EAAE,UAAU,WACpC,MAAM,eACN,OAAO,yBAAyB,EAAE,OAAO,GACvC,OAAO,CAAC,OAAO,iBAAiB,EAAE,QAAQ,CAAC,CAqCvD;AAED;;GAEG;AACH,yCAFW,CAAS,IAAI,EAAJ,IAAI,EAAE,IAAM,EAAN,IAAI,EAAE,KAAE,IAAI,+BAkBrC;AAED;;;GAGG;AACH,0CAFW,IAAI,eAqBd;AAED;;GAEG;AACH,8CAFW,OAAO,WAAW,EAAE,OAAO;;;EAoBrC;iBAxS4C,WAAW;qBAFnC,eAAe"}
|
|
@@ -149,6 +149,16 @@ export function findEncodedFields(view) {
|
|
|
149
149
|
definition.type
|
|
150
150
|
),
|
|
151
151
|
});
|
|
152
|
+
} else if (
|
|
153
|
+
isFieldDef(definition) &&
|
|
154
|
+
channel === "semanticScore"
|
|
155
|
+
) {
|
|
156
|
+
fieldInfos.push({
|
|
157
|
+
view,
|
|
158
|
+
channel,
|
|
159
|
+
field: definition.field,
|
|
160
|
+
type: "quantitative",
|
|
161
|
+
});
|
|
152
162
|
}
|
|
153
163
|
|
|
154
164
|
if ("condition" in definition) {
|
package/package.json
CHANGED
|
@@ -7,7 +7,7 @@
|
|
|
7
7
|
},
|
|
8
8
|
"contributors": [],
|
|
9
9
|
"license": "MIT",
|
|
10
|
-
"version": "0.
|
|
10
|
+
"version": "0.77.0",
|
|
11
11
|
"jsdelivr": "dist/bundle/index.js",
|
|
12
12
|
"unpkg": "dist/bundle/index.js",
|
|
13
13
|
"browser": "dist/bundle/index.js",
|
|
@@ -46,7 +46,7 @@
|
|
|
46
46
|
},
|
|
47
47
|
"dependencies": {
|
|
48
48
|
"@gmod/bam": "^7.1.19",
|
|
49
|
-
"@gmod/bbi": "^9.
|
|
49
|
+
"@gmod/bbi": "^9.2.0",
|
|
50
50
|
"@gmod/bed": "^2.1.10",
|
|
51
51
|
"@gmod/indexedfasta": "^5.0.2",
|
|
52
52
|
"@gmod/tabix": "^3.2.2",
|
|
@@ -78,5 +78,5 @@
|
|
|
78
78
|
"devDependencies": {
|
|
79
79
|
"@types/long": "^4.0.1"
|
|
80
80
|
},
|
|
81
|
-
"gitHead": "
|
|
81
|
+
"gitHead": "2851e22e2069a70d7d02e3ab707b7556573aa17e"
|
|
82
82
|
}
|
|
@@ -1,126 +0,0 @@
|
|
|
1
|
-
import { t as e } from "./chunk-DmhlhrBa.js";
|
|
2
|
-
//#region ../../node_modules/generic-filehandle2/esm/blobFile.js
|
|
3
|
-
var t = class {
|
|
4
|
-
constructor(e) {
|
|
5
|
-
this.blob = e;
|
|
6
|
-
}
|
|
7
|
-
async read(e, t = 0) {
|
|
8
|
-
if (!e) return new Uint8Array();
|
|
9
|
-
let n = t, r = n + e, i = this.blob.slice(n, r);
|
|
10
|
-
return i.bytes ? i.bytes() : new Uint8Array(await i.arrayBuffer());
|
|
11
|
-
}
|
|
12
|
-
async readFile(e) {
|
|
13
|
-
let t = typeof e == "string" ? e : e?.encoding;
|
|
14
|
-
if (t === "utf8") return this.blob.text();
|
|
15
|
-
if (t) throw Error(`unsupported encoding: ${t}`);
|
|
16
|
-
return this.blob.bytes ? this.blob.bytes() : new Uint8Array(await this.blob.arrayBuffer());
|
|
17
|
-
}
|
|
18
|
-
async stat() {
|
|
19
|
-
return { size: this.blob.size };
|
|
20
|
-
}
|
|
21
|
-
async close() {}
|
|
22
|
-
};
|
|
23
|
-
//#endregion
|
|
24
|
-
//#region ../../node_modules/generic-filehandle2/esm/remoteFile.js
|
|
25
|
-
function n(e) {
|
|
26
|
-
return (typeof e == "object" && e && "message" in e ? e.message : `${e}`).replace(/\.$/, "");
|
|
27
|
-
}
|
|
28
|
-
var r = class {
|
|
29
|
-
constructor(e, t = {}) {
|
|
30
|
-
this.baseOverrides = {}, this.url = e;
|
|
31
|
-
let n = t.fetch || globalThis.fetch.bind(globalThis);
|
|
32
|
-
t.overrides && (this.baseOverrides = t.overrides), this.fetchImplementation = n;
|
|
33
|
-
}
|
|
34
|
-
async fetch(e, t) {
|
|
35
|
-
let r = (t) => Error(`${n(t)} fetching ${e}`, { cause: t }), i;
|
|
36
|
-
try {
|
|
37
|
-
i = await this.fetchImplementation(e, t);
|
|
38
|
-
} catch (n) {
|
|
39
|
-
if (`${n}`.includes("Failed to fetch")) {
|
|
40
|
-
console.warn(`generic-filehandle: refetching ${e} to attempt to work around chrome CORS header caching bug`);
|
|
41
|
-
try {
|
|
42
|
-
i = await this.fetchImplementation(e, {
|
|
43
|
-
...t,
|
|
44
|
-
cache: "reload"
|
|
45
|
-
});
|
|
46
|
-
} catch (e) {
|
|
47
|
-
throw r(e);
|
|
48
|
-
}
|
|
49
|
-
} else throw r(n);
|
|
50
|
-
}
|
|
51
|
-
return i;
|
|
52
|
-
}
|
|
53
|
-
async read(e, t, n = {}) {
|
|
54
|
-
if (e === 0) return new Uint8Array();
|
|
55
|
-
let { headers: r = {}, signal: i, overrides: a = {} } = n;
|
|
56
|
-
e < Infinity ? r.range = `bytes=${t}-${t + e - 1}` : e === Infinity && t !== 0 && (r.range = `bytes=${t}-`);
|
|
57
|
-
let o = await this.fetch(this.url, {
|
|
58
|
-
...this.baseOverrides,
|
|
59
|
-
...a,
|
|
60
|
-
headers: {
|
|
61
|
-
...this.baseOverrides.headers,
|
|
62
|
-
...a.headers,
|
|
63
|
-
...r
|
|
64
|
-
},
|
|
65
|
-
method: "GET",
|
|
66
|
-
redirect: "follow",
|
|
67
|
-
mode: "cors",
|
|
68
|
-
signal: i
|
|
69
|
-
});
|
|
70
|
-
if (!o.ok) throw Error(`HTTP ${o.status} fetching ${this.url}`);
|
|
71
|
-
if (o.status === 200 && t === 0 || o.status === 206) {
|
|
72
|
-
let t = o.headers.get("content-range"), n = /\/(\d+)$/.exec(t || "");
|
|
73
|
-
n?.[1] && (this._stat = { size: parseInt(n[1], 10) });
|
|
74
|
-
let r = o.bytes ? await o.bytes() : new Uint8Array(await o.arrayBuffer());
|
|
75
|
-
return r.byteLength <= e ? r : r.subarray(0, e);
|
|
76
|
-
}
|
|
77
|
-
throw Error(o.status === 200 ? `${this.url} fetch returned status 200, expected 206` : `HTTP ${o.status} fetching ${this.url}`);
|
|
78
|
-
}
|
|
79
|
-
async readFile(e = {}) {
|
|
80
|
-
let t, n;
|
|
81
|
-
if (typeof e == "string") t = e, n = {};
|
|
82
|
-
else {
|
|
83
|
-
t = e.encoding;
|
|
84
|
-
let { encoding: r, ...i } = e;
|
|
85
|
-
n = i;
|
|
86
|
-
}
|
|
87
|
-
let { headers: r = {}, signal: i, overrides: a = {} } = n, o = await this.fetch(this.url, {
|
|
88
|
-
...this.baseOverrides,
|
|
89
|
-
...a,
|
|
90
|
-
headers: {
|
|
91
|
-
...this.baseOverrides.headers,
|
|
92
|
-
...a.headers,
|
|
93
|
-
...r
|
|
94
|
-
},
|
|
95
|
-
method: "GET",
|
|
96
|
-
redirect: "follow",
|
|
97
|
-
mode: "cors",
|
|
98
|
-
signal: i
|
|
99
|
-
});
|
|
100
|
-
if (!o.ok) throw Error(`HTTP ${o.status} fetching ${this.url}`);
|
|
101
|
-
if (t === "utf8") return o.text();
|
|
102
|
-
if (t) throw Error(`unsupported encoding: ${t}`);
|
|
103
|
-
return o.bytes ? o.bytes() : new Uint8Array(await o.arrayBuffer());
|
|
104
|
-
}
|
|
105
|
-
async stat() {
|
|
106
|
-
if (!this._stat && (await this.read(10, 0), !this._stat)) throw Error(`unable to determine size of file at ${this.url}`);
|
|
107
|
-
return this._stat;
|
|
108
|
-
}
|
|
109
|
-
async close() {}
|
|
110
|
-
}, i = /* @__PURE__ */ e({
|
|
111
|
-
BlobFile: () => t,
|
|
112
|
-
LocalFile: () => a,
|
|
113
|
-
RemoteFile: () => r
|
|
114
|
-
}), a = class {
|
|
115
|
-
readFile() {
|
|
116
|
-
throw Error("unimplemented");
|
|
117
|
-
}
|
|
118
|
-
read() {
|
|
119
|
-
throw Error("unimplemented");
|
|
120
|
-
}
|
|
121
|
-
close() {
|
|
122
|
-
throw Error("unimplemented");
|
|
123
|
-
}
|
|
124
|
-
};
|
|
125
|
-
//#endregion
|
|
126
|
-
export { i as n, r, a as t };
|