@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.
Files changed (142) hide show
  1. package/README.md +93 -0
  2. package/cjs/components/component/menu.d.ts +9 -0
  3. package/cjs/components/component/menu.js +9 -0
  4. package/cjs/components/component/menu.js.map +1 -0
  5. package/cjs/components/component/tooltip.d.ts +7 -0
  6. package/cjs/components/component/tooltip.js +10 -0
  7. package/cjs/components/component/tooltip.js.map +1 -0
  8. package/cjs/components/custom/checkBox.d.ts +16 -0
  9. package/cjs/components/custom/checkBox.js +10 -0
  10. package/cjs/components/custom/checkBox.js.map +1 -0
  11. package/cjs/components/custom/custom-layout.d.ts +16 -0
  12. package/cjs/components/custom/custom-layout.js +10 -0
  13. package/cjs/components/custom/custom-layout.js.map +1 -0
  14. package/cjs/components/custom/group.d.ts +2 -0
  15. package/cjs/components/custom/group.js +10 -0
  16. package/cjs/components/custom/group.js.map +1 -0
  17. package/cjs/components/custom/image.d.ts +2 -0
  18. package/cjs/components/custom/image.js +10 -0
  19. package/cjs/components/custom/image.js.map +1 -0
  20. package/cjs/components/custom/radio.d.ts +13 -0
  21. package/cjs/components/custom/radio.js +10 -0
  22. package/cjs/components/custom/radio.js.map +1 -0
  23. package/cjs/components/custom/tag.d.ts +12 -0
  24. package/cjs/components/custom/tag.js +10 -0
  25. package/cjs/components/custom/tag.js.map +1 -0
  26. package/cjs/components/custom/text.d.ts +2 -0
  27. package/cjs/components/custom/text.js +10 -0
  28. package/cjs/components/custom/text.js.map +1 -0
  29. package/cjs/components/index.d.ts +15 -0
  30. package/cjs/components/index.js +147 -0
  31. package/cjs/components/index.js.map +1 -0
  32. package/cjs/components/list/list-column.d.ts +3 -0
  33. package/cjs/components/list/list-column.js +10 -0
  34. package/cjs/components/list/list-column.js.map +1 -0
  35. package/cjs/components/pivot/pivot-column-dimension.d.ts +8 -0
  36. package/cjs/components/pivot/pivot-column-dimension.js +10 -0
  37. package/cjs/components/pivot/pivot-column-dimension.js.map +1 -0
  38. package/cjs/components/pivot/pivot-column-header-title.d.ts +3 -0
  39. package/cjs/components/pivot/pivot-column-header-title.js +10 -0
  40. package/cjs/components/pivot/pivot-column-header-title.js.map +1 -0
  41. package/cjs/components/pivot/pivot-corner.d.ts +3 -0
  42. package/cjs/components/pivot/pivot-corner.js +10 -0
  43. package/cjs/components/pivot/pivot-corner.js.map +1 -0
  44. package/cjs/components/pivot/pivot-indicator.d.ts +3 -0
  45. package/cjs/components/pivot/pivot-indicator.js +10 -0
  46. package/cjs/components/pivot/pivot-indicator.js.map +1 -0
  47. package/cjs/components/pivot/pivot-row-dimension.d.ts +8 -0
  48. package/cjs/components/pivot/pivot-row-dimension.js +10 -0
  49. package/cjs/components/pivot/pivot-row-dimension.js.map +1 -0
  50. package/cjs/components/pivot/pivot-row-header-title.d.ts +3 -0
  51. package/cjs/components/pivot/pivot-row-header-title.js +10 -0
  52. package/cjs/components/pivot/pivot-row-header-title.js.map +1 -0
  53. package/cjs/constants.d.ts +1 -0
  54. package/cjs/constants.js +5 -0
  55. package/cjs/constants.js.map +1 -0
  56. package/cjs/eventsUtils.d.ts +101 -0
  57. package/cjs/eventsUtils.js +58 -0
  58. package/cjs/eventsUtils.js.map +1 -0
  59. package/cjs/index.d.ts +5 -0
  60. package/cjs/index.js +38 -0
  61. package/cjs/index.js.map +1 -0
  62. package/cjs/tables/chartModule.d.ts +1 -0
  63. package/cjs/tables/chartModule.js +37 -0
  64. package/cjs/tables/chartModule.js.map +1 -0
  65. package/cjs/tables/index.d.ts +4 -0
  66. package/cjs/tables/index.js +48 -0
  67. package/cjs/tables/index.js.map +1 -0
  68. package/cjs/tables/utils.d.ts +2 -0
  69. package/cjs/tables/utils.js +80 -0
  70. package/cjs/tables/utils.js.map +1 -0
  71. package/dist/vue-vtable.js +4040 -0
  72. package/dist/vue-vtable.min.js +18 -0
  73. package/es/components/component/menu.d.ts +9 -0
  74. package/es/components/component/menu.js +3 -0
  75. package/es/components/component/menu.js.map +1 -0
  76. package/es/components/component/tooltip.d.ts +7 -0
  77. package/es/components/component/tooltip.js +4 -0
  78. package/es/components/component/tooltip.js.map +1 -0
  79. package/es/components/custom/checkBox.d.ts +16 -0
  80. package/es/components/custom/checkBox.js +4 -0
  81. package/es/components/custom/checkBox.js.map +1 -0
  82. package/es/components/custom/custom-layout.d.ts +16 -0
  83. package/es/components/custom/custom-layout.js +4 -0
  84. package/es/components/custom/custom-layout.js.map +1 -0
  85. package/es/components/custom/group.d.ts +2 -0
  86. package/es/components/custom/group.js +4 -0
  87. package/es/components/custom/group.js.map +1 -0
  88. package/es/components/custom/image.d.ts +2 -0
  89. package/es/components/custom/image.js +4 -0
  90. package/es/components/custom/image.js.map +1 -0
  91. package/es/components/custom/radio.d.ts +13 -0
  92. package/es/components/custom/radio.js +4 -0
  93. package/es/components/custom/radio.js.map +1 -0
  94. package/es/components/custom/tag.d.ts +12 -0
  95. package/es/components/custom/tag.js +4 -0
  96. package/es/components/custom/tag.js.map +1 -0
  97. package/es/components/custom/text.d.ts +2 -0
  98. package/es/components/custom/text.js +4 -0
  99. package/es/components/custom/text.js.map +1 -0
  100. package/es/components/index.d.ts +15 -0
  101. package/es/components/index.js +30 -0
  102. package/es/components/index.js.map +1 -0
  103. package/es/components/list/list-column.d.ts +3 -0
  104. package/es/components/list/list-column.js +4 -0
  105. package/es/components/list/list-column.js.map +1 -0
  106. package/es/components/pivot/pivot-column-dimension.d.ts +8 -0
  107. package/es/components/pivot/pivot-column-dimension.js +4 -0
  108. package/es/components/pivot/pivot-column-dimension.js.map +1 -0
  109. package/es/components/pivot/pivot-column-header-title.d.ts +3 -0
  110. package/es/components/pivot/pivot-column-header-title.js +4 -0
  111. package/es/components/pivot/pivot-column-header-title.js.map +1 -0
  112. package/es/components/pivot/pivot-corner.d.ts +3 -0
  113. package/es/components/pivot/pivot-corner.js +4 -0
  114. package/es/components/pivot/pivot-corner.js.map +1 -0
  115. package/es/components/pivot/pivot-indicator.d.ts +3 -0
  116. package/es/components/pivot/pivot-indicator.js +4 -0
  117. package/es/components/pivot/pivot-indicator.js.map +1 -0
  118. package/es/components/pivot/pivot-row-dimension.d.ts +8 -0
  119. package/es/components/pivot/pivot-row-dimension.js +4 -0
  120. package/es/components/pivot/pivot-row-dimension.js.map +1 -0
  121. package/es/components/pivot/pivot-row-header-title.d.ts +3 -0
  122. package/es/components/pivot/pivot-row-header-title.js +4 -0
  123. package/es/components/pivot/pivot-row-header-title.js.map +1 -0
  124. package/es/constants.d.ts +1 -0
  125. package/es/constants.js +1 -0
  126. package/es/constants.js.map +1 -0
  127. package/es/eventsUtils.d.ts +101 -0
  128. package/es/eventsUtils.js +56 -0
  129. package/es/eventsUtils.js.map +1 -0
  130. package/es/index.d.ts +5 -0
  131. package/es/index.js +10 -0
  132. package/es/index.js.map +1 -0
  133. package/es/tables/chartModule.d.ts +1 -0
  134. package/es/tables/chartModule.js +6 -0
  135. package/es/tables/chartModule.js.map +1 -0
  136. package/es/tables/index.d.ts +4 -0
  137. package/es/tables/index.js +8 -0
  138. package/es/tables/index.js.map +1 -0
  139. package/es/tables/utils.d.ts +2 -0
  140. package/es/tables/utils.js +49 -0
  141. package/es/tables/utils.js.map +1 -0
  142. 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
@@ -0,0 +1,5 @@
1
+ import * as VTable from '@visactor/vtable';
2
+ export * from './tables';
3
+ export * from './components';
4
+ export { VTable };
5
+ export declare const version = "1.7.4";
package/es/index.js ADDED
@@ -0,0 +1,10 @@
1
+ import * as VTable from "@visactor/vtable";
2
+
3
+ export * from "./tables";
4
+
5
+ export * from "./components";
6
+
7
+ export { VTable };
8
+
9
+ export const version = "1.7.4";
10
+ //# sourceMappingURL=index.js.map
@@ -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,6 @@
1
+ import * as VTable from "@visactor/vtable";
2
+
3
+ export const registerChartModule = (name, chart) => {
4
+ VTable.register.chartModule(name, chart);
5
+ };
6
+ //# sourceMappingURL=chartModule.js.map
@@ -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,4 @@
1
+ export { default as ListTable } from './list-table.vue';
2
+ export { default as PivotTable } from './pivot-table.vue';
3
+ export { default as PivotChart } from './pivot-chart.vue';
4
+ export { registerChartModule } from './chartModule';
@@ -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,2 @@
1
+ export declare function flattenVNodes(vnodes: any[]): any[];
2
+ export declare function createCustomLayout(children: any): any;
@@ -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
+ }