@pie-lib/graphing-solution-set 2.16.0-beta.0 → 2.16.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.
Files changed (81) hide show
  1. package/CHANGELOG.md +165 -1
  2. package/package.json +14 -9
  3. package/src/axis/axes.jsx +1 -1
  4. package/src/coordinates-label.jsx +1 -1
  5. package/src/graph-with-controls.jsx +1 -1
  6. package/src/grid-setup.jsx +5 -8
  7. package/src/labels.jsx +1 -1
  8. package/src/mark-label.jsx +1 -1
  9. package/src/toggle-bar.jsx +1 -1
  10. package/src/tools/polygon/line.jsx +1 -1
  11. package/src/tools/polygon/polygon.jsx +1 -1
  12. package/src/tools/shared/arrow-head.jsx +1 -1
  13. package/src/tools/shared/line/index.jsx +1 -1
  14. package/src/tools/shared/line/line-path.jsx +1 -1
  15. package/src/tools/shared/point/base-point.jsx +1 -1
  16. package/src/tools/shared/point/index.jsx +1 -1
  17. package/src/tools/shared/styles.js +1 -1
  18. package/src/undo-redo.jsx +1 -1
  19. package/lib/__tests__/graph-with-controls.test.js +0 -191
  20. package/lib/__tests__/graph.test.js +0 -290
  21. package/lib/__tests__/grid.test.js +0 -40
  22. package/lib/__tests__/labels.test.js +0 -59
  23. package/lib/__tests__/mark-label.test.js +0 -154
  24. package/lib/__tests__/toggle-bar.test.js +0 -54
  25. package/lib/__tests__/tool-menu.test.js +0 -43
  26. package/lib/__tests__/undo-redo.test.js +0 -42
  27. package/lib/__tests__/use-debounce.test.js +0 -28
  28. package/lib/__tests__/utils.js +0 -72
  29. package/lib/__tests__/utils.test.js +0 -133
  30. package/lib/axis/__tests__/arrow.test.js +0 -68
  31. package/lib/axis/__tests__/axes.test.js +0 -214
  32. package/lib/axis/arrow.js +0 -115
  33. package/lib/axis/axes.js +0 -415
  34. package/lib/axis/index.js +0 -26
  35. package/lib/bg.js +0 -139
  36. package/lib/container/actions.js +0 -24
  37. package/lib/container/index.js +0 -166
  38. package/lib/container/marks.js +0 -27
  39. package/lib/container/middleware.js +0 -25
  40. package/lib/container/reducer.js +0 -25
  41. package/lib/coordinates-label.js +0 -109
  42. package/lib/graph-with-controls.js +0 -372
  43. package/lib/graph.js +0 -419
  44. package/lib/grid-setup.js +0 -462
  45. package/lib/grid.js +0 -176
  46. package/lib/index.js +0 -51
  47. package/lib/labels.js +0 -299
  48. package/lib/mark-label.js +0 -208
  49. package/lib/toggle-bar.js +0 -336
  50. package/lib/tool-menu.js +0 -325
  51. package/lib/tools/index.js +0 -29
  52. package/lib/tools/line/__tests__/component.test.js +0 -56
  53. package/lib/tools/line/component.js +0 -106
  54. package/lib/tools/line/index.js +0 -16
  55. package/lib/tools/polygon/__tests__/component.test.js +0 -245
  56. package/lib/tools/polygon/__tests__/index.test.js +0 -95
  57. package/lib/tools/polygon/__tests__/line.test.js +0 -43
  58. package/lib/tools/polygon/__tests__/polygon.test.js +0 -73
  59. package/lib/tools/polygon/component.js +0 -457
  60. package/lib/tools/polygon/index.js +0 -106
  61. package/lib/tools/polygon/line.js +0 -151
  62. package/lib/tools/polygon/polygon.js +0 -171
  63. package/lib/tools/shared/__tests__/arrow-head.test.js +0 -62
  64. package/lib/tools/shared/arrow-head.js +0 -75
  65. package/lib/tools/shared/line/__tests__/index.test.js +0 -291
  66. package/lib/tools/shared/line/__tests__/line-path.test.js +0 -78
  67. package/lib/tools/shared/line/__tests__/with-root-edge.test.js +0 -122
  68. package/lib/tools/shared/line/index.js +0 -637
  69. package/lib/tools/shared/line/line-path.js +0 -145
  70. package/lib/tools/shared/line/with-root-edge.js +0 -155
  71. package/lib/tools/shared/point/__tests__/arrow-point.test.js +0 -137
  72. package/lib/tools/shared/point/__tests__/base-point.test.js +0 -134
  73. package/lib/tools/shared/point/arrow-point.js +0 -113
  74. package/lib/tools/shared/point/arrow.js +0 -96
  75. package/lib/tools/shared/point/base-point.js +0 -151
  76. package/lib/tools/shared/point/index.js +0 -94
  77. package/lib/tools/shared/styles.js +0 -49
  78. package/lib/tools/shared/types.js +0 -19
  79. package/lib/undo-redo.js +0 -107
  80. package/lib/use-debounce.js +0 -32
  81. package/lib/utils.js +0 -314
@@ -1,372 +0,0 @@
1
- "use strict";
2
-
3
- var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
4
-
5
- var _typeof = require("@babel/runtime/helpers/typeof");
6
-
7
- Object.defineProperty(exports, "__esModule", {
8
- value: true
9
- });
10
- exports.toolIsAvailable = exports.setToolbarAvailability = exports.getAvailableTool = exports.filterByVisibleToolTypes = exports.filterByValidToolTypes = exports["default"] = exports.GraphWithControls = void 0;
11
-
12
- var _classCallCheck2 = _interopRequireDefault(require("@babel/runtime/helpers/classCallCheck"));
13
-
14
- var _createClass2 = _interopRequireDefault(require("@babel/runtime/helpers/createClass"));
15
-
16
- var _assertThisInitialized2 = _interopRequireDefault(require("@babel/runtime/helpers/assertThisInitialized"));
17
-
18
- var _inherits2 = _interopRequireDefault(require("@babel/runtime/helpers/inherits"));
19
-
20
- var _possibleConstructorReturn2 = _interopRequireDefault(require("@babel/runtime/helpers/possibleConstructorReturn"));
21
-
22
- var _getPrototypeOf2 = _interopRequireDefault(require("@babel/runtime/helpers/getPrototypeOf"));
23
-
24
- var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty"));
25
-
26
- var _react = _interopRequireDefault(require("react"));
27
-
28
- var _propTypes = _interopRequireDefault(require("prop-types"));
29
-
30
- var _styles = require("@material-ui/core/styles");
31
-
32
- var _classnames = _interopRequireDefault(require("classnames"));
33
-
34
- var _uniq = _interopRequireDefault(require("lodash/uniq"));
35
-
36
- var _isString = _interopRequireDefault(require("lodash/isString"));
37
-
38
- var _renderUi = require("@pie-lib/render-ui");
39
-
40
- var _toolMenu = _interopRequireDefault(require("./tool-menu"));
41
-
42
- var _graph = _interopRequireWildcard(require("./graph"));
43
-
44
- var _undoRedo = _interopRequireDefault(require("./undo-redo"));
45
-
46
- var _tools = require("./tools");
47
-
48
- var _core = require("@material-ui/core");
49
-
50
- var _ExpandMore = _interopRequireDefault(require("@material-ui/icons/ExpandMore"));
51
-
52
- function _getRequireWildcardCache(nodeInterop) { if (typeof WeakMap !== "function") return null; var cacheBabelInterop = new WeakMap(); var cacheNodeInterop = new WeakMap(); return (_getRequireWildcardCache = function _getRequireWildcardCache(nodeInterop) { return nodeInterop ? cacheNodeInterop : cacheBabelInterop; })(nodeInterop); }
53
-
54
- function _interopRequireWildcard(obj, nodeInterop) { if (!nodeInterop && obj && obj.__esModule) { return obj; } if (obj === null || _typeof(obj) !== "object" && typeof obj !== "function") { return { "default": obj }; } var cache = _getRequireWildcardCache(nodeInterop); if (cache && cache.has(obj)) { return cache.get(obj); } var newObj = {}; var hasPropertyDescriptor = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var key in obj) { if (key !== "default" && Object.prototype.hasOwnProperty.call(obj, key)) { var desc = hasPropertyDescriptor ? Object.getOwnPropertyDescriptor(obj, key) : null; if (desc && (desc.get || desc.set)) { Object.defineProperty(newObj, key, desc); } else { newObj[key] = obj[key]; } } } newObj["default"] = obj; if (cache) { cache.set(obj, newObj); } return newObj; }
55
-
56
- function _createSuper(Derived) { var hasNativeReflectConstruct = _isNativeReflectConstruct(); return function _createSuperInternal() { var Super = (0, _getPrototypeOf2["default"])(Derived), result; if (hasNativeReflectConstruct) { var NewTarget = (0, _getPrototypeOf2["default"])(this).constructor; result = Reflect.construct(Super, arguments, NewTarget); } else { result = Super.apply(this, arguments); } return (0, _possibleConstructorReturn2["default"])(this, result); }; }
57
-
58
- function _isNativeReflectConstruct() { if (typeof Reflect === "undefined" || !Reflect.construct) return false; if (Reflect.construct.sham) return false; if (typeof Proxy === "function") return true; try { Boolean.prototype.valueOf.call(Reflect.construct(Boolean, [], function () {})); return true; } catch (e) { return false; } }
59
-
60
- function ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); enumerableOnly && (symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; })), keys.push.apply(keys, symbols); } return keys; }
61
-
62
- function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? ownKeys(Object(source), !0).forEach(function (key) { (0, _defineProperty2["default"])(target, key, source[key]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)) : ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } return target; }
63
-
64
- var setToolbarAvailability = function setToolbarAvailability(toolbarTools) {
65
- return _tools.toolsArr.map(function (tA) {
66
- return _objectSpread(_objectSpread({}, tA), {}, {
67
- toolbar: !!toolbarTools.find(function (t) {
68
- return t === tA.type;
69
- })
70
- });
71
- }) || [];
72
- };
73
-
74
- exports.setToolbarAvailability = setToolbarAvailability;
75
-
76
- var toolIsAvailable = function toolIsAvailable(tools, currentTool) {
77
- return currentTool && tools && (tools.find(function (tool) {
78
- return tool.type === currentTool.type;
79
- }) || {}).toolbar;
80
- };
81
-
82
- exports.toolIsAvailable = toolIsAvailable;
83
-
84
- var getAvailableTool = function getAvailableTool(tools) {
85
- return tools.find(function (tool) {
86
- return tool.toolbar;
87
- });
88
- };
89
-
90
- exports.getAvailableTool = getAvailableTool;
91
-
92
- var filterByValidToolTypes = function filterByValidToolTypes(backgroundMarks) {
93
- return backgroundMarks.filter(function (bM) {
94
- return !!_tools.allTools.find(function (tool) {
95
- return tool === bM.type;
96
- });
97
- });
98
- };
99
-
100
- exports.filterByValidToolTypes = filterByValidToolTypes;
101
-
102
- var filterByVisibleToolTypes = function filterByVisibleToolTypes(toolbarTools, marks) {
103
- return marks.filter(function (bM) {
104
- return !!toolbarTools.find(function (tool) {
105
- return tool === bM.type;
106
- });
107
- });
108
- };
109
-
110
- exports.filterByVisibleToolTypes = filterByVisibleToolTypes;
111
-
112
- var getDefaultCurrentTool = function getDefaultCurrentTool(toolType) {
113
- return _tools.toolsArr.find(function (tool) {
114
- return tool.type === toolType;
115
- }) || null;
116
- };
117
-
118
- var Collapsible = function Collapsible(_ref) {
119
- var classes = _ref.classes,
120
- children = _ref.children,
121
- title = _ref.title;
122
- return /*#__PURE__*/_react["default"].createElement(_core.ExpansionPanel, {
123
- elevation: 0,
124
- className: classes.expansionPanel,
125
- disabledGutters: true,
126
- square: true
127
- }, /*#__PURE__*/_react["default"].createElement(_core.ExpansionPanelSummary, {
128
- classes: {
129
- root: classes.summaryRoot,
130
- content: classes.summaryContent
131
- },
132
- expandIcon: /*#__PURE__*/_react["default"].createElement(_ExpandMore["default"], null)
133
- }, /*#__PURE__*/_react["default"].createElement(_core.Typography, {
134
- variant: "subheading"
135
- }, title)), /*#__PURE__*/_react["default"].createElement(_core.ExpansionPanelDetails, {
136
- className: classes.details
137
- }, children));
138
- };
139
-
140
- Collapsible.propTypes = {
141
- classes: _propTypes["default"].object,
142
- children: _propTypes["default"].array,
143
- title: _propTypes["default"].string
144
- };
145
-
146
- var GraphWithControls = /*#__PURE__*/function (_React$Component) {
147
- (0, _inherits2["default"])(GraphWithControls, _React$Component);
148
-
149
- var _super = _createSuper(GraphWithControls);
150
-
151
- function GraphWithControls(props) {
152
- var _this;
153
-
154
- (0, _classCallCheck2["default"])(this, GraphWithControls);
155
- _this = _super.call(this, props);
156
- (0, _defineProperty2["default"])((0, _assertThisInitialized2["default"])(_this), "changeCurrentTool", function (tool, tools) {
157
- return _this.setState({
158
- currentTool: tools.find(function (t) {
159
- return t.type === tool;
160
- })
161
- });
162
- });
163
- (0, _defineProperty2["default"])((0, _assertThisInitialized2["default"])(_this), "toggleLabelMode", function () {
164
- return _this.setState(function (state) {
165
- return {
166
- labelModeEnabled: !state.labelModeEnabled
167
- };
168
- });
169
- });
170
- _this.state = {
171
- currentTool: getDefaultCurrentTool(props.defaultTool),
172
- labelModeEnabled: false
173
- };
174
- return _this;
175
- }
176
-
177
- (0, _createClass2["default"])(GraphWithControls, [{
178
- key: "componentDidUpdate",
179
- value: function componentDidUpdate(prevProps) {
180
- var defaultTool = this.props.defaultTool;
181
-
182
- if (prevProps.defaultTool !== defaultTool) {
183
- var currentTool = getDefaultCurrentTool(defaultTool);
184
- this.setState({
185
- currentTool: currentTool
186
- });
187
- }
188
- }
189
- }, {
190
- key: "render",
191
- value: function render() {
192
- var _this2 = this;
193
-
194
- var _this$state = this.state,
195
- currentTool = _this$state.currentTool,
196
- labelModeEnabled = _this$state.labelModeEnabled;
197
- var _this$props = this.props,
198
- axesSettings = _this$props.axesSettings,
199
- classes = _this$props.classes,
200
- className = _this$props.className,
201
- coordinatesOnHover = _this$props.coordinatesOnHover,
202
- collapsibleToolbar = _this$props.collapsibleToolbar,
203
- collapsibleToolbarTitle = _this$props.collapsibleToolbarTitle,
204
- disabled = _this$props.disabled,
205
- disabledLabels = _this$props.disabledLabels,
206
- disabledTitle = _this$props.disabledTitle,
207
- domain = _this$props.domain,
208
- labels = _this$props.labels,
209
- labelsPlaceholders = _this$props.labelsPlaceholders,
210
- onChangeLabels = _this$props.onChangeLabels,
211
- onChangeMarks = _this$props.onChangeMarks,
212
- onChangeTitle = _this$props.onChangeTitle,
213
- onUndo = _this$props.onUndo,
214
- onRedo = _this$props.onRedo,
215
- range = _this$props.range,
216
- size = _this$props.size,
217
- showLabels = _this$props.showLabels,
218
- showPixelGuides = _this$props.showPixelGuides,
219
- showTitle = _this$props.showTitle,
220
- title = _this$props.title,
221
- titlePlaceholder = _this$props.titlePlaceholder,
222
- language = _this$props.language,
223
- _this$props$disableTo = _this$props.disableToolbar,
224
- disableToolbar = _this$props$disableTo === void 0 ? false : _this$props$disableTo,
225
- gssLineData = _this$props.gssLineData,
226
- onChangeGssLineData = _this$props.onChangeGssLineData,
227
- onSolutionSetSelected = _this$props.onSolutionSetSelected,
228
- onCustomReset = _this$props.onCustomReset;
229
- var _this$props2 = this.props,
230
- backgroundMarks = _this$props2.backgroundMarks,
231
- marks = _this$props2.marks,
232
- toolbarTools = _this$props2.toolbarTools; // make sure only valid tool types are kept (string) and without duplicates
233
-
234
- toolbarTools = (0, _uniq["default"])(toolbarTools || []).filter(function (tT) {
235
- return !!(0, _isString["default"])(tT);
236
- }) || []; // keep only the backgroundMarks that have valid types
237
-
238
- backgroundMarks = filterByValidToolTypes(backgroundMarks || []); // keep only the marks that have types which appear in toolbar
239
-
240
- marks = filterByVisibleToolTypes(toolbarTools, marks || []);
241
- if (gssLineData && gssLineData.lineA && marks[0] && marks[0].type === 'line') marks[0].fill = gssLineData.lineA.lineType;
242
- if (gssLineData && gssLineData.lineB && marks[1] && marks[1].type === 'line') marks[1].fill = gssLineData.lineB.lineType;
243
- var tools = setToolbarAvailability(toolbarTools); // set current tool if there's no current tool or if the existing one is no longer available
244
-
245
- if (!currentTool || !toolIsAvailable(tools, currentTool)) {
246
- currentTool = getAvailableTool(tools);
247
- }
248
-
249
- var gssActions = gssLineData && /*#__PURE__*/_react["default"].createElement(_react["default"].Fragment, null, /*#__PURE__*/_react["default"].createElement(_toolMenu["default"], {
250
- numberOfLines: gssLineData.numberOfLines,
251
- gssLineData: gssLineData,
252
- onChange: onChangeGssLineData,
253
- disabled: !!disabled,
254
- language: language
255
- }), !disabled && /*#__PURE__*/_react["default"].createElement(_undoRedo["default"], {
256
- className: classes.undoRedoOuterDiv,
257
- onUndo: onUndo,
258
- onRedo: onRedo,
259
- onReset: onCustomReset,
260
- language: language
261
- }));
262
-
263
- return /*#__PURE__*/_react["default"].createElement("div", {
264
- className: (0, _classnames["default"])(classes.graphWithControls, className)
265
- }, !disableToolbar && /*#__PURE__*/_react["default"].createElement("div", {
266
- className: classes.controls
267
- }, collapsibleToolbar ? /*#__PURE__*/_react["default"].createElement(Collapsible, {
268
- classes: classes,
269
- title: collapsibleToolbarTitle
270
- }, gssActions) : gssActions), /*#__PURE__*/_react["default"].createElement("div", {
271
- ref: function ref(r) {
272
- return _this2.labelNode = r;
273
- }
274
- }), /*#__PURE__*/_react["default"].createElement(_graph["default"], {
275
- axesSettings: axesSettings,
276
- backgroundMarks: backgroundMarks,
277
- coordinatesOnHover: coordinatesOnHover,
278
- currentTool: currentTool,
279
- disabledLabels: disabledLabels,
280
- disabledTitle: disabledTitle,
281
- domain: domain,
282
- labels: labels,
283
- labelModeEnabled: labelModeEnabled,
284
- labelsPlaceholders: labelsPlaceholders,
285
- marks: marks,
286
- onChangeMarks: !disabled ? onChangeMarks : undefined,
287
- onChangeLabels: onChangeLabels,
288
- onChangeTitle: onChangeTitle,
289
- range: range,
290
- size: size,
291
- showLabels: showLabels,
292
- showPixelGuides: showPixelGuides,
293
- showTitle: showTitle,
294
- title: title,
295
- titlePlaceholder: titlePlaceholder,
296
- tools: tools,
297
- gssLineData: gssLineData,
298
- onSolutionSetSelected: onSolutionSetSelected,
299
- disabled: !!disabled
300
- }));
301
- }
302
- }]);
303
- return GraphWithControls;
304
- }(_react["default"].Component);
305
-
306
- exports.GraphWithControls = GraphWithControls;
307
- (0, _defineProperty2["default"])(GraphWithControls, "propTypes", _objectSpread(_objectSpread({}, _graph.graphPropTypes), {}, {
308
- onUndo: _propTypes["default"].func,
309
- onRedo: _propTypes["default"].func,
310
- onReset: _propTypes["default"].func,
311
- toolbarTools: _propTypes["default"].arrayOf(_propTypes["default"].string),
312
- // array of tool types that have to be displayed in the toolbar, same shape as 'allTools'
313
- language: _propTypes["default"].string
314
- }));
315
- (0, _defineProperty2["default"])(GraphWithControls, "defaultProps", {
316
- collapsibleToolbar: false,
317
- collapsibleToolbarTitle: '',
318
- disabledLabels: false,
319
- disabledTitle: false,
320
- showLabels: true,
321
- showTitle: true,
322
- toolbarTools: []
323
- });
324
-
325
- var styles = function styles(theme) {
326
- return {
327
- graphWithControls: {
328
- display: 'flex',
329
- flexDirection: 'column',
330
- width: 'min-content'
331
- },
332
- controls: {
333
- display: 'flex',
334
- justifyContent: 'space-between',
335
- padding: 'calc(1.25rem - 12px) calc(1.25rem - 12px) 1.25rem',
336
- color: _renderUi.color.text(),
337
- backgroundColor: '#9FA8DA',
338
- '& button': {
339
- fontSize: '0.875rem',
340
- padding: '0.25rem .3rem',
341
- width: '5rem'
342
- }
343
- },
344
- expansionPanel: {
345
- backgroundColor: _renderUi.color.primaryLight(),
346
- width: '100%'
347
- },
348
- summaryRoot: {
349
- padding: "0 ".concat(theme.spacing.unit, "px"),
350
- minHeight: '32px !important'
351
- },
352
- summaryContent: {
353
- margin: '4px 0 !important'
354
- },
355
- details: {
356
- padding: 0,
357
- marginTop: theme.spacing.unit,
358
- display: 'flex',
359
- justifyContent: 'space-between'
360
- },
361
- undoRedoOuterDiv: {
362
- display: 'flex',
363
- flexDirection: 'column',
364
- marginTop: '.5rem'
365
- }
366
- };
367
- };
368
-
369
- var _default = (0, _styles.withStyles)(styles)(GraphWithControls);
370
-
371
- exports["default"] = _default;
372
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../src/graph-with-controls.jsx"],"names":["setToolbarAvailability","toolbarTools","toolsArr","map","tA","toolbar","find","t","type","toolIsAvailable","tools","currentTool","tool","getAvailableTool","filterByValidToolTypes","backgroundMarks","filter","bM","allTools","filterByVisibleToolTypes","marks","getDefaultCurrentTool","toolType","Collapsible","classes","children","title","expansionPanel","root","summaryRoot","content","summaryContent","details","propTypes","PropTypes","object","array","string","GraphWithControls","props","setState","state","labelModeEnabled","defaultTool","prevProps","axesSettings","className","coordinatesOnHover","collapsibleToolbar","collapsibleToolbarTitle","disabled","disabledLabels","disabledTitle","domain","labels","labelsPlaceholders","onChangeLabels","onChangeMarks","onChangeTitle","onUndo","onRedo","range","size","showLabels","showPixelGuides","showTitle","titlePlaceholder","language","disableToolbar","gssLineData","onChangeGssLineData","onSolutionSetSelected","onCustomReset","tT","lineA","fill","lineType","lineB","gssActions","numberOfLines","undoRedoOuterDiv","graphWithControls","controls","r","labelNode","undefined","React","Component","graphPropTypes","func","onReset","arrayOf","styles","theme","display","flexDirection","width","justifyContent","padding","color","text","backgroundColor","fontSize","primaryLight","spacing","unit","minHeight","margin","marginTop"],"mappings":"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","sourcesContent":["import React from 'react';\nimport PropTypes from 'prop-types';\nimport { withStyles } from '@material-ui/core/styles';\nimport classNames from 'classnames';\nimport uniq from 'lodash/uniq';\nimport isString from 'lodash/isString';\nimport { color } from '@pie-lib/render-ui';\nimport ToolMenu from './tool-menu';\nimport Graph, { graphPropTypes } from './graph';\nimport UndoRedo from './undo-redo';\nimport { allTools, toolsArr } from './tools';\nimport { ExpansionPanel, ExpansionPanelDetails, ExpansionPanelSummary, Typography } from '@material-ui/core';\nimport ExpandMoreIcon from '@material-ui/icons/ExpandMore';\n\nexport const setToolbarAvailability = (toolbarTools) =>\n  toolsArr.map((tA) => ({ ...tA, toolbar: !!toolbarTools.find((t) => t === tA.type) })) || [];\n\nexport const toolIsAvailable = (tools, currentTool) =>\n  currentTool && tools && (tools.find((tool) => tool.type === currentTool.type) || {}).toolbar;\n\nexport const getAvailableTool = (tools) => tools.find((tool) => tool.toolbar);\n\nexport const filterByValidToolTypes = (backgroundMarks) =>\n  backgroundMarks.filter((bM) => !!allTools.find((tool) => tool === bM.type));\n\nexport const filterByVisibleToolTypes = (toolbarTools, marks) =>\n  marks.filter((bM) => !!toolbarTools.find((tool) => tool === bM.type));\n\nconst getDefaultCurrentTool = (toolType) => toolsArr.find((tool) => tool.type === toolType) || null;\n\nconst Collapsible = ({ classes, children, title }) => (\n  <ExpansionPanel elevation={0} className={classes.expansionPanel} disabledGutters={true} square={true}>\n    <ExpansionPanelSummary\n      classes={{\n        root: classes.summaryRoot,\n        content: classes.summaryContent,\n      }}\n      expandIcon={<ExpandMoreIcon />}\n    >\n      <Typography variant=\"subheading\">{title}</Typography>\n    </ExpansionPanelSummary>\n    <ExpansionPanelDetails className={classes.details}>{children}</ExpansionPanelDetails>\n  </ExpansionPanel>\n);\n\nCollapsible.propTypes = {\n  classes: PropTypes.object,\n  children: PropTypes.array,\n  title: PropTypes.string,\n};\n\nexport class GraphWithControls extends React.Component {\n  static propTypes = {\n    ...graphPropTypes,\n    onUndo: PropTypes.func,\n    onRedo: PropTypes.func,\n    onReset: PropTypes.func,\n    toolbarTools: PropTypes.arrayOf(PropTypes.string), // array of tool types that have to be displayed in the toolbar, same shape as 'allTools'\n    language: PropTypes.string,\n  };\n\n  static defaultProps = {\n    collapsibleToolbar: false,\n    collapsibleToolbarTitle: '',\n    disabledLabels: false,\n    disabledTitle: false,\n    showLabels: true,\n    showTitle: true,\n    toolbarTools: [],\n  };\n\n  constructor(props) {\n    super(props);\n\n    this.state = {\n      currentTool: getDefaultCurrentTool(props.defaultTool),\n      labelModeEnabled: false,\n    };\n  }\n\n  componentDidUpdate(prevProps) {\n    const { defaultTool } = this.props;\n\n    if (prevProps.defaultTool !== defaultTool) {\n      const currentTool = getDefaultCurrentTool(defaultTool);\n\n      this.setState({ currentTool });\n    }\n  }\n\n  changeCurrentTool = (tool, tools) => this.setState({ currentTool: tools.find((t) => t.type === tool) });\n\n  toggleLabelMode = () => this.setState((state) => ({ labelModeEnabled: !state.labelModeEnabled }));\n\n  render() {\n    let { currentTool, labelModeEnabled } = this.state;\n    const {\n      axesSettings,\n      classes,\n      className,\n      coordinatesOnHover,\n      collapsibleToolbar,\n      collapsibleToolbarTitle,\n      disabled,\n      disabledLabels,\n      disabledTitle,\n      domain,\n      labels,\n      labelsPlaceholders,\n      onChangeLabels,\n      onChangeMarks,\n      onChangeTitle,\n      onUndo,\n      onRedo,\n      range,\n      size,\n      showLabels,\n      showPixelGuides,\n      showTitle,\n      title,\n      titlePlaceholder,\n      language,\n      disableToolbar = false,\n      gssLineData,\n      onChangeGssLineData,\n      onSolutionSetSelected,\n      onCustomReset,\n    } = this.props;\n    let { backgroundMarks, marks, toolbarTools } = this.props;\n\n    // make sure only valid tool types are kept (string) and without duplicates\n    toolbarTools = uniq(toolbarTools || []).filter((tT) => !!isString(tT)) || [];\n\n    // keep only the backgroundMarks that have valid types\n    backgroundMarks = filterByValidToolTypes(backgroundMarks || []);\n\n    // keep only the marks that have types which appear in toolbar\n    marks = filterByVisibleToolTypes(toolbarTools, marks || []);\n\n    if (gssLineData && gssLineData.lineA && marks[0] && marks[0].type === 'line')\n      marks[0].fill = gssLineData.lineA.lineType;\n    if (gssLineData && gssLineData.lineB && marks[1] && marks[1].type === 'line')\n      marks[1].fill = gssLineData.lineB.lineType;\n\n    const tools = setToolbarAvailability(toolbarTools);\n\n    // set current tool if there's no current tool or if the existing one is no longer available\n    if (!currentTool || !toolIsAvailable(tools, currentTool)) {\n      currentTool = getAvailableTool(tools);\n    }\n\n    const gssActions = gssLineData && (\n      <React.Fragment>\n        <ToolMenu\n          numberOfLines={gssLineData.numberOfLines}\n          gssLineData={gssLineData}\n          onChange={onChangeGssLineData}\n          disabled={!!disabled}\n          language={language}\n        />\n        {!disabled && (\n          <UndoRedo\n            className={classes.undoRedoOuterDiv}\n            onUndo={onUndo}\n            onRedo={onRedo}\n            onReset={onCustomReset}\n            language={language}\n          />\n        )}\n      </React.Fragment>\n    );\n\n    return (\n      <div className={classNames(classes.graphWithControls, className)}>\n        {!disableToolbar && (\n          <div className={classes.controls}>\n            {collapsibleToolbar ? (\n              <Collapsible classes={classes} title={collapsibleToolbarTitle}>\n                {gssActions}\n              </Collapsible>\n            ) : (\n              gssActions\n            )}\n          </div>\n        )}\n\n        <div ref={(r) => (this.labelNode = r)} />\n\n        <Graph\n          axesSettings={axesSettings}\n          backgroundMarks={backgroundMarks}\n          coordinatesOnHover={coordinatesOnHover}\n          currentTool={currentTool}\n          disabledLabels={disabledLabels}\n          disabledTitle={disabledTitle}\n          domain={domain}\n          labels={labels}\n          labelModeEnabled={labelModeEnabled}\n          labelsPlaceholders={labelsPlaceholders}\n          marks={marks}\n          onChangeMarks={!disabled ? onChangeMarks : undefined}\n          onChangeLabels={onChangeLabels}\n          onChangeTitle={onChangeTitle}\n          range={range}\n          size={size}\n          showLabels={showLabels}\n          showPixelGuides={showPixelGuides}\n          showTitle={showTitle}\n          title={title}\n          titlePlaceholder={titlePlaceholder}\n          tools={tools}\n          gssLineData={gssLineData}\n          onSolutionSetSelected={onSolutionSetSelected}\n          disabled={!!disabled}\n        />\n      </div>\n    );\n  }\n}\n\nconst styles = (theme) => ({\n  graphWithControls: {\n    display: 'flex',\n    flexDirection: 'column',\n    width: 'min-content',\n  },\n  controls: {\n    display: 'flex',\n    justifyContent: 'space-between',\n    padding: 'calc(1.25rem - 12px) calc(1.25rem - 12px) 1.25rem',\n    color: color.text(),\n    backgroundColor: '#9FA8DA',\n    '& button': {\n      fontSize: '0.875rem',\n      padding: '0.25rem .3rem',\n      width: '5rem',\n    },\n  },\n  expansionPanel: {\n    backgroundColor: color.primaryLight(),\n    width: '100%',\n  },\n  summaryRoot: {\n    padding: `0 ${theme.spacing.unit}px`,\n    minHeight: '32px !important',\n  },\n  summaryContent: {\n    margin: '4px 0 !important',\n  },\n  details: {\n    padding: 0,\n    marginTop: theme.spacing.unit,\n    display: 'flex',\n    justifyContent: 'space-between',\n  },\n  undoRedoOuterDiv: {\n    display: 'flex',\n    flexDirection: 'column',\n    marginTop: '.5rem',\n  },\n});\n\nexport default withStyles(styles)(GraphWithControls);\n"]}