@visactor/vue-vtable 1.7.5-alpha.1
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/README.md +93 -0
- package/cjs/components/component/menu.d.ts +9 -0
- package/cjs/components/component/menu.js +9 -0
- package/cjs/components/component/menu.js.map +1 -0
- package/cjs/components/component/tooltip.d.ts +7 -0
- package/cjs/components/component/tooltip.js +10 -0
- package/cjs/components/component/tooltip.js.map +1 -0
- package/cjs/components/custom/checkBox.d.ts +16 -0
- package/cjs/components/custom/checkBox.js +10 -0
- package/cjs/components/custom/checkBox.js.map +1 -0
- package/cjs/components/custom/custom-layout.d.ts +16 -0
- package/cjs/components/custom/custom-layout.js +10 -0
- package/cjs/components/custom/custom-layout.js.map +1 -0
- package/cjs/components/custom/group.d.ts +2 -0
- package/cjs/components/custom/group.js +10 -0
- package/cjs/components/custom/group.js.map +1 -0
- package/cjs/components/custom/image.d.ts +2 -0
- package/cjs/components/custom/image.js +10 -0
- package/cjs/components/custom/image.js.map +1 -0
- package/cjs/components/custom/radio.d.ts +13 -0
- package/cjs/components/custom/radio.js +10 -0
- package/cjs/components/custom/radio.js.map +1 -0
- package/cjs/components/custom/tag.d.ts +12 -0
- package/cjs/components/custom/tag.js +10 -0
- package/cjs/components/custom/tag.js.map +1 -0
- package/cjs/components/custom/text.d.ts +2 -0
- package/cjs/components/custom/text.js +10 -0
- package/cjs/components/custom/text.js.map +1 -0
- package/cjs/components/index.d.ts +15 -0
- package/cjs/components/index.js +147 -0
- package/cjs/components/index.js.map +1 -0
- package/cjs/components/list/list-column.d.ts +3 -0
- package/cjs/components/list/list-column.js +10 -0
- package/cjs/components/list/list-column.js.map +1 -0
- package/cjs/components/pivot/pivot-column-dimension.d.ts +8 -0
- package/cjs/components/pivot/pivot-column-dimension.js +10 -0
- package/cjs/components/pivot/pivot-column-dimension.js.map +1 -0
- package/cjs/components/pivot/pivot-column-header-title.d.ts +3 -0
- package/cjs/components/pivot/pivot-column-header-title.js +10 -0
- package/cjs/components/pivot/pivot-column-header-title.js.map +1 -0
- package/cjs/components/pivot/pivot-corner.d.ts +3 -0
- package/cjs/components/pivot/pivot-corner.js +10 -0
- package/cjs/components/pivot/pivot-corner.js.map +1 -0
- package/cjs/components/pivot/pivot-indicator.d.ts +3 -0
- package/cjs/components/pivot/pivot-indicator.js +10 -0
- package/cjs/components/pivot/pivot-indicator.js.map +1 -0
- package/cjs/components/pivot/pivot-row-dimension.d.ts +8 -0
- package/cjs/components/pivot/pivot-row-dimension.js +10 -0
- package/cjs/components/pivot/pivot-row-dimension.js.map +1 -0
- package/cjs/components/pivot/pivot-row-header-title.d.ts +3 -0
- package/cjs/components/pivot/pivot-row-header-title.js +10 -0
- package/cjs/components/pivot/pivot-row-header-title.js.map +1 -0
- package/cjs/constants.d.ts +1 -0
- package/cjs/constants.js +5 -0
- package/cjs/constants.js.map +1 -0
- package/cjs/eventsUtils.d.ts +101 -0
- package/cjs/eventsUtils.js +58 -0
- package/cjs/eventsUtils.js.map +1 -0
- package/cjs/index.d.ts +5 -0
- package/cjs/index.js +38 -0
- package/cjs/index.js.map +1 -0
- package/cjs/tables/chartModule.d.ts +1 -0
- package/cjs/tables/chartModule.js +37 -0
- package/cjs/tables/chartModule.js.map +1 -0
- package/cjs/tables/index.d.ts +4 -0
- package/cjs/tables/index.js +48 -0
- package/cjs/tables/index.js.map +1 -0
- package/cjs/tables/utils.d.ts +2 -0
- package/cjs/tables/utils.js +80 -0
- package/cjs/tables/utils.js.map +1 -0
- package/dist/vue-vtable.js +4040 -0
- package/dist/vue-vtable.min.js +18 -0
- package/es/components/component/menu.d.ts +9 -0
- package/es/components/component/menu.js +3 -0
- package/es/components/component/menu.js.map +1 -0
- package/es/components/component/tooltip.d.ts +7 -0
- package/es/components/component/tooltip.js +4 -0
- package/es/components/component/tooltip.js.map +1 -0
- package/es/components/custom/checkBox.d.ts +16 -0
- package/es/components/custom/checkBox.js +4 -0
- package/es/components/custom/checkBox.js.map +1 -0
- package/es/components/custom/custom-layout.d.ts +16 -0
- package/es/components/custom/custom-layout.js +4 -0
- package/es/components/custom/custom-layout.js.map +1 -0
- package/es/components/custom/group.d.ts +2 -0
- package/es/components/custom/group.js +4 -0
- package/es/components/custom/group.js.map +1 -0
- package/es/components/custom/image.d.ts +2 -0
- package/es/components/custom/image.js +4 -0
- package/es/components/custom/image.js.map +1 -0
- package/es/components/custom/radio.d.ts +13 -0
- package/es/components/custom/radio.js +4 -0
- package/es/components/custom/radio.js.map +1 -0
- package/es/components/custom/tag.d.ts +12 -0
- package/es/components/custom/tag.js +4 -0
- package/es/components/custom/tag.js.map +1 -0
- package/es/components/custom/text.d.ts +2 -0
- package/es/components/custom/text.js +4 -0
- package/es/components/custom/text.js.map +1 -0
- package/es/components/index.d.ts +15 -0
- package/es/components/index.js +30 -0
- package/es/components/index.js.map +1 -0
- package/es/components/list/list-column.d.ts +3 -0
- package/es/components/list/list-column.js +4 -0
- package/es/components/list/list-column.js.map +1 -0
- package/es/components/pivot/pivot-column-dimension.d.ts +8 -0
- package/es/components/pivot/pivot-column-dimension.js +4 -0
- package/es/components/pivot/pivot-column-dimension.js.map +1 -0
- package/es/components/pivot/pivot-column-header-title.d.ts +3 -0
- package/es/components/pivot/pivot-column-header-title.js +4 -0
- package/es/components/pivot/pivot-column-header-title.js.map +1 -0
- package/es/components/pivot/pivot-corner.d.ts +3 -0
- package/es/components/pivot/pivot-corner.js +4 -0
- package/es/components/pivot/pivot-corner.js.map +1 -0
- package/es/components/pivot/pivot-indicator.d.ts +3 -0
- package/es/components/pivot/pivot-indicator.js +4 -0
- package/es/components/pivot/pivot-indicator.js.map +1 -0
- package/es/components/pivot/pivot-row-dimension.d.ts +8 -0
- package/es/components/pivot/pivot-row-dimension.js +4 -0
- package/es/components/pivot/pivot-row-dimension.js.map +1 -0
- package/es/components/pivot/pivot-row-header-title.d.ts +3 -0
- package/es/components/pivot/pivot-row-header-title.js +4 -0
- package/es/components/pivot/pivot-row-header-title.js.map +1 -0
- package/es/constants.d.ts +1 -0
- package/es/constants.js +1 -0
- package/es/constants.js.map +1 -0
- package/es/eventsUtils.d.ts +101 -0
- package/es/eventsUtils.js +56 -0
- package/es/eventsUtils.js.map +1 -0
- package/es/index.d.ts +5 -0
- package/es/index.js +10 -0
- package/es/index.js.map +1 -0
- package/es/tables/chartModule.d.ts +1 -0
- package/es/tables/chartModule.js +6 -0
- package/es/tables/chartModule.js.map +1 -0
- package/es/tables/index.d.ts +4 -0
- package/es/tables/index.js +8 -0
- package/es/tables/index.js.map +1 -0
- package/es/tables/utils.d.ts +2 -0
- package/es/tables/utils.js +49 -0
- package/es/tables/utils.js.map +1 -0
- package/package.json +100 -0
|
@@ -0,0 +1,101 @@
|
|
|
1
|
+
import type { TYPES } from '@visactor/vtable';
|
|
2
|
+
export type EventCallback<Params> = (params: Params) => void;
|
|
3
|
+
export interface EventsProps {
|
|
4
|
+
onClickCell?: EventCallback<TYPES.TableEventHandlersEventArgumentMap['click_cell']>;
|
|
5
|
+
onDblClickCell?: EventCallback<TYPES.TableEventHandlersEventArgumentMap['dblclick_cell']>;
|
|
6
|
+
onMouseDownCell?: EventCallback<TYPES.TableEventHandlersEventArgumentMap['mousedown_cell']>;
|
|
7
|
+
onMouseUpCell?: EventCallback<TYPES.TableEventHandlersEventArgumentMap['mouseup_cell']>;
|
|
8
|
+
onSelectedCell?: EventCallback<TYPES.TableEventHandlersEventArgumentMap['selected_cell']>;
|
|
9
|
+
onKeyDown?: EventCallback<TYPES.TableEventHandlersEventArgumentMap['keydown']>;
|
|
10
|
+
onMouseEnterTable?: EventCallback<TYPES.TableEventHandlersEventArgumentMap['mouseenter_table']>;
|
|
11
|
+
onMouseLeaveTable?: EventCallback<TYPES.TableEventHandlersEventArgumentMap['mouseleave_table']>;
|
|
12
|
+
onMouseDownTable?: EventCallback<TYPES.TableEventHandlersEventArgumentMap['mousedown_table']>;
|
|
13
|
+
onMouseMoveCell?: EventCallback<TYPES.TableEventHandlersEventArgumentMap['mousemove_cell']>;
|
|
14
|
+
onMouseEnterCell?: EventCallback<TYPES.TableEventHandlersEventArgumentMap['mouseenter_cell']>;
|
|
15
|
+
onMouseLeaveCell?: EventCallback<TYPES.TableEventHandlersEventArgumentMap['mouseleave_cell']>;
|
|
16
|
+
onContextMenuCell?: EventCallback<TYPES.TableEventHandlersEventArgumentMap['contextmenu_cell']>;
|
|
17
|
+
onResizeColumn?: EventCallback<TYPES.TableEventHandlersEventArgumentMap['resize_column']>;
|
|
18
|
+
onResizeColumnEnd?: EventCallback<TYPES.TableEventHandlersEventArgumentMap['resize_column_end']>;
|
|
19
|
+
onChangeHeaderPosition?: EventCallback<TYPES.TableEventHandlersEventArgumentMap['change_header_position']>;
|
|
20
|
+
onSortClick?: EventCallback<TYPES.TableEventHandlersEventArgumentMap['sort_click']>;
|
|
21
|
+
onFreezeClick?: EventCallback<TYPES.TableEventHandlersEventArgumentMap['freeze_click']>;
|
|
22
|
+
onScroll?: EventCallback<TYPES.TableEventHandlersEventArgumentMap['scroll']>;
|
|
23
|
+
onDropdownMenuClick?: EventCallback<TYPES.TableEventHandlersEventArgumentMap['dropdown_menu_click']>;
|
|
24
|
+
onMouseOverChartSymbol?: EventCallback<TYPES.TableEventHandlersEventArgumentMap['mouseover_chart_symbol']>;
|
|
25
|
+
onDragSelectEnd?: EventCallback<TYPES.TableEventHandlersEventArgumentMap['drag_select_end']>;
|
|
26
|
+
onDropdownIconClick?: EventCallback<TYPES.TableEventHandlersEventArgumentMap['dropdown_icon_click']>;
|
|
27
|
+
onDropdownMenuClear?: EventCallback<TYPES.TableEventHandlersEventArgumentMap['dropdown_menu_clear']>;
|
|
28
|
+
onTreeHierarchyStateChange?: EventCallback<TYPES.TableEventHandlersEventArgumentMap['tree_hierarchy_state_change']>;
|
|
29
|
+
onShowMenu?: EventCallback<TYPES.TableEventHandlersEventArgumentMap['show_menu']>;
|
|
30
|
+
onHideMenu?: EventCallback<TYPES.TableEventHandlersEventArgumentMap['hide_menu']>;
|
|
31
|
+
onIconClick?: EventCallback<TYPES.TableEventHandlersEventArgumentMap['icon_click']>;
|
|
32
|
+
onLegendItemClick?: EventCallback<TYPES.TableEventHandlersEventArgumentMap['legend_item_click']>;
|
|
33
|
+
onLegendItemHover?: EventCallback<TYPES.TableEventHandlersEventArgumentMap['legend_item_hover']>;
|
|
34
|
+
onLegendItemUnHover?: EventCallback<TYPES.TableEventHandlersEventArgumentMap['legend_item_unHover']>;
|
|
35
|
+
onLegendChange?: EventCallback<TYPES.TableEventHandlersEventArgumentMap['legend_change']>;
|
|
36
|
+
onMouseEnterAxis?: EventCallback<TYPES.TableEventHandlersEventArgumentMap['mouseenter_axis']>;
|
|
37
|
+
onMouseLeaveAxis?: EventCallback<TYPES.TableEventHandlersEventArgumentMap['mouseleave_axis']>;
|
|
38
|
+
onCheckboxStateChange?: EventCallback<TYPES.TableEventHandlersEventArgumentMap['checkbox_state_change']>;
|
|
39
|
+
onRadioStateChange?: EventCallback<TYPES.TableEventHandlersEventArgumentMap['radio_state_change']>;
|
|
40
|
+
onAfterRender?: EventCallback<TYPES.TableEventHandlersEventArgumentMap['after_render']>;
|
|
41
|
+
onInitialized?: EventCallback<TYPES.TableEventHandlersEventArgumentMap['initialized']>;
|
|
42
|
+
onPivotSortClick?: EventCallback<TYPES.TableEventHandlersEventArgumentMap['pivot_sort_click']>;
|
|
43
|
+
onDrillMenuClick?: EventCallback<TYPES.TableEventHandlersEventArgumentMap['drillmenu_click']>;
|
|
44
|
+
onVChartEventType?: EventCallback<TYPES.TableEventHandlersEventArgumentMap['vchart_event_type']>;
|
|
45
|
+
onChangCellValue?: EventCallback<TYPES.TableEventHandlersEventArgumentMap['change_cell_value']>;
|
|
46
|
+
onMousedownFillHandle?: EventCallback<TYPES.TableEventHandlersEventArgumentMap['mousedown_fill_handle']>;
|
|
47
|
+
onDragFillHandleEnd?: EventCallback<TYPES.TableEventHandlersEventArgumentMap['drag_fill_handle_end']>;
|
|
48
|
+
onDblclickFillHandle?: EventCallback<TYPES.TableEventHandlersEventArgumentMap['dblclick_fill_handle']>;
|
|
49
|
+
onScrollVerticalEnd?: EventCallback<TYPES.TableEventHandlersEventArgumentMap['scroll_vertical_end']>;
|
|
50
|
+
onScrollHorizontalEnd?: EventCallback<TYPES.TableEventHandlersEventArgumentMap['scroll_horizontal_end']>;
|
|
51
|
+
}
|
|
52
|
+
export declare const TABLE_EVENTS: {
|
|
53
|
+
onClickCell: "click_cell";
|
|
54
|
+
onDblClickCell: "dblclick_cell";
|
|
55
|
+
onMouseDownCell: "mousedown_cell";
|
|
56
|
+
onMouseUpCell: "mouseup_cell";
|
|
57
|
+
onSelectedCell: "selected_cell";
|
|
58
|
+
onKeyDown: "keydown";
|
|
59
|
+
onMouseEnterTable: "mouseenter_table";
|
|
60
|
+
onMouseLeaveTable: "mouseleave_table";
|
|
61
|
+
onMouseDownTable: "mousedown_table";
|
|
62
|
+
onMouseMoveCell: "mousemove_cell";
|
|
63
|
+
onMouseEnterCell: "mouseenter_cell";
|
|
64
|
+
onMouseLeaveCell: "mouseleave_cell";
|
|
65
|
+
onContextMenuCell: "contextmenu_cell";
|
|
66
|
+
onResizeColumn: "resize_column";
|
|
67
|
+
onResizeColumnEnd: "resize_column_end";
|
|
68
|
+
onChangeHeaderPosition: "change_header_position";
|
|
69
|
+
onSortClick: "sort_click";
|
|
70
|
+
onFreezeClick: "freeze_click";
|
|
71
|
+
onScroll: "scroll";
|
|
72
|
+
onDropdownMenuClick: "dropdown_menu_click";
|
|
73
|
+
onMouseOverChartSymbol: "mouseover_chart_symbol";
|
|
74
|
+
onDragSelectEnd: "drag_select_end";
|
|
75
|
+
onDropdownIconClick: "dropdown_icon_click";
|
|
76
|
+
onDropdownMenuClear: "dropdown_menu_clear";
|
|
77
|
+
onTreeHierarchyStateChange: "tree_hierarchy_state_change";
|
|
78
|
+
onShowMenu: "show_menu";
|
|
79
|
+
onHideMenu: "hide_menu";
|
|
80
|
+
onIconClick: "icon_click";
|
|
81
|
+
onLegendItemClick: "legend_item_click";
|
|
82
|
+
onLegendItemHover: "legend_item_hover";
|
|
83
|
+
onLegendItemUnHover: "legend_item_unHover";
|
|
84
|
+
onLegendChange: "legend_change";
|
|
85
|
+
onMouseEnterAxis: "mouseenter_axis";
|
|
86
|
+
onMouseLeaveAxis: "mouseleave_axis";
|
|
87
|
+
onCheckboxStateChange: "checkbox_state_change";
|
|
88
|
+
onRadioStateChange: "radio_state_change";
|
|
89
|
+
onAfterRender: "after_render";
|
|
90
|
+
onInitialized: "initialized";
|
|
91
|
+
onPivotSortClick: "pivot_sort_click";
|
|
92
|
+
onDrillMenuClick: "drillmenu_click";
|
|
93
|
+
onVChartEventType: "vchart_event_type";
|
|
94
|
+
onChangCellValue: "change_cell_value";
|
|
95
|
+
onMousedownFillHandle: "mousedown_fill_handle";
|
|
96
|
+
onDragFillHandleEnd: "drag_fill_handle_end";
|
|
97
|
+
onDblclickFillHandle: "dblclick_fill_handle";
|
|
98
|
+
onScrollVerticalEnd: "scroll_vertical_end";
|
|
99
|
+
onScrollHorizontalEnd: "scroll_horizontal_end";
|
|
100
|
+
};
|
|
101
|
+
export declare const TABLE_EVENTS_KEYS: string[];
|
|
@@ -0,0 +1,56 @@
|
|
|
1
|
+
import { ListTable, PivotTable, PivotChart } from "@visactor/vtable";
|
|
2
|
+
|
|
3
|
+
const EVENT_TYPE = Object.assign(Object.assign(Object.assign({}, ListTable.EVENT_TYPE), PivotTable.EVENT_TYPE), PivotChart.EVENT_TYPE);
|
|
4
|
+
|
|
5
|
+
export const TABLE_EVENTS = {
|
|
6
|
+
onClickCell: EVENT_TYPE.CLICK_CELL,
|
|
7
|
+
onDblClickCell: EVENT_TYPE.DBLCLICK_CELL,
|
|
8
|
+
onMouseDownCell: EVENT_TYPE.MOUSEDOWN_CELL,
|
|
9
|
+
onMouseUpCell: EVENT_TYPE.MOUSEUP_CELL,
|
|
10
|
+
onSelectedCell: EVENT_TYPE.SELECTED_CELL,
|
|
11
|
+
onKeyDown: EVENT_TYPE.KEYDOWN,
|
|
12
|
+
onMouseEnterTable: EVENT_TYPE.MOUSEENTER_TABLE,
|
|
13
|
+
onMouseLeaveTable: EVENT_TYPE.MOUSELEAVE_TABLE,
|
|
14
|
+
onMouseDownTable: EVENT_TYPE.MOUSEDOWN_TABLE,
|
|
15
|
+
onMouseMoveCell: EVENT_TYPE.MOUSEMOVE_CELL,
|
|
16
|
+
onMouseEnterCell: EVENT_TYPE.MOUSEENTER_CELL,
|
|
17
|
+
onMouseLeaveCell: EVENT_TYPE.MOUSELEAVE_CELL,
|
|
18
|
+
onContextMenuCell: EVENT_TYPE.CONTEXTMENU_CELL,
|
|
19
|
+
onResizeColumn: EVENT_TYPE.RESIZE_COLUMN,
|
|
20
|
+
onResizeColumnEnd: EVENT_TYPE.RESIZE_COLUMN_END,
|
|
21
|
+
onChangeHeaderPosition: EVENT_TYPE.CHANGE_HEADER_POSITION,
|
|
22
|
+
onSortClick: EVENT_TYPE.SORT_CLICK,
|
|
23
|
+
onFreezeClick: EVENT_TYPE.FREEZE_CLICK,
|
|
24
|
+
onScroll: EVENT_TYPE.SCROLL,
|
|
25
|
+
onDropdownMenuClick: EVENT_TYPE.DROPDOWN_MENU_CLICK,
|
|
26
|
+
onMouseOverChartSymbol: EVENT_TYPE.MOUSEOVER_CHART_SYMBOL,
|
|
27
|
+
onDragSelectEnd: EVENT_TYPE.DRAG_SELECT_END,
|
|
28
|
+
onDropdownIconClick: EVENT_TYPE.DROPDOWN_ICON_CLICK,
|
|
29
|
+
onDropdownMenuClear: EVENT_TYPE.DROPDOWN_MENU_CLEAR,
|
|
30
|
+
onTreeHierarchyStateChange: EVENT_TYPE.TREE_HIERARCHY_STATE_CHANGE,
|
|
31
|
+
onShowMenu: EVENT_TYPE.SHOW_MENU,
|
|
32
|
+
onHideMenu: EVENT_TYPE.HIDE_MENU,
|
|
33
|
+
onIconClick: EVENT_TYPE.ICON_CLICK,
|
|
34
|
+
onLegendItemClick: EVENT_TYPE.LEGEND_ITEM_CLICK,
|
|
35
|
+
onLegendItemHover: EVENT_TYPE.LEGEND_ITEM_HOVER,
|
|
36
|
+
onLegendItemUnHover: EVENT_TYPE.LEGEND_ITEM_UNHOVER,
|
|
37
|
+
onLegendChange: EVENT_TYPE.LEGEND_CHANGE,
|
|
38
|
+
onMouseEnterAxis: EVENT_TYPE.MOUSEENTER_AXIS,
|
|
39
|
+
onMouseLeaveAxis: EVENT_TYPE.MOUSELEAVE_AXIS,
|
|
40
|
+
onCheckboxStateChange: EVENT_TYPE.CHECKBOX_STATE_CHANGE,
|
|
41
|
+
onRadioStateChange: EVENT_TYPE.RADIO_STATE_CHANGE,
|
|
42
|
+
onAfterRender: EVENT_TYPE.AFTER_RENDER,
|
|
43
|
+
onInitialized: EVENT_TYPE.INITIALIZED,
|
|
44
|
+
onPivotSortClick: EVENT_TYPE.PIVOT_SORT_CLICK,
|
|
45
|
+
onDrillMenuClick: EVENT_TYPE.DRILLMENU_CLICK,
|
|
46
|
+
onVChartEventType: EVENT_TYPE.VCHART_EVENT_TYPE,
|
|
47
|
+
onChangCellValue: EVENT_TYPE.CHANGE_CELL_VALUE,
|
|
48
|
+
onMousedownFillHandle: EVENT_TYPE.MOUSEDOWN_FILL_HANDLE,
|
|
49
|
+
onDragFillHandleEnd: EVENT_TYPE.DRAG_FILL_HANDLE_END,
|
|
50
|
+
onDblclickFillHandle: EVENT_TYPE.DBLCLICK_FILL_HANDLE,
|
|
51
|
+
onScrollVerticalEnd: EVENT_TYPE.SCROLL_VERTICAL_END,
|
|
52
|
+
onScrollHorizontalEnd: EVENT_TYPE.SCROLL_HORIZONTAL_END
|
|
53
|
+
};
|
|
54
|
+
|
|
55
|
+
export const TABLE_EVENTS_KEYS = Object.keys(TABLE_EVENTS);
|
|
56
|
+
//# sourceMappingURL=eventsUtils.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["eventsUtils.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAE,UAAU,EAAE,UAAU,EAAE,MAAM,kBAAkB,CAAC;AAKrE,MAAM,UAAU,iDACX,SAAS,CAAC,UAAU,GACpB,UAAU,CAAC,UAAU,GACrB,UAAU,CAAC,UAAU,CACzB,CAAC;AAkEF,MAAM,CAAC,MAAM,YAAY,GAAG;IAC1B,WAAW,EAAE,UAAU,CAAC,UAAU;IAClC,cAAc,EAAE,UAAU,CAAC,aAAa;IACxC,eAAe,EAAE,UAAU,CAAC,cAAc;IAC1C,aAAa,EAAE,UAAU,CAAC,YAAY;IACtC,cAAc,EAAE,UAAU,CAAC,aAAa;IACxC,SAAS,EAAE,UAAU,CAAC,OAAO;IAC7B,iBAAiB,EAAE,UAAU,CAAC,gBAAgB;IAC9C,iBAAiB,EAAE,UAAU,CAAC,gBAAgB;IAC9C,gBAAgB,EAAE,UAAU,CAAC,eAAe;IAC5C,eAAe,EAAE,UAAU,CAAC,cAAc;IAC1C,gBAAgB,EAAE,UAAU,CAAC,eAAe;IAC5C,gBAAgB,EAAE,UAAU,CAAC,eAAe;IAC5C,iBAAiB,EAAE,UAAU,CAAC,gBAAgB;IAC9C,cAAc,EAAE,UAAU,CAAC,aAAa;IACxC,iBAAiB,EAAE,UAAU,CAAC,iBAAiB;IAC/C,sBAAsB,EAAE,UAAU,CAAC,sBAAsB;IACzD,WAAW,EAAE,UAAU,CAAC,UAAU;IAClC,aAAa,EAAE,UAAU,CAAC,YAAY;IACtC,QAAQ,EAAE,UAAU,CAAC,MAAM;IAC3B,mBAAmB,EAAE,UAAU,CAAC,mBAAmB;IACnD,sBAAsB,EAAE,UAAU,CAAC,sBAAsB;IACzD,eAAe,EAAE,UAAU,CAAC,eAAe;IAE3C,mBAAmB,EAAE,UAAU,CAAC,mBAAmB;IACnD,mBAAmB,EAAE,UAAU,CAAC,mBAAmB;IAEnD,0BAA0B,EAAE,UAAU,CAAC,2BAA2B;IAElE,UAAU,EAAE,UAAU,CAAC,SAAS;IAChC,UAAU,EAAE,UAAU,CAAC,SAAS;IAEhC,WAAW,EAAE,UAAU,CAAC,UAAU;IAElC,iBAAiB,EAAE,UAAU,CAAC,iBAAiB;IAC/C,iBAAiB,EAAE,UAAU,CAAC,iBAAiB;IAC/C,mBAAmB,EAAE,UAAU,CAAC,mBAAmB;IACnD,cAAc,EAAE,UAAU,CAAC,aAAa;IAExC,gBAAgB,EAAE,UAAU,CAAC,eAAe;IAC5C,gBAAgB,EAAE,UAAU,CAAC,eAAe;IAE5C,qBAAqB,EAAE,UAAU,CAAC,qBAAqB;IACvD,kBAAkB,EAAE,UAAU,CAAC,kBAAkB;IACjD,aAAa,EAAE,UAAU,CAAC,YAAY;IACtC,aAAa,EAAE,UAAU,CAAC,WAAW;IAGrC,gBAAgB,EAAE,UAAU,CAAC,gBAAgB;IAC7C,gBAAgB,EAAE,UAAU,CAAC,eAAe;IAG5C,iBAAiB,EAAE,UAAU,CAAC,iBAAiB;IAE/C,gBAAgB,EAAE,UAAU,CAAC,iBAAiB;IAC9C,qBAAqB,EAAE,UAAU,CAAC,qBAAqB;IACvD,mBAAmB,EAAE,UAAU,CAAC,oBAAoB;IACpD,oBAAoB,EAAE,UAAU,CAAC,oBAAoB;IACrD,mBAAmB,EAAE,UAAU,CAAC,mBAAmB;IACnD,qBAAqB,EAAE,UAAU,CAAC,qBAAqB;CACxD,CAAC;AAEF,MAAM,CAAC,MAAM,iBAAiB,GAAG,MAAM,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC","file":"eventsUtils.js","sourcesContent":["import { ListTable, PivotTable, PivotChart } from '@visactor/vtable';\nimport type { TYPES } from '@visactor/vtable';\n\nexport type EventCallback<Params> = (params: Params) => void;\n\nconst EVENT_TYPE = {\n ...ListTable.EVENT_TYPE,\n ...PivotTable.EVENT_TYPE,\n ...PivotChart.EVENT_TYPE\n};\n\nexport interface EventsProps {\n onClickCell?: EventCallback<TYPES.TableEventHandlersEventArgumentMap['click_cell']>;\n onDblClickCell?: EventCallback<TYPES.TableEventHandlersEventArgumentMap['dblclick_cell']>;\n onMouseDownCell?: EventCallback<TYPES.TableEventHandlersEventArgumentMap['mousedown_cell']>;\n onMouseUpCell?: EventCallback<TYPES.TableEventHandlersEventArgumentMap['mouseup_cell']>;\n onSelectedCell?: EventCallback<TYPES.TableEventHandlersEventArgumentMap['selected_cell']>;\n onKeyDown?: EventCallback<TYPES.TableEventHandlersEventArgumentMap['keydown']>;\n onMouseEnterTable?: EventCallback<TYPES.TableEventHandlersEventArgumentMap['mouseenter_table']>;\n onMouseLeaveTable?: EventCallback<TYPES.TableEventHandlersEventArgumentMap['mouseleave_table']>;\n onMouseDownTable?: EventCallback<TYPES.TableEventHandlersEventArgumentMap['mousedown_table']>;\n onMouseMoveCell?: EventCallback<TYPES.TableEventHandlersEventArgumentMap['mousemove_cell']>;\n onMouseEnterCell?: EventCallback<TYPES.TableEventHandlersEventArgumentMap['mouseenter_cell']>;\n onMouseLeaveCell?: EventCallback<TYPES.TableEventHandlersEventArgumentMap['mouseleave_cell']>;\n onContextMenuCell?: EventCallback<TYPES.TableEventHandlersEventArgumentMap['contextmenu_cell']>;\n onResizeColumn?: EventCallback<TYPES.TableEventHandlersEventArgumentMap['resize_column']>;\n onResizeColumnEnd?: EventCallback<TYPES.TableEventHandlersEventArgumentMap['resize_column_end']>;\n onChangeHeaderPosition?: EventCallback<TYPES.TableEventHandlersEventArgumentMap['change_header_position']>;\n onSortClick?: EventCallback<TYPES.TableEventHandlersEventArgumentMap['sort_click']>;\n onFreezeClick?: EventCallback<TYPES.TableEventHandlersEventArgumentMap['freeze_click']>;\n onScroll?: EventCallback<TYPES.TableEventHandlersEventArgumentMap['scroll']>;\n onDropdownMenuClick?: EventCallback<TYPES.TableEventHandlersEventArgumentMap['dropdown_menu_click']>;\n onMouseOverChartSymbol?: EventCallback<TYPES.TableEventHandlersEventArgumentMap['mouseover_chart_symbol']>;\n onDragSelectEnd?: EventCallback<TYPES.TableEventHandlersEventArgumentMap['drag_select_end']>;\n\n onDropdownIconClick?: EventCallback<TYPES.TableEventHandlersEventArgumentMap['dropdown_icon_click']>;\n onDropdownMenuClear?: EventCallback<TYPES.TableEventHandlersEventArgumentMap['dropdown_menu_clear']>;\n\n onTreeHierarchyStateChange?: EventCallback<TYPES.TableEventHandlersEventArgumentMap['tree_hierarchy_state_change']>;\n\n onShowMenu?: EventCallback<TYPES.TableEventHandlersEventArgumentMap['show_menu']>;\n onHideMenu?: EventCallback<TYPES.TableEventHandlersEventArgumentMap['hide_menu']>;\n\n onIconClick?: EventCallback<TYPES.TableEventHandlersEventArgumentMap['icon_click']>;\n\n onLegendItemClick?: EventCallback<TYPES.TableEventHandlersEventArgumentMap['legend_item_click']>;\n onLegendItemHover?: EventCallback<TYPES.TableEventHandlersEventArgumentMap['legend_item_hover']>;\n onLegendItemUnHover?: EventCallback<TYPES.TableEventHandlersEventArgumentMap['legend_item_unHover']>;\n onLegendChange?: EventCallback<TYPES.TableEventHandlersEventArgumentMap['legend_change']>;\n\n onMouseEnterAxis?: EventCallback<TYPES.TableEventHandlersEventArgumentMap['mouseenter_axis']>;\n onMouseLeaveAxis?: EventCallback<TYPES.TableEventHandlersEventArgumentMap['mouseleave_axis']>;\n\n onCheckboxStateChange?: EventCallback<TYPES.TableEventHandlersEventArgumentMap['checkbox_state_change']>;\n onRadioStateChange?: EventCallback<TYPES.TableEventHandlersEventArgumentMap['radio_state_change']>;\n onAfterRender?: EventCallback<TYPES.TableEventHandlersEventArgumentMap['after_render']>;\n onInitialized?: EventCallback<TYPES.TableEventHandlersEventArgumentMap['initialized']>;\n\n // pivot table only\n onPivotSortClick?: EventCallback<TYPES.TableEventHandlersEventArgumentMap['pivot_sort_click']>;\n onDrillMenuClick?: EventCallback<TYPES.TableEventHandlersEventArgumentMap['drillmenu_click']>;\n\n // pivot chart only\n onVChartEventType?: EventCallback<TYPES.TableEventHandlersEventArgumentMap['vchart_event_type']>;\n\n onChangCellValue?: EventCallback<TYPES.TableEventHandlersEventArgumentMap['change_cell_value']>;\n\n onMousedownFillHandle?: EventCallback<TYPES.TableEventHandlersEventArgumentMap['mousedown_fill_handle']>;\n onDragFillHandleEnd?: EventCallback<TYPES.TableEventHandlersEventArgumentMap['drag_fill_handle_end']>;\n onDblclickFillHandle?: EventCallback<TYPES.TableEventHandlersEventArgumentMap['dblclick_fill_handle']>;\n\n onScrollVerticalEnd?: EventCallback<TYPES.TableEventHandlersEventArgumentMap['scroll_vertical_end']>;\n onScrollHorizontalEnd?: EventCallback<TYPES.TableEventHandlersEventArgumentMap['scroll_horizontal_end']>;\n}\n\nexport const TABLE_EVENTS = {\n onClickCell: EVENT_TYPE.CLICK_CELL,\n onDblClickCell: EVENT_TYPE.DBLCLICK_CELL,\n onMouseDownCell: EVENT_TYPE.MOUSEDOWN_CELL,\n onMouseUpCell: EVENT_TYPE.MOUSEUP_CELL,\n onSelectedCell: EVENT_TYPE.SELECTED_CELL,\n onKeyDown: EVENT_TYPE.KEYDOWN,\n onMouseEnterTable: EVENT_TYPE.MOUSEENTER_TABLE,\n onMouseLeaveTable: EVENT_TYPE.MOUSELEAVE_TABLE,\n onMouseDownTable: EVENT_TYPE.MOUSEDOWN_TABLE,\n onMouseMoveCell: EVENT_TYPE.MOUSEMOVE_CELL,\n onMouseEnterCell: EVENT_TYPE.MOUSEENTER_CELL,\n onMouseLeaveCell: EVENT_TYPE.MOUSELEAVE_CELL,\n onContextMenuCell: EVENT_TYPE.CONTEXTMENU_CELL,\n onResizeColumn: EVENT_TYPE.RESIZE_COLUMN,\n onResizeColumnEnd: EVENT_TYPE.RESIZE_COLUMN_END,\n onChangeHeaderPosition: EVENT_TYPE.CHANGE_HEADER_POSITION,\n onSortClick: EVENT_TYPE.SORT_CLICK,\n onFreezeClick: EVENT_TYPE.FREEZE_CLICK,\n onScroll: EVENT_TYPE.SCROLL,\n onDropdownMenuClick: EVENT_TYPE.DROPDOWN_MENU_CLICK,\n onMouseOverChartSymbol: EVENT_TYPE.MOUSEOVER_CHART_SYMBOL,\n onDragSelectEnd: EVENT_TYPE.DRAG_SELECT_END,\n\n onDropdownIconClick: EVENT_TYPE.DROPDOWN_ICON_CLICK,\n onDropdownMenuClear: EVENT_TYPE.DROPDOWN_MENU_CLEAR,\n\n onTreeHierarchyStateChange: EVENT_TYPE.TREE_HIERARCHY_STATE_CHANGE,\n\n onShowMenu: EVENT_TYPE.SHOW_MENU,\n onHideMenu: EVENT_TYPE.HIDE_MENU,\n\n onIconClick: EVENT_TYPE.ICON_CLICK,\n\n onLegendItemClick: EVENT_TYPE.LEGEND_ITEM_CLICK,\n onLegendItemHover: EVENT_TYPE.LEGEND_ITEM_HOVER,\n onLegendItemUnHover: EVENT_TYPE.LEGEND_ITEM_UNHOVER,\n onLegendChange: EVENT_TYPE.LEGEND_CHANGE,\n\n onMouseEnterAxis: EVENT_TYPE.MOUSEENTER_AXIS,\n onMouseLeaveAxis: EVENT_TYPE.MOUSELEAVE_AXIS,\n\n onCheckboxStateChange: EVENT_TYPE.CHECKBOX_STATE_CHANGE,\n onRadioStateChange: EVENT_TYPE.RADIO_STATE_CHANGE,\n onAfterRender: EVENT_TYPE.AFTER_RENDER,\n onInitialized: EVENT_TYPE.INITIALIZED,\n\n // pivot table only\n onPivotSortClick: EVENT_TYPE.PIVOT_SORT_CLICK,\n onDrillMenuClick: EVENT_TYPE.DRILLMENU_CLICK,\n\n // pivot chart only\n onVChartEventType: EVENT_TYPE.VCHART_EVENT_TYPE,\n\n onChangCellValue: EVENT_TYPE.CHANGE_CELL_VALUE,\n onMousedownFillHandle: EVENT_TYPE.MOUSEDOWN_FILL_HANDLE,\n onDragFillHandleEnd: EVENT_TYPE.DRAG_FILL_HANDLE_END,\n onDblclickFillHandle: EVENT_TYPE.DBLCLICK_FILL_HANDLE,\n onScrollVerticalEnd: EVENT_TYPE.SCROLL_VERTICAL_END,\n onScrollHorizontalEnd: EVENT_TYPE.SCROLL_HORIZONTAL_END\n};\n\nexport const TABLE_EVENTS_KEYS = Object.keys(TABLE_EVENTS);\n\n// export const findEventProps = <T extends EventsProps>(\n// props: T,\n// supportedEvents: Record<string, string> = TABLE_EVENTS\n// ): EventsProps => {\n// const result: EventsProps = {};\n\n// Object.keys(props).forEach(key => {\n// if (supportedEvents[key] && props[key]) {\n// result[key] = props[key];\n// }\n// });\n\n// return result;\n// };\n\n// export const bindEventsToTable = <T>(\n// table: IVTable,\n// newProps?: T | null,\n// prevProps?: T | null,\n// supportedEvents: Record<string, string> = TABLE_EVENTS\n// ) => {\n// if (!table) return false;\n// const prevEventProps = prevProps ? findEventProps(prevProps, supportedEvents) : {};\n// const newEventProps = newProps ? findEventProps(newProps, supportedEvents) : {};\n\n// Object.keys(supportedEvents).forEach(eventKey => {\n// const prevHandler = prevEventProps[eventKey];\n// const newHandler = newEventProps[eventKey];\n\n// if (prevHandler !== newHandler) {\n// if (prevHandler) {\n// table.off(supportedEvents[eventKey], prevHandler);\n// }\n// if (newHandler) {\n// table.on(supportedEvents[eventKey] as keyof TYPES.TableEventHandlersEventArgumentMap, newHandler);\n// }\n// }\n// });\n\n// return true;\n// };\n"]}
|
package/es/index.d.ts
ADDED
package/es/index.js
ADDED
package/es/index.js.map
ADDED
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["index.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,MAAM,MAAM,kBAAkB,CAAC;AAE3C,cAAc,UAAU,CAAC;AACzB,cAAc,cAAc,CAAC;AAC7B,OAAO,EAAE,MAAM,EAAE,CAAC;AAElB,MAAM,CAAC,MAAM,OAAO,GAAG,OAAO,CAAC","file":"index.js","sourcesContent":["import * as VTable from '@visactor/vtable';\n\nexport * from './tables';\nexport * from './components';\nexport { VTable };\n\nexport const version = \"1.7.4\";\n"]}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export declare const registerChartModule: (name: string, chart: any) => void;
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["tables/chartModule.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,MAAM,MAAM,kBAAkB,CAAC;AAE3C,MAAM,CAAC,MAAM,mBAAmB,GAAG,CAAC,IAAY,EAAE,KAAU,EAAE,EAAE;IAC9D,MAAM,CAAC,QAAQ,CAAC,WAAW,CAAC,IAAI,EAAE,KAAK,CAAC,CAAC;AAC3C,CAAC,CAAC","file":"chartModule.js","sourcesContent":["import * as VTable from '@visactor/vtable';\n\nexport const registerChartModule = (name: string, chart: any) => {\n VTable.register.chartModule(name, chart);\n};\n"]}
|
|
@@ -0,0 +1,8 @@
|
|
|
1
|
+
export { default as ListTable } from "./list-table.vue";
|
|
2
|
+
|
|
3
|
+
export { default as PivotTable } from "./pivot-table.vue";
|
|
4
|
+
|
|
5
|
+
export { default as PivotChart } from "./pivot-chart.vue";
|
|
6
|
+
|
|
7
|
+
export { registerChartModule } from "./chartModule";
|
|
8
|
+
//# sourceMappingURL=index.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["tables/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,OAAO,IAAI,SAAS,EAAE,MAAM,kBAAkB,CAAC;AACxD,OAAO,EAAE,OAAO,IAAI,UAAU,EAAE,MAAM,mBAAmB,CAAC;AAC1D,OAAO,EAAE,OAAO,IAAI,UAAU,EAAE,MAAM,mBAAmB,CAAC;AAC1D,OAAO,EAAE,mBAAmB,EAAE,MAAM,eAAe,CAAC","file":"index.js","sourcesContent":["export { default as ListTable } from './list-table.vue';\nexport { default as PivotTable } from './pivot-table.vue';\nexport { default as PivotChart } from './pivot-chart.vue';\nexport { registerChartModule } from './chartModule';\n"]}
|
|
@@ -0,0 +1,49 @@
|
|
|
1
|
+
import * as VTable from "@visactor/vtable";
|
|
2
|
+
|
|
3
|
+
import { isFunction } from "@visactor/vutils";
|
|
4
|
+
|
|
5
|
+
export function flattenVNodes(vnodes) {
|
|
6
|
+
return vnodes.flatMap((vnode => Array.isArray(vnode.children) ? flattenVNodes(vnode.children) : vnode));
|
|
7
|
+
}
|
|
8
|
+
|
|
9
|
+
function isEventProp(key, props) {
|
|
10
|
+
return key.startsWith("on") && isFunction(props[key]);
|
|
11
|
+
}
|
|
12
|
+
|
|
13
|
+
export function createCustomLayout(children) {
|
|
14
|
+
const componentMap = {
|
|
15
|
+
Group: VTable.CustomLayout.Group,
|
|
16
|
+
Image: VTable.CustomLayout.Image,
|
|
17
|
+
Text: VTable.CustomLayout.Text,
|
|
18
|
+
Tag: VTable.CustomLayout.Tag,
|
|
19
|
+
Radio: VTable.CustomLayout.Radio,
|
|
20
|
+
CheckBox: VTable.CustomLayout.CheckBox
|
|
21
|
+
};
|
|
22
|
+
return {
|
|
23
|
+
rootComponent: function createComponent(child) {
|
|
24
|
+
if (!child) return null;
|
|
25
|
+
const {type: type, props: props, children: childChildren} = child, componentName = (null == type ? void 0 : type.name) || type, ComponentClass = componentMap[componentName];
|
|
26
|
+
if (!ComponentClass) return null;
|
|
27
|
+
const component = new ComponentClass(Object.assign({}, props));
|
|
28
|
+
!function(component, props) {
|
|
29
|
+
Object.keys(props).forEach((key => {
|
|
30
|
+
if (isEventProp(key, props)) {
|
|
31
|
+
const eventName = key.slice(2).toLowerCase();
|
|
32
|
+
component.addEventListener(eventName, props[key]);
|
|
33
|
+
}
|
|
34
|
+
}));
|
|
35
|
+
}(component, props);
|
|
36
|
+
return function(childChildren) {
|
|
37
|
+
var _a;
|
|
38
|
+
return (null === (_a = null == childChildren ? void 0 : childChildren.default) || void 0 === _a ? void 0 : _a.call(childChildren)) || childChildren || [];
|
|
39
|
+
}(childChildren).forEach((subChild => {
|
|
40
|
+
const subComponent = createComponent(subChild);
|
|
41
|
+
subComponent ? component.add(subComponent) : subChild.type === Symbol.for("v-fgt") && subChild.children.forEach((nestedChild => {
|
|
42
|
+
const nestedComponent = createComponent(nestedChild);
|
|
43
|
+
nestedComponent && component.add(nestedComponent);
|
|
44
|
+
}));
|
|
45
|
+
})), component;
|
|
46
|
+
}(children)
|
|
47
|
+
};
|
|
48
|
+
}
|
|
49
|
+
//# sourceMappingURL=utils.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["tables/utils.ts"],"names":[],"mappings":"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","file":"utils.js","sourcesContent":["import * as VTable from '@visactor/vtable';\nimport { isFunction, merge } from '@visactor/vutils';\nimport { application, REACT_TO_CANOPUS_EVENTS } from '@visactor/vtable/es/vrender';\nimport type { Graphic, IGraphic, IGraphicCreator } from '@visactor/vtable/es/vrender';\nimport { CheckBox, Radio, Tag } from '@visactor/vtable/es/vrender';\nimport { reactive, watch } from 'vue';\n\n// 展平嵌套的虚拟节点\nexport function flattenVNodes(vnodes: any[]): any[] {\n return vnodes.flatMap(vnode => (Array.isArray(vnode.children) ? flattenVNodes(vnode.children) : vnode));\n}\n\n// 检查属性是否为事件\nfunction isEventProp(key: string, props: any) {\n return key.startsWith('on') && isFunction(props[key]);\n}\n\n// 创建自定义布局\nexport function createCustomLayout(children: any): any {\n // 组件映射\n //需要修改成用application.graphicService.creator来创建组件\n const componentMap: Record<string, any> = {\n Group: VTable.CustomLayout.Group,\n Image: VTable.CustomLayout.Image,\n Text: VTable.CustomLayout.Text,\n Tag: VTable.CustomLayout.Tag,\n Radio: VTable.CustomLayout.Radio,\n CheckBox: VTable.CustomLayout.CheckBox\n };\n\n // 创建组件的函数\n function createComponent(child: any): any {\n if (!child) {\n return null;\n }\n\n const { type, props, children: childChildren } = child;\n const componentName = type?.name || type;\n const ComponentClass = componentMap[componentName];\n\n if (!ComponentClass) {\n return null;\n }\n\n // 创建组件实例\n const component = new ComponentClass({ ...props });\n\n // 绑定组件事件\n bindComponentEvents(component, props);\n\n // 递归创建子组件\n const subChildren = resolveChildren(childChildren);\n subChildren.forEach((subChild: any) => {\n const subComponent = createComponent(subChild);\n if (subComponent) {\n component.add(subComponent);\n } else if (subChild.type === Symbol.for('v-fgt')) {\n subChild.children.forEach((nestedChild: any) => {\n const nestedComponent = createComponent(nestedChild);\n if (nestedComponent) {\n component.add(nestedComponent);\n }\n });\n }\n });\n\n return component;\n }\n\n // 处理子节点\n function resolveChildren(childChildren: any): any[] {\n return childChildren?.default?.() || childChildren || [];\n }\n\n // 绑定组件事件\n function bindComponentEvents(component: any, props: any): void {\n Object.keys(props).forEach(key => {\n if (isEventProp(key, props)) {\n const eventName = key.slice(2).toLowerCase(); // 去掉'on'前缀并转换为小写\n component.addEventListener(eventName, props[key]);\n }\n });\n }\n\n // 返回root组件和refs\n return { rootComponent: createComponent(children) };\n}\n"]}
|
package/package.json
ADDED
|
@@ -0,0 +1,100 @@
|
|
|
1
|
+
{
|
|
2
|
+
"name": "@visactor/vue-vtable",
|
|
3
|
+
"version": "1.7.5-alpha.1",
|
|
4
|
+
"description": "The vue version of VTable",
|
|
5
|
+
"keywords": [
|
|
6
|
+
"vue",
|
|
7
|
+
"grid",
|
|
8
|
+
"table",
|
|
9
|
+
"pivottable",
|
|
10
|
+
"visualization",
|
|
11
|
+
"VTable",
|
|
12
|
+
"VisActor",
|
|
13
|
+
"spreadsheet",
|
|
14
|
+
"canvas",
|
|
15
|
+
"datagrid",
|
|
16
|
+
"datatable"
|
|
17
|
+
],
|
|
18
|
+
"author": {
|
|
19
|
+
"name": "VisActor",
|
|
20
|
+
"url": "https://VisActor.io/"
|
|
21
|
+
},
|
|
22
|
+
"license": "MIT",
|
|
23
|
+
"sideEffects": false,
|
|
24
|
+
"main": "cjs/index.js",
|
|
25
|
+
"module": "es/index.js",
|
|
26
|
+
"types": "es/index.d.ts",
|
|
27
|
+
"files": [
|
|
28
|
+
"cjs",
|
|
29
|
+
"es",
|
|
30
|
+
"dist"
|
|
31
|
+
],
|
|
32
|
+
"exports": {
|
|
33
|
+
".": {
|
|
34
|
+
"require": "./cjs/index.js",
|
|
35
|
+
"import": "./es/index.js"
|
|
36
|
+
}
|
|
37
|
+
},
|
|
38
|
+
"scripts": {
|
|
39
|
+
"start": "vite ./demo",
|
|
40
|
+
"build": "cross-env USE_TYPESCRIPT2=true bundle --clean",
|
|
41
|
+
"compile": "tsc --noEmit",
|
|
42
|
+
"eslint": "eslint --debug --fix src/"
|
|
43
|
+
},
|
|
44
|
+
"unpkg": "latest",
|
|
45
|
+
"unpkgFiles": [
|
|
46
|
+
"dist/vue-vtable.js"
|
|
47
|
+
],
|
|
48
|
+
"publishConfig": {
|
|
49
|
+
"access": "public"
|
|
50
|
+
},
|
|
51
|
+
"dependencies": {
|
|
52
|
+
"@visactor/vtable": "workspace:*",
|
|
53
|
+
"@visactor/vutils": "~0.18.13"
|
|
54
|
+
},
|
|
55
|
+
"devDependencies": {
|
|
56
|
+
"@arco-design/web-vue": "^2.11.0",
|
|
57
|
+
"cross-env": "^7.0.3",
|
|
58
|
+
"@visactor/vchart": "1.12.1",
|
|
59
|
+
"@internal/bundler": "workspace:*",
|
|
60
|
+
"@internal/eslint-config": "workspace:*",
|
|
61
|
+
"@internal/ts-config": "workspace:*",
|
|
62
|
+
"@rushstack/eslint-patch": "~1.1.4",
|
|
63
|
+
"vue": "^3.4.14",
|
|
64
|
+
"@vitejs/plugin-vue": "^5.0.3",
|
|
65
|
+
"eslint": "~8.18.0",
|
|
66
|
+
"vite": "3.2.6",
|
|
67
|
+
"typescript": "4.9.5",
|
|
68
|
+
"@babel/core": "7.20.12",
|
|
69
|
+
"@babel/preset-env": "7.20.2",
|
|
70
|
+
"@types/chai": "4.2.22",
|
|
71
|
+
"@types/jest": "^26.0.0",
|
|
72
|
+
"@types/mocha": "9.0.0",
|
|
73
|
+
"@types/node": "*",
|
|
74
|
+
"@types/offscreencanvas": "2019.6.4",
|
|
75
|
+
"chai": "4.3.4",
|
|
76
|
+
"jest": "^26.0.0",
|
|
77
|
+
"jest-electron": "^0.1.12",
|
|
78
|
+
"jest-transform-stub": "^2.0.0",
|
|
79
|
+
"magic-string": "^0.25.7",
|
|
80
|
+
"mocha": "9.1.3",
|
|
81
|
+
"postcss": "8.4.21",
|
|
82
|
+
"rimraf": "3.0.2",
|
|
83
|
+
"sass": "1.43.5",
|
|
84
|
+
"ts-jest": "^26.0.0",
|
|
85
|
+
"ts-loader": "9.2.6",
|
|
86
|
+
"ts-node": "10.9.0",
|
|
87
|
+
"tslib": "2.3.1",
|
|
88
|
+
"ttypescript": "1.5.13",
|
|
89
|
+
"typescript-transform-paths": "3.3.1",
|
|
90
|
+
"json-formatter-js": "^2.3.4",
|
|
91
|
+
"inversify": "6.0.1",
|
|
92
|
+
"vite-plugin-markdown": "^2.1.0",
|
|
93
|
+
"markdown-it": "^13.0.0",
|
|
94
|
+
"node-fetch": "2.6.7",
|
|
95
|
+
"form-data": "~4.0.0",
|
|
96
|
+
"axios": "^1.4.0",
|
|
97
|
+
"eslint-plugin-vue": "^9.26.0",
|
|
98
|
+
"vue-eslint-parser": "^9.4.2"
|
|
99
|
+
}
|
|
100
|
+
}
|