@vuu-ui/vuu-data-local 0.8.18-debug

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/package.json ADDED
@@ -0,0 +1,23 @@
1
+ {
2
+ "name": "@vuu-ui/vuu-data-local",
3
+ "version": "0.8.18-debug",
4
+ "author": "heswell",
5
+ "license": "Apache-2.0",
6
+ "devDependencies": {
7
+ "@vuu-ui/vuu-data-types": "0.8.18-debug",
8
+ "@vuu-ui/vuu-table-types": "0.8.18-debug",
9
+ "@vuu-ui/vuu-filter-types": "0.8.18-debug",
10
+ "@vuu-ui/vuu-protocol-types": "0.8.18-debug"
11
+ },
12
+ "dependencies": {
13
+ "@vuu-ui/vuu-utils": "0.8.18-debug"
14
+ },
15
+ "files": [
16
+ "cjs",
17
+ "esm",
18
+ "/types"
19
+ ],
20
+ "module": "esm/index.js",
21
+ "main": "cjs/index.js",
22
+ "types": "types/index.d.ts"
23
+ }
@@ -0,0 +1,8 @@
1
+ import { DataSourceRow } from "@vuu-ui/vuu-data-types";
2
+ import { VuuAggregation, VuuGroupBy } from "@vuu-ui/vuu-protocol-types";
3
+ import { ColumnMap } from "@vuu-ui/vuu-utils";
4
+ import { GroupMap } from "./group-utils";
5
+ export declare const count: (arr: any[]) => number;
6
+ export declare const aggregateData: (aggregations: VuuAggregation[], targetData: readonly DataSourceRow[], groupBy: VuuGroupBy, leafData: readonly DataSourceRow[], columnMap: ColumnMap, groupMap: GroupMap) => {
7
+ [key: string]: number;
8
+ };
@@ -0,0 +1,81 @@
1
+ import { DataSource, DataSourceConfig, DataSourceConstructorProps, DataSourceEvents, DataSourceFilter, DataSourceRow, DataSourceStatus, MenuRpcResponse, Selection, SubscribeCallback, SubscribeProps, TableSchema, VuuUIMessageInRPCEditReject, VuuUIMessageInRPCEditResponse } from "@vuu-ui/vuu-data-types";
2
+ import { ClientToServerEditRpc, ClientToServerMenuRPC, LinkDescriptorWithLabel, VuuAggregation, VuuGroupBy, VuuMenu, VuuRange, VuuRowDataItemType, VuuSort } from "@vuu-ui/vuu-protocol-types";
3
+ import { ColumnDescriptor } from "@vuu-ui/vuu-table-types";
4
+ import { ColumnMap, EventEmitter } from "@vuu-ui/vuu-utils";
5
+ export interface ArrayDataSourceConstructorProps extends Omit<DataSourceConstructorProps, "bufferSize" | "table"> {
6
+ columnDescriptors: ColumnDescriptor[];
7
+ data: Array<VuuRowDataItemType[]>;
8
+ dataMap?: ColumnMap;
9
+ keyColumn?: string;
10
+ rangeChangeRowset?: "delta" | "full";
11
+ }
12
+ export declare class ArrayDataSource extends EventEmitter<DataSourceEvents> implements DataSource {
13
+ #private;
14
+ private clientCallback;
15
+ private columnDescriptors;
16
+ /** sorted offsets of data within raw data, reflecting sort order
17
+ * of columns specified by client.
18
+ */
19
+ private dataIndices;
20
+ /** Map reflecting positions of data items in raw data */
21
+ private dataMap;
22
+ private groupMap;
23
+ /** the index of key field within raw data row */
24
+ private key;
25
+ private lastRangeServed;
26
+ private rangeChangeRowset;
27
+ private openTreeNodes;
28
+ protected _menu: VuuMenu | undefined;
29
+ protected selectedRows: Selection;
30
+ tableSchema: TableSchema;
31
+ viewport: string;
32
+ private keys;
33
+ protected processedData: DataSourceRow[] | undefined;
34
+ constructor({ aggregations, columnDescriptors, data, dataMap, filter, groupBy, keyColumn, rangeChangeRowset, sort, title, viewport, }: ArrayDataSourceConstructorProps);
35
+ subscribe({ viewport, columns, aggregations, range, sort, groupBy, filter, }: SubscribeProps, callback: SubscribeCallback): Promise<void>;
36
+ unsubscribe(): void;
37
+ suspend(): this;
38
+ resume(): this;
39
+ disable(): this;
40
+ enable(): this;
41
+ select(selected: Selection): void;
42
+ openTreeNode(key: string): void;
43
+ closeTreeNode(key: string): void;
44
+ get links(): LinkDescriptorWithLabel[] | undefined;
45
+ get menu(): VuuMenu | undefined;
46
+ get status(): DataSourceStatus;
47
+ get data(): DataSourceRow[];
48
+ get currentData(): DataSourceRow[];
49
+ get table(): import("@vuu-ui/vuu-protocol-types").VuuTable;
50
+ get config(): DataSourceConfig;
51
+ set config(config: DataSourceConfig);
52
+ applyConfig(config: DataSourceConfig): true | undefined;
53
+ get selectedRowsCount(): number;
54
+ get size(): number;
55
+ get range(): VuuRange;
56
+ set range(range: VuuRange);
57
+ protected delete(row: VuuRowDataItemType[]): void;
58
+ protected insert: (row: VuuRowDataItemType[]) => void;
59
+ protected update: (row: VuuRowDataItemType[], columnName: string) => void;
60
+ protected updateRow: (row: VuuRowDataItemType[]) => void;
61
+ private setRange;
62
+ sendRowsToClient(forceFullRefresh?: boolean, row?: DataSourceRow): void;
63
+ get columns(): string[];
64
+ set columns(columns: string[]);
65
+ get aggregations(): VuuAggregation[];
66
+ set aggregations(aggregations: VuuAggregation[]);
67
+ get sort(): VuuSort;
68
+ set sort(sort: VuuSort);
69
+ get filter(): DataSourceFilter;
70
+ set filter(filter: DataSourceFilter);
71
+ get groupBy(): VuuGroupBy;
72
+ set groupBy(groupBy: VuuGroupBy);
73
+ get title(): string | undefined;
74
+ set title(title: string | undefined);
75
+ get _clientCallback(): SubscribeCallback | undefined;
76
+ createLink({ parentVpId, link: { fromColumn, toColumn }, }: LinkDescriptorWithLabel): void;
77
+ removeLink(): void;
78
+ private findRow;
79
+ applyEdit(row: DataSourceRow, columnName: string, value: VuuRowDataItemType): Promise<true>;
80
+ menuRpcCall(rpcRequest: Omit<ClientToServerMenuRPC, "vpId"> | ClientToServerEditRpc): Promise<MenuRpcResponse | VuuUIMessageInRPCEditReject | VuuUIMessageInRPCEditResponse | undefined>;
81
+ }
@@ -0,0 +1,4 @@
1
+ import { DataSourceRow, Selection } from "@vuu-ui/vuu-data-types";
2
+ import { ColumnMap, KeySet } from "@vuu-ui/vuu-utils";
3
+ export declare const toClientRow: (row: DataSourceRow, keys: KeySet, selection: Selection, dataIndices?: number[]) => DataSourceRow;
4
+ export declare const buildDataToClientMap: (columnMap: ColumnMap, dataMap?: ColumnMap) => number[] | undefined;
@@ -0,0 +1,10 @@
1
+ import { DataSourceRow } from "@vuu-ui/vuu-data-types";
2
+ import { VuuGroupBy } from "@vuu-ui/vuu-protocol-types";
3
+ import { ColumnMap } from "@vuu-ui/vuu-utils";
4
+ export type KeyList = number[];
5
+ export type GroupMap = {
6
+ [key: string]: GroupMap | KeyList;
7
+ };
8
+ export declare const collapseGroup: (key: string, groupedRows: readonly DataSourceRow[]) => DataSourceRow[];
9
+ export declare const expandGroup: (keys: string[], sourceRows: readonly DataSourceRow[], groupBy: VuuGroupBy, columnMap: ColumnMap, groupMap: GroupMap, processedData: readonly DataSourceRow[]) => DataSourceRow[];
10
+ export declare const groupRows: (rows: readonly DataSourceRow[], groupBy: VuuGroupBy, columnMap: ColumnMap) => [DataSourceRow[], GroupMap];
@@ -0,0 +1,4 @@
1
+ import { DataSourceRow } from "@vuu-ui/vuu-data-types";
2
+ import { VuuSort } from "@vuu-ui/vuu-protocol-types";
3
+ import { ColumnMap } from "@vuu-ui/vuu-utils";
4
+ export declare const sortRows: (rows: readonly DataSourceRow[], { sortDefs }: VuuSort, columnMap: ColumnMap) => DataSourceRow[];
@@ -0,0 +1,2 @@
1
+ export * from "./array-data-source/array-data-source";
2
+ export * from "./json-data-source/json-data-source";
@@ -0,0 +1,54 @@
1
+ import { ColumnDescriptor } from "@vuu-ui/vuu-table-types";
2
+ import { LinkDescriptorWithLabel, VuuGroupBy, VuuAggregation, VuuRange, VuuSort, ClientToServerMenuRPC, ClientToServerEditRpc, VuuRowDataItemType } from "@vuu-ui/vuu-protocol-types";
3
+ import { DataSourceFilter, DataSourceRow, DataSource, DataSourceConstructorProps, DataSourceEvents, DataSourceStatus, SubscribeCallback, SubscribeProps, WithFullConfig, Selection, MenuRpcResponse, VuuUIMessageInRPCEditReject, VuuUIMessageInRPCEditResponse } from "@vuu-ui/vuu-data-types";
4
+ import { EventEmitter, JsonData } from "@vuu-ui/vuu-utils";
5
+ export interface JsonDataSourceConstructorProps extends Omit<DataSourceConstructorProps, "bufferSize" | "table"> {
6
+ data: JsonData;
7
+ }
8
+ export declare class JsonDataSource extends EventEmitter<DataSourceEvents> implements DataSource {
9
+ #private;
10
+ columnDescriptors: ColumnDescriptor[];
11
+ private clientCallback;
12
+ private expandedRows;
13
+ private visibleRows;
14
+ rowCount: number | undefined;
15
+ viewport: string;
16
+ private keys;
17
+ constructor({ aggregations, data, filter, groupBy, sort, title, viewport, }: JsonDataSourceConstructorProps);
18
+ subscribe({ viewport, columns, aggregations, range, sort, groupBy, filter, }: SubscribeProps, callback: SubscribeCallback): Promise<void>;
19
+ unsubscribe(): void;
20
+ suspend(): this;
21
+ resume(): this;
22
+ disable(): this;
23
+ enable(): this;
24
+ set data(data: JsonData);
25
+ select(selected: Selection): void;
26
+ openTreeNode(key: string): void;
27
+ closeTreeNode(key: string, cascade?: boolean): void;
28
+ get status(): DataSourceStatus;
29
+ get config(): WithFullConfig;
30
+ applyConfig(): true;
31
+ get selectedRowsCount(): number;
32
+ get size(): number;
33
+ get range(): VuuRange;
34
+ set range(range: VuuRange);
35
+ private sendRowsToClient;
36
+ get columns(): string[];
37
+ set columns(columns: string[]);
38
+ get aggregations(): VuuAggregation[];
39
+ set aggregations(aggregations: VuuAggregation[]);
40
+ get sort(): VuuSort;
41
+ set sort(sort: VuuSort);
42
+ get filter(): DataSourceFilter;
43
+ set filter(filter: DataSourceFilter);
44
+ get groupBy(): VuuGroupBy;
45
+ set groupBy(groupBy: VuuGroupBy);
46
+ get title(): string | undefined;
47
+ set title(title: string | undefined);
48
+ createLink({ parentVpId, link: { fromColumn, toColumn }, }: LinkDescriptorWithLabel): void;
49
+ removeLink(): void;
50
+ menuRpcCall(rpcRequest: Omit<ClientToServerMenuRPC, "vpId"> | ClientToServerEditRpc): Promise<MenuRpcResponse | VuuUIMessageInRPCEditReject | VuuUIMessageInRPCEditResponse | undefined>;
51
+ applyEdit(row: DataSourceRow, columnName: string, value: VuuRowDataItemType): Promise<true>;
52
+ getChildRows(rowKey: string): DataSourceRow[];
53
+ getRowsAtDepth(depth: number, visibleOnly?: boolean): DataSourceRow[];
54
+ }