@axinom/mosaic-ui 0.66.0-rc.8 → 0.66.0

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.
Files changed (146) hide show
  1. package/dist/components/DynamicDataList/DynamicListHeader/DynamicListHeader.d.ts.map +1 -1
  2. package/dist/components/FieldSelection/FieldSelection.d.ts.map +1 -1
  3. package/dist/components/Filters/Filter/Filter.d.ts.map +1 -1
  4. package/dist/components/Filters/Filters.model.d.ts +5 -0
  5. package/dist/components/Filters/Filters.model.d.ts.map +1 -1
  6. package/dist/components/Filters/SelectionTypes/DateTimeFilter/DateTimeFilter.d.ts +2 -0
  7. package/dist/components/Filters/SelectionTypes/DateTimeFilter/DateTimeFilter.d.ts.map +1 -1
  8. package/dist/components/Filters/SelectionTypes/FreeTextFilter/FreeTextFilter.d.ts +2 -0
  9. package/dist/components/Filters/SelectionTypes/FreeTextFilter/FreeTextFilter.d.ts.map +1 -1
  10. package/dist/components/Filters/SelectionTypes/MultiOptionFilter/MultiOptionFilter.d.ts +2 -0
  11. package/dist/components/Filters/SelectionTypes/MultiOptionFilter/MultiOptionFilter.d.ts.map +1 -1
  12. package/dist/components/Filters/SelectionTypes/NumericTextFilter/NumericTextFilter.d.ts +2 -0
  13. package/dist/components/Filters/SelectionTypes/NumericTextFilter/NumericTextFilter.d.ts.map +1 -1
  14. package/dist/components/Filters/SelectionTypes/OptionsFilter/OptionsFilter.d.ts +2 -0
  15. package/dist/components/Filters/SelectionTypes/OptionsFilter/OptionsFilter.d.ts.map +1 -1
  16. package/dist/components/Filters/SelectionTypes/SearcheableOptionsFilter/SearcheableOptionsFilter.d.ts +2 -0
  17. package/dist/components/Filters/SelectionTypes/SearcheableOptionsFilter/SearcheableOptionsFilter.d.ts.map +1 -1
  18. package/dist/components/FormElements/Radio/Radio.d.ts.map +1 -1
  19. package/dist/components/FormElements/ToggleButton/ToggleButton.d.ts.map +1 -1
  20. package/dist/components/Hub/Tile/Tile.d.ts.map +1 -1
  21. package/dist/components/Icons/Icons.d.ts +4 -9
  22. package/dist/components/Icons/Icons.d.ts.map +1 -1
  23. package/dist/components/LandingPageTiles/TileLarge/TileLarge.d.ts.map +1 -1
  24. package/dist/components/LandingPageTiles/TileSmall/TileSmall.d.ts.map +1 -1
  25. package/dist/components/List/ListCheckBox/ListCheckBox.d.ts.map +1 -1
  26. package/dist/components/List/ListHeader/ColumnLabel/ColumnLabel.d.ts.map +1 -1
  27. package/dist/components/List/ListHeader/ListHeader.d.ts.map +1 -1
  28. package/dist/components/List/ListRow/ListRow.d.ts.map +1 -1
  29. package/dist/components/List/ListRow/ListRowCell/ListRowCell.d.ts +15 -0
  30. package/dist/components/List/ListRow/ListRowCell/ListRowCell.d.ts.map +1 -0
  31. package/dist/components/List/ListRow/ListRowCell/renderData.d.ts +9 -0
  32. package/dist/components/List/ListRow/ListRowCell/renderData.d.ts.map +1 -0
  33. package/dist/components/List/ListRow/Renderers/TagsRenderer/TagsRenderer.d.ts.map +1 -1
  34. package/dist/components/Loaders/ImageLoader/ImageLoader.d.ts.map +1 -1
  35. package/dist/components/PageHeader/PageHeaderAction/PageHeaderAction.d.ts.map +1 -1
  36. package/dist/components/Utils/Postgraphile/CreateConnectionRenderer.d.ts +1 -1
  37. package/dist/components/Utils/Postgraphile/CreateConnectionRenderer.d.ts.map +1 -1
  38. package/dist/components/VisualElements/ImgElement.d.ts +50 -0
  39. package/dist/components/VisualElements/ImgElement.d.ts.map +1 -0
  40. package/dist/components/VisualElements/SvgElement.d.ts +14 -0
  41. package/dist/components/VisualElements/SvgElement.d.ts.map +1 -0
  42. package/dist/components/VisualElements/index.d.ts +3 -0
  43. package/dist/components/VisualElements/index.d.ts.map +1 -0
  44. package/dist/components/index.d.ts +1 -0
  45. package/dist/components/index.d.ts.map +1 -1
  46. package/dist/helpers/idleCallbackHelpers.d.ts +42 -0
  47. package/dist/helpers/idleCallbackHelpers.d.ts.map +1 -0
  48. package/dist/helpers/index.d.ts +1 -0
  49. package/dist/helpers/index.d.ts.map +1 -1
  50. package/dist/hooks/useResize/ResizeIndicator.d.ts +8 -0
  51. package/dist/hooks/useResize/ResizeIndicator.d.ts.map +1 -0
  52. package/dist/hooks/useResize/useResize.d.ts +5 -2
  53. package/dist/hooks/useResize/useResize.d.ts.map +1 -1
  54. package/dist/index.d.ts +1 -0
  55. package/dist/index.d.ts.map +1 -1
  56. package/dist/index.es.js +4 -4
  57. package/dist/index.es.js.map +1 -1
  58. package/dist/index.js +4 -4
  59. package/dist/index.js.map +1 -1
  60. package/package.json +2 -2
  61. package/src/components/Accordion/Accordion.scss +1 -1
  62. package/src/components/Accordion/AccordionItem/AccordionItem.scss +2 -2
  63. package/src/components/Buttons/Button/Button.scss +5 -5
  64. package/src/components/Buttons/CompositeButton/CompositeButton.scss +7 -7
  65. package/src/components/Buttons/TextButton/TextButton.scss +6 -6
  66. package/src/components/ConfirmDialog/ConfirmDialog.scss +1 -1
  67. package/src/components/DateTime/DatePicker/DatePicker.scss +12 -12
  68. package/src/components/DateTime/TimePicker/ScrollColumn/ScrollColumn.scss +7 -7
  69. package/src/components/DateTime/TimePicker/TimePicker.scss +1 -1
  70. package/src/components/DynamicDataList/DynamicListHeader/DynamicListHeader.scss +2 -2
  71. package/src/components/DynamicDataList/DynamicListHeader/DynamicListHeader.spec.tsx +2 -0
  72. package/src/components/DynamicDataList/DynamicListHeader/DynamicListHeader.tsx +62 -50
  73. package/src/components/DynamicDataList/DynamicListRow/DynamicListRow.scss +2 -2
  74. package/src/components/FieldSelection/FieldSelection.scss +4 -0
  75. package/src/components/FieldSelection/FieldSelection.tsx +1 -0
  76. package/src/components/Filters/Filter/Filter.scss +34 -15
  77. package/src/components/Filters/Filter/Filter.spec.tsx +1 -1
  78. package/src/components/Filters/Filter/Filter.tsx +46 -34
  79. package/src/components/Filters/Filters.model.ts +6 -0
  80. package/src/components/Filters/SelectionTypes/DateTimeFilter/DateTimeFilter.tsx +5 -0
  81. package/src/components/Filters/SelectionTypes/FreeTextFilter/FreeTextFilter.tsx +4 -0
  82. package/src/components/Filters/SelectionTypes/MultiOptionFilter/MultiOptionFilter.scss +1 -1
  83. package/src/components/Filters/SelectionTypes/MultiOptionFilter/MultiOptionFilter.tsx +9 -1
  84. package/src/components/Filters/SelectionTypes/NumericTextFilter/NumericTextFilter.tsx +5 -0
  85. package/src/components/Filters/SelectionTypes/OptionsFilter/OptionsFilter.scss +6 -10
  86. package/src/components/Filters/SelectionTypes/OptionsFilter/OptionsFilter.tsx +8 -0
  87. package/src/components/Filters/SelectionTypes/SearcheableOptionsFilter/SearcheableOptionsFilter.tsx +6 -1
  88. package/src/components/FormElements/Checkbox/Checkbox.scss +4 -4
  89. package/src/components/FormElements/CustomTags/CustomTags.scss +1 -1
  90. package/src/components/FormElements/FileUploadControl/FileUploadControl.scss +4 -4
  91. package/src/components/FormElements/Radio/Radio.scss +5 -5
  92. package/src/components/FormElements/Radio/Radio.tsx +3 -2
  93. package/src/components/FormElements/Select/Select.scss +11 -6
  94. package/src/components/FormElements/ToggleButton/ToggleButton.scss +7 -7
  95. package/src/components/FormElements/ToggleButton/ToggleButton.tsx +32 -27
  96. package/src/components/Hub/Hub.stories.tsx +3 -2
  97. package/src/components/Hub/Tile/Tile.spec.tsx +7 -2
  98. package/src/components/Hub/Tile/Tile.tsx +2 -1
  99. package/src/components/Icons/Icons.scss +1 -0
  100. package/src/components/Icons/Icons.spec.tsx +90 -41
  101. package/src/components/Icons/Icons.tsx +357 -765
  102. package/src/components/InfoTooltip/InfoTooltip.scss +1 -1
  103. package/src/components/InlineMenu/InlineMenu.scss +2 -2
  104. package/src/components/LandingPageTiles/LandingPageTiles.stories.tsx +3 -2
  105. package/src/components/LandingPageTiles/TileLarge/TileLarge.spec.tsx +5 -1
  106. package/src/components/LandingPageTiles/TileLarge/TileLarge.tsx +2 -1
  107. package/src/components/LandingPageTiles/TileSmall/TileSmall.spec.tsx +7 -2
  108. package/src/components/LandingPageTiles/TileSmall/TileSmall.tsx +2 -1
  109. package/src/components/List/List.scss +4 -4
  110. package/src/components/List/ListCheckBox/ListCheckBox.tsx +1 -0
  111. package/src/components/List/ListHeader/ColumnLabel/ColumnLabel.spec.tsx +6 -6
  112. package/src/components/List/ListHeader/ColumnLabel/ColumnLabel.tsx +10 -13
  113. package/src/components/List/ListHeader/ListHeader.scss +2 -3
  114. package/src/components/List/ListHeader/ListHeader.spec.tsx +2 -0
  115. package/src/components/List/ListHeader/ListHeader.tsx +57 -51
  116. package/src/components/List/ListRow/ListRow.scss +1 -28
  117. package/src/components/List/ListRow/ListRow.spec.tsx +10 -8
  118. package/src/components/List/ListRow/ListRow.tsx +20 -152
  119. package/src/components/List/ListRow/ListRowCell/ListRowCell.scss +26 -0
  120. package/src/components/List/ListRow/ListRowCell/ListRowCell.spec.tsx +491 -0
  121. package/src/components/List/ListRow/ListRowCell/ListRowCell.tsx +57 -0
  122. package/src/components/List/ListRow/ListRowCell/renderData.tsx +124 -0
  123. package/src/components/List/ListRow/Renderers/TagsRenderer/TagsRenderer.spec.tsx +191 -80
  124. package/src/components/List/ListRow/Renderers/TagsRenderer/TagsRenderer.tsx +63 -34
  125. package/src/components/Loaders/ImageLoader/ImageLoader.spec.tsx +13 -14
  126. package/src/components/Loaders/ImageLoader/ImageLoader.tsx +5 -3
  127. package/src/components/PageHeader/PageHeader.scss +1 -1
  128. package/src/components/PageHeader/PageHeaderAction/PageHeaderAction.tsx +13 -2
  129. package/src/components/Tabs/Tab/CustomTab.scss +4 -4
  130. package/src/components/Tabs/TabList/CustomTabList.scss +2 -2
  131. package/src/components/Utils/Postgraphile/CreateConnectionRenderer.spec.ts +48 -12
  132. package/src/components/Utils/Postgraphile/CreateConnectionRenderer.tsx +5 -4
  133. package/src/components/VisualElements/ImgElement.spec.tsx +92 -0
  134. package/src/components/VisualElements/ImgElement.tsx +72 -0
  135. package/src/components/VisualElements/SvgElement.spec.tsx +160 -0
  136. package/src/components/VisualElements/SvgElement.tsx +40 -0
  137. package/src/components/VisualElements/index.ts +7 -0
  138. package/src/components/index.ts +1 -0
  139. package/src/helpers/idleCallbackHelpers.ts +66 -0
  140. package/src/helpers/index.ts +5 -0
  141. package/src/hooks/useResize/ResizeIndicator.scss +7 -0
  142. package/src/hooks/useResize/ResizeIndicator.tsx +39 -0
  143. package/src/hooks/useResize/{useResize.ts → useResize.tsx} +38 -6
  144. package/src/index.ts +2 -0
  145. package/src/styles/branding.scss +89 -0
  146. package/src/styles/variables.scss +245 -187
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@axinom/mosaic-ui",
3
- "version": "0.66.0-rc.8",
3
+ "version": "0.66.0",
4
4
  "description": "UI components for building Axinom Mosaic applications",
5
5
  "author": "Axinom",
6
6
  "license": "PROPRIETARY",
@@ -112,5 +112,5 @@
112
112
  "publishConfig": {
113
113
  "access": "public"
114
114
  },
115
- "gitHead": "b423cad67c00b75057d5304354ba9429e69d2d03"
115
+ "gitHead": "c484ceff643b3ac656a5a5aebb30394be58ee2e0"
116
116
  }
@@ -33,7 +33,7 @@
33
33
  color: var(--accordion-header-text-color, $accordion-header-text-color);
34
34
  font-weight: bold;
35
35
 
36
- border-bottom: solid 1px lighten($gray, 15%);
36
+ border-bottom: solid 1px color-mix(in srgb, var(--ax-neutral) 85%, white);
37
37
 
38
38
  top: 0;
39
39
  position: sticky;
@@ -4,7 +4,7 @@
4
4
  display: grid;
5
5
  grid-template-columns: 50px auto;
6
6
  align-items: center;
7
- background-color: $light-gray;
7
+ background-color: var(--ax-neutral-light);
8
8
  margin-top: 4px;
9
9
  height: 50px;
10
10
  cursor: pointer;
@@ -19,7 +19,7 @@
19
19
  }
20
20
 
21
21
  &.rowExpanded {
22
- background-color: $light-gray-2;
22
+ background-color: var(--ax-neutral-lighter);
23
23
  }
24
24
 
25
25
  &.sticky {
@@ -108,10 +108,10 @@
108
108
  }
109
109
 
110
110
  &:disabled {
111
- border: 1px solid $gray;
111
+ border: 1px solid var(--ax-neutral);
112
112
 
113
113
  svg * {
114
- stroke: $gray;
114
+ stroke: var(--ax-neutral);
115
115
  }
116
116
  }
117
117
  }
@@ -146,7 +146,7 @@
146
146
  background-color: white;
147
147
 
148
148
  svg * {
149
- stroke: $blue;
149
+ stroke: var(--ax-primary);
150
150
  }
151
151
  }
152
152
 
@@ -154,7 +154,7 @@
154
154
  border: none;
155
155
 
156
156
  svg * {
157
- stroke: $gray;
157
+ stroke: var(--ax-neutral);
158
158
  }
159
159
  }
160
160
  }
@@ -193,7 +193,7 @@
193
193
  }
194
194
 
195
195
  &:disabled {
196
- background-color: $gray;
196
+ background-color: var(--ax-neutral);
197
197
 
198
198
  svg * {
199
199
  opacity: 0.5;
@@ -75,7 +75,7 @@
75
75
  $navigation-button-background-disabled-color
76
76
  );
77
77
  pointer-events: none;
78
- color: rgba(white, 0.5);
78
+ color: color-mix(in srgb, white 50%, transparent);
79
79
 
80
80
  svg * {
81
81
  opacity: 0.5;
@@ -121,11 +121,11 @@
121
121
  }
122
122
 
123
123
  &:disabled {
124
- border: 1px solid $gray;
125
- color: $gray;
124
+ border: 1px solid var(--ax-neutral);
125
+ color: var(--ax-neutral);
126
126
 
127
127
  svg * {
128
- stroke: $gray;
128
+ stroke: var(--ax-neutral);
129
129
  }
130
130
  }
131
131
  }
@@ -146,12 +146,12 @@
146
146
 
147
147
  &:active {
148
148
  background-color: white;
149
- color: $blue;
149
+ color: var(--ax-primary);
150
150
  }
151
151
 
152
152
  &:disabled {
153
- background-color: $gray;
154
- color: rgba(white, 0.5);
153
+ background-color: var(--ax-neutral);
154
+ color: color-mix(in srgb, white 50%, transparent);
155
155
  }
156
156
  }
157
157
  }
@@ -50,7 +50,7 @@
50
50
  $navigation-button-background-disabled-color
51
51
  );
52
52
  pointer-events: none;
53
- color: rgba(white, 0.5);
53
+ color: color-mix(in srgb, white 50%, transparent);
54
54
  }
55
55
  }
56
56
 
@@ -84,8 +84,8 @@
84
84
  }
85
85
 
86
86
  &:disabled {
87
- border: 1px solid $gray;
88
- color: $gray;
87
+ border: 1px solid var(--ax-neutral);
88
+ color: var(--ax-neutral);
89
89
  }
90
90
  }
91
91
 
@@ -105,12 +105,12 @@
105
105
 
106
106
  &:active {
107
107
  background-color: white;
108
- color: $blue;
108
+ color: var(--ax-primary);
109
109
  }
110
110
 
111
111
  &:disabled {
112
- background-color: $gray;
113
- color: rgba(white, 0.5);
112
+ background-color: var(--ax-neutral);
113
+ color: color-mix(in srgb, white 50%, transparent);
114
114
  }
115
115
  }
116
116
  }
@@ -32,7 +32,7 @@ $pop-up-horizontal-arrow: 47%;
32
32
 
33
33
  padding: 5px;
34
34
 
35
- color: $dark-gray;
35
+ color: var(--ax-neutral-dark);
36
36
  font-size: 14px;
37
37
 
38
38
  .defaultText {
@@ -36,7 +36,7 @@
36
36
  cursor: pointer;
37
37
  }
38
38
  :global(.react-calendar__navigation) button[disabled] {
39
- background-color: #f0f0f0;
39
+ background-color: var(--ax-neutral-lighter);
40
40
  }
41
41
  :global(.react-calendar__month-view__weekdays) {
42
42
  text-align: center;
@@ -59,7 +59,7 @@
59
59
  padding: calc(0.75em / 0.75) calc(0.5em / 0.75);
60
60
  }
61
61
  :global(.react-calendar__month-view__days__day--neighboringMonth) {
62
- color: #757575;
62
+ color: var(--ax-neutral);
63
63
  }
64
64
  :global(.react-calendar__year-view) :global(.react-calendar__tile),
65
65
  :global(.react-calendar__decade-view) :global(.react-calendar__tile),
@@ -74,37 +74,37 @@
74
74
  background: none;
75
75
  }
76
76
  :global(.react-calendar__tile):disabled {
77
- background-color: #f0f0f0;
77
+ background-color: var(--ax-neutral-lighter);
78
78
  }
79
79
  :global(.react-calendar__tile):enabled:hover {
80
- background-color: #e6e6e6;
80
+ background-color: var(--ax-neutral-light);
81
81
  }
82
82
  :global(.react-calendar__tile--hasActive) {
83
- background: #76baff;
83
+ background: var(--ax-primary-light);
84
84
  }
85
85
  :global(.react-calendar__tile--hasActive):enabled:hover,
86
86
  :global(.react-calendar__tile--hasActive):enabled:focus {
87
- background: #a9d4ff;
87
+ background: color-mix(in srgb, var(--ax-primary-light), white 30%);
88
88
  }
89
89
  :global(.react-calendar__tile--active) {
90
- background: #006edc;
90
+ background: var(--ax-primary-dark);
91
91
  color: white;
92
92
  }
93
93
  :global(.react-calendar__tile--active):enabled:hover,
94
94
  :global(.react-calendar__tile--active):enabled:focus {
95
- background: #1087ff;
95
+ background: var(--ax-primary);
96
96
  }
97
97
  :global(.react-calendar--selectRange) :global(.react-calendar__tile--hover) {
98
- background-color: #e6e6e6;
98
+ background-color: var(--ax-neutral-light);
99
99
  }
100
100
 
101
101
  :global(.react-calendar__tile) {
102
102
  transition: background-color 0.15s ease-in-out 0s;
103
103
 
104
- color: $dark-gray;
104
+ color: var(--ax-neutral-dark);
105
105
 
106
106
  * {
107
- color: $dark-gray;
107
+ color: var(--ax-neutral-dark);
108
108
  }
109
109
 
110
110
  &:hover {
@@ -171,7 +171,7 @@
171
171
  }
172
172
 
173
173
  :global(.react-calendar__month-view__days__day--neighboringMonth) * {
174
- color: $light-gray;
174
+ color: var(--ax-neutral-light);
175
175
  }
176
176
 
177
177
  :global(.react-calendar__tile--active),
@@ -13,7 +13,7 @@
13
13
  .inactive-title {
14
14
  display: grid;
15
15
  font-size: 12px;
16
- color: $gray;
16
+ color: var(--ax-neutral);
17
17
  text-align: center;
18
18
  align-items: center;
19
19
  }
@@ -23,7 +23,7 @@
23
23
 
24
24
  display: grid;
25
25
  font-size: 18px;
26
- color: $dark-gray;
26
+ color: var(--ax-neutral-dark);
27
27
  text-align: center;
28
28
  align-items: center;
29
29
 
@@ -35,10 +35,10 @@
35
35
 
36
36
  &.active {
37
37
  visibility: visible;
38
- background-color: rgba($blue, 0.15);
38
+ background-color: color-mix(in srgb, var(--ax-primary) 15%, transparent);
39
39
 
40
40
  &.selected {
41
- background-color: $blue;
41
+ background-color: var(--ax-primary);
42
42
  color: white;
43
43
  }
44
44
  }
@@ -46,11 +46,11 @@
46
46
  &.selected {
47
47
  visibility: visible;
48
48
 
49
- border: 1px solid $blue;
49
+ border: 1px solid var(--ax-primary);
50
50
  }
51
51
 
52
52
  &:hover {
53
- background-color: rgba($blue, 0.15);
53
+ background-color: color-mix(in srgb, var(--ax-primary) 15%, transparent);
54
54
  }
55
55
  }
56
56
 
@@ -70,7 +70,7 @@
70
70
  }
71
71
 
72
72
  svg * {
73
- stroke: $blue;
73
+ stroke: var(--ax-primary);
74
74
  }
75
75
 
76
76
  &.hidden {
@@ -12,7 +12,7 @@
12
12
  display: grid;
13
13
  grid-column: 1 / 5;
14
14
  font-size: 20px;
15
- color: $dark-gray;
15
+ color: var(--ax-neutral-dark);
16
16
  text-align: center;
17
17
  height: 40px;
18
18
  align-items: center;
@@ -13,7 +13,7 @@
13
13
  grid-auto-rows: var(--dynamic-list-row-height, $dynamic-list-row-height);
14
14
  column-gap: var(--dynamic-list-column-gap, $dynamic-list-column-gap);
15
15
 
16
- border-bottom: solid 1px $light-gray;
16
+ border-bottom: solid 1px var(--ax-neutral-light);
17
17
 
18
18
  justify-items: left;
19
19
  align-items: center;
@@ -36,7 +36,7 @@
36
36
  height: 100%;
37
37
 
38
38
  z-index: 1;
39
- border-right: var(--explorer-list-row-border, 1px solid #dddddd);
39
+ border-right: var(--explorer-list-row-border, 1px solid var(--ax-neutral-light));
40
40
  position: absolute;
41
41
  right: 0;
42
42
 
@@ -238,6 +238,8 @@ describe('DynamicListHeader', () => {
238
238
  } as any),
239
239
  );
240
240
 
241
+ window.dispatchEvent(new Event('mouseup', {} as any));
242
+
241
243
  expect(spy).toHaveBeenCalledTimes(1);
242
244
  });
243
245
  });
@@ -70,60 +70,72 @@ export const DynamicListHeader = <T extends Data>({
70
70
  customStyles.top = 0;
71
71
  }
72
72
 
73
- const { cols, mouseDown } = useResize(columns, onColumnSizesChanged);
73
+ const { cols, mouseDown, ResizeIndicator } = useResize(
74
+ columns,
75
+ onColumnSizesChanged,
76
+ );
74
77
 
75
78
  return (
76
- <div
77
- className={clsx(
78
- classes.container,
79
- 'dynamic-list-header-container',
80
- className,
81
- )}
82
- style={customStyles}
83
- data-test-id="dynamic-list-header"
84
- >
85
- {showPositionColumn && (
86
- <div
87
- className={clsx(classes.column)}
88
- data-test-id="dynamic-list-header-cell"
89
- >
90
- <p className={clsx(classes.position)}>
91
- {positionLabel ?? (allowDragging ? 'Position' : 'Pos')}
92
- </p>
79
+ <>
80
+ {ResizeIndicator}
81
+ <div
82
+ className={clsx(
83
+ classes.container,
84
+ 'dynamic-list-header-container',
85
+ className,
86
+ )}
87
+ style={customStyles}
88
+ data-test-id="dynamic-list-header"
89
+ >
90
+ {showPositionColumn && (
93
91
  <div
94
- className={clsx(classes.resizeHandle, classes.resizeHandleDisabled)}
95
- />
96
- </div>
97
- )}
98
- {columns.map((column, i) => (
99
- <div
100
- key={column.key ?? (column.propertyName as string)}
101
- className={clsx(classes.column)}
102
- ref={cols[i].ref}
103
- data-test-id={`dynamic-list-header-property:${
104
- column.propertyName as string
105
- }`}
106
- >
107
- <p>{column.label}</p>
92
+ className={clsx(classes.column)}
93
+ data-test-id="dynamic-list-header-cell"
94
+ >
95
+ <p className={clsx(classes.position)}>
96
+ {positionLabel ?? (allowDragging ? 'Position' : 'Pos')}
97
+ </p>
98
+ <div
99
+ className={clsx(
100
+ classes.resizeHandle,
101
+ classes.resizeHandleDisabled,
102
+ )}
103
+ />
104
+ </div>
105
+ )}
106
+ {columns.map((column, i) => (
107
+ <div
108
+ key={column.key ?? (column.propertyName as string)}
109
+ className={clsx(classes.column)}
110
+ ref={cols[i].ref}
111
+ data-test-id={`dynamic-list-header-property:${
112
+ column.propertyName as string
113
+ }`}
114
+ >
115
+ <p>{column.label}</p>
116
+ <div
117
+ onMouseDown={
118
+ !column.disableResizing
119
+ ? (e) => {
120
+ e.preventDefault();
121
+ mouseDown(i);
122
+ }
123
+ : undefined
124
+ }
125
+ onDoubleClick={onResetColumnSizes}
126
+ className={clsx(classes.resizeHandle, {
127
+ [classes.resizeHandleDisabled]: column.disableResizing ?? false,
128
+ })}
129
+ />
130
+ </div>
131
+ ))}
132
+ {showActionColumn && (
108
133
  <div
109
- onMouseDown={
110
- !column.disableResizing
111
- ? (e) => {
112
- e.preventDefault();
113
- mouseDown(i);
114
- }
115
- : undefined
116
- }
117
- onDoubleClick={onResetColumnSizes}
118
- className={clsx(classes.resizeHandle, {
119
- [classes.resizeHandleDisabled]: column.disableResizing ?? false,
120
- })}
134
+ className={clsx(classes.column)}
135
+ ref={cols[cols.length - 1].ref}
121
136
  />
122
- </div>
123
- ))}
124
- {showActionColumn && (
125
- <div className={clsx(classes.column)} ref={cols[cols.length - 1].ref} />
126
- )}
127
- </div>
137
+ )}
138
+ </div>
139
+ </>
128
140
  );
129
141
  };
@@ -79,10 +79,10 @@
79
79
  }
80
80
 
81
81
  .dragIcon {
82
- stroke: $light-gray;
82
+ stroke: var(--ax-neutral-light);
83
83
 
84
84
  rect {
85
- fill: $light-gray;
85
+ fill: var(--ax-neutral-light);
86
86
  }
87
87
  }
88
88
  }
@@ -7,6 +7,10 @@
7
7
  align-items: center;
8
8
  }
9
9
 
10
+ .item {
11
+ z-index: 0;
12
+ }
13
+
10
14
  .selectionHeader {
11
15
  display: grid;
12
16
  grid-template-columns: 1fr;
@@ -84,6 +84,7 @@ export const FieldSelection: React.FC<FieldSelectionProps> = ({
84
84
  {selectedFields.map((field) => (
85
85
  <AccordionItem
86
86
  key={field.value}
87
+ className={classes.item}
87
88
  header={
88
89
  <FieldSelectionItemHeader
89
90
  label={field.label as string}
@@ -15,24 +15,31 @@ $input-inactive: 1px solid var(--input-border-color, $input-border-color);
15
15
  border: $input-inactive;
16
16
  }
17
17
 
18
+ &.hasValue {
19
+ background: color-mix(
20
+ in srgb,
21
+ var(--filter-background-color, $filter-background-color) 50%,
22
+ transparent
23
+ );
24
+ }
25
+
18
26
  .title {
19
27
  display: grid;
20
28
  grid-template-columns: auto auto;
21
- grid-template-rows: 48px;
29
+ grid-template-rows: 38px;
22
30
  place-content: space-between;
23
31
  place-items: center;
24
32
  color: var(--filter-title-color, $filter-title-color);
25
33
  font-size: var(--filter-font-size, $filter-font-size);
26
- border: 1px solid white;
34
+ border: 1px solid transparent;
27
35
 
28
- transition: border 0.15s ease-in-out 0s;
29
- transition: background-color 100ms linear;
36
+ transition: border 0.15s ease-in-out 0s, background-color 100ms linear;
30
37
 
31
38
  &:hover {
32
39
  border: $border;
33
40
  }
34
41
 
35
- &.expanded {
42
+ &.active {
36
43
  background-color: var(
37
44
  --filter-background-selected-color,
38
45
  $filter-background-selected-color
@@ -46,13 +53,20 @@ $input-inactive: 1px solid var(--input-border-color, $input-border-color);
46
53
  var(--input-invalid-border-color, $input-invalid-border-color);
47
54
  }
48
55
 
49
- &.active {
56
+ &.hasValue {
50
57
  font-weight: bold;
51
58
  }
52
59
 
53
60
  .button {
61
+ height: 40px;
62
+ width: 40px;
63
+
64
+ &.rotated svg {
65
+ transform: rotate(90deg);
66
+ }
67
+
54
68
  svg {
55
- height: 50%;
69
+ transition: transform 200ms cubic-bezier(0.4, 0, 0.2, 1);
56
70
  }
57
71
 
58
72
  svg * {
@@ -63,7 +77,7 @@ $input-inactive: 1px solid var(--input-border-color, $input-border-color);
63
77
  }
64
78
  }
65
79
 
66
- span {
80
+ label {
67
81
  padding-left: 15px;
68
82
  }
69
83
  }
@@ -78,9 +92,8 @@ $input-inactive: 1px solid var(--input-border-color, $input-border-color);
78
92
  place-items: center;
79
93
 
80
94
  .button {
81
- svg {
82
- height: 50%;
83
- }
95
+ height: 40px;
96
+ width: 40px;
84
97
 
85
98
  svg * {
86
99
  stroke: var(
@@ -92,17 +105,23 @@ $input-inactive: 1px solid var(--input-border-color, $input-border-color);
92
105
 
93
106
  span {
94
107
  padding-left: 30px;
95
- padding-bottom: 10px;
96
108
  }
97
109
  }
98
110
  }
99
111
 
100
112
  .content {
101
- transition: max-height 100ms linear;
102
- overflow: hidden;
103
- max-height: fit-content !important;
113
+ display: grid;
114
+ grid-template-rows: 0fr;
115
+ transition: grid-template-rows 200ms cubic-bezier(0.4, 0, 0.2, 1);
116
+
117
+ &.expanded {
118
+ grid-template-rows: 1fr;
119
+ }
104
120
 
105
121
  .active {
122
+ display: grid;
123
+ overflow: hidden;
124
+
106
125
  border-right: $border;
107
126
  border-bottom: $border;
108
127
  border-left: $border;
@@ -95,7 +95,7 @@ describe('Filter', () => {
95
95
 
96
96
  const filterTitle = wrapper.find('.title');
97
97
 
98
- expect(filterTitle.hasClass('expanded')).toBe(expected);
98
+ expect(filterTitle.hasClass('active')).toBe(expected);
99
99
  });
100
100
 
101
101
  it('passes active state to custom filter', () => {