@genspectrum/dashboard-components 0.16.1 → 0.16.2

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.
package/dist/util.d.ts CHANGED
@@ -896,7 +896,7 @@ declare global {
896
896
 
897
897
  declare global {
898
898
  interface HTMLElementTagNameMap {
899
- 'gs-aggregate': AggregateComponent;
899
+ 'gs-relative-growth-advantage': RelativeGrowthAdvantageComponent;
900
900
  }
901
901
  }
902
902
 
@@ -904,7 +904,7 @@ declare global {
904
904
  declare global {
905
905
  namespace JSX {
906
906
  interface IntrinsicElements {
907
- 'gs-aggregate': DetailedHTMLProps<HTMLAttributes<HTMLElement>, HTMLElement>;
907
+ 'gs-relative-growth-advantage': DetailedHTMLProps<HTMLAttributes<HTMLElement>, HTMLElement>;
908
908
  }
909
909
  }
910
910
  }
@@ -912,7 +912,7 @@ declare global {
912
912
 
913
913
  declare global {
914
914
  interface HTMLElementTagNameMap {
915
- 'gs-relative-growth-advantage': RelativeGrowthAdvantageComponent;
915
+ 'gs-number-sequences-over-time': NumberSequencesOverTimeComponent;
916
916
  }
917
917
  }
918
918
 
@@ -920,7 +920,7 @@ declare global {
920
920
  declare global {
921
921
  namespace JSX {
922
922
  interface IntrinsicElements {
923
- 'gs-relative-growth-advantage': DetailedHTMLProps<HTMLAttributes<HTMLElement>, HTMLElement>;
923
+ 'gs-number-sequences-over-time': DetailedHTMLProps<HTMLAttributes<HTMLElement>, HTMLElement>;
924
924
  }
925
925
  }
926
926
  }
@@ -928,7 +928,7 @@ declare global {
928
928
 
929
929
  declare global {
930
930
  interface HTMLElementTagNameMap {
931
- 'gs-number-sequences-over-time': NumberSequencesOverTimeComponent;
931
+ 'gs-aggregate': AggregateComponent;
932
932
  }
933
933
  }
934
934
 
@@ -936,7 +936,7 @@ declare global {
936
936
  declare global {
937
937
  namespace JSX {
938
938
  interface IntrinsicElements {
939
- 'gs-number-sequences-over-time': DetailedHTMLProps<HTMLAttributes<HTMLElement>, HTMLElement>;
939
+ 'gs-aggregate': DetailedHTMLProps<HTMLAttributes<HTMLElement>, HTMLElement>;
940
940
  }
941
941
  }
942
942
  }
@@ -992,7 +992,10 @@ declare global {
992
992
 
993
993
  declare global {
994
994
  interface HTMLElementTagNameMap {
995
- 'gs-wastewater-mutations-over-time': WastewaterMutationsOverTimeComponent;
995
+ 'gs-location-filter': LocationFilterComponent;
996
+ }
997
+ interface HTMLElementEventMap {
998
+ 'gs-location-changed': LocationChangedEvent;
996
999
  }
997
1000
  }
998
1001
 
@@ -1000,7 +1003,7 @@ declare global {
1000
1003
  declare global {
1001
1004
  namespace JSX {
1002
1005
  interface IntrinsicElements {
1003
- 'gs-wastewater-mutations-over-time': DetailedHTMLProps<HTMLAttributes<HTMLElement>, HTMLElement>;
1006
+ 'gs-location-filter': DetailedHTMLProps<HTMLAttributes<HTMLElement>, HTMLElement>;
1004
1007
  }
1005
1008
  }
1006
1009
  }
@@ -1028,10 +1031,10 @@ declare global {
1028
1031
 
1029
1032
  declare global {
1030
1033
  interface HTMLElementTagNameMap {
1031
- 'gs-location-filter': LocationFilterComponent;
1034
+ 'gs-text-filter': TextFilterComponent;
1032
1035
  }
1033
1036
  interface HTMLElementEventMap {
1034
- 'gs-location-changed': LocationChangedEvent;
1037
+ 'gs-text-filter-changed': TextFilterChangedEvent;
1035
1038
  }
1036
1039
  }
1037
1040
 
@@ -1039,7 +1042,7 @@ declare global {
1039
1042
  declare global {
1040
1043
  namespace JSX {
1041
1044
  interface IntrinsicElements {
1042
- 'gs-location-filter': DetailedHTMLProps<HTMLAttributes<HTMLElement>, HTMLElement>;
1045
+ 'gs-text-filter': DetailedHTMLProps<HTMLAttributes<HTMLElement>, HTMLElement>;
1043
1046
  }
1044
1047
  }
1045
1048
  }
@@ -1047,10 +1050,10 @@ declare global {
1047
1050
 
1048
1051
  declare global {
1049
1052
  interface HTMLElementTagNameMap {
1050
- 'gs-text-filter': TextFilterComponent;
1053
+ 'gs-mutation-filter': MutationFilterComponent;
1051
1054
  }
1052
1055
  interface HTMLElementEventMap {
1053
- 'gs-text-filter-changed': TextFilterChangedEvent;
1056
+ 'gs-mutation-filter-changed': CustomEvent<MutationsFilter>;
1054
1057
  }
1055
1058
  }
1056
1059
 
@@ -1058,7 +1061,7 @@ declare global {
1058
1061
  declare global {
1059
1062
  namespace JSX {
1060
1063
  interface IntrinsicElements {
1061
- 'gs-text-filter': DetailedHTMLProps<HTMLAttributes<HTMLElement>, HTMLElement>;
1064
+ 'gs-mutation-filter': DetailedHTMLProps<HTMLAttributes<HTMLElement>, HTMLElement>;
1062
1065
  }
1063
1066
  }
1064
1067
  }
@@ -1066,10 +1069,10 @@ declare global {
1066
1069
 
1067
1070
  declare global {
1068
1071
  interface HTMLElementTagNameMap {
1069
- 'gs-mutation-filter': MutationFilterComponent;
1072
+ 'gs-lineage-filter': LineageFilterComponent;
1070
1073
  }
1071
1074
  interface HTMLElementEventMap {
1072
- 'gs-mutation-filter-changed': CustomEvent<MutationsFilter>;
1075
+ 'gs-lineage-filter-changed': LineageFilterChangedEvent;
1073
1076
  }
1074
1077
  }
1075
1078
 
@@ -1077,7 +1080,7 @@ declare global {
1077
1080
  declare global {
1078
1081
  namespace JSX {
1079
1082
  interface IntrinsicElements {
1080
- 'gs-mutation-filter': DetailedHTMLProps<HTMLAttributes<HTMLElement>, HTMLElement>;
1083
+ 'gs-lineage-filter': DetailedHTMLProps<HTMLAttributes<HTMLElement>, HTMLElement>;
1081
1084
  }
1082
1085
  }
1083
1086
  }
@@ -1085,10 +1088,7 @@ declare global {
1085
1088
 
1086
1089
  declare global {
1087
1090
  interface HTMLElementTagNameMap {
1088
- 'gs-lineage-filter': LineageFilterComponent;
1089
- }
1090
- interface HTMLElementEventMap {
1091
- 'gs-lineage-filter-changed': LineageFilterChangedEvent;
1091
+ 'gs-wastewater-mutations-over-time': WastewaterMutationsOverTimeComponent;
1092
1092
  }
1093
1093
  }
1094
1094
 
@@ -1096,7 +1096,7 @@ declare global {
1096
1096
  declare global {
1097
1097
  namespace JSX {
1098
1098
  interface IntrinsicElements {
1099
- 'gs-lineage-filter': DetailedHTMLProps<HTMLAttributes<HTMLElement>, HTMLElement>;
1099
+ 'gs-wastewater-mutations-over-time': DetailedHTMLProps<HTMLAttributes<HTMLElement>, HTMLElement>;
1100
1100
  }
1101
1101
  }
1102
1102
  }
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@genspectrum/dashboard-components",
3
- "version": "0.16.1",
3
+ "version": "0.16.2",
4
4
  "description": "GenSpectrum web components for building dashboards",
5
5
  "type": "module",
6
6
  "license": "AGPL-3.0-only",
@@ -1,6 +1,6 @@
1
1
  import { useCombobox } from 'downshift/preact';
2
2
  import { type ComponentChild } from 'preact';
3
- import { useRef, useState } from 'preact/hooks';
3
+ import { useMemo, useRef, useState } from 'preact/hooks';
4
4
 
5
5
  export function DownshiftCombobox<Item>({
6
6
  allItems,
@@ -21,8 +21,10 @@ export function DownshiftCombobox<Item>({
21
21
  }) {
22
22
  const initialSelectedItem = value ?? null;
23
23
 
24
- const [items, setItems] = useState(
25
- allItems.filter((item) => filterItemsByInputValue(item, itemToString(initialSelectedItem))),
24
+ const [itemsFilter, setItemsFilter] = useState(itemToString(initialSelectedItem));
25
+ const items = useMemo(
26
+ () => allItems.filter((item) => filterItemsByInputValue(item, itemsFilter)),
27
+ [allItems, filterItemsByInputValue, itemsFilter],
26
28
  );
27
29
  const divRef = useRef<HTMLDivElement>(null);
28
30
 
@@ -52,7 +54,7 @@ export function DownshiftCombobox<Item>({
52
54
  closeMenu,
53
55
  } = useCombobox({
54
56
  onInputValueChange({ inputValue }) {
55
- setItems(allItems.filter((item) => filterItemsByInputValue(item, inputValue)));
57
+ setItemsFilter(inputValue);
56
58
  },
57
59
  onSelectedItemChange({ selectedItem }) {
58
60
  if (selectedItem !== null) {
@@ -57,7 +57,7 @@ export const WastewaterMutationsOverTimeInner: FunctionComponent<WastewaterMutat
57
57
  componentProps.lapisFilter,
58
58
  componentProps.sequenceType,
59
59
  ),
60
- [],
60
+ [componentProps.lapisFilter, componentProps.sequenceType],
61
61
  );
62
62
 
63
63
  if (isLoading) {