@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(
|
|
20
|
-
static extractResultMetadata(
|
|
21
|
-
static flattenMetadata(metadata: Optional<FtMetadata>[]): FlatMetadata[];
|
|
22
|
-
static flattenMetadata(metadata: Optional<FtMetadata
|
|
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(
|
|
9
|
-
var _a, _b;
|
|
10
|
-
let metadata = ((_b = (_a = result === null ||
|
|
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
|
|
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:
|
|
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
|
}
|