@vtx/components 2.4.0 → 2.5.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/CHANGELOG.md +119 -0
- package/lib/vtx-combogrid/index.js +0 -1
- package/lib/vtx-combogrid/index.js.map +1 -1
- package/lib/vtx-datagrid/Alert.js +45 -0
- package/lib/vtx-datagrid/Alert.js.map +1 -0
- package/lib/vtx-datagrid/index.js +73 -22
- package/lib/vtx-datagrid/index.js.map +1 -1
- package/lib/vtx-datagrid/style/css.js +4 -0
- package/lib/vtx-datagrid/style/css.js.map +1 -1
- package/lib/vtx-datagrid/style/index.css +22 -1
- package/lib/vtx-datagrid/style/index.js +4 -0
- package/lib/vtx-datagrid/style/index.js.map +1 -1
- package/lib/vtx-datagrid/style/index.less +25 -1
- package/lib/vtx-form-layout/Card.js +83 -0
- package/lib/vtx-form-layout/Card.js.map +1 -0
- package/lib/vtx-form-layout/Divider.js +22 -0
- package/lib/vtx-form-layout/Divider.js.map +1 -0
- package/lib/vtx-form-layout/FormItem.js +26 -12
- package/lib/vtx-form-layout/FormItem.js.map +1 -1
- package/lib/vtx-form-layout/Pane.js +34 -0
- package/lib/vtx-form-layout/Pane.js.map +1 -0
- package/lib/vtx-form-layout/Row.js +25 -0
- package/lib/vtx-form-layout/Row.js.map +1 -0
- package/lib/vtx-form-layout/demo/Modal.css +42 -0
- package/lib/vtx-form-layout/demo/Modal.less +41 -0
- package/lib/vtx-form-layout/index.js +30 -7
- package/lib/vtx-form-layout/index.js.map +1 -1
- package/lib/vtx-form-layout/style/css.js +4 -0
- package/lib/vtx-form-layout/style/css.js.map +1 -1
- package/lib/vtx-form-layout/style/index.css +116 -0
- package/lib/vtx-form-layout/style/index.js +4 -0
- package/lib/vtx-form-layout/style/index.js.map +1 -1
- package/lib/vtx-form-layout/style/index.less +133 -0
- package/lib/vtx-image/Preview.js +3 -0
- package/lib/vtx-image/Preview.js.map +1 -1
- package/lib/vtx-input/index.js +13 -2
- package/lib/vtx-input/index.js.map +1 -1
- package/lib/vtx-input/style/index.css +7 -1
- package/lib/vtx-input/style/index.less +5 -1
- package/lib/vtx-modal/Title.js +32 -0
- package/lib/vtx-modal/Title.js.map +1 -0
- package/lib/vtx-modal/index.js +10 -0
- package/lib/vtx-modal/index.js.map +1 -1
- package/lib/vtx-modal/style/index.css +11 -0
- package/lib/vtx-modal/style/index.less +16 -0
- package/lib/vtx-page-layout/Basic.js +0 -1
- package/lib/vtx-page-layout/Basic.js.map +1 -1
- package/lib/vtx-page-layout/Pane.js +50 -0
- package/lib/vtx-page-layout/Pane.js.map +1 -0
- package/lib/vtx-page-layout/TableLayout.js +165 -0
- package/lib/vtx-page-layout/TableLayout.js.map +1 -0
- package/lib/vtx-page-layout/index.js +6 -0
- package/lib/vtx-page-layout/index.js.map +1 -1
- package/lib/vtx-page-layout/style/index.css +52 -3
- package/lib/vtx-page-layout/style/index.less +55 -1
- package/lib/vtx-rps-frame/index.js +1 -1
- package/lib/vtx-rps-frame/index.js.map +1 -1
- package/lib/vtx-scrollable-row/index.js +227 -0
- package/lib/vtx-scrollable-row/index.js.map +1 -0
- package/lib/vtx-scrollable-row/style/css.js +6 -0
- package/lib/vtx-scrollable-row/style/css.js.map +1 -0
- package/lib/vtx-scrollable-row/style/index.css +111 -0
- package/lib/vtx-scrollable-row/style/index.js +6 -0
- package/lib/vtx-scrollable-row/style/index.js.map +1 -0
- package/lib/vtx-scrollable-row/style/index.less +111 -0
- package/lib/vtx-search/VtxCol.js +2 -2
- package/lib/vtx-search/VtxCol.js.map +1 -1
- package/lib/vtx-search/VtxRow.js +6 -3
- package/lib/vtx-search/VtxRow.js.map +1 -1
- package/lib/vtx-search/index.js +42 -38
- package/lib/vtx-search/index.js.map +1 -1
- package/lib/vtx-search/style/css.js +2 -0
- package/lib/vtx-search/style/css.js.map +1 -1
- package/lib/vtx-search/style/index.css +25 -24
- package/lib/vtx-search/style/index.js +2 -0
- package/lib/vtx-search/style/index.js.map +1 -1
- package/lib/vtx-search/style/index.less +27 -25
- package/lib/vtx-select/index.js +2 -1
- package/lib/vtx-select/index.js.map +1 -1
- package/lib/vtx-split-pane/SplitPane.js +1 -0
- package/lib/vtx-split-pane/SplitPane.js.map +1 -1
- package/lib/vtx-statistics-column/Back.js +29 -0
- package/lib/vtx-statistics-column/Back.js.map +1 -0
- package/lib/vtx-statistics-column/Item.js +68 -0
- package/lib/vtx-statistics-column/Item.js.map +1 -0
- package/lib/vtx-statistics-column/Total.js +68 -0
- package/lib/vtx-statistics-column/Total.js.map +1 -0
- package/lib/vtx-statistics-column/context.js +12 -0
- package/lib/vtx-statistics-column/context.js.map +1 -0
- package/lib/vtx-statistics-column/index.js +63 -0
- package/lib/vtx-statistics-column/index.js.map +1 -0
- package/lib/vtx-statistics-column/style/css.js +4 -0
- package/lib/vtx-statistics-column/style/css.js.map +1 -0
- package/lib/vtx-statistics-column/style/index.css +55 -0
- package/lib/vtx-statistics-column/style/index.js +4 -0
- package/lib/vtx-statistics-column/style/index.js.map +1 -0
- package/lib/vtx-statistics-column/style/index.less +61 -0
- package/lib/vtx-upload/index.js +3 -3
- package/lib/vtx-upload/index.js.map +1 -1
- package/lib/vtx-ztree/style/index.css +5 -5
- package/lib/vtx-ztree/style/index.less +5 -5
- package/lib/vtx-ztree-select/index.js +4 -8
- package/lib/vtx-ztree-select/index.js.map +1 -1
- package/lib/vtx-ztree-select/style/index.css +20 -1
- package/lib/vtx-ztree-select/style/index.less +28 -2
- package/package.json +3 -2
package/CHANGELOG.md
CHANGED
|
@@ -1,3 +1,117 @@
|
|
|
1
|
+
## [2.5.1](https://git.cloudhw.cn:3443/front-end/react-components/compare/2.5.0...2.5.1) (2021-12-01)
|
|
2
|
+
|
|
3
|
+
|
|
4
|
+
### ✨ Features
|
|
5
|
+
|
|
6
|
+
* 数据表格VtxDatagrid单元格无数据时默认显示'-' ([3c68da7](https://git.cloudhw.cn:3443/front-end/react-components/commit/3c68da7)) by: **gongjinhua**
|
|
7
|
+
* 文本域VtxInput.TextArea最大输入长度字段显示位置调整 ([4da91a0](https://git.cloudhw.cn:3443/front-end/react-components/commit/4da91a0)) by: **gongjinhua**
|
|
8
|
+
|
|
9
|
+
|
|
10
|
+
### 🎫 Chores
|
|
11
|
+
|
|
12
|
+
* 安装less-plugin-npm-import编译less [@import](https://git.cloudhw.cn:3443/import)导入npm文件 ([fd9aa70](https://git.cloudhw.cn:3443/front-end/react-components/commit/fd9aa70)) by: **gongjinhua**
|
|
13
|
+
|
|
14
|
+
|
|
15
|
+
### 📝 Documentation
|
|
16
|
+
|
|
17
|
+
* 左右布局示例外部容器设置默认宽度1200px ([e46da59](https://git.cloudhw.cn:3443/front-end/react-components/commit/e46da59)) by: **gongjinhua**
|
|
18
|
+
* 表单布局示例修改 ([8032749](https://git.cloudhw.cn:3443/front-end/react-components/commit/8032749)) by: **gongjinhua**
|
|
19
|
+
* 页面布局左右布局示例设置容器样式 ([addc410](https://git.cloudhw.cn:3443/front-end/react-components/commit/addc410)) by: **gongjinhua**
|
|
20
|
+
|
|
21
|
+
|
|
22
|
+
|
|
23
|
+
# [2.5.0](https://git.cloudhw.cn:3443/front-end/react-components/compare/2.4.2...2.5.0) (2021-11-23)
|
|
24
|
+
|
|
25
|
+
|
|
26
|
+
### ✨ Features
|
|
27
|
+
|
|
28
|
+
* 上传附近VtxUpload支持自定义headers和beforeUpload回调中添加file参数 ([1f41160](https://git.cloudhw.cn:3443/front-end/react-components/commit/1f41160)) by: **gongjinhua**
|
|
29
|
+
* 下拉树VtxZtreeSelect清除图标样式和Antd样式统一 ([26befd7](https://git.cloudhw.cn:3443/front-end/react-components/commit/26befd7)) by: **gongjinhua**
|
|
30
|
+
* 下拉选VtxSelect默认支持清除 ([76e54bf](https://git.cloudhw.cn:3443/front-end/react-components/commit/76e54bf)) by: **gongjinhua**
|
|
31
|
+
* 报表VtxRpsFrame属性data_param支持Array ([0b590ef](https://git.cloudhw.cn:3443/front-end/react-components/commit/0b590ef)) by: **gongjinhua**
|
|
32
|
+
* 数据表格VtxDatagrid新增统计列 ([f3f5477](https://git.cloudhw.cn:3443/front-end/react-components/commit/f3f5477)) by: **gongjinhua**
|
|
33
|
+
* 数据表格VtxDatagrid添加indexFixed属性 ([5492760](https://git.cloudhw.cn:3443/front-end/react-components/commit/5492760)) by: **gongjinhua**
|
|
34
|
+
* 文本VtxInput默认过滤两边空格 ([bd9ae00](https://git.cloudhw.cn:3443/front-end/react-components/commit/bd9ae00)) by: **gongjinhua**
|
|
35
|
+
* 文本框VtxInput设置autocomplete为false关闭自动完成 ([549c638](https://git.cloudhw.cn:3443/front-end/react-components/commit/549c638)) by: **gongjinhua**
|
|
36
|
+
* 新增可横向滚动列VtxScrollableRow ([3920852](https://git.cloudhw.cn:3443/front-end/react-components/commit/3920852)) by: **gongjinhua**
|
|
37
|
+
* 新增统计栏VtxStatisticsColumn ([f7a615b](https://git.cloudhw.cn:3443/front-end/react-components/commit/f7a615b)) by: **gongjinhua**
|
|
38
|
+
* 查询布局VtxSearch样式修改 ([4d93dfd](https://git.cloudhw.cn:3443/front-end/react-components/commit/4d93dfd)) by: **gongjinhua**
|
|
39
|
+
* 树ztree搜索框间距调整为12px ([28f857c](https://git.cloudhw.cn:3443/front-end/react-components/commit/28f857c)) by: **gongjinhua**
|
|
40
|
+
* 模态框VtxModal上下内间距调整为20px ([31a2ff2](https://git.cloudhw.cn:3443/front-end/react-components/commit/31a2ff2)) by: **gongjinhua**
|
|
41
|
+
* 模态框VtxModal新增大小配置 ([de1eaa0](https://git.cloudhw.cn:3443/front-end/react-components/commit/de1eaa0)) by: **gongjinhua**
|
|
42
|
+
* 模态框新增标题VtxModal.Title组件 ([2dafc6a](https://git.cloudhw.cn:3443/front-end/react-components/commit/2dafc6a)) by: **gongjinhua**
|
|
43
|
+
* 表单布局VtxFormLayout修改 ([0ea5e88](https://git.cloudhw.cn:3443/front-end/react-components/commit/0ea5e88)) by: **gongjinhua**
|
|
44
|
+
* 表单布局VtxFormLayout布局模式修改 ([46c6cc8](https://git.cloudhw.cn:3443/front-end/react-components/commit/46c6cc8)) by: **gongjinhua**
|
|
45
|
+
* 表单布局VtxFormLayout标签名称后去除冒号":"显示 ([a9e2cdc](https://git.cloudhw.cn:3443/front-end/react-components/commit/a9e2cdc)) by: **gongjinhua**
|
|
46
|
+
* 表单组件VtxFormLayout标签分组和窗格分组 ([59f0495](https://git.cloudhw.cn:3443/front-end/react-components/commit/59f0495)) by: **gongjinhua**
|
|
47
|
+
* 表格VtxDatagrid单元格去除选中背景色 ([f5fade9](https://git.cloudhw.cn:3443/front-end/react-components/commit/f5fade9)) by: **gongjinhua**
|
|
48
|
+
* 表格VtxDatagrid空数据时图标修改,表格样式调整 ([b7a8888](https://git.cloudhw.cn:3443/front-end/react-components/commit/b7a8888)) by: **gongjinhua**
|
|
49
|
+
* 页面布局VtxPageLayout新增左右布局窗格 ([184b7e5](https://git.cloudhw.cn:3443/front-end/react-components/commit/184b7e5)) by: **gongjinhua**
|
|
50
|
+
* 页面布局VtxPageLayout添加统计表格布局 ([44c9f81](https://git.cloudhw.cn:3443/front-end/react-components/commit/44c9f81)) by: **gongjinhua**
|
|
51
|
+
* 页面布局新增CRUD布局 ([f6bb676](https://git.cloudhw.cn:3443/front-end/react-components/commit/f6bb676)) by: **gongjinhua**
|
|
52
|
+
|
|
53
|
+
|
|
54
|
+
### 🎫 Chores
|
|
55
|
+
|
|
56
|
+
* release v2.5.0 ([d7de29b](https://git.cloudhw.cn:3443/front-end/react-components/commit/d7de29b)) by: **gongjinhua**
|
|
57
|
+
* 设置antd主题样式border-radius-base为2px ([bb88a79](https://git.cloudhw.cn:3443/front-end/react-components/commit/bb88a79)) by: **gongjinhua**
|
|
58
|
+
* 调整demo内样式 ([47e2145](https://git.cloudhw.cn:3443/front-end/react-components/commit/47e2145)) by: **gongjinhua**
|
|
59
|
+
|
|
60
|
+
|
|
61
|
+
### 🐛 Bug Fixes
|
|
62
|
+
|
|
63
|
+
* 修复分割面板VtxSplitPane组件销毁后onresize监听事件仍存在导致报错的问题 ([08186c4](https://git.cloudhw.cn:3443/front-end/react-components/commit/08186c4)) by: **gongjinhua**
|
|
64
|
+
* 暂时使用本地变量打包,后续改成antd主题文件中获取 ([b2bf089](https://git.cloudhw.cn:3443/front-end/react-components/commit/b2bf089)) by: **gongjinhua**
|
|
65
|
+
|
|
66
|
+
|
|
67
|
+
### 📝 Documentation
|
|
68
|
+
|
|
69
|
+
* 完善统计栏VtxStatisticsColumn文档 ([bce60c9](https://git.cloudhw.cn:3443/front-end/react-components/commit/bce60c9)) by: **gongjinhua**
|
|
70
|
+
* 数据表格VtxDatagrid添加固定列示例 ([30b9753](https://git.cloudhw.cn:3443/front-end/react-components/commit/30b9753)) by: **gongjinhua**
|
|
71
|
+
* 样式调整 ([2668d35](https://git.cloudhw.cn:3443/front-end/react-components/commit/2668d35)) by: **gongjinhua**
|
|
72
|
+
* 添加富文本空值检验示例 ([00f31c7](https://git.cloudhw.cn:3443/front-end/react-components/commit/00f31c7)) by: **gongjinhua**
|
|
73
|
+
* 添加模态框VtxModal大小配置 ([71b847d](https://git.cloudhw.cn:3443/front-end/react-components/commit/71b847d)) by: **gongjinhua**
|
|
74
|
+
* 版本号修改为2.5.0 ([081963b](https://git.cloudhw.cn:3443/front-end/react-components/commit/081963b)) by: **gongjinhua**
|
|
75
|
+
* 统计栏VtxStatisticsColumn归类到数据显示中 ([4a856aa](https://git.cloudhw.cn:3443/front-end/react-components/commit/4a856aa)) by: **gongjinhua**
|
|
76
|
+
* 表单布局文档示例中模态框宽度使用VtxModal.size ([8f5c0aa](https://git.cloudhw.cn:3443/front-end/react-components/commit/8f5c0aa)) by: **gongjinhua**
|
|
77
|
+
* 表单布局示例文字修改 ([4c6bf94](https://git.cloudhw.cn:3443/front-end/react-components/commit/4c6bf94)) by: **gongjinhua**
|
|
78
|
+
* 表格列设置示例修改 ([2a5c92c](https://git.cloudhw.cn:3443/front-end/react-components/commit/2a5c92c)) by: **gongjinhua**
|
|
79
|
+
|
|
80
|
+
|
|
81
|
+
|
|
82
|
+
## [2.4.2](https://git.cloudhw.cn:3443/front-end/react-components/compare/2.4.1...2.4.2) (2021-10-25)
|
|
83
|
+
|
|
84
|
+
|
|
85
|
+
### 🎫 Chores
|
|
86
|
+
|
|
87
|
+
* release v2.4.2 ([f70e16f](https://git.cloudhw.cn:3443/front-end/react-components/commit/f70e16f)) by: **gongjinhua**
|
|
88
|
+
|
|
89
|
+
|
|
90
|
+
### 🐛 Bug Fixes
|
|
91
|
+
|
|
92
|
+
* 修复VtxImage放大预览时图片路径不全导致图片显示错误的问题 ([e77a582](https://git.cloudhw.cn:3443/front-end/react-components/commit/e77a582)) by: **gongjinhua**
|
|
93
|
+
|
|
94
|
+
|
|
95
|
+
|
|
96
|
+
## [2.4.1](https://git.cloudhw.cn:3443/front-end/react-components/compare/2.4.0...2.4.1) (2021-10-22)
|
|
97
|
+
|
|
98
|
+
|
|
99
|
+
### ✨ Features
|
|
100
|
+
|
|
101
|
+
* 数据表格VtxDatagrid列设置隐藏新增显示列visibleColumnKeys字段 ([3d5d037](https://git.cloudhw.cn:3443/front-end/react-components/commit/3d5d037)) by: **gongjinhua**
|
|
102
|
+
|
|
103
|
+
|
|
104
|
+
### 🎫 Chores
|
|
105
|
+
|
|
106
|
+
* release v2.4.1 ([83276a3](https://git.cloudhw.cn:3443/front-end/react-components/commit/83276a3)) by: **gongjinhua**
|
|
107
|
+
|
|
108
|
+
|
|
109
|
+
### 🐛 Bug Fixes
|
|
110
|
+
|
|
111
|
+
* 修复VtxCombogrid结合Form使用时ref指向混乱的问题 ([b0f116f](https://git.cloudhw.cn:3443/front-end/react-components/commit/b0f116f)) by: **gongjinhua**
|
|
112
|
+
|
|
113
|
+
|
|
114
|
+
|
|
1
115
|
# [2.4.0](https://git.cloudhw.cn:3443/front-end/react-components/compare/2.3.4...2.4.0) (2021-09-18)
|
|
2
116
|
|
|
3
117
|
|
|
@@ -6,6 +120,11 @@
|
|
|
6
120
|
* 新增VtxSignature签名组件 ([9019271](https://git.cloudhw.cn:3443/front-end/react-components/commit/9019271)) by: **gongjinhua**
|
|
7
121
|
|
|
8
122
|
|
|
123
|
+
### 🎫 Chores
|
|
124
|
+
|
|
125
|
+
* release v2.4.0 ([353075c](https://git.cloudhw.cn:3443/front-end/react-components/commit/353075c)) by: **gongjinhua**
|
|
126
|
+
|
|
127
|
+
|
|
9
128
|
|
|
10
129
|
## [2.3.4](https://git.cloudhw.cn:3443/front-end/react-components/compare/2.3.3...2.3.4) (2021-09-16)
|
|
11
130
|
|
|
@@ -97,7 +97,6 @@ function VtxCombogrid(props, ref) {
|
|
|
97
97
|
},
|
|
98
98
|
overlayClassName: "".concat(prefixCls, "-dropdown")
|
|
99
99
|
}, /*#__PURE__*/_react["default"].createElement(_input["default"], {
|
|
100
|
-
ref: ref,
|
|
101
100
|
value: value,
|
|
102
101
|
allowClear: allowClear,
|
|
103
102
|
onClick: function onClick() {
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["vtx-combogrid/index.jsx"],"names":["VtxCombogrid","props","ref","selectedRowKeys","setSelectedRowKeys","visible","setVisible","comboRef","className","style","placeholder","prefixCls","value","allowClear","defaultSelectedRowKeys","rest","join","reset","current","clear","e","target","onChange","React","forwardRef","propTypes","PropTypes","string","bool","object","array"],"mappings":";;;;;;;;;AAAA;;AAEA;;AACA;;AACA;;AACA;;;;;;;;;;;;;;;;;;;;;;;;;;AAEA,SAASA,YAAT,CAAsBC,KAAtB,EAA6BC,GAA7B,EAAkC;AAAA,kBACgB,qBAAS,YAAM;AACzD,WAAO,EAAP;AACH,GAF6C,CADhB;AAAA;AAAA,MACvBC,eADuB;AAAA,MACNC,kBADM;;AAAA,mBAIA,qBAAS,KAAT,CAJA;AAAA;AAAA,MAIvBC,OAJuB;AAAA,MAIdC,UAJc;;AAK9B,MAAMC,QAAQ,GAAG,oBAAjB;;AAL8B,MAO1BC,SAP0B,GAe1BP,KAf0B,CAO1BO,SAP0B;AAAA,MAQ1BC,KAR0B,GAe1BR,KAf0B,CAQ1BQ,KAR0B;AAAA,MAS1BC,WAT0B,GAe1BT,KAf0B,CAS1BS,WAT0B;AAAA,yBAe1BT,KAf0B,CAU1BU,SAV0B;AAAA,MAU1BA,SAV0B,iCAUd,eAVc;AAAA,MAW1BC,KAX0B,GAe1BX,KAf0B,CAW1BW,KAX0B;AAAA,0BAe1BX,KAf0B,CAY1BY,UAZ0B;AAAA,MAY1BA,UAZ0B,kCAYb,IAZa;AAAA,8BAe1BZ,KAf0B,CAa1BE,eAb0B;AAAA,MAaTW,sBAbS,sCAagB,EAbhB;AAAA,MAcvBC,IAduB,4BAe1Bd,KAf0B;;AAiB9B,wBAAU,YAAM;AACZG,IAAAA,kBAAkB,CAACU,sBAAD,CAAlB;AACH,GAFD,EAEG,CAACA,sBAAsB,CAACE,IAAvB,CAA4B,GAA5B,CAAD,CAFH,EAjB8B,CAqB9B;;AACA,kCAAoBd,GAApB,EAAyB;AAAA,WAAO;AAC5B;AACAe,MAAAA,KAF4B,mBAEpB;AACJV,QAAAA,QAAQ,CAACW,OAAT,IAAoBX,QAAQ,CAACW,OAAT,CAAiBC,KAAjB,EAApB;AACH;AAJ2B,KAAP;AAAA,GAAzB;AAOA,sBACI,gCAAC,mBAAD;AACI,IAAA,OAAO,eACH,gCAAC,qBAAD,eACQJ,IADR;AAEI,MAAA,eAAe,EAAEZ,eAFrB;AAGI,MAAA,sBAAsB,EAAEW,sBAH5B;AAII,MAAA,kBAAkB,EAAEV,kBAJxB;AAKI,MAAA,iBAAiB,EAAEE,UALvB;AAMI,MAAA,SAAS,EAAEK,SANf;AAOI,MAAA,mBAAmB,EAAEJ;AAPzB,OAFR;AAYI,IAAA,SAAS,EAAC,YAZd;AAaI,IAAA,OAAO,EAAC,OAbZ;AAcI,IAAA,OAAO,EAAEF,OAdb;AAeI,IAAA,eAAe,EAAE,yBAAAA,OAAO;AAAA,aAAIC,UAAU,CAACD,OAAD,CAAd;AAAA,KAf5B;AAgBI,IAAA,gBAAgB,YAAKM,SAAL;AAhBpB,kBAkBI,gCAAC,iBAAD;AACI,IAAA,
|
|
1
|
+
{"version":3,"sources":["vtx-combogrid/index.jsx"],"names":["VtxCombogrid","props","ref","selectedRowKeys","setSelectedRowKeys","visible","setVisible","comboRef","className","style","placeholder","prefixCls","value","allowClear","defaultSelectedRowKeys","rest","join","reset","current","clear","e","target","onChange","React","forwardRef","propTypes","PropTypes","string","bool","object","array"],"mappings":"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","sourcesContent":["import React, { useState, useEffect, useRef, useImperativeHandle } from 'react';\n\nimport Input from 'antd/es/input';\nimport Popover from 'antd/es/popover';\nimport PropTypes from 'prop-types';\nimport Combogrid from './Combogrid';\n\nfunction VtxCombogrid(props, ref) {\n const [selectedRowKeys, setSelectedRowKeys] = useState(() => {\n return [];\n });\n const [visible, setVisible] = useState(false);\n const comboRef = useRef();\n const {\n className,\n style,\n placeholder,\n prefixCls = 'vtx-combogrid',\n value,\n allowClear = true,\n selectedRowKeys: defaultSelectedRowKeys = [],\n ...rest\n } = props;\n\n useEffect(() => {\n setSelectedRowKeys(defaultSelectedRowKeys);\n }, [defaultSelectedRowKeys.join(',')]);\n\n // 暴露给父组件使用\n useImperativeHandle(ref, () => ({\n // 重置\n reset() {\n comboRef.current && comboRef.current.clear();\n },\n }));\n\n return (\n <Popover\n content={\n <Combogrid\n {...rest}\n selectedRowKeys={selectedRowKeys}\n defaultSelectedRowKeys={defaultSelectedRowKeys}\n setSelectedRowKeys={setSelectedRowKeys}\n setPopoverVisible={setVisible}\n prefixCls={prefixCls}\n wrappedComponentRef={comboRef}\n />\n }\n placement=\"bottomLeft\"\n trigger=\"click\"\n visible={visible}\n onVisibleChange={visible => setVisible(visible)}\n overlayClassName={`${prefixCls}-dropdown`}\n >\n <Input\n value={value}\n allowClear={allowClear}\n onClick={() => setVisible(true)}\n onChange={e => {\n // 只对清空产生值的变化做处理\n if (!e.target.value) {\n rest.onChange && rest.onChange();\n setSelectedRowKeys([]);\n }\n }}\n className={className}\n style={style}\n placeholder={placeholder}\n />\n </Popover>\n );\n}\n\nexport default React.forwardRef(VtxCombogrid);\n\nVtxCombogrid.propTypes = {\n prefixCls: PropTypes.string,\n placeholder: PropTypes.string,\n value: PropTypes.string,\n allowClear: PropTypes.bool,\n className: PropTypes.string,\n style: PropTypes.object,\n selectedRowKeys: PropTypes.array,\n};\n"],"file":"index.js"}
|
|
@@ -0,0 +1,45 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
|
|
3
|
+
Object.defineProperty(exports, "__esModule", {
|
|
4
|
+
value: true
|
|
5
|
+
});
|
|
6
|
+
exports["default"] = void 0;
|
|
7
|
+
|
|
8
|
+
var _react = _interopRequireDefault(require("react"));
|
|
9
|
+
|
|
10
|
+
var _alert = _interopRequireDefault(require("antd/es/alert"));
|
|
11
|
+
|
|
12
|
+
var _propTypes = _interopRequireDefault(require("prop-types"));
|
|
13
|
+
|
|
14
|
+
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { "default": obj }; }
|
|
15
|
+
|
|
16
|
+
function TableAlert(_ref) {
|
|
17
|
+
var prefixCls = _ref.prefixCls,
|
|
18
|
+
_ref$selectedRowKeys = _ref.selectedRowKeys,
|
|
19
|
+
selectedRowKeys = _ref$selectedRowKeys === void 0 ? [] : _ref$selectedRowKeys,
|
|
20
|
+
claerRowSelection = _ref.claerRowSelection;
|
|
21
|
+
|
|
22
|
+
var message = /*#__PURE__*/_react["default"].createElement("div", {
|
|
23
|
+
className: "".concat(prefixCls, "-alert-message")
|
|
24
|
+
}, /*#__PURE__*/_react["default"].createElement("span", {
|
|
25
|
+
className: "".concat(prefixCls, "-alert-info-content")
|
|
26
|
+
}, "\u5DF2\u9009\u62E9", /*#__PURE__*/_react["default"].createElement("strong", null, selectedRowKeys.length), "\u9879"), /*#__PURE__*/_react["default"].createElement("a", {
|
|
27
|
+
className: "".concat(prefixCls, "-alert-info-option"),
|
|
28
|
+
onClick: claerRowSelection
|
|
29
|
+
}, "\u6E05\u7A7A\u9009\u62E9"));
|
|
30
|
+
|
|
31
|
+
return /*#__PURE__*/_react["default"].createElement(_alert["default"], {
|
|
32
|
+
type: "info",
|
|
33
|
+
showIcon: true,
|
|
34
|
+
message: message
|
|
35
|
+
});
|
|
36
|
+
}
|
|
37
|
+
|
|
38
|
+
var _default = TableAlert;
|
|
39
|
+
exports["default"] = _default;
|
|
40
|
+
TableAlert.propTypes = {
|
|
41
|
+
prefixCls: _propTypes["default"].string,
|
|
42
|
+
selectedRowKeys: _propTypes["default"].array,
|
|
43
|
+
claerRowSelection: _propTypes["default"].func
|
|
44
|
+
};
|
|
45
|
+
//# sourceMappingURL=Alert.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["vtx-datagrid/Alert.jsx"],"names":["TableAlert","prefixCls","selectedRowKeys","claerRowSelection","message","length","propTypes","PropTypes","string","array","func"],"mappings":";;;;;;;AAAA;;AACA;;AACA;;;;AAEA,SAASA,UAAT,OAA4E;AAAA,MAAtDC,SAAsD,QAAtDA,SAAsD;AAAA,kCAA3CC,eAA2C;AAAA,MAA3CA,eAA2C,qCAAzB,EAAyB;AAAA,MAArBC,iBAAqB,QAArBA,iBAAqB;;AACxE,MAAMC,OAAO,gBACT;AAAK,IAAA,SAAS,YAAKH,SAAL;AAAd,kBACI;AAAM,IAAA,SAAS,YAAKA,SAAL;AAAf,wCACO,gDAASC,eAAe,CAACG,MAAzB,CADP,WADJ,eAII;AAAG,IAAA,SAAS,YAAKJ,SAAL,uBAAZ;AAAgD,IAAA,OAAO,EAAEE;AAAzD,gCAJJ,CADJ;;AAUA,sBAAO,gCAAC,iBAAD;AAAO,IAAA,IAAI,EAAC,MAAZ;AAAmB,IAAA,QAAQ,MAA3B;AAA4B,IAAA,OAAO,EAAEC;AAArC,IAAP;AACH;;eAEcJ,U;;AAEfA,UAAU,CAACM,SAAX,GAAuB;AACnBL,EAAAA,SAAS,EAAEM,sBAAUC,MADF;AAEnBN,EAAAA,eAAe,EAAEK,sBAAUE,KAFR;AAGnBN,EAAAA,iBAAiB,EAAEI,sBAAUG;AAHV,CAAvB","sourcesContent":["import React from 'react';\nimport Alert from 'antd/es/alert';\nimport PropTypes from 'prop-types';\n\nfunction TableAlert({ prefixCls, selectedRowKeys = [], claerRowSelection }) {\n const message = (\n <div className={`${prefixCls}-alert-message`}>\n <span className={`${prefixCls}-alert-info-content`}>\n 已选择<strong>{selectedRowKeys.length}</strong>项\n </span>\n <a className={`${prefixCls}-alert-info-option`} onClick={claerRowSelection}>\n 清空选择\n </a>\n </div>\n );\n return <Alert type=\"info\" showIcon message={message} />;\n}\n\nexport default TableAlert;\n\nTableAlert.propTypes = {\n prefixCls: PropTypes.string,\n selectedRowKeys: PropTypes.array,\n claerRowSelection: PropTypes.func,\n};\n"],"file":"Alert.js"}
|
|
@@ -19,10 +19,14 @@ var _dropdown = _interopRequireDefault(require("antd/es/dropdown"));
|
|
|
19
19
|
|
|
20
20
|
var _menu = _interopRequireDefault(require("antd/es/menu"));
|
|
21
21
|
|
|
22
|
+
var _empty = _interopRequireDefault(require("antd/es/empty"));
|
|
23
|
+
|
|
22
24
|
var _classnames2 = _interopRequireDefault(require("classnames"));
|
|
23
25
|
|
|
24
26
|
var _propTypes = _interopRequireDefault(require("prop-types"));
|
|
25
27
|
|
|
28
|
+
var _Alert = _interopRequireDefault(require("./Alert"));
|
|
29
|
+
|
|
26
30
|
var _ColumnSetting = _interopRequireDefault(require("./ColumnSetting"));
|
|
27
31
|
|
|
28
32
|
var _ResizeableTitle = _interopRequireDefault(require("./ResizeableTitle"));
|
|
@@ -72,7 +76,7 @@ function _iterableToArrayLimit(arr, i) { if (typeof Symbol === "undefined" || !(
|
|
|
72
76
|
function _arrayWithHoles(arr) { if (Array.isArray(arr)) return arr; }
|
|
73
77
|
|
|
74
78
|
function VtxDatagrid(props) {
|
|
75
|
-
var _dataSource2, _classnames;
|
|
79
|
+
var _rest$rowSelection, _rest$rowSelection2, _dataSource2, _classnames, _rest$rowSelection3;
|
|
76
80
|
|
|
77
81
|
var _useSet = (0, _useSet3["default"])({
|
|
78
82
|
// 显示列
|
|
@@ -83,7 +87,7 @@ function VtxDatagrid(props) {
|
|
|
83
87
|
columnSettingOptions: [],
|
|
84
88
|
datagridId: "vtx-datagrid-".concat(new Date().getTime()),
|
|
85
89
|
scrollY: null,
|
|
86
|
-
size: '
|
|
90
|
+
size: 'middle'
|
|
87
91
|
}),
|
|
88
92
|
_useSet2 = _slicedToArray(_useSet, 2),
|
|
89
93
|
state = _useSet2[0],
|
|
@@ -94,7 +98,11 @@ function VtxDatagrid(props) {
|
|
|
94
98
|
columnSettingOptions = state.columnSettingOptions,
|
|
95
99
|
datagridId = state.datagridId,
|
|
96
100
|
scrollY = state.scrollY,
|
|
97
|
-
size = state.size;
|
|
101
|
+
size = state.size; // 列设置提示高度
|
|
102
|
+
|
|
103
|
+
var alertHeight = (0, _react.useRef)(0); // 工具栏高度
|
|
104
|
+
|
|
105
|
+
var toolbarHeight = (0, _react.useRef)(0);
|
|
98
106
|
|
|
99
107
|
var _props$prefixCls = props.prefixCls,
|
|
100
108
|
prefixCls = _props$prefixCls === void 0 ? 'vtx-datagrid' : _props$prefixCls,
|
|
@@ -108,11 +116,16 @@ function VtxDatagrid(props) {
|
|
|
108
116
|
refreshIconVisible = _props$refreshIconVis === void 0 ? true : _props$refreshIconVis,
|
|
109
117
|
hideColumnSetting = props.hideColumnSetting,
|
|
110
118
|
hideColumnHeight = props.hideColumnHeight,
|
|
119
|
+
visibleColumnKeys = props.visibleColumnKeys,
|
|
111
120
|
defaultVisibleColumnKeys = props.defaultVisibleColumnKeys,
|
|
112
121
|
onVisibleColumnsChange = props.onVisibleColumnsChange,
|
|
113
122
|
onRefresh = props.onRefresh,
|
|
114
123
|
_props$indexColumn = props.indexColumn,
|
|
115
124
|
indexColumn = _props$indexColumn === void 0 ? true : _props$indexColumn,
|
|
125
|
+
_props$indexFixed = props.indexFixed,
|
|
126
|
+
indexFixed = _props$indexFixed === void 0 ? false : _props$indexFixed,
|
|
127
|
+
_props$bordered = props.bordered,
|
|
128
|
+
bordered = _props$bordered === void 0 ? true : _props$bordered,
|
|
116
129
|
_props$indexTitle = props.indexTitle,
|
|
117
130
|
indexTitle = _props$indexTitle === void 0 ? '序号' : _props$indexTitle,
|
|
118
131
|
_props$startIndex = props.startIndex,
|
|
@@ -124,7 +137,11 @@ function VtxDatagrid(props) {
|
|
|
124
137
|
columnResizable = props.columnResizable,
|
|
125
138
|
className = props.className,
|
|
126
139
|
style = props.style,
|
|
127
|
-
|
|
140
|
+
_props$emptyText = props.emptyText,
|
|
141
|
+
emptyText = _props$emptyText === void 0 ? '暂无数据' : _props$emptyText,
|
|
142
|
+
claerRowSelection = props.claerRowSelection,
|
|
143
|
+
searchCollapseEvent$ = props.searchCollapseEvent$,
|
|
144
|
+
rest = _objectWithoutProperties(props, ["prefixCls", "toolbar", "toolbarClassName", "toolbarTilte", "buttonGroup", "refreshIconVisible", "hideColumnSetting", "hideColumnHeight", "visibleColumnKeys", "defaultVisibleColumnKeys", "onVisibleColumnsChange", "onRefresh", "indexColumn", "indexFixed", "bordered", "indexTitle", "startIndex", "autoFit", "headFootHeight", "columnResizable", "className", "style", "emptyText", "claerRowSelection", "searchCollapseEvent$"]);
|
|
128
145
|
|
|
129
146
|
(0, _react.useEffect)(function () {
|
|
130
147
|
// componentDidMount
|
|
@@ -143,7 +160,20 @@ function VtxDatagrid(props) {
|
|
|
143
160
|
if (autoFit) {
|
|
144
161
|
calculateHeight();
|
|
145
162
|
}
|
|
146
|
-
}, [
|
|
163
|
+
}, [(((_rest$rowSelection = rest.rowSelection) === null || _rest$rowSelection === void 0 ? void 0 : _rest$rowSelection.selectedRowKeys) || []).join(',')]); // 只有被TableLayout.Page包裹时才会存在searchCollapseEvent$这个参数
|
|
164
|
+
|
|
165
|
+
if (searchCollapseEvent$) {
|
|
166
|
+
// eslint-disable-next-line react/prop-types
|
|
167
|
+
searchCollapseEvent$.useSubscription(function () {
|
|
168
|
+
// 350ms 是为了等待css动画时间
|
|
169
|
+
var timer = setTimeout(function () {
|
|
170
|
+
calculateHeight();
|
|
171
|
+
timer = '';
|
|
172
|
+
clearTimeout(timer);
|
|
173
|
+
}, 350);
|
|
174
|
+
});
|
|
175
|
+
}
|
|
176
|
+
|
|
147
177
|
(0, _react.useEffect)(function () {
|
|
148
178
|
var _rest$columns;
|
|
149
179
|
|
|
@@ -157,16 +187,17 @@ function VtxDatagrid(props) {
|
|
|
157
187
|
});
|
|
158
188
|
}, [rest.columns]);
|
|
159
189
|
|
|
160
|
-
var parseColumns = function parseColumns() {
|
|
190
|
+
var parseColumns = function parseColumns(type) {
|
|
161
191
|
// 显示工具栏的同时并显示列设置
|
|
162
192
|
if (toolbar && !hideColumnSetting) {
|
|
163
|
-
if (defaultVisibleColumnKeys) {
|
|
193
|
+
if (defaultVisibleColumnKeys || visibleColumnKeys) {
|
|
164
194
|
var _rest$columns2;
|
|
165
195
|
|
|
196
|
+
var columnKeys = type === 'reset' ? defaultVisibleColumnKeys : visibleColumnKeys || defaultVisibleColumnKeys;
|
|
166
197
|
setState({
|
|
167
|
-
checkedColumnKeys:
|
|
198
|
+
checkedColumnKeys: columnKeys,
|
|
168
199
|
visibleColumns: (_rest$columns2 = rest.columns) === null || _rest$columns2 === void 0 ? void 0 : _rest$columns2.filter(function (item) {
|
|
169
|
-
return
|
|
200
|
+
return columnKeys.includes(item.dataIndex || item.key);
|
|
170
201
|
})
|
|
171
202
|
});
|
|
172
203
|
} else {
|
|
@@ -186,15 +217,12 @@ function VtxDatagrid(props) {
|
|
|
186
217
|
}
|
|
187
218
|
};
|
|
188
219
|
|
|
189
|
-
var
|
|
220
|
+
var hasAlert = (((_rest$rowSelection2 = rest.rowSelection) === null || _rest$rowSelection2 === void 0 ? void 0 : _rest$rowSelection2.selectedRowKeys) || []).length > 0;
|
|
221
|
+
alertHeight.current = hasAlert ? 49 : 0;
|
|
222
|
+
toolbarHeight.current = toolbar ? 56 : 0; // 高度计算
|
|
190
223
|
|
|
191
224
|
var calculateHeight = function calculateHeight() {
|
|
192
|
-
var bodyHeight = document.getElementById(datagridId).clientHeight - headFootHeight;
|
|
193
|
-
|
|
194
|
-
if (toolbar) {
|
|
195
|
-
bodyHeight = bodyHeight - toolbarHeight;
|
|
196
|
-
}
|
|
197
|
-
|
|
225
|
+
var bodyHeight = document.getElementById(datagridId).clientHeight - headFootHeight - toolbarHeight.current - alertHeight.current;
|
|
198
226
|
var divs = document.getElementById(datagridId).getElementsByTagName('div');
|
|
199
227
|
var bodyDiv = Array.prototype.filter.call(divs, function (dom) {
|
|
200
228
|
return dom.className == 'ant-table-body';
|
|
@@ -269,7 +297,9 @@ function VtxDatagrid(props) {
|
|
|
269
297
|
checkedColumnKeys: checkedColumnKeys,
|
|
270
298
|
columnSettingOptions: columnSettingOptions,
|
|
271
299
|
onChange: handleChangeColumns,
|
|
272
|
-
onReset:
|
|
300
|
+
onReset: function onReset() {
|
|
301
|
+
return parseColumns('reset');
|
|
302
|
+
}
|
|
273
303
|
}, /*#__PURE__*/_react["default"].createElement(_tooltip["default"], {
|
|
274
304
|
title: "\u5217\u8BBE\u7F6E"
|
|
275
305
|
}, /*#__PURE__*/_react["default"].createElement(_icon["default"], {
|
|
@@ -308,7 +338,9 @@ function VtxDatagrid(props) {
|
|
|
308
338
|
return _objectSpread(_objectSpread({}, newColumn), {}, {
|
|
309
339
|
render: (0, _isFunction["default"])(column.renderButtons) ? function (text, record, index) {
|
|
310
340
|
return (0, _renderColumnButtons["default"])(column.renderButtons, column.renderButtonsVisibleNum, text, record, index);
|
|
311
|
-
} : column.render
|
|
341
|
+
} : 'render' in column ? column.render : function (text) {
|
|
342
|
+
return ['', null, undefined].includes(text) ? '-' : text;
|
|
343
|
+
}
|
|
312
344
|
});
|
|
313
345
|
}); // 配置了列可伸缩
|
|
314
346
|
|
|
@@ -353,7 +385,8 @@ function VtxDatagrid(props) {
|
|
|
353
385
|
title: indexTitle,
|
|
354
386
|
dataIndex: '_serialNum',
|
|
355
387
|
key: '_serialNum',
|
|
356
|
-
width: 70
|
|
388
|
+
width: 70,
|
|
389
|
+
fixed: indexFixed
|
|
357
390
|
}].concat(_toConsumableArray(columns));
|
|
358
391
|
dataSource = (_dataSource = dataSource) === null || _dataSource === void 0 ? void 0 : _dataSource.map(function (item, i) {
|
|
359
392
|
return _objectSpread(_objectSpread({}, item), {}, {
|
|
@@ -374,16 +407,28 @@ function VtxDatagrid(props) {
|
|
|
374
407
|
id: datagridId,
|
|
375
408
|
className: (0, _classnames2["default"])(prefixCls, className, (_classnames = {}, _defineProperty(_classnames, "".concat(prefixCls, "-fit"), autoFit), _defineProperty(_classnames, "".concat(prefixCls, "-nodata"), !((_dataSource2 = dataSource) !== null && _dataSource2 !== void 0 && _dataSource2.length)), _classnames)),
|
|
376
409
|
style: style
|
|
377
|
-
}, toolbarRender, /*#__PURE__*/_react["default"].createElement(
|
|
378
|
-
|
|
410
|
+
}, toolbarRender, hasAlert && /*#__PURE__*/_react["default"].createElement("div", {
|
|
411
|
+
className: "".concat(prefixCls, "-alert")
|
|
412
|
+
}, /*#__PURE__*/_react["default"].createElement(_Alert["default"], {
|
|
413
|
+
prefixCls: prefixCls,
|
|
414
|
+
selectedRowKeys: (_rest$rowSelection3 = rest.rowSelection) === null || _rest$rowSelection3 === void 0 ? void 0 : _rest$rowSelection3.selectedRowKeys,
|
|
415
|
+
claerRowSelection: claerRowSelection
|
|
416
|
+
})), /*#__PURE__*/_react["default"].createElement(_table["default"], _extends({
|
|
417
|
+
size: size,
|
|
418
|
+
bordered: bordered
|
|
379
419
|
}, rest, {
|
|
380
420
|
columns: columns,
|
|
381
421
|
dataSource: dataSource,
|
|
382
422
|
scroll: scroll,
|
|
383
423
|
pagination: getPagination(rest.pagination),
|
|
384
424
|
style: {
|
|
385
|
-
height: "calc(100% - ".concat(toolbarHeight, "px)")
|
|
425
|
+
height: "calc(100% - ".concat(toolbarHeight.current + alertHeight.current, "px)")
|
|
386
426
|
},
|
|
427
|
+
locale: _objectSpread({
|
|
428
|
+
emptyText: /*#__PURE__*/_react["default"].createElement(_empty["default"], {
|
|
429
|
+
description: emptyText
|
|
430
|
+
})
|
|
431
|
+
}, rest.locale),
|
|
387
432
|
components: columnResizable ? {
|
|
388
433
|
header: {
|
|
389
434
|
cell: _ResizeableTitle["default"]
|
|
@@ -397,6 +442,8 @@ VtxDatagrid.propTypes = {
|
|
|
397
442
|
refreshIconVisible: _propTypes["default"].bool,
|
|
398
443
|
hideColumnSetting: _propTypes["default"].bool,
|
|
399
444
|
hideColumnHeight: _propTypes["default"].bool,
|
|
445
|
+
bordered: _propTypes["default"].bool,
|
|
446
|
+
visibleColumnKeys: _propTypes["default"].array,
|
|
400
447
|
defaultVisibleColumnKeys: _propTypes["default"].array,
|
|
401
448
|
onVisibleColumnsChange: _propTypes["default"].func,
|
|
402
449
|
toolbarClassName: _propTypes["default"].string,
|
|
@@ -404,12 +451,16 @@ VtxDatagrid.propTypes = {
|
|
|
404
451
|
toolbarTilte: _propTypes["default"].oneOfType([_propTypes["default"].string, _propTypes["default"].node]),
|
|
405
452
|
onRefresh: _propTypes["default"].func,
|
|
406
453
|
indexColumn: _propTypes["default"].bool,
|
|
454
|
+
indexFixed: _propTypes["default"].oneOfType([_propTypes["default"].string, _propTypes["default"].bool]),
|
|
407
455
|
indexTitle: _propTypes["default"].string,
|
|
408
456
|
startIndex: _propTypes["default"].number,
|
|
409
457
|
buttonGroup: _propTypes["default"].node,
|
|
410
458
|
autoFit: _propTypes["default"].bool,
|
|
411
459
|
headFootHeight: _propTypes["default"].number,
|
|
412
460
|
columnResizable: _propTypes["default"].bool,
|
|
461
|
+
emptyText: _propTypes["default"].oneOfType([_propTypes["default"].string, _propTypes["default"].node]),
|
|
462
|
+
claerRowSelection: _propTypes["default"].func,
|
|
463
|
+
searchCollapseEvent$: _propTypes["default"].object,
|
|
413
464
|
className: _propTypes["default"].string,
|
|
414
465
|
style: _propTypes["default"].object
|
|
415
466
|
};
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["vtx-datagrid/index.jsx"],"names":["VtxDatagrid","props","visibleColumns","checkedColumnKeys","columnSettingOptions","datagridId","Date","getTime","scrollY","size","state","setState","prefixCls","toolbar","toolbarClassName","toolbarTilte","buttonGroup","refreshIconVisible","hideColumnSetting","hideColumnHeight","defaultVisibleColumnKeys","onVisibleColumnsChange","onRefresh","indexColumn","indexTitle","startIndex","autoFit","headFootHeight","columnResizable","className","style","rest","window","addEventListener","calculateHeight","removeEventListener","parseColumns","columns","map","col","key","dataIndex","filter","item","includes","toolbarHeight","bodyHeight","document","getElementById","clientHeight","divs","getElementsByTagName","bodyDiv","Array","prototype","call","dom","minHeight","handleChangeColumns","keys","toolbarRender","getPagination","pagination","pageSizeOptions","showSizeChanger","showQuickJumper","showTotal","total","column","newColumn","renderButtons","renderButtonsVisibleNum","render","text","record","index","onHeaderCell","width","onResize","handleResize","e","nextColumns","dataSource","title","i","_serialNum","scroll","y","length","height","header","cell","ResizeableTitle","undefined","propTypes","PropTypes","string","bool","array","func","oneOfType","node","number","object"],"mappings":"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","sourcesContent":["import React, { useEffect, useLayoutEffect } from 'react';\nimport Table from 'antd/es/table';\nimport Icon from 'antd/es/icon';\nimport Tooltip from 'antd/es/tooltip';\nimport Dropdown from 'antd/es/dropdown';\nimport Menu from 'antd/es/menu';\nimport classnames from 'classnames';\nimport PropTypes from 'prop-types';\n\nimport ColumnSetting from './ColumnSetting';\nimport ResizeableTitle from './ResizeableTitle';\nimport renderColumnButtons from './renderColumnButtons';\nimport useSet from '../_util/useSet';\nimport isFunction from '../_util/isFunction';\n\nexport default function VtxDatagrid(props) {\n const [state, setState] = useSet({\n // 显示列\n visibleColumns: [],\n // 列设置选中的列\n checkedColumnKeys: [],\n // 列设置选项\n columnSettingOptions: [],\n datagridId: `vtx-datagrid-${new Date().getTime()}`,\n scrollY: null,\n size: 'default',\n });\n const {\n visibleColumns,\n checkedColumnKeys,\n columnSettingOptions,\n datagridId,\n scrollY,\n size,\n } = state;\n\n const {\n prefixCls = 'vtx-datagrid',\n toolbar = true,\n toolbarClassName,\n toolbarTilte = '查询结果',\n buttonGroup,\n refreshIconVisible = true,\n hideColumnSetting,\n hideColumnHeight,\n defaultVisibleColumnKeys,\n onVisibleColumnsChange,\n onRefresh,\n indexColumn = true,\n indexTitle = '序号',\n startIndex = 1,\n autoFit = true,\n headFootHeight = 115,\n columnResizable,\n className,\n style,\n ...rest\n } = props;\n\n useEffect(() => {\n // componentDidMount\n if (autoFit) {\n window.addEventListener('resize', calculateHeight, false);\n }\n return () => {\n // componentWillUnmount\n if (autoFit) {\n window.removeEventListener('resize', calculateHeight, false);\n }\n };\n }, []);\n\n useLayoutEffect(() => {\n if (autoFit) {\n calculateHeight();\n }\n }, [scrollY]);\n\n useEffect(() => {\n parseColumns();\n setState({\n columnSettingOptions: rest.columns?.map(col => ({\n ...col,\n key: col.dataIndex || col.key,\n })),\n });\n }, [rest.columns]);\n\n const parseColumns = () => {\n // 显示工具栏的同时并显示列设置\n if (toolbar && !hideColumnSetting) {\n if (defaultVisibleColumnKeys) {\n setState({\n checkedColumnKeys: defaultVisibleColumnKeys,\n visibleColumns: rest.columns?.filter(item =>\n defaultVisibleColumnKeys.includes(item.dataIndex || item.key),\n ),\n });\n } else {\n setState({\n checkedColumnKeys: rest.columns?.map(item => item.dataIndex || item.key),\n visibleColumns: rest.columns,\n });\n }\n } else {\n setState({\n visibleColumns: rest.columns,\n });\n }\n };\n\n const toolbarHeight = toolbar ? 56 : 0;\n // 高度计算\n const calculateHeight = () => {\n let bodyHeight = document.getElementById(datagridId).clientHeight - headFootHeight;\n\n if (toolbar) {\n bodyHeight = bodyHeight - toolbarHeight;\n }\n const divs = document.getElementById(datagridId).getElementsByTagName('div');\n const bodyDiv = Array.prototype.filter.call(\n divs,\n dom => dom.className == 'ant-table-body',\n )[0];\n bodyDiv.style.minHeight = `${bodyHeight}px`;\n setState({\n scrollY: bodyHeight,\n });\n };\n\n // 列设置回调\n const handleChangeColumns = keys => {\n setState({\n checkedColumnKeys: keys,\n visibleColumns: columnSettingOptions?.filter(item => keys.includes(item.key)),\n });\n onVisibleColumnsChange && onVisibleColumnsChange(keys);\n };\n\n // 工具栏\n let toolbarRender;\n if (toolbar) {\n toolbarRender = (\n <div className={classnames(`${prefixCls}-toolbar`, toolbarClassName)}>\n <div className={`${prefixCls}-toolbar-left`}>{toolbarTilte}</div>\n <div className={`${prefixCls}-toolbar-right`}>\n <div\n className={classnames(\n `${prefixCls}-space-item`,\n `${prefixCls}-toolbar-actions`,\n )}\n >\n {buttonGroup}\n </div>\n <div\n className={classnames(\n `${prefixCls}-space-item`,\n `${prefixCls}-toolbar-setting`,\n )}\n >\n {refreshIconVisible && (\n <div\n className={`${prefixCls}-toolbar-setting-item`}\n onClick={() => {\n onRefresh && onRefresh();\n }}\n >\n <Tooltip title=\"刷新\">\n <Icon type=\"redo\" />\n </Tooltip>\n </div>\n )}\n {!hideColumnHeight && (\n <div className={`${prefixCls}-toolbar-setting-item`}>\n <Dropdown\n overlay={\n <Menu\n onClick={({ key }) => setState({ size: key })}\n selectedKeys={[size]}\n >\n <Menu.Item key=\"default\">默认</Menu.Item>\n <Menu.Item key=\"middle\">中等</Menu.Item>\n <Menu.Item key=\"small\">紧凑</Menu.Item>\n </Menu>\n }\n trigger={['click']}\n >\n <Tooltip title=\"列密度\">\n <Icon type=\"column-height\" />\n </Tooltip>\n </Dropdown>\n </div>\n )}\n {!hideColumnSetting && (\n <div className={`${prefixCls}-toolbar-setting-item`}>\n <ColumnSetting\n prefixCls={prefixCls}\n checkedColumnKeys={checkedColumnKeys}\n columnSettingOptions={columnSettingOptions}\n onChange={handleChangeColumns}\n onReset={parseColumns}\n >\n <Tooltip title=\"列设置\">\n <Icon type=\"setting\" />\n </Tooltip>\n </ColumnSetting>\n </div>\n )}\n </div>\n </div>\n </div>\n );\n }\n\n // 分页\n const getPagination = pagination => {\n if (typeof pagination === 'boolean' && !pagination) {\n return pagination;\n }\n return {\n pageSizeOptions: ['10', '20', '30', '40', '50'],\n showSizeChanger: true,\n showQuickJumper: true,\n showTotal(total) {\n return `共 ${total} 条`;\n },\n ...pagination,\n };\n };\n\n // 处理操作按钮\n let columns = (visibleColumns || []).map(column => {\n const newColumn = { ...column };\n if (newColumn.renderButtons) {\n delete newColumn.renderButtons;\n }\n if (newColumn.renderButtonsVisibleNum) {\n delete newColumn.renderButtonsVisibleNum;\n }\n return {\n ...newColumn,\n render: isFunction(column.renderButtons)\n ? function(text, record, index) {\n return renderColumnButtons(\n column.renderButtons,\n column.renderButtonsVisibleNum,\n text,\n record,\n index,\n );\n }\n : column.render,\n };\n });\n // 配置了列可伸缩\n if (columnResizable) {\n columns = columns.map((col, index) => ({\n ...col,\n onHeaderCell: column => ({\n width: column.width,\n onResize: handleResize(index),\n }),\n }));\n const handleResize = index => (e, { size }) => {\n setState(({ visibleColumns }) => {\n const nextColumns = [...visibleColumns];\n nextColumns[index] = {\n ...nextColumns[index],\n width: size.width,\n };\n return { visibleColumns: nextColumns };\n });\n };\n }\n\n // 序号添加\n let dataSource = rest.dataSource;\n if (indexColumn) {\n columns = [\n {\n title: indexTitle,\n dataIndex: '_serialNum',\n key: '_serialNum',\n width: 70,\n },\n ...columns,\n ];\n dataSource = dataSource?.map((item, i) => {\n return {\n ...item,\n _serialNum: i + startIndex,\n };\n });\n }\n\n let scroll;\n if (autoFit) {\n scroll = {\n ...(rest.scroll || {}),\n y: scrollY,\n };\n }\n\n return (\n <div\n id={datagridId}\n className={classnames(prefixCls, className, {\n [`${prefixCls}-fit`]: autoFit,\n [`${prefixCls}-nodata`]: !dataSource?.length,\n })}\n style={style}\n >\n {toolbarRender}\n <Table\n size={size}\n {...rest}\n columns={columns}\n dataSource={dataSource}\n scroll={scroll}\n pagination={getPagination(rest.pagination)}\n style={{ height: `calc(100% - ${toolbarHeight}px)` }}\n components={\n columnResizable\n ? {\n header: {\n cell: ResizeableTitle,\n },\n }\n : undefined\n }\n />\n </div>\n );\n}\n\nVtxDatagrid.propTypes = {\n prefixCls: PropTypes.string,\n refreshIconVisible: PropTypes.bool,\n hideColumnSetting: PropTypes.bool,\n hideColumnHeight: PropTypes.bool,\n defaultVisibleColumnKeys: PropTypes.array,\n onVisibleColumnsChange: PropTypes.func,\n toolbarClassName: PropTypes.string,\n toolbar: PropTypes.bool,\n toolbarTilte: PropTypes.oneOfType([PropTypes.string, PropTypes.node]),\n onRefresh: PropTypes.func,\n indexColumn: PropTypes.bool,\n indexTitle: PropTypes.string,\n startIndex: PropTypes.number,\n buttonGroup: PropTypes.node,\n autoFit: PropTypes.bool,\n headFootHeight: PropTypes.number,\n columnResizable: PropTypes.bool,\n className: PropTypes.string,\n style: PropTypes.object,\n};\n"],"file":"index.js"}
|
|
1
|
+
{"version":3,"sources":["vtx-datagrid/index.jsx"],"names":["VtxDatagrid","props","visibleColumns","checkedColumnKeys","columnSettingOptions","datagridId","Date","getTime","scrollY","size","state","setState","alertHeight","toolbarHeight","prefixCls","toolbar","toolbarClassName","toolbarTilte","buttonGroup","refreshIconVisible","hideColumnSetting","hideColumnHeight","visibleColumnKeys","defaultVisibleColumnKeys","onVisibleColumnsChange","onRefresh","indexColumn","indexFixed","bordered","indexTitle","startIndex","autoFit","headFootHeight","columnResizable","className","style","emptyText","claerRowSelection","searchCollapseEvent$","rest","window","addEventListener","calculateHeight","removeEventListener","rowSelection","selectedRowKeys","join","useSubscription","timer","setTimeout","clearTimeout","parseColumns","columns","map","col","key","dataIndex","type","columnKeys","filter","item","includes","hasAlert","length","current","bodyHeight","document","getElementById","clientHeight","divs","getElementsByTagName","bodyDiv","Array","prototype","call","dom","minHeight","handleChangeColumns","keys","toolbarRender","getPagination","pagination","pageSizeOptions","showSizeChanger","showQuickJumper","showTotal","total","column","newColumn","renderButtons","renderButtonsVisibleNum","render","text","record","index","undefined","onHeaderCell","width","onResize","handleResize","e","nextColumns","dataSource","title","fixed","i","_serialNum","scroll","y","height","locale","header","cell","ResizeableTitle","propTypes","PropTypes","string","bool","array","func","oneOfType","node","number","object"],"mappings":"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","sourcesContent":["import React, { useEffect, useLayoutEffect, useRef } from 'react';\nimport Table from 'antd/es/table';\nimport Icon from 'antd/es/icon';\nimport Tooltip from 'antd/es/tooltip';\nimport Dropdown from 'antd/es/dropdown';\nimport Menu from 'antd/es/menu';\nimport Empty from 'antd/es/empty';\nimport classnames from 'classnames';\nimport PropTypes from 'prop-types';\n\nimport Alert from './Alert';\nimport ColumnSetting from './ColumnSetting';\nimport ResizeableTitle from './ResizeableTitle';\nimport renderColumnButtons from './renderColumnButtons';\nimport useSet from '../_util/useSet';\nimport isFunction from '../_util/isFunction';\n\nexport default function VtxDatagrid(props) {\n const [state, setState] = useSet({\n // 显示列\n visibleColumns: [],\n // 列设置选中的列\n checkedColumnKeys: [],\n // 列设置选项\n columnSettingOptions: [],\n datagridId: `vtx-datagrid-${new Date().getTime()}`,\n scrollY: null,\n size: 'middle',\n });\n const {\n visibleColumns,\n checkedColumnKeys,\n columnSettingOptions,\n datagridId,\n scrollY,\n size,\n } = state;\n\n // 列设置提示高度\n const alertHeight = useRef(0);\n // 工具栏高度\n const toolbarHeight = useRef(0);\n\n const {\n prefixCls = 'vtx-datagrid',\n toolbar = true,\n toolbarClassName,\n toolbarTilte = '查询结果',\n buttonGroup,\n refreshIconVisible = true,\n hideColumnSetting,\n hideColumnHeight,\n visibleColumnKeys,\n defaultVisibleColumnKeys,\n onVisibleColumnsChange,\n onRefresh,\n indexColumn = true,\n indexFixed = false,\n bordered = true,\n indexTitle = '序号',\n startIndex = 1,\n autoFit = true,\n headFootHeight = 115,\n columnResizable,\n className,\n style,\n emptyText = '暂无数据',\n claerRowSelection,\n searchCollapseEvent$,\n ...rest\n } = props;\n\n useEffect(() => {\n // componentDidMount\n if (autoFit) {\n window.addEventListener('resize', calculateHeight, false);\n }\n return () => {\n // componentWillUnmount\n if (autoFit) {\n window.removeEventListener('resize', calculateHeight, false);\n }\n };\n }, []);\n\n useLayoutEffect(() => {\n if (autoFit) {\n calculateHeight();\n }\n }, [(rest.rowSelection?.selectedRowKeys || []).join(',')]);\n\n // 只有被TableLayout.Page包裹时才会存在searchCollapseEvent$这个参数\n if (searchCollapseEvent$) {\n // eslint-disable-next-line react/prop-types\n searchCollapseEvent$.useSubscription(() => {\n // 350ms 是为了等待css动画时间\n let timer = setTimeout(() => {\n calculateHeight();\n timer = '';\n clearTimeout(timer);\n }, 350);\n });\n }\n\n useEffect(() => {\n parseColumns();\n setState({\n columnSettingOptions: rest.columns?.map(col => ({\n ...col,\n key: col.dataIndex || col.key,\n })),\n });\n }, [rest.columns]);\n\n const parseColumns = type => {\n // 显示工具栏的同时并显示列设置\n if (toolbar && !hideColumnSetting) {\n if (defaultVisibleColumnKeys || visibleColumnKeys) {\n const columnKeys =\n type === 'reset'\n ? defaultVisibleColumnKeys\n : visibleColumnKeys || defaultVisibleColumnKeys;\n setState({\n checkedColumnKeys: columnKeys,\n visibleColumns: rest.columns?.filter(item =>\n columnKeys.includes(item.dataIndex || item.key),\n ),\n });\n } else {\n setState({\n checkedColumnKeys: rest.columns?.map(item => item.dataIndex || item.key),\n visibleColumns: rest.columns,\n });\n }\n } else {\n setState({\n visibleColumns: rest.columns,\n });\n }\n };\n\n const hasAlert = (rest.rowSelection?.selectedRowKeys || []).length > 0;\n alertHeight.current = hasAlert ? 49 : 0;\n toolbarHeight.current = toolbar ? 56 : 0;\n // 高度计算\n const calculateHeight = () => {\n const bodyHeight =\n document.getElementById(datagridId).clientHeight -\n headFootHeight -\n toolbarHeight.current -\n alertHeight.current;\n const divs = document.getElementById(datagridId).getElementsByTagName('div');\n const bodyDiv = Array.prototype.filter.call(\n divs,\n dom => dom.className == 'ant-table-body',\n )[0];\n bodyDiv.style.minHeight = `${bodyHeight}px`;\n setState({\n scrollY: bodyHeight,\n });\n };\n\n // 列设置回调\n const handleChangeColumns = keys => {\n setState({\n checkedColumnKeys: keys,\n visibleColumns: columnSettingOptions?.filter(item => keys.includes(item.key)),\n });\n onVisibleColumnsChange && onVisibleColumnsChange(keys);\n };\n\n // 工具栏\n let toolbarRender;\n if (toolbar) {\n toolbarRender = (\n <div className={classnames(`${prefixCls}-toolbar`, toolbarClassName)}>\n <div className={`${prefixCls}-toolbar-left`}>{toolbarTilte}</div>\n <div className={`${prefixCls}-toolbar-right`}>\n <div\n className={classnames(\n `${prefixCls}-space-item`,\n `${prefixCls}-toolbar-actions`,\n )}\n >\n {buttonGroup}\n </div>\n <div\n className={classnames(\n `${prefixCls}-space-item`,\n `${prefixCls}-toolbar-setting`,\n )}\n >\n {refreshIconVisible && (\n <div\n className={`${prefixCls}-toolbar-setting-item`}\n onClick={() => {\n onRefresh && onRefresh();\n }}\n >\n <Tooltip title=\"刷新\">\n <Icon type=\"redo\" />\n </Tooltip>\n </div>\n )}\n {!hideColumnHeight && (\n <div className={`${prefixCls}-toolbar-setting-item`}>\n <Dropdown\n overlay={\n <Menu\n onClick={({ key }) => setState({ size: key })}\n selectedKeys={[size]}\n >\n <Menu.Item key=\"default\">默认</Menu.Item>\n <Menu.Item key=\"middle\">中等</Menu.Item>\n <Menu.Item key=\"small\">紧凑</Menu.Item>\n </Menu>\n }\n trigger={['click']}\n >\n <Tooltip title=\"列密度\">\n <Icon type=\"column-height\" />\n </Tooltip>\n </Dropdown>\n </div>\n )}\n {!hideColumnSetting && (\n <div className={`${prefixCls}-toolbar-setting-item`}>\n <ColumnSetting\n prefixCls={prefixCls}\n checkedColumnKeys={checkedColumnKeys}\n columnSettingOptions={columnSettingOptions}\n onChange={handleChangeColumns}\n onReset={() => parseColumns('reset')}\n >\n <Tooltip title=\"列设置\">\n <Icon type=\"setting\" />\n </Tooltip>\n </ColumnSetting>\n </div>\n )}\n </div>\n </div>\n </div>\n );\n }\n\n // 分页\n const getPagination = pagination => {\n if (typeof pagination === 'boolean' && !pagination) {\n return pagination;\n }\n return {\n pageSizeOptions: ['10', '20', '30', '40', '50'],\n showSizeChanger: true,\n showQuickJumper: true,\n showTotal(total) {\n return `共 ${total} 条`;\n },\n ...pagination,\n };\n };\n\n // 处理操作按钮\n let columns = (visibleColumns || []).map(column => {\n const newColumn = { ...column };\n if (newColumn.renderButtons) {\n delete newColumn.renderButtons;\n }\n if (newColumn.renderButtonsVisibleNum) {\n delete newColumn.renderButtonsVisibleNum;\n }\n return {\n ...newColumn,\n render: isFunction(column.renderButtons)\n ? function(text, record, index) {\n return renderColumnButtons(\n column.renderButtons,\n column.renderButtonsVisibleNum,\n text,\n record,\n index,\n );\n }\n : 'render' in column\n ? column.render\n : function(text) {\n return ['', null, undefined].includes(text) ? '-' : text;\n },\n };\n });\n // 配置了列可伸缩\n if (columnResizable) {\n columns = columns.map((col, index) => ({\n ...col,\n onHeaderCell: column => ({\n width: column.width,\n onResize: handleResize(index),\n }),\n }));\n const handleResize = index => (e, { size }) => {\n setState(({ visibleColumns }) => {\n const nextColumns = [...visibleColumns];\n nextColumns[index] = {\n ...nextColumns[index],\n width: size.width,\n };\n return { visibleColumns: nextColumns };\n });\n };\n }\n\n // 序号添加\n let dataSource = rest.dataSource;\n if (indexColumn) {\n columns = [\n {\n title: indexTitle,\n dataIndex: '_serialNum',\n key: '_serialNum',\n width: 70,\n fixed: indexFixed,\n },\n ...columns,\n ];\n dataSource = dataSource?.map((item, i) => {\n return {\n ...item,\n _serialNum: i + startIndex,\n };\n });\n }\n\n let scroll;\n if (autoFit) {\n scroll = {\n ...(rest.scroll || {}),\n y: scrollY,\n };\n }\n\n return (\n <div\n id={datagridId}\n className={classnames(prefixCls, className, {\n [`${prefixCls}-fit`]: autoFit,\n [`${prefixCls}-nodata`]: !dataSource?.length,\n })}\n style={style}\n >\n {toolbarRender}\n {hasAlert && (\n <div className={`${prefixCls}-alert`}>\n <Alert\n prefixCls={prefixCls}\n selectedRowKeys={rest.rowSelection?.selectedRowKeys}\n claerRowSelection={claerRowSelection}\n />\n </div>\n )}\n <Table\n size={size}\n bordered={bordered}\n {...rest}\n columns={columns}\n dataSource={dataSource}\n scroll={scroll}\n pagination={getPagination(rest.pagination)}\n style={{ height: `calc(100% - ${toolbarHeight.current + alertHeight.current}px)` }}\n locale={{\n emptyText: <Empty description={emptyText} />,\n ...rest.locale,\n }}\n components={\n columnResizable\n ? {\n header: {\n cell: ResizeableTitle,\n },\n }\n : undefined\n }\n />\n </div>\n );\n}\n\nVtxDatagrid.propTypes = {\n prefixCls: PropTypes.string,\n refreshIconVisible: PropTypes.bool,\n hideColumnSetting: PropTypes.bool,\n hideColumnHeight: PropTypes.bool,\n bordered: PropTypes.bool,\n visibleColumnKeys: PropTypes.array,\n defaultVisibleColumnKeys: PropTypes.array,\n onVisibleColumnsChange: PropTypes.func,\n toolbarClassName: PropTypes.string,\n toolbar: PropTypes.bool,\n toolbarTilte: PropTypes.oneOfType([PropTypes.string, PropTypes.node]),\n onRefresh: PropTypes.func,\n indexColumn: PropTypes.bool,\n indexFixed: PropTypes.oneOfType([PropTypes.string, PropTypes.bool]),\n indexTitle: PropTypes.string,\n startIndex: PropTypes.number,\n buttonGroup: PropTypes.node,\n autoFit: PropTypes.bool,\n headFootHeight: PropTypes.number,\n columnResizable: PropTypes.bool,\n emptyText: PropTypes.oneOfType([PropTypes.string, PropTypes.node]),\n claerRowSelection: PropTypes.func,\n searchCollapseEvent$: PropTypes.object,\n className: PropTypes.string,\n style: PropTypes.object,\n};\n"],"file":"index.js"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["vtx-datagrid/style/index.js"],"names":[],"mappings":";;AAAA;;AACA;;AACA;;AACA;;AACA;;AACA;;AACA;;AACA;;AACA","sourcesContent":["import 'antd/es/table/style/css';\nimport 'antd/es/tooltip/style/css';\nimport 'antd/es/popover/style/css';\nimport 'antd/es/checkbox/style/css';\nimport 'antd/es/popconfirm/style/css';\nimport 'antd/es/dropdown/style/css';\nimport 'antd/es/menu/style/css';\nimport 'antd/es/divider/style/css';\nimport './index.less';\n"],"file":"css.js"}
|
|
1
|
+
{"version":3,"sources":["vtx-datagrid/style/index.js"],"names":[],"mappings":";;AAAA;;AACA;;AACA;;AACA;;AACA;;AACA;;AACA;;AACA;;AACA;;AACA;;AACA","sourcesContent":["import 'antd/es/table/style/css';\nimport 'antd/es/tooltip/style/css';\nimport 'antd/es/popover/style/css';\nimport 'antd/es/checkbox/style/css';\nimport 'antd/es/popconfirm/style/css';\nimport 'antd/es/dropdown/style/css';\nimport 'antd/es/menu/style/css';\nimport 'antd/es/divider/style/css';\nimport 'antd/es/empty/style/css';\nimport 'antd/es/alert/style/css';\nimport './index.less';\n"],"file":"css.js"}
|
|
@@ -40,6 +40,28 @@
|
|
|
40
40
|
left: 0;
|
|
41
41
|
border-top: none;
|
|
42
42
|
}
|
|
43
|
+
.vtx-datagrid .ant-table-thead > tr > th {
|
|
44
|
+
background-color: rgba(24, 144, 255, 0.08);
|
|
45
|
+
}
|
|
46
|
+
.vtx-datagrid .ant-table-tbody > tr:nth-child(even) {
|
|
47
|
+
background: #f6f6f6;
|
|
48
|
+
}
|
|
49
|
+
.vtx-datagrid .ant-table-tbody > tr.ant-table-row-selected td {
|
|
50
|
+
background: transparent;
|
|
51
|
+
}
|
|
52
|
+
.vtx-datagrid-alert {
|
|
53
|
+
margin-bottom: 8px;
|
|
54
|
+
}
|
|
55
|
+
.vtx-datagrid-alert-message {
|
|
56
|
+
color: rgba(0, 0, 0, 0.65);
|
|
57
|
+
}
|
|
58
|
+
.vtx-datagrid-alert-info-content > strong {
|
|
59
|
+
margin: 0 4px;
|
|
60
|
+
color: #13c2c2;
|
|
61
|
+
}
|
|
62
|
+
.vtx-datagrid-alert-info-option {
|
|
63
|
+
margin-left: 10px;
|
|
64
|
+
}
|
|
43
65
|
.vtx-datagrid-nodata .ant-table-scroll {
|
|
44
66
|
overflow-y: hidden;
|
|
45
67
|
}
|
|
@@ -47,7 +69,6 @@
|
|
|
47
69
|
display: table;
|
|
48
70
|
width: 100%;
|
|
49
71
|
margin: 16px 0;
|
|
50
|
-
padding: 0 16px;
|
|
51
72
|
}
|
|
52
73
|
.vtx-datagrid-toolbar-left,
|
|
53
74
|
.vtx-datagrid-toolbar-right {
|