react-split-pane 2.0.2 → 3.0.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.
- package/README.md +342 -144
- package/dist/components/Divider.d.ts +31 -0
- package/dist/components/Divider.d.ts.map +1 -0
- package/dist/components/Pane.d.ts +27 -0
- package/dist/components/Pane.d.ts.map +1 -0
- package/dist/components/SplitPane.d.ts +29 -0
- package/dist/components/SplitPane.d.ts.map +1 -0
- package/dist/hooks/useKeyboardResize.d.ts +34 -0
- package/dist/hooks/useKeyboardResize.d.ts.map +1 -0
- package/dist/hooks/usePaneSize.d.ts +16 -0
- package/dist/hooks/usePaneSize.d.ts.map +1 -0
- package/dist/hooks/useResizer.d.ts +44 -0
- package/dist/hooks/useResizer.d.ts.map +1 -0
- package/dist/index.cjs +2 -0
- package/dist/index.cjs.map +1 -0
- package/dist/index.d.ts +8 -0
- package/dist/index.d.ts.map +1 -0
- package/dist/index.js +2 -0
- package/dist/index.js.map +1 -0
- package/dist/keyboard.cjs +2 -0
- package/dist/keyboard.cjs.map +1 -0
- package/dist/keyboard.d.ts +3 -0
- package/dist/keyboard.d.ts.map +1 -0
- package/dist/keyboard.js +2 -0
- package/dist/keyboard.js.map +1 -0
- package/dist/persistence.cjs +2 -0
- package/dist/persistence.cjs.map +1 -0
- package/dist/persistence.d.ts +24 -0
- package/dist/persistence.d.ts.map +1 -0
- package/dist/persistence.js +2 -0
- package/dist/persistence.js.map +1 -0
- package/dist/test/setup.d.ts +2 -0
- package/dist/test/setup.d.ts.map +1 -0
- package/dist/types/index.d.ts +89 -0
- package/dist/types/index.d.ts.map +1 -0
- package/dist/utils/accessibility.d.ts +17 -0
- package/dist/utils/accessibility.d.ts.map +1 -0
- package/dist/utils/calculations.d.ts +29 -0
- package/dist/utils/calculations.d.ts.map +1 -0
- package/package.json +82 -67
- package/styles.css +106 -0
- package/.editorconfig +0 -6
- package/.idea/jsLibraryMappings.xml +0 -6
- package/.idea/misc.xml +0 -7
- package/.idea/modules.xml +0 -8
- package/.idea/react-split-pane.iml +0 -9
- package/.idea/shelf/Get_Resizer_dimensions/shelved.patch +0 -206
- package/.idea/shelf/Get_Resizer_dimensions.xml +0 -4
- package/.idea/shelf/use_now_sh_instead_of_surge_sh/shelved.patch +0 -1799
- package/.idea/shelf/use_now_sh_instead_of_surge_sh.xml +0 -4
- package/.idea/shelf/wip_events/shelved.patch +0 -456
- package/.idea/shelf/wip_events.xml +0 -4
- package/.idea/vcs.xml +0 -6
- package/.idea/workspace.xml +0 -1819
- package/.storybook/addons.js +0 -2
- package/.storybook/config.js +0 -9
- package/.storybook/preview-head.html +0 -33
- package/.travis.yml +0 -10
- package/index.d.ts +0 -53
- package/index.js +0 -3
- package/lib/Pane.js +0 -130
- package/lib/Resizer.js +0 -105
- package/lib/SplitPane.js +0 -505
- package/stories/index.stories.js +0 -40
- package/tsconfig.json +0 -11
package/lib/SplitPane.js
DELETED
|
@@ -1,505 +0,0 @@
|
|
|
1
|
-
'use strict';
|
|
2
|
-
|
|
3
|
-
Object.defineProperty(exports, "__esModule", {
|
|
4
|
-
value: true
|
|
5
|
-
});
|
|
6
|
-
|
|
7
|
-
var _createClass = function () { function defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if ("value" in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } } return function (Constructor, protoProps, staticProps) { if (protoProps) defineProperties(Constructor.prototype, protoProps); if (staticProps) defineProperties(Constructor, staticProps); return Constructor; }; }();
|
|
8
|
-
|
|
9
|
-
exports.getUnit = getUnit;
|
|
10
|
-
exports.convertSizeToCssValue = convertSizeToCssValue;
|
|
11
|
-
|
|
12
|
-
var _react = require('react');
|
|
13
|
-
|
|
14
|
-
var _react2 = _interopRequireDefault(_react);
|
|
15
|
-
|
|
16
|
-
var _propTypes = require('prop-types');
|
|
17
|
-
|
|
18
|
-
var _propTypes2 = _interopRequireDefault(_propTypes);
|
|
19
|
-
|
|
20
|
-
var _glamorous = require('glamorous');
|
|
21
|
-
|
|
22
|
-
var _glamorous2 = _interopRequireDefault(_glamorous);
|
|
23
|
-
|
|
24
|
-
var _Resizer = require('./Resizer');
|
|
25
|
-
|
|
26
|
-
var _Resizer2 = _interopRequireDefault(_Resizer);
|
|
27
|
-
|
|
28
|
-
var _Pane = require('./Pane');
|
|
29
|
-
|
|
30
|
-
var _Pane2 = _interopRequireDefault(_Pane);
|
|
31
|
-
|
|
32
|
-
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
|
|
33
|
-
|
|
34
|
-
function _toConsumableArray(arr) { if (Array.isArray(arr)) { for (var i = 0, arr2 = Array(arr.length); i < arr.length; i++) { arr2[i] = arr[i]; } return arr2; } else { return Array.from(arr); } }
|
|
35
|
-
|
|
36
|
-
function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } }
|
|
37
|
-
|
|
38
|
-
function _possibleConstructorReturn(self, call) { if (!self) { throw new ReferenceError("this hasn't been initialised - super() hasn't been called"); } return call && (typeof call === "object" || typeof call === "function") ? call : self; }
|
|
39
|
-
|
|
40
|
-
function _inherits(subClass, superClass) { if (typeof superClass !== "function" && superClass !== null) { throw new TypeError("Super expression must either be null or a function, not " + typeof superClass); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, enumerable: false, writable: true, configurable: true } }); if (superClass) Object.setPrototypeOf ? Object.setPrototypeOf(subClass, superClass) : subClass.__proto__ = superClass; }
|
|
41
|
-
|
|
42
|
-
var DEFAULT_PANE_SIZE = '1';
|
|
43
|
-
var DEFAULT_PANE_MIN_SIZE = '0';
|
|
44
|
-
var DEFAULT_PANE_MAX_SIZE = '100%';
|
|
45
|
-
|
|
46
|
-
var ColumnStyle = _glamorous2.default.div({
|
|
47
|
-
display: 'flex',
|
|
48
|
-
height: '100%',
|
|
49
|
-
flexDirection: 'column',
|
|
50
|
-
flex: 1,
|
|
51
|
-
outline: 'none',
|
|
52
|
-
overflow: 'hidden',
|
|
53
|
-
userSelect: 'text'
|
|
54
|
-
});
|
|
55
|
-
|
|
56
|
-
var RowStyle = _glamorous2.default.div({
|
|
57
|
-
display: 'flex',
|
|
58
|
-
height: '100%',
|
|
59
|
-
flexDirection: 'row',
|
|
60
|
-
flex: 1,
|
|
61
|
-
outline: 'none',
|
|
62
|
-
overflow: 'hidden',
|
|
63
|
-
userSelect: 'text'
|
|
64
|
-
});
|
|
65
|
-
|
|
66
|
-
function convert(str, size) {
|
|
67
|
-
var tokens = str.match(/([0-9]+)([px|%]*)/);
|
|
68
|
-
var value = tokens[1];
|
|
69
|
-
var unit = tokens[2];
|
|
70
|
-
return toPx(value, unit, size);
|
|
71
|
-
}
|
|
72
|
-
|
|
73
|
-
function toPx(value) {
|
|
74
|
-
var unit = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : 'px';
|
|
75
|
-
var size = arguments[2];
|
|
76
|
-
|
|
77
|
-
switch (unit) {
|
|
78
|
-
case '%':
|
|
79
|
-
{
|
|
80
|
-
return +(size * value / 100).toFixed(2);
|
|
81
|
-
}
|
|
82
|
-
default:
|
|
83
|
-
{
|
|
84
|
-
return +value;
|
|
85
|
-
}
|
|
86
|
-
}
|
|
87
|
-
}
|
|
88
|
-
|
|
89
|
-
function getUnit(size) {
|
|
90
|
-
if (size.endsWith('px')) {
|
|
91
|
-
return 'px';
|
|
92
|
-
}
|
|
93
|
-
|
|
94
|
-
if (size.endsWith('%')) {
|
|
95
|
-
return '%';
|
|
96
|
-
}
|
|
97
|
-
|
|
98
|
-
return 'ratio';
|
|
99
|
-
}
|
|
100
|
-
|
|
101
|
-
function convertSizeToCssValue(value, resizersSize) {
|
|
102
|
-
if (getUnit(value) !== '%') {
|
|
103
|
-
return value;
|
|
104
|
-
}
|
|
105
|
-
|
|
106
|
-
if (!resizersSize) {
|
|
107
|
-
return value;
|
|
108
|
-
}
|
|
109
|
-
|
|
110
|
-
var idx = value.search('%');
|
|
111
|
-
var percent = value.slice(0, idx) / 100;
|
|
112
|
-
if (percent === 0) {
|
|
113
|
-
return value;
|
|
114
|
-
}
|
|
115
|
-
|
|
116
|
-
return 'calc(' + value + ' - ' + resizersSize + 'px*' + percent + ')';
|
|
117
|
-
}
|
|
118
|
-
|
|
119
|
-
function convertToUnit(size, unit, containerSize) {
|
|
120
|
-
switch (unit) {
|
|
121
|
-
case '%':
|
|
122
|
-
return (size / containerSize * 100).toFixed(2) + '%';
|
|
123
|
-
case 'px':
|
|
124
|
-
return size.toFixed(2) + 'px';
|
|
125
|
-
case 'ratio':
|
|
126
|
-
return (size * 100).toFixed(0);
|
|
127
|
-
}
|
|
128
|
-
}
|
|
129
|
-
|
|
130
|
-
var SplitPane = function (_Component) {
|
|
131
|
-
_inherits(SplitPane, _Component);
|
|
132
|
-
|
|
133
|
-
function SplitPane(props) {
|
|
134
|
-
_classCallCheck(this, SplitPane);
|
|
135
|
-
|
|
136
|
-
var _this = _possibleConstructorReturn(this, (SplitPane.__proto__ || Object.getPrototypeOf(SplitPane)).call(this, props));
|
|
137
|
-
|
|
138
|
-
_this.onMouseDown = function (event, resizerIndex) {
|
|
139
|
-
if (event.button !== 0) {
|
|
140
|
-
return;
|
|
141
|
-
}
|
|
142
|
-
|
|
143
|
-
event.preventDefault();
|
|
144
|
-
|
|
145
|
-
_this.onDown(resizerIndex, event.clientX, event.clientY);
|
|
146
|
-
};
|
|
147
|
-
|
|
148
|
-
_this.onTouchStart = function (event, resizerIndex) {
|
|
149
|
-
event.preventDefault();
|
|
150
|
-
|
|
151
|
-
var _event$touches$ = event.touches[0],
|
|
152
|
-
clientX = _event$touches$.clientX,
|
|
153
|
-
clientY = _event$touches$.clientY;
|
|
154
|
-
|
|
155
|
-
|
|
156
|
-
_this.onDown(resizerIndex, clientX, clientY);
|
|
157
|
-
};
|
|
158
|
-
|
|
159
|
-
_this.onDown = function (resizerIndex, clientX, clientY) {
|
|
160
|
-
var _this$props = _this.props,
|
|
161
|
-
allowResize = _this$props.allowResize,
|
|
162
|
-
onResizeStart = _this$props.onResizeStart,
|
|
163
|
-
split = _this$props.split;
|
|
164
|
-
|
|
165
|
-
|
|
166
|
-
if (!allowResize) {
|
|
167
|
-
return;
|
|
168
|
-
}
|
|
169
|
-
|
|
170
|
-
_this.resizerIndex = resizerIndex;
|
|
171
|
-
_this.dimensionsSnapshot = _this.getDimensionsSnapshot(_this.props);
|
|
172
|
-
_this.startClientX = clientX;
|
|
173
|
-
_this.startClientY = clientY;
|
|
174
|
-
|
|
175
|
-
document.addEventListener('mousemove', _this.onMouseMove);
|
|
176
|
-
document.addEventListener('mouseup', _this.onMouseUp);
|
|
177
|
-
|
|
178
|
-
document.addEventListener('touchmove', _this.onTouchMove);
|
|
179
|
-
document.addEventListener('touchend', _this.onMouseUp);
|
|
180
|
-
document.addEventListener('touchcancel', _this.onMouseUp);
|
|
181
|
-
|
|
182
|
-
if (onResizeStart) {
|
|
183
|
-
onResizeStart();
|
|
184
|
-
}
|
|
185
|
-
};
|
|
186
|
-
|
|
187
|
-
_this.onMouseMove = function (event) {
|
|
188
|
-
event.preventDefault();
|
|
189
|
-
|
|
190
|
-
_this.onMove(event.clientX, event.clientY);
|
|
191
|
-
};
|
|
192
|
-
|
|
193
|
-
_this.onTouchMove = function (event) {
|
|
194
|
-
event.preventDefault();
|
|
195
|
-
|
|
196
|
-
var _event$touches$2 = event.touches[0],
|
|
197
|
-
clientX = _event$touches$2.clientX,
|
|
198
|
-
clientY = _event$touches$2.clientY;
|
|
199
|
-
|
|
200
|
-
|
|
201
|
-
_this.onMove(clientX, clientY);
|
|
202
|
-
};
|
|
203
|
-
|
|
204
|
-
_this.onMouseUp = function (event) {
|
|
205
|
-
event.preventDefault();
|
|
206
|
-
|
|
207
|
-
document.removeEventListener('mouseup', _this.onMouseUp);
|
|
208
|
-
document.removeEventListener('mousemove', _this.onMouseMove);
|
|
209
|
-
|
|
210
|
-
document.removeEventListener('touchmove', _this.onTouchMove);
|
|
211
|
-
document.removeEventListener('touchend', _this.onMouseUp);
|
|
212
|
-
document.addEventListener('touchcancel', _this.onMouseUp);
|
|
213
|
-
|
|
214
|
-
if (_this.props.onResizeEnd) {
|
|
215
|
-
_this.props.onResizeEnd(_this.state.sizes);
|
|
216
|
-
}
|
|
217
|
-
};
|
|
218
|
-
|
|
219
|
-
_this.setPaneRef = function (idx, el) {
|
|
220
|
-
if (!_this.paneElements) {
|
|
221
|
-
_this.paneElements = [];
|
|
222
|
-
}
|
|
223
|
-
|
|
224
|
-
_this.paneElements[idx] = el;
|
|
225
|
-
};
|
|
226
|
-
|
|
227
|
-
_this.state = {
|
|
228
|
-
sizes: _this.getPanePropSize(props)
|
|
229
|
-
};
|
|
230
|
-
return _this;
|
|
231
|
-
}
|
|
232
|
-
|
|
233
|
-
_createClass(SplitPane, [{
|
|
234
|
-
key: 'componentWillReceiveProps',
|
|
235
|
-
value: function componentWillReceiveProps(nextProps) {
|
|
236
|
-
this.setState({ sizes: this.getPanePropSize(nextProps) });
|
|
237
|
-
}
|
|
238
|
-
}, {
|
|
239
|
-
key: 'componentWillUnmount',
|
|
240
|
-
value: function componentWillUnmount() {
|
|
241
|
-
document.removeEventListener('mouseup', this.onMouseUp);
|
|
242
|
-
document.removeEventListener('mousemove', this.onMouseMove);
|
|
243
|
-
|
|
244
|
-
document.removeEventListener('touchmove', this.onTouchMove);
|
|
245
|
-
document.removeEventListener('touchend', this.onMouseUp);
|
|
246
|
-
}
|
|
247
|
-
}, {
|
|
248
|
-
key: 'getDimensionsSnapshot',
|
|
249
|
-
value: function getDimensionsSnapshot(props) {
|
|
250
|
-
var split = props.split;
|
|
251
|
-
var paneDimensions = this.getPaneDimensions();
|
|
252
|
-
var splitPaneDimensions = this.splitPane.getBoundingClientRect();
|
|
253
|
-
var minSizes = this.getPanePropMinMaxSize(props, 'minSize');
|
|
254
|
-
var maxSizes = this.getPanePropMinMaxSize(props, 'maxSize');
|
|
255
|
-
|
|
256
|
-
var resizersSize = this.getResizersSize();
|
|
257
|
-
var splitPaneSizePx = split === 'vertical' ? splitPaneDimensions.width - resizersSize : splitPaneDimensions.height - resizersSize;
|
|
258
|
-
|
|
259
|
-
var minSizesPx = minSizes.map(function (s) {
|
|
260
|
-
return convert(s, splitPaneSizePx);
|
|
261
|
-
});
|
|
262
|
-
var maxSizesPx = maxSizes.map(function (s) {
|
|
263
|
-
return convert(s, splitPaneSizePx);
|
|
264
|
-
});
|
|
265
|
-
var sizesPx = paneDimensions.map(function (d) {
|
|
266
|
-
return split === 'vertical' ? d.width : d.height;
|
|
267
|
-
});
|
|
268
|
-
|
|
269
|
-
return {
|
|
270
|
-
resizersSize: resizersSize,
|
|
271
|
-
paneDimensions: paneDimensions,
|
|
272
|
-
splitPaneSizePx: splitPaneSizePx,
|
|
273
|
-
minSizesPx: minSizesPx,
|
|
274
|
-
maxSizesPx: maxSizesPx,
|
|
275
|
-
sizesPx: sizesPx
|
|
276
|
-
};
|
|
277
|
-
}
|
|
278
|
-
}, {
|
|
279
|
-
key: 'getPanePropSize',
|
|
280
|
-
value: function getPanePropSize(props) {
|
|
281
|
-
return _react2.default.Children.map(props.children, function (child) {
|
|
282
|
-
var value = child.props['size'] || child.props['initialSize'];
|
|
283
|
-
if (value === undefined) {
|
|
284
|
-
return DEFAULT_PANE_SIZE;
|
|
285
|
-
}
|
|
286
|
-
|
|
287
|
-
return String(value);
|
|
288
|
-
});
|
|
289
|
-
}
|
|
290
|
-
}, {
|
|
291
|
-
key: 'getPanePropMinMaxSize',
|
|
292
|
-
value: function getPanePropMinMaxSize(props, key) {
|
|
293
|
-
return _react2.default.Children.map(props.children, function (child) {
|
|
294
|
-
var value = child.props[key];
|
|
295
|
-
if (value === undefined) {
|
|
296
|
-
return key === 'maxSize' ? DEFAULT_PANE_MAX_SIZE : DEFAULT_PANE_MIN_SIZE;
|
|
297
|
-
}
|
|
298
|
-
|
|
299
|
-
return value;
|
|
300
|
-
});
|
|
301
|
-
}
|
|
302
|
-
}, {
|
|
303
|
-
key: 'getPaneDimensions',
|
|
304
|
-
value: function getPaneDimensions() {
|
|
305
|
-
return this.paneElements.filter(function (el) {
|
|
306
|
-
return el;
|
|
307
|
-
}).map(function (el) {
|
|
308
|
-
return el.getBoundingClientRect();
|
|
309
|
-
});
|
|
310
|
-
}
|
|
311
|
-
}, {
|
|
312
|
-
key: 'getSizes',
|
|
313
|
-
value: function getSizes() {
|
|
314
|
-
return this.state.sizes;
|
|
315
|
-
}
|
|
316
|
-
}, {
|
|
317
|
-
key: 'onMove',
|
|
318
|
-
value: function onMove(clientX, clientY) {
|
|
319
|
-
var _props = this.props,
|
|
320
|
-
split = _props.split,
|
|
321
|
-
onChange = _props.onChange;
|
|
322
|
-
|
|
323
|
-
var resizerIndex = this.resizerIndex;
|
|
324
|
-
var _dimensionsSnapshot = this.dimensionsSnapshot,
|
|
325
|
-
sizesPx = _dimensionsSnapshot.sizesPx,
|
|
326
|
-
minSizesPx = _dimensionsSnapshot.minSizesPx,
|
|
327
|
-
maxSizesPx = _dimensionsSnapshot.maxSizesPx,
|
|
328
|
-
splitPaneSizePx = _dimensionsSnapshot.splitPaneSizePx,
|
|
329
|
-
paneDimensions = _dimensionsSnapshot.paneDimensions;
|
|
330
|
-
|
|
331
|
-
|
|
332
|
-
var sizeDim = split === 'vertical' ? 'width' : 'height';
|
|
333
|
-
var primary = paneDimensions[resizerIndex];
|
|
334
|
-
var secondary = paneDimensions[resizerIndex + 1];
|
|
335
|
-
var maxSize = primary[sizeDim] + secondary[sizeDim];
|
|
336
|
-
|
|
337
|
-
var primaryMinSizePx = minSizesPx[resizerIndex];
|
|
338
|
-
var secondaryMinSizePx = minSizesPx[resizerIndex + 1];
|
|
339
|
-
var primaryMaxSizePx = Math.min(maxSizesPx[resizerIndex], maxSize);
|
|
340
|
-
var secondaryMaxSizePx = Math.min(maxSizesPx[resizerIndex + 1], maxSize);
|
|
341
|
-
|
|
342
|
-
var moveOffset = split === 'vertical' ? this.startClientX - clientX : this.startClientY - clientY;
|
|
343
|
-
|
|
344
|
-
var primarySizePx = primary[sizeDim] - moveOffset;
|
|
345
|
-
var secondarySizePx = secondary[sizeDim] + moveOffset;
|
|
346
|
-
|
|
347
|
-
var primaryHasReachedLimit = false;
|
|
348
|
-
var secondaryHasReachedLimit = false;
|
|
349
|
-
|
|
350
|
-
if (primarySizePx < primaryMinSizePx) {
|
|
351
|
-
primarySizePx = primaryMinSizePx;
|
|
352
|
-
primaryHasReachedLimit = true;
|
|
353
|
-
} else if (primarySizePx > primaryMaxSizePx) {
|
|
354
|
-
primarySizePx = primaryMaxSizePx;
|
|
355
|
-
primaryHasReachedLimit = true;
|
|
356
|
-
}
|
|
357
|
-
|
|
358
|
-
if (secondarySizePx < secondaryMinSizePx) {
|
|
359
|
-
secondarySizePx = secondaryMinSizePx;
|
|
360
|
-
secondaryHasReachedLimit = true;
|
|
361
|
-
} else if (secondarySizePx > secondaryMaxSizePx) {
|
|
362
|
-
secondarySizePx = secondaryMaxSizePx;
|
|
363
|
-
secondaryHasReachedLimit = true;
|
|
364
|
-
}
|
|
365
|
-
|
|
366
|
-
if (primaryHasReachedLimit) {
|
|
367
|
-
secondarySizePx = primary[sizeDim] + secondary[sizeDim] - primarySizePx;
|
|
368
|
-
} else if (secondaryHasReachedLimit) {
|
|
369
|
-
primarySizePx = primary[sizeDim] + primary[sizeDim] - secondarySizePx;
|
|
370
|
-
}
|
|
371
|
-
|
|
372
|
-
sizesPx[resizerIndex] = primarySizePx;
|
|
373
|
-
sizesPx[resizerIndex + 1] = secondarySizePx;
|
|
374
|
-
|
|
375
|
-
var sizes = this.getSizes().concat();
|
|
376
|
-
var updateRatio = void 0;
|
|
377
|
-
|
|
378
|
-
[primarySizePx, secondarySizePx].forEach(function (paneSize, idx) {
|
|
379
|
-
var unit = getUnit(sizes[resizerIndex + idx]);
|
|
380
|
-
if (unit !== 'ratio') {
|
|
381
|
-
sizes[resizerIndex + idx] = convertToUnit(paneSize, unit, splitPaneSizePx);
|
|
382
|
-
} else {
|
|
383
|
-
updateRatio = true;
|
|
384
|
-
}
|
|
385
|
-
});
|
|
386
|
-
|
|
387
|
-
if (updateRatio) {
|
|
388
|
-
var ratioCount = 0;
|
|
389
|
-
var lastRatioIdx = void 0;
|
|
390
|
-
sizes = sizes.map(function (size, idx) {
|
|
391
|
-
if (getUnit(size) === 'ratio') {
|
|
392
|
-
ratioCount++;
|
|
393
|
-
lastRatioIdx = idx;
|
|
394
|
-
|
|
395
|
-
return convertToUnit(sizesPx[idx], 'ratio');
|
|
396
|
-
}
|
|
397
|
-
|
|
398
|
-
return size;
|
|
399
|
-
});
|
|
400
|
-
|
|
401
|
-
if (ratioCount === 1) {
|
|
402
|
-
sizes[lastRatioIdx] = '1';
|
|
403
|
-
}
|
|
404
|
-
}
|
|
405
|
-
|
|
406
|
-
onChange && onChange(sizes);
|
|
407
|
-
|
|
408
|
-
this.setState({
|
|
409
|
-
sizes: sizes
|
|
410
|
-
});
|
|
411
|
-
}
|
|
412
|
-
}, {
|
|
413
|
-
key: 'getResizersSize',
|
|
414
|
-
value: function getResizersSize() {
|
|
415
|
-
return (_react2.default.Children.count(this.props.children) - 1) * this.props.resizerSize;
|
|
416
|
-
}
|
|
417
|
-
}, {
|
|
418
|
-
key: 'render',
|
|
419
|
-
value: function render() {
|
|
420
|
-
var _this2 = this;
|
|
421
|
-
|
|
422
|
-
var _props2 = this.props,
|
|
423
|
-
children = _props2.children,
|
|
424
|
-
className = _props2.className,
|
|
425
|
-
split = _props2.split;
|
|
426
|
-
|
|
427
|
-
var sizes = this.getSizes();
|
|
428
|
-
var resizersSize = this.getResizersSize();
|
|
429
|
-
|
|
430
|
-
var elements = children.reduce(function (acc, child, idx) {
|
|
431
|
-
var pane = void 0;
|
|
432
|
-
var resizerIndex = idx - 1;
|
|
433
|
-
var isPane = child.type === _Pane2.default;
|
|
434
|
-
var paneProps = {
|
|
435
|
-
index: idx,
|
|
436
|
-
'data-type': 'Pane',
|
|
437
|
-
split: split,
|
|
438
|
-
key: 'Pane-' + idx,
|
|
439
|
-
innerRef: _this2.setPaneRef,
|
|
440
|
-
resizersSize: resizersSize,
|
|
441
|
-
size: sizes[idx]
|
|
442
|
-
};
|
|
443
|
-
|
|
444
|
-
if (isPane) {
|
|
445
|
-
pane = (0, _react.cloneElement)(child, paneProps);
|
|
446
|
-
} else {
|
|
447
|
-
pane = _react2.default.createElement(
|
|
448
|
-
_Pane2.default,
|
|
449
|
-
paneProps,
|
|
450
|
-
child
|
|
451
|
-
);
|
|
452
|
-
}
|
|
453
|
-
|
|
454
|
-
if (acc.length === 0) {
|
|
455
|
-
return [].concat(_toConsumableArray(acc), [pane]);
|
|
456
|
-
} else {
|
|
457
|
-
var resizer = _react2.default.createElement(_Resizer2.default, {
|
|
458
|
-
index: resizerIndex,
|
|
459
|
-
key: 'Resizer-' + resizerIndex,
|
|
460
|
-
split: split,
|
|
461
|
-
onMouseDown: _this2.onMouseDown,
|
|
462
|
-
onTouchStart: _this2.onTouchStart
|
|
463
|
-
});
|
|
464
|
-
|
|
465
|
-
return [].concat(_toConsumableArray(acc), [resizer, pane]);
|
|
466
|
-
}
|
|
467
|
-
}, []);
|
|
468
|
-
|
|
469
|
-
var StyleComponent = split === 'vertical' ? RowStyle : ColumnStyle;
|
|
470
|
-
|
|
471
|
-
return _react2.default.createElement(
|
|
472
|
-
StyleComponent,
|
|
473
|
-
{
|
|
474
|
-
className: className,
|
|
475
|
-
'data-type': 'SplitPane',
|
|
476
|
-
'data-split': split,
|
|
477
|
-
innerRef: function innerRef(el) {
|
|
478
|
-
_this2.splitPane = el;
|
|
479
|
-
}
|
|
480
|
-
},
|
|
481
|
-
elements
|
|
482
|
-
);
|
|
483
|
-
}
|
|
484
|
-
}]);
|
|
485
|
-
|
|
486
|
-
return SplitPane;
|
|
487
|
-
}(_react.Component);
|
|
488
|
-
|
|
489
|
-
SplitPane.propTypes = {
|
|
490
|
-
children: _propTypes2.default.arrayOf(_propTypes2.default.node).isRequired,
|
|
491
|
-
className: _propTypes2.default.string,
|
|
492
|
-
split: _propTypes2.default.oneOf(['vertical', 'horizontal']),
|
|
493
|
-
resizerSize: _propTypes2.default.number,
|
|
494
|
-
onChange: _propTypes2.default.func,
|
|
495
|
-
onResizeStart: _propTypes2.default.func,
|
|
496
|
-
onResizeEnd: _propTypes2.default.func
|
|
497
|
-
};
|
|
498
|
-
|
|
499
|
-
SplitPane.defaultProps = {
|
|
500
|
-
split: 'vertical',
|
|
501
|
-
resizerSize: 1,
|
|
502
|
-
allowResize: true
|
|
503
|
-
};
|
|
504
|
-
|
|
505
|
-
exports.default = SplitPane;
|
package/stories/index.stories.js
DELETED
|
@@ -1,40 +0,0 @@
|
|
|
1
|
-
import React from 'react';
|
|
2
|
-
|
|
3
|
-
import { storiesOf } from '@storybook/react';
|
|
4
|
-
import { action } from '@storybook/addon-actions';
|
|
5
|
-
import { linkTo } from '@storybook/addon-links';
|
|
6
|
-
|
|
7
|
-
import SplitPane from '../lib/SplitPane';
|
|
8
|
-
import Pane from "../lib/Pane";
|
|
9
|
-
|
|
10
|
-
import { Button, Welcome } from '@storybook/react/demo';
|
|
11
|
-
|
|
12
|
-
storiesOf('Welcome', module).add('to Storybook', () => <Welcome showApp={linkTo('Button')} />);
|
|
13
|
-
|
|
14
|
-
storiesOf('Vertical', module)
|
|
15
|
-
.add('with divs', () =>
|
|
16
|
-
<SplitPane split="vertical">
|
|
17
|
-
<div>This is a div</div>
|
|
18
|
-
<div>This is a div</div>
|
|
19
|
-
</SplitPane>
|
|
20
|
-
)
|
|
21
|
-
.add('with Panes', () =>
|
|
22
|
-
<SplitPane split="vertical">
|
|
23
|
-
<Pane>This is a Pane</Pane>
|
|
24
|
-
<Pane>This is a Pane</Pane>
|
|
25
|
-
</SplitPane>
|
|
26
|
-
);
|
|
27
|
-
|
|
28
|
-
storiesOf('Horizontal', module)
|
|
29
|
-
.add('with divs', () =>
|
|
30
|
-
<SplitPane split="horizontal">
|
|
31
|
-
<div>This is a div</div>
|
|
32
|
-
<div>This is a div</div>
|
|
33
|
-
</SplitPane>
|
|
34
|
-
)
|
|
35
|
-
.add('with Panes', () =>
|
|
36
|
-
<SplitPane split="horizontal">
|
|
37
|
-
<Pane>This is a Pane</Pane>
|
|
38
|
-
<Pane>This is a Pane</Pane>
|
|
39
|
-
</SplitPane>
|
|
40
|
-
);
|