@xh/hoist 73.0.0-SNAPSHOT.1746638889909 → 73.0.0-SNAPSHOT.1746639145721
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/CHANGELOG.md +0 -4
- package/build/types/cmp/grid/Types.d.ts +1 -4
- package/build/types/cmp/store/StoreFilterField.d.ts +3 -2
- package/build/types/desktop/cmp/grid/impl/filter/headerfilter/values/ValuesTabModel.d.ts +0 -2
- package/cmp/grid/Types.ts +1 -4
- package/cmp/grid/filter/GridFilterModel.ts +1 -1
- package/cmp/store/StoreFilterField.ts +3 -2
- package/desktop/cmp/grid/impl/filter/headerfilter/values/ValuesTab.scss +0 -13
- package/desktop/cmp/grid/impl/filter/headerfilter/values/ValuesTab.ts +3 -31
- package/desktop/cmp/grid/impl/filter/headerfilter/values/ValuesTabModel.ts +15 -43
- package/package.json +1 -1
- package/tsconfig.tsbuildinfo +1 -1
package/CHANGELOG.md
CHANGED
|
@@ -127,10 +127,6 @@
|
|
|
127
127
|
|
|
128
128
|
### 🎁 New Features
|
|
129
129
|
|
|
130
|
-
* Improvements to Grid columns `HeaderFilter` component:
|
|
131
|
-
* `GridFilterModel` `commitOnChage` now set to `false` by default
|
|
132
|
-
* Addition of ability to append terms to active filter **only** when `commitOnChage:false`
|
|
133
|
-
* Column header filtering functionality now similar to Excel on Windows
|
|
134
130
|
* Introduced a new "JSON Search" feature to the Hoist Admin Console, accessible from the Config,
|
|
135
131
|
User Preference, and JSON Blob tabs. Supports searching JSON values stored within these objects
|
|
136
132
|
to filter and match data using JSON Path expressions.
|
|
@@ -60,10 +60,7 @@ export interface GridFilterModelConfig {
|
|
|
60
60
|
* gridModel's store.
|
|
61
61
|
*/
|
|
62
62
|
bind?: Store | View;
|
|
63
|
-
/**
|
|
64
|
-
* True to update filters immediately after each change made in the column-based filter UI.
|
|
65
|
-
* Defaults to False.
|
|
66
|
-
*/
|
|
63
|
+
/** True (default) to update filters immediately after each change made in the column-based filter UI.*/
|
|
67
64
|
commitOnChange?: boolean;
|
|
68
65
|
/**
|
|
69
66
|
* Specifies the fields this model supports for filtering. Should be configs for
|
|
@@ -11,8 +11,9 @@ export interface StoreFilterFieldProps extends DefaultHoistProps {
|
|
|
11
11
|
autoApply?: boolean;
|
|
12
12
|
/**
|
|
13
13
|
* Field on optional model to which this component should bind its raw (text) value to persist
|
|
14
|
-
* across renders. Specify this field to control the state of this component directly
|
|
15
|
-
*
|
|
14
|
+
* across renders. Specify this field to control the state of this component directly or if
|
|
15
|
+
* deliberately not connecting this component to a Store/GridModel. These are both advanced
|
|
16
|
+
* use-cases - this prop is typically left unset.
|
|
16
17
|
*/
|
|
17
18
|
bind?: string;
|
|
18
19
|
/** Names of field(s) to exclude from search. Cannot be used with `includeFields`. */
|
|
@@ -11,7 +11,6 @@ export declare class ValuesTabModel extends HoistModel {
|
|
|
11
11
|
pendingValues: any[];
|
|
12
12
|
/** Bound search term for `StoreFilterField` */
|
|
13
13
|
filterText: string;
|
|
14
|
-
combineCurrentFilters: boolean;
|
|
15
14
|
/** FieldFilter output by this model. */
|
|
16
15
|
get filter(): FieldFilterSpec;
|
|
17
16
|
get allVisibleRecsChecked(): boolean;
|
|
@@ -27,7 +26,6 @@ export declare class ValuesTabModel extends HoistModel {
|
|
|
27
26
|
reset(): void;
|
|
28
27
|
setRecsChecked(isChecked: boolean, values: any[]): void;
|
|
29
28
|
toggleAllRecsChecked(): void;
|
|
30
|
-
setPendingValues(): void;
|
|
31
29
|
private getFilter;
|
|
32
30
|
private doSyncWithFilter;
|
|
33
31
|
private syncGrid;
|
package/cmp/grid/Types.ts
CHANGED
|
@@ -90,10 +90,7 @@ export interface GridFilterModelConfig {
|
|
|
90
90
|
*/
|
|
91
91
|
bind?: Store | View;
|
|
92
92
|
|
|
93
|
-
/**
|
|
94
|
-
* True to update filters immediately after each change made in the column-based filter UI.
|
|
95
|
-
* Defaults to False.
|
|
96
|
-
*/
|
|
93
|
+
/** True (default) to update filters immediately after each change made in the column-based filter UI.*/
|
|
97
94
|
commitOnChange?: boolean;
|
|
98
95
|
|
|
99
96
|
/**
|
|
@@ -46,7 +46,7 @@ export class GridFilterModel extends HoistModel {
|
|
|
46
46
|
static BLANK_PLACEHOLDER = '[blank]';
|
|
47
47
|
|
|
48
48
|
constructor(
|
|
49
|
-
{bind, commitOnChange =
|
|
49
|
+
{bind, commitOnChange = true, fieldSpecs, fieldSpecDefaults}: GridFilterModelConfig,
|
|
50
50
|
gridModel: GridModel
|
|
51
51
|
) {
|
|
52
52
|
super();
|
|
@@ -21,8 +21,9 @@ export interface StoreFilterFieldProps extends DefaultHoistProps {
|
|
|
21
21
|
|
|
22
22
|
/**
|
|
23
23
|
* Field on optional model to which this component should bind its raw (text) value to persist
|
|
24
|
-
* across renders. Specify this field to control the state of this component directly
|
|
25
|
-
*
|
|
24
|
+
* across renders. Specify this field to control the state of this component directly or if
|
|
25
|
+
* deliberately not connecting this component to a Store/GridModel. These are both advanced
|
|
26
|
+
* use-cases - this prop is typically left unset.
|
|
26
27
|
*/
|
|
27
28
|
bind?: string;
|
|
28
29
|
|
|
@@ -1,17 +1,4 @@
|
|
|
1
1
|
.xh-values-filter-tab {
|
|
2
|
-
.store-filter-header {
|
|
3
|
-
padding: 5px 7px;
|
|
4
|
-
border-bottom: 1px solid var(--xh-grid-header-border-color);
|
|
5
|
-
row-gap: 5px;
|
|
6
|
-
.bp5-control-indicator {
|
|
7
|
-
font-size: 1em;
|
|
8
|
-
}
|
|
9
|
-
span {
|
|
10
|
-
font-size: var(--xh-grid-compact-header-font-size-px);
|
|
11
|
-
color: var(--xh-grid-header-text-color);
|
|
12
|
-
}
|
|
13
|
-
}
|
|
14
|
-
|
|
15
2
|
&__hidden-values-message {
|
|
16
3
|
display: flex;
|
|
17
4
|
padding: var(--xh-pad-half-px);
|
|
@@ -5,11 +5,10 @@
|
|
|
5
5
|
* Copyright © 2025 Extremely Heavy Industries Inc.
|
|
6
6
|
*/
|
|
7
7
|
import {grid} from '@xh/hoist/cmp/grid';
|
|
8
|
-
import {div,
|
|
8
|
+
import {div, placeholder, vframe} from '@xh/hoist/cmp/layout';
|
|
9
9
|
import {storeFilterField} from '@xh/hoist/cmp/store';
|
|
10
10
|
import {hoistCmp, uses} from '@xh/hoist/core';
|
|
11
11
|
import {button} from '@xh/hoist/desktop/cmp/button';
|
|
12
|
-
import {checkbox} from '@xh/hoist/desktop/cmp/input';
|
|
13
12
|
import {panel} from '@xh/hoist/desktop/cmp/panel';
|
|
14
13
|
import {toolbar} from '@xh/hoist/desktop/cmp/toolbar';
|
|
15
14
|
import {Icon} from '@xh/hoist/icon';
|
|
@@ -40,8 +39,7 @@ const tbar = hoistCmp.factory(() => {
|
|
|
40
39
|
placeholder: 'Search...',
|
|
41
40
|
flex: 1,
|
|
42
41
|
autoFocus: true,
|
|
43
|
-
matchMode: 'any'
|
|
44
|
-
includeFields: ['value']
|
|
42
|
+
matchMode: 'any'
|
|
45
43
|
})
|
|
46
44
|
);
|
|
47
45
|
});
|
|
@@ -49,33 +47,7 @@ const tbar = hoistCmp.factory(() => {
|
|
|
49
47
|
const body = hoistCmp.factory<ValuesTabModel>(({model}) => {
|
|
50
48
|
const {isCustomFilter} = model.headerFilterModel;
|
|
51
49
|
if (isCustomFilter) return customFilterPlaceholder();
|
|
52
|
-
return vframe(
|
|
53
|
-
});
|
|
54
|
-
|
|
55
|
-
const storeFilterSelect = hoistCmp.factory<ValuesTabModel>(({model}) => {
|
|
56
|
-
const {gridModel, allVisibleRecsChecked, filterText, headerFilterModel} = model,
|
|
57
|
-
{store} = gridModel;
|
|
58
|
-
return vbox({
|
|
59
|
-
className: 'store-filter-header',
|
|
60
|
-
items: [
|
|
61
|
-
hframe(
|
|
62
|
-
checkbox({
|
|
63
|
-
disabled: store.empty,
|
|
64
|
-
displayUnsetState: true,
|
|
65
|
-
value: allVisibleRecsChecked,
|
|
66
|
-
onChange: () => model.toggleAllRecsChecked()
|
|
67
|
-
}),
|
|
68
|
-
span(`(Select All${filterText ? ' Search Results' : ''})`)
|
|
69
|
-
),
|
|
70
|
-
hframe({
|
|
71
|
-
omit: !filterText || store.empty || headerFilterModel.commitOnChange,
|
|
72
|
-
items: [
|
|
73
|
-
checkbox({bind: 'combineCurrentFilters'}),
|
|
74
|
-
span(`Add current selection to filter`)
|
|
75
|
-
]
|
|
76
|
-
})
|
|
77
|
-
]
|
|
78
|
-
});
|
|
50
|
+
return vframe(grid(), hiddenValuesMessage());
|
|
79
51
|
});
|
|
80
52
|
|
|
81
53
|
const customFilterPlaceholder = hoistCmp.factory<ValuesTabModel>(({model}) => {
|
|
@@ -10,7 +10,7 @@ import {FieldFilterSpec} from '@xh/hoist/data';
|
|
|
10
10
|
import {HeaderFilterModel} from '../HeaderFilterModel';
|
|
11
11
|
import {checkbox} from '@xh/hoist/desktop/cmp/input';
|
|
12
12
|
import {action, bindable, computed, makeObservable, observable} from '@xh/hoist/mobx';
|
|
13
|
-
import {castArray, difference,
|
|
13
|
+
import {castArray, difference, isEmpty, partition, uniq, without} from 'lodash';
|
|
14
14
|
|
|
15
15
|
export class ValuesTabModel extends HoistModel {
|
|
16
16
|
override xhImpl = true;
|
|
@@ -26,12 +26,6 @@ export class ValuesTabModel extends HoistModel {
|
|
|
26
26
|
/** Bound search term for `StoreFilterField` */
|
|
27
27
|
@bindable filterText: string = null;
|
|
28
28
|
|
|
29
|
-
/*
|
|
30
|
-
* Available only when commit on change is false merge
|
|
31
|
-
* current filter with pendingValues on commit
|
|
32
|
-
*/
|
|
33
|
-
@bindable combineCurrentFilters: boolean = false;
|
|
34
|
-
|
|
35
29
|
/** FieldFilter output by this model. */
|
|
36
30
|
@computed.struct
|
|
37
31
|
get filter(): FieldFilterSpec {
|
|
@@ -87,18 +81,11 @@ export class ValuesTabModel extends HoistModel {
|
|
|
87
81
|
this.headerFilterModel = headerFilterModel;
|
|
88
82
|
this.gridModel = this.createGridModel();
|
|
89
83
|
|
|
90
|
-
this.addReaction(
|
|
91
|
-
|
|
92
|
-
|
|
93
|
-
|
|
94
|
-
|
|
95
|
-
},
|
|
96
|
-
{
|
|
97
|
-
track: () => [this.filterText, this.combineCurrentFilters],
|
|
98
|
-
run: () => this.setPendingValues(),
|
|
99
|
-
debounce: 300
|
|
100
|
-
}
|
|
101
|
-
);
|
|
84
|
+
this.addReaction({
|
|
85
|
+
track: () => this.pendingValues,
|
|
86
|
+
run: () => this.syncGrid(),
|
|
87
|
+
fireImmediately: true
|
|
88
|
+
});
|
|
102
89
|
}
|
|
103
90
|
|
|
104
91
|
syncWithFilter() {
|
|
@@ -128,29 +115,6 @@ export class ValuesTabModel extends HoistModel {
|
|
|
128
115
|
//-------------------
|
|
129
116
|
// Implementation
|
|
130
117
|
//-------------------
|
|
131
|
-
@action
|
|
132
|
-
setPendingValues() {
|
|
133
|
-
if (!this.filterText) {
|
|
134
|
-
this.doSyncWithFilter();
|
|
135
|
-
this.syncGrid();
|
|
136
|
-
return;
|
|
137
|
-
}
|
|
138
|
-
|
|
139
|
-
const {records} = this.gridModel.store,
|
|
140
|
-
currentFilterValues = flatten(map(this.columnFilters, 'value')),
|
|
141
|
-
checkedRecs = records.filter(
|
|
142
|
-
it =>
|
|
143
|
-
this.headerFilterModel.commitOnChange ||
|
|
144
|
-
currentFilterValues.length ||
|
|
145
|
-
it.get('isChecked')
|
|
146
|
-
),
|
|
147
|
-
values = map(checkedRecs, it => it.get('value'));
|
|
148
|
-
|
|
149
|
-
this.pendingValues = uniq(
|
|
150
|
-
this.combineCurrentFilters ? [...currentFilterValues, ...values] : values
|
|
151
|
-
);
|
|
152
|
-
}
|
|
153
|
-
|
|
154
118
|
private getFilter() {
|
|
155
119
|
const {gridFilterModel, pendingValues, values, valueCount, field} = this,
|
|
156
120
|
included = pendingValues.map(it => gridFilterModel.fromDisplayValue(it)),
|
|
@@ -253,10 +217,17 @@ export class ValuesTabModel extends HoistModel {
|
|
|
253
217
|
onRowClicked: ({data: record}) => {
|
|
254
218
|
this.setRecsChecked(!record.get('isChecked'), record.get('value'));
|
|
255
219
|
},
|
|
256
|
-
hideHeaders: true,
|
|
257
220
|
columns: [
|
|
258
221
|
{
|
|
259
222
|
field: 'isChecked',
|
|
223
|
+
headerName: ({gridModel}) => {
|
|
224
|
+
return checkbox({
|
|
225
|
+
disabled: gridModel.store.empty,
|
|
226
|
+
displayUnsetState: true,
|
|
227
|
+
value: this.allVisibleRecsChecked,
|
|
228
|
+
onChange: () => this.toggleAllRecsChecked()
|
|
229
|
+
});
|
|
230
|
+
},
|
|
260
231
|
width: 28,
|
|
261
232
|
autosizable: false,
|
|
262
233
|
pinned: true,
|
|
@@ -274,6 +245,7 @@ export class ValuesTabModel extends HoistModel {
|
|
|
274
245
|
},
|
|
275
246
|
{
|
|
276
247
|
field: 'value',
|
|
248
|
+
displayName: '(Select All)',
|
|
277
249
|
align: 'left',
|
|
278
250
|
comparator: (v1, v2, sortDir, abs, {defaultComparator}) => {
|
|
279
251
|
const mul = sortDir === 'desc' ? -1 : 1;
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@xh/hoist",
|
|
3
|
-
"version": "73.0.0-SNAPSHOT.
|
|
3
|
+
"version": "73.0.0-SNAPSHOT.1746639145721",
|
|
4
4
|
"description": "Hoist add-on for building and deploying React Applications.",
|
|
5
5
|
"repository": "github:xh/hoist-react",
|
|
6
6
|
"homepage": "https://xh.io",
|