dlt-for-react 1.1.16 → 1.1.18
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +20 -1
- package/assets/HqCheckButton/index.less +13 -0
- package/assets/HqImage/index.less +11 -0
- package/assets/HqInputPicker/index.less +8 -0
- package/assets/selector/resultview/index.less +53 -0
- package/assets/selector/selectormodal/index.less +15 -0
- package/assets/selector/table/index.less +211 -0
- package/assets/selector/tree/index.less +138 -0
- package/assets/stuSelector/index.less +24 -0
- package/assets/teaSelector/index.less +4 -0
- package/lib/components/HqButton/index.js +95 -0
- package/lib/components/HqCascader/index.js +306 -0
- package/lib/components/HqCheckBox/index.js +375 -0
- package/lib/components/HqCheckButton/index.js +284 -0
- package/lib/components/HqConfirm/index.js +81 -0
- package/lib/components/HqFormItem/FormRules.js +27 -0
- package/lib/components/HqFormItem/index.js +309 -0
- package/lib/components/HqImage/index.js +553 -0
- package/lib/components/HqInputPicker/edit-page.js +585 -0
- package/lib/components/HqInputPicker/index.js +226 -0
- package/lib/components/HqInputPicker/input-const.js +134 -0
- package/lib/components/HqInputPicker/render.js +2496 -0
- package/lib/components/HqInputPicker/setting-checkbox.js +853 -0
- package/lib/components/HqInputPicker/setting-datepicker.js +430 -0
- package/lib/components/HqInputPicker/setting-datetimepicker.js +443 -0
- package/lib/components/HqInputPicker/setting-input.js +555 -0
- package/lib/components/HqInputPicker/setting-inputNumber.js +658 -0
- package/lib/components/HqInputPicker/setting-monthpicker.js +434 -0
- package/lib/components/HqInputPicker/setting-multiSelect.js +533 -0
- package/lib/components/HqInputPicker/setting-nhcascader.js +588 -0
- package/lib/components/HqInputPicker/setting-old-upload.js +428 -0
- package/lib/components/HqInputPicker/setting-radio.js +468 -0
- package/lib/components/HqInputPicker/setting-rangepicker.js +466 -0
- package/lib/components/HqInputPicker/setting-select.js +534 -0
- package/lib/components/HqInputPicker/setting-stu-selector.js +508 -0
- package/lib/components/HqInputPicker/setting-switch.js +274 -0
- package/lib/components/HqInputPicker/setting-tea-selector.js +508 -0
- package/lib/components/HqInputPicker/setting-textarea.js +619 -0
- package/lib/components/HqInputPicker/setting-timepicker.js +437 -0
- package/lib/components/HqInputPicker/setting-upload.js +795 -0
- package/lib/components/HqMultiSelect/index.js +495 -0
- package/lib/components/HqOldUpload/index.js +350 -0
- package/lib/components/HqSelect/getSelectName.js +20 -0
- package/lib/components/HqSelect/index.js +495 -0
- package/lib/components/HqSelector/HqLsrySelector/index.js +269 -267
- package/lib/components/HqSelector/HqRySelector/index.js +4 -2
- package/lib/components/HqSelector/HqWzSelector/index.js +4 -2
- package/lib/components/HqStuSelector/index.js +267 -0
- package/lib/components/HqSwitch/index.js +280 -0
- package/lib/components/HqTeaSelector/index.js +221 -0
- package/lib/components/KyCollapse/index.js +23 -24
- package/lib/components/KyContainerFrame/index.js +2 -2
- package/lib/components/KyEditableTable/component.js +38 -38
- package/lib/components/KyEditableTable/index.js +203 -181
- package/lib/components/KyExcel/index.js +191 -153
- package/lib/components/KyModal/index.js +43 -33
- package/lib/components/KyTable/AddFieldsModal.js +66 -59
- package/lib/components/KyTable/checkButtons.js +3 -13
- package/lib/components/KyTable/index.js +2 -2
- package/lib/components/KyTableCardList/AddFieldsModal.js +280 -282
- package/lib/components/KyTableCardList/index.js +15 -26
- package/lib/components/KyTree/index.js +7 -7
- package/lib/components/KyUpload/index.js +170 -165
- package/lib/components/NHSelector/ListSort/index.js +411 -0
- package/lib/components/NHSelector/index.js +636 -0
- package/lib/components/NHSelector/resultview/index.js +408 -0
- package/lib/components/NHSelector/selectormodal/index.js +303 -0
- package/lib/components/NHSelector/table/index.js +784 -0
- package/lib/components/NHSelector/tree/index.js +554 -0
- package/lib/index.js +164 -36
- package/lib/layouts/LeftMenu/index.js +6 -6
- package/lib/layouts/Login/index-pre.js +107 -103
- package/lib/layouts/Login/index.js +2 -2
- package/lib/layouts/Login/login.js +178 -172
- package/lib/layouts/NavigationBar/index.js +67 -67
- package/lib/layouts/Top/editPassWord.js +84 -64
- package/lib/layouts/Top/index.js +117 -117
- package/lib/layouts/TopMenu/index.js +53 -53
- package/lib/layouts/layout/index.js +115 -118
- package/lib/layouts/mixTop/index.js +95 -95
- package/lib/layouts/settingDrawer/index.js +96 -96
- package/lib/routes/AuthorizedRoute.js +33 -32
- package/lib/utils/NHCore.js +65 -65
- package/package.json +2 -2
- package/lib/utils/createUuid.js +0 -40
- package/lib/utils/getLoginUser.js +0 -10
- package/lib/utils/getSize.js +0 -27
|
@@ -0,0 +1,554 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
|
|
3
|
+
Object.defineProperty(exports, "__esModule", {
|
|
4
|
+
value: true
|
|
5
|
+
});
|
|
6
|
+
exports.default = undefined;
|
|
7
|
+
|
|
8
|
+
var _popover = require("antd/lib/popover");
|
|
9
|
+
|
|
10
|
+
var _popover2 = _interopRequireDefault(_popover);
|
|
11
|
+
|
|
12
|
+
var _getPrototypeOf = require("babel-runtime/core-js/object/get-prototype-of");
|
|
13
|
+
|
|
14
|
+
var _getPrototypeOf2 = _interopRequireDefault(_getPrototypeOf);
|
|
15
|
+
|
|
16
|
+
var _classCallCheck2 = require("babel-runtime/helpers/classCallCheck");
|
|
17
|
+
|
|
18
|
+
var _classCallCheck3 = _interopRequireDefault(_classCallCheck2);
|
|
19
|
+
|
|
20
|
+
var _createClass2 = require("babel-runtime/helpers/createClass");
|
|
21
|
+
|
|
22
|
+
var _createClass3 = _interopRequireDefault(_createClass2);
|
|
23
|
+
|
|
24
|
+
var _possibleConstructorReturn2 = require("babel-runtime/helpers/possibleConstructorReturn");
|
|
25
|
+
|
|
26
|
+
var _possibleConstructorReturn3 = _interopRequireDefault(_possibleConstructorReturn2);
|
|
27
|
+
|
|
28
|
+
var _inherits2 = require("babel-runtime/helpers/inherits");
|
|
29
|
+
|
|
30
|
+
var _inherits3 = _interopRequireDefault(_inherits2);
|
|
31
|
+
|
|
32
|
+
var _input = require("antd/lib/input");
|
|
33
|
+
|
|
34
|
+
var _input2 = _interopRequireDefault(_input);
|
|
35
|
+
|
|
36
|
+
var _tree = require("antd/lib/tree");
|
|
37
|
+
|
|
38
|
+
var _tree2 = _interopRequireDefault(_tree);
|
|
39
|
+
|
|
40
|
+
var _layout = require("antd/lib/layout");
|
|
41
|
+
|
|
42
|
+
var _layout2 = _interopRequireDefault(_layout);
|
|
43
|
+
|
|
44
|
+
require("antd/lib/popover/style");
|
|
45
|
+
|
|
46
|
+
require("antd/lib/input/style");
|
|
47
|
+
|
|
48
|
+
require("antd/lib/tree/style");
|
|
49
|
+
|
|
50
|
+
require("antd/lib/layout/style");
|
|
51
|
+
|
|
52
|
+
var _react = require("react");
|
|
53
|
+
|
|
54
|
+
var _react2 = _interopRequireDefault(_react);
|
|
55
|
+
|
|
56
|
+
var _reactCustomScrollbarsPatched = require("react-custom-scrollbars-patched");
|
|
57
|
+
|
|
58
|
+
var _index = require("../../../index");
|
|
59
|
+
|
|
60
|
+
require("../../../../assets/selector/tree/index.less");
|
|
61
|
+
|
|
62
|
+
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
|
|
63
|
+
|
|
64
|
+
var Sider = _layout2.default.Sider;
|
|
65
|
+
|
|
66
|
+
var TreeNode = _tree2.default.TreeNode;
|
|
67
|
+
var Search = _input2.default.Search;
|
|
68
|
+
var img1 = "";
|
|
69
|
+
var img2 = "";
|
|
70
|
+
|
|
71
|
+
var SelectorTree = function (_React$Component) {
|
|
72
|
+
(0, _inherits3.default)(SelectorTree, _React$Component);
|
|
73
|
+
|
|
74
|
+
function SelectorTree(props) {
|
|
75
|
+
(0, _classCallCheck3.default)(this, SelectorTree);
|
|
76
|
+
|
|
77
|
+
var _this = (0, _possibleConstructorReturn3.default)(this, (SelectorTree.__proto__ || (0, _getPrototypeOf2.default)(SelectorTree)).call(this, props));
|
|
78
|
+
|
|
79
|
+
_initialiseProps.call(_this);
|
|
80
|
+
|
|
81
|
+
_this.state = {
|
|
82
|
+
checkedKeys: [], //选中的值
|
|
83
|
+
selectedKeys: [], //选中节点的数据
|
|
84
|
+
expandedKeys: [],
|
|
85
|
+
searchValue: "",
|
|
86
|
+
autoExpandParent: true,
|
|
87
|
+
data: [], //树数据
|
|
88
|
+
dataList: [], //树列表数据,主要在过滤的时候使用
|
|
89
|
+
singerDataMap: {}, //单选时可以选择的数据,主要在选中数据的时候获取key所对应的完整的值
|
|
90
|
+
multiDataMap: {} //多选时可以选择的数据,主要在选中数据的时候获取key所对应的完整的值
|
|
91
|
+
};
|
|
92
|
+
return _this;
|
|
93
|
+
}
|
|
94
|
+
|
|
95
|
+
/**
|
|
96
|
+
* 查询数据
|
|
97
|
+
*/
|
|
98
|
+
|
|
99
|
+
//设置可以传递参数的默认值
|
|
100
|
+
|
|
101
|
+
|
|
102
|
+
/**
|
|
103
|
+
* 获取数据最上一个节点的父节点
|
|
104
|
+
*/
|
|
105
|
+
|
|
106
|
+
|
|
107
|
+
/**
|
|
108
|
+
* 装换数据的格式
|
|
109
|
+
*/
|
|
110
|
+
|
|
111
|
+
|
|
112
|
+
//获取所有节点数据
|
|
113
|
+
|
|
114
|
+
|
|
115
|
+
//多选时只能选择最后一级的数据,且这个数据select_flag属性不能是0(0表示不能选择)
|
|
116
|
+
|
|
117
|
+
|
|
118
|
+
//单选时数据select_flag属性不能是0(0表示不能选择)
|
|
119
|
+
|
|
120
|
+
//搜索输入变化事件
|
|
121
|
+
|
|
122
|
+
|
|
123
|
+
//字段限制返回
|
|
124
|
+
|
|
125
|
+
|
|
126
|
+
//树字段限制
|
|
127
|
+
|
|
128
|
+
|
|
129
|
+
//单选,选中了数据
|
|
130
|
+
|
|
131
|
+
//多选,选中了选择框
|
|
132
|
+
|
|
133
|
+
|
|
134
|
+
//渲染tree
|
|
135
|
+
|
|
136
|
+
|
|
137
|
+
(0, _createClass3.default)(SelectorTree, [{
|
|
138
|
+
key: "render",
|
|
139
|
+
value: function render() {
|
|
140
|
+
var _this2 = this;
|
|
141
|
+
|
|
142
|
+
return _react2.default.createElement(
|
|
143
|
+
Sider,
|
|
144
|
+
{
|
|
145
|
+
className: "dlt-selector-tree-div",
|
|
146
|
+
style: { background: "#fff", height: "100%" },
|
|
147
|
+
width: this.props.width
|
|
148
|
+
},
|
|
149
|
+
_react2.default.createElement(
|
|
150
|
+
"div",
|
|
151
|
+
{
|
|
152
|
+
className: "dlt-selector-tree-searchHeader",
|
|
153
|
+
style: { paddingLeft: 8 }
|
|
154
|
+
},
|
|
155
|
+
_react2.default.createElement(Search, {
|
|
156
|
+
className: "dlt-selector-tree-searchInput",
|
|
157
|
+
placeholder: "\u8BF7\u8F93\u5165\u67E5\u8BE2\u6761\u4EF6",
|
|
158
|
+
onChange: this.onChange,
|
|
159
|
+
ref: function ref(node) {
|
|
160
|
+
_this2.input = node;
|
|
161
|
+
},
|
|
162
|
+
style: { width: this.props.width - 20, marginRight: 10 }
|
|
163
|
+
})
|
|
164
|
+
),
|
|
165
|
+
this.state.dataList.length === 0 ? _react2.default.createElement(
|
|
166
|
+
"div",
|
|
167
|
+
{ className: "dlt-selector-tree-load-div" },
|
|
168
|
+
"\u6B63\u5728\u52A0\u8F7D\u6570\u636E"
|
|
169
|
+
) : _react2.default.createElement(
|
|
170
|
+
_reactCustomScrollbarsPatched.Scrollbars,
|
|
171
|
+
{
|
|
172
|
+
autoHide: true,
|
|
173
|
+
style: {
|
|
174
|
+
flex: "0 0 " + this.props.width + "px",
|
|
175
|
+
height: parseInt(this.props.height, 10) - 40
|
|
176
|
+
}
|
|
177
|
+
},
|
|
178
|
+
_react2.default.createElement(
|
|
179
|
+
_tree2.default,
|
|
180
|
+
{
|
|
181
|
+
showIcon: this.props.showIcon,
|
|
182
|
+
checkable: this.props.checkable,
|
|
183
|
+
onExpand: this.onExpand,
|
|
184
|
+
expandedKeys: this.state.expandedKeys,
|
|
185
|
+
autoExpandParent: this.state.autoExpandParent,
|
|
186
|
+
onCheck: this.onCheck,
|
|
187
|
+
checkedKeys: this.state.checkedKeys //选中复选框的数据
|
|
188
|
+
, selectedKeys: this.state.selectedKeys //选中节点的数据
|
|
189
|
+
, onSelect: this.onSelect
|
|
190
|
+
},
|
|
191
|
+
this.loop(this.state.data, 1)
|
|
192
|
+
)
|
|
193
|
+
)
|
|
194
|
+
);
|
|
195
|
+
}
|
|
196
|
+
}]);
|
|
197
|
+
return SelectorTree;
|
|
198
|
+
}(_react2.default.Component);
|
|
199
|
+
|
|
200
|
+
SelectorTree.defaultProps = {
|
|
201
|
+
keyField: undefined, //主键字段
|
|
202
|
+
sign: undefined, //获取查询语句的标志
|
|
203
|
+
showIcon: false, //是否显示树图标
|
|
204
|
+
url: undefined, //查询数据的url
|
|
205
|
+
checkable: true, //默认开启多选框
|
|
206
|
+
width: undefined, //树的宽度
|
|
207
|
+
height: undefined, //树的高度
|
|
208
|
+
onSelect: undefined, //选中数据的回调方法
|
|
209
|
+
params: {}, //查询条件
|
|
210
|
+
sqlParams: undefined //sql语句内的参数
|
|
211
|
+
};
|
|
212
|
+
|
|
213
|
+
var _initialiseProps = function _initialiseProps() {
|
|
214
|
+
var _this3 = this;
|
|
215
|
+
|
|
216
|
+
this.getData = function () {
|
|
217
|
+
var obj = _this3;
|
|
218
|
+
(0, _index.NHFetch)(_this3.props.url, "POST", {
|
|
219
|
+
keyField: _this3.props.keyField,
|
|
220
|
+
params: _this3.props.params,
|
|
221
|
+
sign: _this3.props.sign,
|
|
222
|
+
sqlParams: _this3.props.sqlParams
|
|
223
|
+
}).then(function (res) {
|
|
224
|
+
if (res && res.data) {
|
|
225
|
+
var root = _this3.getDataRoot(res.data);
|
|
226
|
+
var data = _this3.buildData(res.data, root);
|
|
227
|
+
var dataList = obj.generateList(data);
|
|
228
|
+
var singerDataMap = obj.getSingerDataMap(data);
|
|
229
|
+
var multiDataMap = obj.getMultiDataMap(data);
|
|
230
|
+
var key = data[0].KEY || data[0].key;
|
|
231
|
+
obj.setState({
|
|
232
|
+
data: data,
|
|
233
|
+
expandedKeys: [key],
|
|
234
|
+
dataList: dataList,
|
|
235
|
+
singerDataMap: singerDataMap,
|
|
236
|
+
multiDataMap: multiDataMap
|
|
237
|
+
});
|
|
238
|
+
}
|
|
239
|
+
});
|
|
240
|
+
};
|
|
241
|
+
|
|
242
|
+
this.getDataRoot = function (data) {
|
|
243
|
+
var keys = {};
|
|
244
|
+
var parentKeys = [];
|
|
245
|
+
for (var i = 0; i < data.length; i++) {
|
|
246
|
+
var key = data[i].KEY || data[i].key;
|
|
247
|
+
var fid = data[i].FID || data[i].fid;
|
|
248
|
+
keys[key] = 1;
|
|
249
|
+
parentKeys.push(fid);
|
|
250
|
+
}
|
|
251
|
+
for (var _i = 0; _i < parentKeys.length; _i++) {
|
|
252
|
+
if (keys[parentKeys[_i]] !== 1) {
|
|
253
|
+
return parentKeys[_i];
|
|
254
|
+
}
|
|
255
|
+
}
|
|
256
|
+
return "-1";
|
|
257
|
+
};
|
|
258
|
+
|
|
259
|
+
this.buildData = function (data, parentKey) {
|
|
260
|
+
if (!data || data.length <= 0) {
|
|
261
|
+
return null;
|
|
262
|
+
}
|
|
263
|
+
var resultList = [];
|
|
264
|
+
for (var i = 0; i < data.length; i++) {
|
|
265
|
+
var fid = data[i].FID || data[i].fid;
|
|
266
|
+
if (fid === parentKey) {
|
|
267
|
+
var key = data[i].KEY || data[i].key;
|
|
268
|
+
var childrenList = _this3.buildData(data, key);
|
|
269
|
+
if (childrenList.length > 0) {
|
|
270
|
+
data[i].children = childrenList;
|
|
271
|
+
}
|
|
272
|
+
resultList.push(data[i]);
|
|
273
|
+
}
|
|
274
|
+
}
|
|
275
|
+
return resultList;
|
|
276
|
+
};
|
|
277
|
+
|
|
278
|
+
this.onExpand = function (expandedKeys) {
|
|
279
|
+
_this3.setState({
|
|
280
|
+
expandedKeys: expandedKeys,
|
|
281
|
+
autoExpandParent: false
|
|
282
|
+
});
|
|
283
|
+
};
|
|
284
|
+
|
|
285
|
+
this.generateList = function (data, parentKey) {
|
|
286
|
+
var dataList = [];
|
|
287
|
+
if (data === null || data === undefined || data.length === 0) {
|
|
288
|
+
return [];
|
|
289
|
+
}
|
|
290
|
+
for (var i = 0; i < data.length; i++) {
|
|
291
|
+
var key = data[i].KEY || data[i].key;
|
|
292
|
+
var title = data[i].TITLE || data[i].title;
|
|
293
|
+
dataList.push({ key: key, title: title, fid: parentKey });
|
|
294
|
+
if (data[i].children && data[i].children.length > 0) {
|
|
295
|
+
dataList = dataList.concat(_this3.generateList(data[i].children, key));
|
|
296
|
+
}
|
|
297
|
+
}
|
|
298
|
+
return dataList;
|
|
299
|
+
};
|
|
300
|
+
|
|
301
|
+
this.getMultiDataMap = function (data) {
|
|
302
|
+
var map = {};
|
|
303
|
+
if (!data || data.length <= 0) {
|
|
304
|
+
return {};
|
|
305
|
+
}
|
|
306
|
+
for (var i = 0; i < data.length; i++) {
|
|
307
|
+
var selectFlag = data[i].SELECT_FLAG || data[i].selectFlag || data[i].select_flag;
|
|
308
|
+
var key = data[i].KEY || data[i].key;
|
|
309
|
+
if ((!data[i].children || data[i].children.length <= 0) && selectFlag !== "0" && selectFlag !== 0) {
|
|
310
|
+
var value = _this3.copyMap(data[i]);
|
|
311
|
+
map[key] = value;
|
|
312
|
+
} else if (data[i].children && data[i].children.length > 0) {
|
|
313
|
+
var childrenMap = _this3.getMultiDataMap(data[i].children);
|
|
314
|
+
for (var _key in childrenMap) {
|
|
315
|
+
map[_key] = childrenMap[_key];
|
|
316
|
+
}
|
|
317
|
+
}
|
|
318
|
+
}
|
|
319
|
+
return map;
|
|
320
|
+
};
|
|
321
|
+
|
|
322
|
+
this.getSingerDataMap = function (data) {
|
|
323
|
+
var map = {};
|
|
324
|
+
if (!data || data.length <= 0) {
|
|
325
|
+
return {};
|
|
326
|
+
}
|
|
327
|
+
for (var i = 0; i < data.length; i++) {
|
|
328
|
+
var selectFlag = data[i].SELECT_FLAG || data[i].selectFlag || data[i].select_flag;
|
|
329
|
+
if (selectFlag !== "0" && selectFlag !== 0) {
|
|
330
|
+
var key = data[i].KEY || data[i].key;
|
|
331
|
+
var value = _this3.copyMap(data[i]);
|
|
332
|
+
map[key] = value;
|
|
333
|
+
}
|
|
334
|
+
if (data[i].children && data[i].children.length > 0) {
|
|
335
|
+
var childrenMap = _this3.getSingerDataMap(data[i].children);
|
|
336
|
+
for (var _key2 in childrenMap) {
|
|
337
|
+
map[_key2] = childrenMap[_key2];
|
|
338
|
+
}
|
|
339
|
+
}
|
|
340
|
+
}
|
|
341
|
+
return map;
|
|
342
|
+
};
|
|
343
|
+
|
|
344
|
+
this.copyMap = function (map) {
|
|
345
|
+
var resultMap = {};
|
|
346
|
+
for (var key in map) {
|
|
347
|
+
if (key !== "children") {
|
|
348
|
+
resultMap[key] = map[key];
|
|
349
|
+
}
|
|
350
|
+
}
|
|
351
|
+
return resultMap;
|
|
352
|
+
};
|
|
353
|
+
|
|
354
|
+
this.onChange = function (e) {
|
|
355
|
+
var value = e.target.value;
|
|
356
|
+
if (value) {
|
|
357
|
+
value = value.trim();
|
|
358
|
+
}
|
|
359
|
+
var expandedKeys = _this3.state.dataList.map(function (item) {
|
|
360
|
+
var title = item.TITLE || item.title;
|
|
361
|
+
if (title.indexOf(value) > -1) {
|
|
362
|
+
var fid = item.FID || item.fid;
|
|
363
|
+
return fid ? fid : null;
|
|
364
|
+
}
|
|
365
|
+
return null;
|
|
366
|
+
}).filter(function (item, i, self) {
|
|
367
|
+
return item && self.indexOf(item) === i;
|
|
368
|
+
});
|
|
369
|
+
if (value === "" || !expandedKeys) {
|
|
370
|
+
if (_this3.state.data && _this3.state.data.length > 0) {
|
|
371
|
+
expandedKeys = [_this3.state.data[0].KEY || _this3.state.data[0].key];
|
|
372
|
+
} else {
|
|
373
|
+
expandedKeys = [];
|
|
374
|
+
}
|
|
375
|
+
}
|
|
376
|
+
_this3.setState({
|
|
377
|
+
expandedKeys: expandedKeys,
|
|
378
|
+
searchValue: value,
|
|
379
|
+
autoExpandParent: true
|
|
380
|
+
});
|
|
381
|
+
};
|
|
382
|
+
|
|
383
|
+
this.modifyTextLength = function (str, len) {
|
|
384
|
+
if (str.length * 2 <= len || len === undefined) {
|
|
385
|
+
return str;
|
|
386
|
+
}
|
|
387
|
+
var strlen = 0;
|
|
388
|
+
var val = "";
|
|
389
|
+
for (var i = 0; i < str.length; i++) {
|
|
390
|
+
val = val + str.charAt(i);
|
|
391
|
+
if (str.charCodeAt(i) > 128) {
|
|
392
|
+
strlen = strlen + 2;
|
|
393
|
+
if (strlen >= len) {
|
|
394
|
+
return val.substring(0, val.length - 1) + "...";
|
|
395
|
+
}
|
|
396
|
+
} else {
|
|
397
|
+
strlen = strlen + 1;
|
|
398
|
+
if (strlen >= len) {
|
|
399
|
+
return val.substring(0, val.length - 2) + "...";
|
|
400
|
+
}
|
|
401
|
+
}
|
|
402
|
+
}
|
|
403
|
+
return val;
|
|
404
|
+
};
|
|
405
|
+
|
|
406
|
+
this.getTextLength = function (val) {
|
|
407
|
+
var width = parseInt(_this3.props.width, 10) - (_this3.props.checkable ? 55 : 35);
|
|
408
|
+
var count = width / 15;
|
|
409
|
+
count = count + 1 - val;
|
|
410
|
+
//如果需要显示图标,则能够显示的字减少一个
|
|
411
|
+
if (_this3.props.showIcon) {
|
|
412
|
+
count = count - 1;
|
|
413
|
+
}
|
|
414
|
+
return parseInt(count, 10) * 2;
|
|
415
|
+
};
|
|
416
|
+
|
|
417
|
+
this.onSelect = function (checkedKeys) {
|
|
418
|
+
if (_this3.props.checkable !== true) {
|
|
419
|
+
var selectKeys = [];
|
|
420
|
+
var selectNodes = [];
|
|
421
|
+
for (var seq in checkedKeys) {
|
|
422
|
+
var checkedKey = checkedKeys[seq];
|
|
423
|
+
if (_this3.state.singerDataMap[checkedKey]) {
|
|
424
|
+
selectKeys.push(checkedKey);
|
|
425
|
+
selectNodes.push(_this3.state.singerDataMap[checkedKey]);
|
|
426
|
+
}
|
|
427
|
+
}
|
|
428
|
+
if (_this3.props.onSelect) {
|
|
429
|
+
_this3.props.onSelect(selectKeys, selectNodes);
|
|
430
|
+
}
|
|
431
|
+
}
|
|
432
|
+
_this3.setState({
|
|
433
|
+
selectedKeys: checkedKeys
|
|
434
|
+
});
|
|
435
|
+
};
|
|
436
|
+
|
|
437
|
+
this.onCheck = function (checkedKeys) {
|
|
438
|
+
_this3.setState({ checkedKeys: checkedKeys });
|
|
439
|
+
if (_this3.props.checkable === true) {
|
|
440
|
+
var selectKeys = [];
|
|
441
|
+
var selectNodes = [];
|
|
442
|
+
for (var seq in checkedKeys) {
|
|
443
|
+
var checkedKey = checkedKeys[seq];
|
|
444
|
+
if (_this3.state.multiDataMap[checkedKey]) {
|
|
445
|
+
selectKeys.push(checkedKey);
|
|
446
|
+
selectNodes.push(_this3.state.multiDataMap[checkedKey]);
|
|
447
|
+
}
|
|
448
|
+
}
|
|
449
|
+
if (_this3.props.onSelect) {
|
|
450
|
+
_this3.props.onSelect(selectKeys, selectNodes);
|
|
451
|
+
}
|
|
452
|
+
}
|
|
453
|
+
};
|
|
454
|
+
|
|
455
|
+
this.handleTreeIcon = function (props) {
|
|
456
|
+
var icon = props.dataRef.ICON || props.dataRef.icon;
|
|
457
|
+
if (icon === 1 || icon === "1") {
|
|
458
|
+
return _react2.default.createElement("img", { src: img1, alt: "" });
|
|
459
|
+
} else if (icon === 2 || icon === "2") {
|
|
460
|
+
return _react2.default.createElement("img", { src: img2, alt: "" });
|
|
461
|
+
}
|
|
462
|
+
return _react2.default.createElement("img", { src: img1, alt: "" });
|
|
463
|
+
};
|
|
464
|
+
|
|
465
|
+
this.loop = function (data, level) {
|
|
466
|
+
return data.map(function (item) {
|
|
467
|
+
var searchValue = _this3.state.searchValue;
|
|
468
|
+
|
|
469
|
+
var bt = item.TITLE || item.title;
|
|
470
|
+
var val = _this3.modifyTextLength(bt, _this3.getTextLength(level));
|
|
471
|
+
var index = val.indexOf(searchValue);
|
|
472
|
+
var beforeStr = val.substr(0, index);
|
|
473
|
+
var afterStr = val.substr(index + searchValue.length);
|
|
474
|
+
var titleContent = _react2.default.createElement(
|
|
475
|
+
"div",
|
|
476
|
+
{ style: { padding: "5px" } },
|
|
477
|
+
bt
|
|
478
|
+
);
|
|
479
|
+
var title = index > -1 ? _react2.default.createElement(
|
|
480
|
+
"span",
|
|
481
|
+
null,
|
|
482
|
+
beforeStr,
|
|
483
|
+
_react2.default.createElement(
|
|
484
|
+
"span",
|
|
485
|
+
{ style: { color: "#f50" } },
|
|
486
|
+
searchValue
|
|
487
|
+
),
|
|
488
|
+
afterStr
|
|
489
|
+
) : _react2.default.createElement(
|
|
490
|
+
"span",
|
|
491
|
+
null,
|
|
492
|
+
val
|
|
493
|
+
);
|
|
494
|
+
if (val.indexOf("...") > -1) {
|
|
495
|
+
title = _react2.default.createElement(
|
|
496
|
+
_popover2.default,
|
|
497
|
+
{ placement: "right", content: titleContent, trigger: "hover" },
|
|
498
|
+
title
|
|
499
|
+
);
|
|
500
|
+
}
|
|
501
|
+
|
|
502
|
+
var key = item.KEY || item.key;
|
|
503
|
+
if (item.children) {
|
|
504
|
+
return _react2.default.createElement(
|
|
505
|
+
TreeNode,
|
|
506
|
+
{
|
|
507
|
+
key: key,
|
|
508
|
+
icon: _this3.handleTreeIcon,
|
|
509
|
+
title: title,
|
|
510
|
+
dataRef: item,
|
|
511
|
+
disabled: _this3.props.disabled
|
|
512
|
+
},
|
|
513
|
+
_this3.loop(item.children, level + 1)
|
|
514
|
+
);
|
|
515
|
+
}
|
|
516
|
+
return _react2.default.createElement(TreeNode, {
|
|
517
|
+
key: key,
|
|
518
|
+
icon: _this3.handleTreeIcon,
|
|
519
|
+
title: title,
|
|
520
|
+
dataRef: item,
|
|
521
|
+
disabled: _this3.props.disabled
|
|
522
|
+
});
|
|
523
|
+
});
|
|
524
|
+
};
|
|
525
|
+
|
|
526
|
+
this.renderTreeNodes = function (data) {
|
|
527
|
+
return data.map(function (item) {
|
|
528
|
+
var title = item.TITLE || item.title;
|
|
529
|
+
var key = item.KEY || item.key;
|
|
530
|
+
if (item.children) {
|
|
531
|
+
return _react2.default.createElement(
|
|
532
|
+
TreeNode,
|
|
533
|
+
{ title: title, key: key, dataRef: item },
|
|
534
|
+
_this3.renderTreeNodes(item.children)
|
|
535
|
+
);
|
|
536
|
+
}
|
|
537
|
+
return _react2.default.createElement(TreeNode, { dataRef: item });
|
|
538
|
+
});
|
|
539
|
+
};
|
|
540
|
+
|
|
541
|
+
this.setCheckedKeys = function (checkedKeys) {
|
|
542
|
+
_this3.setState({
|
|
543
|
+
checkedKeys: checkedKeys
|
|
544
|
+
});
|
|
545
|
+
};
|
|
546
|
+
|
|
547
|
+
this.setSelectedKeys = function (selectedKeys) {
|
|
548
|
+
_this3.setState({
|
|
549
|
+
selectedKeys: selectedKeys
|
|
550
|
+
});
|
|
551
|
+
};
|
|
552
|
+
};
|
|
553
|
+
|
|
554
|
+
exports.default = SelectorTree;
|