@pie-lib/plot 4.0.4-next.3 → 4.0.4-next.30

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (59) hide show
  1. package/dist/_virtual/_rolldown/runtime.js +20 -0
  2. package/dist/draggable.d.ts +13 -0
  3. package/dist/draggable.js +13 -0
  4. package/dist/graph-props.d.ts +22 -0
  5. package/dist/graph-props.js +29 -0
  6. package/dist/grid-draggable.d.ts +91 -0
  7. package/dist/grid-draggable.js +168 -0
  8. package/dist/index.d.ts +16 -0
  9. package/dist/index.js +8 -0
  10. package/dist/label.d.ts +30 -0
  11. package/dist/label.js +132 -0
  12. package/dist/node_modules/.bun/clsx@2.1.1/node_modules/clsx/dist/clsx.js +16 -0
  13. package/dist/node_modules/.bun/invariant@2.2.4/node_modules/invariant/browser.js +28 -0
  14. package/dist/node_modules/.bun/react-draggable@4.6.0_6dbf9a050bc9aadb/node_modules/react-draggable/build/cjs/chunk-D5BXCJ5G.js +503 -0
  15. package/dist/node_modules/.bun/react-draggable@4.6.0_6dbf9a050bc9aadb/node_modules/react-draggable/build/cjs/cjs.js +5 -0
  16. package/dist/root.d.ts +68 -0
  17. package/dist/root.js +302 -0
  18. package/dist/trig.d.ts +41 -0
  19. package/dist/trig.js +47 -0
  20. package/dist/types.d.ts +125 -0
  21. package/dist/types.js +46 -0
  22. package/dist/utils.d.ts +44 -0
  23. package/dist/utils.js +82 -0
  24. package/package.json +35 -25
  25. package/CHANGELOG.json +0 -17
  26. package/CHANGELOG.md +0 -838
  27. package/LICENSE.md +0 -5
  28. package/lib/draggable.js +0 -44
  29. package/lib/draggable.js.map +0 -1
  30. package/lib/graph-props.js +0 -46
  31. package/lib/graph-props.js.map +0 -1
  32. package/lib/grid-draggable.js +0 -361
  33. package/lib/grid-draggable.js.map +0 -1
  34. package/lib/index.js +0 -44
  35. package/lib/index.js.map +0 -1
  36. package/lib/label.js +0 -173
  37. package/lib/label.js.map +0 -1
  38. package/lib/root.js +0 -474
  39. package/lib/root.js.map +0 -1
  40. package/lib/trig.js +0 -149
  41. package/lib/trig.js.map +0 -1
  42. package/lib/types.js +0 -40
  43. package/lib/types.js.map +0 -1
  44. package/lib/utils.js +0 -165
  45. package/lib/utils.js.map +0 -1
  46. package/src/__tests__/draggable.test.jsx +0 -41
  47. package/src/__tests__/grid-draggable.test.jsx +0 -487
  48. package/src/__tests__/root.test.jsx +0 -277
  49. package/src/__tests__/trig.test.js +0 -163
  50. package/src/__tests__/utils.test.js +0 -229
  51. package/src/draggable.jsx +0 -11
  52. package/src/graph-props.js +0 -34
  53. package/src/grid-draggable.jsx +0 -332
  54. package/src/index.js +0 -9
  55. package/src/label.jsx +0 -199
  56. package/src/root.jsx +0 -485
  57. package/src/trig.js +0 -151
  58. package/src/types.js +0 -41
  59. package/src/utils.js +0 -167
package/lib/root.js DELETED
@@ -1,474 +0,0 @@
1
- "use strict";
2
-
3
- var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
4
- Object.defineProperty(exports, "__esModule", {
5
- value: true
6
- });
7
- exports["default"] = exports.Root = void 0;
8
- var _extends2 = _interopRequireDefault(require("@babel/runtime/helpers/extends"));
9
- var _toConsumableArray2 = _interopRequireDefault(require("@babel/runtime/helpers/toConsumableArray"));
10
- var _classCallCheck2 = _interopRequireDefault(require("@babel/runtime/helpers/classCallCheck"));
11
- var _createClass2 = _interopRequireDefault(require("@babel/runtime/helpers/createClass"));
12
- var _possibleConstructorReturn2 = _interopRequireDefault(require("@babel/runtime/helpers/possibleConstructorReturn"));
13
- var _getPrototypeOf2 = _interopRequireDefault(require("@babel/runtime/helpers/getPrototypeOf"));
14
- var _inherits2 = _interopRequireDefault(require("@babel/runtime/helpers/inherits"));
15
- var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty"));
16
- var _react = _interopRequireDefault(require("react"));
17
- var _styles = require("@mui/material/styles");
18
- var _propTypes = _interopRequireDefault(require("prop-types"));
19
- var _d3Selection = require("d3-selection");
20
- var _renderUi = require("@pie-lib/render-ui");
21
- var _editableHtmlTipTap = _interopRequireDefault(require("@pie-lib/editable-html-tip-tap"));
22
- var _types = require("./types");
23
- var _label = _interopRequireDefault(require("./label"));
24
- var _utils = require("./utils");
25
- function _createForOfIteratorHelper(r, e) { var t = "undefined" != typeof Symbol && r[Symbol.iterator] || r["@@iterator"]; if (!t) { if (Array.isArray(r) || (t = _unsupportedIterableToArray(r)) || e && r && "number" == typeof r.length) { t && (r = t); var _n = 0, F = function F() {}; return { s: F, n: function n() { return _n >= r.length ? { done: !0 } : { done: !1, value: r[_n++] }; }, e: function e(r) { throw r; }, f: F }; } throw new TypeError("Invalid attempt to iterate non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method."); } var o, a = !0, u = !1; return { s: function s() { t = t.call(r); }, n: function n() { var r = t.next(); return a = r.done, r; }, e: function e(r) { u = !0, o = r; }, f: function f() { try { a || null == t["return"] || t["return"](); } finally { if (u) throw o; } } }; }
26
- function _unsupportedIterableToArray(r, a) { if (r) { if ("string" == typeof r) return _arrayLikeToArray(r, a); var t = {}.toString.call(r).slice(8, -1); return "Object" === t && r.constructor && (t = r.constructor.name), "Map" === t || "Set" === t ? Array.from(r) : "Arguments" === t || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(t) ? _arrayLikeToArray(r, a) : void 0; } }
27
- function _arrayLikeToArray(r, a) { (null == a || a > r.length) && (a = r.length); for (var e = 0, n = Array(a); e < a; e++) n[e] = r[e]; return n; }
28
- function _callSuper(t, o, e) { return o = (0, _getPrototypeOf2["default"])(o), (0, _possibleConstructorReturn2["default"])(t, _isNativeReflectConstruct() ? Reflect.construct(o, e || [], (0, _getPrototypeOf2["default"])(t).constructor) : o.apply(t, e)); }
29
- function _isNativeReflectConstruct() { try { var t = !Boolean.prototype.valueOf.call(Reflect.construct(Boolean, [], function () {})); } catch (t) {} return (_isNativeReflectConstruct = function _isNativeReflectConstruct() { return !!t; })(); }
30
- function ownKeys(e, r) { var t = Object.keys(e); if (Object.getOwnPropertySymbols) { var o = Object.getOwnPropertySymbols(e); r && (o = o.filter(function (r) { return Object.getOwnPropertyDescriptor(e, r).enumerable; })), t.push.apply(t, o); } return t; }
31
- function _objectSpread(e) { for (var r = 1; r < arguments.length; r++) { var t = null != arguments[r] ? arguments[r] : {}; r % 2 ? ownKeys(Object(t), !0).forEach(function (r) { (0, _defineProperty2["default"])(e, r, t[r]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(e, Object.getOwnPropertyDescriptors(t)) : ownKeys(Object(t)).forEach(function (r) { Object.defineProperty(e, r, Object.getOwnPropertyDescriptor(t, r)); }); } return e; }
32
- var centerPlaceholder = {
33
- '& .ProseMirror p.is-editor-empty::before, & .ProseMirror div.is-editor-empty::before': {
34
- left: 0,
35
- right: 0,
36
- width: '100%',
37
- textAlign: 'center'
38
- }
39
- };
40
- var StyledRoot = (0, _styles.styled)('div')(function (_ref) {
41
- var theme = _ref.theme;
42
- return {
43
- border: "solid 1px ".concat(_renderUi.color.primaryLight()),
44
- color: _renderUi.color.defaults.TEXT,
45
- backgroundColor: theme.palette.common.white,
46
- touchAction: 'none',
47
- position: 'relative',
48
- boxSizing: 'unset' // to override the default border-box in IBX that breaks the component width layout
49
- };
50
- });
51
- var Wrapper = (0, _styles.styled)('div')({
52
- display: 'flex',
53
- position: 'relative'
54
- });
55
- var DefineChartSvg = (0, _styles.styled)('svg')({
56
- paddingLeft: '50px',
57
- overflow: 'visible',
58
- boxSizing: 'content-box'
59
- });
60
- var ChartSvg = (0, _styles.styled)('svg')({
61
- overflow: 'visible',
62
- boxSizing: 'content-box'
63
- });
64
- var GraphBox = (0, _styles.styled)('g')({
65
- cursor: 'pointer',
66
- userSelect: 'none'
67
- });
68
- var GraphTitle = (0, _styles.styled)('div')(function (_ref2) {
69
- var theme = _ref2.theme;
70
- return _objectSpread({
71
- color: _renderUi.color.defaults.TEXT,
72
- fontSize: theme.typography.fontSize + 2,
73
- padding: "".concat(theme.spacing(1.5), " ").concat(theme.spacing(0.5), " 0"),
74
- textAlign: 'center',
75
- '&.disabled': {
76
- pointerEvents: 'none'
77
- },
78
- '&.rightMargin': {
79
- marginRight: '74px'
80
- },
81
- '& p': {
82
- margin: 0
83
- }
84
- }, centerPlaceholder);
85
- });
86
- var ChartTitle = (0, _styles.styled)('div')(function (_ref3) {
87
- var theme = _ref3.theme;
88
- return _objectSpread({
89
- color: _renderUi.color.defaults.TEXT,
90
- fontSize: theme.typography.fontSize + 4,
91
- padding: "".concat(theme.spacing(1.5), " ").concat(theme.spacing(0.5), " 0"),
92
- textAlign: 'center',
93
- '&.disabled': {
94
- pointerEvents: 'none'
95
- },
96
- '&.rightMargin': {
97
- marginRight: '74px'
98
- },
99
- '& p': {
100
- margin: 0
101
- }
102
- }, centerPlaceholder);
103
- });
104
- var TopPixelGuides = (0, _styles.styled)('div')({
105
- display: 'flex',
106
- paddingTop: '6px'
107
- });
108
- var TopPixelIndicator = (0, _styles.styled)('div')({
109
- display: 'flex',
110
- flexDirection: 'column',
111
- alignItems: 'center',
112
- width: '100px',
113
- pointerEvents: 'none',
114
- userSelect: 'none'
115
- });
116
- var SidePixelGuides = (0, _styles.styled)('div')({
117
- width: '70px',
118
- display: 'flex',
119
- flexDirection: 'column',
120
- marginRight: '6px'
121
- });
122
- var SidePixelIndicator = (0, _styles.styled)('div')({
123
- textAlign: 'right',
124
- height: '20px',
125
- pointerEvents: 'none',
126
- userSelect: 'none',
127
- '&:not(:last-child)': {
128
- marginBottom: '80px'
129
- }
130
- });
131
- var Root = exports.Root = /*#__PURE__*/function (_React$Component) {
132
- function Root(props) {
133
- var _this;
134
- (0, _classCallCheck2["default"])(this, Root);
135
- _this = _callSuper(this, Root, [props]);
136
- (0, _defineProperty2["default"])(_this, "mouseMove", function (g, event) {
137
- var _this$props = _this.props,
138
- graphProps = _this$props.graphProps,
139
- onMouseMove = _this$props.onMouseMove;
140
- if (!onMouseMove) {
141
- return;
142
- }
143
- var scale = graphProps.scale,
144
- snap = graphProps.snap;
145
- var coords = (0, _d3Selection.pointer)(event, g.node());
146
- var x = scale.x.invert(coords[0]);
147
- var y = scale.y.invert(coords[1]);
148
- var snapped = {
149
- x: snap.x(x),
150
- y: snap.y(y)
151
- };
152
- onMouseMove(snapped);
153
- });
154
- (0, _defineProperty2["default"])(_this, "onChangeLabel", function (newValue, side) {
155
- var _this$props2 = _this.props,
156
- labels = _this$props2.labels,
157
- onChangeLabels = _this$props2.onChangeLabels,
158
- isChart = _this$props2.isChart;
159
- if (!onChangeLabels) {
160
- return;
161
- }
162
- if (isChart) {
163
- if (side === 'left') {
164
- onChangeLabels('range', newValue);
165
- } else {
166
- onChangeLabels('domain', newValue);
167
- }
168
- return;
169
- }
170
- onChangeLabels(_objectSpread(_objectSpread({}, labels), {}, (0, _defineProperty2["default"])({}, side, newValue)));
171
- });
172
- (0, _defineProperty2["default"])(_this, "measureTitleHeight", function () {
173
- var titleElement = _this.titleRef;
174
- if (titleElement) {
175
- var titleHeight = titleElement.clientHeight;
176
- _this.setState({
177
- titleHeight: titleHeight,
178
- prevTitle: _this.props.title
179
- });
180
- if (!_this.resizeObserver && typeof ResizeObserver !== 'undefined') {
181
- _this.setupVisibilityObserver();
182
- }
183
- }
184
- });
185
- (0, _defineProperty2["default"])(_this, "handleKeyDown", function () {
186
- setTimeout(function () {
187
- _this.measureTitleHeight();
188
- }, 0);
189
- });
190
- // handle edge case where chart is hidden with display:none and then shown with display:block
191
- (0, _defineProperty2["default"])(_this, "setupVisibilityObserver", function () {
192
- if (typeof ResizeObserver !== 'undefined' && _this.titleRef) {
193
- _this.resizeObserver = new ResizeObserver(function (entries) {
194
- var _iterator = _createForOfIteratorHelper(entries),
195
- _step;
196
- try {
197
- for (_iterator.s(); !(_step = _iterator.n()).done;) {
198
- var entry = _step.value;
199
- var _entry$contentRect = entry.contentRect,
200
- width = _entry$contentRect.width,
201
- height = _entry$contentRect.height;
202
- // trigger if element becomes visible and we haven't measured this height yet
203
- if (width > 0 && height > 0) {
204
- setTimeout(function () {
205
- _this.measureTitleHeight();
206
- }, 10);
207
- break;
208
- }
209
- }
210
- } catch (err) {
211
- _iterator.e(err);
212
- } finally {
213
- _iterator.f();
214
- }
215
- });
216
- _this.resizeObserver.observe(_this.titleRef);
217
- }
218
- });
219
- (0, _defineProperty2["default"])(_this, "cleanupVisibilityObserver", function () {
220
- if (_this.resizeObserver) {
221
- _this.resizeObserver.disconnect();
222
- _this.resizeObserver = null;
223
- }
224
- });
225
- _this.state = {
226
- titleHeight: 0
227
- };
228
- _this.resizeObserver = null;
229
- return _this;
230
- }
231
- (0, _inherits2["default"])(Root, _React$Component);
232
- return (0, _createClass2["default"])(Root, [{
233
- key: "componentDidMount",
234
- value: function componentDidMount() {
235
- var g = (0, _d3Selection.select)(this.g);
236
- g.on('mousemove', this.mouseMove.bind(this, g));
237
- this.measureTitleHeight();
238
- this.setupVisibilityObserver();
239
- }
240
- }, {
241
- key: "componentWillUnmount",
242
- value: function componentWillUnmount() {
243
- var g = (0, _d3Selection.select)(this.g);
244
- g.on('mousemove', null);
245
- this.cleanupVisibilityObserver();
246
- }
247
- }, {
248
- key: "componentDidUpdate",
249
- value: function componentDidUpdate(prevProps) {
250
- if (prevProps.title !== this.props.title) {
251
- this.measureTitleHeight();
252
- }
253
- }
254
- }, {
255
- key: "render",
256
- value: function render() {
257
- var _this2 = this;
258
- var _this$props3 = this.props,
259
- disabledTitle = _this$props3.disabledTitle,
260
- disabledLabels = _this$props3.disabledLabels,
261
- labels = _this$props3.labels,
262
- labelsPlaceholders = _this$props3.labelsPlaceholders,
263
- titlePlaceholder = _this$props3.titlePlaceholder,
264
- graphProps = _this$props3.graphProps,
265
- children = _this$props3.children,
266
- defineChart = _this$props3.defineChart,
267
- onChangeTitle = _this$props3.onChangeTitle,
268
- isChart = _this$props3.isChart,
269
- showLabels = _this$props3.showLabels,
270
- showPixelGuides = _this$props3.showPixelGuides,
271
- showTitle = _this$props3.showTitle,
272
- title = _this$props3.title,
273
- rootRef = _this$props3.rootRef,
274
- _this$props3$mathMlOp = _this$props3.mathMlOptions,
275
- mathMlOptions = _this$props3$mathMlOp === void 0 ? {} : _this$props3$mathMlOp,
276
- labelsCharactersLimit = _this$props3.labelsCharactersLimit;
277
- var _graphProps$size = graphProps.size,
278
- _graphProps$size$widt = _graphProps$size.width,
279
- width = _graphProps$size$widt === void 0 ? 500 : _graphProps$size$widt,
280
- _graphProps$size$heig = _graphProps$size.height,
281
- height = _graphProps$size$heig === void 0 ? 500 : _graphProps$size$heig,
282
- domain = graphProps.domain,
283
- range = graphProps.range;
284
- var topPadding = 40;
285
- var leftPadding = (0, _utils.isEmptyString)((0, _utils.extractTextFromHTML)(labels === null || labels === void 0 ? void 0 : labels.left)) && (0, _utils.isEmptyObject)(labelsPlaceholders) ? 48 : 70;
286
- var rightPadding = (0, _utils.isEmptyString)((0, _utils.extractTextFromHTML)(labels === null || labels === void 0 ? void 0 : labels.right)) && (0, _utils.isEmptyObject)(labelsPlaceholders) ? 48 : 70;
287
- var finalWidth = width + leftPadding + rightPadding + (domain.padding || 0) * 2;
288
- var finalHeight = height + topPadding * 2 + (range.padding || 0) * 2;
289
- var activeTitlePlugins = ['bold', 'italic', 'underline', 'superscript', 'subscript', 'strikethrough', 'math'
290
- // 'languageCharacters'
291
- ];
292
- var actualHeight = defineChart && showPixelGuides ? height - 160 : height;
293
- var nbOfVerticalLines = parseInt(width / 100);
294
- var nbOfHorizontalLines = parseInt(actualHeight / 100);
295
- var sideGridlinesPadding = parseInt(actualHeight % 100);
296
- var titleHeight = this.state.titleHeight;
297
- return /*#__PURE__*/_react["default"].createElement(StyledRoot, null, showPixelGuides && /*#__PURE__*/_react["default"].createElement(TopPixelGuides, {
298
- style: {
299
- marginLeft: isChart ? 80 : showLabels ? 30 : 10
300
- }
301
- }, (0, _toConsumableArray2["default"])(Array(nbOfVerticalLines + 1).keys()).map(function (value) {
302
- return /*#__PURE__*/_react["default"].createElement(_renderUi.Readable, {
303
- "false": true,
304
- key: "top-guide-".concat(value)
305
- }, /*#__PURE__*/_react["default"].createElement(TopPixelIndicator, null, /*#__PURE__*/_react["default"].createElement("div", null, value * 100, "px"), /*#__PURE__*/_react["default"].createElement("div", null, "|")));
306
- })), showTitle && (disabledTitle ? /*#__PURE__*/_react["default"].createElement("div", {
307
- ref: function ref(r) {
308
- return _this2.titleRef = r;
309
- },
310
- style: _objectSpread(_objectSpread({}, isChart && {
311
- width: finalWidth
312
- }), (0, _utils.isEmptyString)((0, _utils.extractTextFromHTML)(title)) && {
313
- display: 'none'
314
- })
315
- }, isChart ? /*#__PURE__*/_react["default"].createElement(ChartTitle, {
316
- className: "disabled",
317
- dangerouslySetInnerHTML: {
318
- __html: title || ''
319
- }
320
- }) : /*#__PURE__*/_react["default"].createElement(GraphTitle, {
321
- className: "disabled",
322
- dangerouslySetInnerHTML: {
323
- __html: title || ''
324
- }
325
- })) : /*#__PURE__*/_react["default"].createElement("div", {
326
- ref: function ref(r) {
327
- return _this2.titleRef = r;
328
- }
329
- }, isChart ? /*#__PURE__*/_react["default"].createElement(ChartTitle, {
330
- className: showPixelGuides ? 'rightMargin' : ''
331
- }, /*#__PURE__*/_react["default"].createElement(_editableHtmlTipTap["default"], (0, _extends2["default"])({}, isChart && {
332
- width: finalWidth
333
- }, {
334
- markup: title || '',
335
- onChange: onChangeTitle,
336
- placeholder: defineChart && titlePlaceholder || !disabledTitle && 'Click here to add a title for this graph',
337
- toolbarOpts: {
338
- noPadding: true,
339
- noBorder: true
340
- },
341
- activePlugins: activeTitlePlugins,
342
- disableScrollbar: true,
343
- onKeyDown: this.handleKeyDown
344
- }))) : /*#__PURE__*/_react["default"].createElement(GraphTitle, {
345
- className: showPixelGuides ? 'rightMargin' : ''
346
- }, /*#__PURE__*/_react["default"].createElement(_editableHtmlTipTap["default"], (0, _extends2["default"])({}, isChart && {
347
- width: finalWidth
348
- }, {
349
- markup: title || '',
350
- onChange: onChangeTitle,
351
- placeholder: defineChart && titlePlaceholder || !disabledTitle && 'Click here to add a title for this graph',
352
- toolbarOpts: {
353
- noPadding: true,
354
- noBorder: true
355
- },
356
- activePlugins: activeTitlePlugins,
357
- disableScrollbar: true,
358
- onKeyDown: this.handleKeyDown
359
- }))))), showLabels && !isChart && /*#__PURE__*/_react["default"].createElement(_label["default"], {
360
- side: "top",
361
- text: labels.top,
362
- disabledLabel: disabledLabels,
363
- placeholder: labelsPlaceholders === null || labelsPlaceholders === void 0 ? void 0 : labelsPlaceholders.top,
364
- graphHeight: finalHeight,
365
- graphWidth: finalWidth,
366
- onChange: function onChange(value) {
367
- return _this2.onChangeLabel(value, 'top');
368
- },
369
- mathMlOptions: mathMlOptions,
370
- preventNewLines: true,
371
- charactersLimit: labelsCharactersLimit
372
- }), /*#__PURE__*/_react["default"].createElement(Wrapper, null, showLabels && /*#__PURE__*/_react["default"].createElement(_label["default"], {
373
- side: "left",
374
- text: labels.left,
375
- disabledLabel: disabledLabels,
376
- placeholder: labelsPlaceholders === null || labelsPlaceholders === void 0 ? void 0 : labelsPlaceholders.left,
377
- graphHeight: finalHeight,
378
- graphWidth: finalWidth,
379
- isChartLeftLabel: isChart && !defineChart,
380
- isDefineChartLeftLabel: isChart && defineChart,
381
- onChange: function onChange(value) {
382
- return _this2.onChangeLabel(value, 'left');
383
- },
384
- mathMlOptions: mathMlOptions,
385
- preventNewLines: true,
386
- charactersLimit: labelsCharactersLimit
387
- }), defineChart ? /*#__PURE__*/_react["default"].createElement(DefineChartSvg, {
388
- width: finalWidth,
389
- height: finalHeight
390
- }, /*#__PURE__*/_react["default"].createElement(GraphBox, {
391
- ref: function ref(r) {
392
- _this2.g = r;
393
- if (rootRef) {
394
- rootRef(r);
395
- }
396
- },
397
- transform: "translate(".concat(leftPadding + (domain.padding || 0), ", ").concat(topPadding + (range.padding || 0), ")")
398
- }, children)) : /*#__PURE__*/_react["default"].createElement(ChartSvg, {
399
- width: finalWidth,
400
- height: finalHeight
401
- }, /*#__PURE__*/_react["default"].createElement(GraphBox, {
402
- ref: function ref(r) {
403
- _this2.g = r;
404
- if (rootRef) {
405
- rootRef(r);
406
- }
407
- },
408
- transform: "translate(".concat(leftPadding + (domain.padding || 0), ", ").concat(topPadding + (range.padding || 0), ")")
409
- }, children)), showLabels && !isChart && /*#__PURE__*/_react["default"].createElement(_label["default"], {
410
- side: "right",
411
- text: labels.right,
412
- disabledLabel: disabledLabels,
413
- placeholder: labelsPlaceholders === null || labelsPlaceholders === void 0 ? void 0 : labelsPlaceholders.right,
414
- graphHeight: finalHeight,
415
- graphWidth: finalWidth,
416
- onChange: function onChange(value) {
417
- return _this2.onChangeLabel(value, 'right');
418
- },
419
- mathMlOptions: mathMlOptions,
420
- preventNewLines: true,
421
- charactersLimit: labelsCharactersLimit
422
- }), showPixelGuides && /*#__PURE__*/_react["default"].createElement(SidePixelGuides, {
423
- style: {
424
- paddingTop: sideGridlinesPadding,
425
- marginTop: 31
426
- }
427
- }, (0, _toConsumableArray2["default"])(Array(nbOfHorizontalLines + 1).keys()).reverse().map(function (value) {
428
- return /*#__PURE__*/_react["default"].createElement(_renderUi.Readable, {
429
- "false": true,
430
- key: "top-guide-".concat(value)
431
- }, /*#__PURE__*/_react["default"].createElement(SidePixelIndicator, null, "\u2501 ", value * 100, "px"));
432
- }))), showLabels && /*#__PURE__*/_react["default"].createElement(_label["default"], {
433
- side: "bottom",
434
- text: labels.bottom,
435
- disabledLabel: disabledLabels,
436
- placeholder: labelsPlaceholders === null || labelsPlaceholders === void 0 ? void 0 : labelsPlaceholders.bottom,
437
- graphHeight: finalHeight,
438
- graphWidth: finalWidth,
439
- titleHeight: titleHeight,
440
- isChartBottomLabel: isChart && !defineChart,
441
- isDefineChartBottomLabel: isChart && defineChart,
442
- onChange: function onChange(value) {
443
- return _this2.onChangeLabel(value, 'bottom');
444
- },
445
- mathMlOptions: mathMlOptions,
446
- preventNewLines: true,
447
- charactersLimit: labelsCharactersLimit
448
- }));
449
- }
450
- }]);
451
- }(_react["default"].Component);
452
- (0, _defineProperty2["default"])(Root, "propTypes", {
453
- title: _propTypes["default"].string,
454
- children: _types.ChildrenType,
455
- defineChart: _propTypes["default"].bool,
456
- disabledLabels: _propTypes["default"].bool,
457
- disabledTitle: _propTypes["default"].bool,
458
- graphProps: _types.GraphPropsType.isRequired,
459
- isChart: _propTypes["default"].bool,
460
- labels: _propTypes["default"].object,
461
- labelsPlaceholders: _propTypes["default"].object,
462
- onChangeTitle: _propTypes["default"].func,
463
- onMouseMove: _propTypes["default"].func,
464
- showLabels: _propTypes["default"].bool,
465
- showTitle: _propTypes["default"].bool,
466
- showPixelGuides: _propTypes["default"].bool,
467
- rootRef: _propTypes["default"].func,
468
- onChangeLabels: _propTypes["default"].func,
469
- titlePlaceholder: _propTypes["default"].string,
470
- mathMlOptions: _propTypes["default"].object,
471
- labelsCharactersLimit: _propTypes["default"].number
472
- });
473
- var _default = exports["default"] = Root;
474
- //# sourceMappingURL=root.js.map
package/lib/root.js.map DELETED
@@ -1 +0,0 @@
1
- {"version":3,"file":"root.js","names":["_react","_interopRequireDefault","require","_styles","_propTypes","_d3Selection","_renderUi","_editableHtmlTipTap","_types","_label","_utils","_createForOfIteratorHelper","r","e","t","Symbol","iterator","Array","isArray","_unsupportedIterableToArray","length","_n","F","s","n","done","value","f","TypeError","o","a","u","call","next","_arrayLikeToArray","toString","slice","constructor","name","from","test","_callSuper","_getPrototypeOf2","_possibleConstructorReturn2","_isNativeReflectConstruct","Reflect","construct","apply","Boolean","prototype","valueOf","ownKeys","Object","keys","getOwnPropertySymbols","filter","getOwnPropertyDescriptor","enumerable","push","_objectSpread","arguments","forEach","_defineProperty2","getOwnPropertyDescriptors","defineProperties","defineProperty","centerPlaceholder","left","right","width","textAlign","StyledRoot","styled","_ref","theme","border","concat","color","primaryLight","defaults","TEXT","backgroundColor","palette","common","white","touchAction","position","boxSizing","Wrapper","display","DefineChartSvg","paddingLeft","overflow","ChartSvg","GraphBox","cursor","userSelect","GraphTitle","_ref2","fontSize","typography","padding","spacing","pointerEvents","marginRight","margin","ChartTitle","_ref3","TopPixelGuides","paddingTop","TopPixelIndicator","flexDirection","alignItems","SidePixelGuides","SidePixelIndicator","height","marginBottom","Root","exports","_React$Component","props","_this","_classCallCheck2","g","event","_this$props","graphProps","onMouseMove","scale","snap","coords","pointer","node","x","invert","y","snapped","newValue","side","_this$props2","labels","onChangeLabels","isChart","titleElement","titleRef","titleHeight","clientHeight","setState","prevTitle","title","resizeObserver","ResizeObserver","setupVisibilityObserver","setTimeout","measureTitleHeight","entries","_iterator","_step","entry","_entry$contentRect","contentRect","err","observe","disconnect","state","_inherits2","_createClass2","key","componentDidMount","select","on","mouseMove","bind","componentWillUnmount","cleanupVisibilityObserver","componentDidUpdate","prevProps","render","_this2","_this$props3","disabledTitle","disabledLabels","labelsPlaceholders","titlePlaceholder","children","defineChart","onChangeTitle","showLabels","showPixelGuides","showTitle","rootRef","_this$props3$mathMlOp","mathMlOptions","labelsCharactersLimit","_graphProps$size","size","_graphProps$size$widt","_graphProps$size$heig","domain","range","topPadding","leftPadding","isEmptyString","extractTextFromHTML","isEmptyObject","rightPadding","finalWidth","finalHeight","activeTitlePlugins","actualHeight","nbOfVerticalLines","parseInt","nbOfHorizontalLines","sideGridlinesPadding","createElement","style","marginLeft","_toConsumableArray2","map","Readable","ref","className","dangerouslySetInnerHTML","__html","_extends2","markup","onChange","placeholder","toolbarOpts","noPadding","noBorder","activePlugins","disableScrollbar","onKeyDown","handleKeyDown","text","top","disabledLabel","graphHeight","graphWidth","onChangeLabel","preventNewLines","charactersLimit","isChartLeftLabel","isDefineChartLeftLabel","transform","marginTop","reverse","bottom","isChartBottomLabel","isDefineChartBottomLabel","React","Component","PropTypes","string","ChildrenType","bool","GraphPropsType","isRequired","object","func","number","_default"],"sources":["../src/root.jsx"],"sourcesContent":["import React from 'react';\nimport { styled } from '@mui/material/styles';\nimport PropTypes from 'prop-types';\nimport { pointer, select } from 'd3-selection';\n\nimport { color, Readable } from '@pie-lib/render-ui';\nimport EditableHtml from '@pie-lib/editable-html-tip-tap';\nimport { ChildrenType, GraphPropsType } from './types';\nimport Label from './label';\nimport { extractTextFromHTML, isEmptyObject, isEmptyString } from './utils';\n\nconst centerPlaceholder = {\n '& .ProseMirror p.is-editor-empty::before, & .ProseMirror div.is-editor-empty::before': {\n left: 0,\n right: 0,\n width: '100%',\n textAlign: 'center',\n },\n};\n\nconst StyledRoot = styled('div')(({ theme }) => ({\n border: `solid 1px ${color.primaryLight()}`,\n color: color.defaults.TEXT,\n backgroundColor: theme.palette.common.white,\n touchAction: 'none',\n position: 'relative',\n boxSizing: 'unset', // to override the default border-box in IBX that breaks the component width layout\n}));\n\nconst Wrapper = styled('div')({\n display: 'flex',\n position: 'relative',\n});\n\nconst DefineChartSvg = styled('svg')({\n paddingLeft: '50px',\n overflow: 'visible',\n boxSizing: 'content-box',\n});\n\nconst ChartSvg = styled('svg')({\n overflow: 'visible',\n boxSizing: 'content-box',\n});\n\nconst GraphBox = styled('g')({\n cursor: 'pointer',\n userSelect: 'none',\n});\n\nconst GraphTitle = styled('div')(({ theme }) => ({\n color: color.defaults.TEXT,\n fontSize: theme.typography.fontSize + 2,\n padding: `${theme.spacing(1.5)} ${theme.spacing(0.5)} 0`,\n textAlign: 'center',\n '&.disabled': {\n pointerEvents: 'none',\n },\n '&.rightMargin': {\n marginRight: '74px',\n },\n '& p': {\n margin: 0,\n },\n ...centerPlaceholder,\n}));\n\nconst ChartTitle = styled('div')(({ theme }) => ({\n color: color.defaults.TEXT,\n fontSize: theme.typography.fontSize + 4,\n padding: `${theme.spacing(1.5)} ${theme.spacing(0.5)} 0`,\n textAlign: 'center',\n '&.disabled': {\n pointerEvents: 'none',\n },\n '&.rightMargin': {\n marginRight: '74px',\n },\n '& p': {\n margin: 0,\n },\n ...centerPlaceholder,\n}));\n\nconst TopPixelGuides = styled('div')({\n display: 'flex',\n paddingTop: '6px',\n});\n\nconst TopPixelIndicator = styled('div')({\n display: 'flex',\n flexDirection: 'column',\n alignItems: 'center',\n width: '100px',\n pointerEvents: 'none',\n userSelect: 'none',\n});\n\nconst SidePixelGuides = styled('div')({\n width: '70px',\n display: 'flex',\n flexDirection: 'column',\n marginRight: '6px',\n});\n\nconst SidePixelIndicator = styled('div')({\n textAlign: 'right',\n height: '20px',\n pointerEvents: 'none',\n userSelect: 'none',\n '&:not(:last-child)': {\n marginBottom: '80px',\n },\n});\n\nexport class Root extends React.Component {\n constructor(props) {\n super(props);\n this.state = {\n titleHeight: 0,\n };\n this.resizeObserver = null;\n }\n\n static propTypes = {\n title: PropTypes.string,\n children: ChildrenType,\n defineChart: PropTypes.bool,\n disabledLabels: PropTypes.bool,\n disabledTitle: PropTypes.bool,\n graphProps: GraphPropsType.isRequired,\n isChart: PropTypes.bool,\n labels: PropTypes.object,\n labelsPlaceholders: PropTypes.object,\n onChangeTitle: PropTypes.func,\n onMouseMove: PropTypes.func,\n showLabels: PropTypes.bool,\n showTitle: PropTypes.bool,\n showPixelGuides: PropTypes.bool,\n rootRef: PropTypes.func,\n onChangeLabels: PropTypes.func,\n titlePlaceholder: PropTypes.string,\n mathMlOptions: PropTypes.object,\n labelsCharactersLimit: PropTypes.number,\n };\n\n mouseMove = (g, event) => {\n const { graphProps, onMouseMove } = this.props;\n\n if (!onMouseMove) {\n return;\n }\n\n const { scale, snap } = graphProps;\n const coords = pointer(event, g.node());\n const x = scale.x.invert(coords[0]);\n const y = scale.y.invert(coords[1]);\n\n const snapped = {\n x: snap.x(x),\n y: snap.y(y),\n };\n\n onMouseMove(snapped);\n };\n\n componentDidMount() {\n const g = select(this.g);\n g.on('mousemove', this.mouseMove.bind(this, g));\n this.measureTitleHeight();\n this.setupVisibilityObserver();\n }\n\n componentWillUnmount() {\n const g = select(this.g);\n g.on('mousemove', null);\n this.cleanupVisibilityObserver();\n }\n\n componentDidUpdate(prevProps) {\n if (prevProps.title !== this.props.title) {\n this.measureTitleHeight();\n }\n }\n\n onChangeLabel = (newValue, side) => {\n const { labels, onChangeLabels, isChart } = this.props;\n\n if (!onChangeLabels) {\n return;\n }\n\n if (isChart) {\n if (side === 'left') {\n onChangeLabels('range', newValue);\n } else {\n onChangeLabels('domain', newValue);\n }\n\n return;\n }\n\n onChangeLabels({\n ...labels,\n [side]: newValue,\n });\n };\n\n measureTitleHeight = () => {\n const titleElement = this.titleRef;\n if (titleElement) {\n const titleHeight = titleElement.clientHeight;\n this.setState({ titleHeight, prevTitle: this.props.title });\n\n if (!this.resizeObserver && typeof ResizeObserver !== 'undefined') {\n this.setupVisibilityObserver();\n }\n }\n };\n\n handleKeyDown = () => {\n setTimeout(() => {\n this.measureTitleHeight();\n }, 0);\n };\n\n // handle edge case where chart is hidden with display:none and then shown with display:block\n setupVisibilityObserver = () => {\n if (typeof ResizeObserver !== 'undefined' && this.titleRef) {\n this.resizeObserver = new ResizeObserver((entries) => {\n for (let entry of entries) {\n const { width, height } = entry.contentRect;\n // trigger if element becomes visible and we haven't measured this height yet\n if (width > 0 && height > 0) {\n setTimeout(() => {\n this.measureTitleHeight();\n }, 10);\n break;\n }\n }\n });\n\n this.resizeObserver.observe(this.titleRef);\n }\n };\n\n cleanupVisibilityObserver = () => {\n if (this.resizeObserver) {\n this.resizeObserver.disconnect();\n this.resizeObserver = null;\n }\n };\n\n render() {\n const {\n disabledTitle,\n disabledLabels,\n labels,\n labelsPlaceholders,\n titlePlaceholder,\n graphProps,\n children,\n defineChart,\n onChangeTitle,\n isChart,\n showLabels,\n showPixelGuides,\n showTitle,\n title,\n rootRef,\n mathMlOptions = {},\n labelsCharactersLimit,\n } = this.props;\n const {\n size: { width = 500, height = 500 },\n domain,\n range,\n } = graphProps;\n\n const topPadding = 40;\n const leftPadding = isEmptyString(extractTextFromHTML(labels?.left)) && isEmptyObject(labelsPlaceholders) ? 48 : 70;\n const rightPadding =\n isEmptyString(extractTextFromHTML(labels?.right)) && isEmptyObject(labelsPlaceholders) ? 48 : 70;\n const finalWidth = width + leftPadding + rightPadding + (domain.padding || 0) * 2;\n const finalHeight = height + topPadding * 2 + (range.padding || 0) * 2;\n\n const activeTitlePlugins = [\n 'bold',\n 'italic',\n 'underline',\n 'superscript',\n 'subscript',\n 'strikethrough',\n 'math',\n // 'languageCharacters'\n ];\n\n const actualHeight = defineChart && showPixelGuides ? height - 160 : height;\n const nbOfVerticalLines = parseInt(width / 100);\n const nbOfHorizontalLines = parseInt(actualHeight / 100);\n const sideGridlinesPadding = parseInt(actualHeight % 100);\n const { titleHeight } = this.state;\n\n return (\n <StyledRoot>\n {showPixelGuides && (\n <TopPixelGuides style={{ marginLeft: isChart ? 80 : showLabels ? 30 : 10 }}>\n {[...Array(nbOfVerticalLines + 1).keys()].map((value) => (\n <Readable false key={`top-guide-${value}`}>\n <TopPixelIndicator>\n <div>{value * 100}px</div>\n <div>|</div>\n </TopPixelIndicator>\n </Readable>\n ))}\n </TopPixelGuides>\n )}\n {showTitle &&\n (disabledTitle ? (\n <div\n ref={(r) => (this.titleRef = r)}\n style={{\n ...(isChart && { width: finalWidth }),\n ...(isEmptyString(extractTextFromHTML(title)) && { display: 'none' }),\n }}\n >\n {isChart ? (\n <ChartTitle className=\"disabled\" dangerouslySetInnerHTML={{ __html: title || '' }} />\n ) : (\n <GraphTitle className=\"disabled\" dangerouslySetInnerHTML={{ __html: title || '' }} />\n )}\n </div>\n ) : (\n <div ref={(r) => (this.titleRef = r)}>\n {isChart ? (\n <ChartTitle className={showPixelGuides ? 'rightMargin' : ''}>\n <EditableHtml\n {...(isChart && {\n width: finalWidth,\n })}\n markup={title || ''}\n onChange={onChangeTitle}\n placeholder={\n (defineChart && titlePlaceholder) ||\n (!disabledTitle && 'Click here to add a title for this graph')\n }\n toolbarOpts={{ noPadding: true, noBorder: true }}\n activePlugins={activeTitlePlugins}\n disableScrollbar\n onKeyDown={this.handleKeyDown}\n />\n </ChartTitle>\n ) : (\n <GraphTitle className={showPixelGuides ? 'rightMargin' : ''}>\n <EditableHtml\n {...(isChart && {\n width: finalWidth,\n })}\n markup={title || ''}\n onChange={onChangeTitle}\n placeholder={\n (defineChart && titlePlaceholder) ||\n (!disabledTitle && 'Click here to add a title for this graph')\n }\n toolbarOpts={{ noPadding: true, noBorder: true }}\n activePlugins={activeTitlePlugins}\n disableScrollbar\n onKeyDown={this.handleKeyDown}\n />\n </GraphTitle>\n )}\n </div>\n ))}\n {showLabels && !isChart && (\n <Label\n side=\"top\"\n text={labels.top}\n disabledLabel={disabledLabels}\n placeholder={labelsPlaceholders?.top}\n graphHeight={finalHeight}\n graphWidth={finalWidth}\n onChange={(value) => this.onChangeLabel(value, 'top')}\n mathMlOptions={mathMlOptions}\n preventNewLines={true}\n charactersLimit={labelsCharactersLimit}\n />\n )}\n <Wrapper>\n {showLabels && (\n <Label\n side=\"left\"\n text={labels.left}\n disabledLabel={disabledLabels}\n placeholder={labelsPlaceholders?.left}\n graphHeight={finalHeight}\n graphWidth={finalWidth}\n isChartLeftLabel={isChart && !defineChart}\n isDefineChartLeftLabel={isChart && defineChart}\n onChange={(value) => this.onChangeLabel(value, 'left')}\n mathMlOptions={mathMlOptions}\n preventNewLines={true}\n charactersLimit={labelsCharactersLimit}\n />\n )}\n {defineChart ? (\n <DefineChartSvg width={finalWidth} height={finalHeight}>\n <GraphBox\n ref={(r) => {\n this.g = r;\n if (rootRef) {\n rootRef(r);\n }\n }}\n transform={`translate(${leftPadding + (domain.padding || 0)}, ${topPadding + (range.padding || 0)})`}\n >\n {children}\n </GraphBox>\n </DefineChartSvg>\n ) : (\n <ChartSvg width={finalWidth} height={finalHeight}>\n <GraphBox\n ref={(r) => {\n this.g = r;\n if (rootRef) {\n rootRef(r);\n }\n }}\n transform={`translate(${leftPadding + (domain.padding || 0)}, ${topPadding + (range.padding || 0)})`}\n >\n {children}\n </GraphBox>\n </ChartSvg>\n )}\n {showLabels && !isChart && (\n <Label\n side=\"right\"\n text={labels.right}\n disabledLabel={disabledLabels}\n placeholder={labelsPlaceholders?.right}\n graphHeight={finalHeight}\n graphWidth={finalWidth}\n onChange={(value) => this.onChangeLabel(value, 'right')}\n mathMlOptions={mathMlOptions}\n preventNewLines={true}\n charactersLimit={labelsCharactersLimit}\n />\n )}\n {showPixelGuides && (\n <SidePixelGuides\n style={{\n paddingTop: sideGridlinesPadding,\n marginTop: 31,\n }}\n >\n {[...Array(nbOfHorizontalLines + 1).keys()].reverse().map((value) => (\n <Readable false key={`top-guide-${value}`}>\n <SidePixelIndicator>━ {value * 100}px</SidePixelIndicator>\n </Readable>\n ))}\n </SidePixelGuides>\n )}\n </Wrapper>\n {showLabels && (\n <Label\n side=\"bottom\"\n text={labels.bottom}\n disabledLabel={disabledLabels}\n placeholder={labelsPlaceholders?.bottom}\n graphHeight={finalHeight}\n graphWidth={finalWidth}\n titleHeight={titleHeight}\n isChartBottomLabel={isChart && !defineChart}\n isDefineChartBottomLabel={isChart && defineChart}\n onChange={(value) => this.onChangeLabel(value, 'bottom')}\n mathMlOptions={mathMlOptions}\n preventNewLines={true}\n charactersLimit={labelsCharactersLimit}\n />\n )}\n </StyledRoot>\n );\n }\n}\n\nexport default Root;\n"],"mappings":"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","ignoreList":[]}