stk-table-vue 0.11.11 → 0.11.12

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 (96) hide show
  1. package/README.md +173 -173
  2. package/lib/{index-C40Rz-HL.js → index-BzpbBYPO.js} +166 -167
  3. package/lib/src/StkTable/StkTable.vue.d.ts +840 -831
  4. package/lib/src/StkTable/custom-cells/EditableCell/EditableCell.vue.d.ts +18 -0
  5. package/lib/src/StkTable/custom-cells/EditableCell/createEditableCell.d.ts +33 -0
  6. package/lib/src/StkTable/custom-cells/EditableCell/index.d.ts +3 -0
  7. package/lib/src/StkTable/{components → custom-cells}/Filter/Dropdown/index.d.ts +26 -26
  8. package/lib/src/StkTable/{components → custom-cells}/Filter/Dropdown/index.vue.d.ts +16 -16
  9. package/lib/src/StkTable/{components → custom-cells}/Filter/Filter.vue.d.ts +35 -35
  10. package/lib/src/StkTable/{components/Filter/useFilter.d.ts → custom-cells/Filter/createFilter.d.ts} +23 -33
  11. package/lib/src/StkTable/custom-cells/Filter/index.d.ts +2 -0
  12. package/lib/src/StkTable/custom-cells/Filter/types.d.ts +38 -0
  13. package/lib/src/StkTable/features/const.d.ts +1 -1
  14. package/lib/src/StkTable/features/index.d.ts +1 -1
  15. package/lib/src/StkTable/features/useAreaSelection.d.ts +25 -24
  16. package/lib/src/StkTable/index.d.ts +9 -7
  17. package/lib/src/StkTable/registerFeature.d.ts +9 -9
  18. package/lib/src/StkTable/types/index.d.ts +416 -401
  19. package/lib/src/StkTable/useAutoResize.d.ts +10 -10
  20. package/lib/src/StkTable/useColResize.d.ts +5 -5
  21. package/lib/src/StkTable/useFixedCol.d.ts +9 -9
  22. package/lib/src/StkTable/useFixedStyle.d.ts +16 -16
  23. package/lib/src/StkTable/useGetFixedColPosition.d.ts +9 -9
  24. package/lib/src/StkTable/useHighlight.d.ts +8 -8
  25. package/lib/src/StkTable/useKeyboardArrowScroll.d.ts +10 -10
  26. package/lib/src/StkTable/useMaxRowSpan.d.ts +4 -4
  27. package/lib/src/StkTable/useMergeCells.d.ts +7 -7
  28. package/lib/src/StkTable/useRowExpand.d.ts +9 -9
  29. package/lib/src/StkTable/useScrollRowByRow.d.ts +3 -3
  30. package/lib/src/StkTable/useScrollbar.d.ts +45 -45
  31. package/lib/src/StkTable/useSorter.d.ts +38 -38
  32. package/lib/src/StkTable/useTableColumns.d.ts +8 -8
  33. package/lib/src/StkTable/useThDrag.d.ts +7 -7
  34. package/lib/src/StkTable/useTrDrag.d.ts +7 -7
  35. package/lib/src/StkTable/useTree.d.ts +10 -10
  36. package/lib/src/StkTable/useVirtualScroll.d.ts +78 -78
  37. package/lib/src/StkTable/utils/index.d.ts +71 -71
  38. package/lib/stk-table-vue.js +4490 -4269
  39. package/lib/style.css +674 -649
  40. package/lib/test/defaultSort.test.d.ts +1 -1
  41. package/lib/test/setSorter.test.d.ts +1 -1
  42. package/package.json +84 -84
  43. package/src/StkTable/StkTable.vue +1799 -1771
  44. package/src/StkTable/components/DragHandle.vue +9 -9
  45. package/src/StkTable/components/SortIcon.vue +6 -6
  46. package/src/StkTable/components/TreeNodeCell.vue +19 -19
  47. package/src/StkTable/components/TriangleIcon.vue +3 -3
  48. package/src/StkTable/const.ts +50 -50
  49. package/src/StkTable/custom-cells/EditableCell/EditableCell.less +18 -0
  50. package/src/StkTable/custom-cells/EditableCell/EditableCell.vue +100 -0
  51. package/src/StkTable/custom-cells/EditableCell/createEditableCell.ts +41 -0
  52. package/src/StkTable/custom-cells/EditableCell/index.ts +5 -0
  53. package/src/StkTable/{components → custom-cells}/Filter/Dropdown/index.ts +16 -16
  54. package/src/StkTable/{components → custom-cells}/Filter/Dropdown/index.vue +184 -185
  55. package/src/StkTable/{components → custom-cells}/Filter/Filter.less +118 -129
  56. package/src/StkTable/{components → custom-cells}/Filter/Filter.vue +66 -61
  57. package/src/StkTable/{components/Filter/useFilter.ts → custom-cells/Filter/createFilter.ts} +103 -90
  58. package/src/StkTable/custom-cells/Filter/index.ts +6 -0
  59. package/src/StkTable/custom-cells/Filter/types.ts +39 -0
  60. package/src/StkTable/features/const.ts +1 -1
  61. package/src/StkTable/features/index.ts +1 -1
  62. package/src/StkTable/features/useAreaSelection.ts +951 -899
  63. package/src/StkTable/index.ts +12 -9
  64. package/src/StkTable/registerFeature.ts +40 -39
  65. package/src/StkTable/style.less +749 -749
  66. package/src/StkTable/types/highlightDimOptions.ts +26 -26
  67. package/src/StkTable/types/index.ts +437 -426
  68. package/src/StkTable/useAutoResize.ts +87 -87
  69. package/src/StkTable/useColResize.ts +202 -202
  70. package/src/StkTable/useFixedCol.ts +142 -142
  71. package/src/StkTable/useFixedStyle.ts +75 -75
  72. package/src/StkTable/useGetFixedColPosition.ts +63 -63
  73. package/src/StkTable/useHighlight.ts +253 -253
  74. package/src/StkTable/useKeyboardArrowScroll.ts +114 -114
  75. package/src/StkTable/useMaxRowSpan.ts +50 -50
  76. package/src/StkTable/useMergeCells.ts +138 -138
  77. package/src/StkTable/useRowExpand.ts +81 -81
  78. package/src/StkTable/useScrollRowByRow.ts +96 -96
  79. package/src/StkTable/useScrollbar.ts +169 -169
  80. package/src/StkTable/useSorter.ts +259 -259
  81. package/src/StkTable/useTableColumns.ts +129 -129
  82. package/src/StkTable/useThDrag.ts +96 -96
  83. package/src/StkTable/useTrDrag.ts +100 -100
  84. package/src/StkTable/useTree.ts +152 -152
  85. package/src/StkTable/useVirtualScroll.ts +554 -554
  86. package/src/StkTable/useWheeling.ts +23 -23
  87. package/src/StkTable/utils/constRefUtils.ts +29 -29
  88. package/src/StkTable/utils/index.ts +324 -324
  89. package/src/StkTable/utils/useTriggerRef.ts +33 -33
  90. package/src/VirtualTree.vue +622 -622
  91. package/src/VirtualTreeSelect.vue +367 -367
  92. package/src/vite-env.d.ts +10 -10
  93. package/lib/src/StkTable/components/Filter/index.d.ts +0 -2
  94. package/lib/src/StkTable/components/Filter/types.d.ts +0 -11
  95. package/src/StkTable/components/Filter/index.ts +0 -6
  96. package/src/StkTable/components/Filter/types.ts +0 -18
package/README.md CHANGED
@@ -1,173 +1,173 @@
1
- <p align="center">
2
- <a href="https://ja-plus.github.io/stk-table-vue/">
3
- <img src="./docs-src/public/assets/logo.svg" width="152">
4
- </a>
5
- <h3 align='center'>Stk Table Vue</h3>
6
- <p align="center">
7
- <a href="https://www.npmjs.com/package/stk-table-vue"><img src="https://img.shields.io/npm/v/stk-table-vue"></a>
8
- <a href="https://www.npmjs.com/package/stk-table-vue"><img src="https://img.shields.io/npm/dw/stk-table-vue"></a>
9
- <a href="https://github.com/ja-plus/stk-table-vue/stargazers"><img src="https://img.shields.io/github/stars/ja-plus/stk-table-vue.svg"></a>
10
- <a href="https://raw.githubusercontent.com/ja-plus/stk-table-vue/master/LICENSE"><img src="https://img.shields.io/npm/l/stk-table-vue"></a>
11
- <a href="https://github.com/ja-plus/stk-table-vue"><img src="https://img.shields.io/npm/types/stk-table-vue"></a>
12
- </p>
13
- </p>
14
-
15
- Stk Table Vue(Sticky Table) is a high-performance virtual list component based on Vue.
16
-
17
- Smooth performance with tens of thousands of rows
18
-
19
- Used for real-time data display, with data highlighting and dynamic effects.
20
-
21
- Support Vue3 and Vue2.7
22
-
23
-
24
- ## Documentation
25
- ### [Stk Table Vue Official](https://ja-plus.github.io/stk-table-vue/)
26
-
27
-
28
- ## Repo:
29
- - [Github](https://github.com/ja-plus/stk-table-vue)
30
- - [Gitee](https://gitee.com/japlus/stk-table-vue)
31
-
32
- ## Demo
33
- [<span style="font-size: 16px;font-weight: bold;">Online Demo in stackblitz</span>](https://stackblitz.com/edit/vitejs-vite-ad91hh?file=src%2FDemo%2Findex.vue)
34
-
35
- ## Usage
36
- > npm install stk-table-vue
37
-
38
- ```html
39
- <script setup>
40
- import { StkTable } from 'stk-table-vue'
41
- import { ref, useTemplateRef } from 'vue'
42
- const stkTableRef = ref<InstanceType<typeof StkTable>>();
43
- // or Vue 3.5 useTemplateRef
44
- const stkTableRef = useTemplateRef('stkTableRef');
45
-
46
- // highlight row
47
- stkTableRef.value.setHighlightDimRow([rowKey], {
48
- method: 'css' | 'animation', // default animation
49
- className: 'custom-class-name', // for method 'css'
50
- keyframe: [{ backgroundColor: '#aaa' }, { backgroundColor: '#222' }], // same as https://developer.mozilla.org/zh-CN/docs/Web/API/Web_Animations_API/Keyframe_Formats
51
- duration: 2000,
52
- });
53
- // highlight cell
54
- stkTableRef.value.setHighlightDimCell(rowKey, colDataIndex, {
55
- method: 'css' | 'animation',
56
- className: 'custom-class-name', // for method 'css'
57
- keyframe: [{ backgroundColor: '#aaa' }, { backgroundColor: '#222' }], // for method 'animation'
58
- duration: 2000,
59
- });
60
-
61
- const columns = [
62
- {title: 'name', dataIndex: 'name'},
63
- {title: 'age', dataIndex: 'age'},
64
- {title: 'address', dataIndex: 'address'},
65
- ];
66
-
67
- const dataSource = [
68
- {id: 1, name: 'John', age: 32, address: 'New York'},
69
- {id: 2, name: 'Jim', age: 42, address: 'London'},
70
- {id: 3, name: 'Joe', age: 52, address: 'Tokyo'},
71
- {id: 4, name: 'Jack', age: 62, address: 'Sydney'},
72
- {id: 5, name: 'Jill', age: 72, address: 'Paris'},
73
- ]
74
-
75
- </script>
76
-
77
- <template>
78
- <StkTable ref='stkTableRef' row-key="id" :data-source="dataSource" :columns="columns"></StkTable>
79
- </template>
80
-
81
- ```
82
-
83
- ### Vue2.7 Usage
84
- [Vue2.7 Usage](https://ja-plus.github.io/stk-table-vue/main/start/vue2-usage.html)
85
-
86
- ## API
87
- * [Props](https://ja-plus.github.io/stk-table-vue/main/api/table-props.html)
88
-
89
- * [Emits](https://ja-plus.github.io/stk-table-vue/main/api/emits.html)
90
-
91
- * [Slots](https://ja-plus.github.io/stk-table-vue/main/api/slots.html)
92
-
93
- * [Expose](https://ja-plus.github.io/stk-table-vue/main/api/expose.html)
94
-
95
- * [StkTableColumn: Define column type](https://ja-plus.github.io/stk-table-vue/main/api/stk-table-column.html)
96
-
97
- * [Highlight: setHighlightDimCell & setHighlightDimRow](https://ja-plus.github.io/stk-table-vue/main/api/expose.html#sethighlightdimcell)
98
-
99
-
100
- ### Example
101
- ```vue
102
- <template>
103
- <StkTable
104
- ref="stkTable"
105
- row-key="name"
106
- v-model:columns="columns"
107
- :style="{height:props.height}"
108
- theme='dark'
109
- height='200px'
110
- bordered="h"
111
- :row-height="28"
112
- :show-overflow="false"
113
- :show-header-overflow="false"
114
- :sort-remote="false"
115
- col-resizable
116
- header-drag
117
- virtual
118
- virtual-x
119
- no-data-full
120
- col-resizable
121
- auto-resize
122
- fixed-col-shadow
123
- :col-min-width="10"
124
- :headless="false"
125
- :data-source="dataSource"
126
- @current-change="onCurrentChange"
127
- @row-menu="onRowMenu"
128
- @header-row-menu="onHeaderRowMenu"
129
- @row-click="onRowClick"
130
- @row-dblclick="onRowDblclick"
131
- @sort-change="handleSortChange"
132
- @cell-click="onCellClick"
133
- @header-cell-click="onHeaderCellClick"
134
- @scroll="onTableScroll"
135
- @scroll-x="onTableScrollX"
136
- @col-order-change="onColOrderChange"
137
- />
138
- </template>
139
- <script setup>
140
- import { h, defineComponent } from 'vue';
141
- const columns = [
142
- {
143
- title: 'Name',
144
- dataIndex: 'name',
145
- fixed: 'left',
146
- width: '200px',
147
- headerClassName: 'my-th',
148
- className: 'my-td',
149
- sorter: true,
150
- customHeaderCell: function FunctionalComponent(props){
151
- return h(
152
- 'span',
153
- { style: 'overflow:hidden;text-overflow:ellipsis;white-space:nowrap' },
154
- props.col.title + '(render) text-overflow,',
155
- );
156
- },
157
- customCell: defineComponent({
158
- setup(){
159
- //...
160
- return () => <div></div> // vue jsx
161
- }
162
- })
163
- },
164
- ]
165
- </script>
166
- ```
167
-
168
- ## Compare
169
- Compare performance with other vue table [vue-table-compare](https://github.com/ja-plus/vue-table-compare)
170
-
171
-
172
- ## Other
173
- * `$*$`
1
+ <p align="center">
2
+ <a href="https://ja-plus.github.io/stk-table-vue/">
3
+ <img src="./docs-src/public/assets/logo.svg" width="152">
4
+ </a>
5
+ <h3 align='center'>Stk Table Vue</h3>
6
+ <p align="center">
7
+ <a href="https://www.npmjs.com/package/stk-table-vue"><img src="https://img.shields.io/npm/v/stk-table-vue"></a>
8
+ <a href="https://www.npmjs.com/package/stk-table-vue"><img src="https://img.shields.io/npm/dw/stk-table-vue"></a>
9
+ <a href="https://github.com/ja-plus/stk-table-vue/stargazers"><img src="https://img.shields.io/github/stars/ja-plus/stk-table-vue.svg"></a>
10
+ <a href="https://raw.githubusercontent.com/ja-plus/stk-table-vue/master/LICENSE"><img src="https://img.shields.io/npm/l/stk-table-vue"></a>
11
+ <a href="https://github.com/ja-plus/stk-table-vue"><img src="https://img.shields.io/npm/types/stk-table-vue"></a>
12
+ </p>
13
+ </p>
14
+
15
+ Stk Table Vue(Sticky Table) is a high-performance virtual list component based on Vue.
16
+
17
+ Smooth performance with tens of thousands of rows
18
+
19
+ Used for real-time data display, with data highlighting and dynamic effects.
20
+
21
+ Support Vue3 and Vue2.7
22
+
23
+
24
+ ## Documentation
25
+ ### [Stk Table Vue Official](https://ja-plus.github.io/stk-table-vue/)
26
+
27
+
28
+ ## Repo:
29
+ - [Github](https://github.com/ja-plus/stk-table-vue)
30
+ - [Gitee](https://gitee.com/japlus/stk-table-vue)
31
+
32
+ ## Demo
33
+ [<span style="font-size: 16px;font-weight: bold;">Online Demo in stackblitz</span>](https://stackblitz.com/edit/vitejs-vite-ad91hh?file=src%2FDemo%2Findex.vue)
34
+
35
+ ## Usage
36
+ > npm install stk-table-vue
37
+
38
+ ```html
39
+ <script setup>
40
+ import { StkTable } from 'stk-table-vue'
41
+ import { ref, useTemplateRef } from 'vue'
42
+ const stkTableRef = ref<InstanceType<typeof StkTable>>();
43
+ // or Vue 3.5 useTemplateRef
44
+ const stkTableRef = useTemplateRef('stkTableRef');
45
+
46
+ // highlight row
47
+ stkTableRef.value.setHighlightDimRow([rowKey], {
48
+ method: 'css' | 'animation', // default animation
49
+ className: 'custom-class-name', // for method 'css'
50
+ keyframe: [{ backgroundColor: '#aaa' }, { backgroundColor: '#222' }], // same as https://developer.mozilla.org/zh-CN/docs/Web/API/Web_Animations_API/Keyframe_Formats
51
+ duration: 2000,
52
+ });
53
+ // highlight cell
54
+ stkTableRef.value.setHighlightDimCell(rowKey, colDataIndex, {
55
+ method: 'css' | 'animation',
56
+ className: 'custom-class-name', // for method 'css'
57
+ keyframe: [{ backgroundColor: '#aaa' }, { backgroundColor: '#222' }], // for method 'animation'
58
+ duration: 2000,
59
+ });
60
+
61
+ const columns = [
62
+ {title: 'name', dataIndex: 'name'},
63
+ {title: 'age', dataIndex: 'age'},
64
+ {title: 'address', dataIndex: 'address'},
65
+ ];
66
+
67
+ const dataSource = [
68
+ {id: 1, name: 'John', age: 32, address: 'New York'},
69
+ {id: 2, name: 'Jim', age: 42, address: 'London'},
70
+ {id: 3, name: 'Joe', age: 52, address: 'Tokyo'},
71
+ {id: 4, name: 'Jack', age: 62, address: 'Sydney'},
72
+ {id: 5, name: 'Jill', age: 72, address: 'Paris'},
73
+ ]
74
+
75
+ </script>
76
+
77
+ <template>
78
+ <StkTable ref='stkTableRef' row-key="id" :data-source="dataSource" :columns="columns"></StkTable>
79
+ </template>
80
+
81
+ ```
82
+
83
+ ### Vue2.7 Usage
84
+ [Vue2.7 Usage](https://ja-plus.github.io/stk-table-vue/main/start/vue2-usage.html)
85
+
86
+ ## API
87
+ * [Props](https://ja-plus.github.io/stk-table-vue/main/api/table-props.html)
88
+
89
+ * [Emits](https://ja-plus.github.io/stk-table-vue/main/api/emits.html)
90
+
91
+ * [Slots](https://ja-plus.github.io/stk-table-vue/main/api/slots.html)
92
+
93
+ * [Expose](https://ja-plus.github.io/stk-table-vue/main/api/expose.html)
94
+
95
+ * [StkTableColumn: Define column type](https://ja-plus.github.io/stk-table-vue/main/api/stk-table-column.html)
96
+
97
+ * [Highlight: setHighlightDimCell & setHighlightDimRow](https://ja-plus.github.io/stk-table-vue/main/api/expose.html#sethighlightdimcell)
98
+
99
+
100
+ ### Example
101
+ ```vue
102
+ <template>
103
+ <StkTable
104
+ ref="stkTable"
105
+ row-key="name"
106
+ v-model:columns="columns"
107
+ :style="{height:props.height}"
108
+ theme='dark'
109
+ height='200px'
110
+ bordered="h"
111
+ :row-height="28"
112
+ :show-overflow="false"
113
+ :show-header-overflow="false"
114
+ :sort-remote="false"
115
+ col-resizable
116
+ header-drag
117
+ virtual
118
+ virtual-x
119
+ no-data-full
120
+ col-resizable
121
+ auto-resize
122
+ fixed-col-shadow
123
+ :col-min-width="10"
124
+ :headless="false"
125
+ :data-source="dataSource"
126
+ @current-change="onCurrentChange"
127
+ @row-menu="onRowMenu"
128
+ @header-row-menu="onHeaderRowMenu"
129
+ @row-click="onRowClick"
130
+ @row-dblclick="onRowDblclick"
131
+ @sort-change="handleSortChange"
132
+ @cell-click="onCellClick"
133
+ @header-cell-click="onHeaderCellClick"
134
+ @scroll="onTableScroll"
135
+ @scroll-x="onTableScrollX"
136
+ @col-order-change="onColOrderChange"
137
+ />
138
+ </template>
139
+ <script setup>
140
+ import { h, defineComponent } from 'vue';
141
+ const columns = [
142
+ {
143
+ title: 'Name',
144
+ dataIndex: 'name',
145
+ fixed: 'left',
146
+ width: '200px',
147
+ headerClassName: 'my-th',
148
+ className: 'my-td',
149
+ sorter: true,
150
+ customHeaderCell: function FunctionalComponent(props){
151
+ return h(
152
+ 'span',
153
+ { style: 'overflow:hidden;text-overflow:ellipsis;white-space:nowrap' },
154
+ props.col.title + '(render) text-overflow,',
155
+ );
156
+ },
157
+ customCell: defineComponent({
158
+ setup(){
159
+ //...
160
+ return () => <div></div> // vue jsx
161
+ }
162
+ })
163
+ },
164
+ ]
165
+ </script>
166
+ ```
167
+
168
+ ## Compare
169
+ Compare performance with other vue table [vue-table-compare](https://github.com/ja-plus/vue-table-compare)
170
+
171
+
172
+ ## Other
173
+ * `$*$`