Skip to content

Commit

Permalink
fix: hidden rows in filter plugin
Browse files Browse the repository at this point in the history
  • Loading branch information
m2a2x committed Nov 14, 2024
1 parent 9554909 commit 42a45be
Show file tree
Hide file tree
Showing 12 changed files with 79 additions and 39 deletions.
2 changes: 1 addition & 1 deletion docs
Submodule docs updated 227 files
2 changes: 1 addition & 1 deletion packages/angular
2 changes: 1 addition & 1 deletion packages/svelte
Submodule svelte updated 1 files
+2 −2 package.json
2 changes: 1 addition & 1 deletion packages/vue3
Submodule vue3 updated 2 files
+2 −2 demo/package.json
+2 −2 package.json
6 changes: 2 additions & 4 deletions src/components.d.ts
Original file line number Diff line number Diff line change
Expand Up @@ -5,7 +5,7 @@
* It contains typing information for all components that exist in this project.
*/
import { HTMLStencilElement, JSXBase } from "@stencil/core/internal";
import { AfterEditEvent, AllDimensionType, ApplyFocusEvent, BeforeCellRenderEvent, BeforeEdit, BeforeRangeSaveDataDetails, BeforeRowRenderEvent, BeforeSaveDataDetails, Cell, CellTemplateProp, ChangedRange, ColumnDataSchemaModel, ColumnGrouping, ColumnProp, ColumnRegular, ColumnType, DataFormat, DataType, DimensionCols, DimensionRows, DimensionSettingsState, DimensionType, DimensionTypeCol, DragStartEvent, EditCell, EditorCtr, Editors, ElementScroll, ExtraNodeFuncConfig, FocusAfterRenderEvent, FocusRenderEvent, FocusTemplateFunc, HyperFunc, InitialHeaderClick, MultiDimensionType, Nullable, PluginBaseComponent, PositionItem, Providers, RangeArea, RangeClipboardCopyEventProps, RangeClipboardPasteEvent, RowDefinition, RowHeaders, SaveDataDetails, SelectionStoreState, TempRange, Theme, ViewportData, ViewPortResizeEvent, ViewPortScrollEvent, ViewportState, ViewSettingSizeProp } from "./types/index";
import { AfterEditEvent, AllDimensionType, ApplyFocusEvent, BeforeCellRenderEvent, BeforeEdit, BeforeRangeSaveDataDetails, BeforeRowRenderEvent, BeforeSaveDataDetails, Cell, CellTemplateProp, ChangedRange, ColumnDataSchemaModel, ColumnGrouping, ColumnProp, ColumnRegular, ColumnType, DataFormat, DataType, DimensionCols, DimensionRows, DimensionSettingsState, DimensionType, DimensionTypeCol, DragStartEvent, EditCell, EditorCtr, Editors, ElementScroll, ExtraNodeFuncConfig, FocusAfterRenderEvent, FocusRenderEvent, FocusTemplateFunc, InitialHeaderClick, MultiDimensionType, Nullable, PluginBaseComponent, PositionItem, Providers, RangeArea, RangeClipboardCopyEventProps, RangeClipboardPasteEvent, RowDefinition, RowHeaders, SaveDataDetails, SelectionStoreState, TempRange, Theme, ViewportData, ViewPortResizeEvent, ViewPortScrollEvent, ViewportState, ViewSettingSizeProp } from "./types/index";
import { GridPlugin } from "./plugins/base.plugin";
import { AutoSizeColumnConfig } from "./plugins/column.auto-size.plugin";
import { ColumnFilterConfig, FilterCaptions, FilterCollection, LogicFunction, MultiFilterItem, ShowData } from "./plugins/filter/filter.types";
Expand All @@ -19,7 +19,7 @@ import { DSourceState, Groups } from "./store/index";
import { ResizeProps } from "./components/header/resizable.directive";
import { HeaderRenderProps } from "./components/header/header-renderer";
import { EventData } from "./components/overlay/selection.utils";
export { AfterEditEvent, AllDimensionType, ApplyFocusEvent, BeforeCellRenderEvent, BeforeEdit, BeforeRangeSaveDataDetails, BeforeRowRenderEvent, BeforeSaveDataDetails, Cell, CellTemplateProp, ChangedRange, ColumnDataSchemaModel, ColumnGrouping, ColumnProp, ColumnRegular, ColumnType, DataFormat, DataType, DimensionCols, DimensionRows, DimensionSettingsState, DimensionType, DimensionTypeCol, DragStartEvent, EditCell, EditorCtr, Editors, ElementScroll, ExtraNodeFuncConfig, FocusAfterRenderEvent, FocusRenderEvent, FocusTemplateFunc, HyperFunc, InitialHeaderClick, MultiDimensionType, Nullable, PluginBaseComponent, PositionItem, Providers, RangeArea, RangeClipboardCopyEventProps, RangeClipboardPasteEvent, RowDefinition, RowHeaders, SaveDataDetails, SelectionStoreState, TempRange, Theme, ViewportData, ViewPortResizeEvent, ViewPortScrollEvent, ViewportState, ViewSettingSizeProp } from "./types/index";
export { AfterEditEvent, AllDimensionType, ApplyFocusEvent, BeforeCellRenderEvent, BeforeEdit, BeforeRangeSaveDataDetails, BeforeRowRenderEvent, BeforeSaveDataDetails, Cell, CellTemplateProp, ChangedRange, ColumnDataSchemaModel, ColumnGrouping, ColumnProp, ColumnRegular, ColumnType, DataFormat, DataType, DimensionCols, DimensionRows, DimensionSettingsState, DimensionType, DimensionTypeCol, DragStartEvent, EditCell, EditorCtr, Editors, ElementScroll, ExtraNodeFuncConfig, FocusAfterRenderEvent, FocusRenderEvent, FocusTemplateFunc, InitialHeaderClick, MultiDimensionType, Nullable, PluginBaseComponent, PositionItem, Providers, RangeArea, RangeClipboardCopyEventProps, RangeClipboardPasteEvent, RowDefinition, RowHeaders, SaveDataDetails, SelectionStoreState, TempRange, Theme, ViewportData, ViewPortResizeEvent, ViewPortScrollEvent, ViewportState, ViewSettingSizeProp } from "./types/index";
export { GridPlugin } from "./plugins/base.plugin";
export { AutoSizeColumnConfig } from "./plugins/column.auto-size.plugin";
export { ColumnFilterConfig, FilterCaptions, FilterCollection, LogicFunction, MultiFilterItem, ShowData } from "./plugins/filter/filter.types";
Expand Down Expand Up @@ -434,7 +434,6 @@ export namespace Components {
* Disables dynamic filtering. A way to apply filters on Save only
*/
"disableDynamicFiltering": boolean;
"extraContent"?: (h: HyperFunc<VNode>, data: ShowData) => VNode | VNode[];
"filterCaptions": FilterCaptions | undefined;
"filterEntities": Record<string, LogicFunction>;
"filterNames": Record<string, string>;
Expand Down Expand Up @@ -1813,7 +1812,6 @@ declare namespace LocalJSX {
* Disables dynamic filtering. A way to apply filters on Save only
*/
"disableDynamicFiltering"?: boolean;
"extraContent"?: (h: HyperFunc<VNode>, data: ShowData) => VNode | VNode[];
"filterCaptions"?: FilterCaptions | undefined;
"filterEntities"?: Record<string, LogicFunction>;
"filterNames"?: Record<string, string>;
Expand Down
8 changes: 4 additions & 4 deletions src/components/revoGrid/plugin.service.ts
Original file line number Diff line number Diff line change
@@ -1,11 +1,11 @@
import { PluginBaseComponent, PluginProviders } from '@type';
import { BasePlugin, GridPlugin } from 'src/plugins';
import { PluginBaseComponent, PluginProviders, PluginServiceBase } from '@type';
import { GridPlugin } from 'src/plugins';

/**
* Plugin service
* Manages plugins
*/
export class PluginService {
export class PluginService implements PluginServiceBase {
/**
* Plugins
* Define plugins collection
Expand Down Expand Up @@ -72,7 +72,7 @@ export class PluginService {
/**
* Get plugin by class
*/
getByClass<T extends BasePlugin>(
getByClass<T extends PluginBaseComponent>(
pluginClass: new (...args: any[]) => T,
): T | undefined {
return this.internalPlugins.find(p => p instanceof pluginClass) as
Expand Down
1 change: 1 addition & 0 deletions src/components/revoGrid/revo-grid.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -1394,6 +1394,7 @@ export class RevoGridComponent {
dimension: this.dimensionProvider,
viewport: this.viewportProvider,
selection: this.selectionStoreConnector,
plugins: this.pluginService,
};

return pluginData;
Expand Down
2 changes: 1 addition & 1 deletion src/index.ts
Original file line number Diff line number Diff line change
Expand Up @@ -4,4 +4,4 @@ export * from './plugins';
export * from './components';
export * from './utils';
export { TextEditor } from './components/editors/text-editor';
export { h } from '@stencil/core';
export { h, type FunctionalComponent } from '@stencil/core';
44 changes: 28 additions & 16 deletions src/plugins/filter/filter.panel.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -21,7 +21,7 @@ import {
MultiFilterItem,
ShowData,
} from './filter.types';
import { ColumnProp, HyperFunc } from '@type';
import type { ColumnProp } from '@type';
import { FilterType } from './filter.indexed';

const defaultType: FilterType = 'none';
Expand All @@ -48,7 +48,7 @@ export class FilterPanel {
// drops the filter
reset: 'Reset',
cancel: 'Cancel',
add: 'Add more condition...',
add: 'Add condition',
placeholder: 'Enter value...',
and: 'and',
or: 'or',
Expand All @@ -68,9 +68,6 @@ export class FilterPanel {
* Disables dynamic filtering. A way to apply filters on Save only
*/
@Prop() disableDynamicFiltering = false;

@Prop() extraContent?: (h: HyperFunc<VNode>, data: ShowData) => VNode | VNode[];

@Event() filterChange: EventEmitter<MultiFilterItem>;
@Event() resetChange: EventEmitter<ColumnProp>;

Expand Down Expand Up @@ -132,7 +129,7 @@ export class FilterPanel {
const prop = this.changes?.prop;
if (typeof prop === 'undefined') return '';

const propFilters = this.filterItems[prop]?.filter(f => !f.hidden) || [];
const propFilters = this.filterItems[prop];
const capts = Object.assign(
this.filterCaptionsInternal,
this.filterCaptions,
Expand All @@ -141,6 +138,9 @@ export class FilterPanel {
<div key={this.filterId}>
{propFilters.map((filter, index) => {
let andOrButton;
if (filter.hidden) {
return;
}

// hide toggle button if there is only one filter and the last one
if (index !== this.filterItems[prop].length - 1) {
Expand Down Expand Up @@ -175,7 +175,7 @@ export class FilterPanel {
);
})}

{propFilters.length > 0 ? <div class="add-filter-divider" /> : ''}
{propFilters.filter(f => !f.hidden).length > 0 ? <div class="add-filter-divider" /> : ''}
</div>
);
}
Expand Down Expand Up @@ -365,6 +365,15 @@ export class FilterPanel {
const options: VNode[] = [];
const prop = this.changes.prop;

const hidden = new Set<string>();
Object.entries(this.filterItems).forEach(([_, values]) => {
values.forEach((filter) => {
if (filter.hidden) {
hidden.add(filter.type);
}
})
});

if (!isDefaultTypeRemoved) {
const capts = Object.assign(
this.filterCaptionsInternal,
Expand All @@ -384,14 +393,17 @@ export class FilterPanel {
}

for (let gIndex in this.changes.filterTypes) {
options.push(
...this.changes.filterTypes[gIndex].map(k => (
<option value={k} selected={type === k}>
{this.filterNames[k]}
</option>
)),
);
options.push(<option disabled></option>);
const group = this.changes.filterTypes[gIndex].filter(k => !hidden.has(k));
if (group.length) {
options.push(
...group.map(k => (
<option value={k} selected={type === k}>
{this.filterNames[k]}
</option>
)),
);
options.push(<option disabled></option>);
}
}
return options;
}
Expand Down Expand Up @@ -444,7 +456,7 @@ export class FilterPanel {
}}
>
<slot slot="header" />
{ this.extraContent?.(h, this.changes) }
{ this.changes.extraContent?.(this.changes) || '' }
<label>{capts.title}</label>
<div class="filter-holder">{this.getFilterItemsList()}</div>

Expand Down
25 changes: 18 additions & 7 deletions src/plugins/filter/filter.plugin.tsx
Original file line number Diff line number Diff line change
@@ -1,6 +1,6 @@
import { h, type VNode } from '@stencil/core';

import type { ColumnProp, ColumnRegular, DataType, HyperFunc, PluginProviders } from '@type';
import type { ColumnProp, ColumnRegular, DataType, PluginProviders } from '@type';
import { BasePlugin } from '../base.plugin';
import { FILTER_PROP, isFilterBtn } from './filter.button';
import {
Expand Down Expand Up @@ -47,6 +47,14 @@ export class FilterPlugin extends BasePlugin {
filterCollection: FilterCollection = {};
multiFilterItems: MultiFilterItem = {};

/**
* Filter types
* @example
* {
* string: ['contains', 'beginswith'],
* number: ['eqN', 'neqN', 'gt']
* }
*/
filterByType: Record<string, string[]> =
{ ...filterTypes };
filterNameIndexByType: Record<string, string> = {
Expand All @@ -58,12 +66,12 @@ export class FilterPlugin extends BasePlugin {

filterProp = FILTER_PROP;

extraHyperContent?: (h: HyperFunc<VNode>, data: ShowData) => VNode | VNode[];
extraHyperContent?: (data: ShowData) => VNode | VNode[];

constructor(
public revogrid: HTMLRevoGridElement,
providers: PluginProviders,
config?: ColumnFilterConfig,
public config?: ColumnFilterConfig,
) {
super(revogrid, providers);
if (config) {
Expand All @@ -82,7 +90,6 @@ export class FilterPlugin extends BasePlugin {
onFilterChange={e => this.onFilterChange(e.detail)}
onResetChange={e => this.onFilterReset(e.detail)}
disableDynamicFiltering={config?.disableDynamicFiltering}
extraContent={this.extraHyperContent}
ref={e => (this.pop = e)}
> { this.extraContent() }</revogr-filter-panel>,
];
Expand Down Expand Up @@ -111,7 +118,7 @@ export class FilterPlugin extends BasePlugin {
};
this.addEventListener(
'headerclick',
(e: CustomEvent<HTMLRevoGridElementEventMap['headerclick']>) =>
(e) =>
this.headerclick(e),
);
this.addEventListener(
Expand Down Expand Up @@ -220,14 +227,18 @@ export class FilterPlugin extends BasePlugin {
const buttonPos = el.getBoundingClientRect();
const prop = e.detail.prop;

this.pop.show({
const data: ShowData = {
...e.detail,
...this.filterCollection[prop],
x: buttonPos.x - gridPos.x,
y: buttonPos.y - gridPos.y + buttonPos.height,
autoCorrect: true,
prop,
filterTypes: this.getColumnFilter(e.detail.filter),
filterItems: this.multiFilterItems,
};
this.pop.show({
...data,
extraContent: this.extraHyperContent,
});
}

Expand Down
8 changes: 5 additions & 3 deletions src/plugins/filter/filter.types.ts
Original file line number Diff line number Diff line change
@@ -1,5 +1,5 @@
import { ColumnProp } from '@type';
import { FilterType } from './filter.indexed';
import type { ColumnProp, ColumnRegular } from '@type';
import type { FilterType } from './filter.indexed';

export type DateEnum =
| 'today'
Expand Down Expand Up @@ -143,4 +143,6 @@ export type ShowData = {
autoCorrect?: boolean;
filterTypes?: Record<string, string[]>;
filterItems?: MultiFilterItem;
} & FilterItem;
// pass vnodes from plugins
extraContent?: (data: ShowData) => any;
} & FilterItem & Omit<ColumnRegular, 'filter'>;
16 changes: 16 additions & 0 deletions src/types/plugin.types.ts
Original file line number Diff line number Diff line change
@@ -1,9 +1,19 @@
import { PluginBaseComponent } from '@type';
import ColumnDataProvider from '../services/column.data.provider';
import { DataProvider } from '../services/data.provider';
import DimensionProvider from '../services/dimension.provider';
import type { SelectionStoreConnector } from '../services/selection.store.connector';
import ViewportProvider from '../services/viewport.provider';

export interface PluginServiceBase {
get(): PluginBaseComponent[];
add(plugin: PluginBaseComponent): void;
remove(plugin: PluginBaseComponent): void;
getByClass<T extends PluginBaseComponent>(
pluginClass: new (...args: any[]) => T,
): T | undefined;
}

/**
* Services that are provided by the various plugins for use by the grid. Each plugin
* is responsible for providing a specific service, and the `PluginProviders` type collects all the services provided
Expand All @@ -30,6 +40,12 @@ export type PluginProviders = {
* The viewport service provides access to the grid's viewport state.
*/
viewport: ViewportProvider;

/**
* Plugin services
*/

plugins: PluginServiceBase;
};


Expand Down

0 comments on commit 42a45be

Please sign in to comment.