@treasuryspatial/viewer-kit 0.2.35 → 0.2.36
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/compute/warm.d.ts +19 -0
- package/dist/compute/warm.d.ts.map +1 -0
- package/dist/compute/warm.js +23 -0
- package/dist/uploads/grasshopper.d.ts +1 -0
- package/dist/uploads/grasshopper.d.ts.map +1 -1
- package/dist/uploads/grasshopper.js +10 -0
- package/dist/uploads/index.d.ts +1 -1
- package/dist/uploads/index.d.ts.map +1 -1
- package/dist/uploads/index.js +1 -1
- package/package.json +1 -1
|
@@ -0,0 +1,19 @@
|
|
|
1
|
+
export type ComputeWarmHost = {
|
|
2
|
+
id?: string;
|
|
3
|
+
url: string;
|
|
4
|
+
headers?: Record<string, string>;
|
|
5
|
+
};
|
|
6
|
+
export type ComputeWarmResult = {
|
|
7
|
+
id?: string;
|
|
8
|
+
ok: boolean;
|
|
9
|
+
status?: number;
|
|
10
|
+
error?: string;
|
|
11
|
+
};
|
|
12
|
+
type WarmOptions = {
|
|
13
|
+
endpoint?: string;
|
|
14
|
+
timeoutMs?: number;
|
|
15
|
+
};
|
|
16
|
+
export declare const warmComputeHost: (host: ComputeWarmHost, { endpoint, timeoutMs }?: WarmOptions) => Promise<ComputeWarmResult>;
|
|
17
|
+
export declare const warmComputeHosts: (hosts: ComputeWarmHost[], options?: WarmOptions) => Promise<ComputeWarmResult[]>;
|
|
18
|
+
export {};
|
|
19
|
+
//# sourceMappingURL=warm.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"warm.d.ts","sourceRoot":"","sources":["../../src/compute/warm.ts"],"names":[],"mappings":"AAAA,MAAM,MAAM,eAAe,GAAG;IAC5B,EAAE,CAAC,EAAE,MAAM,CAAC;IACZ,GAAG,EAAE,MAAM,CAAC;IACZ,OAAO,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,MAAM,CAAC,CAAC;CAClC,CAAC;AAEF,MAAM,MAAM,iBAAiB,GAAG;IAC9B,EAAE,CAAC,EAAE,MAAM,CAAC;IACZ,EAAE,EAAE,OAAO,CAAC;IACZ,MAAM,CAAC,EAAE,MAAM,CAAC;IAChB,KAAK,CAAC,EAAE,MAAM,CAAC;CAChB,CAAC;AAEF,KAAK,WAAW,GAAG;IACjB,QAAQ,CAAC,EAAE,MAAM,CAAC;IAClB,SAAS,CAAC,EAAE,MAAM,CAAC;CACpB,CAAC;AAIF,eAAO,MAAM,eAAe,GAC1B,MAAM,eAAe,EACrB,0BAAyC,WAAgB,KACxD,OAAO,CAAC,iBAAiB,CAgB3B,CAAC;AAEF,eAAO,MAAM,gBAAgB,GAC3B,OAAO,eAAe,EAAE,EACxB,UAAU,WAAW,KACpB,OAAO,CAAC,iBAAiB,EAAE,CAE7B,CAAC"}
|
|
@@ -0,0 +1,23 @@
|
|
|
1
|
+
const normalizeBase = (url) => (url.endsWith("/") ? url.slice(0, -1) : url);
|
|
2
|
+
export const warmComputeHost = async (host, { endpoint = "/sdk", timeoutMs = 8000 } = {}) => {
|
|
3
|
+
const base = normalizeBase(host.url);
|
|
4
|
+
const controller = new AbortController();
|
|
5
|
+
const timeout = setTimeout(() => controller.abort(), timeoutMs);
|
|
6
|
+
try {
|
|
7
|
+
const response = await fetch(`${base}${endpoint.startsWith("/") ? endpoint : `/${endpoint}`}`, {
|
|
8
|
+
method: "GET",
|
|
9
|
+
headers: host.headers,
|
|
10
|
+
signal: controller.signal,
|
|
11
|
+
});
|
|
12
|
+
return { id: host.id, ok: response.ok, status: response.status };
|
|
13
|
+
}
|
|
14
|
+
catch (error) {
|
|
15
|
+
return { id: host.id, ok: false, error: error?.message ?? "warmup failed" };
|
|
16
|
+
}
|
|
17
|
+
finally {
|
|
18
|
+
clearTimeout(timeout);
|
|
19
|
+
}
|
|
20
|
+
};
|
|
21
|
+
export const warmComputeHosts = async (hosts, options) => {
|
|
22
|
+
return Promise.all(hosts.map((host) => warmComputeHost(host, options)));
|
|
23
|
+
};
|
|
@@ -7,6 +7,7 @@ export type SolveGrasshopperOptions = {
|
|
|
7
7
|
allowEmptyGeometry?: boolean;
|
|
8
8
|
};
|
|
9
9
|
export declare function solveGrasshopperFile(file: File, { apiRoute, values, preview, onStatus, allowEmptyGeometry }?: SolveGrasshopperOptions): Promise<GrasshopperSolveResult>;
|
|
10
|
+
export declare function warmGrasshopperSolver(file: File, { apiRoute, preview, onStatus, }?: Omit<SolveGrasshopperOptions, "values" | "allowEmptyGeometry">): Promise<GrasshopperSolveResult>;
|
|
10
11
|
export declare const mapGrasshopperInputType: (inputType?: string) => string;
|
|
11
12
|
export declare const buildGrasshopperValues: (inputs: GrasshopperInput[], valuesByKey: Record<string, unknown>, keyResolver?: (input: GrasshopperInput, index: number) => string) => GrasshopperValue[];
|
|
12
13
|
export declare const buildGrasshopperDefaults: (inputs: GrasshopperInput[], keyResolver?: (input: GrasshopperInput, index: number) => string) => Record<string, unknown>;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"grasshopper.d.ts","sourceRoot":"","sources":["../../src/uploads/grasshopper.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,gBAAgB,EAAE,sBAAsB,EAAE,gBAAgB,EAAE,MAAM,SAAS,CAAC;AA0D1F,MAAM,MAAM,uBAAuB,GAAG;IACpC,QAAQ,CAAC,EAAE,MAAM,CAAC;IAClB,MAAM,CAAC,EAAE,gBAAgB,EAAE,CAAC;IAC5B,OAAO,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,CAAC;IAClC,QAAQ,CAAC,EAAE,CAAC,MAAM,EAAE,MAAM,KAAK,IAAI,CAAC;IACpC,kBAAkB,CAAC,EAAE,OAAO,CAAC;CAC9B,CAAC;AAyBF,wBAAsB,oBAAoB,CACxC,IAAI,EAAE,IAAI,EACV,EAAE,QAA0B,EAAE,MAAM,EAAE,OAAO,EAAE,QAAQ,EAAE,kBAAkB,EAAE,GAAE,uBAA4B,GAC1G,OAAO,CAAC,sBAAsB,CAAC,CAsCjC;AAED,eAAO,MAAM,uBAAuB,GAAI,YAAY,MAAM,KAAG,MAM5D,CAAC;AAsBF,eAAO,MAAM,sBAAsB,GACjC,QAAQ,gBAAgB,EAAE,EAC1B,aAAa,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,EACpC,cAAc,CAAC,KAAK,EAAE,gBAAgB,EAAE,KAAK,EAAE,MAAM,KAAK,MAAM,KAC/D,gBAAgB,EAkBlB,CAAC;AAEF,eAAO,MAAM,wBAAwB,GACnC,QAAQ,gBAAgB,EAAE,EAC1B,cAAc,CAAC,KAAK,EAAE,gBAAgB,EAAE,KAAK,EAAE,MAAM,KAAK,MAAM,KAC/D,MAAM,CAAC,MAAM,EAAE,OAAO,CAexB,CAAC"}
|
|
1
|
+
{"version":3,"file":"grasshopper.d.ts","sourceRoot":"","sources":["../../src/uploads/grasshopper.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,gBAAgB,EAAE,sBAAsB,EAAE,gBAAgB,EAAE,MAAM,SAAS,CAAC;AA0D1F,MAAM,MAAM,uBAAuB,GAAG;IACpC,QAAQ,CAAC,EAAE,MAAM,CAAC;IAClB,MAAM,CAAC,EAAE,gBAAgB,EAAE,CAAC;IAC5B,OAAO,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,CAAC;IAClC,QAAQ,CAAC,EAAE,CAAC,MAAM,EAAE,MAAM,KAAK,IAAI,CAAC;IACpC,kBAAkB,CAAC,EAAE,OAAO,CAAC;CAC9B,CAAC;AAyBF,wBAAsB,oBAAoB,CACxC,IAAI,EAAE,IAAI,EACV,EAAE,QAA0B,EAAE,MAAM,EAAE,OAAO,EAAE,QAAQ,EAAE,kBAAkB,EAAE,GAAE,uBAA4B,GAC1G,OAAO,CAAC,sBAAsB,CAAC,CAsCjC;AAED,wBAAsB,qBAAqB,CACzC,IAAI,EAAE,IAAI,EACV,EACE,QAA0B,EAC1B,OAAO,EACP,QAAQ,GACT,GAAE,IAAI,CAAC,uBAAuB,EAAE,QAAQ,GAAG,oBAAoB,CAAM,GACrE,OAAO,CAAC,sBAAsB,CAAC,CASjC;AAED,eAAO,MAAM,uBAAuB,GAAI,YAAY,MAAM,KAAG,MAM5D,CAAC;AAsBF,eAAO,MAAM,sBAAsB,GACjC,QAAQ,gBAAgB,EAAE,EAC1B,aAAa,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,EACpC,cAAc,CAAC,KAAK,EAAE,gBAAgB,EAAE,KAAK,EAAE,MAAM,KAAK,MAAM,KAC/D,gBAAgB,EAkBlB,CAAC;AAEF,eAAO,MAAM,wBAAwB,GACnC,QAAQ,gBAAgB,EAAE,EAC1B,cAAc,CAAC,KAAK,EAAE,gBAAgB,EAAE,KAAK,EAAE,MAAM,KAAK,MAAM,KAC/D,MAAM,CAAC,MAAM,EAAE,OAAO,CAexB,CAAC"}
|
|
@@ -109,6 +109,16 @@ export async function solveGrasshopperFile(file, { apiRoute = "/api/gh-solve", v
|
|
|
109
109
|
}
|
|
110
110
|
return parsed;
|
|
111
111
|
}
|
|
112
|
+
export async function warmGrasshopperSolver(file, { apiRoute = "/api/gh-solve", preview, onStatus, } = {}) {
|
|
113
|
+
const warmPreview = preview ?? { meshOnly: true };
|
|
114
|
+
return solveGrasshopperFile(file, {
|
|
115
|
+
apiRoute,
|
|
116
|
+
values: [],
|
|
117
|
+
preview: warmPreview,
|
|
118
|
+
onStatus,
|
|
119
|
+
allowEmptyGeometry: true,
|
|
120
|
+
});
|
|
121
|
+
}
|
|
112
122
|
export const mapGrasshopperInputType = (inputType) => {
|
|
113
123
|
const normalized = (inputType ?? "").toLowerCase();
|
|
114
124
|
if (normalized === "integer" || normalized === "int")
|
package/dist/uploads/index.d.ts
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
import type { UploadFileKind, UploadLimits } from "./types";
|
|
2
2
|
export type { UploadFileKind, UploadLimits, UploadResult, GrasshopperInput, GrasshopperSolveResult, GrasshopperValue, Geometry3dmSolveResult, Geometry3dmSolveStats, MeshLoadResult, MeshLoadStats, } from "./types";
|
|
3
|
-
export { solveGrasshopperFile, buildGrasshopperValues, buildGrasshopperDefaults, mapGrasshopperInputType } from "./grasshopper";
|
|
3
|
+
export { solveGrasshopperFile, warmGrasshopperSolver, buildGrasshopperValues, buildGrasshopperDefaults, mapGrasshopperInputType, } from "./grasshopper";
|
|
4
4
|
export { solveGeometry3dmFile } from "./geometry3dm";
|
|
5
5
|
export { loadMeshFile } from "./mesh";
|
|
6
6
|
export declare const detectUploadKind: (file: File) => UploadFileKind;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/uploads/index.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,cAAc,EAAE,YAAY,EAAE,MAAM,SAAS,CAAC;AAE5D,YAAY,EACV,cAAc,EACd,YAAY,EACZ,YAAY,EACZ,gBAAgB,EAChB,sBAAsB,EACtB,gBAAgB,EAChB,sBAAsB,EACtB,qBAAqB,EACrB,cAAc,EACd,aAAa,GACd,MAAM,SAAS,CAAC;AACjB,OAAO,
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/uploads/index.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,cAAc,EAAE,YAAY,EAAE,MAAM,SAAS,CAAC;AAE5D,YAAY,EACV,cAAc,EACd,YAAY,EACZ,YAAY,EACZ,gBAAgB,EAChB,sBAAsB,EACtB,gBAAgB,EAChB,sBAAsB,EACtB,qBAAqB,EACrB,cAAc,EACd,aAAa,GACd,MAAM,SAAS,CAAC;AACjB,OAAO,EACL,oBAAoB,EACpB,qBAAqB,EACrB,sBAAsB,EACtB,wBAAwB,EACxB,uBAAuB,GACxB,MAAM,eAAe,CAAC;AACvB,OAAO,EAAE,oBAAoB,EAAE,MAAM,eAAe,CAAC;AACrD,OAAO,EAAE,YAAY,EAAE,MAAM,QAAQ,CAAC;AAEtC,eAAO,MAAM,gBAAgB,GAAI,MAAM,IAAI,KAAG,cAY7C,CAAC;AAEF,eAAO,MAAM,qBAAqB,EAAE,YAGnC,CAAC"}
|
package/dist/uploads/index.js
CHANGED
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
export { solveGrasshopperFile, buildGrasshopperValues, buildGrasshopperDefaults, mapGrasshopperInputType } from "./grasshopper";
|
|
1
|
+
export { solveGrasshopperFile, warmGrasshopperSolver, buildGrasshopperValues, buildGrasshopperDefaults, mapGrasshopperInputType, } from "./grasshopper";
|
|
2
2
|
export { solveGeometry3dmFile } from "./geometry3dm";
|
|
3
3
|
export { loadMeshFile } from "./mesh";
|
|
4
4
|
export const detectUploadKind = (file) => {
|