@deephaven/jsapi-bootstrap 0.60.1-object-fetcher.0 → 0.60.1-object-fetcher.7

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.
@@ -1,15 +1,15 @@
1
1
  import React from 'react';
2
- import { ObjectMetadata } from './useObjectFetcher';
2
+ import { VariableDescriptor } from '@deephaven/jsapi-types';
3
3
  type DeferredApiBootstrapProps = React.PropsWithChildren<{
4
4
  onError?: (error: unknown) => void;
5
5
  /**
6
6
  * Options to use when fetching the deferred API.
7
7
  */
8
- metadata: ObjectMetadata;
8
+ widget: VariableDescriptor;
9
9
  }>;
10
10
  /**
11
11
  * Does not render children until the deferred API is resolved.
12
12
  */
13
- export declare const DeferredApiBootstrap: React.MemoExoticComponent<({ children, onError, metadata, }: DeferredApiBootstrapProps) => JSX.Element | null>;
13
+ export declare const DeferredApiBootstrap: React.MemoExoticComponent<({ children, onError, widget, }: DeferredApiBootstrapProps) => JSX.Element | null>;
14
14
  export default DeferredApiBootstrap;
15
15
  //# sourceMappingURL=DeferredApiBootstrap.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"DeferredApiBootstrap.d.ts","sourceRoot":"","sources":["../src/DeferredApiBootstrap.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,MAAM,OAAO,CAAC;AAG1B,OAAO,EAAE,cAAc,EAAE,MAAM,oBAAoB,CAAC;AAEpD,KAAK,yBAAyB,GAAG,KAAK,CAAC,iBAAiB,CAAC;IACvD,OAAO,CAAC,EAAE,CAAC,KAAK,EAAE,OAAO,KAAK,IAAI,CAAC;IACnC;;OAEG;IACH,QAAQ,EAAE,cAAc,CAAC;CAC1B,CAAC,CAAC;AAEH;;GAEG;AACH,eAAO,MAAM,oBAAoB,+DAK5B,yBAAyB,KAAG,WAAW,GAAG,IAAI,CAYlD,CAAC;AAIF,eAAe,oBAAoB,CAAC"}
1
+ {"version":3,"file":"DeferredApiBootstrap.d.ts","sourceRoot":"","sources":["../src/DeferredApiBootstrap.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,MAAM,OAAO,CAAC;AAC1B,OAAO,EAAE,kBAAkB,EAAE,MAAM,wBAAwB,CAAC;AAI5D,KAAK,yBAAyB,GAAG,KAAK,CAAC,iBAAiB,CAAC;IACvD,OAAO,CAAC,EAAE,CAAC,KAAK,EAAE,OAAO,KAAK,IAAI,CAAC;IACnC;;OAEG;IACH,MAAM,EAAE,kBAAkB,CAAC;CAC5B,CAAC,CAAC;AAEH;;GAEG;AACH,eAAO,MAAM,oBAAoB,6DAK5B,yBAAyB,KAAG,WAAW,GAAG,IAAI,CAYlD,CAAC;AAIF,eAAe,oBAAoB,CAAC"}
@@ -9,9 +9,9 @@ export var DeferredApiBootstrap = /*#__PURE__*/React.memo(_ref => {
9
9
  var {
10
10
  children,
11
11
  onError,
12
- metadata
12
+ widget
13
13
  } = _ref;
14
- var [api, apiError] = useDeferredApi(metadata);
14
+ var [api, apiError] = useDeferredApi(widget);
15
15
  if (apiError != null) {
16
16
  onError === null || onError === void 0 ? void 0 : onError(apiError);
17
17
  return null;
@@ -1 +1 @@
1
- {"version":3,"file":"DeferredApiBootstrap.js","names":["React","useDeferredApi","ApiContext","jsx","_jsx","DeferredApiBootstrap","memo","_ref","children","onError","metadata","api","apiError","Provider","value","displayName"],"sources":["../src/DeferredApiBootstrap.tsx"],"sourcesContent":["import React from 'react';\nimport useDeferredApi from './useDeferredApi';\nimport { ApiContext } from './ApiBootstrap';\nimport { ObjectMetadata } from './useObjectFetcher';\n\ntype DeferredApiBootstrapProps = React.PropsWithChildren<{\n onError?: (error: unknown) => void;\n /**\n * Options to use when fetching the deferred API.\n */\n metadata: ObjectMetadata;\n}>;\n\n/**\n * Does not render children until the deferred API is resolved.\n */\nexport const DeferredApiBootstrap = React.memo(\n ({\n children,\n onError,\n metadata,\n }: DeferredApiBootstrapProps): JSX.Element | null => {\n const [api, apiError] = useDeferredApi(metadata);\n if (apiError != null) {\n onError?.(apiError);\n return null;\n }\n if (api == null) {\n // Still waiting for the API to load\n return null;\n }\n return <ApiContext.Provider value={api}>{children}</ApiContext.Provider>;\n }\n);\n\nDeferredApiBootstrap.displayName = 'DeferredApiBootstrap';\n\nexport default DeferredApiBootstrap;\n"],"mappings":"AAAA,OAAOA,KAAK,MAAM,OAAO;AAAC,OACnBC,cAAc;AAAA,SACZC,UAAU;AAAA,SAAAC,GAAA,IAAAC,IAAA;AAWnB;AACA;AACA;AACA,OAAO,IAAMC,oBAAoB,gBAAGL,KAAK,CAACM,IAAI,CAC5CC,IAAA,IAIqD;EAAA,IAJpD;IACCC,QAAQ;IACRC,OAAO;IACPC;EACyB,CAAC,GAAAH,IAAA;EAC1B,IAAM,CAACI,GAAG,EAAEC,QAAQ,CAAC,GAAGX,cAAc,CAACS,QAAQ,CAAC;EAChD,IAAIE,QAAQ,IAAI,IAAI,EAAE;IACpBH,OAAO,aAAPA,OAAO,uBAAPA,OAAO,CAAGG,QAAQ,CAAC;IACnB,OAAO,IAAI;EACb;EACA,IAAID,GAAG,IAAI,IAAI,EAAE;IACf;IACA,OAAO,IAAI;EACb;EACA,oBAAOP,IAAA,CAACF,UAAU,CAACW,QAAQ;IAACC,KAAK,EAAEH,GAAI;IAAAH,QAAA,EAAEA;EAAQ,CAAsB,CAAC;AAC1E,CACF,CAAC;AAEDH,oBAAoB,CAACU,WAAW,GAAG,sBAAsB;AAEzD,eAAeV,oBAAoB"}
1
+ {"version":3,"file":"DeferredApiBootstrap.js","names":["React","useDeferredApi","ApiContext","jsx","_jsx","DeferredApiBootstrap","memo","_ref","children","onError","widget","api","apiError","Provider","value","displayName"],"sources":["../src/DeferredApiBootstrap.tsx"],"sourcesContent":["import React from 'react';\nimport { VariableDescriptor } from '@deephaven/jsapi-types';\nimport useDeferredApi from './useDeferredApi';\nimport { ApiContext } from './ApiBootstrap';\n\ntype DeferredApiBootstrapProps = React.PropsWithChildren<{\n onError?: (error: unknown) => void;\n /**\n * Options to use when fetching the deferred API.\n */\n widget: VariableDescriptor;\n}>;\n\n/**\n * Does not render children until the deferred API is resolved.\n */\nexport const DeferredApiBootstrap = React.memo(\n ({\n children,\n onError,\n widget,\n }: DeferredApiBootstrapProps): JSX.Element | null => {\n const [api, apiError] = useDeferredApi(widget);\n if (apiError != null) {\n onError?.(apiError);\n return null;\n }\n if (api == null) {\n // Still waiting for the API to load\n return null;\n }\n return <ApiContext.Provider value={api}>{children}</ApiContext.Provider>;\n }\n);\n\nDeferredApiBootstrap.displayName = 'DeferredApiBootstrap';\n\nexport default DeferredApiBootstrap;\n"],"mappings":"AAAA,OAAOA,KAAK,MAAM,OAAO;AAAC,OAEnBC,cAAc;AAAA,SACZC,UAAU;AAAA,SAAAC,GAAA,IAAAC,IAAA;AAUnB;AACA;AACA;AACA,OAAO,IAAMC,oBAAoB,gBAAGL,KAAK,CAACM,IAAI,CAC5CC,IAAA,IAIqD;EAAA,IAJpD;IACCC,QAAQ;IACRC,OAAO;IACPC;EACyB,CAAC,GAAAH,IAAA;EAC1B,IAAM,CAACI,GAAG,EAAEC,QAAQ,CAAC,GAAGX,cAAc,CAACS,MAAM,CAAC;EAC9C,IAAIE,QAAQ,IAAI,IAAI,EAAE;IACpBH,OAAO,aAAPA,OAAO,uBAAPA,OAAO,CAAGG,QAAQ,CAAC;IACnB,OAAO,IAAI;EACb;EACA,IAAID,GAAG,IAAI,IAAI,EAAE;IACf;IACA,OAAO,IAAI;EACb;EACA,oBAAOP,IAAA,CAACF,UAAU,CAACW,QAAQ;IAACC,KAAK,EAAEH,GAAI;IAAAH,QAAA,EAAEA;EAAQ,CAAsB,CAAC;AAC1E,CACF,CAAC;AAEDH,oBAAoB,CAACU,WAAW,GAAG,sBAAsB;AAEzD,eAAeV,oBAAoB"}
@@ -1,14 +1,18 @@
1
1
  /// <reference types="react" />
2
- import type { dh as DhType } from '@deephaven/jsapi-types';
3
- import { ObjectMetadata } from './useObjectFetcher';
4
- export type DeferredApiFetcher = (metadata?: ObjectMetadata) => Promise<DhType>;
2
+ import type { dh as DhType, VariableDescriptor } from '@deephaven/jsapi-types';
3
+ /**
4
+ * Function to fetch an API based on a provided descriptor object.
5
+ * Depending on the context there may be more properties on the descriptor,
6
+ * providing more information about the object, such as a session ID.
7
+ */
8
+ export type DeferredApiFetcher = (descriptor?: VariableDescriptor) => Promise<DhType>;
5
9
  export declare const DeferredApiContext: import("react").Context<DhType | DeferredApiFetcher | null>;
6
10
  /**
7
- * Retrieve the API for the current context, given the object metadata provided.
11
+ * Retrieve the API for the current context, given the widget provided.
8
12
  * The API may need to be loaded, and will return `null` until it is ready.
9
- * @param metadata The object metadata to use to fetch the API
13
+ * @param widget The widget descriptor to use to fetch the API
10
14
  * @returns A tuple with the API instance, and an error if one occurred.
11
15
  */
12
- export declare function useDeferredApi(metadata: ObjectMetadata): [DhType | null, unknown | null];
16
+ export declare function useDeferredApi(widget: VariableDescriptor): [DhType | null, unknown | null];
13
17
  export default useDeferredApi;
14
18
  //# sourceMappingURL=useDeferredApi.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"useDeferredApi.d.ts","sourceRoot":"","sources":["../src/useDeferredApi.ts"],"names":[],"mappings":";AACA,OAAO,KAAK,EAAE,EAAE,IAAI,MAAM,EAAE,MAAM,wBAAwB,CAAC;AAE3D,OAAO,EAAE,cAAc,EAAE,MAAM,oBAAoB,CAAC;AAEpD,MAAM,MAAM,kBAAkB,GAAG,CAAC,QAAQ,CAAC,EAAE,cAAc,KAAK,OAAO,CAAC,MAAM,CAAC,CAAC;AAEhF,eAAO,MAAM,kBAAkB,6DAExB,CAAC;AAER;;;;;GAKG;AACH,wBAAgB,cAAc,CAC5B,QAAQ,EAAE,cAAc,GACvB,CAAC,MAAM,GAAG,IAAI,EAAE,OAAO,GAAG,IAAI,CAAC,CAkDjC;AAED,eAAe,cAAc,CAAC"}
1
+ {"version":3,"file":"useDeferredApi.d.ts","sourceRoot":"","sources":["../src/useDeferredApi.ts"],"names":[],"mappings":";AACA,OAAO,KAAK,EAAE,EAAE,IAAI,MAAM,EAAE,kBAAkB,EAAE,MAAM,wBAAwB,CAAC;AAG/E;;;;GAIG;AACH,MAAM,MAAM,kBAAkB,GAAG,CAC/B,UAAU,CAAC,EAAE,kBAAkB,KAC5B,OAAO,CAAC,MAAM,CAAC,CAAC;AAErB,eAAO,MAAM,kBAAkB,6DAExB,CAAC;AAER;;;;;GAKG;AACH,wBAAgB,cAAc,CAC5B,MAAM,EAAE,kBAAkB,GACzB,CAAC,MAAM,GAAG,IAAI,EAAE,OAAO,GAAG,IAAI,CAAC,CAkDjC;AAED,eAAe,cAAc,CAAC"}
@@ -2,15 +2,20 @@ function asyncGeneratorStep(gen, resolve, reject, _next, _throw, key, arg) { try
2
2
  function _asyncToGenerator(fn) { return function () { var self = this, args = arguments; return new Promise(function (resolve, reject) { var gen = fn.apply(self, args); function _next(value) { asyncGeneratorStep(gen, resolve, reject, _next, _throw, "next", value); } function _throw(err) { asyncGeneratorStep(gen, resolve, reject, _next, _throw, "throw", err); } _next(undefined); }); }; }
3
3
  import { createContext, useContext, useEffect, useState } from 'react';
4
4
  import { ApiContext } from "./ApiBootstrap.js";
5
+ /**
6
+ * Function to fetch an API based on a provided descriptor object.
7
+ * Depending on the context there may be more properties on the descriptor,
8
+ * providing more information about the object, such as a session ID.
9
+ */
5
10
  export var DeferredApiContext = /*#__PURE__*/createContext(null);
6
11
 
7
12
  /**
8
- * Retrieve the API for the current context, given the object metadata provided.
13
+ * Retrieve the API for the current context, given the widget provided.
9
14
  * The API may need to be loaded, and will return `null` until it is ready.
10
- * @param metadata The object metadata to use to fetch the API
15
+ * @param widget The widget descriptor to use to fetch the API
11
16
  * @returns A tuple with the API instance, and an error if one occurred.
12
17
  */
13
- export function useDeferredApi(metadata) {
18
+ export function useDeferredApi(widget) {
14
19
  var [api, setApi] = useState(null);
15
20
  var [error, setError] = useState(null);
16
21
  var deferredApi = useContext(DeferredApiContext);
@@ -34,7 +39,7 @@ export function useDeferredApi(metadata) {
34
39
  _loadApi = _asyncToGenerator(function* () {
35
40
  if (typeof deferredApi === 'function') {
36
41
  try {
37
- var newApi = yield deferredApi(metadata);
42
+ var newApi = yield deferredApi(widget);
38
43
  if (!isCancelled) {
39
44
  setApi(newApi);
40
45
  setError(null);
@@ -55,7 +60,7 @@ export function useDeferredApi(metadata) {
55
60
  return () => {
56
61
  isCancelled = true;
57
62
  };
58
- }, [contextApi, deferredApi, metadata]);
63
+ }, [contextApi, deferredApi, widget]);
59
64
  return [api, error];
60
65
  }
61
66
  export default useDeferredApi;
@@ -1 +1 @@
1
- {"version":3,"file":"useDeferredApi.js","names":["createContext","useContext","useEffect","useState","ApiContext","DeferredApiContext","useDeferredApi","metadata","api","setApi","error","setError","deferredApi","contextApi","Error","isCancelled","loadApi","_loadApi","apply","arguments","_asyncToGenerator","newApi","e"],"sources":["../src/useDeferredApi.ts"],"sourcesContent":["import { createContext, useContext, useEffect, useState } from 'react';\nimport type { dh as DhType } from '@deephaven/jsapi-types';\nimport { ApiContext } from './ApiBootstrap';\nimport { ObjectMetadata } from './useObjectFetcher';\n\nexport type DeferredApiFetcher = (metadata?: ObjectMetadata) => Promise<DhType>;\n\nexport const DeferredApiContext = createContext<\n DhType | DeferredApiFetcher | null\n>(null);\n\n/**\n * Retrieve the API for the current context, given the object metadata provided.\n * The API may need to be loaded, and will return `null` until it is ready.\n * @param metadata The object metadata to use to fetch the API\n * @returns A tuple with the API instance, and an error if one occurred.\n */\nexport function useDeferredApi(\n metadata: ObjectMetadata\n): [DhType | null, unknown | null] {\n const [api, setApi] = useState<DhType | null>(null);\n const [error, setError] = useState<unknown | null>(null);\n const deferredApi = useContext(DeferredApiContext);\n const contextApi = useContext(ApiContext);\n\n useEffect(() => {\n if (deferredApi == null) {\n if (contextApi != null) {\n setApi(contextApi);\n setError(null);\n return;\n }\n setApi(null);\n setError(\n new Error(\n 'No API available in useDeferredApi. Was code wrapped in ApiBootstrap or DeferredApiContext.Provider?'\n )\n );\n return;\n }\n let isCancelled = false;\n\n async function loadApi() {\n if (typeof deferredApi === 'function') {\n try {\n const newApi = await deferredApi(metadata);\n if (!isCancelled) {\n setApi(newApi);\n setError(null);\n }\n } catch (e) {\n if (!isCancelled) {\n setApi(null);\n setError(e);\n }\n }\n } else {\n setApi(deferredApi);\n }\n }\n\n loadApi();\n\n return () => {\n isCancelled = true;\n };\n }, [contextApi, deferredApi, metadata]);\n\n return [api, error];\n}\n\nexport default useDeferredApi;\n"],"mappings":";;AAAA,SAASA,aAAa,EAAEC,UAAU,EAAEC,SAAS,EAAEC,QAAQ,QAAQ,OAAO;AAAC,SAE9DC,UAAU;AAKnB,OAAO,IAAMC,kBAAkB,gBAAGL,aAAa,CAE7C,IAAI,CAAC;;AAEP;AACA;AACA;AACA;AACA;AACA;AACA,OAAO,SAASM,cAAcA,CAC5BC,QAAwB,EACS;EACjC,IAAM,CAACC,GAAG,EAAEC,MAAM,CAAC,GAAGN,QAAQ,CAAgB,IAAI,CAAC;EACnD,IAAM,CAACO,KAAK,EAAEC,QAAQ,CAAC,GAAGR,QAAQ,CAAiB,IAAI,CAAC;EACxD,IAAMS,WAAW,GAAGX,UAAU,CAACI,kBAAkB,CAAC;EAClD,IAAMQ,UAAU,GAAGZ,UAAU,CAACG,UAAU,CAAC;EAEzCF,SAAS,CAAC,MAAM;IACd,IAAIU,WAAW,IAAI,IAAI,EAAE;MACvB,IAAIC,UAAU,IAAI,IAAI,EAAE;QACtBJ,MAAM,CAACI,UAAU,CAAC;QAClBF,QAAQ,CAAC,IAAI,CAAC;QACd;MACF;MACAF,MAAM,CAAC,IAAI,CAAC;MACZE,QAAQ,CACN,IAAIG,KAAK,CACP,sGACF,CACF,CAAC;MACD;IACF;IACA,IAAIC,WAAW,GAAG,KAAK;IAAC,SAETC,OAAOA,CAAA;MAAA,OAAAC,QAAA,CAAAC,KAAA,OAAAC,SAAA;IAAA;IAAA,SAAAF,SAAA;MAAAA,QAAA,GAAAG,iBAAA,CAAtB,aAAyB;QACvB,IAAI,OAAOR,WAAW,KAAK,UAAU,EAAE;UACrC,IAAI;YACF,IAAMS,MAAM,SAAST,WAAW,CAACL,QAAQ,CAAC;YAC1C,IAAI,CAACQ,WAAW,EAAE;cAChBN,MAAM,CAACY,MAAM,CAAC;cACdV,QAAQ,CAAC,IAAI,CAAC;YAChB;UACF,CAAC,CAAC,OAAOW,CAAC,EAAE;YACV,IAAI,CAACP,WAAW,EAAE;cAChBN,MAAM,CAAC,IAAI,CAAC;cACZE,QAAQ,CAACW,CAAC,CAAC;YACb;UACF;QACF,CAAC,MAAM;UACLb,MAAM,CAACG,WAAW,CAAC;QACrB;MACF,CAAC;MAAA,OAAAK,QAAA,CAAAC,KAAA,OAAAC,SAAA;IAAA;IAEDH,OAAO,CAAC,CAAC;IAET,OAAO,MAAM;MACXD,WAAW,GAAG,IAAI;IACpB,CAAC;EACH,CAAC,EAAE,CAACF,UAAU,EAAED,WAAW,EAAEL,QAAQ,CAAC,CAAC;EAEvC,OAAO,CAACC,GAAG,EAAEE,KAAK,CAAC;AACrB;AAEA,eAAeJ,cAAc"}
1
+ {"version":3,"file":"useDeferredApi.js","names":["createContext","useContext","useEffect","useState","ApiContext","DeferredApiContext","useDeferredApi","widget","api","setApi","error","setError","deferredApi","contextApi","Error","isCancelled","loadApi","_loadApi","apply","arguments","_asyncToGenerator","newApi","e"],"sources":["../src/useDeferredApi.ts"],"sourcesContent":["import { createContext, useContext, useEffect, useState } from 'react';\nimport type { dh as DhType, VariableDescriptor } from '@deephaven/jsapi-types';\nimport { ApiContext } from './ApiBootstrap';\n\n/**\n * Function to fetch an API based on a provided descriptor object.\n * Depending on the context there may be more properties on the descriptor,\n * providing more information about the object, such as a session ID.\n */\nexport type DeferredApiFetcher = (\n descriptor?: VariableDescriptor\n) => Promise<DhType>;\n\nexport const DeferredApiContext = createContext<\n DhType | DeferredApiFetcher | null\n>(null);\n\n/**\n * Retrieve the API for the current context, given the widget provided.\n * The API may need to be loaded, and will return `null` until it is ready.\n * @param widget The widget descriptor to use to fetch the API\n * @returns A tuple with the API instance, and an error if one occurred.\n */\nexport function useDeferredApi(\n widget: VariableDescriptor\n): [DhType | null, unknown | null] {\n const [api, setApi] = useState<DhType | null>(null);\n const [error, setError] = useState<unknown | null>(null);\n const deferredApi = useContext(DeferredApiContext);\n const contextApi = useContext(ApiContext);\n\n useEffect(() => {\n if (deferredApi == null) {\n if (contextApi != null) {\n setApi(contextApi);\n setError(null);\n return;\n }\n setApi(null);\n setError(\n new Error(\n 'No API available in useDeferredApi. Was code wrapped in ApiBootstrap or DeferredApiContext.Provider?'\n )\n );\n return;\n }\n let isCancelled = false;\n\n async function loadApi() {\n if (typeof deferredApi === 'function') {\n try {\n const newApi = await deferredApi(widget);\n if (!isCancelled) {\n setApi(newApi);\n setError(null);\n }\n } catch (e) {\n if (!isCancelled) {\n setApi(null);\n setError(e);\n }\n }\n } else {\n setApi(deferredApi);\n }\n }\n\n loadApi();\n\n return () => {\n isCancelled = true;\n };\n }, [contextApi, deferredApi, widget]);\n\n return [api, error];\n}\n\nexport default useDeferredApi;\n"],"mappings":";;AAAA,SAASA,aAAa,EAAEC,UAAU,EAAEC,SAAS,EAAEC,QAAQ,QAAQ,OAAO;AAAC,SAE9DC,UAAU;AAEnB;AACA;AACA;AACA;AACA;AAKA,OAAO,IAAMC,kBAAkB,gBAAGL,aAAa,CAE7C,IAAI,CAAC;;AAEP;AACA;AACA;AACA;AACA;AACA;AACA,OAAO,SAASM,cAAcA,CAC5BC,MAA0B,EACO;EACjC,IAAM,CAACC,GAAG,EAAEC,MAAM,CAAC,GAAGN,QAAQ,CAAgB,IAAI,CAAC;EACnD,IAAM,CAACO,KAAK,EAAEC,QAAQ,CAAC,GAAGR,QAAQ,CAAiB,IAAI,CAAC;EACxD,IAAMS,WAAW,GAAGX,UAAU,CAACI,kBAAkB,CAAC;EAClD,IAAMQ,UAAU,GAAGZ,UAAU,CAACG,UAAU,CAAC;EAEzCF,SAAS,CAAC,MAAM;IACd,IAAIU,WAAW,IAAI,IAAI,EAAE;MACvB,IAAIC,UAAU,IAAI,IAAI,EAAE;QACtBJ,MAAM,CAACI,UAAU,CAAC;QAClBF,QAAQ,CAAC,IAAI,CAAC;QACd;MACF;MACAF,MAAM,CAAC,IAAI,CAAC;MACZE,QAAQ,CACN,IAAIG,KAAK,CACP,sGACF,CACF,CAAC;MACD;IACF;IACA,IAAIC,WAAW,GAAG,KAAK;IAAC,SAETC,OAAOA,CAAA;MAAA,OAAAC,QAAA,CAAAC,KAAA,OAAAC,SAAA;IAAA;IAAA,SAAAF,SAAA;MAAAA,QAAA,GAAAG,iBAAA,CAAtB,aAAyB;QACvB,IAAI,OAAOR,WAAW,KAAK,UAAU,EAAE;UACrC,IAAI;YACF,IAAMS,MAAM,SAAST,WAAW,CAACL,MAAM,CAAC;YACxC,IAAI,CAACQ,WAAW,EAAE;cAChBN,MAAM,CAACY,MAAM,CAAC;cACdV,QAAQ,CAAC,IAAI,CAAC;YAChB;UACF,CAAC,CAAC,OAAOW,CAAC,EAAE;YACV,IAAI,CAACP,WAAW,EAAE;cAChBN,MAAM,CAAC,IAAI,CAAC;cACZE,QAAQ,CAACW,CAAC,CAAC;YACb;UACF;QACF,CAAC,MAAM;UACLb,MAAM,CAACG,WAAW,CAAC;QACrB;MACF,CAAC;MAAA,OAAAK,QAAA,CAAAC,KAAA,OAAAC,SAAA;IAAA;IAEDH,OAAO,CAAC,CAAC;IAET,OAAO,MAAM;MACXD,WAAW,GAAG,IAAI;IACpB,CAAC;EACH,CAAC,EAAE,CAACF,UAAU,EAAED,WAAW,EAAEL,MAAM,CAAC,CAAC;EAErC,OAAO,CAACC,GAAG,EAAEE,KAAK,CAAC;AACrB;AAEA,eAAeJ,cAAc"}
@@ -1,17 +1,47 @@
1
1
  /// <reference types="react" />
2
- import { VariableDefinition } from '@deephaven/jsapi-types';
2
+ import { VariableDescriptor, VariableDefinition } from '@deephaven/jsapi-types';
3
3
  /**
4
- * Metadata for an object. Used when needing to fetch an object.
4
+ * Descriptor for a variable by name. Used when needed to fetch an object.
5
5
  */
6
- export type ObjectMetadata = Record<string, unknown> & VariableDefinition;
7
- export type ObjectFetcher<T = unknown> = (metadata: ObjectMetadata) => Promise<T>;
6
+ export type NameVariableDescriptor = {
7
+ /** Type of the variable */
8
+ type: string;
9
+ /** Name of the variable */
10
+ name: string;
11
+ };
12
+ /**
13
+ * Descriptor for a variable by id. Used when needed to fetch an object.
14
+ */
15
+ export type IdVariableDescriptor = {
16
+ /** Type of the variable */
17
+ type: string;
18
+ /** Id of the variable */
19
+ id: string;
20
+ };
21
+ export declare function isNameVariableDescriptor(value: unknown): value is NameVariableDescriptor;
22
+ export declare function isIdVariableDescriptor(value: unknown): value is IdVariableDescriptor;
23
+ export declare function isVariableDescriptor(value: unknown): value is VariableDescriptor;
24
+ /**
25
+ * Function to fetch an object based on a provided descriptor object
26
+ */
27
+ export type ObjectFetcher<T = unknown> = (descriptor: VariableDescriptor) => Promise<T>;
8
28
  export declare const ObjectFetcherContext: import("react").Context<ObjectFetcher<unknown> | null>;
9
29
  /**
10
- * Get the metadata for an object definition that is serializable.
11
- * @param definition Object definition to get the metadata for
12
- * @returns Metadata object that is serializable
30
+ * Gets a descriptor that only has the ID or name set, but not both.
31
+ * API will throw an error if both are set when fetching from the connection.
32
+ * @param descriptor Variable descriptor to sanitize
33
+ * @returns Descriptor object that has either the ID or name set, but not both.
34
+ */
35
+ export declare function sanitizeVariableDescriptor(descriptor: Partial<VariableDescriptor>): NameVariableDescriptor | IdVariableDescriptor;
36
+ /**
37
+ * Get the variable descriptor for a definition.
38
+ * @param definition Definition to get the variable descriptor from
39
+ * @returns Serializable VariableDescriptor object
40
+ */
41
+ export declare function getVariableDescriptor(definition: Partial<VariableDefinition>): VariableDescriptor;
42
+ /**
43
+ * Use a function to fetch an object based on provided metadata
44
+ * @returns Function to asynchronously fetch an object based on provided metadata
13
45
  */
14
- export declare function getObjectMetadata(definition: VariableDefinition): ObjectMetadata;
15
- export declare function getVariableDefinition(metadata: ObjectMetadata): VariableDefinition;
16
- export declare function useObjectFetcher(): ObjectFetcher;
46
+ export declare function useObjectFetcher<T = unknown>(): ObjectFetcher<T>;
17
47
  //# sourceMappingURL=useObjectFetcher.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"useObjectFetcher.d.ts","sourceRoot":"","sources":["../src/useObjectFetcher.ts"],"names":[],"mappings":";AAAA,OAAO,EAAE,kBAAkB,EAAE,MAAM,wBAAwB,CAAC;AAI5D;;GAEG;AACH,MAAM,MAAM,cAAc,GAAG,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,GAAG,kBAAkB,CAAC;AAE1E,MAAM,MAAM,aAAa,CAAC,CAAC,GAAG,OAAO,IAAI,CACvC,QAAQ,EAAE,cAAc,KACrB,OAAO,CAAC,CAAC,CAAC,CAAC;AAEhB,eAAO,MAAM,oBAAoB,wDAA4C,CAAC;AAE9E;;;;GAIG;AACH,wBAAgB,iBAAiB,CAC/B,UAAU,EAAE,kBAAkB,GAC7B,cAAc,CAQhB;AAED,wBAAgB,qBAAqB,CACnC,QAAQ,EAAE,cAAc,GACvB,kBAAkB,CAYpB;AAED,wBAAgB,gBAAgB,IAAI,aAAa,CAKhD"}
1
+ {"version":3,"file":"useObjectFetcher.d.ts","sourceRoot":"","sources":["../src/useObjectFetcher.ts"],"names":[],"mappings":";AAAA,OAAO,EAAE,kBAAkB,EAAE,kBAAkB,EAAE,MAAM,wBAAwB,CAAC;AAIhF;;GAEG;AACH,MAAM,MAAM,sBAAsB,GAAG;IACnC,2BAA2B;IAC3B,IAAI,EAAE,MAAM,CAAC;IACb,2BAA2B;IAC3B,IAAI,EAAE,MAAM,CAAC;CACd,CAAC;AAEF;;GAEG;AACH,MAAM,MAAM,oBAAoB,GAAG;IACjC,2BAA2B;IAC3B,IAAI,EAAE,MAAM,CAAC;IACb,yBAAyB;IACzB,EAAE,EAAE,MAAM,CAAC;CACZ,CAAC;AAEF,wBAAgB,wBAAwB,CACtC,KAAK,EAAE,OAAO,GACb,KAAK,IAAI,sBAAsB,CAOjC;AAED,wBAAgB,sBAAsB,CACpC,KAAK,EAAE,OAAO,GACb,KAAK,IAAI,oBAAoB,CAO/B;AAED,wBAAgB,oBAAoB,CAClC,KAAK,EAAE,OAAO,GACb,KAAK,IAAI,kBAAkB,CAE7B;AAED;;GAEG;AACH,MAAM,MAAM,aAAa,CAAC,CAAC,GAAG,OAAO,IAAI,CACvC,UAAU,EAAE,kBAAkB,KAC3B,OAAO,CAAC,CAAC,CAAC,CAAC;AAEhB,eAAO,MAAM,oBAAoB,wDAA4C,CAAC;AAE9E;;;;;GAKG;AACH,wBAAgB,0BAA0B,CACxC,UAAU,EAAE,OAAO,CAAC,kBAAkB,CAAC,GACtC,sBAAsB,GAAG,oBAAoB,CAe/C;AAED;;;;GAIG;AACH,wBAAgB,qBAAqB,CACnC,UAAU,EAAE,OAAO,CAAC,kBAAkB,CAAC,GACtC,kBAAkB,CAMpB;AAED;;;GAGG;AACH,wBAAgB,gBAAgB,CAAC,CAAC,GAAG,OAAO,KAAK,aAAa,CAAC,CAAC,CAAC,CAKhE"}
@@ -2,39 +2,71 @@ import { useContextOrThrow } from '@deephaven/react-hooks';
2
2
  import { createContext } from 'react';
3
3
 
4
4
  /**
5
- * Metadata for an object. Used when needing to fetch an object.
5
+ * Descriptor for a variable by name. Used when needed to fetch an object.
6
+ */
7
+
8
+ /**
9
+ * Descriptor for a variable by id. Used when needed to fetch an object.
10
+ */
11
+
12
+ export function isNameVariableDescriptor(value) {
13
+ return typeof value === 'object' && value != null && typeof value.type === 'string' && value.name != null;
14
+ }
15
+ export function isIdVariableDescriptor(value) {
16
+ return typeof value === 'object' && value != null && typeof value.type === 'string' && value.id != null;
17
+ }
18
+ export function isVariableDescriptor(value) {
19
+ return isNameVariableDescriptor(value) || isIdVariableDescriptor(value);
20
+ }
21
+
22
+ /**
23
+ * Function to fetch an object based on a provided descriptor object
6
24
  */
7
25
 
8
26
  export var ObjectFetcherContext = /*#__PURE__*/createContext(null);
9
27
 
10
28
  /**
11
- * Get the metadata for an object definition that is serializable.
12
- * @param definition Object definition to get the metadata for
13
- * @returns Metadata object that is serializable
29
+ * Gets a descriptor that only has the ID or name set, but not both.
30
+ * API will throw an error if both are set when fetching from the connection.
31
+ * @param descriptor Variable descriptor to sanitize
32
+ * @returns Descriptor object that has either the ID or name set, but not both.
14
33
  */
15
- export function getObjectMetadata(definition) {
16
- // Can't use a spread operator because the VariableDefinition JS API object uses property accessors
17
- return {
18
- id: definition.id,
19
- name: definition.name,
20
- type: definition.type,
21
- title: definition.title
22
- };
23
- }
24
- export function getVariableDefinition(metadata) {
25
- var _metadata$title;
26
- if (metadata.id != null) {
34
+ export function sanitizeVariableDescriptor(descriptor) {
35
+ // Can't use a spread operator because of how the GWT compiled code defines properties on the object: https://github.com/gwtproject/gwt/issues/9913
36
+ if (isIdVariableDescriptor(descriptor)) {
37
+ return {
38
+ id: descriptor.id,
39
+ type: descriptor.type
40
+ };
41
+ }
42
+ if (isNameVariableDescriptor(descriptor)) {
43
+ var _descriptor$name;
27
44
  return {
28
- type: metadata.type,
29
- id: metadata.id
45
+ name: (_descriptor$name = descriptor.name) !== null && _descriptor$name !== void 0 ? _descriptor$name : '',
46
+ type: descriptor.type
30
47
  };
31
48
  }
49
+ throw new Error("Invalid descriptor: ".concat(descriptor));
50
+ }
51
+
52
+ /**
53
+ * Get the variable descriptor for a definition.
54
+ * @param definition Definition to get the variable descriptor from
55
+ * @returns Serializable VariableDescriptor object
56
+ */
57
+ export function getVariableDescriptor(definition) {
58
+ var _definition$type, _definition$title;
32
59
  return {
33
- type: metadata.type,
34
- name: metadata.name,
35
- title: (_metadata$title = metadata.title) !== null && _metadata$title !== void 0 ? _metadata$title : metadata.name
60
+ type: (_definition$type = definition.type) !== null && _definition$type !== void 0 ? _definition$type : '',
61
+ name: (_definition$title = definition.title) !== null && _definition$title !== void 0 ? _definition$title : definition.name,
62
+ id: definition.id
36
63
  };
37
64
  }
65
+
66
+ /**
67
+ * Use a function to fetch an object based on provided metadata
68
+ * @returns Function to asynchronously fetch an object based on provided metadata
69
+ */
38
70
  export function useObjectFetcher() {
39
71
  return useContextOrThrow(ObjectFetcherContext, 'No ObjectFetcher available in useObjectFetcher. Was code wrapped in ObjectFetcherContext.Provider?');
40
72
  }
@@ -1 +1 @@
1
- {"version":3,"file":"useObjectFetcher.js","names":["useContextOrThrow","createContext","ObjectFetcherContext","getObjectMetadata","definition","id","name","type","title","getVariableDefinition","metadata","_metadata$title","useObjectFetcher"],"sources":["../src/useObjectFetcher.ts"],"sourcesContent":["import { VariableDefinition } from '@deephaven/jsapi-types';\nimport { useContextOrThrow } from '@deephaven/react-hooks';\nimport { createContext } from 'react';\n\n/**\n * Metadata for an object. Used when needing to fetch an object.\n */\nexport type ObjectMetadata = Record<string, unknown> & VariableDefinition;\n\nexport type ObjectFetcher<T = unknown> = (\n metadata: ObjectMetadata\n) => Promise<T>;\n\nexport const ObjectFetcherContext = createContext<ObjectFetcher | null>(null);\n\n/**\n * Get the metadata for an object definition that is serializable.\n * @param definition Object definition to get the metadata for\n * @returns Metadata object that is serializable\n */\nexport function getObjectMetadata(\n definition: VariableDefinition\n): ObjectMetadata {\n // Can't use a spread operator because the VariableDefinition JS API object uses property accessors\n return {\n id: definition.id,\n name: definition.name,\n type: definition.type,\n title: definition.title,\n };\n}\n\nexport function getVariableDefinition(\n metadata: ObjectMetadata\n): VariableDefinition {\n if (metadata.id != null) {\n return {\n type: metadata.type,\n id: metadata.id,\n };\n }\n return {\n type: metadata.type,\n name: metadata.name,\n title: metadata.title ?? metadata.name,\n };\n}\n\nexport function useObjectFetcher(): ObjectFetcher {\n return useContextOrThrow(\n ObjectFetcherContext,\n 'No ObjectFetcher available in useObjectFetcher. Was code wrapped in ObjectFetcherContext.Provider?'\n );\n}\n"],"mappings":"AACA,SAASA,iBAAiB,QAAQ,wBAAwB;AAC1D,SAASC,aAAa,QAAQ,OAAO;;AAErC;AACA;AACA;;AAOA,OAAO,IAAMC,oBAAoB,gBAAGD,aAAa,CAAuB,IAAI,CAAC;;AAE7E;AACA;AACA;AACA;AACA;AACA,OAAO,SAASE,iBAAiBA,CAC/BC,UAA8B,EACd;EAChB;EACA,OAAO;IACLC,EAAE,EAAED,UAAU,CAACC,EAAE;IACjBC,IAAI,EAAEF,UAAU,CAACE,IAAI;IACrBC,IAAI,EAAEH,UAAU,CAACG,IAAI;IACrBC,KAAK,EAAEJ,UAAU,CAACI;EACpB,CAAC;AACH;AAEA,OAAO,SAASC,qBAAqBA,CACnCC,QAAwB,EACJ;EAAA,IAAAC,eAAA;EACpB,IAAID,QAAQ,CAACL,EAAE,IAAI,IAAI,EAAE;IACvB,OAAO;MACLE,IAAI,EAAEG,QAAQ,CAACH,IAAI;MACnBF,EAAE,EAAEK,QAAQ,CAACL;IACf,CAAC;EACH;EACA,OAAO;IACLE,IAAI,EAAEG,QAAQ,CAACH,IAAI;IACnBD,IAAI,EAAEI,QAAQ,CAACJ,IAAI;IACnBE,KAAK,GAAAG,eAAA,GAAED,QAAQ,CAACF,KAAK,cAAAG,eAAA,cAAAA,eAAA,GAAID,QAAQ,CAACJ;EACpC,CAAC;AACH;AAEA,OAAO,SAASM,gBAAgBA,CAAA,EAAkB;EAChD,OAAOZ,iBAAiB,CACtBE,oBAAoB,EACpB,oGACF,CAAC;AACH"}
1
+ {"version":3,"file":"useObjectFetcher.js","names":["useContextOrThrow","createContext","isNameVariableDescriptor","value","type","name","isIdVariableDescriptor","id","isVariableDescriptor","ObjectFetcherContext","sanitizeVariableDescriptor","descriptor","_descriptor$name","Error","concat","getVariableDescriptor","definition","_definition$type","_definition$title","title","useObjectFetcher"],"sources":["../src/useObjectFetcher.ts"],"sourcesContent":["import { VariableDescriptor, VariableDefinition } from '@deephaven/jsapi-types';\nimport { useContextOrThrow } from '@deephaven/react-hooks';\nimport { createContext } from 'react';\n\n/**\n * Descriptor for a variable by name. Used when needed to fetch an object.\n */\nexport type NameVariableDescriptor = {\n /** Type of the variable */\n type: string;\n /** Name of the variable */\n name: string;\n};\n\n/**\n * Descriptor for a variable by id. Used when needed to fetch an object.\n */\nexport type IdVariableDescriptor = {\n /** Type of the variable */\n type: string;\n /** Id of the variable */\n id: string;\n};\n\nexport function isNameVariableDescriptor(\n value: unknown\n): value is NameVariableDescriptor {\n return (\n typeof value === 'object' &&\n value != null &&\n typeof (value as NameVariableDescriptor).type === 'string' &&\n (value as NameVariableDescriptor).name != null\n );\n}\n\nexport function isIdVariableDescriptor(\n value: unknown\n): value is IdVariableDescriptor {\n return (\n typeof value === 'object' &&\n value != null &&\n typeof (value as IdVariableDescriptor).type === 'string' &&\n (value as IdVariableDescriptor).id != null\n );\n}\n\nexport function isVariableDescriptor(\n value: unknown\n): value is VariableDescriptor {\n return isNameVariableDescriptor(value) || isIdVariableDescriptor(value);\n}\n\n/**\n * Function to fetch an object based on a provided descriptor object\n */\nexport type ObjectFetcher<T = unknown> = (\n descriptor: VariableDescriptor\n) => Promise<T>;\n\nexport const ObjectFetcherContext = createContext<ObjectFetcher | null>(null);\n\n/**\n * Gets a descriptor that only has the ID or name set, but not both.\n * API will throw an error if both are set when fetching from the connection.\n * @param descriptor Variable descriptor to sanitize\n * @returns Descriptor object that has either the ID or name set, but not both.\n */\nexport function sanitizeVariableDescriptor(\n descriptor: Partial<VariableDescriptor>\n): NameVariableDescriptor | IdVariableDescriptor {\n // Can't use a spread operator because of how the GWT compiled code defines properties on the object: https://github.com/gwtproject/gwt/issues/9913\n if (isIdVariableDescriptor(descriptor)) {\n return {\n id: descriptor.id,\n type: descriptor.type,\n };\n }\n if (isNameVariableDescriptor(descriptor)) {\n return {\n name: descriptor.name ?? '',\n type: descriptor.type,\n };\n }\n throw new Error(`Invalid descriptor: ${descriptor}`);\n}\n\n/**\n * Get the variable descriptor for a definition.\n * @param definition Definition to get the variable descriptor from\n * @returns Serializable VariableDescriptor object\n */\nexport function getVariableDescriptor(\n definition: Partial<VariableDefinition>\n): VariableDescriptor {\n return {\n type: definition.type ?? '',\n name: definition.title ?? definition.name,\n id: definition.id,\n };\n}\n\n/**\n * Use a function to fetch an object based on provided metadata\n * @returns Function to asynchronously fetch an object based on provided metadata\n */\nexport function useObjectFetcher<T = unknown>(): ObjectFetcher<T> {\n return useContextOrThrow(\n ObjectFetcherContext,\n 'No ObjectFetcher available in useObjectFetcher. Was code wrapped in ObjectFetcherContext.Provider?'\n ) as ObjectFetcher<T>;\n}\n"],"mappings":"AACA,SAASA,iBAAiB,QAAQ,wBAAwB;AAC1D,SAASC,aAAa,QAAQ,OAAO;;AAErC;AACA;AACA;;AAQA;AACA;AACA;;AAQA,OAAO,SAASC,wBAAwBA,CACtCC,KAAc,EACmB;EACjC,OACE,OAAOA,KAAK,KAAK,QAAQ,IACzBA,KAAK,IAAI,IAAI,IACb,OAAQA,KAAK,CAA4BC,IAAI,KAAK,QAAQ,IACzDD,KAAK,CAA4BE,IAAI,IAAI,IAAI;AAElD;AAEA,OAAO,SAASC,sBAAsBA,CACpCH,KAAc,EACiB;EAC/B,OACE,OAAOA,KAAK,KAAK,QAAQ,IACzBA,KAAK,IAAI,IAAI,IACb,OAAQA,KAAK,CAA0BC,IAAI,KAAK,QAAQ,IACvDD,KAAK,CAA0BI,EAAE,IAAI,IAAI;AAE9C;AAEA,OAAO,SAASC,oBAAoBA,CAClCL,KAAc,EACe;EAC7B,OAAOD,wBAAwB,CAACC,KAAK,CAAC,IAAIG,sBAAsB,CAACH,KAAK,CAAC;AACzE;;AAEA;AACA;AACA;;AAKA,OAAO,IAAMM,oBAAoB,gBAAGR,aAAa,CAAuB,IAAI,CAAC;;AAE7E;AACA;AACA;AACA;AACA;AACA;AACA,OAAO,SAASS,0BAA0BA,CACxCC,UAAuC,EACQ;EAC/C;EACA,IAAIL,sBAAsB,CAACK,UAAU,CAAC,EAAE;IACtC,OAAO;MACLJ,EAAE,EAAEI,UAAU,CAACJ,EAAE;MACjBH,IAAI,EAAEO,UAAU,CAACP;IACnB,CAAC;EACH;EACA,IAAIF,wBAAwB,CAACS,UAAU,CAAC,EAAE;IAAA,IAAAC,gBAAA;IACxC,OAAO;MACLP,IAAI,GAAAO,gBAAA,GAAED,UAAU,CAACN,IAAI,cAAAO,gBAAA,cAAAA,gBAAA,GAAI,EAAE;MAC3BR,IAAI,EAAEO,UAAU,CAACP;IACnB,CAAC;EACH;EACA,MAAM,IAAIS,KAAK,wBAAAC,MAAA,CAAwBH,UAAU,CAAE,CAAC;AACtD;;AAEA;AACA;AACA;AACA;AACA;AACA,OAAO,SAASI,qBAAqBA,CACnCC,UAAuC,EACnB;EAAA,IAAAC,gBAAA,EAAAC,iBAAA;EACpB,OAAO;IACLd,IAAI,GAAAa,gBAAA,GAAED,UAAU,CAACZ,IAAI,cAAAa,gBAAA,cAAAA,gBAAA,GAAI,EAAE;IAC3BZ,IAAI,GAAAa,iBAAA,GAAEF,UAAU,CAACG,KAAK,cAAAD,iBAAA,cAAAA,iBAAA,GAAIF,UAAU,CAACX,IAAI;IACzCE,EAAE,EAAES,UAAU,CAACT;EACjB,CAAC;AACH;;AAEA;AACA;AACA;AACA;AACA,OAAO,SAASa,gBAAgBA,CAAA,EAAkC;EAChE,OAAOpB,iBAAiB,CACtBS,oBAAoB,EACpB,oGACF,CAAC;AACH"}
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@deephaven/jsapi-bootstrap",
3
- "version": "0.60.1-object-fetcher.0+7fe24cdd",
3
+ "version": "0.60.1-object-fetcher.7+443993f3",
4
4
  "description": "Deephaven JSAPI Bootstrap",
5
5
  "author": "Deephaven Data Labs LLC",
6
6
  "license": "Apache-2.0",
@@ -22,10 +22,10 @@
22
22
  "build:sass": "sass --embed-sources --load-path=../../node_modules ./src:./dist"
23
23
  },
24
24
  "dependencies": {
25
- "@deephaven/components": "^0.60.1-object-fetcher.0+7fe24cdd",
26
- "@deephaven/jsapi-types": "^0.60.1-object-fetcher.0+7fe24cdd",
27
- "@deephaven/log": "^0.60.1-object-fetcher.0+7fe24cdd",
28
- "@deephaven/react-hooks": "^0.60.1-object-fetcher.0+7fe24cdd"
25
+ "@deephaven/components": "^0.60.1-object-fetcher.7+443993f3",
26
+ "@deephaven/jsapi-types": "^0.60.1-object-fetcher.7+443993f3",
27
+ "@deephaven/log": "^0.60.1-object-fetcher.7+443993f3",
28
+ "@deephaven/react-hooks": "^0.60.1-object-fetcher.7+443993f3"
29
29
  },
30
30
  "devDependencies": {
31
31
  "react": "^17.x"
@@ -40,5 +40,5 @@
40
40
  "publishConfig": {
41
41
  "access": "public"
42
42
  },
43
- "gitHead": "7fe24cddd638b5b922b609693756ecbf5a989094"
43
+ "gitHead": "443993f3fcc4a7501c154248468f65ff23f0ef23"
44
44
  }