@pie-lib/charting 6.2.0-next.0 → 6.2.0-next.2
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/lib/__tests__/actions-button.test.js +332 -0
- package/lib/__tests__/axes.test.js +746 -0
- package/lib/__tests__/chart-setup.test.js +796 -0
- package/lib/__tests__/chart-type.test.js +25 -0
- package/lib/__tests__/chart.test.js +103 -0
- package/lib/__tests__/grid.test.js +39 -0
- package/lib/__tests__/key-legend.test.js +235 -0
- package/lib/__tests__/mark-label.test.js +46 -0
- package/lib/__tests__/tool-menu.test.js +627 -0
- package/lib/__tests__/utils.js +56 -0
- package/lib/__tests__/utils.test.js +186 -0
- package/lib/actions-button.js +1 -1
- package/lib/axes.js +1 -1
- package/lib/bars/__tests__/bar.test.js +53 -0
- package/lib/bars/__tests__/histogram.test.js +53 -0
- package/lib/bars/__tests__/utils.js +50 -0
- package/lib/bars/bar.js +1 -1
- package/lib/bars/common/__tests__/bars.test.js +76 -0
- package/lib/bars/common/__tests__/utils.js +50 -0
- package/lib/bars/common/bars.js +1 -1
- package/lib/bars/common/correct-check-icon.js +1 -1
- package/lib/bars/histogram.js +1 -1
- package/lib/chart-setup.js +1 -1
- package/lib/chart-type.js +1 -1
- package/lib/chart-types.js +1 -1
- package/lib/chart.js +1 -1
- package/lib/common/__tests__/correctness-indicators.test.js +887 -0
- package/lib/common/__tests__/drag-handle.test.js +73 -0
- package/lib/common/__tests__/utils.js +50 -0
- package/lib/common/correctness-indicators.js +1 -1
- package/lib/common/drag-handle.js +1 -1
- package/lib/common/drag-icon.js +1 -1
- package/lib/common/styles.js +1 -1
- package/lib/grid.js +1 -1
- package/lib/index.js +1 -1
- package/lib/key-legend.js +1 -1
- package/lib/line/__tests__/line-cross.test.js +617 -0
- package/lib/line/__tests__/line-dot.test.js +47 -0
- package/lib/line/__tests__/utils.js +56 -0
- package/lib/line/common/__tests__/drag-handle.test.js +73 -0
- package/lib/line/common/__tests__/line.test.js +92 -0
- package/lib/line/common/__tests__/utils.js +50 -0
- package/lib/line/common/drag-handle.js +1 -1
- package/lib/line/common/line.js +1 -1
- package/lib/line/line-cross.js +1 -1
- package/lib/line/line-dot.js +1 -1
- package/lib/mark-label.js +1 -1
- package/lib/plot/__tests__/dot.test.js +513 -0
- package/lib/plot/__tests__/line.test.js +566 -0
- package/lib/plot/__tests__/utils.js +50 -0
- package/lib/plot/common/__tests__/plot.test.js +79 -0
- package/lib/plot/common/__tests__/utils.js +50 -0
- package/lib/plot/common/plot.js +1 -1
- package/lib/plot/dot.js +1 -1
- package/lib/plot/line.js +1 -1
- package/lib/tool-menu.js +1 -1
- package/lib/utils.js +1 -1
- package/package.json +8 -11
- package/LICENSE.md +0 -5
|
@@ -0,0 +1,25 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
|
|
3
|
+
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
|
|
4
|
+
var _react = _interopRequireDefault(require("react"));
|
|
5
|
+
var _testUtils = require("@pie-lib/test-utils");
|
|
6
|
+
var _chartType = _interopRequireDefault(require("../chart-type"));
|
|
7
|
+
describe('ChartType', function () {
|
|
8
|
+
var props;
|
|
9
|
+
var onChange = jest.fn();
|
|
10
|
+
beforeEach(function () {
|
|
11
|
+
props = {
|
|
12
|
+
classes: {},
|
|
13
|
+
value: 'bar',
|
|
14
|
+
onChange: onChange
|
|
15
|
+
};
|
|
16
|
+
});
|
|
17
|
+
describe('rendering', function () {
|
|
18
|
+
it('renders chart type selector', function () {
|
|
19
|
+
var _render = (0, _testUtils.render)(/*#__PURE__*/_react["default"].createElement(_chartType["default"], props)),
|
|
20
|
+
container = _render.container;
|
|
21
|
+
expect(container.firstChild).toBeInTheDocument();
|
|
22
|
+
});
|
|
23
|
+
});
|
|
24
|
+
});
|
|
25
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJfcmVhY3QiLCJfaW50ZXJvcFJlcXVpcmVEZWZhdWx0IiwicmVxdWlyZSIsIl90ZXN0VXRpbHMiLCJfY2hhcnRUeXBlIiwiZGVzY3JpYmUiLCJwcm9wcyIsIm9uQ2hhbmdlIiwiamVzdCIsImZuIiwiYmVmb3JlRWFjaCIsImNsYXNzZXMiLCJ2YWx1ZSIsIml0IiwiX3JlbmRlciIsInJlbmRlciIsImNyZWF0ZUVsZW1lbnQiLCJjb250YWluZXIiLCJleHBlY3QiLCJmaXJzdENoaWxkIiwidG9CZUluVGhlRG9jdW1lbnQiXSwic291cmNlcyI6WyIuLi8uLi9zcmMvX190ZXN0c19fL2NoYXJ0LXR5cGUudGVzdC5qc3giXSwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IFJlYWN0IGZyb20gJ3JlYWN0JztcbmltcG9ydCB7IHJlbmRlciB9IGZyb20gJ0BwaWUtbGliL3Rlc3QtdXRpbHMnO1xuaW1wb3J0IENoYXJ0VHlwZSBmcm9tICcuLi9jaGFydC10eXBlJztcblxuZGVzY3JpYmUoJ0NoYXJ0VHlwZScsICgpID0+IHtcbiAgbGV0IHByb3BzO1xuICBjb25zdCBvbkNoYW5nZSA9IGplc3QuZm4oKTtcblxuICBiZWZvcmVFYWNoKCgpID0+IHtcbiAgICBwcm9wcyA9IHtcbiAgICAgIGNsYXNzZXM6IHt9LFxuICAgICAgdmFsdWU6ICdiYXInLFxuICAgICAgb25DaGFuZ2UsXG4gICAgfTtcbiAgfSk7XG5cbiAgZGVzY3JpYmUoJ3JlbmRlcmluZycsICgpID0+IHtcbiAgICBpdCgncmVuZGVycyBjaGFydCB0eXBlIHNlbGVjdG9yJywgKCkgPT4ge1xuICAgICAgY29uc3QgeyBjb250YWluZXIgfSA9IHJlbmRlcig8Q2hhcnRUeXBlIHsuLi5wcm9wc30gLz4pO1xuICAgICAgZXhwZWN0KGNvbnRhaW5lci5maXJzdENoaWxkKS50b0JlSW5UaGVEb2N1bWVudCgpO1xuICAgIH0pO1xuICB9KTtcbn0pO1xuIl0sIm1hcHBpbmdzIjoiOzs7QUFBQSxJQUFBQSxNQUFBLEdBQUFDLHNCQUFBLENBQUFDLE9BQUE7QUFDQSxJQUFBQyxVQUFBLEdBQUFELE9BQUE7QUFDQSxJQUFBRSxVQUFBLEdBQUFILHNCQUFBLENBQUFDLE9BQUE7QUFFQUcsUUFBUSxDQUFDLFdBQVcsRUFBRSxZQUFNO0VBQzFCLElBQUlDLEtBQUs7RUFDVCxJQUFNQyxRQUFRLEdBQUdDLElBQUksQ0FBQ0MsRUFBRSxDQUFDLENBQUM7RUFFMUJDLFVBQVUsQ0FBQyxZQUFNO0lBQ2ZKLEtBQUssR0FBRztNQUNOSyxPQUFPLEVBQUUsQ0FBQyxDQUFDO01BQ1hDLEtBQUssRUFBRSxLQUFLO01BQ1pMLFFBQVEsRUFBUkE7SUFDRixDQUFDO0VBQ0gsQ0FBQyxDQUFDO0VBRUZGLFFBQVEsQ0FBQyxXQUFXLEVBQUUsWUFBTTtJQUMxQlEsRUFBRSxDQUFDLDZCQUE2QixFQUFFLFlBQU07TUFDdEMsSUFBQUMsT0FBQSxHQUFzQixJQUFBQyxpQkFBTSxlQUFDZixNQUFBLFlBQUFnQixhQUFBLENBQUNaLFVBQUEsV0FBUyxFQUFLRSxLQUFRLENBQUMsQ0FBQztRQUE5Q1csU0FBUyxHQUFBSCxPQUFBLENBQVRHLFNBQVM7TUFDakJDLE1BQU0sQ0FBQ0QsU0FBUyxDQUFDRSxVQUFVLENBQUMsQ0FBQ0MsaUJBQWlCLENBQUMsQ0FBQztJQUNsRCxDQUFDLENBQUM7RUFDSixDQUFDLENBQUM7QUFDSixDQUFDLENBQUMiLCJpZ25vcmVMaXN0IjpbXX0=
|
|
@@ -0,0 +1,103 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
|
|
3
|
+
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
|
|
4
|
+
var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty"));
|
|
5
|
+
var _react = _interopRequireDefault(require("react"));
|
|
6
|
+
var _testUtils = require("@pie-lib/test-utils");
|
|
7
|
+
var _chart = require("../chart");
|
|
8
|
+
var _utils = require("./utils");
|
|
9
|
+
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; }
|
|
10
|
+
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; }
|
|
11
|
+
describe('ChartAxes', function () {
|
|
12
|
+
var onDataChange = jest.fn();
|
|
13
|
+
var renderComponent = function renderComponent(extras) {
|
|
14
|
+
var defaults = {
|
|
15
|
+
classes: {},
|
|
16
|
+
onDataChange: onDataChange,
|
|
17
|
+
className: 'className',
|
|
18
|
+
graphProps: (0, _utils.graphProps)(),
|
|
19
|
+
xBand: (0, _utils.createBandScale)(['a', 'b', 'c'], [0, 100]),
|
|
20
|
+
charts: [{
|
|
21
|
+
type: 'bar',
|
|
22
|
+
Component: function Component() {
|
|
23
|
+
return /*#__PURE__*/_react["default"].createElement("div", null);
|
|
24
|
+
}
|
|
25
|
+
}],
|
|
26
|
+
chartType: 'bar',
|
|
27
|
+
domain: {},
|
|
28
|
+
range: {
|
|
29
|
+
min: 0,
|
|
30
|
+
max: 10
|
|
31
|
+
},
|
|
32
|
+
size: {
|
|
33
|
+
width: 100,
|
|
34
|
+
height: 100
|
|
35
|
+
},
|
|
36
|
+
data: []
|
|
37
|
+
};
|
|
38
|
+
var props = _objectSpread(_objectSpread({}, defaults), extras);
|
|
39
|
+
return (0, _testUtils.render)(/*#__PURE__*/_react["default"].createElement(_chart.Chart, props));
|
|
40
|
+
};
|
|
41
|
+
describe('rendering', function () {
|
|
42
|
+
it('renders chart container', function () {
|
|
43
|
+
var _renderComponent = renderComponent(),
|
|
44
|
+
container = _renderComponent.container;
|
|
45
|
+
expect(container.firstChild).toBeInTheDocument();
|
|
46
|
+
expect(container.querySelector('svg')).toBeInTheDocument();
|
|
47
|
+
});
|
|
48
|
+
it('renders chart with default size', function () {
|
|
49
|
+
var _renderComponent2 = renderComponent(),
|
|
50
|
+
container = _renderComponent2.container;
|
|
51
|
+
var svg = container.querySelector('svg');
|
|
52
|
+
expect(svg).toBeInTheDocument();
|
|
53
|
+
expect(svg).toHaveAttribute('width', '240');
|
|
54
|
+
expect(svg).toHaveAttribute('height', '240');
|
|
55
|
+
});
|
|
56
|
+
it('renders chart when size is not defined', function () {
|
|
57
|
+
var _renderComponent3 = renderComponent({
|
|
58
|
+
size: undefined
|
|
59
|
+
}),
|
|
60
|
+
container = _renderComponent3.container;
|
|
61
|
+
expect(container.firstChild).toBeInTheDocument();
|
|
62
|
+
var svg = container.querySelector('svg');
|
|
63
|
+
expect(svg).toBeInTheDocument();
|
|
64
|
+
});
|
|
65
|
+
it('renders chart without chartType property', function () {
|
|
66
|
+
var _renderComponent4 = renderComponent({
|
|
67
|
+
chartType: null
|
|
68
|
+
}),
|
|
69
|
+
container = _renderComponent4.container;
|
|
70
|
+
expect(container.firstChild).toBeInTheDocument();
|
|
71
|
+
expect(container.querySelector('svg')).toBeInTheDocument();
|
|
72
|
+
});
|
|
73
|
+
it('renders chart without chartType and charts properties', function () {
|
|
74
|
+
var _renderComponent5 = renderComponent({
|
|
75
|
+
chartType: null,
|
|
76
|
+
charts: null
|
|
77
|
+
}),
|
|
78
|
+
container = _renderComponent5.container;
|
|
79
|
+
expect(container.firstChild).toBeInTheDocument();
|
|
80
|
+
});
|
|
81
|
+
it('renders chart without chartType property and empty charts property', function () {
|
|
82
|
+
var _renderComponent6 = renderComponent({
|
|
83
|
+
chartType: null,
|
|
84
|
+
charts: []
|
|
85
|
+
}),
|
|
86
|
+
container = _renderComponent6.container;
|
|
87
|
+
expect(container.firstChild).toBeInTheDocument();
|
|
88
|
+
});
|
|
89
|
+
it('renders chart with chartType property and empty charts property', function () {
|
|
90
|
+
var _renderComponent7 = renderComponent({
|
|
91
|
+
charts: []
|
|
92
|
+
}),
|
|
93
|
+
container = _renderComponent7.container;
|
|
94
|
+
expect(container.firstChild).toBeInTheDocument();
|
|
95
|
+
expect(container.querySelector('svg')).toBeInTheDocument();
|
|
96
|
+
});
|
|
97
|
+
});
|
|
98
|
+
|
|
99
|
+
// Note: changeData, getChart, and deleteCategory are internal implementation details.
|
|
100
|
+
// In RTL philosophy, we test user-visible behavior rather than implementation.
|
|
101
|
+
// These methods would be tested indirectly through user interactions that trigger them.
|
|
102
|
+
});
|
|
103
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_react","_interopRequireDefault","require","_testUtils","_chart","_utils","ownKeys","e","r","t","Object","keys","getOwnPropertySymbols","o","filter","getOwnPropertyDescriptor","enumerable","push","apply","_objectSpread","arguments","length","forEach","_defineProperty2","getOwnPropertyDescriptors","defineProperties","defineProperty","describe","onDataChange","jest","fn","renderComponent","extras","defaults","classes","className","graphProps","xBand","createBandScale","charts","type","Component","createElement","chartType","domain","range","min","max","size","width","height","data","props","render","Chart","it","_renderComponent","container","expect","firstChild","toBeInTheDocument","querySelector","_renderComponent2","svg","toHaveAttribute","_renderComponent3","undefined","_renderComponent4","_renderComponent5","_renderComponent6","_renderComponent7"],"sources":["../../src/__tests__/chart.test.jsx"],"sourcesContent":["import React from 'react';\nimport { render } from '@pie-lib/test-utils';\nimport { Chart } from '../chart';\nimport { createBandScale, graphProps } from './utils';\n\ndescribe('ChartAxes', () => {\n  let onDataChange = jest.fn();\n\n  const renderComponent = (extras) => {\n    const defaults = {\n      classes: {},\n      onDataChange,\n      className: 'className',\n      graphProps: graphProps(),\n      xBand: createBandScale(['a', 'b', 'c'], [0, 100]),\n      charts: [\n        {\n          type: 'bar',\n          Component: () => <div />,\n        },\n      ],\n      chartType: 'bar',\n      domain: {},\n      range: {\n        min: 0,\n        max: 10,\n      },\n      size: {\n        width: 100,\n        height: 100,\n      },\n      data: [],\n    };\n    const props = { ...defaults, ...extras };\n    return render(<Chart {...props} />);\n  };\n\n  describe('rendering', () => {\n    it('renders chart container', () => {\n      const { container } = renderComponent();\n      expect(container.firstChild).toBeInTheDocument();\n      expect(container.querySelector('svg')).toBeInTheDocument();\n    });\n\n    it('renders chart with default size', () => {\n      const { container } = renderComponent();\n      const svg = container.querySelector('svg');\n      expect(svg).toBeInTheDocument();\n      expect(svg).toHaveAttribute('width', '240');\n      expect(svg).toHaveAttribute('height', '240');\n    });\n\n    it('renders chart when size is not defined', () => {\n      const { container } = renderComponent({ size: undefined });\n      expect(container.firstChild).toBeInTheDocument();\n      const svg = container.querySelector('svg');\n      expect(svg).toBeInTheDocument();\n    });\n\n    it('renders chart without chartType property', () => {\n      const { container } = renderComponent({ chartType: null });\n      expect(container.firstChild).toBeInTheDocument();\n      expect(container.querySelector('svg')).toBeInTheDocument();\n    });\n\n    it('renders chart without chartType and charts properties', () => {\n      const { container } = renderComponent({ chartType: null, charts: null });\n      expect(container.firstChild).toBeInTheDocument();\n    });\n\n    it('renders chart without chartType property and empty charts property', () => {\n      const { container } = renderComponent({ chartType: null, charts: [] });\n      expect(container.firstChild).toBeInTheDocument();\n    });\n\n    it('renders chart with chartType property and empty charts property', () => {\n      const { container } = renderComponent({ charts: [] });\n      expect(container.firstChild).toBeInTheDocument();\n      expect(container.querySelector('svg')).toBeInTheDocument();\n    });\n  });\n\n  // Note: changeData, getChart, and deleteCategory are internal implementation details.\n  // In RTL philosophy, we test user-visible behavior rather than implementation.\n  // These methods would be tested indirectly through user interactions that trigger them.\n});\n"],"mappings":"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","ignoreList":[]}
|
|
@@ -0,0 +1,39 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
|
|
3
|
+
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
|
|
4
|
+
var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty"));
|
|
5
|
+
var _react = _interopRequireDefault(require("react"));
|
|
6
|
+
var _testUtils = require("@pie-lib/test-utils");
|
|
7
|
+
var _grid = require("../grid");
|
|
8
|
+
var _utils = require("./utils");
|
|
9
|
+
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; }
|
|
10
|
+
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; }
|
|
11
|
+
describe('Grid', function () {
|
|
12
|
+
var renderComponent = function renderComponent(extras) {
|
|
13
|
+
var defaults = {
|
|
14
|
+
classes: {},
|
|
15
|
+
className: 'className',
|
|
16
|
+
graphProps: (0, _utils.graphProps)(),
|
|
17
|
+
xBand: (0, _utils.createBandScale)(['a', 'b', 'c'], [0, 400])
|
|
18
|
+
};
|
|
19
|
+
var props = _objectSpread(_objectSpread({}, defaults), extras);
|
|
20
|
+
return (0, _testUtils.render)(/*#__PURE__*/_react["default"].createElement("svg", null, /*#__PURE__*/_react["default"].createElement(_grid.Grid, props)));
|
|
21
|
+
};
|
|
22
|
+
describe('rendering', function () {
|
|
23
|
+
it('renders grid container', function () {
|
|
24
|
+
var _renderComponent = renderComponent(),
|
|
25
|
+
container = _renderComponent.container;
|
|
26
|
+
expect(container.firstChild).toBeInTheDocument();
|
|
27
|
+
});
|
|
28
|
+
it('renders grid with SVG group', function () {
|
|
29
|
+
var _renderComponent2 = renderComponent(),
|
|
30
|
+
container = _renderComponent2.container;
|
|
31
|
+
var svg = container.querySelector('svg');
|
|
32
|
+
expect(svg).toBeInTheDocument();
|
|
33
|
+
// Grid renders a <g> element (StyledGridGroup)
|
|
34
|
+
var gridGroup = container.querySelector('g');
|
|
35
|
+
expect(gridGroup).toBeInTheDocument();
|
|
36
|
+
});
|
|
37
|
+
});
|
|
38
|
+
});
|
|
39
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJfcmVhY3QiLCJfaW50ZXJvcFJlcXVpcmVEZWZhdWx0IiwicmVxdWlyZSIsIl90ZXN0VXRpbHMiLCJfZ3JpZCIsIl91dGlscyIsIm93bktleXMiLCJlIiwiciIsInQiLCJPYmplY3QiLCJrZXlzIiwiZ2V0T3duUHJvcGVydHlTeW1ib2xzIiwibyIsImZpbHRlciIsImdldE93blByb3BlcnR5RGVzY3JpcHRvciIsImVudW1lcmFibGUiLCJwdXNoIiwiYXBwbHkiLCJfb2JqZWN0U3ByZWFkIiwiYXJndW1lbnRzIiwibGVuZ3RoIiwiZm9yRWFjaCIsIl9kZWZpbmVQcm9wZXJ0eTIiLCJnZXRPd25Qcm9wZXJ0eURlc2NyaXB0b3JzIiwiZGVmaW5lUHJvcGVydGllcyIsImRlZmluZVByb3BlcnR5IiwiZGVzY3JpYmUiLCJyZW5kZXJDb21wb25lbnQiLCJleHRyYXMiLCJkZWZhdWx0cyIsImNsYXNzZXMiLCJjbGFzc05hbWUiLCJncmFwaFByb3BzIiwieEJhbmQiLCJjcmVhdGVCYW5kU2NhbGUiLCJwcm9wcyIsInJlbmRlciIsImNyZWF0ZUVsZW1lbnQiLCJHcmlkIiwiaXQiLCJfcmVuZGVyQ29tcG9uZW50IiwiY29udGFpbmVyIiwiZXhwZWN0IiwiZmlyc3RDaGlsZCIsInRvQmVJblRoZURvY3VtZW50IiwiX3JlbmRlckNvbXBvbmVudDIiLCJzdmciLCJxdWVyeVNlbGVjdG9yIiwiZ3JpZEdyb3VwIl0sInNvdXJjZXMiOlsiLi4vLi4vc3JjL19fdGVzdHNfXy9ncmlkLnRlc3QuanN4Il0sInNvdXJjZXNDb250ZW50IjpbImltcG9ydCBSZWFjdCBmcm9tICdyZWFjdCc7XG5pbXBvcnQgeyByZW5kZXIgfSBmcm9tICdAcGllLWxpYi90ZXN0LXV0aWxzJztcbmltcG9ydCB7IEdyaWQgfSBmcm9tICcuLi9ncmlkJztcbmltcG9ydCB7IGNyZWF0ZUJhbmRTY2FsZSwgZ3JhcGhQcm9wcyB9IGZyb20gJy4vdXRpbHMnO1xuXG5kZXNjcmliZSgnR3JpZCcsICgpID0+IHtcbiAgY29uc3QgcmVuZGVyQ29tcG9uZW50ID0gKGV4dHJhcykgPT4ge1xuICAgIGNvbnN0IGRlZmF1bHRzID0ge1xuICAgICAgY2xhc3Nlczoge30sXG4gICAgICBjbGFzc05hbWU6ICdjbGFzc05hbWUnLFxuICAgICAgZ3JhcGhQcm9wczogZ3JhcGhQcm9wcygpLFxuICAgICAgeEJhbmQ6IGNyZWF0ZUJhbmRTY2FsZShbJ2EnLCAnYicsICdjJ10sIFswLCA0MDBdKSxcbiAgICB9O1xuICAgIGNvbnN0IHByb3BzID0geyAuLi5kZWZhdWx0cywgLi4uZXh0cmFzIH07XG4gICAgcmV0dXJuIHJlbmRlcihcbiAgICAgIDxzdmc+XG4gICAgICAgIDxHcmlkIHsuLi5wcm9wc30gLz5cbiAgICAgIDwvc3ZnPixcbiAgICApO1xuICB9O1xuXG4gIGRlc2NyaWJlKCdyZW5kZXJpbmcnLCAoKSA9PiB7XG4gICAgaXQoJ3JlbmRlcnMgZ3JpZCBjb250YWluZXInLCAoKSA9PiB7XG4gICAgICBjb25zdCB7IGNvbnRhaW5lciB9ID0gcmVuZGVyQ29tcG9uZW50KCk7XG4gICAgICBleHBlY3QoY29udGFpbmVyLmZpcnN0Q2hpbGQpLnRvQmVJblRoZURvY3VtZW50KCk7XG4gICAgfSk7XG5cbiAgICBpdCgncmVuZGVycyBncmlkIHdpdGggU1ZHIGdyb3VwJywgKCkgPT4ge1xuICAgICAgY29uc3QgeyBjb250YWluZXIgfSA9IHJlbmRlckNvbXBvbmVudCgpO1xuICAgICAgY29uc3Qgc3ZnID0gY29udGFpbmVyLnF1ZXJ5U2VsZWN0b3IoJ3N2ZycpO1xuICAgICAgZXhwZWN0KHN2ZykudG9CZUluVGhlRG9jdW1lbnQoKTtcbiAgICAgIC8vIEdyaWQgcmVuZGVycyBhIDxnPiBlbGVtZW50IChTdHlsZWRHcmlkR3JvdXApXG4gICAgICBjb25zdCBncmlkR3JvdXAgPSBjb250YWluZXIucXVlcnlTZWxlY3RvcignZycpO1xuICAgICAgZXhwZWN0KGdyaWRHcm91cCkudG9CZUluVGhlRG9jdW1lbnQoKTtcbiAgICB9KTtcbiAgfSk7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
|
|
@@ -0,0 +1,235 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
|
|
3
|
+
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
|
|
4
|
+
var _toConsumableArray2 = _interopRequireDefault(require("@babel/runtime/helpers/toConsumableArray"));
|
|
5
|
+
var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty"));
|
|
6
|
+
var _extends2 = _interopRequireDefault(require("@babel/runtime/helpers/extends"));
|
|
7
|
+
var _react = _interopRequireDefault(require("react"));
|
|
8
|
+
var _react2 = require("@testing-library/react");
|
|
9
|
+
var _styles = require("@mui/material/styles");
|
|
10
|
+
var _keyLegend = _interopRequireDefault(require("../key-legend"));
|
|
11
|
+
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; }
|
|
12
|
+
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; }
|
|
13
|
+
jest.mock('@pie-lib/translator', function () {
|
|
14
|
+
return {
|
|
15
|
+
__esModule: true,
|
|
16
|
+
"default": {
|
|
17
|
+
translator: {
|
|
18
|
+
t: jest.fn(function (key) {
|
|
19
|
+
var translations = {
|
|
20
|
+
'charting.keyLegend.incorrectAnswer': 'Incorrect answer selected',
|
|
21
|
+
'charting.keyLegend.correctAnswer': 'Correct answer selected',
|
|
22
|
+
'charting.keyLegend.correctKeyAnswer': 'Correct answer'
|
|
23
|
+
};
|
|
24
|
+
return translations[key] || key;
|
|
25
|
+
})
|
|
26
|
+
}
|
|
27
|
+
}
|
|
28
|
+
};
|
|
29
|
+
});
|
|
30
|
+
jest.mock('@mui/icons-material/Check', function () {
|
|
31
|
+
return function Check(props) {
|
|
32
|
+
return /*#__PURE__*/_react["default"].createElement("div", (0, _extends2["default"])({
|
|
33
|
+
"data-testid": "check-icon"
|
|
34
|
+
}, props));
|
|
35
|
+
};
|
|
36
|
+
});
|
|
37
|
+
jest.mock('@mui/icons-material/Close', function () {
|
|
38
|
+
return function Close(props) {
|
|
39
|
+
return /*#__PURE__*/_react["default"].createElement("div", (0, _extends2["default"])({
|
|
40
|
+
"data-testid": "close-icon"
|
|
41
|
+
}, props));
|
|
42
|
+
};
|
|
43
|
+
});
|
|
44
|
+
var theme;
|
|
45
|
+
beforeAll(function () {
|
|
46
|
+
theme = (0, _styles.createTheme)();
|
|
47
|
+
});
|
|
48
|
+
describe('KeyLegend', function () {
|
|
49
|
+
var renderComponent = function renderComponent() {
|
|
50
|
+
var extras = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};
|
|
51
|
+
var defaults = {
|
|
52
|
+
language: 'en'
|
|
53
|
+
};
|
|
54
|
+
var props = _objectSpread(_objectSpread({}, defaults), extras);
|
|
55
|
+
return (0, _react2.render)(/*#__PURE__*/_react["default"].createElement(_styles.ThemeProvider, {
|
|
56
|
+
theme: theme
|
|
57
|
+
}, /*#__PURE__*/_react["default"].createElement(_keyLegend["default"], props)));
|
|
58
|
+
};
|
|
59
|
+
describe('rendering', function () {
|
|
60
|
+
it('renders without crashing', function () {
|
|
61
|
+
var _renderComponent = renderComponent(),
|
|
62
|
+
container = _renderComponent.container;
|
|
63
|
+
expect(container).toBeInTheDocument();
|
|
64
|
+
});
|
|
65
|
+
it('renders Key title', function () {
|
|
66
|
+
var _renderComponent2 = renderComponent(),
|
|
67
|
+
getByText = _renderComponent2.getByText;
|
|
68
|
+
expect(getByText('Key')).toBeInTheDocument();
|
|
69
|
+
});
|
|
70
|
+
it('renders incorrect answer row', function () {
|
|
71
|
+
var _renderComponent3 = renderComponent(),
|
|
72
|
+
getByText = _renderComponent3.getByText;
|
|
73
|
+
expect(getByText('Incorrect answer selected')).toBeInTheDocument();
|
|
74
|
+
});
|
|
75
|
+
it('renders correct answer row', function () {
|
|
76
|
+
var _renderComponent4 = renderComponent(),
|
|
77
|
+
getByText = _renderComponent4.getByText;
|
|
78
|
+
expect(getByText('Correct answer selected')).toBeInTheDocument();
|
|
79
|
+
});
|
|
80
|
+
it('renders correct key answer row', function () {
|
|
81
|
+
var _renderComponent5 = renderComponent(),
|
|
82
|
+
getByText = _renderComponent5.getByText;
|
|
83
|
+
expect(getByText('Correct answer')).toBeInTheDocument();
|
|
84
|
+
});
|
|
85
|
+
it('renders with custom language', function () {
|
|
86
|
+
var _renderComponent6 = renderComponent({
|
|
87
|
+
language: 'es'
|
|
88
|
+
}),
|
|
89
|
+
container = _renderComponent6.container;
|
|
90
|
+
expect(container).toBeInTheDocument();
|
|
91
|
+
});
|
|
92
|
+
it('renders with undefined language', function () {
|
|
93
|
+
var _renderComponent7 = renderComponent({
|
|
94
|
+
language: undefined
|
|
95
|
+
}),
|
|
96
|
+
container = _renderComponent7.container;
|
|
97
|
+
expect(container).toBeInTheDocument();
|
|
98
|
+
});
|
|
99
|
+
});
|
|
100
|
+
describe('icons', function () {
|
|
101
|
+
it('renders incorrect icon (Close)', function () {
|
|
102
|
+
var _renderComponent8 = renderComponent(),
|
|
103
|
+
getAllByTestId = _renderComponent8.getAllByTestId;
|
|
104
|
+
var closeIcons = getAllByTestId('close-icon');
|
|
105
|
+
expect(closeIcons.length).toBeGreaterThan(0);
|
|
106
|
+
});
|
|
107
|
+
it('renders correct icons (Check)', function () {
|
|
108
|
+
var _renderComponent9 = renderComponent(),
|
|
109
|
+
getAllByTestId = _renderComponent9.getAllByTestId;
|
|
110
|
+
var checkIcons = getAllByTestId('check-icon');
|
|
111
|
+
expect(checkIcons.length).toBe(2);
|
|
112
|
+
});
|
|
113
|
+
it('renders small check icon for correct key answer', function () {
|
|
114
|
+
var _renderComponent0 = renderComponent(),
|
|
115
|
+
getAllByTestId = _renderComponent0.getAllByTestId;
|
|
116
|
+
var checkIcons = getAllByTestId('check-icon');
|
|
117
|
+
expect(checkIcons.length).toBeGreaterThan(0);
|
|
118
|
+
checkIcons.forEach(function (icon) {
|
|
119
|
+
expect(icon).toBeInTheDocument();
|
|
120
|
+
});
|
|
121
|
+
});
|
|
122
|
+
});
|
|
123
|
+
describe('structure', function () {
|
|
124
|
+
it('has correct number of rows', function () {
|
|
125
|
+
var _renderComponent1 = renderComponent(),
|
|
126
|
+
container = _renderComponent1.container;
|
|
127
|
+
var texts = ['Incorrect answer selected', 'Correct answer selected', 'Correct answer'];
|
|
128
|
+
texts.forEach(function (text) {
|
|
129
|
+
expect(container.textContent).toContain(text);
|
|
130
|
+
});
|
|
131
|
+
});
|
|
132
|
+
it('displays title at the top', function () {
|
|
133
|
+
var _renderComponent10 = renderComponent(),
|
|
134
|
+
container = _renderComponent10.container;
|
|
135
|
+
var firstChild = container.querySelector('div > div');
|
|
136
|
+
expect(firstChild === null || firstChild === void 0 ? void 0 : firstChild.textContent).toContain('Key');
|
|
137
|
+
});
|
|
138
|
+
});
|
|
139
|
+
describe('styling', function () {
|
|
140
|
+
it('applies styled container', function () {
|
|
141
|
+
var _container$firstChild;
|
|
142
|
+
var _renderComponent11 = renderComponent(),
|
|
143
|
+
container = _renderComponent11.container;
|
|
144
|
+
var styledDiv = (_container$firstChild = container.firstChild) === null || _container$firstChild === void 0 ? void 0 : _container$firstChild.firstChild;
|
|
145
|
+
expect(styledDiv).toBeInTheDocument();
|
|
146
|
+
});
|
|
147
|
+
it('renders all content in proper structure', function () {
|
|
148
|
+
var _renderComponent12 = renderComponent(),
|
|
149
|
+
container = _renderComponent12.container;
|
|
150
|
+
expect(container.querySelector('[data-testid="close-icon"]')).toBeInTheDocument();
|
|
151
|
+
expect(container.querySelectorAll('[data-testid="check-icon"]').length).toBe(2);
|
|
152
|
+
});
|
|
153
|
+
});
|
|
154
|
+
describe('accessibility', function () {
|
|
155
|
+
it('has readable text content', function () {
|
|
156
|
+
var _renderComponent13 = renderComponent(),
|
|
157
|
+
container = _renderComponent13.container;
|
|
158
|
+
var text = container.textContent;
|
|
159
|
+
expect(text).toContain('Key');
|
|
160
|
+
expect(text).toContain('Incorrect answer selected');
|
|
161
|
+
expect(text).toContain('Correct answer selected');
|
|
162
|
+
expect(text).toContain('Correct answer');
|
|
163
|
+
});
|
|
164
|
+
it('icons have proper structure for screen readers', function () {
|
|
165
|
+
var _renderComponent14 = renderComponent(),
|
|
166
|
+
getAllByTestId = _renderComponent14.getAllByTestId;
|
|
167
|
+
var icons = [].concat((0, _toConsumableArray2["default"])(getAllByTestId('close-icon')), (0, _toConsumableArray2["default"])(getAllByTestId('check-icon')));
|
|
168
|
+
expect(icons.length).toBeGreaterThan(0);
|
|
169
|
+
});
|
|
170
|
+
});
|
|
171
|
+
describe('edge cases', function () {
|
|
172
|
+
it('handles null language', function () {
|
|
173
|
+
var _renderComponent15 = renderComponent({
|
|
174
|
+
language: null
|
|
175
|
+
}),
|
|
176
|
+
container = _renderComponent15.container;
|
|
177
|
+
expect(container).toBeInTheDocument();
|
|
178
|
+
});
|
|
179
|
+
it('handles empty string language', function () {
|
|
180
|
+
var _renderComponent16 = renderComponent({
|
|
181
|
+
language: ''
|
|
182
|
+
}),
|
|
183
|
+
container = _renderComponent16.container;
|
|
184
|
+
expect(container).toBeInTheDocument();
|
|
185
|
+
});
|
|
186
|
+
it('renders consistently with different language codes', function () {
|
|
187
|
+
var languages = ['en', 'es', 'fr', 'de', 'zh'];
|
|
188
|
+
languages.forEach(function (lang) {
|
|
189
|
+
var _renderComponent17 = renderComponent({
|
|
190
|
+
language: lang
|
|
191
|
+
}),
|
|
192
|
+
container = _renderComponent17.container,
|
|
193
|
+
unmount = _renderComponent17.unmount;
|
|
194
|
+
expect(container).toBeInTheDocument();
|
|
195
|
+
unmount();
|
|
196
|
+
});
|
|
197
|
+
});
|
|
198
|
+
});
|
|
199
|
+
describe('translation integration', function () {
|
|
200
|
+
it('calls translator with language parameter', function () {
|
|
201
|
+
var Translator = require('@pie-lib/translator')["default"];
|
|
202
|
+
var t = Translator.translator.t;
|
|
203
|
+
renderComponent({
|
|
204
|
+
language: 'es'
|
|
205
|
+
});
|
|
206
|
+
expect(t).toHaveBeenCalled();
|
|
207
|
+
});
|
|
208
|
+
it('displays all required translation keys', function () {
|
|
209
|
+
var _renderComponent18 = renderComponent(),
|
|
210
|
+
container = _renderComponent18.container;
|
|
211
|
+
var text = container.textContent;
|
|
212
|
+
expect(text).toContain('Incorrect answer selected');
|
|
213
|
+
expect(text).toContain('Correct answer selected');
|
|
214
|
+
expect(text).toContain('Correct answer');
|
|
215
|
+
});
|
|
216
|
+
});
|
|
217
|
+
describe('layout', function () {
|
|
218
|
+
it('renders in a flex column layout', function () {
|
|
219
|
+
var _container$firstChild2;
|
|
220
|
+
var _renderComponent19 = renderComponent(),
|
|
221
|
+
container = _renderComponent19.container;
|
|
222
|
+
var mainContainer = (_container$firstChild2 = container.firstChild) === null || _container$firstChild2 === void 0 ? void 0 : _container$firstChild2.firstChild;
|
|
223
|
+
expect(mainContainer).toBeInTheDocument();
|
|
224
|
+
});
|
|
225
|
+
it('has proper spacing between elements', function () {
|
|
226
|
+
var _renderComponent20 = renderComponent(),
|
|
227
|
+
getByText = _renderComponent20.getByText;
|
|
228
|
+
expect(getByText('Key')).toBeInTheDocument();
|
|
229
|
+
expect(getByText('Incorrect answer selected')).toBeInTheDocument();
|
|
230
|
+
expect(getByText('Correct answer selected')).toBeInTheDocument();
|
|
231
|
+
expect(getByText('Correct answer')).toBeInTheDocument();
|
|
232
|
+
});
|
|
233
|
+
});
|
|
234
|
+
});
|
|
235
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_react","_interopRequireDefault","require","_react2","_styles","_keyLegend","ownKeys","e","r","t","Object","keys","getOwnPropertySymbols","o","filter","getOwnPropertyDescriptor","enumerable","push","apply","_objectSpread","arguments","length","forEach","_defineProperty2","getOwnPropertyDescriptors","defineProperties","defineProperty","jest","mock","__esModule","translator","fn","key","translations","Check","props","createElement","_extends2","Close","theme","beforeAll","createTheme","describe","renderComponent","extras","undefined","defaults","language","render","ThemeProvider","it","_renderComponent","container","expect","toBeInTheDocument","_renderComponent2","getByText","_renderComponent3","_renderComponent4","_renderComponent5","_renderComponent6","_renderComponent7","_renderComponent8","getAllByTestId","closeIcons","toBeGreaterThan","_renderComponent9","checkIcons","toBe","_renderComponent0","icon","_renderComponent1","texts","text","textContent","toContain","_renderComponent10","firstChild","querySelector","_container$firstChild","_renderComponent11","styledDiv","_renderComponent12","querySelectorAll","_renderComponent13","_renderComponent14","icons","concat","_toConsumableArray2","_renderComponent15","_renderComponent16","languages","lang","_renderComponent17","unmount","Translator","toHaveBeenCalled","_renderComponent18","_container$firstChild2","_renderComponent19","mainContainer","_renderComponent20"],"sources":["../../src/__tests__/key-legend.test.jsx"],"sourcesContent":["import React from 'react';\nimport { render } from '@testing-library/react';\nimport { createTheme, ThemeProvider } from '@mui/material/styles';\nimport KeyLegend from '../key-legend';\n\njest.mock('@pie-lib/translator', () => ({\n  __esModule: true,\n  default: {\n    translator: {\n      t: jest.fn((key) => {\n        const translations = {\n          'charting.keyLegend.incorrectAnswer': 'Incorrect answer selected',\n          'charting.keyLegend.correctAnswer': 'Correct answer selected',\n          'charting.keyLegend.correctKeyAnswer': 'Correct answer',\n        };\n        return translations[key] || key;\n      }),\n    },\n  },\n}));\n\njest.mock('@mui/icons-material/Check', () => {\n  return function Check(props) {\n    return <div data-testid=\"check-icon\" {...props} />;\n  };\n});\n\njest.mock('@mui/icons-material/Close', () => {\n  return function Close(props) {\n    return <div data-testid=\"close-icon\" {...props} />;\n  };\n});\n\nlet theme;\n\nbeforeAll(() => {\n  theme = createTheme();\n});\n\ndescribe('KeyLegend', () => {\n  const renderComponent = (extras = {}) => {\n    const defaults = {\n      language: 'en',\n    };\n    const props = { ...defaults, ...extras };\n    return render(\n      <ThemeProvider theme={theme}>\n        <KeyLegend {...props} />\n      </ThemeProvider>,\n    );\n  };\n\n  describe('rendering', () => {\n    it('renders without crashing', () => {\n      const { container } = renderComponent();\n      expect(container).toBeInTheDocument();\n    });\n\n    it('renders Key title', () => {\n      const { getByText } = renderComponent();\n      expect(getByText('Key')).toBeInTheDocument();\n    });\n\n    it('renders incorrect answer row', () => {\n      const { getByText } = renderComponent();\n      expect(getByText('Incorrect answer selected')).toBeInTheDocument();\n    });\n\n    it('renders correct answer row', () => {\n      const { getByText } = renderComponent();\n      expect(getByText('Correct answer selected')).toBeInTheDocument();\n    });\n\n    it('renders correct key answer row', () => {\n      const { getByText } = renderComponent();\n      expect(getByText('Correct answer')).toBeInTheDocument();\n    });\n\n    it('renders with custom language', () => {\n      const { container } = renderComponent({ language: 'es' });\n      expect(container).toBeInTheDocument();\n    });\n\n    it('renders with undefined language', () => {\n      const { container } = renderComponent({ language: undefined });\n      expect(container).toBeInTheDocument();\n    });\n  });\n\n  describe('icons', () => {\n    it('renders incorrect icon (Close)', () => {\n      const { getAllByTestId } = renderComponent();\n      const closeIcons = getAllByTestId('close-icon');\n      expect(closeIcons.length).toBeGreaterThan(0);\n    });\n\n    it('renders correct icons (Check)', () => {\n      const { getAllByTestId } = renderComponent();\n      const checkIcons = getAllByTestId('check-icon');\n      expect(checkIcons.length).toBe(2);\n    });\n\n    it('renders small check icon for correct key answer', () => {\n      const { getAllByTestId } = renderComponent();\n      const checkIcons = getAllByTestId('check-icon');\n\n      expect(checkIcons.length).toBeGreaterThan(0);\n\n      checkIcons.forEach((icon) => {\n        expect(icon).toBeInTheDocument();\n      });\n    });\n  });\n\n  describe('structure', () => {\n    it('has correct number of rows', () => {\n      const { container } = renderComponent();\n      const texts = ['Incorrect answer selected', 'Correct answer selected', 'Correct answer'];\n\n      texts.forEach((text) => {\n        expect(container.textContent).toContain(text);\n      });\n    });\n\n    it('displays title at the top', () => {\n      const { container } = renderComponent();\n      const firstChild = container.querySelector('div > div');\n      expect(firstChild?.textContent).toContain('Key');\n    });\n  });\n\n  describe('styling', () => {\n    it('applies styled container', () => {\n      const { container } = renderComponent();\n      const styledDiv = container.firstChild?.firstChild;\n      expect(styledDiv).toBeInTheDocument();\n    });\n\n    it('renders all content in proper structure', () => {\n      const { container } = renderComponent();\n      expect(container.querySelector('[data-testid=\"close-icon\"]')).toBeInTheDocument();\n      expect(container.querySelectorAll('[data-testid=\"check-icon\"]').length).toBe(2);\n    });\n  });\n\n  describe('accessibility', () => {\n    it('has readable text content', () => {\n      const { container } = renderComponent();\n      const text = container.textContent;\n\n      expect(text).toContain('Key');\n      expect(text).toContain('Incorrect answer selected');\n      expect(text).toContain('Correct answer selected');\n      expect(text).toContain('Correct answer');\n    });\n\n    it('icons have proper structure for screen readers', () => {\n      const { getAllByTestId } = renderComponent();\n      const icons = [...getAllByTestId('close-icon'), ...getAllByTestId('check-icon')];\n\n      expect(icons.length).toBeGreaterThan(0);\n    });\n  });\n\n  describe('edge cases', () => {\n    it('handles null language', () => {\n      const { container } = renderComponent({ language: null });\n      expect(container).toBeInTheDocument();\n    });\n\n    it('handles empty string language', () => {\n      const { container } = renderComponent({ language: '' });\n      expect(container).toBeInTheDocument();\n    });\n\n    it('renders consistently with different language codes', () => {\n      const languages = ['en', 'es', 'fr', 'de', 'zh'];\n\n      languages.forEach((lang) => {\n        const { container, unmount } = renderComponent({ language: lang });\n        expect(container).toBeInTheDocument();\n        unmount();\n      });\n    });\n  });\n\n  describe('translation integration', () => {\n    it('calls translator with language parameter', () => {\n      const Translator = require('@pie-lib/translator').default;\n      const { t } = Translator.translator;\n\n      renderComponent({ language: 'es' });\n\n      expect(t).toHaveBeenCalled();\n    });\n\n    it('displays all required translation keys', () => {\n      const { container } = renderComponent();\n      const text = container.textContent;\n\n      expect(text).toContain('Incorrect answer selected');\n      expect(text).toContain('Correct answer selected');\n      expect(text).toContain('Correct answer');\n    });\n  });\n\n  describe('layout', () => {\n    it('renders in a flex column layout', () => {\n      const { container } = renderComponent();\n      const mainContainer = container.firstChild?.firstChild;\n      expect(mainContainer).toBeInTheDocument();\n    });\n\n    it('has proper spacing between elements', () => {\n      const { getByText } = renderComponent();\n\n      expect(getByText('Key')).toBeInTheDocument();\n      expect(getByText('Incorrect answer selected')).toBeInTheDocument();\n      expect(getByText('Correct answer selected')).toBeInTheDocument();\n      expect(getByText('Correct answer')).toBeInTheDocument();\n    });\n  });\n});\n"],"mappings":"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","ignoreList":[]}
|
|
@@ -0,0 +1,46 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
|
|
3
|
+
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
|
|
4
|
+
var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty"));
|
|
5
|
+
var _react = _interopRequireDefault(require("react"));
|
|
6
|
+
var _testUtils = require("@pie-lib/test-utils");
|
|
7
|
+
var _markLabel = require("../mark-label");
|
|
8
|
+
var _utils = require("./utils");
|
|
9
|
+
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; }
|
|
10
|
+
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; }
|
|
11
|
+
describe('MarkLabel', function () {
|
|
12
|
+
var onChange = jest.fn();
|
|
13
|
+
var renderComponent = function renderComponent(extras) {
|
|
14
|
+
var defaults = {
|
|
15
|
+
classes: {},
|
|
16
|
+
defineChart: false,
|
|
17
|
+
className: 'className',
|
|
18
|
+
onChange: onChange,
|
|
19
|
+
mark: {
|
|
20
|
+
x: 1,
|
|
21
|
+
y: 1
|
|
22
|
+
},
|
|
23
|
+
graphProps: (0, _utils.graphProps)(0, 10, 0, 10)
|
|
24
|
+
};
|
|
25
|
+
var props = _objectSpread(_objectSpread({}, defaults), extras);
|
|
26
|
+
return (0, _testUtils.render)(/*#__PURE__*/_react["default"].createElement(_markLabel.MarkLabel, props));
|
|
27
|
+
};
|
|
28
|
+
describe('rendering', function () {
|
|
29
|
+
it('renders mark label', function () {
|
|
30
|
+
var _renderComponent = renderComponent(),
|
|
31
|
+
container = _renderComponent.container;
|
|
32
|
+
expect(container.firstChild).toBeInTheDocument();
|
|
33
|
+
});
|
|
34
|
+
it('renders mark label at different positions', function () {
|
|
35
|
+
var _renderComponent2 = renderComponent({
|
|
36
|
+
mark: {
|
|
37
|
+
x: 10,
|
|
38
|
+
y: 10
|
|
39
|
+
}
|
|
40
|
+
}),
|
|
41
|
+
container = _renderComponent2.container;
|
|
42
|
+
expect(container.firstChild).toBeInTheDocument();
|
|
43
|
+
});
|
|
44
|
+
});
|
|
45
|
+
});
|
|
46
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJfcmVhY3QiLCJfaW50ZXJvcFJlcXVpcmVEZWZhdWx0IiwicmVxdWlyZSIsIl90ZXN0VXRpbHMiLCJfbWFya0xhYmVsIiwiX3V0aWxzIiwib3duS2V5cyIsImUiLCJyIiwidCIsIk9iamVjdCIsImtleXMiLCJnZXRPd25Qcm9wZXJ0eVN5bWJvbHMiLCJvIiwiZmlsdGVyIiwiZ2V0T3duUHJvcGVydHlEZXNjcmlwdG9yIiwiZW51bWVyYWJsZSIsInB1c2giLCJhcHBseSIsIl9vYmplY3RTcHJlYWQiLCJhcmd1bWVudHMiLCJsZW5ndGgiLCJmb3JFYWNoIiwiX2RlZmluZVByb3BlcnR5MiIsImdldE93blByb3BlcnR5RGVzY3JpcHRvcnMiLCJkZWZpbmVQcm9wZXJ0aWVzIiwiZGVmaW5lUHJvcGVydHkiLCJkZXNjcmliZSIsIm9uQ2hhbmdlIiwiamVzdCIsImZuIiwicmVuZGVyQ29tcG9uZW50IiwiZXh0cmFzIiwiZGVmYXVsdHMiLCJjbGFzc2VzIiwiZGVmaW5lQ2hhcnQiLCJjbGFzc05hbWUiLCJtYXJrIiwieCIsInkiLCJncmFwaFByb3BzIiwiZ2V0R3JhcGhQcm9wcyIsInByb3BzIiwicmVuZGVyIiwiY3JlYXRlRWxlbWVudCIsIk1hcmtMYWJlbCIsIml0IiwiX3JlbmRlckNvbXBvbmVudCIsImNvbnRhaW5lciIsImV4cGVjdCIsImZpcnN0Q2hpbGQiLCJ0b0JlSW5UaGVEb2N1bWVudCIsIl9yZW5kZXJDb21wb25lbnQyIl0sInNvdXJjZXMiOlsiLi4vLi4vc3JjL19fdGVzdHNfXy9tYXJrLWxhYmVsLnRlc3QuanN4Il0sInNvdXJjZXNDb250ZW50IjpbImltcG9ydCBSZWFjdCBmcm9tICdyZWFjdCc7XG5pbXBvcnQgeyByZW5kZXIgfSBmcm9tICdAcGllLWxpYi90ZXN0LXV0aWxzJztcbmltcG9ydCB7IE1hcmtMYWJlbCB9IGZyb20gJy4uL21hcmstbGFiZWwnO1xuaW1wb3J0IHsgZ3JhcGhQcm9wcyBhcyBnZXRHcmFwaFByb3BzIH0gZnJvbSAnLi91dGlscyc7XG5cbmRlc2NyaWJlKCdNYXJrTGFiZWwnLCAoKSA9PiB7XG4gIGxldCBvbkNoYW5nZSA9IGplc3QuZm4oKTtcblxuICBjb25zdCByZW5kZXJDb21wb25lbnQgPSAoZXh0cmFzKSA9PiB7XG4gICAgY29uc3QgZGVmYXVsdHMgPSB7XG4gICAgICBjbGFzc2VzOiB7fSxcbiAgICAgIGRlZmluZUNoYXJ0OiBmYWxzZSxcbiAgICAgIGNsYXNzTmFtZTogJ2NsYXNzTmFtZScsXG4gICAgICBvbkNoYW5nZSxcbiAgICAgIG1hcms6IHsgeDogMSwgeTogMSB9LFxuICAgICAgZ3JhcGhQcm9wczogZ2V0R3JhcGhQcm9wcygwLCAxMCwgMCwgMTApLFxuICAgIH07XG4gICAgY29uc3QgcHJvcHMgPSB7IC4uLmRlZmF1bHRzLCAuLi5leHRyYXMgfTtcbiAgICByZXR1cm4gcmVuZGVyKDxNYXJrTGFiZWwgey4uLnByb3BzfSAvPik7XG4gIH07XG5cbiAgZGVzY3JpYmUoJ3JlbmRlcmluZycsICgpID0+IHtcbiAgICBpdCgncmVuZGVycyBtYXJrIGxhYmVsJywgKCkgPT4ge1xuICAgICAgY29uc3QgeyBjb250YWluZXIgfSA9IHJlbmRlckNvbXBvbmVudCgpO1xuICAgICAgZXhwZWN0KGNvbnRhaW5lci5maXJzdENoaWxkKS50b0JlSW5UaGVEb2N1bWVudCgpO1xuICAgIH0pO1xuXG4gICAgaXQoJ3JlbmRlcnMgbWFyayBsYWJlbCBhdCBkaWZmZXJlbnQgcG9zaXRpb25zJywgKCkgPT4ge1xuICAgICAgY29uc3QgeyBjb250YWluZXIgfSA9IHJlbmRlckNvbXBvbmVudCh7IG1hcms6IHsgeDogMTAsIHk6IDEwIH0gfSk7XG4gICAgICBleHBlY3QoY29udGFpbmVyLmZpcnN0Q2hpbGQpLnRvQmVJblRoZURvY3VtZW50KCk7XG4gICAgfSk7XG4gIH0pO1xufSk7XG4iXSwibWFwcGluZ3MiOiI7Ozs7QUFBQSxJQUFBQSxNQUFBLEdBQUFDLHNCQUFBLENBQUFDLE9BQUE7QUFDQSxJQUFBQyxVQUFBLEdBQUFELE9BQUE7QUFDQSxJQUFBRSxVQUFBLEdBQUFGLE9BQUE7QUFDQSxJQUFBRyxNQUFBLEdBQUFILE9BQUE7QUFBc0QsU0FBQUksUUFBQUMsQ0FBQSxFQUFBQyxDQUFBLFFBQUFDLENBQUEsR0FBQUMsTUFBQSxDQUFBQyxJQUFBLENBQUFKLENBQUEsT0FBQUcsTUFBQSxDQUFBRSxxQkFBQSxRQUFBQyxDQUFBLEdBQUFILE1BQUEsQ0FBQUUscUJBQUEsQ0FBQUwsQ0FBQSxHQUFBQyxDQUFBLEtBQUFLLENBQUEsR0FBQUEsQ0FBQSxDQUFBQyxNQUFBLFdBQUFOLENBQUEsV0FBQUUsTUFBQSxDQUFBSyx3QkFBQSxDQUFBUixDQUFBLEVBQUFDLENBQUEsRUFBQVEsVUFBQSxPQUFBUCxDQUFBLENBQUFRLElBQUEsQ0FBQUMsS0FBQSxDQUFBVCxDQUFBLEVBQUFJLENBQUEsWUFBQUosQ0FBQTtBQUFBLFNBQUFVLGNBQUFaLENBQUEsYUFBQUMsQ0FBQSxNQUFBQSxDQUFBLEdBQUFZLFNBQUEsQ0FBQUMsTUFBQSxFQUFBYixDQUFBLFVBQUFDLENBQUEsV0FBQVcsU0FBQSxDQUFBWixDQUFBLElBQUFZLFNBQUEsQ0FBQVosQ0FBQSxRQUFBQSxDQUFBLE9BQUFGLE9BQUEsQ0FBQUksTUFBQSxDQUFBRCxDQUFBLE9BQUFhLE9BQUEsV0FBQWQsQ0FBQSxRQUFBZSxnQkFBQSxhQUFBaEIsQ0FBQSxFQUFBQyxDQUFBLEVBQUFDLENBQUEsQ0FBQUQsQ0FBQSxTQUFBRSxNQUFBLENBQUFjLHlCQUFBLEdBQUFkLE1BQUEsQ0FBQWUsZ0JBQUEsQ0FBQWxCLENBQUEsRUFBQUcsTUFBQSxDQUFBYyx5QkFBQSxDQUFBZixDQUFBLEtBQUFILE9BQUEsQ0FBQUksTUFBQSxDQUFBRCxDQUFBLEdBQUFhLE9BQUEsV0FBQWQsQ0FBQSxJQUFBRSxNQUFBLENBQUFnQixjQUFBLENBQUFuQixDQUFBLEVBQUFDLENBQUEsRUFBQUUsTUFBQSxDQUFBSyx3QkFBQSxDQUFBTixDQUFBLEVBQUFELENBQUEsaUJBQUFELENBQUE7QUFFdERvQixRQUFRLENBQUMsV0FBVyxFQUFFLFlBQU07RUFDMUIsSUFBSUMsUUFBUSxHQUFHQyxJQUFJLENBQUNDLEVBQUUsQ0FBQyxDQUFDO0VBRXhCLElBQU1DLGVBQWUsR0FBRyxTQUFsQkEsZUFBZUEsQ0FBSUMsTUFBTSxFQUFLO0lBQ2xDLElBQU1DLFFBQVEsR0FBRztNQUNmQyxPQUFPLEVBQUUsQ0FBQyxDQUFDO01BQ1hDLFdBQVcsRUFBRSxLQUFLO01BQ2xCQyxTQUFTLEVBQUUsV0FBVztNQUN0QlIsUUFBUSxFQUFSQSxRQUFRO01BQ1JTLElBQUksRUFBRTtRQUFFQyxDQUFDLEVBQUUsQ0FBQztRQUFFQyxDQUFDLEVBQUU7TUFBRSxDQUFDO01BQ3BCQyxVQUFVLEVBQUUsSUFBQUMsaUJBQWEsRUFBQyxDQUFDLEVBQUUsRUFBRSxFQUFFLENBQUMsRUFBRSxFQUFFO0lBQ3hDLENBQUM7SUFDRCxJQUFNQyxLQUFLLEdBQUF2QixhQUFBLENBQUFBLGFBQUEsS0FBUWMsUUFBUSxHQUFLRCxNQUFNLENBQUU7SUFDeEMsT0FBTyxJQUFBVyxpQkFBTSxlQUFDM0MsTUFBQSxZQUFBNEMsYUFBQSxDQUFDeEMsVUFBQSxDQUFBeUMsU0FBUyxFQUFLSCxLQUFRLENBQUMsQ0FBQztFQUN6QyxDQUFDO0VBRURmLFFBQVEsQ0FBQyxXQUFXLEVBQUUsWUFBTTtJQUMxQm1CLEVBQUUsQ0FBQyxvQkFBb0IsRUFBRSxZQUFNO01BQzdCLElBQUFDLGdCQUFBLEdBQXNCaEIsZUFBZSxDQUFDLENBQUM7UUFBL0JpQixTQUFTLEdBQUFELGdCQUFBLENBQVRDLFNBQVM7TUFDakJDLE1BQU0sQ0FBQ0QsU0FBUyxDQUFDRSxVQUFVLENBQUMsQ0FBQ0MsaUJBQWlCLENBQUMsQ0FBQztJQUNsRCxDQUFDLENBQUM7SUFFRkwsRUFBRSxDQUFDLDJDQUEyQyxFQUFFLFlBQU07TUFDcEQsSUFBQU0saUJBQUEsR0FBc0JyQixlQUFlLENBQUM7VUFBRU0sSUFBSSxFQUFFO1lBQUVDLENBQUMsRUFBRSxFQUFFO1lBQUVDLENBQUMsRUFBRTtVQUFHO1FBQUUsQ0FBQyxDQUFDO1FBQXpEUyxTQUFTLEdBQUFJLGlCQUFBLENBQVRKLFNBQVM7TUFDakJDLE1BQU0sQ0FBQ0QsU0FBUyxDQUFDRSxVQUFVLENBQUMsQ0FBQ0MsaUJBQWlCLENBQUMsQ0FBQztJQUNsRCxDQUFDLENBQUM7RUFDSixDQUFDLENBQUM7QUFDSixDQUFDLENBQUMiLCJpZ25vcmVMaXN0IjpbXX0=
|