dlt-for-react 2.0.16 → 2.1.0

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.
@@ -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;
@@ -16,25 +16,17 @@ function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { de
16
16
  * @param {*} processId 流程的ID
17
17
  */
18
18
  var toFormFillingPage = function toFormFillingPage(processId, docUnid, callback) {
19
- var key = arguments.length > 3 && arguments[3] !== undefined ? arguments[3] : "docUnid";
20
- var csbz = arguments.length > 4 && arguments[4] !== undefined ? arguments[4] : undefined;
19
+ var csbz = arguments.length > 3 && arguments[3] !== undefined ? arguments[3] : undefined;
21
20
 
22
21
  var flag = !csbz ? "XTGL_BPM_URL" : csbz;
23
22
  (0, _NHFetch2.default)(window.xtglUrl + "/common/parameters/get", "POST", [flag]).then(function (res) {
24
23
  if (res) {
25
24
  var url = res.data[flag];
26
- var myWindow = window.open(!csbz ? url + "/#/formRender/run?processId=" + processId + "&" + key + "=" + docUnid : url + "processId=" + processId + "&docUnid=" + docUnid);
25
+ var myWindow = window.open(!csbz ? url + "/#/formRender/run?processId=" + processId + "&docUnid=" + docUnid : url + "processId=" + processId + "&docUnid=" + docUnid);
27
26
  if (callback) {
28
27
  callback(myWindow, url);
29
28
  }
30
29
  }
31
30
  });
32
- }; /*
33
- * @FilePath: \xgui-for-react\src\utils\toFormFillingPage.js
34
- * @Description:
35
- * @Author: jiangzhongxin
36
- * @LastEditors: jiangzhongxin
37
- * @LastEditTime: 2024-05-07 14:52:18
38
- * @Copyright: 2024 LIANYI TECHNOLOGY CO.,LTD. All Rights Reserved. 联奕科技有限公司
39
- */
31
+ };
40
32
  exports.default = toFormFillingPage;
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "dlt-for-react",
3
- "version": "2.0.16",
3
+ "version": "2.1.0",
4
4
  "description": "dlt for react",
5
5
  "main": "lib/index.js",
6
6
  "scripts": {
@@ -1,40 +0,0 @@
1
- 'use strict';
2
-
3
- Object.defineProperty(exports, "__esModule", {
4
- value: true
5
- });
6
- //获取UUID
7
- var createUuid = function createUuid() {
8
- var len = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : 32;
9
- var radix = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : 16;
10
-
11
- var chars = '0123456789abcdefghijklmnopqrstuvwxyz'.split('');
12
- var uuid = [],
13
- i;
14
- radix = radix || chars.length;
15
-
16
- if (len) {
17
- // Compact form
18
- for (i = 0; i < len; i++) {
19
- uuid[i] = chars[0 | Math.random() * radix];
20
- }
21
- } else {
22
- // rfc4122, version 4 form
23
- var r;
24
-
25
- // rfc4122 requires these characters
26
- uuid[8] = uuid[13] = uuid[18] = uuid[23] = '-';
27
- uuid[14] = '4';
28
-
29
- // Fill in random data. At i==19 set the high bits of clock sequence as
30
- // per rfc4122, sec. 4.1.5
31
- for (i = 0; i < 36; i++) {
32
- if (!uuid[i]) {
33
- r = 0 | Math.random() * 16;
34
- uuid[i] = chars[i == 19 ? r & 0x3 | 0x8 : r];
35
- }
36
- }
37
- }
38
- return uuid.join('');
39
- };
40
- exports.default = createUuid;
@@ -1,10 +0,0 @@
1
- 'use strict';
2
-
3
- Object.defineProperty(exports, "__esModule", {
4
- value: true
5
- });
6
- var getLoginUser = function getLoginUser(auth) {
7
- var loginUser = sessionStorage.getItem('userLogin') ? JSON.parse(sessionStorage.getItem('userLogin')) : { authorization: {}, menus: [] };
8
- return loginUser;
9
- };
10
- exports.default = getLoginUser;
@@ -1,27 +0,0 @@
1
- 'use strict';
2
-
3
- Object.defineProperty(exports, "__esModule", {
4
- value: true
5
- });
6
- var getSize = function getSize() {
7
- var setting = sessionStorage.getItem('setting');
8
- var breadcrumbHeight = 0; //面包屑高度
9
- if (setting) {
10
- // 存在布局配置
11
- var _JSON$parse = JSON.parse(setting),
12
- layout = _JSON$parse.layout;
13
-
14
- breadcrumbHeight = layout === 'mixmenu' ? 40 : 0; //若是混合布局 contentH高度需要减去面包屑高度
15
- }
16
- var windowW = void 0,
17
- windowH = void 0,
18
- contentH = void 0,
19
- scrollT = void 0;
20
- windowH = window.innerHeight;
21
- windowW = window.innerWidth;
22
- scrollT = document.documentElement.scrollTop || document.body.scrollTop;
23
- contentH = windowH - 65 - breadcrumbHeight;
24
- return { windowW: windowW, windowH: windowH, contentH: contentH, scrollT: scrollT };
25
- };
26
-
27
- exports.default = getSize;