@pie-lib/config-ui 11.30.0-mui-update.0 → 11.30.1-beta-1

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 (105) hide show
  1. package/CHANGELOG.md +12 -9
  2. package/lib/__tests__/choice-utils.test.js +16 -0
  3. package/lib/__tests__/langs.test.js +55 -0
  4. package/lib/__tests__/number-text-field.test.js +128 -0
  5. package/lib/__tests__/settings-panel.test.js +201 -0
  6. package/lib/__tests__/two-choice.test.js +33 -0
  7. package/lib/alert-dialog.js +42 -23
  8. package/lib/alert-dialog.js.map +1 -1
  9. package/lib/checkbox.js +71 -56
  10. package/lib/checkbox.js.map +1 -1
  11. package/lib/choice-configuration/__tests__/feedback-menu.test.js +20 -0
  12. package/lib/choice-configuration/__tests__/index.test.js +119 -0
  13. package/lib/choice-configuration/feedback-menu.js +63 -24
  14. package/lib/choice-configuration/feedback-menu.js.map +1 -1
  15. package/lib/choice-configuration/index.js +257 -201
  16. package/lib/choice-configuration/index.js.map +1 -1
  17. package/lib/choice-utils.js +18 -6
  18. package/lib/choice-utils.js.map +1 -1
  19. package/lib/feedback-config/__tests__/feedback-config.test.js +78 -0
  20. package/lib/feedback-config/__tests__/feedback-selector.test.js +71 -0
  21. package/lib/feedback-config/feedback-selector.js +114 -77
  22. package/lib/feedback-config/feedback-selector.js.map +1 -1
  23. package/lib/feedback-config/group.js +40 -26
  24. package/lib/feedback-config/group.js.map +1 -1
  25. package/lib/feedback-config/index.js +90 -38
  26. package/lib/feedback-config/index.js.map +1 -1
  27. package/lib/form-section.js +33 -24
  28. package/lib/form-section.js.map +1 -1
  29. package/lib/help.js +80 -39
  30. package/lib/help.js.map +1 -1
  31. package/lib/index.js +31 -1
  32. package/lib/index.js.map +1 -1
  33. package/lib/input.js +54 -21
  34. package/lib/input.js.map +1 -1
  35. package/lib/inputs.js +95 -61
  36. package/lib/inputs.js.map +1 -1
  37. package/lib/langs.js +100 -56
  38. package/lib/langs.js.map +1 -1
  39. package/lib/layout/__tests__/config.layout.test.js +33 -0
  40. package/lib/layout/__tests__/layout-content.test.js +6 -0
  41. package/lib/layout/config-layout.js +99 -48
  42. package/lib/layout/config-layout.js.map +1 -1
  43. package/lib/layout/index.js +3 -0
  44. package/lib/layout/index.js.map +1 -1
  45. package/lib/layout/layout-contents.js +101 -72
  46. package/lib/layout/layout-contents.js.map +1 -1
  47. package/lib/layout/settings-box.js +56 -27
  48. package/lib/layout/settings-box.js.map +1 -1
  49. package/lib/mui-box/index.js +57 -41
  50. package/lib/mui-box/index.js.map +1 -1
  51. package/lib/number-text-field-custom.js +161 -79
  52. package/lib/number-text-field-custom.js.map +1 -1
  53. package/lib/number-text-field.js +115 -57
  54. package/lib/number-text-field.js.map +1 -1
  55. package/lib/radio-with-label.js +31 -23
  56. package/lib/radio-with-label.js.map +1 -1
  57. package/lib/settings/display-size.js +32 -16
  58. package/lib/settings/display-size.js.map +1 -1
  59. package/lib/settings/index.js +47 -14
  60. package/lib/settings/index.js.map +1 -1
  61. package/lib/settings/panel.js +228 -142
  62. package/lib/settings/panel.js.map +1 -1
  63. package/lib/settings/settings-radio-label.js +30 -21
  64. package/lib/settings/settings-radio-label.js.map +1 -1
  65. package/lib/settings/toggle.js +46 -34
  66. package/lib/settings/toggle.js.map +1 -1
  67. package/lib/tabs/index.js +57 -22
  68. package/lib/tabs/index.js.map +1 -1
  69. package/lib/tags-input/__tests__/index.test.js +88 -0
  70. package/lib/tags-input/index.js +99 -50
  71. package/lib/tags-input/index.js.map +1 -1
  72. package/lib/two-choice.js +90 -46
  73. package/lib/two-choice.js.map +1 -1
  74. package/lib/with-stateful-model.js +31 -8
  75. package/lib/with-stateful-model.js.map +1 -1
  76. package/package.json +10 -12
  77. package/src/__tests__/number-text-field.test.jsx +1 -1
  78. package/src/alert-dialog.jsx +18 -14
  79. package/src/checkbox.jsx +46 -42
  80. package/src/choice-configuration/feedback-menu.jsx +5 -5
  81. package/src/choice-configuration/index.jsx +193 -205
  82. package/src/feedback-config/feedback-selector.jsx +53 -51
  83. package/src/feedback-config/group.jsx +22 -21
  84. package/src/feedback-config/index.jsx +29 -27
  85. package/src/form-section.jsx +18 -18
  86. package/src/help.jsx +28 -20
  87. package/src/input.jsx +1 -1
  88. package/src/inputs.jsx +50 -34
  89. package/src/langs.jsx +46 -40
  90. package/src/layout/config-layout.jsx +36 -25
  91. package/src/layout/layout-contents.jsx +34 -34
  92. package/src/layout/settings-box.jsx +19 -16
  93. package/src/mui-box/index.jsx +43 -35
  94. package/src/number-text-field-custom.jsx +36 -30
  95. package/src/number-text-field.jsx +30 -22
  96. package/src/radio-with-label.jsx +13 -17
  97. package/src/settings/display-size.jsx +11 -12
  98. package/src/settings/panel.jsx +89 -83
  99. package/src/settings/settings-radio-label.jsx +13 -17
  100. package/src/settings/toggle.jsx +29 -29
  101. package/src/tabs/index.jsx +8 -8
  102. package/src/tags-input/index.jsx +38 -35
  103. package/src/two-choice.jsx +19 -15
  104. package/LICENSE.md +0 -5
  105. package/NEXT.CHANGELOG.json +0 -1
package/CHANGELOG.md CHANGED
@@ -3,19 +3,18 @@
3
3
  All notable changes to this project will be documented in this file.
4
4
  See [Conventional Commits](https://conventionalcommits.org) for commit guidelines.
5
5
 
6
- # [11.30.0-mui-update.0](https://github.com/pie-framework/pie-lib/compare/@pie-lib/config-ui@11.29.0-mui-update.0...@pie-lib/config-ui@11.30.0-mui-update.0) (2025-11-05)
6
+ ## [11.30.1](https://github.com/pie-framework/pie-lib/compare/@pie-lib/config-ui@11.25.2...@pie-lib/config-ui@11.30.1) (2025-10-22)
7
7
 
8
8
 
9
9
  ### Bug Fixes
10
10
 
11
- * label positioning in input render-ui ([8012817](https://github.com/pie-framework/pie-lib/commit/80128173dc596181de296633e9413bba8b79db81))
12
- * remove parantheses ([07c8d13](https://github.com/pie-framework/pie-lib/commit/07c8d1366d768b1e22e31fb930a7d41a2a31d5ca))
11
+ * avoid redundant re-renders by guarding layoutMode setState ([3f4aecd](https://github.com/pie-framework/pie-lib/commit/3f4aecd1c862b94a9faf3e058086da30995ae60d))
13
12
 
14
13
 
15
14
 
16
15
 
17
16
 
18
- # [11.29.0-mui-update.0](https://github.com/pie-framework/pie-lib/compare/@pie-lib/config-ui@11.28.0-mui-update.0...@pie-lib/config-ui@11.29.0-mui-update.0) (2025-11-03)
17
+ # [11.29.0](https://github.com/pie-framework/pie-lib/compare/@pie-lib/config-ui@11.28.0...@pie-lib/config-ui@11.29.0) (2025-10-16)
19
18
 
20
19
  **Note:** Version bump only for package @pie-lib/config-ui
21
20
 
@@ -23,7 +22,7 @@ See [Conventional Commits](https://conventionalcommits.org) for commit guideline
23
22
 
24
23
 
25
24
 
26
- # [11.28.0-mui-update.0](https://github.com/pie-framework/pie-lib/compare/@pie-lib/config-ui@11.26.0-mui-update.0...@pie-lib/config-ui@11.28.0-mui-update.0) (2025-11-03)
25
+ # [11.28.0](https://github.com/pie-framework/pie-lib/compare/@pie-lib/config-ui@11.25.0...@pie-lib/config-ui@11.28.0) (2025-10-16)
27
26
 
28
27
  **Note:** Version bump only for package @pie-lib/config-ui
29
28
 
@@ -31,13 +30,17 @@ See [Conventional Commits](https://conventionalcommits.org) for commit guideline
31
30
 
32
31
 
33
32
 
34
- # [11.26.0-mui-update.0](https://github.com/pie-framework/pie-lib/compare/@pie-lib/config-ui@11.25.2...@pie-lib/config-ui@11.26.0-mui-update.0) (2025-10-31)
33
+ # [11.27.0](https://github.com/pie-framework/pie-lib/compare/@pie-lib/config-ui@11.25.0...@pie-lib/config-ui@11.27.0) (2025-10-16)
34
+
35
+ **Note:** Version bump only for package @pie-lib/config-ui
36
+
35
37
 
36
38
 
37
- ### Features
38
39
 
39
- * **config-ui:** migrate to material v5 PD-5258 ([3ea0799](https://github.com/pie-framework/pie-lib/commit/3ea0799ce78ca20c938c7765b7af5a47194c39d1))
40
- * bump react and react-dom ([01dc19e](https://github.com/pie-framework/pie-lib/commit/01dc19e88bbc8d372c561d1511df1a82937d45af))
40
+
41
+ # [11.26.0](https://github.com/pie-framework/pie-lib/compare/@pie-lib/config-ui@11.25.0...@pie-lib/config-ui@11.26.0) (2025-10-16)
42
+
43
+ **Note:** Version bump only for package @pie-lib/config-ui
41
44
 
42
45
 
43
46
 
@@ -0,0 +1,16 @@
1
+ "use strict";
2
+
3
+ var _choiceUtils = require("../choice-utils");
4
+
5
+ describe('firstAvailableIndex', function () {
6
+ var assert = function assert(values, index, expected) {
7
+ it("[".concat(values.join(','), "], ").concat(index, " ==> ").concat(expected), function () {
8
+ expect((0, _choiceUtils.firstAvailableIndex)(['0'], 0)).toEqual('1');
9
+ });
10
+ };
11
+
12
+ assert(['0'], 0, '1');
13
+ assert(['0', '1', '2'], 0, '3');
14
+ assert(['0', '1', '2'], 100, '100');
15
+ });
16
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9fX3Rlc3RzX18vY2hvaWNlLXV0aWxzLnRlc3QuanMiXSwibmFtZXMiOlsiZGVzY3JpYmUiLCJhc3NlcnQiLCJ2YWx1ZXMiLCJpbmRleCIsImV4cGVjdGVkIiwiaXQiLCJqb2luIiwiZXhwZWN0IiwidG9FcXVhbCJdLCJtYXBwaW5ncyI6Ijs7QUFBQTs7QUFFQUEsUUFBUSxDQUFDLHFCQUFELEVBQXdCLFlBQU07QUFDcEMsTUFBTUMsTUFBTSxHQUFHLFNBQVRBLE1BQVMsQ0FBQ0MsTUFBRCxFQUFTQyxLQUFULEVBQWdCQyxRQUFoQixFQUE2QjtBQUMxQ0MsSUFBQUEsRUFBRSxZQUFLSCxNQUFNLENBQUNJLElBQVAsQ0FBWSxHQUFaLENBQUwsZ0JBQTJCSCxLQUEzQixrQkFBd0NDLFFBQXhDLEdBQW9ELFlBQU07QUFDMURHLE1BQUFBLE1BQU0sQ0FBQyxzQ0FBb0IsQ0FBQyxHQUFELENBQXBCLEVBQTJCLENBQTNCLENBQUQsQ0FBTixDQUFzQ0MsT0FBdEMsQ0FBOEMsR0FBOUM7QUFDRCxLQUZDLENBQUY7QUFHRCxHQUpEOztBQUtBUCxFQUFBQSxNQUFNLENBQUMsQ0FBQyxHQUFELENBQUQsRUFBUSxDQUFSLEVBQVcsR0FBWCxDQUFOO0FBQ0FBLEVBQUFBLE1BQU0sQ0FBQyxDQUFDLEdBQUQsRUFBTSxHQUFOLEVBQVcsR0FBWCxDQUFELEVBQWtCLENBQWxCLEVBQXFCLEdBQXJCLENBQU47QUFDQUEsRUFBQUEsTUFBTSxDQUFDLENBQUMsR0FBRCxFQUFNLEdBQU4sRUFBVyxHQUFYLENBQUQsRUFBa0IsR0FBbEIsRUFBdUIsS0FBdkIsQ0FBTjtBQUNELENBVE8sQ0FBUiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IGZpcnN0QXZhaWxhYmxlSW5kZXggfSBmcm9tICcuLi9jaG9pY2UtdXRpbHMnO1xuXG5kZXNjcmliZSgnZmlyc3RBdmFpbGFibGVJbmRleCcsICgpID0+IHtcbiAgY29uc3QgYXNzZXJ0ID0gKHZhbHVlcywgaW5kZXgsIGV4cGVjdGVkKSA9PiB7XG4gICAgaXQoYFske3ZhbHVlcy5qb2luKCcsJyl9XSwgJHtpbmRleH0gPT0+ICR7ZXhwZWN0ZWR9YCwgKCkgPT4ge1xuICAgICAgZXhwZWN0KGZpcnN0QXZhaWxhYmxlSW5kZXgoWycwJ10sIDApKS50b0VxdWFsKCcxJyk7XG4gICAgfSk7XG4gIH07XG4gIGFzc2VydChbJzAnXSwgMCwgJzEnKTtcbiAgYXNzZXJ0KFsnMCcsICcxJywgJzInXSwgMCwgJzMnKTtcbiAgYXNzZXJ0KFsnMCcsICcxJywgJzInXSwgMTAwLCAnMTAwJyk7XG59KTtcbiJdfQ==
@@ -0,0 +1,55 @@
1
+ "use strict";
2
+
3
+ var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
4
+
5
+ var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty"));
6
+
7
+ var _enzyme = require("enzyme");
8
+
9
+ var _react = _interopRequireDefault(require("react"));
10
+
11
+ var _langs = require("../langs");
12
+
13
+ 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; }
14
+
15
+ 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; }
16
+
17
+ describe('langs', function () {
18
+ var onChange;
19
+
20
+ var wrapper = function wrapper(extras) {
21
+ var defaults = {
22
+ uid: '1',
23
+ onChange: onChange,
24
+ classes: {},
25
+ langs: ['en-US', 'es-ES']
26
+ };
27
+
28
+ var props = _objectSpread(_objectSpread({}, defaults), extras);
29
+
30
+ return (0, _enzyme.shallow)( /*#__PURE__*/_react["default"].createElement(_langs.RawLangs, props));
31
+ };
32
+
33
+ beforeEach(function () {
34
+ onChange = jest.fn();
35
+ });
36
+ describe('snapshot', function () {
37
+ it('renders', function () {
38
+ expect(wrapper()).toMatchSnapshot();
39
+ });
40
+ });
41
+ describe('logic', function () {
42
+ describe('choose', function () {
43
+ it('calls onChange', function () {
44
+ var w = wrapper();
45
+ w.instance().choose({
46
+ target: {
47
+ value: 'en-US'
48
+ }
49
+ });
50
+ expect(onChange).toBeCalledWith('en-US');
51
+ });
52
+ });
53
+ });
54
+ });
55
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9fX3Rlc3RzX18vbGFuZ3MudGVzdC5qc3giXSwibmFtZXMiOlsiZGVzY3JpYmUiLCJvbkNoYW5nZSIsIndyYXBwZXIiLCJleHRyYXMiLCJkZWZhdWx0cyIsInVpZCIsImNsYXNzZXMiLCJsYW5ncyIsInByb3BzIiwiYmVmb3JlRWFjaCIsImplc3QiLCJmbiIsIml0IiwiZXhwZWN0IiwidG9NYXRjaFNuYXBzaG90IiwidyIsImluc3RhbmNlIiwiY2hvb3NlIiwidGFyZ2V0IiwidmFsdWUiLCJ0b0JlQ2FsbGVkV2l0aCJdLCJtYXBwaW5ncyI6Ijs7Ozs7O0FBQUE7O0FBQ0E7O0FBQ0E7Ozs7OztBQUVBQSxRQUFRLENBQUMsT0FBRCxFQUFVLFlBQU07QUFDdEIsTUFBSUMsUUFBSjs7QUFDQSxNQUFNQyxPQUFPLEdBQUcsU0FBVkEsT0FBVSxDQUFDQyxNQUFELEVBQVk7QUFDMUIsUUFBTUMsUUFBUSxHQUFHO0FBQ2ZDLE1BQUFBLEdBQUcsRUFBRSxHQURVO0FBRWZKLE1BQUFBLFFBQVEsRUFBUkEsUUFGZTtBQUdmSyxNQUFBQSxPQUFPLEVBQUUsRUFITTtBQUlmQyxNQUFBQSxLQUFLLEVBQUUsQ0FBQyxPQUFELEVBQVUsT0FBVjtBQUpRLEtBQWpCOztBQU1BLFFBQU1DLEtBQUssbUNBQVFKLFFBQVIsR0FBcUJELE1BQXJCLENBQVg7O0FBQ0EsV0FBTyxtQ0FBUSxnQ0FBQyxlQUFELEVBQWNLLEtBQWQsQ0FBUixDQUFQO0FBQ0QsR0FURDs7QUFXQUMsRUFBQUEsVUFBVSxDQUFDLFlBQU07QUFDZlIsSUFBQUEsUUFBUSxHQUFHUyxJQUFJLENBQUNDLEVBQUwsRUFBWDtBQUNELEdBRlMsQ0FBVjtBQUlBWCxFQUFBQSxRQUFRLENBQUMsVUFBRCxFQUFhLFlBQU07QUFDekJZLElBQUFBLEVBQUUsQ0FBQyxTQUFELEVBQVksWUFBTTtBQUNsQkMsTUFBQUEsTUFBTSxDQUFDWCxPQUFPLEVBQVIsQ0FBTixDQUFrQlksZUFBbEI7QUFDRCxLQUZDLENBQUY7QUFHRCxHQUpPLENBQVI7QUFNQWQsRUFBQUEsUUFBUSxDQUFDLE9BQUQsRUFBVSxZQUFNO0FBQ3RCQSxJQUFBQSxRQUFRLENBQUMsUUFBRCxFQUFXLFlBQU07QUFDdkJZLE1BQUFBLEVBQUUsQ0FBQyxnQkFBRCxFQUFtQixZQUFNO0FBQ3pCLFlBQU1HLENBQUMsR0FBR2IsT0FBTyxFQUFqQjtBQUNBYSxRQUFBQSxDQUFDLENBQUNDLFFBQUYsR0FBYUMsTUFBYixDQUFvQjtBQUFFQyxVQUFBQSxNQUFNLEVBQUU7QUFBRUMsWUFBQUEsS0FBSyxFQUFFO0FBQVQ7QUFBVixTQUFwQjtBQUNBTixRQUFBQSxNQUFNLENBQUNaLFFBQUQsQ0FBTixDQUFpQm1CLGNBQWpCLENBQWdDLE9BQWhDO0FBQ0QsT0FKQyxDQUFGO0FBS0QsS0FOTyxDQUFSO0FBT0QsR0FSTyxDQUFSO0FBU0QsQ0FoQ08sQ0FBUiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IHNoYWxsb3cgfSBmcm9tICdlbnp5bWUnO1xuaW1wb3J0IFJlYWN0IGZyb20gJ3JlYWN0JztcbmltcG9ydCB7IFJhd0xhbmdzIH0gZnJvbSAnLi4vbGFuZ3MnO1xuXG5kZXNjcmliZSgnbGFuZ3MnLCAoKSA9PiB7XG4gIGxldCBvbkNoYW5nZTtcbiAgY29uc3Qgd3JhcHBlciA9IChleHRyYXMpID0+IHtcbiAgICBjb25zdCBkZWZhdWx0cyA9IHtcbiAgICAgIHVpZDogJzEnLFxuICAgICAgb25DaGFuZ2UsXG4gICAgICBjbGFzc2VzOiB7fSxcbiAgICAgIGxhbmdzOiBbJ2VuLVVTJywgJ2VzLUVTJ10sXG4gICAgfTtcbiAgICBjb25zdCBwcm9wcyA9IHsgLi4uZGVmYXVsdHMsIC4uLmV4dHJhcyB9O1xuICAgIHJldHVybiBzaGFsbG93KDxSYXdMYW5ncyB7Li4ucHJvcHN9IC8+KTtcbiAgfTtcblxuICBiZWZvcmVFYWNoKCgpID0+IHtcbiAgICBvbkNoYW5nZSA9IGplc3QuZm4oKTtcbiAgfSk7XG5cbiAgZGVzY3JpYmUoJ3NuYXBzaG90JywgKCkgPT4ge1xuICAgIGl0KCdyZW5kZXJzJywgKCkgPT4ge1xuICAgICAgZXhwZWN0KHdyYXBwZXIoKSkudG9NYXRjaFNuYXBzaG90KCk7XG4gICAgfSk7XG4gIH0pO1xuXG4gIGRlc2NyaWJlKCdsb2dpYycsICgpID0+IHtcbiAgICBkZXNjcmliZSgnY2hvb3NlJywgKCkgPT4ge1xuICAgICAgaXQoJ2NhbGxzIG9uQ2hhbmdlJywgKCkgPT4ge1xuICAgICAgICBjb25zdCB3ID0gd3JhcHBlcigpO1xuICAgICAgICB3Lmluc3RhbmNlKCkuY2hvb3NlKHsgdGFyZ2V0OiB7IHZhbHVlOiAnZW4tVVMnIH0gfSk7XG4gICAgICAgIGV4cGVjdChvbkNoYW5nZSkudG9CZUNhbGxlZFdpdGgoJ2VuLVVTJyk7XG4gICAgICB9KTtcbiAgICB9KTtcbiAgfSk7XG59KTtcbiJdfQ==
@@ -0,0 +1,128 @@
1
+ "use strict";
2
+
3
+ var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
4
+
5
+ var _react = _interopRequireDefault(require("react"));
6
+
7
+ var _enzyme = require("enzyme");
8
+
9
+ var _numberTextField = require("../number-text-field");
10
+
11
+ var _TextField = _interopRequireDefault(require("@material-ui/core/TextField"));
12
+
13
+ describe('NumberTextField', function () {
14
+ describe('render', function () {
15
+ var value = 1;
16
+ var onChange, component, textField, onBlur;
17
+ var min = 1;
18
+ var max = 10;
19
+ describe('TextField', function () {
20
+ beforeEach(function () {
21
+ onChange = jest.fn();
22
+ onBlur = jest.fn();
23
+ component = (0, _enzyme.shallow)( /*#__PURE__*/_react["default"].createElement(_numberTextField.NumberTextField, {
24
+ value: value,
25
+ min: min,
26
+ max: max,
27
+ classes: {},
28
+ onChange: onChange,
29
+ onBlur: onBlur
30
+ }));
31
+ textField = component.find(_TextField["default"]);
32
+ });
33
+ it('should render mui TextField', function () {
34
+ expect(textField.length).toEqual(1);
35
+ });
36
+ describe('props', function () {
37
+ var props;
38
+ beforeEach(function () {
39
+ props = textField.props();
40
+ });
41
+ it('should contain value', function () {
42
+ expect(props.value).toEqual(value);
43
+ });
44
+ });
45
+ describe('logic', function () {
46
+ describe('clamp', function () {
47
+ var assertClamp = function assertClamp(input, expected) {
48
+ it("".concat(input, " => ").concat(expected), function () {
49
+ var result = component.instance().clamp(input);
50
+ expect(result).toEqual(expected);
51
+ });
52
+ };
53
+
54
+ assertClamp('foo', 1);
55
+ assertClamp(1, 1);
56
+ assertClamp(2, 2);
57
+ assertClamp(0, 1);
58
+ assertClamp(-1, 1);
59
+ assertClamp(10, 10);
60
+ assertClamp(11, 10);
61
+ });
62
+ describe('onBlur', function () {
63
+ var event = function event(value) {
64
+ return {
65
+ target: {
66
+ value: value
67
+ }
68
+ };
69
+ };
70
+
71
+ describe('called with valid string representation of int', function () {
72
+ it('should be called with parsed int', function () {
73
+ var e = event('1');
74
+ textField.simulate('change', e);
75
+ expect(component.state('value')).toEqual('1');
76
+ e.target.value = '100';
77
+ textField.simulate('change', e);
78
+ expect(component.state('value')).toEqual('100');
79
+ var beforeMax = (max - 1).toString();
80
+ e.target.value = beforeMax;
81
+ textField.simulate('blur', e);
82
+ expect(component.state('value')).toEqual(beforeMax);
83
+ });
84
+ });
85
+ describe('called with invalid string representation of int', function () {
86
+ it('should be called with min value', function () {
87
+ var e = event('aa');
88
+ textField.simulate('change', e);
89
+ expect(component.state('value')).toEqual('aa');
90
+ textField.simulate('blur', e);
91
+ expect(component.state('value')).toEqual(min.toString());
92
+ });
93
+ });
94
+ describe('called with empty string', function () {
95
+ it('should be called with min value', function () {
96
+ var e = event('');
97
+ textField.simulate('change', e);
98
+ expect(component.state('value')).toEqual('');
99
+ textField.simulate('blur', e);
100
+ expect(component.state('value')).toEqual(min.toString());
101
+ });
102
+ });
103
+ describe('string int less than min', function () {
104
+ var value = (min - 1).toString();
105
+ it('should be called with value of min', function () {
106
+ var e = event(value);
107
+ textField.simulate('change', e);
108
+ expect(component.state('value')).toEqual(value);
109
+ textField.simulate('blur', e);
110
+ expect(component.state('value')).toEqual(min.toString());
111
+ });
112
+ });
113
+ describe('string int exceeds max', function () {
114
+ var value = (max + 1).toString();
115
+ it('should be called with value of max', function () {
116
+ var e = event(value);
117
+ textField.simulate('change', e);
118
+ expect(component.state('value')).toEqual(value);
119
+ textField.simulate('blur', e);
120
+ expect(component.state('value')).toEqual(max.toString());
121
+ });
122
+ });
123
+ });
124
+ });
125
+ });
126
+ });
127
+ });
128
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/__tests__/number-text-field.test.jsx"],"names":["describe","value","onChange","component","textField","onBlur","min","max","beforeEach","jest","fn","find","TextField","it","expect","length","toEqual","props","assertClamp","input","expected","result","instance","clamp","event","target","e","simulate","state","beforeMax","toString"],"mappings":"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","sourcesContent":["import React from 'react';\nimport { shallow } from 'enzyme';\nimport { NumberTextField } from '../number-text-field';\nimport TextField from '@material-ui/core/TextField';\n\ndescribe('NumberTextField', () => {\n  describe('render', () => {\n    let value = 1;\n    let onChange, component, textField, onBlur;\n    let min = 1;\n    let max = 10;\n\n    describe('TextField', () => {\n      beforeEach(() => {\n        onChange = jest.fn();\n        onBlur = jest.fn();\n        component = shallow(\n          <NumberTextField value={value} min={min} max={max} classes={{}} onChange={onChange} onBlur={onBlur} />,\n        );\n        textField = component.find(TextField);\n      });\n\n      it('should render mui TextField', () => {\n        expect(textField.length).toEqual(1);\n      });\n\n      describe('props', () => {\n        let props;\n\n        beforeEach(() => {\n          props = textField.props();\n        });\n\n        it('should contain value', () => {\n          expect(props.value).toEqual(value);\n        });\n      });\n\n      describe('logic', () => {\n        describe('clamp', () => {\n          const assertClamp = (input, expected) => {\n            it(`${input} => ${expected}`, () => {\n              const result = component.instance().clamp(input);\n              expect(result).toEqual(expected);\n            });\n          };\n\n          assertClamp('foo', 1);\n          assertClamp(1, 1);\n          assertClamp(2, 2);\n          assertClamp(0, 1);\n          assertClamp(-1, 1);\n          assertClamp(10, 10);\n          assertClamp(11, 10);\n        });\n\n        describe('onBlur', () => {\n          const event = (value) => ({\n            target: { value },\n          });\n\n          describe('called with valid string representation of int', () => {\n            it('should be called with parsed int', () => {\n              const e = event('1');\n\n              textField.simulate('change', e);\n\n              expect(component.state('value')).toEqual('1');\n\n              e.target.value = '100';\n\n              textField.simulate('change', e);\n\n              expect(component.state('value')).toEqual('100');\n\n              const beforeMax = (max - 1).toString();\n              e.target.value = beforeMax;\n\n              textField.simulate('blur', e);\n\n              expect(component.state('value')).toEqual(beforeMax);\n            });\n          });\n\n          describe('called with invalid string representation of int', () => {\n            it('should be called with min value', () => {\n              const e = event('aa');\n\n              textField.simulate('change', e);\n\n              expect(component.state('value')).toEqual('aa');\n\n              textField.simulate('blur', e);\n\n              expect(component.state('value')).toEqual(min.toString());\n            });\n          });\n\n          describe('called with empty string', () => {\n            it('should be called with min value', () => {\n              const e = event('');\n\n              textField.simulate('change', e);\n\n              expect(component.state('value')).toEqual('');\n\n              textField.simulate('blur', e);\n\n              expect(component.state('value')).toEqual(min.toString());\n            });\n          });\n\n          describe('string int less than min', () => {\n            const value = (min - 1).toString();\n\n            it('should be called with value of min', () => {\n              const e = event(value);\n\n              textField.simulate('change', e);\n\n              expect(component.state('value')).toEqual(value);\n\n              textField.simulate('blur', e);\n\n              expect(component.state('value')).toEqual(min.toString());\n            });\n          });\n\n          describe('string int exceeds max', () => {\n            const value = (max + 1).toString();\n\n            it('should be called with value of max', () => {\n              const e = event(value);\n\n              textField.simulate('change', e);\n\n              expect(component.state('value')).toEqual(value);\n\n              textField.simulate('blur', e);\n\n              expect(component.state('value')).toEqual(max.toString());\n            });\n          });\n        });\n      });\n    });\n  });\n});\n"]}
@@ -0,0 +1,201 @@
1
+ "use strict";
2
+
3
+ var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
4
+
5
+ var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty"));
6
+
7
+ var _extends2 = _interopRequireDefault(require("@babel/runtime/helpers/extends"));
8
+
9
+ var _react = _interopRequireDefault(require("react"));
10
+
11
+ var _enzyme = require("enzyme");
12
+
13
+ var _panel = require("../settings/panel");
14
+
15
+ var _settings = require("../settings");
16
+
17
+ 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; }
18
+
19
+ 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; }
20
+
21
+ describe('Settings Panel', function () {
22
+ var w;
23
+ var onChange = jest.fn();
24
+ var configure = {
25
+ orientationLabel: 'Orientation',
26
+ settingsOrientation: true,
27
+ editChoiceLabel: false
28
+ };
29
+ var model = {
30
+ choiceAreaLayout: 'vertical'
31
+ };
32
+
33
+ var groups = function groups(_ref) {
34
+ var configure = _ref.configure;
35
+ return {
36
+ 'Group 1': {
37
+ choiceAreaLayout: configure.settingsOrientation && {
38
+ type: 'radio',
39
+ label: configure.orientationLabel,
40
+ choices: [{
41
+ label: 'opt1',
42
+ value: 'opt1'
43
+ }, {
44
+ label: 'opt2',
45
+ value: 'opt2'
46
+ }],
47
+ equationEditor: (0, _settings.dropdown)('Dropdown', ['geometry', 'advanced-algebra', 'statistics', 'miscellaneous']),
48
+ graph: (0, _settings.numberFields)('Graph Display Size', {
49
+ domain: {
50
+ label: 'Domain',
51
+ suffix: 'px'
52
+ },
53
+ range: {
54
+ label: 'Range',
55
+ suffix: 'px'
56
+ },
57
+ width: {
58
+ label: 'Width',
59
+ suffix: 'px',
60
+ min: 50,
61
+ max: 250
62
+ }
63
+ })
64
+ },
65
+ editChoiceLabel: {
66
+ type: 'toggle',
67
+ label: 'Edit choice label',
68
+ isConfigProperty: true
69
+ }
70
+ }
71
+ };
72
+ };
73
+
74
+ var wrapper = function wrapper(extras) {
75
+ return (0, _enzyme.shallow)( /*#__PURE__*/_react["default"].createElement(_panel.Panel, (0, _extends2["default"])({
76
+ model: model,
77
+ configuration: configure,
78
+ onChangeModel: onChange,
79
+ onChangeConfiguration: onChange,
80
+ groups: groups({
81
+ configure: configure
82
+ })
83
+ }, extras)));
84
+ };
85
+
86
+ describe('snapshot', function () {
87
+ it('renders', function () {
88
+ w = wrapper();
89
+ expect(w).toMatchSnapshot();
90
+ });
91
+ it('does not render radio buttons', function () {
92
+ w = wrapper({
93
+ groups: groups({
94
+ configure: _objectSpread(_objectSpread({}, configure), {}, {
95
+ settingsOrientation: false
96
+ })
97
+ })
98
+ });
99
+ expect(w).toMatchSnapshot();
100
+ });
101
+ });
102
+ describe('logic', function () {
103
+ describe('onChange gets called', function () {
104
+ it('updates model props', function () {
105
+ w.instance().change('test', false);
106
+ expect(onChange).toBeCalledWith(_objectSpread(_objectSpread({}, model), {}, {
107
+ test: false
108
+ }), 'test');
109
+ });
110
+ it('updates configuration props', function () {
111
+ w.instance().change('test.test', true, true);
112
+ expect(onChange).toBeCalledWith(_objectSpread(_objectSpread({}, configure), {}, {
113
+ test: {
114
+ test: true
115
+ }
116
+ }), 'test.test');
117
+ });
118
+ });
119
+ });
120
+ });
121
+ describe('toggle', function () {
122
+ it('returns a toggle type object', function () {
123
+ var setting = (0, _settings.toggle)('Label');
124
+ expect(setting).toEqual({
125
+ label: 'Label',
126
+ type: 'toggle',
127
+ isConfigProperty: false,
128
+ disabled: false
129
+ });
130
+ });
131
+ });
132
+ describe('radio', function () {
133
+ it('returns a radio type object', function () {
134
+ var setting = (0, _settings.radio)('Radio', ['one', 'two']);
135
+ expect(setting).toEqual({
136
+ label: 'Radio',
137
+ type: 'radio',
138
+ isConfigProperty: false,
139
+ choices: [{
140
+ label: 'one',
141
+ value: 'one'
142
+ }, {
143
+ label: 'two',
144
+ value: 'two'
145
+ }]
146
+ });
147
+ });
148
+ });
149
+ describe('dropdown', function () {
150
+ it('returns a dropdown type object', function () {
151
+ var setting = (0, _settings.dropdown)('Dropdown', ['one', 'two']);
152
+ expect(setting).toEqual({
153
+ label: 'Dropdown',
154
+ type: 'dropdown',
155
+ isConfigProperty: false,
156
+ choices: ['one', 'two']
157
+ });
158
+ });
159
+ });
160
+ describe('numberField', function () {
161
+ it('returns a numberField type object', function () {
162
+ var setting = (0, _settings.numberField)('Number Field', {
163
+ max: 12
164
+ }, true);
165
+ expect(setting).toEqual({
166
+ label: 'Number Field',
167
+ type: 'numberField',
168
+ isConfigProperty: true,
169
+ max: 12
170
+ });
171
+ });
172
+ });
173
+ describe('numberFields', function () {
174
+ it('returns a numberFields type object', function () {
175
+ var setting = (0, _settings.numberFields)('Number Fields', {
176
+ one: {
177
+ label: 'One'
178
+ },
179
+ two: {
180
+ label: 'Two'
181
+ }
182
+ });
183
+ expect(setting).toEqual({
184
+ label: 'Number Fields',
185
+ type: 'numberFields',
186
+ fields: {
187
+ one: {
188
+ type: 'numberField',
189
+ label: 'One',
190
+ isConfigProperty: false
191
+ },
192
+ two: {
193
+ type: 'numberField',
194
+ label: 'Two',
195
+ isConfigProperty: false
196
+ }
197
+ }
198
+ });
199
+ });
200
+ });
201
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/__tests__/settings-panel.test.js"],"names":["describe","w","onChange","jest","fn","configure","orientationLabel","settingsOrientation","editChoiceLabel","model","choiceAreaLayout","groups","type","label","choices","value","equationEditor","graph","domain","suffix","range","width","min","max","isConfigProperty","wrapper","extras","it","expect","toMatchSnapshot","instance","change","toBeCalledWith","test","setting","toEqual","disabled","one","two","fields"],"mappings":"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","sourcesContent":["import React from 'react';\nimport { shallow } from 'enzyme';\nimport { Panel } from '../settings/panel';\nimport { toggle, radio, dropdown, numberField, numberFields } from '../settings';\n\ndescribe('Settings Panel', () => {\n  let w;\n  let onChange = jest.fn();\n  let configure = {\n    orientationLabel: 'Orientation',\n\n    settingsOrientation: true,\n    editChoiceLabel: false,\n  };\n  let model = {\n    choiceAreaLayout: 'vertical',\n  };\n\n  let groups = ({ configure }) => ({\n    'Group 1': {\n      choiceAreaLayout: configure.settingsOrientation && {\n        type: 'radio',\n        label: configure.orientationLabel,\n        choices: [\n          { label: 'opt1', value: 'opt1' },\n          { label: 'opt2', value: 'opt2' },\n        ],\n        equationEditor: dropdown('Dropdown', ['geometry', 'advanced-algebra', 'statistics', 'miscellaneous']),\n        graph: numberFields('Graph Display Size', {\n          domain: {\n            label: 'Domain',\n            suffix: 'px',\n          },\n          range: {\n            label: 'Range',\n            suffix: 'px',\n          },\n          width: {\n            label: 'Width',\n            suffix: 'px',\n            min: 50,\n            max: 250,\n          },\n        }),\n      },\n      editChoiceLabel: { type: 'toggle', label: 'Edit choice label', isConfigProperty: true },\n    },\n  });\n\n  const wrapper = (extras) => {\n    return shallow(\n      <Panel\n        model={model}\n        configuration={configure}\n        onChangeModel={onChange}\n        onChangeConfiguration={onChange}\n        groups={groups({ configure })}\n        {...extras}\n      />,\n    );\n  };\n\n  describe('snapshot', () => {\n    it('renders', () => {\n      w = wrapper();\n\n      expect(w).toMatchSnapshot();\n    });\n\n    it('does not render radio buttons', () => {\n      w = wrapper({\n        groups: groups({\n          configure: {\n            ...configure,\n            settingsOrientation: false,\n          },\n        }),\n      });\n\n      expect(w).toMatchSnapshot();\n    });\n  });\n\n  describe('logic', () => {\n    describe('onChange gets called', () => {\n      it('updates model props', () => {\n        w.instance().change('test', false);\n\n        expect(onChange).toBeCalledWith(\n          {\n            ...model,\n            test: false,\n          },\n          'test',\n        );\n      });\n\n      it('updates configuration props', () => {\n        w.instance().change('test.test', true, true);\n\n        expect(onChange).toBeCalledWith(\n          {\n            ...configure,\n            test: {\n              test: true,\n            },\n          },\n          'test.test',\n        );\n      });\n    });\n  });\n});\n\ndescribe('toggle', () => {\n  it('returns a toggle type object', () => {\n    const setting = toggle('Label');\n\n    expect(setting).toEqual({\n      label: 'Label',\n      type: 'toggle',\n      isConfigProperty: false,\n      disabled: false,\n    });\n  });\n});\n\ndescribe('radio', () => {\n  it('returns a radio type object', () => {\n    const setting = radio('Radio', ['one', 'two']);\n\n    expect(setting).toEqual({\n      label: 'Radio',\n      type: 'radio',\n      isConfigProperty: false,\n      choices: [\n        {\n          label: 'one',\n          value: 'one',\n        },\n        {\n          label: 'two',\n          value: 'two',\n        },\n      ],\n    });\n  });\n});\n\ndescribe('dropdown', () => {\n  it('returns a dropdown type object', () => {\n    const setting = dropdown('Dropdown', ['one', 'two']);\n\n    expect(setting).toEqual({\n      label: 'Dropdown',\n      type: 'dropdown',\n      isConfigProperty: false,\n      choices: ['one', 'two'],\n    });\n  });\n});\n\ndescribe('numberField', () => {\n  it('returns a numberField type object', () => {\n    const setting = numberField('Number Field', { max: 12 }, true);\n\n    expect(setting).toEqual({\n      label: 'Number Field',\n      type: 'numberField',\n      isConfigProperty: true,\n      max: 12,\n    });\n  });\n});\n\ndescribe('numberFields', () => {\n  it('returns a numberFields type object', () => {\n    const setting = numberFields('Number Fields', {\n      one: {\n        label: 'One',\n      },\n      two: {\n        label: 'Two',\n      },\n    });\n\n    expect(setting).toEqual({\n      label: 'Number Fields',\n      type: 'numberFields',\n      fields: {\n        one: {\n          type: 'numberField',\n          label: 'One',\n          isConfigProperty: false,\n        },\n        two: {\n          type: 'numberField',\n          label: 'Two',\n          isConfigProperty: false,\n        },\n      },\n    });\n  });\n});\n"]}
@@ -0,0 +1,33 @@
1
+ "use strict";
2
+
3
+ var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
4
+
5
+ var _react = _interopRequireDefault(require("react"));
6
+
7
+ var _reactTestRenderer = _interopRequireDefault(require("react-test-renderer"));
8
+
9
+ var _twoChoice = require("../two-choice");
10
+
11
+ describe('NChoice', function () {
12
+ it('renders n choice radio buttons vertical correctly', function () {
13
+ var tree = _reactTestRenderer["default"].create( /*#__PURE__*/_react["default"].createElement(_twoChoice.NChoice, {
14
+ direction: "vertical",
15
+ header: "n-choice-vertical",
16
+ value: 'left',
17
+ onChange: jest.fn(),
18
+ opts: [{
19
+ label: 'left',
20
+ value: 'left'
21
+ }, {
22
+ label: 'center',
23
+ value: 'center'
24
+ }, {
25
+ label: 'right',
26
+ value: 'right'
27
+ }]
28
+ })).toJSON();
29
+
30
+ expect(tree).toMatchSnapshot();
31
+ });
32
+ });
33
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9fX3Rlc3RzX18vdHdvLWNob2ljZS50ZXN0LmpzIl0sIm5hbWVzIjpbImRlc2NyaWJlIiwiaXQiLCJ0cmVlIiwicmVuZGVyZXIiLCJjcmVhdGUiLCJqZXN0IiwiZm4iLCJsYWJlbCIsInZhbHVlIiwidG9KU09OIiwiZXhwZWN0IiwidG9NYXRjaFNuYXBzaG90Il0sIm1hcHBpbmdzIjoiOzs7O0FBQUE7O0FBQ0E7O0FBQ0E7O0FBRUFBLFFBQVEsQ0FBQyxTQUFELEVBQVksWUFBTTtBQUN4QkMsRUFBQUEsRUFBRSxDQUFDLG1EQUFELEVBQXNELFlBQU07QUFDNUQsUUFBTUMsSUFBSSxHQUFHQyw4QkFDVkMsTUFEVSxlQUVULGdDQUFDLGtCQUFEO0FBQ0UsTUFBQSxTQUFTLEVBQUMsVUFEWjtBQUVFLE1BQUEsTUFBTSxFQUFDLG1CQUZUO0FBR0UsTUFBQSxLQUFLLEVBQUUsTUFIVDtBQUlFLE1BQUEsUUFBUSxFQUFFQyxJQUFJLENBQUNDLEVBQUwsRUFKWjtBQUtFLE1BQUEsSUFBSSxFQUFFLENBQ0o7QUFBRUMsUUFBQUEsS0FBSyxFQUFFLE1BQVQ7QUFBaUJDLFFBQUFBLEtBQUssRUFBRTtBQUF4QixPQURJLEVBRUo7QUFBRUQsUUFBQUEsS0FBSyxFQUFFLFFBQVQ7QUFBbUJDLFFBQUFBLEtBQUssRUFBRTtBQUExQixPQUZJLEVBR0o7QUFBRUQsUUFBQUEsS0FBSyxFQUFFLE9BQVQ7QUFBa0JDLFFBQUFBLEtBQUssRUFBRTtBQUF6QixPQUhJO0FBTFIsTUFGUyxFQWNWQyxNQWRVLEVBQWI7O0FBZUFDLElBQUFBLE1BQU0sQ0FBQ1IsSUFBRCxDQUFOLENBQWFTLGVBQWI7QUFDRCxHQWpCQyxDQUFGO0FBa0JELENBbkJPLENBQVIiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgUmVhY3QgZnJvbSAncmVhY3QnO1xuaW1wb3J0IHJlbmRlcmVyIGZyb20gJ3JlYWN0LXRlc3QtcmVuZGVyZXInO1xuaW1wb3J0IHsgTkNob2ljZSB9IGZyb20gJy4uL3R3by1jaG9pY2UnO1xuXG5kZXNjcmliZSgnTkNob2ljZScsICgpID0+IHtcbiAgaXQoJ3JlbmRlcnMgbiBjaG9pY2UgcmFkaW8gYnV0dG9ucyB2ZXJ0aWNhbCBjb3JyZWN0bHknLCAoKSA9PiB7XG4gICAgY29uc3QgdHJlZSA9IHJlbmRlcmVyXG4gICAgICAuY3JlYXRlKFxuICAgICAgICA8TkNob2ljZVxuICAgICAgICAgIGRpcmVjdGlvbj1cInZlcnRpY2FsXCJcbiAgICAgICAgICBoZWFkZXI9XCJuLWNob2ljZS12ZXJ0aWNhbFwiXG4gICAgICAgICAgdmFsdWU9eydsZWZ0J31cbiAgICAgICAgICBvbkNoYW5nZT17amVzdC5mbigpfVxuICAgICAgICAgIG9wdHM9e1tcbiAgICAgICAgICAgIHsgbGFiZWw6ICdsZWZ0JywgdmFsdWU6ICdsZWZ0JyB9LFxuICAgICAgICAgICAgeyBsYWJlbDogJ2NlbnRlcicsIHZhbHVlOiAnY2VudGVyJyB9LFxuICAgICAgICAgICAgeyBsYWJlbDogJ3JpZ2h0JywgdmFsdWU6ICdyaWdodCcgfSxcbiAgICAgICAgICBdfVxuICAgICAgICAvPixcbiAgICAgIClcbiAgICAgIC50b0pTT04oKTtcbiAgICBleHBlY3QodHJlZSkudG9NYXRjaFNuYXBzaG90KCk7XG4gIH0pO1xufSk7XG4iXX0=
@@ -1,44 +1,46 @@
1
1
  "use strict";
2
2
 
3
3
  var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
4
+
4
5
  Object.defineProperty(exports, "__esModule", {
5
6
  value: true
6
7
  });
7
8
  exports["default"] = void 0;
9
+
8
10
  var _react = _interopRequireDefault(require("react"));
11
+
9
12
  var _propTypes = _interopRequireDefault(require("prop-types"));
10
- var _material = require("@mui/material");
11
- var _styles = require("@mui/material/styles");
12
- var StyledDialogTitle = (0, _styles.styled)(_material.DialogTitle)(function () {
13
- return {
14
- fontSize: 'max(1.25rem, 18px)'
15
- };
16
- });
17
- var StyledDialogContentText = (0, _styles.styled)(_material.DialogContentText)(function () {
18
- return {
19
- fontSize: 'max(1rem, 14px)'
20
- };
21
- });
13
+
14
+ var _core = require("@material-ui/core");
15
+
16
+ var _styles = require("@material-ui/core/styles");
17
+
22
18
  var AlertDialog = function AlertDialog(_ref) {
23
19
  var text = _ref.text,
24
- title = _ref.title,
25
- onClose = _ref.onClose,
26
- onConfirm = _ref.onConfirm,
27
- open = _ref.open,
28
- onCloseText = _ref.onCloseText,
29
- onConfirmText = _ref.onConfirmText;
30
- return /*#__PURE__*/_react["default"].createElement(_material.Dialog, {
20
+ title = _ref.title,
21
+ onClose = _ref.onClose,
22
+ onConfirm = _ref.onConfirm,
23
+ open = _ref.open,
24
+ onCloseText = _ref.onCloseText,
25
+ onConfirmText = _ref.onConfirmText,
26
+ classes = _ref.classes;
27
+ return /*#__PURE__*/_react["default"].createElement(_core.Dialog, {
31
28
  open: open,
32
29
  onClose: onClose
33
- }, title && /*#__PURE__*/_react["default"].createElement(StyledDialogTitle, null, title), text && /*#__PURE__*/_react["default"].createElement(_material.DialogContent, null, /*#__PURE__*/_react["default"].createElement(StyledDialogContentText, null, text)), /*#__PURE__*/_react["default"].createElement(_material.DialogActions, null, onClose && /*#__PURE__*/_react["default"].createElement(_material.Button, {
30
+ }, title && /*#__PURE__*/_react["default"].createElement(_core.DialogTitle, {
31
+ className: classes.heading
32
+ }, title), text && /*#__PURE__*/_react["default"].createElement(_core.DialogContent, null, /*#__PURE__*/_react["default"].createElement(_core.DialogContentText, {
33
+ className: classes.subheading
34
+ }, text)), /*#__PURE__*/_react["default"].createElement(_core.DialogActions, null, onClose && /*#__PURE__*/_react["default"].createElement(_core.Button, {
34
35
  onClick: onClose,
35
36
  color: "primary"
36
- }, onCloseText), onConfirm && /*#__PURE__*/_react["default"].createElement(_material.Button, {
37
+ }, onCloseText), onConfirm && /*#__PURE__*/_react["default"].createElement(_core.Button, {
37
38
  autoFocus: true,
38
39
  onClick: onConfirm,
39
40
  color: "primary"
40
41
  }, onConfirmText)));
41
42
  };
43
+
42
44
  AlertDialog.defaultProps = {
43
45
  onCloseText: 'CANCEL',
44
46
  onConfirmText: 'OK'
@@ -50,7 +52,24 @@ AlertDialog.propTypes = {
50
52
  onConfirm: _propTypes["default"].func,
51
53
  open: _propTypes["default"].bool,
52
54
  onConfirmText: _propTypes["default"].string,
53
- onCloseText: _propTypes["default"].string
55
+ onCloseText: _propTypes["default"].string,
56
+ classes: _propTypes["default"].object
54
57
  };
55
- var _default = exports["default"] = AlertDialog;
58
+
59
+ var styles = function styles() {
60
+ return {
61
+ heading: {
62
+ '& h2': {
63
+ fontSize: 'max(1.25rem, 18px)'
64
+ }
65
+ },
66
+ subheading: {
67
+ fontSize: 'max(1rem, 14px)'
68
+ }
69
+ };
70
+ };
71
+
72
+ var _default = (0, _styles.withStyles)(styles)(AlertDialog);
73
+
74
+ exports["default"] = _default;
56
75
  //# sourceMappingURL=alert-dialog.js.map