@fluid-topics/ft-search-result-context 1.1.15 → 1.1.16

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,4 +1,4 @@
1
- import { FtSearchResultCluster, FtSearchResultClusterEntry } from "@fluid-topics/public-api";
1
+ import { FtMetadataDescriptor, FtSearchResultCluster, FtSearchResultClusterEntry } from "@fluid-topics/public-api";
2
2
  import { FlatMetadata } from "./utils";
3
3
  export interface ClusterItem {
4
4
  metadata: FlatMetadata;
@@ -8,8 +8,10 @@ export declare class ClusteringHelper {
8
8
  private cluster;
9
9
  private selectedResult;
10
10
  private clusteringMetadata;
11
- constructor(cluster: FtSearchResultCluster, selectedResult: FtSearchResultClusterEntry, clusteringMetadata: Set<string>);
12
- computeClustersItemsForMetadata(key: string): ClusterItem[];
11
+ private metadataDescriptors;
12
+ constructor(cluster: FtSearchResultCluster, selectedResult: FtSearchResultClusterEntry, clusteringMetadata: Set<string>, metadataDescriptors: Array<FtMetadataDescriptor>);
13
+ computeClustersItemsForMetadata(key: string, locale: string): ClusterItem[];
14
+ private compareMetadata;
13
15
  private findMatchingResult;
14
16
  private findResultMatchingMetadata;
15
17
  private resultMatchesMetadata;
@@ -1,17 +1,28 @@
1
1
  import { extractResultMetadata } from "./utils";
2
2
  export class ClusteringHelper {
3
- constructor(cluster, selectedResult, clusteringMetadata) {
3
+ constructor(cluster, selectedResult, clusteringMetadata, metadataDescriptors) {
4
4
  this.cluster = cluster;
5
5
  this.selectedResult = selectedResult;
6
6
  this.clusteringMetadata = clusteringMetadata;
7
+ this.metadataDescriptors = metadataDescriptors;
7
8
  }
8
- computeClustersItemsForMetadata(key) {
9
+ computeClustersItemsForMetadata(key, locale) {
9
10
  var _a;
10
11
  const metadataValues = (_a = this.cluster) === null || _a === void 0 ? void 0 : _a.entries.flatMap(result => extractResultMetadata(result).filter(m => m.key === key)).filter((flatMeta, index, array) => array.findIndex(i => i.value === flatMeta.value) === index); // for unicity
11
12
  return metadataValues.map(flatMeta => ({
12
13
  result: this.findMatchingResult(key, flatMeta.value),
13
14
  metadata: flatMeta
14
- }));
15
+ })).sort((a, b) => this.compareMetadata(a.metadata.value, b.metadata.value, key, locale));
16
+ }
17
+ compareMetadata(a, b, key, locale) {
18
+ let descriptor = this.metadataDescriptors.find((descriptor) => key == descriptor.key);
19
+ let sortRule = (descriptor === null || descriptor === void 0 ? void 0 : descriptor.sortRule) || "NONE";
20
+ let reverseOrder = (descriptor === null || descriptor === void 0 ? void 0 : descriptor.reverseSort) || false;
21
+ if (sortRule == "ALPHABET" || sortRule == "VERSION") {
22
+ let result = a.localeCompare(b, locale, { numeric: true });
23
+ return reverseOrder ? result * -1 : result;
24
+ }
25
+ return 0;
15
26
  }
16
27
  findMatchingResult(key, value) {
17
28
  var _a, _b;
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@fluid-topics/ft-search-result-context",
3
- "version": "1.1.15",
3
+ "version": "1.1.16",
4
4
  "description": "Search result context for integrated search component",
5
5
  "keywords": [
6
6
  "Lit"
@@ -19,11 +19,11 @@
19
19
  "url": "ssh://git@scm.mrs.antidot.net:2222/fluidtopics/ft-web-components.git"
20
20
  },
21
21
  "dependencies": {
22
- "@fluid-topics/ft-wc-utils": "1.1.15",
22
+ "@fluid-topics/ft-wc-utils": "1.1.16",
23
23
  "lit": "3.1.0"
24
24
  },
25
25
  "devDependencies": {
26
- "@fluid-topics/public-api": "1.0.52"
26
+ "@fluid-topics/public-api": "1.0.54"
27
27
  },
28
- "gitHead": "23ba72e09227eb846df014039cad4415e3549c84"
28
+ "gitHead": "28b18ce8d88cc14097865aad4a8b31406b351434"
29
29
  }