@reltio/components 1.4.2051 → 1.4.2053

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 (171) hide show
  1. package/AttributeListItem/AttributeListItem.d.ts +1 -1
  2. package/ChartTooltip/ChartTooltip.js +3 -3
  3. package/ColumnsSettings/components/ColumnListItem/ColumnListItem.d.ts +11 -26
  4. package/ColumnsSettings/components/ColumnListItem/ColumnListItem.js +0 -14
  5. package/DropDownMenuButton/DropDownMenuButton.js +1 -1
  6. package/HOCs/withAsyncMount/withAsyncMount.test.js +52 -52
  7. package/IgnoreButton/IgnoreButton.spec.js +109 -20
  8. package/Image/Image.d.ts +1 -1
  9. package/Image/Image.js +8 -8
  10. package/Image/Image.test.js +46 -51
  11. package/ImageActionsOverlay/ImageActionsOverlay.js +2 -1
  12. package/ImageActionsOverlay/ImageActionsOverlay.test.js +207 -125
  13. package/ImageActionsOverlay/components/CheckedIcon/CheckedIcon.js +1 -1
  14. package/ImageAttributesGallery/ImageAttributesGallery.test.js +525 -281
  15. package/ImageAttributesLine/ImageAttributesLine.js +1 -1
  16. package/ImageAttributesLine/ImageAttributesLine.test.js +187 -193
  17. package/ImageAttributesLine/imageAttributeValues.test-data.d.ts +10 -0
  18. package/ImageAttributesLine/imageAttributeValues.test-data.js +22 -0
  19. package/ImageAttributesLineEditor/ImageAttributesLineEditor.test.js +315 -298
  20. package/ImageDetailsView/ImageDetailsView.test.js +529 -55
  21. package/ImageDetailsView/attributes.test-data.d.ts +4 -1
  22. package/ImageDetailsView/attributes.test-data.js +98 -1
  23. package/ImageDetailsView/components/ImageDetailsViewCarousel/ImageDetailsViewCarousel.js +2 -2
  24. package/ImageDetailsView/components/MetaInfoItem/MetaInfoItem.js +1 -1
  25. package/ImageDetailsView/components/MetaInfoList/MetaInfoList.js +1 -1
  26. package/ImageDetailsView/components/Thumbnails/Thumbnails.js +1 -1
  27. package/ImageDetailsView/helpers.test.js +4 -4
  28. package/ImageGalleryDialog/ImageGalleryDialog.test.js +89 -46
  29. package/ImportButton/ImportButton.test.js +94 -24
  30. package/InlineAttributesList/InlineAttributesList.test.js +22 -62
  31. package/InlineAttributesList/attributes.test-data.d.ts +4 -2
  32. package/InlineAttributesList/attributes.test-data.js +40 -1
  33. package/InlineAttributesPager/InlineAttributesPager.d.ts +1 -2
  34. package/InlineAttributesPager/InlineAttributesPager.js +1 -4
  35. package/InlineAttributesPager/InlineAttributesPager.test.js +393 -183
  36. package/InlineComplexAttribute/InlineComplexAttribute.js +1 -1
  37. package/InlineComplexAttribute/InlineComplexAttribute.test.js +396 -182
  38. package/InlineImageAttribute/InlineImageAttribute.test.js +103 -55
  39. package/InlineNestedAttribute/InlineNestedAttribute.test.js +105 -43
  40. package/InlineReferenceAttribute/InlineReferenceAttribute.test.js +165 -107
  41. package/InlineSimpleAttribute/InlineSimpleAttribute.spec.js +352 -346
  42. package/InlineSimpleAttributeEditor/InlineSimpleAttributeEditor.test.js +285 -194
  43. package/InternalLink/InternalLink.test.js +41 -11
  44. package/LookupEditor/LookupEditor.test.js +180 -44
  45. package/LookupEditor/components/GroupedDropDownEditor/helpers.test.js +1 -1
  46. package/MapChart/MapChart.js +3 -8
  47. package/MapChart/MapChart.test.js +152 -188
  48. package/MapChart/components/Legend/Legend.js +3 -3
  49. package/MaskingSwitcher/MaskingSwitcher.js +1 -1
  50. package/MatchRulesBadge/MatchRulesBadge.test.js +93 -24
  51. package/SelectEditor/SelectEditor.d.ts +4 -10
  52. package/SelectEditor/SelectEditor.js +0 -4
  53. package/SelectEditor/SelectEditor.test.js +79 -9
  54. package/cjs/AttributeListItem/AttributeListItem.d.ts +1 -1
  55. package/cjs/ChartTooltip/ChartTooltip.js +3 -3
  56. package/cjs/ColumnsSettings/components/ColumnListItem/ColumnListItem.d.ts +11 -26
  57. package/cjs/ColumnsSettings/components/ColumnListItem/ColumnListItem.js +0 -14
  58. package/cjs/DropDownMenuButton/DropDownMenuButton.js +1 -1
  59. package/cjs/HOCs/withAsyncMount/withAsyncMount.test.js +56 -56
  60. package/cjs/IgnoreButton/IgnoreButton.spec.js +109 -20
  61. package/cjs/Image/Image.d.ts +1 -1
  62. package/cjs/Image/Image.js +8 -8
  63. package/cjs/Image/Image.test.js +46 -51
  64. package/cjs/ImageActionsOverlay/ImageActionsOverlay.js +2 -1
  65. package/cjs/ImageActionsOverlay/ImageActionsOverlay.test.js +207 -125
  66. package/cjs/ImageActionsOverlay/components/CheckedIcon/CheckedIcon.js +1 -1
  67. package/cjs/ImageAttributesGallery/ImageAttributesGallery.test.js +525 -281
  68. package/cjs/ImageAttributesLine/ImageAttributesLine.js +1 -1
  69. package/cjs/ImageAttributesLine/ImageAttributesLine.test.js +195 -224
  70. package/cjs/ImageAttributesLine/imageAttributeValues.test-data.d.ts +10 -0
  71. package/cjs/ImageAttributesLine/imageAttributeValues.test-data.js +23 -1
  72. package/cjs/ImageAttributesLineEditor/ImageAttributesLineEditor.test.js +316 -299
  73. package/cjs/ImageDetailsView/ImageDetailsView.test.js +529 -55
  74. package/cjs/ImageDetailsView/attributes.test-data.d.ts +4 -1
  75. package/cjs/ImageDetailsView/attributes.test-data.js +99 -2
  76. package/cjs/ImageDetailsView/components/ImageDetailsViewCarousel/ImageDetailsViewCarousel.js +2 -2
  77. package/cjs/ImageDetailsView/components/MetaInfoItem/MetaInfoItem.js +1 -1
  78. package/cjs/ImageDetailsView/components/MetaInfoList/MetaInfoList.js +1 -1
  79. package/cjs/ImageDetailsView/components/Thumbnails/Thumbnails.js +1 -1
  80. package/cjs/ImageDetailsView/helpers.test.js +3 -3
  81. package/cjs/ImageGalleryDialog/ImageGalleryDialog.test.js +89 -46
  82. package/cjs/ImportButton/ImportButton.test.js +94 -24
  83. package/cjs/InlineAttributesList/InlineAttributesList.test.js +22 -62
  84. package/cjs/InlineAttributesList/attributes.test-data.d.ts +4 -2
  85. package/cjs/InlineAttributesList/attributes.test-data.js +41 -2
  86. package/cjs/InlineAttributesPager/InlineAttributesPager.d.ts +1 -2
  87. package/cjs/InlineAttributesPager/InlineAttributesPager.js +1 -4
  88. package/cjs/InlineAttributesPager/InlineAttributesPager.test.js +393 -183
  89. package/cjs/InlineComplexAttribute/InlineComplexAttribute.js +1 -1
  90. package/cjs/InlineComplexAttribute/InlineComplexAttribute.test.js +395 -204
  91. package/cjs/InlineImageAttribute/InlineImageAttribute.test.js +103 -55
  92. package/cjs/InlineNestedAttribute/InlineNestedAttribute.test.js +105 -43
  93. package/cjs/InlineReferenceAttribute/InlineReferenceAttribute.test.js +164 -106
  94. package/cjs/InlineSimpleAttribute/InlineSimpleAttribute.spec.js +351 -345
  95. package/cjs/InlineSimpleAttributeEditor/InlineSimpleAttributeEditor.test.js +307 -193
  96. package/cjs/InternalLink/InternalLink.test.js +40 -10
  97. package/cjs/LookupEditor/LookupEditor.test.js +178 -65
  98. package/cjs/LookupEditor/components/GroupedDropDownEditor/helpers.test.js +1 -1
  99. package/cjs/MapChart/MapChart.js +3 -8
  100. package/cjs/MapChart/MapChart.test.js +152 -188
  101. package/cjs/MapChart/components/Legend/Legend.js +3 -3
  102. package/cjs/MaskingSwitcher/MaskingSwitcher.js +1 -1
  103. package/cjs/MatchRulesBadge/MatchRulesBadge.test.js +93 -24
  104. package/cjs/SelectEditor/SelectEditor.d.ts +4 -10
  105. package/cjs/SelectEditor/SelectEditor.js +0 -4
  106. package/cjs/SelectEditor/SelectEditor.test.js +79 -9
  107. package/cjs/hooks/useAsyncMount/useAsyncMount.d.ts +1 -1
  108. package/cjs/hooks/useAsyncMount/useAsyncMount.js +1 -1
  109. package/hooks/useAsyncMount/useAsyncMount.d.ts +1 -1
  110. package/hooks/useAsyncMount/useAsyncMount.js +1 -1
  111. package/package.json +2 -2
  112. package/HOCs/withTableContext/withTableContext.test.d.ts +0 -1
  113. package/HOCs/withTableContext/withTableContext.test.js +0 -41
  114. package/ImageAttributesGallery/components/GalleryView/GalleryView.test.d.ts +0 -1
  115. package/ImageAttributesGallery/components/GalleryView/GalleryView.test.js +0 -98
  116. package/ImageDetailsView/components/ImageDetailsViewCarousel/ImageDetailsViewCarousel.test.d.ts +0 -1
  117. package/ImageDetailsView/components/ImageDetailsViewCarousel/ImageDetailsViewCarousel.test.js +0 -99
  118. package/ImageDetailsView/components/ImageDetailsViewSidebar/ImageDetailsViewSidebar.test.d.ts +0 -1
  119. package/ImageDetailsView/components/ImageDetailsViewSidebar/ImageDetailsViewSidebar.test.js +0 -65
  120. package/ImageDetailsView/components/MetaInfo/MetaInfo.test.d.ts +0 -1
  121. package/ImageDetailsView/components/MetaInfo/MetaInfo.test.js +0 -306
  122. package/ImageDetailsView/components/MetaInfoForm/MetaInfoForm.test.d.ts +0 -1
  123. package/ImageDetailsView/components/MetaInfoForm/MetaInfoForm.test.js +0 -134
  124. package/ImageDetailsView/components/MetaInfoHeader/MetaInfoHeader.test.d.ts +0 -1
  125. package/ImageDetailsView/components/MetaInfoHeader/MetaInfoHeader.test.js +0 -99
  126. package/ImageDetailsView/components/MetaInfoItem/MetaInfoItem.test.d.ts +0 -1
  127. package/ImageDetailsView/components/MetaInfoItem/MetaInfoItem.test.js +0 -36
  128. package/ImageDetailsView/components/MetaInfoList/MetaInfoList.test.d.ts +0 -1
  129. package/ImageDetailsView/components/MetaInfoList/MetaInfoList.test.js +0 -161
  130. package/ImageDetailsView/components/Thumbnails/Thumbnails.test.d.ts +0 -1
  131. package/ImageDetailsView/components/Thumbnails/Thumbnails.test.js +0 -76
  132. package/InlineAttributesPager/components/InlineImageAttributesBlock/InlineImageAttributesBlock.test.d.ts +0 -1
  133. package/InlineAttributesPager/components/InlineImageAttributesBlock/InlineImageAttributesBlock.test.js +0 -104
  134. package/InlineAttributesPager/components/InlineNestedAttributesBlock/InlineNestedAttributesBlock.test.d.ts +0 -1
  135. package/InlineAttributesPager/components/InlineNestedAttributesBlock/InlineNestedAttributesBlock.test.js +0 -114
  136. package/InlineAttributesPager/components/InlineReferenceAttributesBlock/InlineReferenceAttributesBlock.test.d.ts +0 -1
  137. package/InlineAttributesPager/components/InlineReferenceAttributesBlock/InlineReferenceAttributesBlock.test.js +0 -177
  138. package/InlineSimpleAttribute/components/CrosswalkMenuItem/CrosswalkMenuItem.spec.d.ts +0 -1
  139. package/InlineSimpleAttribute/components/CrosswalkMenuItem/CrosswalkMenuItem.spec.js +0 -52
  140. package/LookupEditor/components/GroupedDropDownEditor/GroupedDropDownEditor.test.d.ts +0 -1
  141. package/LookupEditor/components/GroupedDropDownEditor/GroupedDropDownEditor.test.js +0 -37
  142. package/cjs/HOCs/withTableContext/withTableContext.test.d.ts +0 -1
  143. package/cjs/HOCs/withTableContext/withTableContext.test.js +0 -46
  144. package/cjs/ImageAttributesGallery/components/GalleryView/GalleryView.test.d.ts +0 -1
  145. package/cjs/ImageAttributesGallery/components/GalleryView/GalleryView.test.js +0 -103
  146. package/cjs/ImageDetailsView/components/ImageDetailsViewCarousel/ImageDetailsViewCarousel.test.d.ts +0 -1
  147. package/cjs/ImageDetailsView/components/ImageDetailsViewCarousel/ImageDetailsViewCarousel.test.js +0 -104
  148. package/cjs/ImageDetailsView/components/ImageDetailsViewSidebar/ImageDetailsViewSidebar.test.d.ts +0 -1
  149. package/cjs/ImageDetailsView/components/ImageDetailsViewSidebar/ImageDetailsViewSidebar.test.js +0 -70
  150. package/cjs/ImageDetailsView/components/MetaInfo/MetaInfo.test.d.ts +0 -1
  151. package/cjs/ImageDetailsView/components/MetaInfo/MetaInfo.test.js +0 -311
  152. package/cjs/ImageDetailsView/components/MetaInfoForm/MetaInfoForm.test.d.ts +0 -1
  153. package/cjs/ImageDetailsView/components/MetaInfoForm/MetaInfoForm.test.js +0 -139
  154. package/cjs/ImageDetailsView/components/MetaInfoHeader/MetaInfoHeader.test.d.ts +0 -1
  155. package/cjs/ImageDetailsView/components/MetaInfoHeader/MetaInfoHeader.test.js +0 -104
  156. package/cjs/ImageDetailsView/components/MetaInfoItem/MetaInfoItem.test.d.ts +0 -1
  157. package/cjs/ImageDetailsView/components/MetaInfoItem/MetaInfoItem.test.js +0 -41
  158. package/cjs/ImageDetailsView/components/MetaInfoList/MetaInfoList.test.d.ts +0 -1
  159. package/cjs/ImageDetailsView/components/MetaInfoList/MetaInfoList.test.js +0 -166
  160. package/cjs/ImageDetailsView/components/Thumbnails/Thumbnails.test.d.ts +0 -1
  161. package/cjs/ImageDetailsView/components/Thumbnails/Thumbnails.test.js +0 -81
  162. package/cjs/InlineAttributesPager/components/InlineImageAttributesBlock/InlineImageAttributesBlock.test.d.ts +0 -1
  163. package/cjs/InlineAttributesPager/components/InlineImageAttributesBlock/InlineImageAttributesBlock.test.js +0 -109
  164. package/cjs/InlineAttributesPager/components/InlineNestedAttributesBlock/InlineNestedAttributesBlock.test.d.ts +0 -1
  165. package/cjs/InlineAttributesPager/components/InlineNestedAttributesBlock/InlineNestedAttributesBlock.test.js +0 -119
  166. package/cjs/InlineAttributesPager/components/InlineReferenceAttributesBlock/InlineReferenceAttributesBlock.test.d.ts +0 -1
  167. package/cjs/InlineAttributesPager/components/InlineReferenceAttributesBlock/InlineReferenceAttributesBlock.test.js +0 -182
  168. package/cjs/InlineSimpleAttribute/components/CrosswalkMenuItem/CrosswalkMenuItem.spec.d.ts +0 -1
  169. package/cjs/InlineSimpleAttribute/components/CrosswalkMenuItem/CrosswalkMenuItem.spec.js +0 -57
  170. package/cjs/LookupEditor/components/GroupedDropDownEditor/GroupedDropDownEditor.test.d.ts +0 -1
  171. package/cjs/LookupEditor/components/GroupedDropDownEditor/GroupedDropDownEditor.test.js +0 -42
@@ -1,13 +1,83 @@
1
+ var __assign = (this && this.__assign) || function () {
2
+ __assign = Object.assign || function(t) {
3
+ for (var s, i = 1, n = arguments.length; i < n; i++) {
4
+ s = arguments[i];
5
+ for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p))
6
+ t[p] = s[p];
7
+ }
8
+ return t;
9
+ };
10
+ return __assign.apply(this, arguments);
11
+ };
12
+ var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
13
+ function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
14
+ return new (P || (P = Promise))(function (resolve, reject) {
15
+ function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
16
+ function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
17
+ function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
18
+ step((generator = generator.apply(thisArg, _arguments || [])).next());
19
+ });
20
+ };
21
+ var __generator = (this && this.__generator) || function (thisArg, body) {
22
+ var _ = { label: 0, sent: function() { if (t[0] & 1) throw t[1]; return t[1]; }, trys: [], ops: [] }, f, y, t, g = Object.create((typeof Iterator === "function" ? Iterator : Object).prototype);
23
+ return g.next = verb(0), g["throw"] = verb(1), g["return"] = verb(2), typeof Symbol === "function" && (g[Symbol.iterator] = function() { return this; }), g;
24
+ function verb(n) { return function (v) { return step([n, v]); }; }
25
+ function step(op) {
26
+ if (f) throw new TypeError("Generator is already executing.");
27
+ while (g && (g = 0, op[0] && (_ = 0)), _) try {
28
+ if (f = 1, y && (t = op[0] & 2 ? y["return"] : op[0] ? y["throw"] || ((t = y["return"]) && t.call(y), 0) : y.next) && !(t = t.call(y, op[1])).done) return t;
29
+ if (y = 0, t) op = [op[0] & 2, t.value];
30
+ switch (op[0]) {
31
+ case 0: case 1: t = op; break;
32
+ case 4: _.label++; return { value: op[1], done: false };
33
+ case 5: _.label++; y = op[1]; op = [0]; continue;
34
+ case 7: op = _.ops.pop(); _.trys.pop(); continue;
35
+ default:
36
+ if (!(t = _.trys, t = t.length > 0 && t[t.length - 1]) && (op[0] === 6 || op[0] === 2)) { _ = 0; continue; }
37
+ if (op[0] === 3 && (!t || (op[1] > t[0] && op[1] < t[3]))) { _.label = op[1]; break; }
38
+ if (op[0] === 6 && _.label < t[1]) { _.label = t[1]; t = op; break; }
39
+ if (t && _.label < t[2]) { _.label = t[2]; _.ops.push(op); break; }
40
+ if (t[2]) _.ops.pop();
41
+ _.trys.pop(); continue;
42
+ }
43
+ op = body.call(thisArg, _);
44
+ } catch (e) { op = [6, e]; y = 0; } finally { f = t = 0; }
45
+ if (op[0] & 5) throw op[1]; return { value: op[0] ? op[1] : void 0, done: true };
46
+ }
47
+ };
1
48
  import React from 'react';
2
- import { shallow } from 'enzyme/build';
3
- import { DropDownEditor } from '../DropDownEditor';
49
+ import { render, screen } from '@testing-library/react';
50
+ import userEvent from '@testing-library/user-event';
4
51
  import { SelectEditor } from './SelectEditor';
5
52
  describe('SelectEditor', function () {
6
- it('should render DropDownEditor', function () {
7
- var entries = [{ value: 'String1' }, { value: 'String2' }, { value: 'String3' }], value = 'String2';
8
- var wrapper = shallow(React.createElement(SelectEditor, { value: value, entries: entries }));
9
- var dropDown = wrapper.find(DropDownEditor);
10
- expect(dropDown.prop('value')).toBe(value);
11
- expect(dropDown.prop('entries')).toEqual(entries);
12
- });
53
+ var defaultProps = {
54
+ value: 'String1',
55
+ classes: { root: 'customRoot' },
56
+ entries: [{ value: 'String1' }, { value: 'String2' }, { value: 'String3' }],
57
+ onChange: jest.fn()
58
+ };
59
+ it('should render DropDownEditor', function () { return __awaiter(void 0, void 0, void 0, function () {
60
+ var user, button;
61
+ return __generator(this, function (_a) {
62
+ switch (_a.label) {
63
+ case 0:
64
+ user = userEvent.setup();
65
+ render(React.createElement(SelectEditor, __assign({}, defaultProps)));
66
+ expect(screen.getByText('String1')).toBeInTheDocument();
67
+ expect(screen.queryByText('String2')).not.toBeInTheDocument();
68
+ button = screen.getByRole('button');
69
+ expect(button).toHaveClass('customRoot');
70
+ return [4 /*yield*/, user.click(button)];
71
+ case 1:
72
+ _a.sent();
73
+ expect(screen.getByText('String2')).toBeInTheDocument();
74
+ expect(screen.getByText('String3')).toBeInTheDocument();
75
+ return [4 /*yield*/, user.click(screen.getByText('String3'))];
76
+ case 2:
77
+ _a.sent();
78
+ expect(defaultProps.onChange).toHaveBeenCalledWith('String3');
79
+ return [2 /*return*/];
80
+ }
81
+ });
82
+ }); });
13
83
  });
@@ -6,7 +6,7 @@ export declare const RecommendedIconWithTooltip: React.ForwardRefExoticComponent
6
6
  tooltipPlacement?: import("@mui/material").TooltipProps["placement"];
7
7
  showForDisabled?: boolean;
8
8
  } & React.SVGProps<SVGSVGElement>, "ref"> & React.RefAttributes<HTMLElement>>;
9
- type Data = {
9
+ type Data = Record<string, unknown> & {
10
10
  attrType?: AttributeType;
11
11
  };
12
12
  type Props = {
@@ -15,11 +15,11 @@ var ChartTooltip = function (_a) {
15
15
  var localizedValue = (tooltipPayload === null || tooltipPayload === void 0 ? void 0 : tooltipPayload.localizedValue) || (tooltipPayload === null || tooltipPayload === void 0 ? void 0 : tooltipPayload.value);
16
16
  var tooltipLabel = tooltipPayload === null || tooltipPayload === void 0 ? void 0 : tooltipPayload.label;
17
17
  var percent = tooltipPayload === null || tooltipPayload === void 0 ? void 0 : tooltipPayload.percent;
18
- return (active && (react_1.default.createElement("div", { className: styles.tooltipWrapper },
18
+ return (active && (react_1.default.createElement("div", { "data-reltio-id": "chart-tooltip", className: styles.tooltipWrapper },
19
19
  react_1.default.createElement("p", { className: styles.tooltipTitle }, tooltipLabel),
20
- (0, ramda_1.isNil)(percent) ? (react_1.default.createElement("p", { className: styles.tooltipValue },
20
+ (0, ramda_1.isNil)(percent) ? (react_1.default.createElement("p", { "data-reltio-id": "chart-tooltip-value", className: styles.tooltipValue },
21
21
  "Value: ",
22
- localizedValue)) : (react_1.default.createElement("p", { className: styles.tooltipValueBold },
22
+ localizedValue)) : (react_1.default.createElement("p", { "data-reltio-id": "chart-tooltip-value", className: styles.tooltipValueBold },
23
23
  localizedValue,
24
24
  react_1.default.createElement("span", { className: styles.tooltipPercent },
25
25
  " (",
@@ -1,27 +1,12 @@
1
- export function ColumnListItem({ item, onClick, checked, level, style, isFocused, isGroupItem, hideCheckBox }: {
2
- item: any;
3
- onClick: any;
4
- checked: any;
5
- level: any;
6
- style: any;
7
- isFocused: any;
8
- isGroupItem: any;
9
- hideCheckBox: any;
10
- }): React.JSX.Element;
11
- export namespace ColumnListItem {
12
- namespace propTypes {
13
- let item: PropTypes.Requireable<PropTypes.InferProps<{
14
- label: PropTypes.Requireable<string>;
15
- filterText: PropTypes.Requireable<string>;
16
- }>>;
17
- let level: PropTypes.Requireable<number>;
18
- let onClick: PropTypes.Requireable<(...args: any[]) => any>;
19
- let checked: PropTypes.Requireable<boolean>;
20
- let style: PropTypes.Requireable<object>;
21
- let isGroupItem: PropTypes.Requireable<boolean>;
22
- let isFocused: PropTypes.Requireable<boolean>;
23
- let hideCheckBox: PropTypes.Requireable<boolean>;
24
- }
25
- }
26
1
  import React from 'react';
27
- import PropTypes from 'prop-types';
2
+ import { AttributeListItem } from '../../../AttributeListItem';
3
+ type Props = Pick<React.ComponentProps<typeof AttributeListItem>, 'hideCheckBox' | 'onClick' | 'checked' | 'level' | 'style' | 'isFocused'> & {
4
+ item: {
5
+ id: string;
6
+ label: string;
7
+ filterText?: string;
8
+ };
9
+ isGroupItem?: boolean;
10
+ };
11
+ export declare const ColumnListItem: ({ item, onClick, checked, level, style, isFocused, isGroupItem, hideCheckBox }: Props) => React.JSX.Element;
12
+ export {};
@@ -5,7 +5,6 @@ var __importDefault = (this && this.__importDefault) || function (mod) {
5
5
  Object.defineProperty(exports, "__esModule", { value: true });
6
6
  exports.ColumnListItem = void 0;
7
7
  var react_1 = __importDefault(require("react"));
8
- var prop_types_1 = __importDefault(require("prop-types"));
9
8
  var classnames_1 = __importDefault(require("classnames"));
10
9
  var AttributeListItem_1 = require("../../../AttributeListItem");
11
10
  var Highlighter_1 = require("../../../Highlighter");
@@ -17,16 +16,3 @@ var ColumnListItem = function (_a) {
17
16
  return (react_1.default.createElement(AttributeListItem_1.AttributeListItem, { hideCheckBox: hideCheckBox, key: item.id, onClick: onClick, checked: checked, level: level, data: item, label: react_1.default.createElement(Highlighter_1.Highlighter, { text: item.label, highlight: item.filterText }), labelInText: item.label, style: style, isFocused: isFocused, hideIcon: isGroupItem, className: (0, classnames_1.default)((_b = {}, _b[styles.groupItem] = isGroupItem, _b)) }));
18
17
  };
19
18
  exports.ColumnListItem = ColumnListItem;
20
- exports.ColumnListItem.propTypes = {
21
- item: prop_types_1.default.shape({
22
- label: prop_types_1.default.string,
23
- filterText: prop_types_1.default.string
24
- }),
25
- level: prop_types_1.default.number,
26
- onClick: prop_types_1.default.func,
27
- checked: prop_types_1.default.bool,
28
- style: prop_types_1.default.object,
29
- isGroupItem: prop_types_1.default.bool,
30
- isFocused: prop_types_1.default.bool,
31
- hideCheckBox: prop_types_1.default.bool
32
- };
@@ -69,7 +69,7 @@ function DropDownMenuButton(_a) {
69
69
  return react_1.default.createElement(MenuItemRenderer, { item: item, key: index, onMenuClose: handleToggle });
70
70
  };
71
71
  return (react_1.default.createElement(react_1.default.Fragment, null,
72
- react_1.default.createElement(ButtonComponent, __assign({ "data-reltio-id": 'drop-down-menu-button', ref: buttonRef, className: (0, classnames_1.default)(styles.buttonRoot, (_b = {},
72
+ react_1.default.createElement(ButtonComponent, __assign({ "data-reltio-id": "drop-down-menu-button", ref: buttonRef, className: (0, classnames_1.default)(styles.buttonRoot, (_b = {},
73
73
  _b[styles.selected] = isOpen,
74
74
  _b), className), onClick: handleToggle, "aria-pressed": isOpen, "aria-controls": isOpen ? menuId : undefined, "aria-haspopup": "true" }, buttonProps), buttonContent),
75
75
  react_1.default.createElement(Menu_1.default, __assign({ id: menuId, variant: "menu", open: isOpen, autoFocus: false, classes: { paper: styles.paper }, anchorEl: buttonRef.current, onClose: handleToggle, anchorOrigin: {
@@ -1,95 +1,95 @@
1
1
  "use strict";
2
+ var __assign = (this && this.__assign) || function () {
3
+ __assign = Object.assign || function(t) {
4
+ for (var s, i = 1, n = arguments.length; i < n; i++) {
5
+ s = arguments[i];
6
+ for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p))
7
+ t[p] = s[p];
8
+ }
9
+ return t;
10
+ };
11
+ return __assign.apply(this, arguments);
12
+ };
2
13
  var __importDefault = (this && this.__importDefault) || function (mod) {
3
14
  return (mod && mod.__esModule) ? mod : { "default": mod };
4
15
  };
5
16
  Object.defineProperty(exports, "__esModule", { value: true });
6
17
  var react_1 = __importDefault(require("react"));
7
- var enzyme_1 = require("enzyme");
8
- var test_utils_1 = require("react-dom/test-utils");
18
+ var react_2 = require("@testing-library/react");
9
19
  var AsyncMountContext_1 = require("../../contexts/AsyncMountContext");
10
20
  var withAsyncMount_1 = require("./withAsyncMount");
11
21
  describe('withAsyncMount tests', function () {
12
22
  beforeAll(function () {
13
23
  jest.useFakeTimers();
14
24
  });
25
+ var defaultContextValue = { enabled: true, queueSizeThreshold: 0 };
15
26
  var Component = function (_a) {
16
27
  var value = _a.value;
17
- return react_1.default.createElement("div", { "data-id": value });
18
- }; //eslint-disable-line
28
+ return react_1.default.createElement("div", { "data-reltio-id": value });
29
+ };
30
+ var Placeholder = function () { return react_1.default.createElement("span", { "data-reltio-id": "placeholder" }); };
31
+ var setUp = function (_a) {
32
+ var _b = _a === void 0 ? {} : _a, _c = _b.contextValue, contextValue = _c === void 0 ? {} : _c, _d = _b.withProvider, withProvider = _d === void 0 ? true : _d, _e = _b.withPlaceholder, withPlaceholder = _e === void 0 ? false : _e;
33
+ var Providers = function (_a) {
34
+ var children = _a.children;
35
+ return (react_1.default.createElement(AsyncMountContext_1.AsyncMountContext.Provider, { value: __assign(__assign({}, defaultContextValue), contextValue) }, children));
36
+ };
37
+ var AsyncMountedComponent = (0, withAsyncMount_1.withAsyncMount)(Component, withPlaceholder ? Placeholder : undefined);
38
+ return (0, react_2.render)(react_1.default.createElement(AsyncMountedComponent, { value: "test-value" }), { wrapper: withProvider ? Providers : undefined });
39
+ };
19
40
  it('should mount wrapped component in sync way without AsyncMountContext.Provider', function () {
20
- var AsyncMountedComponent = (0, withAsyncMount_1.withAsyncMount)(Component);
21
- var component = (0, enzyme_1.mount)(react_1.default.createElement(AsyncMountedComponent, { value: "123" }));
22
- expect(component.find(Component).exists()).toBe(true);
41
+ setUp({ withProvider: false });
42
+ expect(react_2.screen.getByTestId('test-value')).toBeInTheDocument();
23
43
  });
24
44
  it('should mount wrapped component in sync way with AsyncMountContext.Provider if value.enabled = false', function () {
25
- var AsyncMountedComponent = (0, withAsyncMount_1.withAsyncMount)(Component);
26
- var component = (0, enzyme_1.mount)(react_1.default.createElement(AsyncMountContext_1.AsyncMountContext.Provider, { value: { enabled: false, queueSizeThreshold: 0 } },
27
- react_1.default.createElement(AsyncMountedComponent, { value: "123" })));
28
- expect(component.find(Component).exists()).toBe(true);
45
+ setUp({ contextValue: { enabled: false } });
46
+ expect(react_2.screen.getByTestId('test-value')).toBeInTheDocument();
29
47
  });
30
48
  it('should mount wrapped component in async way with AsyncMountContext.Provider if value.enabled = true', function () {
31
- var AsyncMountedComponent = (0, withAsyncMount_1.withAsyncMount)(Component);
32
- var component = (0, enzyme_1.mount)(react_1.default.createElement(AsyncMountContext_1.AsyncMountContext.Provider, { value: { enabled: true, queueSizeThreshold: 0 } },
33
- react_1.default.createElement(AsyncMountedComponent, { value: "123" })));
34
- expect(component.find(Component).exists()).toBe(false);
35
- expect(component.isEmptyRender()).toBe(true);
36
- (0, test_utils_1.act)(function () {
49
+ setUp({ contextValue: { enabled: true } });
50
+ expect(react_2.screen.queryByTestId('test-value')).not.toBeInTheDocument();
51
+ (0, react_2.act)(function () {
37
52
  jest.runOnlyPendingTimers();
38
53
  });
39
- component.update();
40
- expect(component.find(Component).exists()).toBe(true);
41
- expect(component.find(Component).prop('value')).toBe('123');
42
- expect(component.isEmptyRender()).toBe(false);
54
+ expect(react_2.screen.getByTestId('test-value')).toBeInTheDocument();
43
55
  });
44
56
  it('should render PlaceholderComponent instead of Component before mounting if its passed as second argument', function () {
45
- var Placeholder = function () { return react_1.default.createElement("span", null); };
46
- var AsyncMountedComponent = (0, withAsyncMount_1.withAsyncMount)(Component, Placeholder);
47
- var component = (0, enzyme_1.mount)(react_1.default.createElement(AsyncMountContext_1.AsyncMountContext.Provider, { value: { enabled: true, queueSizeThreshold: 0 } },
48
- react_1.default.createElement(AsyncMountedComponent, { value: "123" })));
49
- expect(component.find(Component).exists()).toBe(false);
50
- expect(component.find(Placeholder).exists()).toBe(true);
51
- (0, test_utils_1.act)(function () {
57
+ setUp({ withPlaceholder: true });
58
+ expect(react_2.screen.queryByTestId('test-value')).not.toBeInTheDocument();
59
+ expect(react_2.screen.getByTestId('placeholder')).toBeInTheDocument();
60
+ (0, react_2.act)(function () {
52
61
  jest.runOnlyPendingTimers();
53
62
  });
54
- component.update();
55
- expect(component.find(Component).exists()).toBe(true);
56
- expect(component.find(Component).prop('value')).toBe('123');
57
- expect(component.find(Placeholder).exists()).toBe(false);
63
+ expect(react_2.screen.getByTestId('test-value')).toBeInTheDocument();
64
+ expect(react_2.screen.queryByTestId('placeholder')).not.toBeInTheDocument();
58
65
  });
59
66
  describe('queueSizeThreshold behavior', function () {
60
67
  it('should not use context value.queueSizeThreshold by default', function () {
61
68
  var AsyncMountedComponent = (0, withAsyncMount_1.withAsyncMount)(Component);
62
- var component = (0, enzyme_1.mount)(react_1.default.createElement(AsyncMountContext_1.AsyncMountContext.Provider, { value: { enabled: true, queueSizeThreshold: 0 } },
63
- react_1.default.createElement(AsyncMountedComponent, { value: "123" }),
64
- react_1.default.createElement(AsyncMountedComponent, { value: "123" })));
65
- expect(component.find(Component).length).toBe(0);
66
- (0, test_utils_1.act)(function () {
69
+ (0, react_2.render)(react_1.default.createElement(AsyncMountContext_1.AsyncMountContext.Provider, { value: { enabled: true, queueSizeThreshold: 0 } },
70
+ react_1.default.createElement(AsyncMountedComponent, { value: "test-value" }),
71
+ react_1.default.createElement(AsyncMountedComponent, { value: "test-value" })));
72
+ expect(react_2.screen.queryAllByTestId('test-value').length).toBe(0);
73
+ (0, react_2.act)(function () {
67
74
  jest.runOnlyPendingTimers();
68
75
  });
69
- component.update();
70
- expect(component.find(Component).length).toBe(2);
76
+ expect(react_2.screen.queryAllByTestId('test-value').length).toBe(2);
71
77
  });
72
78
  it('should use async mount only after exceeding of "value.queueSizeThreshold" number of component mounts', function () {
73
79
  var AsyncMountedComponent = (0, withAsyncMount_1.withAsyncMount)(Component);
74
- var component = (0, enzyme_1.mount)(react_1.default.createElement(AsyncMountContext_1.AsyncMountContext.Provider, { value: { enabled: true, queueSizeThreshold: 2 } },
75
- react_1.default.createElement(AsyncMountedComponent, { value: "123" }),
76
- react_1.default.createElement(AsyncMountedComponent, { value: "123" })));
77
- expect(component.find(Component).length).toBe(2);
78
- (0, test_utils_1.act)(function () {
79
- jest.runOnlyPendingTimers();
80
- });
81
- component.update();
82
- expect(component.find(Component).length).toBe(2);
83
- component = (0, enzyme_1.mount)(react_1.default.createElement(AsyncMountContext_1.AsyncMountContext.Provider, { value: { enabled: true, queueSizeThreshold: 2 } },
84
- react_1.default.createElement(AsyncMountedComponent, { value: "123" }),
85
- react_1.default.createElement(AsyncMountedComponent, { value: "123" }),
86
- react_1.default.createElement(AsyncMountedComponent, { value: "123" })));
87
- expect(component.find(Component).length).toBe(2);
88
- (0, test_utils_1.act)(function () {
80
+ var Providers = function (_a) {
81
+ var children = _a.children;
82
+ return (react_1.default.createElement(AsyncMountContext_1.AsyncMountContext.Provider, { value: { enabled: true, queueSizeThreshold: 2 } }, children));
83
+ };
84
+ (0, react_2.render)(react_1.default.createElement(react_1.default.Fragment, null,
85
+ react_1.default.createElement(AsyncMountedComponent, { value: "test-value" }),
86
+ react_1.default.createElement(AsyncMountedComponent, { value: "test-value" }),
87
+ react_1.default.createElement(AsyncMountedComponent, { value: "test-value" })), { wrapper: Providers });
88
+ expect(react_2.screen.queryAllByTestId('test-value').length).toBe(2);
89
+ (0, react_2.act)(function () {
89
90
  jest.runOnlyPendingTimers();
90
91
  });
91
- component.update();
92
- expect(component.find(Component).length).toBe(3);
92
+ expect(react_2.screen.queryAllByTestId('test-value').length).toBe(3);
93
93
  });
94
94
  });
95
95
  });
@@ -1,34 +1,123 @@
1
1
  "use strict";
2
+ var __assign = (this && this.__assign) || function () {
3
+ __assign = Object.assign || function(t) {
4
+ for (var s, i = 1, n = arguments.length; i < n; i++) {
5
+ s = arguments[i];
6
+ for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p))
7
+ t[p] = s[p];
8
+ }
9
+ return t;
10
+ };
11
+ return __assign.apply(this, arguments);
12
+ };
13
+ var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
14
+ function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
15
+ return new (P || (P = Promise))(function (resolve, reject) {
16
+ function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
17
+ function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
18
+ function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
19
+ step((generator = generator.apply(thisArg, _arguments || [])).next());
20
+ });
21
+ };
22
+ var __generator = (this && this.__generator) || function (thisArg, body) {
23
+ var _ = { label: 0, sent: function() { if (t[0] & 1) throw t[1]; return t[1]; }, trys: [], ops: [] }, f, y, t, g = Object.create((typeof Iterator === "function" ? Iterator : Object).prototype);
24
+ return g.next = verb(0), g["throw"] = verb(1), g["return"] = verb(2), typeof Symbol === "function" && (g[Symbol.iterator] = function() { return this; }), g;
25
+ function verb(n) { return function (v) { return step([n, v]); }; }
26
+ function step(op) {
27
+ if (f) throw new TypeError("Generator is already executing.");
28
+ while (g && (g = 0, op[0] && (_ = 0)), _) try {
29
+ if (f = 1, y && (t = op[0] & 2 ? y["return"] : op[0] ? y["throw"] || ((t = y["return"]) && t.call(y), 0) : y.next) && !(t = t.call(y, op[1])).done) return t;
30
+ if (y = 0, t) op = [op[0] & 2, t.value];
31
+ switch (op[0]) {
32
+ case 0: case 1: t = op; break;
33
+ case 4: _.label++; return { value: op[1], done: false };
34
+ case 5: _.label++; y = op[1]; op = [0]; continue;
35
+ case 7: op = _.ops.pop(); _.trys.pop(); continue;
36
+ default:
37
+ if (!(t = _.trys, t = t.length > 0 && t[t.length - 1]) && (op[0] === 6 || op[0] === 2)) { _ = 0; continue; }
38
+ if (op[0] === 3 && (!t || (op[1] > t[0] && op[1] < t[3]))) { _.label = op[1]; break; }
39
+ if (op[0] === 6 && _.label < t[1]) { _.label = t[1]; t = op; break; }
40
+ if (t && _.label < t[2]) { _.label = t[2]; _.ops.push(op); break; }
41
+ if (t[2]) _.ops.pop();
42
+ _.trys.pop(); continue;
43
+ }
44
+ op = body.call(thisArg, _);
45
+ } catch (e) { op = [6, e]; y = 0; } finally { f = t = 0; }
46
+ if (op[0] & 5) throw op[1]; return { value: op[0] ? op[1] : void 0, done: true };
47
+ }
48
+ };
2
49
  var __importDefault = (this && this.__importDefault) || function (mod) {
3
50
  return (mod && mod.__esModule) ? mod : { "default": mod };
4
51
  };
5
52
  Object.defineProperty(exports, "__esModule", { value: true });
6
53
  var react_1 = __importDefault(require("react"));
7
- var enzyme_1 = require("enzyme");
8
- var SmallIconButton_1 = require("../SmallIconButton");
9
- var Ignored_1 = __importDefault(require("../icons/Ignored"));
10
- var IgnoredOutlined_1 = __importDefault(require("../icons/IgnoredOutlined"));
54
+ var react_2 = require("@testing-library/react");
55
+ var user_event_1 = __importDefault(require("@testing-library/user-event"));
11
56
  var IgnoreButton_1 = require("./IgnoreButton");
12
57
  describe('Ignore button test', function () {
13
- var component, onClickFn;
14
- var getButton = function (component) { return component.find(SmallIconButton_1.SmallIconButtonWithTooltip); };
58
+ var onClickSpy = jest.fn();
15
59
  beforeEach(function () {
16
- onClickFn = jest.fn();
17
- component = (0, enzyme_1.mount)(react_1.default.createElement(IgnoreButton_1.IgnoreButton, { isIgnored: false, onClick: onClickFn }));
18
- });
19
- it('should pass button props correctly', function () {
20
- expect(getButton(component).prop('onClick')).toBe(onClickFn);
21
- component.setProps({ disabled: true });
22
- expect(getButton(component).prop('disabled')).toBe(true);
60
+ jest.clearAllMocks();
23
61
  });
62
+ var setUp = function (props) {
63
+ if (props === void 0) { props = {}; }
64
+ var user = user_event_1.default.setup();
65
+ (0, react_2.render)(react_1.default.createElement(IgnoreButton_1.IgnoreButton, __assign({ isIgnored: false, onClick: onClickSpy }, props)));
66
+ return { user: user };
67
+ };
68
+ it('should pass button props correctly', function () { return __awaiter(void 0, void 0, void 0, function () {
69
+ var user, button;
70
+ return __generator(this, function (_a) {
71
+ switch (_a.label) {
72
+ case 0:
73
+ user = setUp().user;
74
+ button = react_2.screen.getByRole('button');
75
+ expect(button).toBeEnabled();
76
+ return [4 /*yield*/, user.click(button)];
77
+ case 1:
78
+ _a.sent();
79
+ expect(onClickSpy).toHaveBeenCalledTimes(1);
80
+ return [2 /*return*/];
81
+ }
82
+ });
83
+ }); });
24
84
  it('should show correct icon', function () {
25
- expect(getButton(component).prop('icon')).toBe(IgnoredOutlined_1.default);
26
- component.setProps({ isIgnored: true });
27
- expect(getButton(component).prop('icon')).toBe(Ignored_1.default);
85
+ setUp();
86
+ expect(react_2.screen.getByTestId('SvgIgnoredOutlined')).toBeInTheDocument();
28
87
  });
29
- it('should show correct tooltip', function () {
30
- expect(getButton(component).prop('tooltipTitle')).toBe('Ignore');
31
- component.setProps({ disabled: true });
32
- expect(getButton(component).prop('tooltipTitle')).toBe("You don't have permissions to ignore");
88
+ it('should show correct icon when ignored', function () {
89
+ setUp({ isIgnored: true });
90
+ expect(react_2.screen.getByTestId('SvgIgnored')).toBeInTheDocument();
33
91
  });
92
+ it('should show correct tooltip', function () { return __awaiter(void 0, void 0, void 0, function () {
93
+ var user, button;
94
+ return __generator(this, function (_a) {
95
+ switch (_a.label) {
96
+ case 0:
97
+ user = setUp().user;
98
+ button = react_2.screen.getByRole('button');
99
+ return [4 /*yield*/, user.hover(button)];
100
+ case 1:
101
+ _a.sent();
102
+ expect(react_2.screen.getByText('Ignore')).toBeInTheDocument();
103
+ return [2 /*return*/];
104
+ }
105
+ });
106
+ }); });
107
+ it('should show correct tooltip when disabled', function () { return __awaiter(void 0, void 0, void 0, function () {
108
+ var user, button;
109
+ return __generator(this, function (_a) {
110
+ switch (_a.label) {
111
+ case 0:
112
+ user = setUp({ disabled: true }).user;
113
+ button = react_2.screen.getByRole('button');
114
+ return [4 /*yield*/, user.hover(button)];
115
+ case 1:
116
+ _a.sent();
117
+ expect(button).toBeDisabled();
118
+ expect(react_2.screen.getByText("You don't have permissions to ignore")).toBeInTheDocument();
119
+ return [2 /*return*/];
120
+ }
121
+ });
122
+ }); });
34
123
  });
@@ -8,5 +8,5 @@ type Props = {
8
8
  overlay?: React.ReactNode;
9
9
  onClick?: () => void;
10
10
  };
11
- declare const _default: React.MemoExoticComponent<(props: Props) => React.JSX.Element>;
11
+ declare const _default: React.MemoExoticComponent<({ src, className, containerClassName, size, overlay, ...otherProps }: Props) => React.JSX.Element>;
12
12
  export default _default;
@@ -56,12 +56,12 @@ var mdm_sdk_1 = require("@reltio/mdm-sdk");
56
56
  var constants_1 = require("./constants");
57
57
  var types_1 = require("../types");
58
58
  var styles_1 = require("./styles");
59
- var Image = function (props) {
60
- var _a;
61
- var src = props.src, className = props.className, containerClassName = props.containerClassName, _b = props.size, size = _b === void 0 ? constants_1.ImageSizesStyles.SMALL : _b, _c = props.overlay, overlay = _c === void 0 ? null : _c, otherProps = __rest(props, ["src", "className", "containerClassName", "size", "overlay"]);
59
+ var Image = function (_a) {
60
+ var _b;
61
+ var src = _a.src, className = _a.className, containerClassName = _a.containerClassName, _c = _a.size, size = _c === void 0 ? constants_1.ImageSizesStyles.SMALL : _c, _d = _a.overlay, overlay = _d === void 0 ? null : _d, otherProps = __rest(_a, ["src", "className", "containerClassName", "size", "overlay"]);
62
62
  var sizeStyles = size || constants_1.ImageSizesStyles.SMALL;
63
63
  var styles = (0, styles_1.useStyles)(sizeStyles);
64
- var _d = (0, react_1.useState)(types_1.RequestStates.LOADING), imageLoadingState = _d[0], setImageLoadingState = _d[1];
64
+ var _e = (0, react_1.useState)(types_1.RequestStates.LOADING), imageLoadingState = _e[0], setImageLoadingState = _e[1];
65
65
  (0, react_1.useEffect)(function () {
66
66
  setImageLoadingState(types_1.RequestStates.LOADING);
67
67
  }, [src]);
@@ -75,10 +75,10 @@ var Image = function (props) {
75
75
  var imageIsLoaded = imageLoadingState === types_1.RequestStates.LOADED;
76
76
  var imageLoadingError = imageLoadingState === types_1.RequestStates.ERROR;
77
77
  return imageLoadingError ? (react_1.default.createElement("div", __assign({ className: (0, classnames_1.default)(styles.defaultContainer, styles.image, className) }, otherProps),
78
- react_1.default.createElement(BrokenImage_1.default, { className: styles.defaultImage }))) : (react_1.default.createElement("div", { className: (0, classnames_1.default)(styles.root, containerClassName) },
79
- !(0, mdm_sdk_1.isEmptyValue)(src) && (react_1.default.createElement("img", __assign({ src: src, className: (0, classnames_1.default)(styles.image, className, (_a = {},
80
- _a[styles.hideImage] = imageIsLoading,
81
- _a)), onLoad: onImageLoad, onError: onImageLoadFail, alt: 'image' }, otherProps))),
78
+ react_1.default.createElement(BrokenImage_1.default, { "data-reltio-id": "not-available-image", className: styles.defaultImage }))) : (react_1.default.createElement("div", { className: (0, classnames_1.default)(styles.root, containerClassName) },
79
+ !(0, mdm_sdk_1.isEmptyValue)(src) && (react_1.default.createElement("img", __assign({ src: src, className: (0, classnames_1.default)(styles.image, className, (_b = {},
80
+ _b[styles.hideImage] = imageIsLoading,
81
+ _b)), onLoad: onImageLoad, onError: onImageLoadFail, alt: 'image' }, otherProps))),
82
82
  imageIsLoading && (react_1.default.createElement("div", __assign({ className: (0, classnames_1.default)(styles.defaultContainer, styles.image, className) }, otherProps),
83
83
  react_1.default.createElement(DefaultImage_1.default, { className: styles.defaultImage }))),
84
84
  imageIsLoaded && overlay));