@fluid-topics/ft-wc-utils 1.2.22 → 1.2.24

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.
@@ -5,22 +5,29 @@ export interface FlatMetadata {
5
5
  label: string;
6
6
  value: Optional<string>;
7
7
  displayValue: string;
8
+ displayTooltipValue: string;
8
9
  }
9
10
  export interface ClusterItem {
10
11
  metadata: FlatMetadata;
11
12
  result: FtSearchResultClusterEntry;
12
13
  }
14
+ export interface ExtractResultMetadataOptions {
15
+ result: FtSearchResultClusterEntry;
16
+ key?: string;
17
+ hierarchicalValueTruncatingLevel?: number;
18
+ dateFormatter?: ((value: string) => string);
19
+ }
13
20
  export declare class ClusteringHelper {
14
21
  private allResults;
15
22
  private selectedResult;
16
23
  private clusteringMetadata;
17
24
  private metadataDescriptors;
18
25
  constructor(allResults: Array<FtSearchResultClusterEntry>, selectedResult: FtSearchResultClusterEntry, clusteringMetadata: Set<string>, metadataDescriptors: Array<FtMetadataDescriptor>);
19
- static extractResultMetadata(result: FtSearchResultClusterEntry): FlatMetadata[];
20
- static extractResultMetadata(result: FtSearchResultClusterEntry, key: string): Optional<FlatMetadata>;
21
- static flattenMetadata(metadata: Optional<FtMetadata>[]): FlatMetadata[];
22
- static flattenMetadata(metadata: Optional<FtMetadata>): Optional<FlatMetadata>;
23
- computeClustersItemsForMetadata(key: string, locale: string, undefinedDisplayValue?: string): ClusterItem[];
26
+ static extractResultMetadata(options: Omit<ExtractResultMetadataOptions, "key">): FlatMetadata[];
27
+ static extractResultMetadata(options: ExtractResultMetadataOptions): Optional<FlatMetadata>;
28
+ static flattenMetadata(metadata: Optional<FtMetadata>[], hierarchicalValueTruncatingLevel?: number, dateFormatter?: ((value: string) => string)): FlatMetadata[];
29
+ static flattenMetadata(metadata: Optional<FtMetadata>, hierarchicalValueTruncatingLevel?: number, dateFormatter?: ((value: string) => string)): Optional<FlatMetadata>;
30
+ computeClustersItemsForMetadata(key: string, locale: string, undefinedDisplayValue?: string, hierarchicalValueTruncatingLevel?: number, dateFormatter?: ((value: string) => string)): ClusterItem[];
24
31
  private compareMetadata;
25
32
  getMetadataDescriptor(key: string): FtMetadataDescriptor | undefined;
26
33
  private findBestResultForMetadataValue;
@@ -5,17 +5,17 @@ export class ClusteringHelper {
5
5
  this.clusteringMetadata = clusteringMetadata;
6
6
  this.metadataDescriptors = metadataDescriptors;
7
7
  }
8
- static extractResultMetadata(result, key) {
9
- var _a, _b;
10
- let metadata = ((_b = (_a = result === null || result === void 0 ? void 0 : result.map) !== null && _a !== void 0 ? _a : result === null || result === void 0 ? void 0 : result.document) !== null && _b !== void 0 ? _b : result === null || result === void 0 ? void 0 : result.topic).metadata;
11
- if (key == null) {
12
- return ClusteringHelper.flattenMetadata(metadata);
8
+ static extractResultMetadata(options) {
9
+ var _a, _b, _c, _d, _e;
10
+ let metadata = ((_d = (_b = (_a = options.result) === null || _a === void 0 ? void 0 : _a.map) !== null && _b !== void 0 ? _b : (_c = options.result) === null || _c === void 0 ? void 0 : _c.document) !== null && _d !== void 0 ? _d : (_e = options.result) === null || _e === void 0 ? void 0 : _e.topic).metadata;
11
+ if (options.key == null) {
12
+ return ClusteringHelper.flattenMetadata(metadata, options.hierarchicalValueTruncatingLevel, options.dateFormatter);
13
13
  }
14
- return ClusteringHelper.flattenMetadata(metadata.find(m => m.key === key));
14
+ return ClusteringHelper.flattenMetadata(metadata.find(m => m.key === options.key), options.hierarchicalValueTruncatingLevel, options.dateFormatter);
15
15
  }
16
- static flattenMetadata(metadata) {
16
+ static flattenMetadata(metadata, hierarchicalValueTruncatingLevel, dateFormatter) {
17
17
  if (Array.isArray(metadata)) {
18
- return metadata.map(m => ClusteringHelper.flattenMetadata(m)).filter(m => m != null);
18
+ return metadata.map(m => ClusteringHelper.flattenMetadata(m, hierarchicalValueTruncatingLevel, dateFormatter)).filter(m => m != null);
19
19
  }
20
20
  const isHierarchical = (metadata === null || metadata === void 0 ? void 0 : metadata.hierarchicalValues) != null && metadata.hierarchicalValues.length > 0;
21
21
  if (metadata == null || (metadata.values.length == 0 && !isHierarchical)) {
@@ -26,7 +26,7 @@ export class ClusteringHelper {
26
26
  const displayValues = [];
27
27
  metadata.hierarchicalValues.forEach(tree => {
28
28
  values.push(tree.join(" > "));
29
- if (tree.length > 2) {
29
+ if (hierarchicalValueTruncatingLevel && hierarchicalValueTruncatingLevel > 1 && tree.length >= hierarchicalValueTruncatingLevel) {
30
30
  displayValues.push(`... > ${tree[tree.length - 1]}`);
31
31
  }
32
32
  else {
@@ -37,25 +37,31 @@ export class ClusteringHelper {
37
37
  key: metadata.key,
38
38
  label: metadata.label,
39
39
  value: values.join(", "),
40
- displayValue: displayValues.join(", ")
40
+ displayValue: displayValues.join(", "),
41
+ displayTooltipValue: values.join(", "),
41
42
  };
42
43
  }
43
44
  else {
45
+ // Date metadata cannot be hierarchical
44
46
  const value = metadata.values.join(", ");
47
+ const displayValue = metadata.values
48
+ .map(value => dateFormatter ? dateFormatter(value) : value)
49
+ .join(", ");
45
50
  return {
46
51
  key: metadata.key,
47
52
  label: metadata.label,
48
53
  value: value,
49
- displayValue: value
54
+ displayValue: displayValue,
55
+ displayTooltipValue: displayValue,
50
56
  };
51
57
  }
52
58
  }
53
- computeClustersItemsForMetadata(key, locale, undefinedDisplayValue = "No value") {
59
+ computeClustersItemsForMetadata(key, locale, undefinedDisplayValue = "No value", hierarchicalValueTruncatingLevel, dateFormatter) {
54
60
  var _a, _b;
55
- let currentResultMetadataTargeted = ClusteringHelper.extractResultMetadata(this.selectedResult, key);
61
+ let currentResultMetadataTargeted = ClusteringHelper.extractResultMetadata({ result: this.selectedResult, key, dateFormatter });
56
62
  let metadataLabel = (_a = currentResultMetadataTargeted === null || currentResultMetadataTargeted === void 0 ? void 0 : currentResultMetadataTargeted.label) !== null && _a !== void 0 ? _a : (_b = this.getMetadataDescriptor(key)) === null || _b === void 0 ? void 0 : _b.label;
57
63
  const otherValues = this.allResults
58
- .map(result => ClusteringHelper.extractResultMetadata(result, key))
64
+ .map(result => ClusteringHelper.extractResultMetadata({ result, key, hierarchicalValueTruncatingLevel, dateFormatter }))
59
65
  .map(m => m !== null && m !== void 0 ? m : { key: key, label: metadataLabel, value: undefined, displayValue: undefinedDisplayValue })
60
66
  .filter(m => m.value != (currentResultMetadataTargeted === null || currentResultMetadataTargeted === void 0 ? void 0 : currentResultMetadataTargeted.value))
61
67
  .filter((flatMeta, index, array) => array.findIndex(i => i.value === flatMeta.value) === index); // for unicity
@@ -85,8 +91,8 @@ export class ClusteringHelper {
85
91
  }
86
92
  findBestResultForMetadataValue(key, value) {
87
93
  const resultsMatchingRequiredValue = this.allResults
88
- .filter(result => { var _a; return ((_a = ClusteringHelper.extractResultMetadata(result, key)) === null || _a === void 0 ? void 0 : _a.value) == value; });
89
- let currentResultMetadata = ClusteringHelper.extractResultMetadata(this.selectedResult)
94
+ .filter(result => { var _a; return ((_a = ClusteringHelper.extractResultMetadata({ result, key })) === null || _a === void 0 ? void 0 : _a.value) == value; });
95
+ let currentResultMetadata = ClusteringHelper.extractResultMetadata({ result: this.selectedResult })
90
96
  .filter(m => this.clusteringMetadata.has(m.key));
91
97
  let wishedMetadata = [...currentResultMetadata.filter(m => m.key !== key)];
92
98
  let bestResult;
@@ -104,7 +110,7 @@ export class ClusteringHelper {
104
110
  return bestResult;
105
111
  }
106
112
  countMatchingMetadata(result, expectedMetadata) {
107
- return ClusteringHelper.extractResultMetadata(result)
113
+ return ClusteringHelper.extractResultMetadata({ result })
108
114
  .filter(m => expectedMetadata.some(em => em.key === m.key && em.value === m.value)).length;
109
115
  }
110
116
  }