Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

feat: Create UI to Display Partitioned Tables #1663

Merged
merged 40 commits into from
Jan 18, 2024
Merged
Show file tree
Hide file tree
Changes from 16 commits
Commits
Show all changes
40 commits
Select commit Hold shift + click to select a range
9c94210
Create IrisGridPartitionedTableModel
georgecwan Oct 23, 2023
00c96df
Merge branch 'main' of https://github.com/deephaven/web-client-ui int…
georgecwan Nov 2, 2023
12b638c
Handle partitions and partitionColumns with model
georgecwan Nov 6, 2023
dffd2bb
Update IrisGridPartitionSelector for PartitionedTable
georgecwan Nov 16, 2023
7ead3b5
Fix partially selected partitions
georgecwan Nov 16, 2023
ac52c3f
Merge branch 'main' of github.com:GcWan/web-client-ui into 1143-parti…
georgecwan Nov 16, 2023
35120eb
Fix minor bugs and button formatting
georgecwan Nov 22, 2023
64cfaf4
Add new partition selector dropdowns
georgecwan Nov 29, 2023
563a6c5
Merge branch 'main' of https://github.com/deephaven/web-client-ui int…
georgecwan Nov 29, 2023
a2cdec0
Fix bug when no partition is selected
georgecwan Nov 29, 2023
6bcb03a
Fix error with char and long types
georgecwan Nov 29, 2023
0b578b1
Fix unit tests
georgecwan Nov 30, 2023
5f69436
Rename PartitionedTable model file
georgecwan Nov 30, 2023
3a5c1fb
Update key tables to match jsapi
georgecwan Dec 1, 2023
208dd61
Remove partitionColumns setter
georgecwan Dec 7, 2023
3131270
Check partition in IrisGridTableModel constructor
georgecwan Dec 7, 2023
93ab3bc
Merge branch 'main' of https://github.com/deephaven/web-client-ui int…
georgecwan Dec 7, 2023
105dc3a
Fix styling
georgecwan Dec 11, 2023
57d787e
Remove recursion in partition selector
georgecwan Dec 12, 2023
a139bf2
Remove log statements
georgecwan Dec 12, 2023
9eea801
Add PartitionedGridModel
georgecwan Dec 15, 2023
98f9ba3
Add PartitionedGridModel
georgecwan Dec 18, 2023
e01581a
Merge branch 'main' of https://github.com/deephaven/web-client-ui int…
georgecwan Dec 18, 2023
e86692c
Update unit tests
georgecwan Dec 18, 2023
820eb2e
Use model in partition selector
georgecwan Dec 22, 2023
5e82a31
Fix initial key selection
georgecwan Dec 22, 2023
394932d
Fix unit tests
georgecwan Dec 22, 2023
1899334
WIP cleaning up George's partitioned table selector
mofojed Jan 4, 2024
c0bf727
Cleaning up some more
mofojed Jan 5, 2024
6726531
Don't throw for getting properties
mofojed Jan 5, 2024
4e0ae6c
Some more cleanup
mofojed Jan 5, 2024
19a1b35
Fix bad import
mofojed Jan 5, 2024
a9e834b
Fix failing test
mofojed Jan 5, 2024
dd761a1
Fix rehydration and char partitions
mofojed Jan 5, 2024
cbd28aa
Merge remote-tracking branch 'origin/main' into 1143-partitioned-tabl…
mofojed Jan 5, 2024
f4cba3a
Fix review comments
mofojed Jan 8, 2024
02542dd
Fix the columns used in the partition selector
mofojed Jan 16, 2024
5ce6ff9
Fix issues found in review with ticking partition tables
mofojed Jan 18, 2024
b81cd58
Merge remote-tracking branch 'origin/main' into pr/georgecwan/1663
dsmmcken Jan 18, 2024
681bc24
adjust color variables
dsmmcken Jan 18, 2024
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
16 changes: 16 additions & 0 deletions packages/code-studio/src/styleguide/MockIrisGridTreeModel.ts
Original file line number Diff line number Diff line change
Expand Up @@ -222,6 +222,22 @@ class MockIrisGridTreeModel
// Ignore for mock
}

get partition(): never[] {
return [];
}

set partition(partition: never[]) {
// Ignore for mock
}

get partitionColumns(): never[] {
return [];
}

set partitionColumns(partitionColumns: never[]) {
// Ignore for mock
}

georgecwan marked this conversation as resolved.
Show resolved Hide resolved
set formatter(formatter: Formatter) {
// Ignore for mock
}
Expand Down
3 changes: 2 additions & 1 deletion packages/console/src/common/ConsoleUtils.ts
Original file line number Diff line number Diff line change
Expand Up @@ -56,7 +56,8 @@ class ConsoleUtils {
return (
type === dh.VariableType.TABLE ||
type === dh.VariableType.TREETABLE ||
type === dh.VariableType.HIERARCHICALTABLE
type === dh.VariableType.HIERARCHICALTABLE ||
type === dh.VariableType.PARTITIONEDTABLE
);
}

Expand Down
1 change: 1 addition & 0 deletions packages/console/src/common/ObjectIcon.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -14,6 +14,7 @@ function ObjectIcon({ type }: ObjectIconProps): JSX.Element {
case dh.VariableType.TABLEMAP:
case dh.VariableType.TREETABLE:
case dh.VariableType.HIERARCHICALTABLE:
case dh.VariableType.PARTITIONEDTABLE:
return <FontAwesomeIcon icon={dhTable} />;
case dh.VariableType.FIGURE:
return <FontAwesomeIcon icon={vsGraph} />;
Expand Down
7 changes: 6 additions & 1 deletion packages/dashboard-core-plugins/src/GridPluginConfig.ts
Original file line number Diff line number Diff line change
Expand Up @@ -9,7 +9,12 @@ const GridPluginConfig: WidgetPlugin = {
type: PluginType.WIDGET_PLUGIN,
component: GridWidgetPlugin,
panelComponent: GridPanelPlugin,
supportedTypes: ['Table', 'TreeTable', 'HierarchicalTable'],
supportedTypes: [
'Table',
'TreeTable',
'HierarchicalTable',
'PartitionedTable',
],
icon: dhTable,
};

Expand Down
2 changes: 0 additions & 2 deletions packages/dashboard-core-plugins/src/panels/IrisGridPanel.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -1240,7 +1240,6 @@ export class IrisGridPanel extends PureComponent<
model,
movedColumns,
movedRows,
partitions,
partitionColumns,
georgecwan marked this conversation as resolved.
Show resolved Hide resolved
quickFilters,
reverseType,
Expand Down Expand Up @@ -1321,7 +1320,6 @@ export class IrisGridPanel extends PureComponent<
isStuckToRight={isStuckToRight}
movedColumns={movedColumns}
movedRows={movedRows}
partitions={partitions}
partitionColumns={partitionColumns}
quickFilters={quickFilters}
reverseType={reverseType}
Expand Down
1 change: 1 addition & 0 deletions packages/embed-grid/src/App.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -23,6 +23,7 @@ const SUPPORTED_TYPES: string[] = [
dh.VariableType.TREETABLE,
dh.VariableType.HIERARCHICALTABLE,
dh.VariableType.PANDAS,
dh.VariableType.PARTITIONEDTABLE,
];

export type Command = 'filter' | 'sort';
Expand Down
262 changes: 262 additions & 0 deletions packages/iris-grid/src/EmptyIrisGridModel.ts
Original file line number Diff line number Diff line change
@@ -0,0 +1,262 @@
/* eslint class-methods-use-this: "off" */
import {
GridRange,
ModelIndex,
MoveOperation,
VisibleIndex,
} from '@deephaven/grid';
import {
Column,
ColumnStatistics,
CustomColumn,
dh as DhType,
FilterCondition,
Format,
RollupConfig,
Row,
Sort,
Table,
} from '@deephaven/jsapi-types';
import { ColumnName, Formatter } from '@deephaven/jsapi-utils';
import IrisGridModel from './IrisGridModel';
import ColumnHeaderGroup from './ColumnHeaderGroup';
import {
PendingDataErrorMap,
PendingDataMap,
UITotalsTableConfig,
} from './CommonTypes';

class EmptyIrisGridModel extends IrisGridModel {
constructor(dh: DhType, formatter = new Formatter(dh)) {
super(dh);

this.modelFormatter = formatter;
}

modelFormatter: Formatter;

get rowCount(): number {
return 0;
}

get columnCount(): number {
return 0;
}

textForCell(column: number, row: number): string {
return '';
}

textForColumnHeader(column: ModelIndex, depth?: number): string | undefined {
return undefined;
}

get columns(): readonly Column[] {
return [];
}

getColumnIndexByName(name: string): ModelIndex | undefined {
return undefined;
}

get initialMovedColumns(): readonly MoveOperation[] {
return [];
}

get initialMovedRows(): readonly MoveOperation[] {
return [];
}

get initialColumnHeaderGroups(): readonly ColumnHeaderGroup[] {
return [];
}

get groupedColumns(): readonly Column[] {
return [];
}

formatForCell(column: ModelIndex, row: ModelIndex): Format | undefined {
return undefined;
}

valueForCell(column: ModelIndex, row: ModelIndex): unknown {
return undefined;
}

get filter(): readonly FilterCondition[] {
return [];
}

set filter(filter: readonly FilterCondition[]) {
// No-op
}

get partition(): readonly unknown[] {
return [];
}

set partition(partition: readonly unknown[]) {
// No-op
}

get partitionColumns(): readonly Column[] {
return [];
}

get formatter(): Formatter {
return this.modelFormatter;
}

set formatter(formatter: Formatter) {
this.modelFormatter = formatter;
}

displayString(
value: unknown,
columnType: string,
columnName?: ColumnName
): string {
return '';
}

get sort(): Sort[] {
return [];
}

set sort(sort: Sort[]) {
// No-op
}

get customColumns(): readonly ColumnName[] {
return [];
}

set customColumns(customColumns: readonly ColumnName[]) {
// No-op
}

get formatColumns(): readonly CustomColumn[] {
return [];
}

updateFrozenColumns(columns: readonly ColumnName[]): void {
// Do nothing
}

get rollupConfig(): RollupConfig | null {
return null;
}

set rollupConfig(rollupConfig: RollupConfig | null) {
// No-op
}

get totalsConfig(): UITotalsTableConfig | null {
return null;
}

set totalsConfig(totalsConfig: UITotalsTableConfig | null) {
// No-op
}

export(): Promise<Table> {
throw new Error('Method not implemented.');
}

columnStatistics(column: Column): Promise<ColumnStatistics> {
throw new Error('Method not implemented.');
}

get selectDistinctColumns(): readonly ColumnName[] {
return [];
}

set selectDistinctColumns(selectDistinctColumns: readonly ColumnName[]) {
// No-op
}

get pendingDataMap(): PendingDataMap {
return new Map();
}

set pendingDataMap(map: PendingDataMap) {
// No-op
}

get pendingRowCount(): number {
return 0;
}

set pendingRowCount(count: number) {
// No-op
}

get pendingDataErrors(): PendingDataErrorMap {
return new Map();
}

commitPending(): Promise<void> {
return Promise.resolve();
}

setViewport(
top: VisibleIndex,
bottom: VisibleIndex,
columns?: Column[]
): void {
// No-op
}

snapshot(ranges: readonly GridRange[]): Promise<readonly unknown[][]> {
return Promise.resolve([]);
}

textSnapshot(
ranges: readonly GridRange[],
includeHeaders?: boolean,
formatValue?: (value: unknown, column: Column, row?: Row) => string
): Promise<string> {
return Promise.resolve('');
}

valuesTable(columns: Column | readonly Column[]): Promise<Table> {
throw new Error('Method not implemented.');
}

delete(ranges: readonly GridRange[]): Promise<void> {
return Promise.resolve();
}

seekRow(
startRow: number,
column: Column,
valueType: unknown,
value: unknown,
insensitive?: boolean,
contains?: boolean,
isBackwards?: boolean
): Promise<number> {
return Promise.resolve(0);
}

get columnHeaderGroups(): readonly ColumnHeaderGroup[] {
return [];
}

set columnHeaderGroups(groups: readonly ColumnHeaderGroup[]) {
// No-op
}

get columnHeaderGroupMap(): ReadonlyMap<string, ColumnHeaderGroup> {
return new Map();
}

getColumnHeaderParentGroup(
modelIndex: ModelIndex,
depth: number
): ColumnHeaderGroup | undefined {
return undefined;
}
}

export default EmptyIrisGridModel;
Loading
Loading