@gopowerteam/table-render 0.0.20 → 0.0.21

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 (91) hide show
  1. package/dist/cjs/config/provide.config.d.ts +6 -0
  2. package/dist/cjs/defines/define-columns.d.ts +3 -0
  3. package/dist/cjs/defines/define-table-load.d.ts +2 -0
  4. package/dist/cjs/defines/index.d.ts +2 -0
  5. package/dist/cjs/hooks/index.d.ts +2 -0
  6. package/dist/cjs/hooks/use-events.d.ts +38 -0
  7. package/dist/cjs/hooks/use-export.d.ts +7 -0
  8. package/dist/cjs/hooks/use-table.d.ts +13 -0
  9. package/dist/cjs/index.d.ts +6 -0
  10. package/dist/cjs/install.d.ts +3 -0
  11. package/dist/cjs/interfaces/index.d.ts +11 -0
  12. package/dist/cjs/interfaces/pageable-options.d.ts +26 -0
  13. package/dist/cjs/interfaces/sortable-options.d.ts +8 -0
  14. package/dist/cjs/interfaces/table-column-options.d.ts +51 -0
  15. package/dist/cjs/interfaces/table-column-render.d.ts +27 -0
  16. package/dist/cjs/interfaces/table-load-params.d.ts +18 -0
  17. package/dist/cjs/resolver.d.ts +8 -0
  18. package/dist/cjs/table-columns/button/index.d.ts +26 -0
  19. package/dist/cjs/table-columns/currency/index.d.ts +9 -0
  20. package/dist/cjs/table-columns/date/index.d.ts +17 -0
  21. package/dist/cjs/table-columns/dict/index.d.ts +13 -0
  22. package/dist/cjs/table-columns/image/index.d.ts +10 -0
  23. package/dist/cjs/table-columns/index.d.ts +11 -0
  24. package/dist/cjs/table-columns/phone/index.d.ts +7 -0
  25. package/dist/cjs/table-columns/render/index.d.ts +5 -0
  26. package/dist/cjs/table-columns/tag/index.d.ts +8 -0
  27. package/dist/cjs/table-columns/text/index.d.ts +11 -0
  28. package/dist/cjs/table-render/index.d.ts +1845 -0
  29. package/dist/cjs/table-render/table-actions-render.d.ts +2 -0
  30. package/dist/cjs/table-render/table-column-render.d.ts +29 -0
  31. package/dist/cjs/table-render/table-edit-render.d.ts +30 -0
  32. package/dist/cjs/table-render/table-form-render.d.ts +2 -0
  33. package/dist/cjs/table-render/table-pagination-render.d.ts +2 -0
  34. package/dist/cjs/table-render/table-selection-render.d.ts +9 -0
  35. package/dist/cjs/table-render/table-view-render.d.ts +73 -0
  36. package/dist/cjs/utils/create-column-render.d.ts +7 -0
  37. package/dist/cjs/utils/create-table-form.d.ts +3 -0
  38. package/dist/cjs/utils/create-table-source.d.ts +3 -0
  39. package/dist/cjs/utils/get-column-value.d.ts +8 -0
  40. package/dist/cjs/utils/index.d.ts +6 -0
  41. package/dist/cjs/utils/is-promise.d.ts +1 -0
  42. package/dist/cjs/utils/page.service.d.ts +37 -0
  43. package/dist/cjs/utils/set-column-value.d.ts +8 -0
  44. package/dist/cjs/utils/sort.service.d.ts +26 -0
  45. package/dist/cjs/utils/to-px.d.ts +1 -0
  46. package/dist/es/config/provide.config.d.ts +6 -0
  47. package/dist/es/defines/define-columns.d.ts +3 -0
  48. package/dist/es/defines/define-table-load.d.ts +2 -0
  49. package/dist/es/defines/index.d.ts +2 -0
  50. package/dist/es/hooks/index.d.ts +2 -0
  51. package/dist/es/hooks/use-events.d.ts +38 -0
  52. package/dist/es/hooks/use-export.d.ts +7 -0
  53. package/dist/es/hooks/use-table.d.ts +13 -0
  54. package/dist/es/index.d.ts +6 -0
  55. package/dist/es/install.d.ts +3 -0
  56. package/dist/es/interfaces/index.d.ts +11 -0
  57. package/dist/es/interfaces/pageable-options.d.ts +26 -0
  58. package/dist/es/interfaces/sortable-options.d.ts +8 -0
  59. package/dist/es/interfaces/table-column-options.d.ts +51 -0
  60. package/dist/es/interfaces/table-column-render.d.ts +27 -0
  61. package/dist/es/interfaces/table-load-params.d.ts +18 -0
  62. package/dist/es/resolver.d.ts +8 -0
  63. package/dist/es/table-columns/button/index.d.ts +26 -0
  64. package/dist/es/table-columns/currency/index.d.ts +9 -0
  65. package/dist/es/table-columns/date/index.d.ts +17 -0
  66. package/dist/es/table-columns/dict/index.d.ts +13 -0
  67. package/dist/es/table-columns/image/index.d.ts +10 -0
  68. package/dist/es/table-columns/index.d.ts +11 -0
  69. package/dist/es/table-columns/phone/index.d.ts +7 -0
  70. package/dist/es/table-columns/render/index.d.ts +5 -0
  71. package/dist/es/table-columns/tag/index.d.ts +8 -0
  72. package/dist/es/table-columns/text/index.d.ts +11 -0
  73. package/dist/es/table-render/index.d.ts +1845 -0
  74. package/dist/es/table-render/table-actions-render.d.ts +2 -0
  75. package/dist/es/table-render/table-column-render.d.ts +29 -0
  76. package/dist/es/table-render/table-edit-render.d.ts +30 -0
  77. package/dist/es/table-render/table-form-render.d.ts +2 -0
  78. package/dist/es/table-render/table-pagination-render.d.ts +2 -0
  79. package/dist/es/table-render/table-selection-render.d.ts +9 -0
  80. package/dist/es/table-render/table-view-render.d.ts +73 -0
  81. package/dist/es/utils/create-column-render.d.ts +7 -0
  82. package/dist/es/utils/create-table-form.d.ts +3 -0
  83. package/dist/es/utils/create-table-source.d.ts +3 -0
  84. package/dist/es/utils/get-column-value.d.ts +8 -0
  85. package/dist/es/utils/index.d.ts +6 -0
  86. package/dist/es/utils/is-promise.d.ts +1 -0
  87. package/dist/es/utils/page.service.d.ts +37 -0
  88. package/dist/es/utils/set-column-value.d.ts +8 -0
  89. package/dist/es/utils/sort.service.d.ts +26 -0
  90. package/dist/es/utils/to-px.d.ts +1 -0
  91. package/package.json +1 -1
@@ -0,0 +1,6 @@
1
+ import type { InjectionKey } from 'vue';
2
+ import type { DataRecord } from '../interfaces';
3
+ export declare const provides: {
4
+ id: InjectionKey<string>;
5
+ source: InjectionKey<DataRecord[]>;
6
+ };
@@ -0,0 +1,3 @@
1
+ import type { DataRecord, TableColumnsOptions, TableColumnsStringKeyOptions, TableColumnsTypeKeyOptions } from '../interfaces';
2
+ export declare function defineColumns<T = DataRecord>(columns: TableColumnsTypeKeyOptions<T>): TableColumnsOptions<T>;
3
+ export declare function defineColumns<T = DataRecord>(columns: TableColumnsStringKeyOptions<T>): TableColumnsOptions<T>;
@@ -0,0 +1,2 @@
1
+ import type { TableLoadParams } from '../interfaces';
2
+ export declare function defineTableLoad(load: (params: TableLoadParams) => void): (params: TableLoadParams) => void;
@@ -0,0 +1,2 @@
1
+ export * from './define-columns';
2
+ export * from './define-table-load';
@@ -0,0 +1,2 @@
1
+ export * from './use-table';
2
+ export * from './use-events';
@@ -0,0 +1,38 @@
1
+ import type { FormItemsOptions } from '@gopowerteam/form-render';
2
+ import type { DataRecord, TableColumnsOptions } from '..';
3
+ export type TableEvent = 'export' | 'reload' | 'preview' | 'edit';
4
+ export interface TableReloadEventOptions {
5
+ reset?: boolean;
6
+ }
7
+ export interface TablePreviewEventOptions {
8
+ key?: string | number;
9
+ record?: DataRecord;
10
+ mode?: 'dialog' | 'drawer';
11
+ title?: string;
12
+ }
13
+ export interface TableEditEventOptions<T = DataRecord> {
14
+ key?: string | number;
15
+ record?: T;
16
+ mode?: 'dialog' | 'drawer';
17
+ title?: string;
18
+ form: FormItemsOptions<T>;
19
+ onSubmit?: (record: DataRecord) => void;
20
+ }
21
+ export interface TableExportEventOptions {
22
+ columns?: TableColumnsOptions;
23
+ source?: DataRecord[];
24
+ filename?: string;
25
+ }
26
+ export interface EventEmits {
27
+ (event: 'reload', options?: TableReloadEventOptions): void;
28
+ (event: 'preview', options?: TablePreviewEventOptions): void;
29
+ (event: 'export', options?: TableExportEventOptions): void;
30
+ (event: 'edit', options: TableEditEventOptions): void;
31
+ (event: TableEvent, options?: TableExportEventOptions | TableReloadEventOptions | TablePreviewEventOptions | TableEditEventOptions): void;
32
+ }
33
+ export declare function useEvents(events: {
34
+ reload: (options?: TableReloadEventOptions) => void;
35
+ export: (options?: TableExportEventOptions) => void;
36
+ preview: (options?: TablePreviewEventOptions) => void;
37
+ edit: (options: TableEditEventOptions) => void;
38
+ }): EventEmits;
@@ -0,0 +1,7 @@
1
+ import type { DataRecord, TableColumnsOptions } from '../interfaces';
2
+ export declare function getTableRowValue(columns: TableColumnsOptions<any>, record: DataRecord): Record<string, any>;
3
+ declare function exportExcel(columns: TableColumnsOptions, source: DataRecord[], filename?: string): void;
4
+ export declare function useExport(): {
5
+ exportExcel: typeof exportExcel;
6
+ };
7
+ export {};
@@ -0,0 +1,13 @@
1
+ import { type ComponentPublicInstance, type Ref } from 'vue';
2
+ import type { TableRender } from '../table-render';
3
+ type TableRenderInstance = InstanceType<typeof TableRender>;
4
+ type TableRenderExpose = {
5
+ -readonly [K in keyof Omit<TableRenderInstance, keyof ComponentPublicInstance>]: TableRenderInstance[K];
6
+ };
7
+ /**
8
+ * 获取TableRender实例
9
+ * @param key
10
+ * @returns
11
+ */
12
+ export declare function useTable(key: string): Readonly<Ref<TableRenderExpose>>;
13
+ export {};
@@ -0,0 +1,6 @@
1
+ export * from './table-render';
2
+ export * from './interfaces';
3
+ export * from './hooks';
4
+ export * from './defines';
5
+ export * from './resolver';
6
+ export { default } from './install';
@@ -0,0 +1,3 @@
1
+ import type { Plugin } from 'vue';
2
+ declare const _default: Plugin;
3
+ export default _default;
@@ -0,0 +1,11 @@
1
+ export * from './table-column-render';
2
+ export * from './table-column-options';
3
+ export * from './table-load-params';
4
+ export * from './sortable-options';
5
+ export * from './pageable-options';
6
+ export interface DataRecord {
7
+ [key: string]: any;
8
+ }
9
+ export interface DataProp {
10
+ [key: string]: any;
11
+ }
@@ -0,0 +1,26 @@
1
+ export interface PageableOptions {
2
+ /**
3
+ * 当前页码
4
+ */
5
+ pageIndex: number;
6
+ /**
7
+ * 分页容量
8
+ */
9
+ pageSize: number;
10
+ /**
11
+ * 分页容量选项
12
+ */
13
+ pageSizeOpts: number[];
14
+ /**
15
+ * 分页布局
16
+ */
17
+ pageLayouts: Array<'PrevJump' | 'PrevPage' | 'JumpNumber' | 'NextPage' | 'NextJump' | 'Sizes' | 'FullJump' | 'Total'>;
18
+ /**
19
+ * 数据总数
20
+ */
21
+ total: number;
22
+ /**
23
+ * 重置分页数据
24
+ */
25
+ reset(): void;
26
+ }
@@ -0,0 +1,8 @@
1
+ export interface SortableOptions {
2
+ /**
3
+ * 重置分页数据
4
+ */
5
+ reset(): void;
6
+ update(key: string, diretion: 'asc' | 'desc'): void;
7
+ remove(key: string): void;
8
+ }
@@ -0,0 +1,51 @@
1
+ import type { FormItemOptions } from '@gopowerteam/form-render';
2
+ import type { TableColumnData } from '@arco-design/web-vue';
3
+ import type { TableColumnRender } from './table-column-render';
4
+ import type { DataRecord } from '.';
5
+ export interface TableColumnPreviewOptions {
6
+ span?: number;
7
+ }
8
+ export interface TableColumnSharedOptions {
9
+ align?: 'left' | 'right' | 'center';
10
+ width?: number;
11
+ ellipsis?: boolean;
12
+ }
13
+ export interface TableFormSharedOptions {
14
+ minWidth?: number;
15
+ }
16
+ /**
17
+ * 列配置
18
+ */
19
+ export interface TableColumnOptions<T> {
20
+ key: string | keyof T;
21
+ title: string;
22
+ index?: string;
23
+ fixed?: 'left' | 'right';
24
+ align?: 'left' | 'right' | 'center';
25
+ width?: number | 'auto';
26
+ render?: TableColumnRender<T>;
27
+ form?: boolean | Omit<FormItemOptions, 'key' | 'title'>;
28
+ formatter?: DataFormatter<T>;
29
+ ellipsis?: boolean;
30
+ preview?: TableColumnPreviewOptions;
31
+ exportable?: ExportColumnOptions | boolean;
32
+ sortable?: 'asc' | 'desc';
33
+ treeNode?: boolean;
34
+ visiable?: boolean | (() => boolean);
35
+ extraProps?: Partial<Omit<TableColumnData, 'dataIndex' | 'title' | 'fixed' | 'align' | 'width'>>;
36
+ }
37
+ export interface TableColumnTypeKeyOptions<T> extends TableColumnOptions<T> {
38
+ key: keyof T;
39
+ }
40
+ export interface TableColumnStringKeyOptions<T> extends TableColumnOptions<T> {
41
+ key: string;
42
+ }
43
+ export interface ExportColumnOptions {
44
+ header?: string;
45
+ width?: number;
46
+ content?: (record: DataRecord) => string | number | undefined;
47
+ }
48
+ export type TableColumnsOptions<T = DataRecord> = TableColumnOptions<T>[];
49
+ export type TableColumnsTypeKeyOptions<T = DataRecord> = TableColumnTypeKeyOptions<T>[];
50
+ export type TableColumnsStringKeyOptions<T = DataRecord> = TableColumnStringKeyOptions<T>[];
51
+ export type DataFormatter<T> = (record: T) => string | number | Date | undefined;
@@ -0,0 +1,27 @@
1
+ import type { EventEmits } from '../hooks';
2
+ import type { TableColumnRenders } from '../table-columns';
3
+ import type { TableColumnOptions } from './table-column-options';
4
+ interface TableColumnRenderResultType {
5
+ $type?: string;
6
+ $disableColumnMode?: boolean;
7
+ $disableViewMode?: boolean;
8
+ }
9
+ export interface TableColumnRenderResult<T> extends TableColumnRenderResultType {
10
+ (record: T, columnOptions: TableColumnOptions<T>, ctx?: {
11
+ previewing?: boolean;
12
+ emits?: EventEmits;
13
+ }): JSX.Element;
14
+ }
15
+ /**
16
+ * Render函数
17
+ */
18
+ export interface TableColumnRender<T> {
19
+ (render: TableColumnRenderFun<T>): TableColumnRenderResult<T>;
20
+ }
21
+ /**
22
+ * Render函数模板
23
+ */
24
+ type TableColumnRenderFun<T> = ReturnType<typeof TableColumnRenders<T>> & {
25
+ [key: string]: any;
26
+ };
27
+ export {};
@@ -0,0 +1,18 @@
1
+ import type { RequestPlugin } from '@gopowerteam/request';
2
+ import type { SortableOptions } from './sortable-options';
3
+ import type { PageableOptions } from './pageable-options';
4
+ export interface DataRecord {
5
+ [key: string]: any;
6
+ }
7
+ export interface DataProp {
8
+ [key: string]: any;
9
+ }
10
+ /**
11
+ * 数据加载参数
12
+ */
13
+ export interface TableLoadParams {
14
+ form: DataRecord;
15
+ page?: (RequestPlugin & PageableOptions);
16
+ sort?: (RequestPlugin & SortableOptions);
17
+ update: (data: DataRecord[]) => void;
18
+ }
@@ -0,0 +1,8 @@
1
+ export declare function TableRenderResolver(): {
2
+ type: "component";
3
+ resolve: (name: string) => {
4
+ name: string;
5
+ from: string;
6
+ sideEffects: string[];
7
+ } | undefined;
8
+ };
@@ -0,0 +1,26 @@
1
+ export type RenderButtonColumnOptions<T> = RenderSingleButtonColumnOptions<T> | RenderSingleButtonColumnOptions<T>[] | RenderMultipleButtonColumnOptions<T>;
2
+ export interface RenderSingleButtonColumnOptions<T> {
3
+ content?: string | ((record: T) => string | number | undefined);
4
+ onClick?: (record: T) => Promise<void> | void;
5
+ autoReload?: boolean;
6
+ type?: 'primary' | 'secondary' | 'outline' | 'dashed' | 'text';
7
+ shape?: 'square' | 'round' | 'circle';
8
+ visiable?: boolean | ((record: T) => boolean);
9
+ disabled?: boolean | ((record: T) => boolean);
10
+ confirm?: boolean;
11
+ icon?: () => JSX.Element;
12
+ confirmText?: string;
13
+ confirmAppend?: string | HTMLElement;
14
+ confirmOffset?: {
15
+ left: number;
16
+ top: number;
17
+ };
18
+ confirmPosition?: {
19
+ left: number;
20
+ top: number;
21
+ };
22
+ }
23
+ export interface RenderMultipleButtonColumnOptions<T> {
24
+ buttons?: RenderSingleButtonColumnOptions<T>[];
25
+ }
26
+ export declare function renderButtonColumn<T>(options: RenderButtonColumnOptions<T>): import("../..").TableColumnRenderResult<T>;
@@ -0,0 +1,9 @@
1
+ import type { DataRecord } from '../../interfaces';
2
+ export interface CurrencyColumnOptions {
3
+ prefix?: string;
4
+ suffix?: string;
5
+ precision?: number;
6
+ scale?: number;
7
+ thousands?: boolean;
8
+ }
9
+ export declare function renderCurrencyColumn<T = DataRecord>(options?: CurrencyColumnOptions): import("../../interfaces").TableColumnRenderResult<T>;
@@ -0,0 +1,17 @@
1
+ import type { DataRecord } from '../../interfaces';
2
+ export interface DateColumnOptions {
3
+ format?: keyof typeof dateFormats | (() => string);
4
+ }
5
+ declare const dateFormats: {
6
+ date: string;
7
+ datetime: string;
8
+ time: string;
9
+ week: string;
10
+ };
11
+ /**
12
+ * 渲染Date Column
13
+ * @param options DateColumn列选项
14
+ * @returns JSX
15
+ */
16
+ export declare function renderDateColumn<T = DataRecord>(options?: DateColumnOptions): import("../../interfaces").TableColumnRenderResult<T>;
17
+ export {};
@@ -0,0 +1,13 @@
1
+ import type { DataRecord } from '../../interfaces';
2
+ type Dict = Map<string | number | boolean, string | number | boolean>;
3
+ declare const TagType: {
4
+ success: string;
5
+ warning: string;
6
+ error: string;
7
+ };
8
+ export type DictColumnOptions = Dict | {
9
+ dict: Dict;
10
+ tag: boolean | keyof typeof TagType;
11
+ };
12
+ export declare function renderDictColumn<T = DataRecord>(options: DictColumnOptions): import("../../interfaces").TableColumnRenderResult<T>;
13
+ export {};
@@ -0,0 +1,10 @@
1
+ import type { DataRecord } from '../../interfaces';
2
+ export interface ImageColumnOptions {
3
+ width?: string;
4
+ height?: string;
5
+ radius?: string;
6
+ preview?: boolean;
7
+ rotate?: number;
8
+ parse?: (key: string) => Promise<string>;
9
+ }
10
+ export declare function renderImageColumn<T = DataRecord>(options?: ImageColumnOptions): import("../..").TableColumnRenderResult<T>;
@@ -0,0 +1,11 @@
1
+ export declare function TableColumnRenders<T>(): {
2
+ text: (options?: import("./text").TextColumnOptions<T> | undefined) => import("..").TableColumnRenderResult<T>;
3
+ dict: (options: import("./dict").DictColumnOptions) => import("..").TableColumnRenderResult<T>;
4
+ tag: (options?: import("./tag").TagColumnOptions | undefined) => import("..").TableColumnRenderResult<T>;
5
+ render: (renderer: import("./render").RenderColumnOptions<T>) => import("..").TableColumnRenderResult<T>;
6
+ phone: (options?: import("./phone").PhoneColumnOptions | undefined) => import("..").TableColumnRenderResult<T>;
7
+ image: (options?: import("./image").ImageColumnOptions | undefined) => import("..").TableColumnRenderResult<T>;
8
+ currency: (options?: import("./currency").CurrencyColumnOptions | undefined) => import("..").TableColumnRenderResult<T>;
9
+ date: (options?: import("./currency").CurrencyColumnOptions | undefined) => import("..").TableColumnRenderResult<T>;
10
+ button: (options: import("./button").RenderButtonColumnOptions<T>) => import("..").TableColumnRenderResult<T>;
11
+ };
@@ -0,0 +1,7 @@
1
+ import type { DataRecord } from '../../interfaces';
2
+ export interface PhoneColumnOptions {
3
+ safe?: boolean;
4
+ separator?: string;
5
+ callable?: boolean;
6
+ }
7
+ export declare function renderPhoneColumn<T = DataRecord>(options?: PhoneColumnOptions): import("../../interfaces").TableColumnRenderResult<T>;
@@ -0,0 +1,5 @@
1
+ import type { DataRecord } from '../../interfaces';
2
+ export interface RenderColumnOptions<T> {
3
+ (record: T): JSX.Element;
4
+ }
5
+ export declare function renderRenderColumn<T = DataRecord>(renderer: RenderColumnOptions<T>): import("../../interfaces").TableColumnRenderResult<T>;
@@ -0,0 +1,8 @@
1
+ import type { DataRecord } from '../../interfaces';
2
+ export interface TagColumnOptions {
3
+ textColors?: string[] | ((tag: any, index: number) => string);
4
+ backgroundColors?: string[] | ((tag: any, index: number) => string);
5
+ border?: string;
6
+ radius?: number;
7
+ }
8
+ export declare function renderTagColumn<T = DataRecord>(options?: TagColumnOptions): import("../../interfaces").TableColumnRenderResult<T>;
@@ -0,0 +1,11 @@
1
+ import type { DataRecord } from '../../interfaces';
2
+ export type TextColumnOptions<T> = TextColumnObjectOptions<T> | TextColumnFunctionOptions<T>;
3
+ export interface TextColumnObjectOptions<T> {
4
+ color?: string | ((record: T) => string);
5
+ content?: string | ((record: T) => string | number | undefined);
6
+ size?: string | number | ((record: T) => string | number);
7
+ }
8
+ export interface TextColumnFunctionOptions<T> {
9
+ (record: T): string | number | undefined;
10
+ }
11
+ export declare function renderTextColumn<T = DataRecord>(options?: TextColumnOptions<T>): import("../../interfaces").TableColumnRenderResult<T>;