@fluid-topics/ft-reader-context 1.1.53 → 1.1.55

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.
@@ -3,12 +3,13 @@ import { FtReaderReduxStore } from "./redux";
3
3
  import type { FtReaderService } from "./utils/FtReaderService";
4
4
  export declare class FtReaderStateManager {
5
5
  store: FtReaderReduxStore;
6
+ private clusteringHelperProvider?;
6
7
  static build(id: string, serviceProvider?: () => Promise<FtReaderService>): FtReaderStateManager;
7
8
  metadataForSwitchToRelatives: Set<string>;
8
9
  clusteringHelper?: ClusteringHelper;
9
10
  service?: FtReaderService;
10
11
  errorHandler?: (e: Error) => void;
11
- constructor(store: FtReaderReduxStore, serviceProvider: () => Promise<FtReaderService>);
12
+ constructor(store: FtReaderReduxStore, serviceProvider: () => Promise<FtReaderService>, clusteringHelperProvider?: (() => ClusteringHelper) | undefined);
12
13
  initService(serviceProvider: () => Promise<FtReaderService>): Promise<void>;
13
14
  setMapId(mapId?: string): Promise<void>;
14
15
  setVisibleTopics(tocIds: string[]): void;
@@ -23,6 +24,7 @@ export declare class FtReaderStateManager {
23
24
  reload(): Promise<void>;
24
25
  private fetchData;
25
26
  private fetchRelatives;
27
+ private updateClusteringHelper;
26
28
  private createClusteringHelper;
27
29
  navigateToRelativeTopicIfFound(topicPivotMetadataValue: string): Promise<boolean>;
28
30
  setSearchInDocumentQuery(query: string): void;
@@ -6,8 +6,9 @@ export class FtReaderStateManager {
6
6
  static build(id, serviceProvider) {
7
7
  return new FtReaderStateManager(createReaderStore(id.trim() || "context"), serviceProvider !== null && serviceProvider !== void 0 ? serviceProvider : FtOfficialReaderService.build);
8
8
  }
9
- constructor(store, serviceProvider) {
9
+ constructor(store, serviceProvider, clusteringHelperProvider) {
10
10
  this.store = store;
11
+ this.clusteringHelperProvider = clusteringHelperProvider;
11
12
  this.metadataForSwitchToRelatives = new Set();
12
13
  this.loadDebouncer = new Debouncer(10);
13
14
  this.initService(serviceProvider);
@@ -107,16 +108,31 @@ export class FtReaderStateManager {
107
108
  (_b = this.service) === null || _b === void 0 ? void 0 : _b.getRelativesForDocument((_c = this.store.getState().configuration) === null || _c === void 0 ? void 0 : _c.relativePivotMetadata, relativeMetadataValues).then((searchResults) => {
108
109
  const relatives = searchResults.results.flatMap((result) => result.entries);
109
110
  this.store.actions.relatives(relatives);
110
- this.createClusteringHelper();
111
+ this.updateClusteringHelper();
111
112
  });
112
113
  }
114
+ else {
115
+ this.updateClusteringHelper();
116
+ }
117
+ }
118
+ updateClusteringHelper() {
119
+ this.clusteringHelper = this.createClusteringHelper();
120
+ if (this.clusteringHelper) {
121
+ this.store.eventBus.dispatchEvent(new CustomEvent("clustering-helper-created"));
122
+ }
113
123
  }
114
124
  createClusteringHelper() {
115
125
  var _a, _b;
116
- if (this.store.getState().relatives) {
117
- this.clusteringHelper = new ClusteringHelper(this.store.getState().relatives, this.store.getState().relatives.find((relative) => { var _a; return ((_a = relative.map) === null || _a === void 0 ? void 0 : _a.mapId) == this.store.getState().mapId; }), this.metadataForSwitchToRelatives, (_b = (_a = ftAppInfoStore.getState().metadataConfiguration) === null || _a === void 0 ? void 0 : _a.descriptors) !== null && _b !== void 0 ? _b : []);
118
- this.store.eventBus.dispatchEvent(new CustomEvent("clustering-helper-created"));
126
+ if (this.clusteringHelperProvider) {
127
+ return this.clusteringHelperProvider();
128
+ }
129
+ let relatives = this.store.getState().relatives;
130
+ if (relatives) {
131
+ let selectedResult = relatives.find((relative) => { var _a; return ((_a = relative.map) === null || _a === void 0 ? void 0 : _a.mapId) == this.store.getState().mapId; });
132
+ let metadataDescriptors = (_b = (_a = ftAppInfoStore.getState().metadataConfiguration) === null || _a === void 0 ? void 0 : _a.descriptors) !== null && _b !== void 0 ? _b : [];
133
+ return new ClusteringHelper(relatives, selectedResult, this.metadataForSwitchToRelatives, metadataDescriptors);
119
134
  }
135
+ return undefined;
120
136
  }
121
137
  async navigateToRelativeTopicIfFound(topicPivotMetadataValue) {
122
138
  var _a, _b, _c;
@@ -143,11 +159,11 @@ export class FtReaderStateManager {
143
159
  this.fetchRelatives();
144
160
  }
145
161
  else {
146
- this.createClusteringHelper();
162
+ this.updateClusteringHelper();
147
163
  }
148
164
  }
149
165
  unregisterMetadataForSwitchToRelatives(id) {
150
166
  this.metadataForSwitchToRelatives.delete(id);
151
- this.createClusteringHelper();
167
+ this.updateClusteringHelper();
152
168
  }
153
169
  }
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@fluid-topics/ft-reader-context",
3
- "version": "1.1.53",
3
+ "version": "1.1.55",
4
4
  "description": "Context block for integrated reader components",
5
5
  "keywords": [
6
6
  "Lit"
@@ -19,13 +19,13 @@
19
19
  "url": "ssh://git@scm.mrs.antidot.net:2222/fluidtopics/ft-web-components.git"
20
20
  },
21
21
  "dependencies": {
22
- "@fluid-topics/ft-app-context": "1.1.53",
23
- "@fluid-topics/ft-wc-utils": "1.1.53",
22
+ "@fluid-topics/ft-app-context": "1.1.55",
23
+ "@fluid-topics/ft-wc-utils": "1.1.55",
24
24
  "@reduxjs/toolkit": "^1.6.2",
25
25
  "lit": "3.1.0"
26
26
  },
27
27
  "devDependencies": {
28
28
  "@fluid-topics/public-api": "1.0.62"
29
29
  },
30
- "gitHead": "9533374bb075edb940b4426a00561f27c34d2f01"
30
+ "gitHead": "f548a38dc05ea47ac4e94d97fe62625fc9297fcc"
31
31
  }