@vuu-ui/vuu-data-remote 2.1.12 → 2.1.13

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.
@@ -31,7 +31,8 @@ const datasourceMessages = [
31
31
  "vuu-links",
32
32
  "vuu-menu",
33
33
  "sort",
34
- "subscribed"
34
+ "subscribed",
35
+ "subscribe-failed"
35
36
  ];
36
37
  const shouldMessageBeRoutedToDataSource = (message) => {
37
38
  const type = message.type;
@@ -1 +1 @@
1
- {"version":3,"file":"data-source.js","sources":["../../../packages/vuu-data-remote/src/data-source.ts"],"sourcesContent":["import type {\n DataSourceCallbackMessage,\n DataSourceConfig,\n DataSourceConfigMessage,\n DataSourceDataSizeMessage,\n WithRequestId,\n} from \"@vuu-ui/vuu-data-types\";\nimport type { SelectSuccessWithRowCount } from \"@vuu-ui/vuu-protocol-types\";\n\nexport const isSizeOnly = (\n message: DataSourceCallbackMessage,\n): message is DataSourceDataSizeMessage =>\n message.type === \"viewport-update\" && message.mode === \"size-only\";\n\nexport const toDataSourceConfig = (\n message: DataSourceConfigMessage,\n): DataSourceConfig => {\n switch (message.type) {\n case \"aggregate\":\n return { aggregations: message.aggregations };\n case \"columns\":\n return { columns: message.columns };\n case \"filter\":\n return { filterSpec: message.filter };\n case \"groupBy\":\n return { groupBy: message.groupBy };\n case \"sort\":\n return { sort: message.sort };\n case \"config\":\n return message.config;\n }\n};\n\nconst datasourceMessages = [\n \"config\",\n \"aggregate\",\n \"viewport-clear\",\n \"viewport-update\",\n \"columns\",\n \"debounce-begin\",\n \"disabled\",\n \"enabled\",\n \"filter\",\n \"groupBy\",\n \"vuu-links\",\n \"vuu-menu\",\n \"sort\",\n \"subscribed\",\n];\n\nexport const shouldMessageBeRoutedToDataSource = (\n message: unknown,\n): message is Exclude<\n DataSourceCallbackMessage,\n WithRequestId<SelectSuccessWithRowCount>\n> => {\n const type = (message as DataSourceCallbackMessage).type;\n return datasourceMessages.includes(type);\n};\n\nexport const isDataSourceConfigMessage = (\n message: DataSourceCallbackMessage,\n): message is DataSourceConfigMessage =>\n [\"config\", \"aggregate\", \"columns\", \"filter\", \"groupBy\", \"sort\"].includes(\n message.type,\n );\n"],"names":[],"mappings":";;AASO,MAAM,aAAa,CACxB,OAAA,KAEA,QAAQ,IAAS,KAAA,iBAAA,IAAqB,QAAQ,IAAS,KAAA;AAE5C,MAAA,kBAAA,GAAqB,CAChC,OACqB,KAAA;AACrB,EAAA,QAAQ,QAAQ,IAAM;AAAA,IACpB,KAAK,WAAA;AACH,MAAO,OAAA,EAAE,YAAc,EAAA,OAAA,CAAQ,YAAa,EAAA;AAAA,IAC9C,KAAK,SAAA;AACH,MAAO,OAAA,EAAE,OAAS,EAAA,OAAA,CAAQ,OAAQ,EAAA;AAAA,IACpC,KAAK,QAAA;AACH,MAAO,OAAA,EAAE,UAAY,EAAA,OAAA,CAAQ,MAAO,EAAA;AAAA,IACtC,KAAK,SAAA;AACH,MAAO,OAAA,EAAE,OAAS,EAAA,OAAA,CAAQ,OAAQ,EAAA;AAAA,IACpC,KAAK,MAAA;AACH,MAAO,OAAA,EAAE,IAAM,EAAA,OAAA,CAAQ,IAAK,EAAA;AAAA,IAC9B,KAAK,QAAA;AACH,MAAA,OAAO,OAAQ,CAAA,MAAA;AAAA;AAErB;AAEA,MAAM,kBAAqB,GAAA;AAAA,EACzB,QAAA;AAAA,EACA,WAAA;AAAA,EACA,gBAAA;AAAA,EACA,iBAAA;AAAA,EACA,SAAA;AAAA,EACA,gBAAA;AAAA,EACA,UAAA;AAAA,EACA,SAAA;AAAA,EACA,QAAA;AAAA,EACA,SAAA;AAAA,EACA,WAAA;AAAA,EACA,UAAA;AAAA,EACA,MAAA;AAAA,EACA;AACF,CAAA;AAEa,MAAA,iCAAA,GAAoC,CAC/C,OAIG,KAAA;AACH,EAAA,MAAM,OAAQ,OAAsC,CAAA,IAAA;AACpD,EAAO,OAAA,kBAAA,CAAmB,SAAS,IAAI,CAAA;AACzC;AAEa,MAAA,yBAAA,GAA4B,CACvC,OAAA,KAEA,CAAC,QAAA,EAAU,aAAa,SAAW,EAAA,QAAA,EAAU,SAAW,EAAA,MAAM,CAAE,CAAA,QAAA;AAAA,EAC9D,OAAQ,CAAA;AACV;;;;;;;"}
1
+ {"version":3,"file":"data-source.js","sources":["../../../packages/vuu-data-remote/src/data-source.ts"],"sourcesContent":["import type {\n DataSourceCallbackMessage,\n DataSourceConfig,\n DataSourceConfigMessage,\n DataSourceDataSizeMessage,\n WithRequestId,\n} from \"@vuu-ui/vuu-data-types\";\nimport type { SelectSuccessWithRowCount } from \"@vuu-ui/vuu-protocol-types\";\n\nexport const isSizeOnly = (\n message: DataSourceCallbackMessage,\n): message is DataSourceDataSizeMessage =>\n message.type === \"viewport-update\" && message.mode === \"size-only\";\n\nexport const toDataSourceConfig = (\n message: DataSourceConfigMessage,\n): DataSourceConfig => {\n switch (message.type) {\n case \"aggregate\":\n return { aggregations: message.aggregations };\n case \"columns\":\n return { columns: message.columns };\n case \"filter\":\n return { filterSpec: message.filter };\n case \"groupBy\":\n return { groupBy: message.groupBy };\n case \"sort\":\n return { sort: message.sort };\n case \"config\":\n return message.config;\n }\n};\n\nconst datasourceMessages = [\n \"config\",\n \"aggregate\",\n \"viewport-clear\",\n \"viewport-update\",\n \"columns\",\n \"debounce-begin\",\n \"disabled\",\n \"enabled\",\n \"filter\",\n \"groupBy\",\n \"vuu-links\",\n \"vuu-menu\",\n \"sort\",\n \"subscribed\",\n \"subscribe-failed\",\n];\n\nexport const shouldMessageBeRoutedToDataSource = (\n message: unknown,\n): message is Exclude<\n DataSourceCallbackMessage,\n WithRequestId<SelectSuccessWithRowCount>\n> => {\n const type = (message as DataSourceCallbackMessage).type;\n return datasourceMessages.includes(type);\n};\n\nexport const isDataSourceConfigMessage = (\n message: DataSourceCallbackMessage,\n): message is DataSourceConfigMessage =>\n [\"config\", \"aggregate\", \"columns\", \"filter\", \"groupBy\", \"sort\"].includes(\n message.type,\n );\n"],"names":[],"mappings":";;AASO,MAAM,aAAa,CACxB,OAAA,KAEA,QAAQ,IAAS,KAAA,iBAAA,IAAqB,QAAQ,IAAS,KAAA;AAE5C,MAAA,kBAAA,GAAqB,CAChC,OACqB,KAAA;AACrB,EAAA,QAAQ,QAAQ,IAAM;AAAA,IACpB,KAAK,WAAA;AACH,MAAO,OAAA,EAAE,YAAc,EAAA,OAAA,CAAQ,YAAa,EAAA;AAAA,IAC9C,KAAK,SAAA;AACH,MAAO,OAAA,EAAE,OAAS,EAAA,OAAA,CAAQ,OAAQ,EAAA;AAAA,IACpC,KAAK,QAAA;AACH,MAAO,OAAA,EAAE,UAAY,EAAA,OAAA,CAAQ,MAAO,EAAA;AAAA,IACtC,KAAK,SAAA;AACH,MAAO,OAAA,EAAE,OAAS,EAAA,OAAA,CAAQ,OAAQ,EAAA;AAAA,IACpC,KAAK,MAAA;AACH,MAAO,OAAA,EAAE,IAAM,EAAA,OAAA,CAAQ,IAAK,EAAA;AAAA,IAC9B,KAAK,QAAA;AACH,MAAA,OAAO,OAAQ,CAAA,MAAA;AAAA;AAErB;AAEA,MAAM,kBAAqB,GAAA;AAAA,EACzB,QAAA;AAAA,EACA,WAAA;AAAA,EACA,gBAAA;AAAA,EACA,iBAAA;AAAA,EACA,SAAA;AAAA,EACA,gBAAA;AAAA,EACA,UAAA;AAAA,EACA,SAAA;AAAA,EACA,QAAA;AAAA,EACA,SAAA;AAAA,EACA,WAAA;AAAA,EACA,UAAA;AAAA,EACA,MAAA;AAAA,EACA,YAAA;AAAA,EACA;AACF,CAAA;AAEa,MAAA,iCAAA,GAAoC,CAC/C,OAIG,KAAA;AACH,EAAA,MAAM,OAAQ,OAAsC,CAAA,IAAA;AACpD,EAAO,OAAA,kBAAA,CAAmB,SAAS,IAAI,CAAA;AACzC;AAEa,MAAA,yBAAA,GAA4B,CACvC,OAAA,KAEA,CAAC,QAAA,EAAU,aAAa,SAAW,EAAA,QAAA,EAAU,SAAW,EAAA,MAAM,CAAE,CAAA,QAAA;AAAA,EAC9D,OAAQ,CAAA;AACV;;;;;;;"}
@@ -323,6 +323,7 @@ var InvalidLoginMessages = [
323
323
  INVALID_TOKEN,
324
324
  TOKEN_EXPIRED
325
325
  ];
326
+ var isErrorMessage = (message) => typeof message == "object" && (message == null ? void 0 : message.type) === "ERROR";
326
327
  var isLoginErrorMessage = (message) => typeof message === "string" && InvalidLoginMessages.includes(message);
327
328
  var isSelectRequest = (message) => message && typeof message === "object" && "type" in message && (message.type === "SELECT_ROW" || message.type === "DESELECT_ROW" || message.type === "SELECT_ROW_RANGE" || message.type === "SELECT_ALL" || message.type === "DESELECT_ALL");
328
329
  var isRpcServiceRequest = (message) => message.type === "RPC_REQUEST";
@@ -1771,7 +1772,13 @@ var ServerProxy = class {
1771
1772
  pendingSubscription,
1772
1773
  pendingTableSchema
1773
1774
  ]);
1774
- if (isCreateVpSuccess(subscribeResponse)) {
1775
+ if (isErrorMessage(tableSchema)) {
1776
+ this.postMessageToClient({
1777
+ clientViewportId: message.viewport,
1778
+ type: "subscribe-failed",
1779
+ msg: \`failed to fetch schema for table \${message.table.table}: \${tableSchema.msg}\`
1780
+ });
1781
+ } else if (isCreateVpSuccess(subscribeResponse)) {
1775
1782
  const { viewPortId: serverViewportId } = subscribeResponse;
1776
1783
  const { status: previousViewportStatus } = viewport;
1777
1784
  if (message.viewport !== serverViewportId) {
@@ -1819,6 +1826,11 @@ var ServerProxy = class {
1819
1826
  });
1820
1827
  }
1821
1828
  } else {
1829
+ this.postMessageToClient({
1830
+ clientViewportId: message.viewport,
1831
+ type: "subscribe-failed",
1832
+ msg: \`failed to open subscription on table \${message.table.table}: \${subscribeResponse.msg}\`
1833
+ });
1822
1834
  }
1823
1835
  } else {
1824
1836
  error2(\`spurious subscribe call \${message.viewport}\`);
@@ -2204,7 +2216,8 @@ var ServerProxy = class {
2204
2216
  }
2205
2217
  case "GET_TABLE_META": {
2206
2218
  this.getTableMeta(message.table, requestId).then((tableSchema) => {
2207
- if (tableSchema) {
2219
+ if (isErrorMessage(tableSchema)) {
2220
+ } else if (tableSchema) {
2208
2221
  this.postMessageToClient({
2209
2222
  type: "TABLE_META_RESP",
2210
2223
  tableSchema,
@@ -2225,10 +2238,9 @@ var ServerProxy = class {
2225
2238
  }
2226
2239
  getTableMeta(table, requestId = nextRequestId()) {
2227
2240
  if (isSessionTable(table)) {
2228
- return this.awaitResponseToMessage(
2229
- { type: "GET_TABLE_META", table },
2230
- requestId
2231
- ).then(createSchemaFromTableMetadata);
2241
+ return this.awaitResponseToMessage({ type: "GET_TABLE_META", table }, requestId).then(
2242
+ (resp) => isErrorMessage(resp) ? resp : createSchemaFromTableMetadata(resp)
2243
+ );
2232
2244
  }
2233
2245
  const key = \`\${table.module}:\${table.table}\`;
2234
2246
  let tableMetaRequest = this.cachedTableMetaRequests.get(key);
@@ -2239,7 +2251,13 @@ var ServerProxy = class {
2239
2251
  );
2240
2252
  this.cachedTableMetaRequests.set(key, tableMetaRequest);
2241
2253
  }
2242
- return tableMetaRequest == null ? void 0 : tableMetaRequest.then((response) => this.cacheTableMeta(response));
2254
+ return tableMetaRequest == null ? void 0 : tableMetaRequest.then((response) => {
2255
+ if (isErrorMessage(response)) {
2256
+ return response;
2257
+ } else {
2258
+ return this.cacheTableMeta(response);
2259
+ }
2260
+ });
2243
2261
  }
2244
2262
  awaitResponseToMessage(message, requestId = nextRequestId()) {
2245
2263
  return new Promise((resolve, reject) => {